{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "6b9e5763-9ac3-4b7d-a653-9d7c68c076e9",
   "metadata": {},
   "source": [
    "## Metric Computation for Linear Constraint Baselines (Table 1)\n",
    "\n",
    "This notebook evaluates models under **linear equality constraints** such as initial condition consistency and global conservation, as reported in **Table 1** of the main paper. It computes and logs relevant metrics for the following methods:\n",
    "\n",
    "- **ProbHardE2E-Ob**: Our proposed method using end-to-end oblique projection on the predicted mean during training and inference.\n",
    "- **ProbConserv**: Post-hoc projected mean using an oblique projection layer applied only at inference time.\n",
    "- **Unconstrained (VarianceNO)**: Baseline model trained and evaluated without any constraint enforcement.\n",
    "\n",
    "---\n",
    "\n",
    "## What This Notebook Does   \n",
    "\n",
    "Runs the all the cases listed above and computes the metrics such as MSE, CE, CRPS.\n",
    "\n",
    "### Usage\n",
    "\n",
    "To switch between methods or PDEs, set the appropriate values in the `args` dictionary. For example:\n",
    "\n",
    "```python\n",
    "args = {\n",
    " '--model': 'OutputVarFNO2d',\n",
    " '--dataset': 'HeatEquation_1D',     # or PME_1D, LinearAdvection_1D\n",
    " '--dataset_params': '1,5',\n",
    " '--predict_time': '0,-1,5',\n",
    " '--n_samples': '200',\n",
    " '--batch_size': '20',\n",
    "...\n",
    "}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "6b3ccdb8-4fd8-4224-b23e-979fa8228059",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = '2'\n",
    "\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from models.FNO2d import FNO2d\n",
    "from models.DiverseFNO2d import DiverseFNO2d\n",
    "from models.UncertainNO import *\n",
    "import utils\n",
    "from einops import rearrange, reduce, repeat\n",
    "import os\n",
    "from docopt import docopt\n",
    "import dill\n",
    "from datasets import *\n",
    "import probconserv\n",
    "import sys\n",
    "import torch.optim as optim\n",
    "\n",
    "# args = docopt(__doc__)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "5fdcc8cd-82d9-4cec-888d-806541259f2c",
   "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": 93,
   "id": "1d5eb530-ab43-4054-8953-9efdb86b3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "args = {'--batch_size': '20',\n",
    " '--dataset': 'StefanPME_1D',\n",
    " '--dataset_params': '0.6,0.65',\n",
    " '--epochs': '200',\n",
    " '--fno_modes': '12',\n",
    " '--fno_width': '32',\n",
    " '--grid_len': '100',\n",
    " '--lr': '1e-3',\n",
    " '--m.drop_prob': '0.1',\n",
    " '--m.n_models': '10',\n",
    " '--m.n_regularize': '5',\n",
    " '--m.reg_strength': '1',\n",
    " '--m.reg_type': 'weights_l2',\n",
    " '--model': 'OutputVarFNO2d',\n",
    " '--n_samples': '200',\n",
    " '--no_train': False,\n",
    " '--ood_dataset_params': None,\n",
    " '--predict_time': '0,-1,5',\n",
    " '--seed': '0',\n",
    " '--time_len': '100',\n",
    " '--tplot': '0.5',\n",
    " '--train_ood_dataset_params': '0.6,0.65'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "9ac91626-a64a-4ae2-ae5f-f63f492a7d4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\" \n",
    "experiment_name = \"trial\"\n",
    "# print(f\"Experiment: {experiment_name}\")\n",
    "# print(args)\n",
    "save_args = utils.filter_config(args, [\"generate\", \"--no_train\", \"--ood_dataset_params\", \"--tplot\"], mode=\"remove\")  # Also removes \".\" keys\n",
    "\n",
    "is_train = not bool(args[\"--no_train\"])\n",
    "\n",
    "# Parameters\n",
    "n_x = int(args[\"--grid_len\"])\n",
    "n_t = int(args[\"--time_len\"])\n",
    "n_samples = int(args[\"--n_samples\"])\n",
    "n_train = int(0.8 * n_samples)\n",
    "n_valid = int(0.2 * n_samples)\n",
    "n_test = n_samples // 2\n",
    "\n",
    "is_markov = False\n",
    "\n",
    "dataset = args[\"--dataset\"]\n",
    "dataset_params = [float(val) for val in args[\"--dataset_params\"].split(\",\")]\n",
    "train_ood_dataset_params = [float(val) for val in args[\"--train_ood_dataset_params\"].split(\",\")]\n",
    "ood_dataset_params = train_ood_dataset_params\n",
    "if not is_train:\n",
    "    ood_dataset_params = [float(val) for val in args[\"--ood_dataset_params\"].split(\",\")]\n",
    "\n",
    "tpred = [int(val) for val in args[\"--predict_time\"].split(\",\")]\n",
    "\n",
    "fno_modes = int(args[\"--fno_modes\"])\n",
    "fno_width = int(args[\"--fno_width\"])\n",
    "\n",
    "batch_size = int(args[\"--batch_size\"])\n",
    "lr = float(args[\"--lr\"])\n",
    "epochs = int(args[\"--epochs\"])\n",
    "step_size = 50\n",
    "gamma = 0.5\n",
    "# ################\n",
    "\n",
    "# Set seed\n",
    "utils.set_seed(int(args[\"--seed\"]))\n",
    "\n",
    "# Generate dataset\n",
    "if dataset.lower() == \"HeatEquation_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 2 * np.pi, n_x)\n",
    "    dataset_class = HeatEquation_1D\n",
    "elif dataset.lower() == \"PME_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = PME_1D\n",
    "elif dataset.lower() == \"StefanPME_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = StefanPME_1D\n",
    "elif dataset.lower() == \"LinearAdvection_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = LinearAdvection_1D\n",
    "else:\n",
    "    raise NotImplementedError\n",
    "\n",
    "t_sliced = t[slice(*tpred)]\n",
    "T = len(t_sliced)\n",
    "\n",
    "def get_xy_from_pu(p, u, is_markov=False):\n",
    "    T = u.shape[2]\n",
    "    #TODO: What does is_markov do here?\n",
    "    if is_markov:\n",
    "        x0, y0 = p, u\n",
    "        \n",
    "        y0_vectorized = rearrange(y0[:, :, 0:T-1], \"nf nx nt 1 -> (nf nt) nx 1\")\n",
    "        x0 = repeat(x0, \"nf nx 1 -> (nf nt) nx 1\", nt=T-1)\n",
    "        x = torch.cat([x0, y0_vectorized], dim=-1)\n",
    "        \n",
    "        y = rearrange(y0[:, :, 1:T], \"nf nx nt 1 -> (nf nt) nx 1\")\n",
    "    else:\n",
    "        x, y = p, u\n",
    "        x = repeat(x, \"nf nx 1 -> nf nx T 1\", T=T)\n",
    "    return x, y\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "b02f6033-3977-4d51-8f39-024a376dbabf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here 160\n",
      "torch.Size([160, 100, 1]) torch.Size([160, 100, 20, 1])\n",
      "torch.Size([160, 100, 20, 1]) torch.Size([160, 100, 20, 1])\n"
     ]
    }
   ],
   "source": [
    "if is_train:\n",
    "    # Train data\n",
    "    print(\"Here\", n_train)\n",
    "    a, u, p = dataset_class.generate_dataset(n_train, grid, t, tpred, *dataset_params)\n",
    "    print(a.shape, u.shape)\n",
    "    x_train, y_train = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Validation data\n",
    "    a, u, p = dataset_class.generate_dataset(n_valid, grid, t, tpred, *dataset_params)\n",
    "    x_valid, y_valid = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # In-distribution test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *dataset_params)\n",
    "    x_id_test, y_id_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Out-of-distribution inputs only\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *train_ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Data loaders\n",
    "    train_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_train, y_train), \n",
    "                                            batch_size=batch_size, shuffle=True)\n",
    "    valid_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_valid, y_valid), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    id_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_id_test, y_id_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "else:\n",
    "    # OOD test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "\n",
    "print(x_train.shape, y_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b64f1eeb-0e6e-4167-a082-5479ac453cb9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# tpred = torch.tensor(tpred).to(device), dataset_class = dataset_class, t=t.to(device), grid_train=grid.to(device))\n",
    "# stop = time.time()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2bbd9b90-2b82-439d-b7e1-a642fdd2d348",
   "metadata": {},
   "outputs": [],
   "source": [
    "constraint_context = {\n",
    "    \"t\": t.to(device),\n",
    "    \"tpred\": torch.tensor(tpred).to(device),\n",
    "    \"grid_train\": grid.to(device),\n",
    "    \"dataset_class\": dataset_class\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a7e5c61c-2b59-466f-9b4a-6157fa29ad4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=False, base_model_params=FNO2d_params, constraint_context=constraint_context)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4333d6f8-fe2c-4caa-a889-efae589c31ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "96aa9ee0-a30e-458b-85e2-5e7dbbd89dc4",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_true = torch.mean(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "fc1ac32d-6fb2-4293-8ea7-f90486a32dce",
   "metadata": {},
   "outputs": [],
   "source": [
    "var_true = torch.var(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f07c25ce-49e4-4331-81a3-ee678808a6b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100, 20, 1])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu_true.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "0f4d18b3-1988-4417-9122-3a8709048fc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.0000e+00, 2.1284e-04, 4.2556e-04, 6.3808e-04, 8.5027e-04, 1.0620e-03,\n",
      "        1.2733e-03, 1.4838e-03, 1.6937e-03, 1.9027e-03, 2.1107e-03, 2.3178e-03,\n",
      "        2.5236e-03, 2.7282e-03, 2.9315e-03, 3.1333e-03, 3.3337e-03, 3.5324e-03,\n",
      "        3.7294e-03, 3.9246e-03, 4.1180e-03, 4.3094e-03, 4.4988e-03, 4.6861e-03,\n",
      "        4.8712e-03, 5.0541e-03, 5.2348e-03, 5.4130e-03, 5.5889e-03, 5.7623e-03,\n",
      "        5.9331e-03, 2.7728e-01, 3.0200e-01, 1.1456e-01, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00])\n"
     ]
    },
    {
     "data": {
      "image/png": "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iPj4ePHll18alDl27Jj4+9//LgIDA4VCoRCNGzcWgwcPFrt377Zwpkwf44ULF8STTz4p/Pz8hFKpFPHx8WLbtm1G63z379aUixcvitmzZ4sHHnhAhISECDc3NxEcHCwGDBgg9uzZY1DW3OtbiMopJeLi4oSHh4fw9vYWbdu2Fa+88oq4fv26voypqQO+/fZb0a5dO6FUKkVUVJR4++23xapVqwQAkZ6eri9n6rVp7d/43cy95u5k69QBtn486/7Wjd3u/JvW/a3qbnK5XISFhYmHH35YfPDBB0KlUtn0vPcKiRAOHu1K5AIGDRqEP/74Q39lEhER3bs4ZonueSUlJQY/nzt3Dtu3bze5ajcREd1b2LJE97zw8HCMGjUK0dHRuHz5MpYtWwa1Wo1jx45VmR+IiKi2aDQaiwP6vby8amUqiXsdB3jTPa9v37748ssvkZWVBYVCgc6dO2PBggUMSkRUpzIyMixODpqcnGwwiJ5qBluWiIiI6qHS0lKLKxxER0fbfbUqWY9hiYiIiMgMDvAmIiIiMoNjlhxAq9Xi+vXr8Pb2rpFlOYiIiMjxhBAoKChARESE2YlZGZYc4Pr161VWmCciIiLnkJGRgUaNGpm8n2HJAby9vQFUnmwfH586rg0RERFZQ6VSITIyUv85bgrDkgPout58fHwYloiIiJyMpSE0HOBNREREZAbDEhEREZEZDEtEREREZjAsEREREZnBsERERERkBsMSERERkRkMS0RERERmMCwRERERmcGwRERERGQGwxIRERGRGQxLRERERGYwLBERERGZwbBEREREZAbDEhEREZEZDEtELkZdoanrKhARuRSGJSIXU1LGsERE5EgMS0QupohhiYjIoZwqLO3btw8DBw5EREQEJBIJtm7darb8li1b8PDDDyM4OBg+Pj7o3LkzfvzxR4Myc+bMgUQiMbjFxsbW4FEQ1axidUVdV4GIyKU4VVgqKirC/fffj6VLl1pVft++fXj44Yexfft2HDlyBA899BAGDhyIY8eOGZRr3bo1MjMz9bf9+/fXRPWJakWZRouyCm1dV4OIyGW41XUFbNGvXz/069fP6vKLFy82+HnBggX45ptv8N1336FDhw767W5ubggLC3NUNYnqlBBAaYUGcjen+i5ERFRv3VPvplqtFgUFBQgICDDYfu7cOURERCA6OhrDhw/HlStX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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 2\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Plotting mean and variance for {dataset}\".format(k = np.mean(dataset_params), dataset = dataset))\n",
    "    plt.xlabel(\"x\")\n",
    "    mu =  mu_true[:,t_idx,:].squeeze(-1)\n",
    "    plt.plot(grid, mu)\n",
    "    std = torch.sqrt(var_true[:,t_idx,:]).squeeze(-1)\n",
    "    print(std)\n",
    "    plt.fill_between(grid, mu + 3*std, mu - 3*std, alpha = 0.2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ac0b8967",
   "metadata": {},
   "source": [
    "## Running VarianceNO out of the box"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "6fd587e6-4cf8-4cc4-92bd-ac09c7be790a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function datasets.StefanPME_1D.get_mass_rhs_func.<locals>.mass_rhs_func(inputs)>"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func(x=x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "385681cf-a2fa-4ba9-8a9b-462fabb915ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "x_train_reshaped = rearrange(x_train, \" nf nx nt 1 -> nf (nx nt)\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b339b6e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f3073741-14be-4b35-b8cc-30ed22fbc4bc",
   "metadata": {},
   "outputs": [],
   "source": [
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d71ec298-4bbc-4186-a938-8675f0526890",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "87e15df0-69a3-4d0e-82f0-f04540d1a1e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0101, 0.0202, 0.0303, 0.0404, 0.0505, 0.0606, 0.0707, 0.0808,\n",
       "        0.0909, 0.1010, 0.1111, 0.1212, 0.1313, 0.1414, 0.1515, 0.1616, 0.1717,\n",
       "        0.1818, 0.1919, 0.2020, 0.2121, 0.2222, 0.2323, 0.2424, 0.2525, 0.2626,\n",
       "        0.2727, 0.2828, 0.2929, 0.3030, 0.3131, 0.3232, 0.3333, 0.3434, 0.3535,\n",
       "        0.3636, 0.3737, 0.3838, 0.3939, 0.4040, 0.4141, 0.4242, 0.4343, 0.4444,\n",
       "        0.4545, 0.4646, 0.4747, 0.4848, 0.4949, 0.5051, 0.5152, 0.5253, 0.5354,\n",
       "        0.5455, 0.5556, 0.5657, 0.5758, 0.5859, 0.5960, 0.6061, 0.6162, 0.6263,\n",
       "        0.6364, 0.6465, 0.6566, 0.6667, 0.6768, 0.6869, 0.6970, 0.7071, 0.7172,\n",
       "        0.7273, 0.7374, 0.7475, 0.7576, 0.7677, 0.7778, 0.7879, 0.7980, 0.8081,\n",
       "        0.8182, 0.8283, 0.8384, 0.8485, 0.8586, 0.8687, 0.8788, 0.8889, 0.8990,\n",
       "        0.9091, 0.9192, 0.9293, 0.9394, 0.9495, 0.9596, 0.9697, 0.9798, 0.9899,\n",
       "        1.0000])"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "2165975d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, -1, 5]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tpred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1ad2c532",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0, -1,  5])"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.tensor(tpred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "18a1c208-a4df-4f27-8dad-f2466164e855",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "6ff40f4d-d8b7-45f7-8e3a-8115564540df",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=0.319329, Validation loss=0.280639 (saved)\n",
      "Epoch 1: Train loss=0.253436, Validation loss=0.227272 (saved)\n",
      "Epoch 2: Train loss=0.204412, Validation loss=0.178092 (saved)\n",
      "Epoch 3: Train loss=0.169371, Validation loss=0.157141 (saved)\n",
      "Epoch 4: Train loss=0.147764, Validation loss=0.133057 (saved)\n",
      "Epoch 5: Train loss=0.116245, Validation loss=0.088435 (saved)\n",
      "Epoch 6: Train loss=0.065839, Validation loss=0.054081 (saved)\n",
      "Epoch 7: Train loss=0.042999, Validation loss=0.040795 (saved)\n",
      "Epoch 8: Train loss=0.038802, Validation loss=0.031297 (saved)\n",
      "Epoch 9: Train loss=0.029257, Validation loss=0.027983 (saved)\n",
      "Epoch 10: Train loss=0.024853, Validation loss=0.022973 (saved)\n",
      "Epoch 11: Train loss=0.021270, Validation loss=0.019798 (saved)\n",
      "Epoch 12: Train loss=0.018513, Validation loss=0.016497 (saved)\n",
      "Epoch 13: Train loss=0.017514, Validation loss=0.021413 \n",
      "Epoch 14: Train loss=0.018660, Validation loss=0.019557 \n",
      "Epoch 15: Train loss=0.016260, Validation loss=0.014094 (saved)\n",
      "Epoch 16: Train loss=0.015307, Validation loss=0.012963 (saved)\n",
      "Epoch 17: Train loss=0.015038, Validation loss=0.016119 \n",
      "Epoch 18: Train loss=0.015560, Validation loss=0.012431 (saved)\n",
      "Epoch 19: Train loss=0.015546, Validation loss=0.012652 \n",
      "Epoch 20: Train loss=0.013482, Validation loss=0.012401 (saved)\n",
      "Epoch 21: Train loss=0.014541, Validation loss=0.014634 \n",
      "Epoch 22: Train loss=0.014413, Validation loss=0.014008 \n",
      "Epoch 23: Train loss=0.014136, Validation loss=0.011987 (saved)\n",
      "Epoch 24: Train loss=0.012018, Validation loss=0.015338 \n",
      "Epoch 25: Train loss=0.015609, Validation loss=0.013673 \n",
      "Epoch 26: Train loss=0.012469, Validation loss=0.012099 \n",
      "Epoch 27: Train loss=0.014450, Validation loss=0.011229 (saved)\n",
      "Epoch 28: Train loss=0.013003, Validation loss=0.011331 \n",
      "Epoch 29: Train loss=0.013219, Validation loss=0.012060 \n",
      "Epoch 30: Train loss=0.013517, Validation loss=0.011823 \n",
      "Epoch 31: Train loss=0.013087, Validation loss=0.011896 \n",
      "Epoch 32: Train loss=0.012988, Validation loss=0.011156 (saved)\n",
      "Epoch 33: Train loss=0.012744, Validation loss=0.012801 \n",
      "Epoch 34: Train loss=0.012858, Validation loss=0.011134 (saved)\n",
      "Epoch 35: Train loss=0.013039, Validation loss=0.011829 \n",
      "Epoch 36: Train loss=0.013041, Validation loss=0.012895 \n",
      "Epoch 37: Train loss=0.012621, Validation loss=0.011942 \n",
      "Epoch 38: Train loss=0.013083, Validation loss=0.013173 \n",
      "Epoch 39: Train loss=0.012571, Validation loss=0.012731 \n",
      "Epoch 40: Train loss=0.012756, Validation loss=0.012274 \n",
      "Epoch 41: Train loss=0.011783, Validation loss=0.013834 \n",
      "Epoch 42: Train loss=0.012251, Validation loss=0.012386 \n",
      "Epoch 43: Train loss=0.013498, Validation loss=0.013577 \n",
      "Epoch 44: Train loss=0.012888, Validation loss=0.012255 \n",
      "Epoch 45: Train loss=0.011948, Validation loss=0.010519 (saved)\n",
      "Epoch 46: Train loss=0.011914, Validation loss=0.012432 \n",
      "Epoch 47: Train loss=0.012457, Validation loss=0.010584 \n",
      "Epoch 48: Train loss=0.011806, Validation loss=0.011542 \n",
      "Epoch 49: Train loss=0.012246, Validation loss=0.011733 \n",
      "Epoch 50: Train loss=0.011132, Validation loss=0.011321 \n",
      "Epoch 51: Train loss=0.010793, Validation loss=0.010055 (saved)\n",
      "Epoch 52: Train loss=0.010522, Validation loss=0.010105 \n",
      "Epoch 53: Train loss=0.010241, Validation loss=0.010019 (saved)\n",
      "Epoch 54: Train loss=0.010542, Validation loss=0.011044 \n",
      "Epoch 55: Train loss=0.010403, Validation loss=0.010801 \n",
      "Epoch 56: Train loss=0.010492, Validation loss=0.009560 (saved)\n",
      "Epoch 57: Train loss=0.010457, Validation loss=0.010010 \n",
      "Epoch 58: Train loss=0.010683, Validation loss=0.010033 \n",
      "Epoch 59: Train loss=0.010845, Validation loss=0.012715 \n",
      "Epoch 60: Train loss=0.010570, Validation loss=0.010839 \n",
      "Epoch 61: Train loss=0.010556, Validation loss=0.009506 (saved)\n",
      "Epoch 62: Train loss=0.010982, Validation loss=0.009999 \n",
      "Epoch 63: Train loss=0.010625, Validation loss=0.009638 \n",
      "Epoch 64: Train loss=0.011165, Validation loss=0.009576 \n",
      "Epoch 65: Train loss=0.010323, Validation loss=0.009585 \n",
      "Epoch 66: Train loss=0.009870, Validation loss=0.009584 \n",
      "Epoch 67: Train loss=0.010674, Validation loss=0.009422 (saved)\n",
      "Epoch 68: Train loss=0.010756, Validation loss=0.010373 \n",
      "Epoch 69: Train loss=0.011028, Validation loss=0.010252 \n",
      "Epoch 70: Train loss=0.010489, Validation loss=0.009497 \n",
      "Epoch 71: Train loss=0.010644, Validation loss=0.009537 \n",
      "Epoch 72: Train loss=0.010332, Validation loss=0.011844 \n",
      "Epoch 73: Train loss=0.010545, Validation loss=0.010417 \n",
      "Epoch 74: Train loss=0.011340, Validation loss=0.010284 \n",
      "Epoch 75: Train loss=0.011392, Validation loss=0.012148 \n",
      "Epoch 76: Train loss=0.011347, Validation loss=0.009902 \n",
      "Epoch 77: Train loss=0.010600, Validation loss=0.012182 \n",
      "Epoch 78: Train loss=0.011225, Validation loss=0.010148 \n",
      "Epoch 79: Train loss=0.010424, Validation loss=0.009799 \n",
      "Epoch 80: Train loss=0.010217, Validation loss=0.010090 \n",
      "Epoch 81: Train loss=0.010772, Validation loss=0.009609 \n",
      "Epoch 82: Train loss=0.010879, Validation loss=0.012793 \n",
      "Epoch 83: Train loss=0.011174, Validation loss=0.009917 \n",
      "Epoch 84: Train loss=0.010058, Validation loss=0.009896 \n",
      "Epoch 85: Train loss=0.010424, Validation loss=0.012950 \n",
      "Epoch 86: Train loss=0.011212, Validation loss=0.009748 \n",
      "Epoch 87: Train loss=0.010960, Validation loss=0.010778 \n",
      "Epoch 88: Train loss=0.011499, Validation loss=0.011755 \n",
      "Epoch 89: Train loss=0.011427, Validation loss=0.009684 \n",
      "Epoch 90: Train loss=0.011031, Validation loss=0.010657 \n",
      "Epoch 91: Train loss=0.010896, Validation loss=0.010032 \n",
      "Epoch 92: Train loss=0.010613, Validation loss=0.010002 \n",
      "Epoch 93: Train loss=0.010150, Validation loss=0.010004 \n",
      "Epoch 94: Train loss=0.010209, Validation loss=0.010301 \n",
      "Epoch 95: Train loss=0.010921, Validation loss=0.009658 \n",
      "Epoch 96: Train loss=0.011829, Validation loss=0.009730 \n",
      "Epoch 97: Train loss=0.010229, Validation loss=0.010107 \n",
      "Epoch 98: Train loss=0.011018, Validation loss=0.009543 \n",
      "Epoch 99: Train loss=0.010913, Validation loss=0.011202 \n",
      "Epoch 100: Train loss=0.010470, Validation loss=0.009445 \n",
      "Epoch 101: Train loss=0.010186, Validation loss=0.009576 \n",
      "Epoch 102: Train loss=0.010158, Validation loss=0.010181 \n",
      "Epoch 103: Train loss=0.009955, Validation loss=0.009663 \n",
      "Epoch 104: Train loss=0.009787, Validation loss=0.009634 \n",
      "Epoch 105: Train loss=0.009882, Validation loss=0.009947 \n",
      "Epoch 106: Train loss=0.009853, Validation loss=0.009565 \n",
      "Epoch 107: Train loss=0.009696, Validation loss=0.009155 (saved)\n",
      "Epoch 108: Train loss=0.009544, Validation loss=0.009142 (saved)\n",
      "Epoch 109: Train loss=0.009634, Validation loss=0.009472 \n",
      "Epoch 110: Train loss=0.009586, Validation loss=0.009077 (saved)\n",
      "Epoch 111: Train loss=0.009476, Validation loss=0.009505 \n",
      "Epoch 112: Train loss=0.009635, Validation loss=0.009090 \n",
      "Epoch 113: Train loss=0.009490, Validation loss=0.009272 \n",
      "Epoch 114: Train loss=0.009817, Validation loss=0.009203 \n",
      "Epoch 115: Train loss=0.010214, Validation loss=0.010748 \n",
      "Epoch 116: Train loss=0.010210, Validation loss=0.009441 \n",
      "Epoch 117: Train loss=0.009761, Validation loss=0.009093 \n",
      "Epoch 118: Train loss=0.009719, Validation loss=0.009184 \n",
      "Epoch 119: Train loss=0.009553, Validation loss=0.009045 (saved)\n",
      "Epoch 120: Train loss=0.009483, Validation loss=0.009044 (saved)\n",
      "Epoch 121: Train loss=0.009451, Validation loss=0.009023 (saved)\n",
      "Epoch 122: Train loss=0.009817, Validation loss=0.009008 (saved)\n",
      "Epoch 123: Train loss=0.009577, Validation loss=0.009143 \n",
      "Epoch 124: Train loss=0.009394, Validation loss=0.009208 \n",
      "Epoch 125: Train loss=0.009618, Validation loss=0.008934 (saved)\n",
      "Epoch 126: Train loss=0.009621, Validation loss=0.009341 \n",
      "Epoch 127: Train loss=0.009463, Validation loss=0.009335 \n",
      "Epoch 128: Train loss=0.009666, Validation loss=0.009000 \n",
      "Epoch 129: Train loss=0.009556, Validation loss=0.009473 \n",
      "Epoch 130: Train loss=0.009629, Validation loss=0.009789 \n",
      "Epoch 131: Train loss=0.010325, Validation loss=0.011325 \n",
      "Epoch 132: Train loss=0.010526, Validation loss=0.010037 \n",
      "Epoch 133: Train loss=0.010469, Validation loss=0.010326 \n",
      "Epoch 134: Train loss=0.011022, Validation loss=0.011225 \n",
      "Epoch 135: Train loss=0.010393, Validation loss=0.010482 \n",
      "Epoch 136: Train loss=0.010694, Validation loss=0.009410 \n",
      "Epoch 137: Train loss=0.010161, Validation loss=0.009406 \n",
      "Epoch 138: Train loss=0.010368, Validation loss=0.010172 \n",
      "Epoch 139: Train loss=0.010357, Validation loss=0.009787 \n",
      "Epoch 140: Train loss=0.009917, Validation loss=0.010286 \n",
      "Epoch 141: Train loss=0.010561, Validation loss=0.010079 \n",
      "Epoch 142: Train loss=0.010580, Validation loss=0.009265 \n",
      "Epoch 143: Train loss=0.009804, Validation loss=0.009736 \n",
      "Epoch 144: Train loss=0.009618, Validation loss=0.009354 \n",
      "Epoch 145: Train loss=0.009683, Validation loss=0.008991 \n",
      "Epoch 146: Train loss=0.009950, Validation loss=0.011489 \n",
      "Epoch 147: Train loss=0.010538, Validation loss=0.010565 \n",
      "Epoch 148: Train loss=0.010069, Validation loss=0.009308 \n",
      "Epoch 149: Train loss=0.010118, Validation loss=0.010349 \n",
      "Epoch 150: Train loss=0.010001, Validation loss=0.009113 \n",
      "Epoch 151: Train loss=0.009604, Validation loss=0.009274 \n",
      "Epoch 152: Train loss=0.009523, Validation loss=0.009286 \n",
      "Epoch 153: Train loss=0.009394, Validation loss=0.008987 \n",
      "Epoch 154: Train loss=0.009302, Validation loss=0.008954 \n",
      "Epoch 155: Train loss=0.009276, Validation loss=0.008912 (saved)\n",
      "Epoch 156: Train loss=0.009247, Validation loss=0.008926 \n",
      "Epoch 157: Train loss=0.009238, Validation loss=0.008881 (saved)\n",
      "Epoch 158: Train loss=0.009252, Validation loss=0.008873 (saved)\n",
      "Epoch 159: Train loss=0.009222, Validation loss=0.008867 (saved)\n",
      "Epoch 160: Train loss=0.009220, Validation loss=0.008942 \n",
      "Epoch 161: Train loss=0.009294, Validation loss=0.008983 \n",
      "Epoch 162: Train loss=0.009277, Validation loss=0.008845 (saved)\n",
      "Epoch 163: Train loss=0.009208, Validation loss=0.009079 \n",
      "Epoch 164: Train loss=0.009293, Validation loss=0.008979 \n",
      "Epoch 165: Train loss=0.009350, Validation loss=0.009223 \n",
      "Epoch 166: Train loss=0.009396, Validation loss=0.008896 \n",
      "Epoch 167: Train loss=0.009342, Validation loss=0.009035 \n",
      "Epoch 168: Train loss=0.009296, Validation loss=0.008884 \n",
      "Epoch 169: Train loss=0.009224, Validation loss=0.008867 \n",
      "Epoch 170: Train loss=0.009169, Validation loss=0.008795 (saved)\n",
      "Epoch 171: Train loss=0.009113, Validation loss=0.008765 (saved)\n",
      "Epoch 172: Train loss=0.009102, Validation loss=0.008755 (saved)\n",
      "Epoch 173: Train loss=0.009108, Validation loss=0.008747 (saved)\n",
      "Epoch 174: Train loss=0.009148, Validation loss=0.008902 \n",
      "Epoch 175: Train loss=0.009189, Validation loss=0.008763 \n",
      "Epoch 176: Train loss=0.009102, Validation loss=0.008946 \n",
      "Epoch 177: Train loss=0.009111, Validation loss=0.008851 \n",
      "Epoch 178: Train loss=0.009165, Validation loss=0.009026 \n",
      "Epoch 179: Train loss=0.009350, Validation loss=0.008860 \n",
      "Epoch 180: Train loss=0.009439, Validation loss=0.008760 \n",
      "Epoch 181: Train loss=0.009253, Validation loss=0.008859 \n",
      "Epoch 182: Train loss=0.009320, Validation loss=0.009389 \n",
      "Epoch 183: Train loss=0.009510, Validation loss=0.009308 \n",
      "Epoch 184: Train loss=0.009601, Validation loss=0.008834 \n",
      "Epoch 185: Train loss=0.009507, Validation loss=0.009028 \n",
      "Epoch 186: Train loss=0.009838, Validation loss=0.009490 \n",
      "Epoch 187: Train loss=0.009509, Validation loss=0.009705 \n",
      "Epoch 188: Train loss=0.009560, Validation loss=0.009414 \n",
      "Epoch 189: Train loss=0.009358, Validation loss=0.008854 \n",
      "Epoch 190: Train loss=0.009098, Validation loss=0.008754 \n",
      "Epoch 191: Train loss=0.009110, Validation loss=0.008872 \n",
      "Epoch 192: Train loss=0.009147, Validation loss=0.008715 (saved)\n",
      "Epoch 193: Train loss=0.009085, Validation loss=0.008729 \n",
      "Epoch 194: Train loss=0.009063, Validation loss=0.008693 (saved)\n",
      "Epoch 195: Train loss=0.009057, Validation loss=0.008719 \n",
      "Epoch 196: Train loss=0.009081, Validation loss=0.008685 (saved)\n",
      "Epoch 197: Train loss=0.009129, Validation loss=0.009130 \n",
      "Epoch 198: Train loss=0.009346, Validation loss=0.008832 \n",
      "Epoch 199: Train loss=0.009209, Validation loss=0.008704 \n",
      "Finished training with best train loss: 0.009019 and validation loss: 0.008685\n"
     ]
    }
   ],
   "source": [
    "x_ood_test = x_ood_test.to(device)\n",
    "start = time.time()\n",
    "model.fit(train_loader, valid_loader, x_test=x_ood_test, epochs=epochs, lr=lr, step_size=step_size, gamma=gamma, tpred = torch.tensor(tpred).to(device), dataset_class = dataset_class, t=t.to(device), grid_train=grid.to(device))\n",
    "stop = time.time()\n",
    "# print(stop-start)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "fb522e5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# %timeit model.fit(train_loader, valid_loader, x_test=x_ood_test, epochs=1, lr=lr, step_size=step_size, gamma=gamma, tpred = torch.tensor(tpred).to(device), dataset_class = dataset_class, t=t.to(device), grid_train=grid.to(device))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "41b11e17-4840-42fe-9a5b-34d65f0a77d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model, test_loader, **test_params):\n",
    "    test_type = test_params.get(\"test_type\", \"id\")\n",
    "    mu = []\n",
    "    var = []\n",
    "    results = {}\n",
    "    results[\"loss\"] = 0.0\n",
    "\n",
    "    model = model.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for batch_idx, batch in enumerate(test_loader):\n",
    "            x, y = batch\n",
    "            x, y = x.to(device), y.to(device)\n",
    "\n",
    "            out = model(x)\n",
    "\n",
    "            # _mu, _var = out\n",
    "            # _std = torch.sqrt(_var)\n",
    "\n",
    "            # out = model.base_model._apply_constraints(_mu, _std, x, t, tpred, grid, dataset_class)\n",
    "\n",
    "\n",
    "\n",
    "            if model.probconserv:\n",
    "                _mu, _var = out\n",
    "                _std = torch.sqrt(_var)\n",
    "                mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "                new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                                mu=_mu[:, :, :, 0], \n",
    "                                                                std=_std[:, :, :, 0], \n",
    "                                                                mass_rhs_func=mass_rhs_func, \n",
    "                                                                t=t, \n",
    "                                                                tpred=tpred, \n",
    "                                                                grid_train=grid, \n",
    "                                                                precis_g=np.inf,\n",
    "                                                                second_deriv_alpha=None,\n",
    "                                                                )\n",
    "                out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "            results[\"loss\"] += model.loss_func(out, y).item()\n",
    "            utils.compute_all_metrics(out, y, results)\n",
    "\n",
    "            if uq:\n",
    "                mu.append(out[0].detach().cpu())\n",
    "                var.append(out[1].detach().cpu())\n",
    "            else:\n",
    "                mu.append(out.detach().cpu())\n",
    "\n",
    "    # print(results['mse'])\n",
    "    # print(len(test_loader.dataset))\n",
    "\n",
    "    for key in results.keys():\n",
    "        if not key.endswith(\"by_example\"):\n",
    "            results[key] /= len(test_loader.dataset)\n",
    "        if type(results[key]) == torch.Tensor:\n",
    "            results[key] = results[key].tolist()\n",
    "\n",
    "    # Plot\n",
    "    mu = torch.cat(mu, dim=0)\n",
    "    if uq:\n",
    "        var = torch.cat(var, dim=0)\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        var = None\n",
    "        std = None\n",
    "    x = test_loader.dataset.tensors[0]\n",
    "    y = test_loader.dataset.tensors[1]\n",
    "\n",
    "    if uq:\n",
    "        results[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y).item()\n",
    "        results[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y).item()\n",
    "\n",
    "        if is_probconserv:\n",
    "            print(\"Here\")\n",
    "            mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "            new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu[:, :, :, 0], \n",
    "                std=std[:, :, :, 0], \n",
    "                mass_rhs_func=mass_rhs_func, \n",
    "                t=t, \n",
    "                tpred=tpred, \n",
    "                grid_train=grid, \n",
    "                precis_g=np.inf,\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            new_mu = new_mu[:, :, :, None]\n",
    "            new_std = new_std[:, :, :, None]\n",
    "            new_var = new_std**2\n",
    "\n",
    "            probconserv_results = utils.compute_all_metrics((new_mu, new_var), y, {})\n",
    "            for key in probconserv_results.keys():\n",
    "                if not key.endswith(\"by_example\"):\n",
    "                    probconserv_results[key] /= len(test_loader.dataset)\n",
    "                if type(probconserv_results[key]) == torch.Tensor:\n",
    "                    probconserv_results[key] = probconserv_results[key].tolist()\n",
    "\n",
    "            probconserv_results[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, new_var, y).item()\n",
    "            probconserv_results[\"rmsce_all\"] = utils.compute_rmsce(new_mu, new_var, y).item()\n",
    "\n",
    "            cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "            new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "            results[\"cerr_by_example\"] = cerr.tolist()\n",
    "            results[\"mcerr\"] = cerr.mean().item()\n",
    "            probconserv_results[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "            probconserv_results[\"mcerr\"] = new_cerr.mean().item()\n",
    "\n",
    "            for key in probconserv_results.keys():\n",
    "                results[f\"pc.{key}\"] = probconserv_results[key]\n",
    "    \n",
    "    # results[\"time\"] = utils.compute_forward_time(model, x[:batch_size].to(device), repetitions=10)\n",
    "    results[\"n_params\"] = utils.compute_n_params(model)\n",
    "    results[\"n_flops\"] = utils.compute_n_flops(model_name, Np=n_x*n_t, fno_modes=fno_modes, fno_width=fno_width, n_layers=4, n_models=n_models)\n",
    "\n",
    "    dataset_params_correct_type = dataset_params if test_type == \"id\" or test_type == \"train\" else ood_dataset_params\n",
    "\n",
    "    mse_by_example = torch.tensor(results[\"mse_by_example\"])\n",
    "    random_idx = np.random.choice(mse_by_example.shape[0])\n",
    "    _, worst_idx = mse_by_example.max(dim=0)\n",
    "    _, best_idx = mse_by_example.min(dim=0)\n",
    "    _, median_idx = mse_by_example.median(dim=0)\n",
    "\n",
    "    for example_name, example_idx in zip([\"random\", \"worst\", \"best\", \"median\"], [random_idx, worst_idx, best_idx, median_idx]):\n",
    "        if uq:\n",
    "            results[f\"examples.{example_name}\"] = (mu[example_idx].tolist(), var[example_idx].tolist(), y[example_idx].tolist(), x[example_idx].tolist())\n",
    "            if is_probconserv:\n",
    "                results[f\"pc.examples.{example_name}\"] = (new_mu[example_idx].tolist(), new_var[example_idx].tolist(), y[example_idx].tolist(), x[example_idx].tolist())\n",
    "        else:\n",
    "            results[f\"examples.{example_name}\"] = (mu[example_idx].tolist(), None, y[example_idx].tolist(), x[example_idx].tolist())\n",
    "\n",
    "        # prefix = f\"{test_type}_{example_name}_params={dataset_params_correct_type}\"\n",
    "        # plot_and_save(prefix, example_idx, x.squeeze(-1), y.squeeze(-1), mu.squeeze(-1), std.squeeze(-1) if std is not None else None)\n",
    "\n",
    "    # utils.dict_to_file({\"test_type\": test_type, \"params\": dataset_params_correct_type, \"results\": results}, \n",
    "    #                    f\"{run_folder}/results_{test_type}_params={dataset_params_correct_type}.json\")\n",
    "\n",
    "    return results\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "58fe7954-8db9-47db-ba7c-39fde51a4146",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here\n",
      "Here\n",
      "Here\n",
      "Here\n",
      "Train results\n",
      "MSE: 0.003934333729557693\n",
      "n-MeRCI: 0.7952125072479248\n",
      "RMSCE: 0.14643684029579163\n",
      "Cerr: 0.1673741489648819\n",
      "In-domain results\n",
      "MSE: 0.003620891869068146\n",
      "n-MeRCI: 0.7020969986915588\n",
      "RMSCE: 0.15096278488636017\n",
      "ProbConserv Results\n",
      "MSE: 0.0026939848065376283\n",
      "n-MeRCI: 0.6139422059059143\n",
      "RMSCE: 0.14420323073863983\n",
      "Cerr: 0.15493953227996826\n",
      "Prob_Cerr: 3.805108406140789e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 0.004248667731881142\n",
      "n-MeRCI: 0.7636370658874512\n",
      "RMSCE: 0.16999807953834534\n",
      "ProbConserv Results\n",
      "MSE: 0.0030339550971984863\n",
      "n-MeRCI: 0.7053958773612976\n",
      "RMSCE: 0.16439616680145264\n",
      "Cerr: 0.18041248619556427\n",
      "Prob_Cerr: 3.776894175189227e-07\n"
     ]
    }
   ],
   "source": [
    "is_probconserv = True\n",
    "\n",
    "train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "if is_train:\n",
    "    train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "    train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "    id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "    print(\"Train results\")\n",
    "    print(f\"MSE: {train_results['mse']}\")\n",
    "    print(f\"n-MeRCI: {train_results['nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {train_results['rmsce_all']}\")\n",
    "    print(f\"Cerr: {train_results['mcerr']}\")\n",
    "\n",
    "    \n",
    "\n",
    "    print(\"In-domain results\")\n",
    "    print(f\"MSE: {id_results['mse']}\")\n",
    "    print(f\"n-MeRCI: {id_results['nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {id_results['rmsce_all']}\")\n",
    "\n",
    "    if is_probconserv:\n",
    "        print(\"ProbConserv Results\")\n",
    "        print(f\"MSE: {id_results['pc.mse']}\")\n",
    "        print(f\"n-MeRCI: {id_results['pc.nMeRCI_all']}\")\n",
    "        print(f\"RMSCE: {id_results['pc.rmsce_all']}\")\n",
    "        print(f\"Cerr: {id_results['mcerr']}\")\n",
    "        print(f\"Prob_Cerr: {id_results['pc.mcerr']}\")\n",
    "        \n",
    "\n",
    "ood_results = test(model, ood_test_loader, test_type=\"ood\")\n",
    "\n",
    "print(\"\\n\")\n",
    "print(\"Out-of-domain results\")\n",
    "print(f\"MSE: {ood_results['mse']}\")\n",
    "print(f\"n-MeRCI: {ood_results['nMeRCI_all']}\")\n",
    "print(f\"RMSCE: {ood_results['rmsce_all']}\")\n",
    "\n",
    "if is_probconserv:\n",
    "    print(\"ProbConserv Results\")\n",
    "    print(f\"MSE: {ood_results['pc.mse']}\")\n",
    "    print(f\"n-MeRCI: {ood_results['pc.nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {ood_results['pc.rmsce_all']}\")\n",
    "    print(f\"Cerr: {ood_results['mcerr']}\")\n",
    "    print(f\"Prob_Cerr: {ood_results['pc.mcerr']}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "98acb797",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0026939848065376283"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "1ec3729e-d8e6-454f-8e4e-6b05f44a94f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_train.to(device))\n",
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "a79d0c9c-0631-48de-a30f-71c30dcad40d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_statistics(\n",
    "    model, \n",
    "    x_data, \n",
    "    y_data, \n",
    "    t, \n",
    "    tpred, \n",
    "    grid, \n",
    "    dataset_class, \n",
    "    apply_probconserv=False, \n",
    "    plot=False,\n",
    "    x_data_test=None, \n",
    "    y_data_test=None,\n",
    "    return_latex=False,\n",
    "    name=\"Model\"\n",
    "):\n",
    "    import torch\n",
    "    import utils\n",
    "    import probconserv\n",
    "    import matplotlib.pyplot as plt\n",
    "\n",
    "    device = next(model.parameters()).device\n",
    "    x_data = x_data.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        out = model(x_data)\n",
    "\n",
    "    if isinstance(out, tuple):\n",
    "        mu, var = out[0].cpu(), out[1].cpu()\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        mu = out.cpu()\n",
    "        std = torch.zeros_like(mu)\n",
    "        var = torch.square(std)\n",
    "\n",
    "    x_cpu = x_data.cpu()\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_cpu)\n",
    "\n",
    "    if apply_probconserv:\n",
    "        new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "            mu=mu[:, :, :, 0],\n",
    "            std=std[:, :, :, 0],\n",
    "            mass_rhs_func=mass_rhs_func,\n",
    "            t=t,\n",
    "            tpred=tpred,\n",
    "            grid_train=grid,\n",
    "            precis_g=float('inf'),\n",
    "            second_deriv_alpha=None,\n",
    "        )\n",
    "        mu = new_mu.unsqueeze(-1)\n",
    "        std = new_std.unsqueeze(-1)\n",
    "        var = torch.square(std)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "    else:\n",
    "        t_sliced = t[slice(*tpred)]\n",
    "        ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu.shape[0])\n",
    "        xs = repeat(grid, \"nx -> nf nx\", nf=mu.shape[0])\n",
    "        inputs = meshgrid(ts, xs)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs_func(inputs)).abs().sum(dim=-1)\n",
    "\n",
    "    stats = utils.compute_all_metrics_avg((mu, var), y_data, {})\n",
    "    stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y_data).item()\n",
    "    stats[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y_data).item()\n",
    "    stats[\"cerr_by_example\"] = cerr.tolist()\n",
    "    stats[\"mcerr\"] = cerr.mean().item()\n",
    "\n",
    "    # --- Test dataset ---\n",
    "    test_stats = None\n",
    "    if x_data_test is not None and y_data_test is not None:\n",
    "        x_data_test = x_data_test.to(device)\n",
    "        with torch.no_grad():\n",
    "            test_out = model(x_data_test)\n",
    "\n",
    "        if isinstance(test_out, tuple):\n",
    "            mu_test, var_test = test_out[0].cpu(), test_out[1].cpu()\n",
    "            std_test = torch.sqrt(var_test)\n",
    "        else:\n",
    "            mu_test = test_out.cpu()\n",
    "            std_test = torch.zeros_like(mu_test)\n",
    "            var_test = torch.square(std_test)\n",
    "\n",
    "        x_test_cpu = x_data_test.cpu()\n",
    "        test_mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_test_cpu)\n",
    "\n",
    "        if apply_probconserv:\n",
    "            new_mu_test, new_std_test, _, test_mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu_test[:, :, :, 0],\n",
    "                std=std_test[:, :, :, 0],\n",
    "                mass_rhs_func=test_mass_rhs_func,\n",
    "                t=t,\n",
    "                tpred=tpred,\n",
    "                grid_train=grid,\n",
    "                precis_g=float('inf'),\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            mu_test = new_mu_test.unsqueeze(-1)\n",
    "            std_test = new_std_test.unsqueeze(-1)\n",
    "            var_test = torch.square(std_test)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs).abs().sum(dim=-1)\n",
    "        else:\n",
    "            t_sliced = t[slice(*tpred)]\n",
    "            ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu_test.shape[0])\n",
    "            xs = repeat(grid, \"nx -> nf nx\", nf=mu_test.shape[0])\n",
    "            inputs = meshgrid(ts, xs)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs_func(inputs)).abs().sum(dim=-1)\n",
    "\n",
    "        test_stats = utils.compute_all_metrics_avg((mu_test, var_test), y_data_test, {})\n",
    "        test_stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"rmsce_all\"] = utils.compute_rmsce(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"cerr_by_example\"] = cerr_test.tolist()\n",
    "        test_stats[\"mcerr\"] = cerr_test.mean().item()\n",
    "\n",
    "    # --- Optional plot ---\n",
    "    if plot:\n",
    "        t_idx = 1\n",
    "        param_idx = 0\n",
    "        with torch.no_grad():\n",
    "            plt.ylabel(f\"u(x, t={t[slice(*tpred)][t_idx]:.2f})\")\n",
    "            plt.xlabel(\"x\")\n",
    "            plt.title(f\"Predicted vs True (param = {x_data[param_idx,0,0,0].item():.2f})\")\n",
    "            mu_plot = mu[param_idx, :, t_idx, 0]\n",
    "            std_plot = std[param_idx, :, t_idx, 0]\n",
    "            y_true_plot = y_data[param_idx, :, t_idx, 0]\n",
    "            plt.plot(grid, mu_plot, '--', lw=2, label=\"μ ± 3σ\")\n",
    "            plt.fill_between(grid, mu_plot + 3*std_plot, mu_plot - 3*std_plot, alpha=0.2)\n",
    "            plt.plot(grid, y_true_plot, color=\"green\", label=\"true\")\n",
    "            plt.legend()\n",
    "            plt.show()\n",
    "\n",
    "    # --- Optional LaTeX row ---\n",
    "    latex_row = None\n",
    "    if return_latex and test_stats:\n",
    "        latex_row = (\n",
    "            f\"{name} & \"\n",
    "            f\"{stats['mse']:.3E} & {stats['nMeRCI_all']:.3E} & {stats['rmsce_all']:.3E} & {stats['mcerr']:.3E} & {stats['crps']:.3E} & \"\n",
    "            f\"{test_stats['mse']:.3E} & {test_stats['nMeRCI_all']:.3E} & {test_stats['rmsce_all']:.3E} & {test_stats['mcerr']:.3E} & {test_stats['crps']:.3E} \\\\\\\\\"\n",
    "        )\n",
    "\n",
    "    return (stats, test_stats, latex_row) if return_latex else (stats, test_stats)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "db6f209f-6714-4ba7-b97a-b583407fc622",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_stats, test_stats, latex = compute_statistics(\n",
    "    model,\n",
    "    x_train, y_train,\n",
    "    x_data_test=x_ood_test, \n",
    "    y_data_test=y_ood_test,\n",
    "    t=t, tpred=tpred, grid=grid,\n",
    "    dataset_class=dataset_class,\n",
    "    apply_probconserv=False,\n",
    "    plot=False,\n",
    "    return_latex=True,\n",
    "    name=\"Unconstrained\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "5dd8a74e-ed48-4729-b03f-5b2479cb2b80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.004248667657375336"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "cf825126-4de6-4fbc-a562-0ba92a03117d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.18041248619556427"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mcerr']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "aa38b7e2-b371-44c0-b8b2-d9b9e007af2c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.009512819051742553"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['crps']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "beca3af8-a7aa-4108-9d1f-34e99c4c2fd2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Unconstrained & 3.934E-03 & 7.952E-01 & 1.464E-01 & 1.674E-01 & 9.019E-03 & 4.249E-03 & 7.636E-01 & 1.700E-01 & 1.804E-01 & 9.513E-03 \\\\\\\\'"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3daaebb7-8bc5-4fc0-9488-cbc03fb52b4e",
   "metadata": {},
   "source": [
    "'ProbConserv & 2.10E-03 & 7.83E-01 & 1.73E-01 & 3.61E-07 & 7.83E-03 & 2.26E-02 & 8.72E-01 & 4.19E-01 & 4.97E-07 & 3.41E-02 \\\\\\\\'\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "45271205-293d-4a07-8c1f-3fa249cfe744",
   "metadata": {},
   "source": [
    "## Experiments to check CRPS (sampling) and CRPS without sampling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "f3f1485f-07fb-4039-a0c4-d0480edbd8bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0090, device='cuda:0', grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.loss_func(out, y.to(device))/len(out[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "7f826c2e-eee5-4b4a-abc0-daf2e505aa50",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "out[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "4dd459b4-d1b8-4d83-8540-074bb8374287",
   "metadata": {},
   "outputs": [],
   "source": [
    "crps_by_sample = utils.compute_sampling_crps_by_example(mu, var, y,nbins=500)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "400f807a-3676-42a2-82fd-f0ee6999c64e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0090, grad_fn=<MeanBackward0>)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.mean(crps_by_sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "913e8446-4753-427f-8d64-d69dbed2b866",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "9e8ad8c6-28e9-45ff-a9e3-a7c828ed5f2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_train.to(device))\n",
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "\n",
    "new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "    mu=mu[:, :, :, 0], \n",
    "    std=std[:, :, :, 0], \n",
    "    mass_rhs_func=mass_rhs_func, \n",
    "    t=t, \n",
    "    tpred=tpred, \n",
    "    grid_train=grid, \n",
    "    precis_g=np.inf,\n",
    "    second_deriv_alpha=None,\n",
    ")\n",
    "new_mu = new_mu[:, :, :, None]\n",
    "new_std = new_std[:, :, :, None]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "64b75faa-0ce0-47f9-ae71-2aae64386daf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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rsHHx8du56XCeK0rBq9zxeB1rhi8zhWjPK+zEALp6ekIDw+HTGa9JxArQsWQyWSoVq1auZ3fx8eHf2QVhNe6YvA6Vwxe54rB61wxyus6F1UJMmJnaSIiInJZTISIiIjIZTERqiRqtRqTJ0+GWq2u7FCcHq91xeB1rhi8zhWD17li3A/XmZ2liYiIyGWxIkREREQui4kQERERuSwmQkREROSymAgRERGRy2IiVI4WLFiAyMhIuLm5oW3btjhw4ECR+3///fdo0KAB3Nzc0LRpU2zevLmCInVsJbnOS5YsQceOHeHv7w9/f39ER0cX+3uhe0r6mjZas2YNJElC7969yzdAJ1HS65ySkoIRI0YgLCwMarUa9erV4/uHDUp6nefOnYv69evD3d0dERERGD16NHJyciooWsf0559/omfPnggPD4ckSdi4cWOxx+zatQsPPPAA1Go16tSpgxUrVpRvkILKxZo1a4RKpRLLli0TJ0+eFMOGDRN+fn4iISHB4v579uwRcrlcfPrpp+LUqVPigw8+EEqlUpw4caKCI3csJb3OL7zwgliwYIE4evSoOH36tBg0aJDw9fUV//33XwVH7nhKeq2N4uLiRNWqVUXHjh1Fr169KiZYB1bS65ybmytat24tunfvLnbv3i3i4uLErl27xLFjxyo4csdS0uu8atUqoVarxapVq0RcXJzYunWrCAsLE6NHj67gyB3L5s2bxfvvvy9+/PFHAUBs2LChyP0vXbokPDw8xJgxY8SpU6fE/PnzhVwuF1u2bCm3GJkIlZM2bdqIESNGmH7W6XQiPDxcxMbGWty/T58+okePHmbb2rZtK1555ZVyjdPRlfQ6F6TVaoW3t7dYuXJleYXoNEpzrbVarWjXrp34+uuvxcCBA5kI2aCk13nRokWiVq1aQqPRVFSITqGk13nEiBHikUceMds2ZswY0b59+3KN05nYkgi98847onHjxmbb+vbtK2JiYsotLjaNlQONRoPDhw8jOjratE0mkyE6Ohr79u2zeMy+ffvM9geAmJgYq/tT6a5zQVlZWcjLy0NAQEB5hekUSnutp02bhuDgYAwdOrQiwnR4pbnOP//8M6KiojBixAiEhISgSZMmmD59OnQ6XUWF7XBKc53btWuHw4cPm5rPLl26hM2bN6N79+4VErOrqIzPQi66Wg5u374NnU6HkJAQs+0hISE4c+aMxWPi4+Mt7h8fH19ucTq60lzngt59912Eh4cX+sMjc6W51rt378bSpUtx7NixCojQOZTmOl+6dAm///47+vfvj82bN+PChQt4/fXXkZeXh8mTJ1dE2A6nNNf5hRdewO3bt9GhQwcIIaDVavHqq6/ivffeq4iQXYa1z8K0tDRkZ2fD3d3d7o/JihC5rBkzZmDNmjXYsGED3NzcKjscp5Keno6XXnoJS5YsQWBgYGWH49T0ej2Cg4Px1VdfoVWrVujbty/ef/99LF68uLJDcyq7du3C9OnTsXDhQhw5cgQ//vgjNm3ahA8//LCyQ6MyYkWoHAQGBkIulyMhIcFse0JCAkJDQy0eExoaWqL9qXTX2WjmzJmYMWMGtm/fjmbNmpVnmE6hpNf64sWLuHz5Mnr27GnaptfrAQAKhQJnz55F7dq1yzdoB1Sa13RYWBiUSiXkcrlpW8OGDREfHw+NRgOVSlWuMTui0lzniRMn4qWXXsLLL78MAGjatCkyMzMxfPhwvP/++5DJWFewB2ufhT4+PuVSDQJYESoXKpUKrVq1wo4dO0zb9Ho9duzYgaioKIvHREVFme0PANu2bbO6P5XuOgPAp59+ig8//BBbtmxB69atKyJUh1fSa92gQQOcOHECx44dM92efPJJdOnSBceOHUNERERFhu8wSvOabt++PS5cuGBKNAHg3LlzCAsLYxJkRWmuc1ZWVqFkx5h8Ci7ZaTeV8llYbt2wXdyaNWuEWq0WK1asEKdOnRLDhw8Xfn5+Ij4+XgghxEsvvSTGjx9v2n/Pnj1CoVCImTNnitOnT4vJkydz+LwNSnqdZ8yYIVQqlVi/fr24efOm6Zaenl5ZT8FhlPRaF8RRY7Yp6XW+evWq8Pb2FiNHjhRnz54Vv/zyiwgODhYfffRRZT0Fh1DS6zx58mTh7e0t/ve//4lLly6J3377TdSuXVv06dOnsp6CQ0hPTxdHjx4VR48eFQDE7NmzxdGjR8WVK1eEEEKMHz9evPTSS6b9jcPnx40bJ06fPi0WLFjA4fOObP78+aJ69epCpVKJNm3aiL///tt0X6dOncTAgQPN9l+3bp2oV6+eUKlUonHjxmLTpk0VHLFjKsl1rlGjhgBQ6DZ58uSKD9wBlfQ1nR8TIduV9Drv3btXtG3bVqjValGrVi3x8ccfC61WW8FRO56SXOe8vDwxZcoUUbt2beHm5iYiIiLE66+/Lu7cuVPxgTuQnTt3WnzPNV7bgQMHik6dOhU6pkWLFkKlUolatWqJ5cuXl2uMkhCs6REREZFrYh8hIiIicllMhIiIiMhlMREiIiIil8VEiIiIiFwWEyEiIiJyWUyEiIiIyGUxESIiIiKXxUSIiIiIXBYTISIiInJZTISIiIjIZTERIiKXcuvWLYSGhmL69OmmbXv37oVKpSq06jUROT+uNUZELmfz5s3o3bs39u7di/r166NFixbo1asXZs+eXdmhEVEFYyJERC5pxIgR2L59O1q3bo0TJ07g4MGDUKvVlR0WEVUwJkJE5JKys7PRpEkTXLt2DYcPH0bTpk0rOyQiqgTsI0RELunixYu4ceMG9Ho9Ll++XNnhEFElYUWIiFyORqNBmzZt0KJFC9SvXx9z587FiRMnEBwcXNmhEVEFYyJERC5n3LhxWL9+PY4fPw4vLy906tQJvr6++OWXXyo7NCKqYGwaIyKXsmvXLsydOxfffvstfHx8IJPJ8O233+Kvv/7CokWLKjs8IqpgrAgRERGRy2JFiIiIiFwWEyEiIiJyWUyEiIiIyGUxESIiIiKXxUSIiIiIXBYTISIiInJZTISIiIjIZTERIiIiIpfFRIiIiIhcFhMhIiIicllMhIiIiMhlMREiIiIil/X/3d30WnsoRvcAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_train[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_train[parameter_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "fbeef4c3-208f-490b-9f76-24ba47485adc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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u379Oh544IFCz2+eqiIkJMRquzlht/UlZvv27Rg+fDj69u2LJUuWFP0kXBQTISqRoKAgeHl5wWAwFPnhuHHjRtStWxfffvut1bfCuLi4ig6zRMzFzmfPnrX6pnj79m2bby7F5efnh3r16uGff/6xbLNXSF2vXj388ssv6NSpU6k+GP/v//4POTk52Lx5s1VrT3G61MpbrVq10KlTJ+zatQsvvvhioa1H1ZG5kL2org5bgoKC4O7ujtOnTxe479SpU5DJZAU+BEvqzJkzVj8LIXD27FnLF5Bjx47h33//xerVqzF8+HDLftu3by/2Y5THOYqrXr16SE9PL/L9xN7fjrkLUqlUVkjLojmBKcrKlSsLHWFqHhxy4MABq6Tn2rVruHLlCsaMGVPo+du0aYNly5YV6OYzT9ia/8vSvn37MHDgQLRt2xZff/21w/0dVibWCFGJyOVyPPHEE/jmm2+sPuDN8g5LN38bzPvtb9++fdi7d2/FB1oCPXv2hEKhKDDU/OOPPy7W8UePHrU5suTixYs4ceKEVTeJeRTU3bt3rfYdNGgQDAYDZs+eXeA8er2+wP752brWKSkpWLlyZbGeQ3l7++23ERcXV+w6q+pi586dmD17NurUqWMZRl4Scrkcffr0wffff2/VVZWUlIS1a9eic+fORXblFuXzzz+3ql/auHEjrl+/jocfftgSA2D9WhBCYMGCBSV6HmU9R3ENGjQIe/fuxU8//VTgvrt371pmXTbXmeX/WwgODkb37t3x6aef4vr16wXOkX+qjJIqrxqhZs2aoXHjxli6dKnVsPfFixdDkiQ8+eSTlm0pKSk4deqUVRdk//79oVarsXLlSqsWOfPo0d69e1u2nTx5En379kVkZCR++OGHcm91dDZMEcmmFStW2Bzu/Morr2Du3Ln49ddf0b59e4wePRpNmzZFcnIyDh06hF9++QXJyckAgEcffRTffvstBg4ciL59+yIhIQFLlixB06ZNLYV/1UFISAheeeUVfPDBB3jsscfw0EMP4ejRo/jxxx8RGBhY5Cys27dvR1xcHB577DF06NABnp6eOH/+PFasWIGcnByruU7atGkDwDRbc3R0NORyOZ5++ml069YNY8eORXx8PI4cOYI+ffpAqVTizJkz2LBhAxYsWGD1Rplfnz59oFKp0K9fP4wdOxbp6elYtmwZgoODbX44VLRu3bqhW7duxdo3JSXF7pw9zzzzTLEf8/fff7cU1t68eRMZGRmWLsmuXbuia9euVvv/+OOPOHXqFPR6PZKSkrBz505s374dtWvXxubNm+3OhF2Ut99+G9u3b0fnzp0xbtw4KBQKfPrpp8jJycG8efNKdc68/P390blzZ4wcORJJSUmYP38+6tevbxnq37hxY9SrVw+vvfYarl69Cm9vb3zzzTclat0sj3MU1+TJk7F582Y8+uijlikcMjIycOzYMWzcuBEXLlxAYGAg3Nzc0LRpU6xfvx4NGzaEv78/mjdvjubNm2PRokXo3LkzWrRogdGjR6Nu3bpISkrC3r17ceXKFRw9erTU8ZVnK9N7772Hxx57DH369MHTTz+Nf/75Bx9//DGef/55NGnSxLLfpk2bMHLkSKtWptDQUEydOhXTp0/HQw89hAEDBuDo0aNYtmwZhgwZgnbt2gEA0tLSEB0djTt37mDy5MnYsmWLVQz16tVDVFRUuT0np1D5A9WoOjMPL7V3u3z5shBCiKSkJDF+/HgREREhlEqlCA0NFT179hRLly61nMtoNIo5c+aI2rVrC7VaLVq3bi1++OEHERMTI2rXrm3Zz94wZCHuDZ+/efOmzTgTEhIs2+wNn88/TNo8DPnXX3+1bNPr9WLatGkiNDRUuLm5iR49eoiTJ0+KgIAA8cILLxR6zc6fPy+mT58uOnToIIKDg4VCoRBBQUGib9++YufOnVb76vV68dJLL4mgoCAhSVKBofRLly4Vbdq0EW5ubsLLy0u0aNFCvP766+LatWuWfewNn9+8ebNo2bKl0Gg0IjIyUrz77rtixYoVNq9T3759CxzfrVs3qyHn9maWzq+w319eJR0+X9K3J/NrxdYt75Dr/K9xlUolQkNDRe/evcWCBQushqaX9nkfOnRIREdHC09PT+Hu7i4efPBBsWfPHqt9SjqLu/n38dVXX4nY2FgRHBws3NzcRN++fa2GswshxIkTJ0SvXr2Ep6enCAwMFKNHjxZHjx4tMMzb3mupPM5hb9ZwW6+/tLQ0ERsbK+rXry9UKpUIDAwUHTt2FO+//77QarWW/fbs2SPatGkjVCpVgd/ruXPnxPDhw0VoaKhQKpWiRo0a4tFHHxUbN2607FMdZs7ftGmTaNWqlVCr1aJmzZrirbfesnqOQtyLM/+QfKPRKBYuXCgaNmwolEqliIiIKHC8+XVp71bUdCCuSBKigipGiRzc3bt34efnh7fffttqUUOiqrBr1y48+OCD2LBhQ6Gtg0RUMqwRIgJszuExf/58AI67wCMRERWNNUJEMM21sWrVKstSCbt378ZXX32FPn362FxDjCqHwWAostjV09PTsrwFEVFJMREigmnuI4VCgXnz5iE1NdVSQF3U/D9UsS5fvlzk5HdxcXFWBelERCXBGiEiqrays7Oxe/fuQvepW7eu1XIWREQlwUSIiIiIXBaLpYmIiMhlsUaoCEajEdeuXYOXl1eRE+sRERFR9SCEQFpaGsLDwwusp5cXE6EiXLt2rcxrAxEREVHVuHz5MmrWrGn3fiZCRfDy8gJgupBlXSOIiIiIKkdqaioiIiIsn+P2MBEqgrk7zNvbm4kQERGRgymqrIXF0kREROSymAgRERGRy2IiRERERC6LNUJE5HCMRiO0Wm1Vh0FEVUipVEIul5f5PEyEiMihaLVaJCQkwGg0VnUoRFTFfH19ERoaWqZ5/pgIEZHDEELg+vXrkMvliIiIKHSSNCJyXkIIZGZm4saNGwCAsLCwUp+LiRAROQy9Xo/MzEyEh4fD3d29qsMhoirk5uYGALhx4waCg4NL3U3Gr1NE5DAMBgMAQKVSVXEkRFQdmL8Q6XS6Up+DiRARORyu+0dEQPm8FzARIiIiIpfFRIiIiIhcFhMhIiIicllMhIiInFD37t3x6quvFvh3VcbhCBwl3tu3byM4OBgXLlyo6lAqzNNPP40PPvigwh+HiRARkZP79ttvMXv27GLv7yjJQHW3ePFitGzZEt7e3vD29kZUVBR+/PHHcjn3O++8g/79+yMyMrJczleYESNGQJKkArezZ89a3T937lyr47777jubxcyXL1/Gc889h/DwcKhUKtSuXRuvvPIKbt++bbXfW2+9hXfeeQcpKSkV9+TARKhKpWSWfrgfETm38lxCxN/fH15eXuV2Prqne/fuWLVqlc37atasiblz5+LgwYM4cOAAevTogf79++P48eNleszMzEwsX74co0aNKtN5isP8OnzooYdw/fp1q1udOnUs+2k0Grz77ru4c+dOoec7f/482rZtizNnzuCrr77C2bNnsWTJEuzYsQNRUVFITk627Nu8eXPUq1cPX375ZcU8uVwOlQj9/vvv6NevH8LDwyFJEr777rsij9m1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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_train[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")        \n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "5ea3ace5-4141-4975-9823-0ec6d7aab7cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "ucons_stats_train = utils.compute_all_metrics_avg((mu, torch.square(std)), y_train, {})\n",
    "ucons_stats_train[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, torch.square(std), y_train).item()\n",
    "ucons_stats_train[\"rmsce_all\"] = utils.compute_rmsce(mu, torch.square(std), y_train).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "bbc1aeab-f5a3-45e5-8f17-c47458e866f2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.0014267205260694027,\n",
       "  0.00444853026419878,\n",
       "  0.00513400137424469,\n",
       "  0.005158242769539356,\n",
       "  0.0024629903491586447,\n",
       "  0.0021592930424958467,\n",
       "  0.0014260878087952733,\n",
       "  0.006635133642703295,\n",
       "  0.001456900266930461,\n",
       "  0.00215919385664165,\n",
       "  0.00201966124586761,\n",
       "  0.0016415445134043694,\n",
       "  0.007087093777954578,\n",
       "  0.0044428096152842045,\n",
       "  0.0025615599006414413,\n",
       "  0.0014456723583862185,\n",
       "  0.002973332768306136,\n",
       "  0.00477535929530859,\n",
       "  0.0045839110389351845,\n",
       "  0.002874194411560893,\n",
       "  0.002607774455100298,\n",
       "  0.007209554314613342,\n",
       "  0.001640663598664105,\n",
       "  0.006435875780880451,\n",
       "  0.001600691699422896,\n",
       "  0.0015920362202450633,\n",
       "  0.007967252284288406,\n",
       "  0.006447898223996162,\n",
       "  0.004139324184507132,\n",
       "  0.0018701591761782765,\n",
       "  0.0024622937198728323,\n",
       "  0.007778361439704895,\n",
       "  0.0042872647754848,\n",
       "  0.002869904274120927,\n",
       "  0.004578666761517525,\n",
       "  0.006444946397095919,\n",
       "  0.0032191257923841476,\n",
       "  0.007778123486787081,\n",
       "  0.0038541960529983044,\n",
       "  0.004274004604667425,\n",
       "  0.0014638942666351795,\n",
       "  0.0030946077313274145,\n",
       "  0.0018313054461032152,\n",
       "  0.006445898674428463,\n",
       "  0.005161991808563471,\n",
       "  0.003094085957854986,\n",
       "  0.004951290786266327,\n",
       "  0.0047749681398272514,\n",
       "  0.0028728062752634287,\n",
       "  0.0014148327754810452,\n",
       "  0.004951552487909794,\n",
       "  0.008791239932179451,\n",
       "  0.002973369089886546,\n",
       "  0.0017031998140737414,\n",
       "  0.005132314283400774,\n",
       "  0.003218176309019327,\n",
       "  0.0019827967043966055,\n",
       "  0.00514725036919117,\n",
       "  0.004580073058605194,\n",
       "  0.00309389247559011,\n",
       "  0.0041239093989133835,\n",
       "  0.0029734927229583263,\n",
       "  0.003217511111870408,\n",
       "  0.0022820348385721445,\n",
       "  0.00460808677598834,\n",
       "  0.0014987107133492827,\n",
       "  0.0014632183592766523,\n",
       "  0.002075193217024207,\n",
       "  0.004950971342623234,\n",
       "  0.00858326442539692,\n",
       "  0.005148554220795631,\n",
       "  0.0023651369847357273,\n",
       "  0.0029732792172580957,\n",
       "  0.007209462113678455,\n",
       "  0.007778697181493044,\n",
       "  0.007779358886182308,\n",
       "  0.0019831627141684294,\n",
       "  0.005959550850093365,\n",
       "  0.0015606599627062678,\n",
       "  0.00414024293422699,\n",
       "  0.00644647516310215,\n",
       "  0.007779693230986595,\n",
       "  0.006436390336602926,\n",
       "  0.007247551344335079,\n",
       "  0.0019828209187835455,\n",
       "  0.0016000254545360804,\n",
       "  0.0016003826167434454,\n",
       "  0.002870346885174513,\n",
       "  0.0029730829410254955,\n",
       "  0.003217519959434867,\n",
       "  0.0029726726934313774,\n",
       "  0.0042745135724544525,\n",
       "  0.006072684191167355,\n",
       "  0.00297283916734159,\n",
       "  0.007074735593050718,\n",
       "  0.0042871409095823765,\n",
       "  0.004274357575923204,\n",
       "  0.001983462832868099,\n",
       "  0.005145919043570757,\n",
       "  0.003220613580197096,\n",
       "  0.008377613499760628,\n",
       "  0.005319399293512106,\n",
       "  0.0028740973211824894,\n",
       "  0.001870329026132822,\n",
       "  0.007088086102157831,\n",
       "  0.0014261819887906313,\n",
       "  0.005153454374521971,\n",
       "  0.005148349329829216,\n",
       "  0.001413805759511888,\n",
       "  0.0017613668460398912,\n",
       "  0.0025619775988161564,\n",
       "  0.0047751679085195065,\n",
       "  0.0036522787995636463,\n",
       "  0.007967359386384487,\n",
       "  0.005510724149644375,\n",
       "  0.005298761185258627,\n",
       "  0.001704563619568944,\n",
       "  0.0014635429251939058,\n",
       "  0.0017612290102988482,\n",
       "  0.0021584350615739822,\n",
       "  0.002973265713080764,\n",
       "  0.0015355217037722468,\n",
       "  0.0030991605017334223,\n",
       "  0.004273730795830488,\n",
       "  0.007085689343512058,\n",
       "  0.0032174447551369667,\n",
       "  0.0017044205451384187,\n",
       "  0.0030993111431598663,\n",
       "  0.0022667020093649626,\n",
       "  0.0051349494606256485,\n",
       "  0.0016400049207732081,\n",
       "  0.0020746879745274782,\n",
       "  0.004286475945264101,\n",
       "  0.0014140092534944415,\n",
       "  0.00607268325984478,\n",
       "  0.0014929238241165876,\n",
       "  0.0014452149625867605,\n",
       "  0.0014570601051673293,\n",
       "  0.0019832609687000513,\n",
       "  0.004951439797878265,\n",
       "  0.008378001861274242,\n",
       "  0.004951414652168751,\n",
       "  0.008378134109079838,\n",
       "  0.0014128843322396278,\n",
       "  0.006284216418862343,\n",
       "  0.0028675429057329893,\n",
       "  0.005510569550096989,\n",
       "  0.0014267718652263284,\n",
       "  0.0030974813271313906,\n",
       "  0.005149755161255598,\n",
       "  0.006445182953029871,\n",
       "  0.005298555828630924,\n",
       "  0.001640946022234857,\n",
       "  0.004608070943504572,\n",
       "  0.004448639694601297,\n",
       "  0.007083825301378965,\n",
       "  0.004951073322445154,\n",
       "  0.00514524569734931,\n",
       "  0.0016401290195062757,\n",
       "  0.0025626071728765965],\n",
       " 'mse': 0.003934333473443985,\n",
       " 'nll_by_example': [-9608.55078125,\n",
       "  -7294.361328125,\n",
       "  -7346.646484375,\n",
       "  -7825.19580078125,\n",
       "  -9318.21484375,\n",
       "  -8899.41796875,\n",
       "  -9621.076171875,\n",
       "  -4389.72509765625,\n",
       "  -9662.6669921875,\n",
       "  -8913.830078125,\n",
       "  -9496.9111328125,\n",
       "  -9633.4072265625,\n",
       "  -5652.4267578125,\n",
       "  -8246.5107421875,\n",
       "  -9247.30859375,\n",
       "  -9550.080078125,\n",
       "  -8269.828125,\n",
       "  -6777.587890625,\n",
       "  -8166.703125,\n",
       "  -9177.7001953125,\n",
       "  -8450.4140625,\n",
       "  -3807.164306640625,\n",
       "  -9625.9287109375,\n",
       "  -5047.947265625,\n",
       "  -9654.9580078125,\n",
       "  -9418.2080078125,\n",
       "  -2611.203369140625,\n",
       "  -6070.7744140625,\n",
       "  -8419.8623046875,\n",
       "  -9572.67578125,\n",
       "  -9306.740234375,\n",
       "  -3142.568359375,\n",
       "  -8327.3896484375,\n",
       "  -9103.6875,\n",
       "  -8066.3740234375,\n",
       "  -6013.2734375,\n",
       "  -8652.98046875,\n",
       "  -3195.19091796875,\n",
       "  -7941.1796875,\n",
       "  -7677.9287109375,\n",
       "  -9524.7451171875,\n",
       "  -8926.109375,\n",
       "  -9250.650390625,\n",
       "  -6031.9130859375,\n",
       "  -7893.90478515625,\n",
       "  -8916.11328125,\n",
       "  -6497.53369140625,\n",
       "  -6888.8701171875,\n",
       "  -9154.3681640625,\n",
       "  -9635.322265625,\n",
       "  -6422.6630859375,\n",
       "  1301.4114990234375,\n",
       "  -8261.1416015625,\n",
       "  -9346.23046875,\n",
       "  -6126.3017578125,\n",
       "  -8632.328125,\n",
       "  -9196.732421875,\n",
       "  -7615.51123046875,\n",
       "  -8093.63671875,\n",
       "  -8912.36328125,\n",
       "  -7892.8974609375,\n",
       "  -8231.3759765625,\n",
       "  -8617.724609375,\n",
       "  -8751.9951171875,\n",
       "  -7193.7734375,\n",
       "  -9665.4501953125,\n",
       "  -9548.173828125,\n",
       "  -9041.373046875,\n",
       "  -6587.97998046875,\n",
       "  20.390228271484375,\n",
       "  -7641.04833984375,\n",
       "  -9363.7451171875,\n",
       "  -8282.7626953125,\n",
       "  -3828.17529296875,\n",
       "  -3067.89697265625,\n",
       "  -2920.0986328125,\n",
       "  -9155.947265625,\n",
       "  -6765.0107421875,\n",
       "  -9448.771484375,\n",
       "  -8437.15234375,\n",
       "  -6043.1435546875,\n",
       "  -2844.583740234375,\n",
       "  -4923.05615234375,\n",
       "  -5180.68017578125,\n",
       "  -9194.1220703125,\n",
       "  -9651.5556640625,\n",
       "  -9653.439453125,\n",
       "  -9111.56640625,\n",
       "  -8329.384765625,\n",
       "  -8617.9228515625,\n",
       "  -8425.431640625,\n",
       "  -7534.05322265625,\n",
       "  -5440.916015625,\n",
       "  -8386.7900390625,\n",
       "  -5421.8759765625,\n",
       "  -8325.056640625,\n",
       "  -7578.40576171875,\n",
       "  -9121.5283203125,\n",
       "  -7589.3349609375,\n",
       "  -8684.9189453125,\n",
       "  -481.4311828613281,\n",
       "  -6054.8876953125,\n",
       "  -9176.099609375,\n",
       "  -9574.5888671875,\n",
       "  -5670.66748046875,\n",
       "  -9619.306640625,\n",
       "  -7735.34716796875,\n",
       "  -7637.0615234375,\n",
       "  -9648.5224609375,\n",
       "  -9305.5908203125,\n",
       "  -9254.470703125,\n",
       "  -6831.85400390625,\n",
       "  -8529.328125,\n",
       "  -2587.306396484375,\n",
       "  -5858.76953125,\n",
       "  -7184.35498046875,\n",
       "  -9579.98046875,\n",
       "  -9537.1708984375,\n",
       "  -9317.1591796875,\n",
       "  -9020.2294921875,\n",
       "  -8285.986328125,\n",
       "  -9511.525390625,\n",
       "  -9010.3515625,\n",
       "  -7754.09814453125,\n",
       "  -5626.681640625,\n",
       "  -8616.2314453125,\n",
       "  -9578.1728515625,\n",
       "  -9013.0498046875,\n",
       "  -9401.8916015625,\n",
       "  -7366.44677734375,\n",
       "  -9619.8017578125,\n",
       "  -9105.2158203125,\n",
       "  -8312.4267578125,\n",
       "  -9646.1904296875,\n",
       "  -5441.14990234375,\n",
       "  -9665.1650390625,\n",
       "  -9563.87109375,\n",
       "  -9661.9765625,\n",
       "  -9144.830078125,\n",
       "  -6455.0634765625,\n",
       "  -395.15545654296875,\n",
       "  -6461.92578125,\n",
       "  -366.2185974121094,\n",
       "  -9657.3544921875,\n",
       "  -6362.9228515625,\n",
       "  -9060.5986328125,\n",
       "  -5899.9541015625,\n",
       "  -9607.45703125,\n",
       "  -8979.904296875,\n",
       "  -7664.3544921875,\n",
       "  -6017.9296875,\n",
       "  -7180.017578125,\n",
       "  -9628.41015625,\n",
       "  -7198.02490234375,\n",
       "  -7263.2685546875,\n",
       "  -5592.27490234375,\n",
       "  -6558.9697265625,\n",
       "  -7575.9384765625,\n",
       "  -9620.9921875,\n",
       "  -9265.189453125],\n",
       " 'nll': -7646.55859375,\n",
       " 'piw_by_example': [0.05645707994699478,\n",
       "  0.05624809488654137,\n",
       "  0.05677349120378494,\n",
       "  0.056739527732133865,\n",
       "  0.056603141129016876,\n",
       "  0.05635097622871399,\n",
       "  0.05646185204386711,\n",
       "  0.05615010857582092,\n",
       "  0.05648843199014664,\n",
       "  0.056352321058511734,\n",
       "  0.05657099559903145,\n",
       "  0.05653011426329613,\n",
       "  0.056825198233127594,\n",
       "  0.05671083182096481,\n",
       "  0.05661363899707794,\n",
       "  0.05643991380929947,\n",
       "  0.05630214512348175,\n",
       "  0.05622377619147301,\n",
       "  0.0567169263958931,\n",
       "  0.05662264674901962,\n",
       "  0.05631447210907936,\n",
       "  0.05613580346107483,\n",
       "  0.05653366819024086,\n",
       "  0.0561671145260334,\n",
       "  0.05651640519499779,\n",
       "  0.056413400918245316,\n",
       "  0.05610719323158264,\n",
       "  0.05681437626481056,\n",
       "  0.05669807270169258,\n",
       "  0.05655200034379959,\n",
       "  0.056604936718940735,\n",
       "  0.056123003363609314,\n",
       "  0.05670534446835518,\n",
       "  0.05663231015205383,\n",
       "  0.05672498419880867,\n",
       "  0.05681784451007843,\n",
       "  0.056680258363485336,\n",
       "  0.05612468346953392,\n",
       "  0.0562826544046402,\n",
       "  0.056267913430929184,\n",
       "  0.05643390491604805,\n",
       "  0.05665263906121254,\n",
       "  0.05638902261853218,\n",
       "  0.05681673809885979,\n",
       "  0.05673431232571602,\n",
       "  0.05665375664830208,\n",
       "  0.05621194466948509,\n",
       "  0.05622900649905205,\n",
       "  0.056625768542289734,\n",
       "  0.05646810680627823,\n",
       "  0.05620865523815155,\n",
       "  0.056073471903800964,\n",
       "  0.05630156770348549,\n",
       "  0.056402143090963364,\n",
       "  0.05619684234261513,\n",
       "  0.05668222904205322,\n",
       "  0.0563824363052845,\n",
       "  0.05675486475229263,\n",
       "  0.05672283470630646,\n",
       "  0.056654155254364014,\n",
       "  0.05628024414181709,\n",
       "  0.05629952996969223,\n",
       "  0.05668359994888306,\n",
       "  0.056337933987379074,\n",
       "  0.05624329671263695,\n",
       "  0.05650291591882706,\n",
       "  0.05643947422504425,\n",
       "  0.05636497959494591,\n",
       "  0.056215982884168625,\n",
       "  0.05608637258410454,\n",
       "  0.05675305426120758,\n",
       "  0.056595899164676666,\n",
       "  0.05630304291844368,\n",
       "  0.05613650754094124,\n",
       "  0.05612063780426979,\n",
       "  0.0561160147190094,\n",
       "  0.05637755244970322,\n",
       "  0.05679165944457054,\n",
       "  0.05641873553395271,\n",
       "  0.05669654160737991,\n",
       "  0.05681604519486427,\n",
       "  0.05611367151141167,\n",
       "  0.056162524968385696,\n",
       "  0.05684169754385948,\n",
       "  0.05638210475444794,\n",
       "  0.05651922896504402,\n",
       "  0.05651773139834404,\n",
       "  0.05663129687309265,\n",
       "  0.05630628019571304,\n",
       "  0.056683581322431564,\n",
       "  0.05631319060921669,\n",
       "  0.05625985935330391,\n",
       "  0.05617951229214668,\n",
       "  0.056310366839170456,\n",
       "  0.05683864653110504,\n",
       "  0.0567055381834507,\n",
       "  0.05626230686903,\n",
       "  0.05637358874082565,\n",
       "  0.05675674229860306,\n",
       "  0.05667717382311821,\n",
       "  0.05609377846121788,\n",
       "  0.056195564568042755,\n",
       "  0.05662287399172783,\n",
       "  0.05655142292380333,\n",
       "  0.05682411417365074,\n",
       "  0.05646112933754921,\n",
       "  0.05674619972705841,\n",
       "  0.056753333657979965,\n",
       "  0.0564754419028759,\n",
       "  0.05639635771512985,\n",
       "  0.056612592190504074,\n",
       "  0.05622631683945656,\n",
       "  0.05668990686535835,\n",
       "  0.056106485426425934,\n",
       "  0.05619116872549057,\n",
       "  0.056781403720378876,\n",
       "  0.05655033886432648,\n",
       "  0.056436799466609955,\n",
       "  0.05639797821640968,\n",
       "  0.056362882256507874,\n",
       "  0.05630326643586159,\n",
       "  0.05643110349774361,\n",
       "  0.05664302408695221,\n",
       "  0.056272316724061966,\n",
       "  0.05682672560214996,\n",
       "  0.0566837415099144,\n",
       "  0.05655090883374214,\n",
       "  0.05664271116256714,\n",
       "  0.05658944696187973,\n",
       "  0.05677216127514839,\n",
       "  0.05653635039925575,\n",
       "  0.05637187883257866,\n",
       "  0.05670661851763725,\n",
       "  0.056473974138498306,\n",
       "  0.05617951229214668,\n",
       "  0.056493859738111496,\n",
       "  0.0564434714615345,\n",
       "  0.056487493216991425,\n",
       "  0.056376248598098755,\n",
       "  0.05621007829904556,\n",
       "  0.0560913011431694,\n",
       "  0.05621037259697914,\n",
       "  0.056090474128723145,\n",
       "  0.05648209899663925,\n",
       "  0.056802891194820404,\n",
       "  0.056637633591890335,\n",
       "  0.05619285628199577,\n",
       "  0.05645669624209404,\n",
       "  0.05664656311273575,\n",
       "  0.05675136297941208,\n",
       "  0.05681757628917694,\n",
       "  0.05678168311715126,\n",
       "  0.05653253570199013,\n",
       "  0.05624350905418396,\n",
       "  0.05624648928642273,\n",
       "  0.05682874098420143,\n",
       "  0.05621468275785446,\n",
       "  0.05675768479704857,\n",
       "  0.05653584003448486,\n",
       "  0.05661103129386902],\n",
       " 'piw': 0.05647381544113159,\n",
       " 'crps_by_example': [0.005349585320800543,\n",
       "  0.009727968834340572,\n",
       "  0.01078631542623043,\n",
       "  0.010689286515116692,\n",
       "  0.006550121586769819,\n",
       "  0.006339007057249546,\n",
       "  0.005344213452190161,\n",
       "  0.013360683806240559,\n",
       "  0.005359490867704153,\n",
       "  0.006334967911243439,\n",
       "  0.006008056458085775,\n",
       "  0.005552490241825581,\n",
       "  0.014040261507034302,\n",
       "  0.009540495462715626,\n",
       "  0.006688511464744806,\n",
       "  0.005392557941377163,\n",
       "  0.007518084719777107,\n",
       "  0.010290664620697498,\n",
       "  0.009760340675711632,\n",
       "  0.007086881436407566,\n",
       "  0.007011060602962971,\n",
       "  0.014270068146288395,\n",
       "  0.005553815979510546,\n",
       "  0.012976258993148804,\n",
       "  0.0055089727975428104,\n",
       "  0.005584106780588627,\n",
       "  0.015514791943132877,\n",
       "  0.013008682988584042,\n",
       "  0.00904802605509758,\n",
       "  0.005818679928779602,\n",
       "  0.006552914623171091,\n",
       "  0.015164935030043125,\n",
       "  0.009287161752581596,\n",
       "  0.007104524411261082,\n",
       "  0.00978163443505764,\n",
       "  0.01301945187151432,\n",
       "  0.007697723805904388,\n",
       "  0.015156126581132412,\n",
       "  0.008770531043410301,\n",
       "  0.009394633583724499,\n",
       "  0.005419741850346327,\n",
       "  0.007448808290064335,\n",
       "  0.00588294817134738,\n",
       "  0.013015974313020706,\n",
       "  0.010675192810595036,\n",
       "  0.007451159879565239,\n",
       "  0.01059806626290083,\n",
       "  0.010267664678394794,\n",
       "  0.007092433050274849,\n",
       "  0.005328301806002855,\n",
       "  0.010613027028739452,\n",
       "  0.01694445312023163,\n",
       "  0.007520218845456839,\n",
       "  0.005721644032746553,\n",
       "  0.01092613022774458,\n",
       "  0.0077025191858410835,\n",
       "  0.006060880143195391,\n",
       "  0.010732049122452736,\n",
       "  0.009775863960385323,\n",
       "  0.0074520418420434,\n",
       "  0.009144091047346592,\n",
       "  0.007527523208409548,\n",
       "  0.007705905940383673,\n",
       "  0.006530191749334335,\n",
       "  0.00996643491089344,\n",
       "  0.0053964764811098576,\n",
       "  0.005410952027887106,\n",
       "  0.006206418853253126,\n",
       "  0.010579860769212246,\n",
       "  0.016559269279241562,\n",
       "  0.010726860724389553,\n",
       "  0.006425997707992792,\n",
       "  0.007514891680330038,\n",
       "  0.01426646113395691,\n",
       "  0.015177366323769093,\n",
       "  0.015201812610030174,\n",
       "  0.00607324531301856,\n",
       "  0.012144030071794987,\n",
       "  0.0055411928333342075,\n",
       "  0.00904423650354147,\n",
       "  0.013013866730034351,\n",
       "  0.015214215964078903,\n",
       "  0.012998956255614758,\n",
       "  0.01437553483992815,\n",
       "  0.006061675492674112,\n",
       "  0.005509186070412397,\n",
       "  0.0055090514943003654,\n",
       "  0.007102638017386198,\n",
       "  0.007503347471356392,\n",
       "  0.007705859374254942,\n",
       "  0.007479272782802582,\n",
       "  0.009426901116967201,\n",
       "  0.012396185658872128,\n",
       "  0.007489006035029888,\n",
       "  0.014082138426601887,\n",
       "  0.009287675842642784,\n",
       "  0.00941700953990221,\n",
       "  0.006083553656935692,\n",
       "  0.010737362317740917,\n",
       "  0.007690301164984703,\n",
       "  0.016211211681365967,\n",
       "  0.01120862364768982,\n",
       "  0.007087258622050285,\n",
       "  0.005818260367959738,\n",
       "  0.014036940410733223,\n",
       "  0.005344984121620655,\n",
       "  0.010707653127610683,\n",
       "  0.010727675631642342,\n",
       "  0.005321937147527933,\n",
       "  0.0057938965037465096,\n",
       "  0.006686768494546413,\n",
       "  0.010279478505253792,\n",
       "  0.00834234245121479,\n",
       "  0.015518652275204659,\n",
       "  0.011517632752656937,\n",
       "  0.011075866408646107,\n",
       "  0.005634295754134655,\n",
       "  0.005415105726569891,\n",
       "  0.005790193565189838,\n",
       "  0.0063046556897461414,\n",
       "  0.007514095399528742,\n",
       "  0.005493578035384417,\n",
       "  0.0074289776384830475,\n",
       "  0.009377331472933292,\n",
       "  0.014044958166778088,\n",
       "  0.007706244941800833,\n",
       "  0.005634713917970657,\n",
       "  0.007428342010825872,\n",
       "  0.006303082220256329,\n",
       "  0.010782334953546524,\n",
       "  0.005554986651986837,\n",
       "  0.00618768809363246,\n",
       "  0.009290412999689579,\n",
       "  0.005323104560375214,\n",
       "  0.012396142818033695,\n",
       "  0.00539209833368659,\n",
       "  0.00538724334910512,\n",
       "  0.005359996110200882,\n",
       "  0.006076586898416281,\n",
       "  0.01060656551271677,\n",
       "  0.016224704682826996,\n",
       "  0.010605191811919212,\n",
       "  0.016229212284088135,\n",
       "  0.005317230708897114,\n",
       "  0.012696064077317715,\n",
       "  0.0071148197166621685,\n",
       "  0.011509723961353302,\n",
       "  0.00535004585981369,\n",
       "  0.007436142303049564,\n",
       "  0.010722116567194462,\n",
       "  0.013018591329455376,\n",
       "  0.011076724156737328,\n",
       "  0.005553359631448984,\n",
       "  0.009965518489480019,\n",
       "  0.00973469391465187,\n",
       "  0.014051227830350399,\n",
       "  0.010585714131593704,\n",
       "  0.010740076191723347,\n",
       "  0.005554753355681896,\n",
       "  0.006684168707579374],\n",
       " 'crps': 0.009019263088703156,\n",
       " 'nMeRCI_all': 0.7952120900154114,\n",
       " 'rmsce_all': 0.14643330872058868}"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "6090d363-b486-478d-9694-278e7526154d",
   "metadata": {},
   "outputs": [],
   "source": [
    "probconserv_stats_train = utils.compute_all_metrics_avg((new_mu, torch.square(new_std)), y_train, {})\n",
    "probconserv_stats_train[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, torch.square(new_std), y_train).item()\n",
    "probconserv_stats_train[\"rmsce_all\"] = utils.compute_rmsce(new_mu, torch.square(new_std), y_train).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "fbc2b1ac-a8a6-4991-bc08-aad3f87982e0",
   "metadata": {},
   "outputs": [],
   "source": [
    "cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "ucons_stats_train[\"cerr_by_example\"] = cerr.tolist()\n",
    "ucons_stats_train[\"mcerr\"] = cerr.mean().item()\n",
    "probconserv_stats_train[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "probconserv_stats_train[\"mcerr\"] = new_cerr.mean().item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "aa190002-f493-40a0-857d-79de73857da7",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_ood_test.to(device))\n",
    "\n",
    "x = ood_test_loader.dataset.tensors[0]\n",
    "y = ood_test_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "39e9bde3-2eba-4801-aa30-88c2c043ec20",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "2384c2df-e413-4a42-8107-977afa42306e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9dRTWLFiBfr161dmebVaDbVaXQmRERERUVVzqUQoOzsbZ86cMf2cmJiIgwcPwt/fH/Xq1cOkSZNw6dIlfP311wAKm8Pi4+Mxd+5cREdHIzk5GQDg5uYGHx+fKnkNREREVH241PD5LVu2oEePHiW2x8fHY+nSpRg+fDiSkpKwZcsWAIULZf7111+llrdFZmYmfHx8kJGRwT5CRNWE0WiETqer6jCIqAoplUrI5fJS99v6+e1SiVBVYCJEVL3odDokJibCaDRWdShEVMV8fX0REhJisUO0rZ/fLtU0RkS1mxACV65cgVwuR0REhNVJ0oio5hJCIDc3F6mpqQCA0NBQh8/FRIiIXIZer0dubi7CwsLg7u5e1eEQURVyc3MDAKSmpiIoKMhqM5k1/DpFRC7DYDAAAFQqVRVHQkTVQdEXooKCAofPwUSIiFwO1/0jIsA59wImQkRERFRrMREiIiKiWouJEBEREdVaTISIiGqg7t274+WXXy7x/6qMwxW4SrzXr19HUFAQkpKSqjqUCvPYY4/h448/rvDnYSJERFTD/fTTT3jnnXdsLu8qyUB19/nnn6N169bw9vaGt7c3YmJi8Ntvvznl3O+99x4efPBBREZGOuV81gwfPhySJJV4FC15VbT//fffNztu7dq1FjszX7hwAU899RTCwsKgUqlQv359vPTSS7h+/bpZuf/973947733kJGRUXEvDkyEiKiaytHqqzqEKuXMJUT8/f3h5eXltPPRLd27dy91yaa6devi/fffx759+7B3717ce++9ePDBB3H06NFyPWdubi4WLVqEkSNHlus8tih6H/bu3RtXrlwxezRo0MBUTqPR4IMPPkBaWprV8507dw4dOnTA6dOn8f333+PMmTNYsGABEhISEBMTgxs3bpjKtmzZEg0bNsS3335bMS/uJiZCRFQtZeYXQKevOctodO/eHWPHjsXYsWPh4+ODgIAATJ48GUWrHBXtf/nllxEQEIC4uDgAheuqzZgxAw0aNICbmxvatGmD1atXm507JycHw4YNg6enJ0JDQ0s0J9xew2M0GvHhhx+iUaNGUKvVqFevHt577z0Ahd/u//rrL8ydO9f0zT8pKckpcViybds2KJVK5Ofnm7YlJSVBkiT8999/Fo/ZsGEDunTpAl9fX9SpUwf3338/zp49W+I1v/jii3jttdfg7++PkJAQ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TxfHRMh29l7nHTt2iOjoaKFWq0VUVJR47733hF6vr+SoXY8917mgoEC8/fbbomHDhkKj0YiIiAjx/PPPi7S0tMoP3IVs3rzZ4j236NrGx8eLbt26lTimbdu2QqVSiaioKLFkyZIKjVESgnV6REREVDuxjxARERHVWkyEiIiIqNZiIkRERES1FhMhIiIiqrWYCBEREVGtxUSIiIiIai0mQkRERFRrMREiIiKiWouJEBEREdVaTISIiIio1mIiRES1ytWrVxESEoLp06ebtu3YsQMqlarEqtdEVPNxrTEiqnXWr1+PAQMGYMeOHWjSpAnatm2LBx98ELNmzarq0IiokjERIqJaacyYMfjzzz/RoUMHHD58GHv27IFara7qsIiokjERIqJaKS8vDy1btsSFCxewb98+tGrVqqpDIqIqwD5CRFQrnT17FpcvX4bRaERSUlJVh0NEVYQ1QkRU6+h0OnTs2BFt27ZFkyZNMGfOHBw+fBhBQUFVHRoRVTImQkRU67z66qtYvXo1Dh06BE9PT3Tr1g0+Pj749ddfqzo0IqpkbBojolply5YtmDNnDr755ht4e3tDJpPhm2++wdatW/H5559XdXhEVMlYI0RERES1FmuEiIiIqNZiIkRERES1FhMhIiIiqrWYCBEREVGtxUSIiIiIai0mQkRERFRrMREiIiKiWouJEBEREdVaTISIiIio1mIiRERERLUWEyEiIiKqtZgIERERUa31/xDUrw+79/fwAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 4\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_ood_test[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_ood_test[parameter_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "bbca5941-d33a-4608-b00c-99f5024fd3aa",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = ood_test_loader.dataset.tensors[0]\n",
    "y = ood_test_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "    mu=mu[:, :, :, 0], \n",
    "    std=std[:, :, :, 0], \n",
    "    mass_rhs_func=mass_rhs_func, \n",
    "    t=t, \n",
    "    tpred=tpred, \n",
    "    grid_train=grid, \n",
    "    precis_g=np.inf,\n",
    "    second_deriv_alpha=None,\n",
    ")\n",
    "new_mu = new_mu[:, :, :, None]\n",
    "new_std = new_std[:, :, :, None]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "6b809290-3cb4-4d19-a03a-ed6435a705a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.2825)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 4\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_ood_test[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_ood_test[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_ood_test[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "f5762b3e-644a-4cae-ac0f-5ab97ce326bf",
   "metadata": {},
   "outputs": [],
   "source": [
    "ucons_stats_test = utils.compute_all_metrics_avg((mu, torch.square(std)), y_ood_test, {})\n",
    "ucons_stats_test[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, torch.square(std), y_ood_test).item()\n",
    "ucons_stats_test[\"rmsce_all\"] = utils.compute_rmsce(mu, torch.square(std), y_ood_test).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "053bdcfd-e155-4a61-9532-50a72beda9c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "probconserv_stats_test = utils.compute_all_metrics_avg((new_mu, torch.square(new_std)), y_ood_test, {})\n",
    "probconserv_stats_test[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, torch.square(new_std), y_ood_test).item()\n",
    "probconserv_stats_test[\"rmsce_all\"] = utils.compute_rmsce(new_mu, torch.square(new_std), y_ood_test).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "973a1ea0-a774-4d8a-9947-fabe05d76bfc",
   "metadata": {},
   "outputs": [],
   "source": [
    "cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "ucons_stats_test[\"cerr_by_example\"] = cerr.tolist()\n",
    "ucons_stats_test[\"mcerr\"] = cerr.mean().item()\n",
    "probconserv_stats_test[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "probconserv_stats_test[\"mcerr\"] = new_cerr.mean().item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "da438412-1398-430d-ba74-82db34174f39",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.0014267205260694027,\n",
       "  0.00444853026419878,\n",
       "  0.00513400137424469,\n",
       "  0.005158242769539356,\n",
       "  0.0024629903491586447,\n",
       "  0.0021592930424958467,\n",
       "  0.0014260878087952733,\n",
       "  0.006635133642703295,\n",
       "  0.001456900266930461,\n",
       "  0.00215919385664165,\n",
       "  0.00201966124586761,\n",
       "  0.0016415445134043694,\n",
       "  0.007087093777954578,\n",
       "  0.0044428096152842045,\n",
       "  0.0025615599006414413,\n",
       "  0.0014456723583862185,\n",
       "  0.002973332768306136,\n",
       "  0.00477535929530859,\n",
       "  0.0045839110389351845,\n",
       "  0.002874194411560893,\n",
       "  0.002607774455100298,\n",
       "  0.007209554314613342,\n",
       "  0.001640663598664105,\n",
       "  0.006435875780880451,\n",
       "  0.001600691699422896,\n",
       "  0.0015920362202450633,\n",
       "  0.007967252284288406,\n",
       "  0.006447898223996162,\n",
       "  0.004139324184507132,\n",
       "  0.0018701591761782765,\n",
       "  0.0024622937198728323,\n",
       "  0.007778361439704895,\n",
       "  0.0042872647754848,\n",
       "  0.002869904274120927,\n",
       "  0.004578666761517525,\n",
       "  0.006444946397095919,\n",
       "  0.0032191257923841476,\n",
       "  0.007778123486787081,\n",
       "  0.0038541960529983044,\n",
       "  0.004274004604667425,\n",
       "  0.0014638942666351795,\n",
       "  0.0030946077313274145,\n",
       "  0.0018313054461032152,\n",
       "  0.006445898674428463,\n",
       "  0.005161991808563471,\n",
       "  0.003094085957854986,\n",
       "  0.004951290786266327,\n",
       "  0.0047749681398272514,\n",
       "  0.0028728062752634287,\n",
       "  0.0014148327754810452,\n",
       "  0.004951552487909794,\n",
       "  0.008791239932179451,\n",
       "  0.002973369089886546,\n",
       "  0.0017031998140737414,\n",
       "  0.005132314283400774,\n",
       "  0.003218176309019327,\n",
       "  0.0019827967043966055,\n",
       "  0.00514725036919117,\n",
       "  0.004580073058605194,\n",
       "  0.00309389247559011,\n",
       "  0.0041239093989133835,\n",
       "  0.0029734927229583263,\n",
       "  0.003217511111870408,\n",
       "  0.0022820348385721445,\n",
       "  0.00460808677598834,\n",
       "  0.0014987107133492827,\n",
       "  0.0014632183592766523,\n",
       "  0.002075193217024207,\n",
       "  0.004950971342623234,\n",
       "  0.00858326442539692,\n",
       "  0.005148554220795631,\n",
       "  0.0023651369847357273,\n",
       "  0.0029732792172580957,\n",
       "  0.007209462113678455,\n",
       "  0.007778697181493044,\n",
       "  0.007779358886182308,\n",
       "  0.0019831627141684294,\n",
       "  0.005959550850093365,\n",
       "  0.0015606599627062678,\n",
       "  0.00414024293422699,\n",
       "  0.00644647516310215,\n",
       "  0.007779693230986595,\n",
       "  0.006436390336602926,\n",
       "  0.007247551344335079,\n",
       "  0.0019828209187835455,\n",
       "  0.0016000254545360804,\n",
       "  0.0016003826167434454,\n",
       "  0.002870346885174513,\n",
       "  0.0029730829410254955,\n",
       "  0.003217519959434867,\n",
       "  0.0029726726934313774,\n",
       "  0.0042745135724544525,\n",
       "  0.006072684191167355,\n",
       "  0.00297283916734159,\n",
       "  0.007074735593050718,\n",
       "  0.0042871409095823765,\n",
       "  0.004274357575923204,\n",
       "  0.001983462832868099,\n",
       "  0.005145919043570757,\n",
       "  0.003220613580197096,\n",
       "  0.008377613499760628,\n",
       "  0.005319399293512106,\n",
       "  0.0028740973211824894,\n",
       "  0.001870329026132822,\n",
       "  0.007088086102157831,\n",
       "  0.0014261819887906313,\n",
       "  0.005153454374521971,\n",
       "  0.005148349329829216,\n",
       "  0.001413805759511888,\n",
       "  0.0017613668460398912,\n",
       "  0.0025619775988161564,\n",
       "  0.0047751679085195065,\n",
       "  0.0036522787995636463,\n",
       "  0.007967359386384487,\n",
       "  0.005510724149644375,\n",
       "  0.005298761185258627,\n",
       "  0.001704563619568944,\n",
       "  0.0014635429251939058,\n",
       "  0.0017612290102988482,\n",
       "  0.0021584350615739822,\n",
       "  0.002973265713080764,\n",
       "  0.0015355217037722468,\n",
       "  0.0030991605017334223,\n",
       "  0.004273730795830488,\n",
       "  0.007085689343512058,\n",
       "  0.0032174447551369667,\n",
       "  0.0017044205451384187,\n",
       "  0.0030993111431598663,\n",
       "  0.0022667020093649626,\n",
       "  0.0051349494606256485,\n",
       "  0.0016400049207732081,\n",
       "  0.0020746879745274782,\n",
       "  0.004286475945264101,\n",
       "  0.0014140092534944415,\n",
       "  0.00607268325984478,\n",
       "  0.0014929238241165876,\n",
       "  0.0014452149625867605,\n",
       "  0.0014570601051673293,\n",
       "  0.0019832609687000513,\n",
       "  0.004951439797878265,\n",
       "  0.008378001861274242,\n",
       "  0.004951414652168751,\n",
       "  0.008378134109079838,\n",
       "  0.0014128843322396278,\n",
       "  0.006284216418862343,\n",
       "  0.0028675429057329893,\n",
       "  0.005510569550096989,\n",
       "  0.0014267718652263284,\n",
       "  0.0030974813271313906,\n",
       "  0.005149755161255598,\n",
       "  0.006445182953029871,\n",
       "  0.005298555828630924,\n",
       "  0.001640946022234857,\n",
       "  0.004608070943504572,\n",
       "  0.004448639694601297,\n",
       "  0.007083825301378965,\n",
       "  0.004951073322445154,\n",
       "  0.00514524569734931,\n",
       "  0.0016401290195062757,\n",
       "  0.0025626071728765965],\n",
       " 'mse': 0.003934333473443985,\n",
       " 'nll_by_example': [-9608.55078125,\n",
       "  -7294.361328125,\n",
       "  -7346.646484375,\n",
       "  -7825.19580078125,\n",
       "  -9318.21484375,\n",
       "  -8899.41796875,\n",
       "  -9621.076171875,\n",
       "  -4389.72509765625,\n",
       "  -9662.6669921875,\n",
       "  -8913.830078125,\n",
       "  -9496.9111328125,\n",
       "  -9633.4072265625,\n",
       "  -5652.4267578125,\n",
       "  -8246.5107421875,\n",
       "  -9247.30859375,\n",
       "  -9550.080078125,\n",
       "  -8269.828125,\n",
       "  -6777.587890625,\n",
       "  -8166.703125,\n",
       "  -9177.7001953125,\n",
       "  -8450.4140625,\n",
       "  -3807.164306640625,\n",
       "  -9625.9287109375,\n",
       "  -5047.947265625,\n",
       "  -9654.9580078125,\n",
       "  -9418.2080078125,\n",
       "  -2611.203369140625,\n",
       "  -6070.7744140625,\n",
       "  -8419.8623046875,\n",
       "  -9572.67578125,\n",
       "  -9306.740234375,\n",
       "  -3142.568359375,\n",
       "  -8327.3896484375,\n",
       "  -9103.6875,\n",
       "  -8066.3740234375,\n",
       "  -6013.2734375,\n",
       "  -8652.98046875,\n",
       "  -3195.19091796875,\n",
       "  -7941.1796875,\n",
       "  -7677.9287109375,\n",
       "  -9524.7451171875,\n",
       "  -8926.109375,\n",
       "  -9250.650390625,\n",
       "  -6031.9130859375,\n",
       "  -7893.90478515625,\n",
       "  -8916.11328125,\n",
       "  -6497.53369140625,\n",
       "  -6888.8701171875,\n",
       "  -9154.3681640625,\n",
       "  -9635.322265625,\n",
       "  -6422.6630859375,\n",
       "  1301.4114990234375,\n",
       "  -8261.1416015625,\n",
       "  -9346.23046875,\n",
       "  -6126.3017578125,\n",
       "  -8632.328125,\n",
       "  -9196.732421875,\n",
       "  -7615.51123046875,\n",
       "  -8093.63671875,\n",
       "  -8912.36328125,\n",
       "  -7892.8974609375,\n",
       "  -8231.3759765625,\n",
       "  -8617.724609375,\n",
       "  -8751.9951171875,\n",
       "  -7193.7734375,\n",
       "  -9665.4501953125,\n",
       "  -9548.173828125,\n",
       "  -9041.373046875,\n",
       "  -6587.97998046875,\n",
       "  20.390228271484375,\n",
       "  -7641.04833984375,\n",
       "  -9363.7451171875,\n",
       "  -8282.7626953125,\n",
       "  -3828.17529296875,\n",
       "  -3067.89697265625,\n",
       "  -2920.0986328125,\n",
       "  -9155.947265625,\n",
       "  -6765.0107421875,\n",
       "  -9448.771484375,\n",
       "  -8437.15234375,\n",
       "  -6043.1435546875,\n",
       "  -2844.583740234375,\n",
       "  -4923.05615234375,\n",
       "  -5180.68017578125,\n",
       "  -9194.1220703125,\n",
       "  -9651.5556640625,\n",
       "  -9653.439453125,\n",
       "  -9111.56640625,\n",
       "  -8329.384765625,\n",
       "  -8617.9228515625,\n",
       "  -8425.431640625,\n",
       "  -7534.05322265625,\n",
       "  -5440.916015625,\n",
       "  -8386.7900390625,\n",
       "  -5421.8759765625,\n",
       "  -8325.056640625,\n",
       "  -7578.40576171875,\n",
       "  -9121.5283203125,\n",
       "  -7589.3349609375,\n",
       "  -8684.9189453125,\n",
       "  -481.4311828613281,\n",
       "  -6054.8876953125,\n",
       "  -9176.099609375,\n",
       "  -9574.5888671875,\n",
       "  -5670.66748046875,\n",
       "  -9619.306640625,\n",
       "  -7735.34716796875,\n",
       "  -7637.0615234375,\n",
       "  -9648.5224609375,\n",
       "  -9305.5908203125,\n",
       "  -9254.470703125,\n",
       "  -6831.85400390625,\n",
       "  -8529.328125,\n",
       "  -2587.306396484375,\n",
       "  -5858.76953125,\n",
       "  -7184.35498046875,\n",
       "  -9579.98046875,\n",
       "  -9537.1708984375,\n",
       "  -9317.1591796875,\n",
       "  -9020.2294921875,\n",
       "  -8285.986328125,\n",
       "  -9511.525390625,\n",
       "  -9010.3515625,\n",
       "  -7754.09814453125,\n",
       "  -5626.681640625,\n",
       "  -8616.2314453125,\n",
       "  -9578.1728515625,\n",
       "  -9013.0498046875,\n",
       "  -9401.8916015625,\n",
       "  -7366.44677734375,\n",
       "  -9619.8017578125,\n",
       "  -9105.2158203125,\n",
       "  -8312.4267578125,\n",
       "  -9646.1904296875,\n",
       "  -5441.14990234375,\n",
       "  -9665.1650390625,\n",
       "  -9563.87109375,\n",
       "  -9661.9765625,\n",
       "  -9144.830078125,\n",
       "  -6455.0634765625,\n",
       "  -395.15545654296875,\n",
       "  -6461.92578125,\n",
       "  -366.2185974121094,\n",
       "  -9657.3544921875,\n",
       "  -6362.9228515625,\n",
       "  -9060.5986328125,\n",
       "  -5899.9541015625,\n",
       "  -9607.45703125,\n",
       "  -8979.904296875,\n",
       "  -7664.3544921875,\n",
       "  -6017.9296875,\n",
       "  -7180.017578125,\n",
       "  -9628.41015625,\n",
       "  -7198.02490234375,\n",
       "  -7263.2685546875,\n",
       "  -5592.27490234375,\n",
       "  -6558.9697265625,\n",
       "  -7575.9384765625,\n",
       "  -9620.9921875,\n",
       "  -9265.189453125],\n",
       " 'nll': -7646.55859375,\n",
       " 'piw_by_example': [0.05645707994699478,\n",
       "  0.05624809488654137,\n",
       "  0.05677349120378494,\n",
       "  0.056739527732133865,\n",
       "  0.056603141129016876,\n",
       "  0.05635097622871399,\n",
       "  0.05646185204386711,\n",
       "  0.05615010857582092,\n",
       "  0.05648843199014664,\n",
       "  0.056352321058511734,\n",
       "  0.05657099559903145,\n",
       "  0.05653011426329613,\n",
       "  0.056825198233127594,\n",
       "  0.05671083182096481,\n",
       "  0.05661363899707794,\n",
       "  0.05643991380929947,\n",
       "  0.05630214512348175,\n",
       "  0.05622377619147301,\n",
       "  0.0567169263958931,\n",
       "  0.05662264674901962,\n",
       "  0.05631447210907936,\n",
       "  0.05613580346107483,\n",
       "  0.05653366819024086,\n",
       "  0.0561671145260334,\n",
       "  0.05651640519499779,\n",
       "  0.056413400918245316,\n",
       "  0.05610719323158264,\n",
       "  0.05681437626481056,\n",
       "  0.05669807270169258,\n",
       "  0.05655200034379959,\n",
       "  0.056604936718940735,\n",
       "  0.056123003363609314,\n",
       "  0.05670534446835518,\n",
       "  0.05663231015205383,\n",
       "  0.05672498419880867,\n",
       "  0.05681784451007843,\n",
       "  0.056680258363485336,\n",
       "  0.05612468346953392,\n",
       "  0.0562826544046402,\n",
       "  0.056267913430929184,\n",
       "  0.05643390491604805,\n",
       "  0.05665263906121254,\n",
       "  0.05638902261853218,\n",
       "  0.05681673809885979,\n",
       "  0.05673431232571602,\n",
       "  0.05665375664830208,\n",
       "  0.05621194466948509,\n",
       "  0.05622900649905205,\n",
       "  0.056625768542289734,\n",
       "  0.05646810680627823,\n",
       "  0.05620865523815155,\n",
       "  0.056073471903800964,\n",
       "  0.05630156770348549,\n",
       "  0.056402143090963364,\n",
       "  0.05619684234261513,\n",
       "  0.05668222904205322,\n",
       "  0.0563824363052845,\n",
       "  0.05675486475229263,\n",
       "  0.05672283470630646,\n",
       "  0.056654155254364014,\n",
       "  0.05628024414181709,\n",
       "  0.05629952996969223,\n",
       "  0.05668359994888306,\n",
       "  0.056337933987379074,\n",
       "  0.05624329671263695,\n",
       "  0.05650291591882706,\n",
       "  0.05643947422504425,\n",
       "  0.05636497959494591,\n",
       "  0.056215982884168625,\n",
       "  0.05608637258410454,\n",
       "  0.05675305426120758,\n",
       "  0.056595899164676666,\n",
       "  0.05630304291844368,\n",
       "  0.05613650754094124,\n",
       "  0.05612063780426979,\n",
       "  0.0561160147190094,\n",
       "  0.05637755244970322,\n",
       "  0.05679165944457054,\n",
       "  0.05641873553395271,\n",
       "  0.05669654160737991,\n",
       "  0.05681604519486427,\n",
       "  0.05611367151141167,\n",
       "  0.056162524968385696,\n",
       "  0.05684169754385948,\n",
       "  0.05638210475444794,\n",
       "  0.05651922896504402,\n",
       "  0.05651773139834404,\n",
       "  0.05663129687309265,\n",
       "  0.05630628019571304,\n",
       "  0.056683581322431564,\n",
       "  0.05631319060921669,\n",
       "  0.05625985935330391,\n",
       "  0.05617951229214668,\n",
       "  0.056310366839170456,\n",
       "  0.05683864653110504,\n",
       "  0.0567055381834507,\n",
       "  0.05626230686903,\n",
       "  0.05637358874082565,\n",
       "  0.05675674229860306,\n",
       "  0.05667717382311821,\n",
       "  0.05609377846121788,\n",
       "  0.056195564568042755,\n",
       "  0.05662287399172783,\n",
       "  0.05655142292380333,\n",
       "  0.05682411417365074,\n",
       "  0.05646112933754921,\n",
       "  0.05674619972705841,\n",
       "  0.056753333657979965,\n",
       "  0.0564754419028759,\n",
       "  0.05639635771512985,\n",
       "  0.056612592190504074,\n",
       "  0.05622631683945656,\n",
       "  0.05668990686535835,\n",
       "  0.056106485426425934,\n",
       "  0.05619116872549057,\n",
       "  0.056781403720378876,\n",
       "  0.05655033886432648,\n",
       "  0.056436799466609955,\n",
       "  0.05639797821640968,\n",
       "  0.056362882256507874,\n",
       "  0.05630326643586159,\n",
       "  0.05643110349774361,\n",
       "  0.05664302408695221,\n",
       "  0.056272316724061966,\n",
       "  0.05682672560214996,\n",
       "  0.0566837415099144,\n",
       "  0.05655090883374214,\n",
       "  0.05664271116256714,\n",
       "  0.05658944696187973,\n",
       "  0.05677216127514839,\n",
       "  0.05653635039925575,\n",
       "  0.05637187883257866,\n",
       "  0.05670661851763725,\n",
       "  0.056473974138498306,\n",
       "  0.05617951229214668,\n",
       "  0.056493859738111496,\n",
       "  0.0564434714615345,\n",
       "  0.056487493216991425,\n",
       "  0.056376248598098755,\n",
       "  0.05621007829904556,\n",
       "  0.0560913011431694,\n",
       "  0.05621037259697914,\n",
       "  0.056090474128723145,\n",
       "  0.05648209899663925,\n",
       "  0.056802891194820404,\n",
       "  0.056637633591890335,\n",
       "  0.05619285628199577,\n",
       "  0.05645669624209404,\n",
       "  0.05664656311273575,\n",
       "  0.05675136297941208,\n",
       "  0.05681757628917694,\n",
       "  0.05678168311715126,\n",
       "  0.05653253570199013,\n",
       "  0.05624350905418396,\n",
       "  0.05624648928642273,\n",
       "  0.05682874098420143,\n",
       "  0.05621468275785446,\n",
       "  0.05675768479704857,\n",
       "  0.05653584003448486,\n",
       "  0.05661103129386902],\n",
       " 'piw': 0.05647381544113159,\n",
       " 'crps_by_example': [0.005349585320800543,\n",
       "  0.009727968834340572,\n",
       "  0.01078631542623043,\n",
       "  0.010689286515116692,\n",
       "  0.006550121586769819,\n",
       "  0.006339007057249546,\n",
       "  0.005344213452190161,\n",
       "  0.013360683806240559,\n",
       "  0.005359490867704153,\n",
       "  0.006334967911243439,\n",
       "  0.006008056458085775,\n",
       "  0.005552490241825581,\n",
       "  0.014040261507034302,\n",
       "  0.009540495462715626,\n",
       "  0.006688511464744806,\n",
       "  0.005392557941377163,\n",
       "  0.007518084719777107,\n",
       "  0.010290664620697498,\n",
       "  0.009760340675711632,\n",
       "  0.007086881436407566,\n",
       "  0.007011060602962971,\n",
       "  0.014270068146288395,\n",
       "  0.005553815979510546,\n",
       "  0.012976258993148804,\n",
       "  0.0055089727975428104,\n",
       "  0.005584106780588627,\n",
       "  0.015514791943132877,\n",
       "  0.013008682988584042,\n",
       "  0.00904802605509758,\n",
       "  0.005818679928779602,\n",
       "  0.006552914623171091,\n",
       "  0.015164935030043125,\n",
       "  0.009287161752581596,\n",
       "  0.007104524411261082,\n",
       "  0.00978163443505764,\n",
       "  0.01301945187151432,\n",
       "  0.007697723805904388,\n",
       "  0.015156126581132412,\n",
       "  0.008770531043410301,\n",
       "  0.009394633583724499,\n",
       "  0.005419741850346327,\n",
       "  0.007448808290064335,\n",
       "  0.00588294817134738,\n",
       "  0.013015974313020706,\n",
       "  0.010675192810595036,\n",
       "  0.007451159879565239,\n",
       "  0.01059806626290083,\n",
       "  0.010267664678394794,\n",
       "  0.007092433050274849,\n",
       "  0.005328301806002855,\n",
       "  0.010613027028739452,\n",
       "  0.01694445312023163,\n",
       "  0.007520218845456839,\n",
       "  0.005721644032746553,\n",
       "  0.01092613022774458,\n",
       "  0.0077025191858410835,\n",
       "  0.006060880143195391,\n",
       "  0.010732049122452736,\n",
       "  0.009775863960385323,\n",
       "  0.0074520418420434,\n",
       "  0.009144091047346592,\n",
       "  0.007527523208409548,\n",
       "  0.007705905940383673,\n",
       "  0.006530191749334335,\n",
       "  0.00996643491089344,\n",
       "  0.0053964764811098576,\n",
       "  0.005410952027887106,\n",
       "  0.006206418853253126,\n",
       "  0.010579860769212246,\n",
       "  0.016559269279241562,\n",
       "  0.010726860724389553,\n",
       "  0.006425997707992792,\n",
       "  0.007514891680330038,\n",
       "  0.01426646113395691,\n",
       "  0.015177366323769093,\n",
       "  0.015201812610030174,\n",
       "  0.00607324531301856,\n",
       "  0.012144030071794987,\n",
       "  0.0055411928333342075,\n",
       "  0.00904423650354147,\n",
       "  0.013013866730034351,\n",
       "  0.015214215964078903,\n",
       "  0.012998956255614758,\n",
       "  0.01437553483992815,\n",
       "  0.006061675492674112,\n",
       "  0.005509186070412397,\n",
       "  0.0055090514943003654,\n",
       "  0.007102638017386198,\n",
       "  0.007503347471356392,\n",
       "  0.007705859374254942,\n",
       "  0.007479272782802582,\n",
       "  0.009426901116967201,\n",
       "  0.012396185658872128,\n",
       "  0.007489006035029888,\n",
       "  0.014082138426601887,\n",
       "  0.009287675842642784,\n",
       "  0.00941700953990221,\n",
       "  0.006083553656935692,\n",
       "  0.010737362317740917,\n",
       "  0.007690301164984703,\n",
       "  0.016211211681365967,\n",
       "  0.01120862364768982,\n",
       "  0.007087258622050285,\n",
       "  0.005818260367959738,\n",
       "  0.014036940410733223,\n",
       "  0.005344984121620655,\n",
       "  0.010707653127610683,\n",
       "  0.010727675631642342,\n",
       "  0.005321937147527933,\n",
       "  0.0057938965037465096,\n",
       "  0.006686768494546413,\n",
       "  0.010279478505253792,\n",
       "  0.00834234245121479,\n",
       "  0.015518652275204659,\n",
       "  0.011517632752656937,\n",
       "  0.011075866408646107,\n",
       "  0.005634295754134655,\n",
       "  0.005415105726569891,\n",
       "  0.005790193565189838,\n",
       "  0.0063046556897461414,\n",
       "  0.007514095399528742,\n",
       "  0.005493578035384417,\n",
       "  0.0074289776384830475,\n",
       "  0.009377331472933292,\n",
       "  0.014044958166778088,\n",
       "  0.007706244941800833,\n",
       "  0.005634713917970657,\n",
       "  0.007428342010825872,\n",
       "  0.006303082220256329,\n",
       "  0.010782334953546524,\n",
       "  0.005554986651986837,\n",
       "  0.00618768809363246,\n",
       "  0.009290412999689579,\n",
       "  0.005323104560375214,\n",
       "  0.012396142818033695,\n",
       "  0.00539209833368659,\n",
       "  0.00538724334910512,\n",
       "  0.005359996110200882,\n",
       "  0.006076586898416281,\n",
       "  0.01060656551271677,\n",
       "  0.016224704682826996,\n",
       "  0.010605191811919212,\n",
       "  0.016229212284088135,\n",
       "  0.005317230708897114,\n",
       "  0.012696064077317715,\n",
       "  0.0071148197166621685,\n",
       "  0.011509723961353302,\n",
       "  0.00535004585981369,\n",
       "  0.007436142303049564,\n",
       "  0.010722116567194462,\n",
       "  0.013018591329455376,\n",
       "  0.011076724156737328,\n",
       "  0.005553359631448984,\n",
       "  0.009965518489480019,\n",
       "  0.00973469391465187,\n",
       "  0.014051227830350399,\n",
       "  0.010585714131593704,\n",
       "  0.010740076191723347,\n",
       "  0.005554753355681896,\n",
       "  0.006684168707579374],\n",
       " 'crps': 0.009019263088703156,\n",
       " 'nMeRCI_all': 0.7952120900154114,\n",
       " 'rmsce_all': 0.14643330872058868,\n",
       " 'cerr_by_example': [0.011166437529027462,\n",
       "  0.18313875794410706,\n",
       "  0.261165976524353,\n",
       "  0.2339150607585907,\n",
       "  0.12304434925317764,\n",
       "  0.0957031100988388,\n",
       "  0.010300561785697937,\n",
       "  0.2678021192550659,\n",
       "  0.027925100177526474,\n",
       "  0.09455607831478119,\n",
       "  0.0965629369020462,\n",
       "  0.06267981976270676,\n",
       "  0.30235016345977783,\n",
       "  0.21078525483608246,\n",
       "  0.131663978099823,\n",
       "  0.021985333412885666,\n",
       "  0.1370067298412323,\n",
       "  0.2040276974439621,\n",
       "  0.21570971608161926,\n",
       "  0.13905733823776245,\n",
       "  0.12655200064182281,\n",
       "  0.2802719473838806,\n",
       "  0.0656476691365242,\n",
       "  0.25300800800323486,\n",
       "  0.0512944720685482,\n",
       "  0.043482955545186996,\n",
       "  0.3053145408630371,\n",
       "  0.29375383257865906,\n",
       "  0.20047716796398163,\n",
       "  0.08085280656814575,\n",
       "  0.12452521920204163,\n",
       "  0.2914709150791168,\n",
       "  0.20634835958480835,\n",
       "  0.14695894718170166,\n",
       "  0.22221198678016663,\n",
       "  0.29651710391044617,\n",
       "  0.18603357672691345,\n",
       "  0.29000261425971985,\n",
       "  0.15360680222511292,\n",
       "  0.16617724299430847,\n",
       "  0.02684003673493862,\n",
       "  0.16356147825717926,\n",
       "  0.06373660266399384,\n",
       "  0.29562753438949585,\n",
       "  0.22972168028354645,\n",
       "  0.16446441411972046,\n",
       "  0.21421121060848236,\n",
       "  0.19952228665351868,\n",
       "  0.14160916209220886,\n",
       "  0.012512275949120522,\n",
       "  0.21705378592014313,\n",
       "  0.3350009024143219,\n",
       "  0.1375119388103485,\n",
       "  0.05275875702500343,\n",
       "  0.22725839912891388,\n",
       "  0.18763110041618347,\n",
       "  0.06926796585321426,\n",
       "  0.2462434619665146,\n",
       "  0.22046808898448944,\n",
       "  0.16479703783988953,\n",
       "  0.15564784407615662,\n",
       "  0.139231339097023,\n",
       "  0.18875275552272797,\n",
       "  0.10670378804206848,\n",
       "  0.18724961578845978,\n",
       "  0.040023475885391235,\n",
       "  0.022339796647429466,\n",
       "  0.0839121863245964,\n",
       "  0.21073095500469208,\n",
       "  0.323621541261673,\n",
       "  0.24477963149547577,\n",
       "  0.1170874685049057,\n",
       "  0.13625019788742065,\n",
       "  0.2796610891819,\n",
       "  0.29354116320610046,\n",
       "  0.2975943982601166,\n",
       "  0.07335494458675385,\n",
       "  0.27568185329437256,\n",
       "  0.03915749117732048,\n",
       "  0.1992385983467102,\n",
       "  0.29508569836616516,\n",
       "  0.29964202642440796,\n",
       "  0.2570040225982666,\n",
       "  0.315423846244812,\n",
       "  0.06953385472297668,\n",
       "  0.05363640934228897,\n",
       "  0.052381813526153564,\n",
       "  0.14614033699035645,\n",
       "  0.13349656760692596,\n",
       "  0.1887373924255371,\n",
       "  0.12764927744865417,\n",
       "  0.17306312918663025,\n",
       "  0.24226248264312744,\n",
       "  0.1300317347049713,\n",
       "  0.31301140785217285,\n",
       "  0.20651094615459442,\n",
       "  0.1709688901901245,\n",
       "  0.07667534053325653,\n",
       "  0.24774080514907837,\n",
       "  0.18353170156478882,\n",
       "  0.31710878014564514,\n",
       "  0.22835847735404968,\n",
       "  0.13923504948616028,\n",
       "  0.08037714660167694,\n",
       "  0.3014942407608032,\n",
       "  0.01035664789378643,\n",
       "  0.239279106259346,\n",
       "  0.24500924348831177,\n",
       "  0.01716373674571514,\n",
       "  0.057603925466537476,\n",
       "  0.1308078169822693,\n",
       "  0.20184342563152313,\n",
       "  0.1938580572605133,\n",
       "  0.30594632029533386,\n",
       "  0.23215240240097046,\n",
       "  0.2674817442893982,\n",
       "  0.07947900891304016,\n",
       "  0.02450663410127163,\n",
       "  0.056238092482089996,\n",
       "  0.08567862212657928,\n",
       "  0.13606147468090057,\n",
       "  0.029121732339262962,\n",
       "  0.15571679174900055,\n",
       "  0.16242018342018127,\n",
       "  0.30355969071388245,\n",
       "  0.18886372447013855,\n",
       "  0.07994335889816284,\n",
       "  0.1554577350616455,\n",
       "  0.1117793619632721,\n",
       "  0.26009711623191833,\n",
       "  0.06786979734897614,\n",
       "  0.07811286300420761,\n",
       "  0.20738200843334198,\n",
       "  0.016004402190446854,\n",
       "  0.24225491285324097,\n",
       "  0.03246475011110306,\n",
       "  0.01920865848660469,\n",
       "  0.02712453156709671,\n",
       "  0.07444079965353012,\n",
       "  0.21582677960395813,\n",
       "  0.3192850351333618,\n",
       "  0.21556726098060608,\n",
       "  0.3200109601020813,\n",
       "  0.02261635661125183,\n",
       "  0.2846289873123169,\n",
       "  0.15132133662700653,\n",
       "  0.2306997925043106,\n",
       "  0.011304851621389389,\n",
       "  0.15860626101493835,\n",
       "  0.24342963099479675,\n",
       "  0.2962966561317444,\n",
       "  0.26770833134651184,\n",
       "  0.06469550728797913,\n",
       "  0.18706396222114563,\n",
       "  0.18451613187789917,\n",
       "  0.3051668405532837,\n",
       "  0.21185283362865448,\n",
       "  0.2484986037015915,\n",
       "  0.06744993478059769,\n",
       "  0.12951570749282837],\n",
       " 'mcerr': 0.1673741638660431}"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09f0df61-ed39-4fe8-8463-87a363b11ef6",
   "metadata": {},
   "source": [
    "## E2E Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "c36a3814-61c7-4f14-a367-bad3828213de",
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\" \n",
    "experiment_name = \"trial\"\n",
    "# print(f\"Experiment: {experiment_name}\")\n",
    "# print(args)\n",
    "save_args = utils.filter_config(args, [\"generate\", \"--no_train\", \"--ood_dataset_params\", \"--tplot\"], mode=\"remove\")  # Also removes \".\" keys\n",
    "\n",
    "is_train = not bool(args[\"--no_train\"])\n",
    "\n",
    "# Parameters\n",
    "n_x = int(args[\"--grid_len\"])\n",
    "n_t = int(args[\"--time_len\"])\n",
    "n_samples = int(args[\"--n_samples\"])\n",
    "n_train = int(0.8 * n_samples)\n",
    "n_valid = int(0.2 * n_samples)\n",
    "n_test = n_samples // 2\n",
    "\n",
    "is_markov = False\n",
    "\n",
    "dataset = args[\"--dataset\"]\n",
    "dataset_params = [float(val) for val in args[\"--dataset_params\"].split(\",\")]\n",
    "train_ood_dataset_params = [float(val) for val in args[\"--train_ood_dataset_params\"].split(\",\")]\n",
    "ood_dataset_params = train_ood_dataset_params\n",
    "if not is_train:\n",
    "    ood_dataset_params = [float(val) for val in args[\"--ood_dataset_params\"].split(\",\")]\n",
    "\n",
    "tpred = [int(val) for val in args[\"--predict_time\"].split(\",\")]\n",
    "\n",
    "fno_modes = int(args[\"--fno_modes\"])\n",
    "fno_width = int(args[\"--fno_width\"])\n",
    "\n",
    "batch_size = int(args[\"--batch_size\"])\n",
    "lr = float(args[\"--lr\"])\n",
    "epochs = int(args[\"--epochs\"])\n",
    "step_size = 50\n",
    "gamma = 0.5\n",
    "# ################\n",
    "\n",
    "# Set seed\n",
    "utils.set_seed(int(args[\"--seed\"]))\n",
    "\n",
    "# Generate dataset\n",
    "if dataset.lower() == \"HeatEquation_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 2 * np.pi, n_x)\n",
    "    dataset_class = HeatEquation_1D\n",
    "elif dataset.lower() == \"PME_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = PME_1D\n",
    "elif dataset.lower() == \"StefanPME_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = StefanPME_1D\n",
    "elif dataset.lower() == \"LinearAdvection_1D\".lower():\n",
    "    t = torch.linspace(0, 1, n_t)\n",
    "    grid = torch.linspace(0, 1, n_x)\n",
    "    dataset_class = LinearAdvection_1D\n",
    "else:\n",
    "    raise NotImplementedError\n",
    "\n",
    "t_sliced = t[slice(*tpred)]\n",
    "T = len(t_sliced)\n",
    "\n",
    "def get_xy_from_pu(p, u, is_markov=False):\n",
    "    T = u.shape[2]\n",
    "    #TODO: What does is_markov do here?\n",
    "    if is_markov:\n",
    "        x0, y0 = p, u\n",
    "        \n",
    "        y0_vectorized = rearrange(y0[:, :, 0:T-1], \"nf nx nt 1 -> (nf nt) nx 1\")\n",
    "        x0 = repeat(x0, \"nf nx 1 -> (nf nt) nx 1\", nt=T-1)\n",
    "        x = torch.cat([x0, y0_vectorized], dim=-1)\n",
    "        \n",
    "        y = rearrange(y0[:, :, 1:T], \"nf nx nt 1 -> (nf nt) nx 1\")\n",
    "    else:\n",
    "        x, y = p, u\n",
    "        x = repeat(x, \"nf nx 1 -> nf nx T 1\", T=T)\n",
    "    return x, y\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "8d06a5a3-4116-421c-bd9a-e01ead11928c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here 160\n",
      "torch.Size([160, 100, 1]) torch.Size([160, 100, 20, 1])\n",
      "torch.Size([160, 100, 20, 1]) torch.Size([160, 100, 20, 1])\n"
     ]
    }
   ],
   "source": [
    "if is_train:\n",
    "    # Train data\n",
    "    print(\"Here\", n_train)\n",
    "    a, u, p = dataset_class.generate_dataset(n_train, grid, t, tpred, *dataset_params)\n",
    "    print(a.shape, u.shape)\n",
    "    x_train, y_train = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Validation data\n",
    "    a, u, p = dataset_class.generate_dataset(n_valid, grid, t, tpred, *dataset_params)\n",
    "    x_valid, y_valid = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # In-distribution test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *dataset_params)\n",
    "    x_id_test, y_id_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Out-of-distribution inputs only\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *train_ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Data loaders\n",
    "    train_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_train, y_train), \n",
    "                                            batch_size=batch_size, shuffle=True)\n",
    "    valid_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_valid, y_valid), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    id_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_id_test, y_id_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "else:\n",
    "    # OOD test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "\n",
    "print(x_train.shape, y_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "e11c51cf-7916-4324-83b5-d62666a03138",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=True, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "dd02c190-49e0-490f-85a4-1189103cef61",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0101, 0.0202, 0.0303, 0.0404, 0.0505, 0.0606, 0.0707, 0.0808,\n",
       "        0.0909, 0.1010, 0.1111, 0.1212, 0.1313, 0.1414, 0.1515, 0.1616, 0.1717,\n",
       "        0.1818, 0.1919, 0.2020, 0.2121, 0.2222, 0.2323, 0.2424, 0.2525, 0.2626,\n",
       "        0.2727, 0.2828, 0.2929, 0.3030, 0.3131, 0.3232, 0.3333, 0.3434, 0.3535,\n",
       "        0.3636, 0.3737, 0.3838, 0.3939, 0.4040, 0.4141, 0.4242, 0.4343, 0.4444,\n",
       "        0.4545, 0.4646, 0.4747, 0.4848, 0.4949, 0.5051, 0.5152, 0.5253, 0.5354,\n",
       "        0.5455, 0.5556, 0.5657, 0.5758, 0.5859, 0.5960, 0.6061, 0.6162, 0.6263,\n",
       "        0.6364, 0.6465, 0.6566, 0.6667, 0.6768, 0.6869, 0.6970, 0.7071, 0.7172,\n",
       "        0.7273, 0.7374, 0.7475, 0.7576, 0.7677, 0.7778, 0.7879, 0.7980, 0.8081,\n",
       "        0.8182, 0.8283, 0.8384, 0.8485, 0.8586, 0.8687, 0.8788, 0.8889, 0.8990,\n",
       "        0.9091, 0.9192, 0.9293, 0.9394, 0.9495, 0.9596, 0.9697, 0.9798, 0.9899,\n",
       "        1.0000])"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "1db18c6a-1e20-4739-b76a-6b3cb5bf4d73",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<bound method StefanPME_1D.get_mass_rhs_func of <class 'datasets.StefanPME_1D'>>"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "7d1e8d19-c876-4e02-a95c-36987cb27c62",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=0.240677, Validation loss=0.233155 (saved)\n",
      "Epoch 1: Train loss=0.221364, Validation loss=0.195543 (saved)\n",
      "Epoch 2: Train loss=0.164193, Validation loss=0.130092 (saved)\n",
      "Epoch 3: Train loss=0.102205, Validation loss=0.065249 (saved)\n",
      "Epoch 4: Train loss=0.045373, Validation loss=0.035751 (saved)\n",
      "Epoch 5: Train loss=0.029284, Validation loss=0.027301 (saved)\n",
      "Epoch 6: Train loss=0.024350, Validation loss=0.022262 (saved)\n",
      "Epoch 7: Train loss=0.021504, Validation loss=0.020004 (saved)\n",
      "Epoch 8: Train loss=0.020281, Validation loss=0.019283 (saved)\n",
      "Epoch 9: Train loss=0.019532, Validation loss=0.018691 (saved)\n",
      "Epoch 10: Train loss=0.018963, Validation loss=0.018240 (saved)\n",
      "Epoch 11: Train loss=0.018609, Validation loss=0.017988 (saved)\n",
      "Epoch 12: Train loss=0.018323, Validation loss=0.017836 (saved)\n",
      "Epoch 13: Train loss=0.018415, Validation loss=0.017538 (saved)\n",
      "Epoch 14: Train loss=0.017795, Validation loss=0.016897 (saved)\n",
      "Epoch 15: Train loss=0.017782, Validation loss=0.023684 \n",
      "Epoch 16: Train loss=0.020265, Validation loss=0.018283 \n",
      "Epoch 17: Train loss=0.018285, Validation loss=0.017315 \n",
      "Epoch 18: Train loss=0.017571, Validation loss=0.016626 (saved)\n",
      "Epoch 19: Train loss=0.018118, Validation loss=0.018554 \n",
      "Epoch 20: Train loss=0.018518, Validation loss=0.017441 \n",
      "Epoch 21: Train loss=0.017687, Validation loss=0.018163 \n",
      "Epoch 22: Train loss=0.018216, Validation loss=0.017460 \n",
      "Epoch 23: Train loss=0.017760, Validation loss=0.017373 \n",
      "Epoch 24: Train loss=0.018312, Validation loss=0.017289 \n",
      "Epoch 25: Train loss=0.017565, Validation loss=0.016838 \n",
      "Epoch 26: Train loss=0.017124, Validation loss=0.015610 (saved)\n",
      "Epoch 27: Train loss=0.019435, Validation loss=0.016059 \n",
      "Epoch 28: Train loss=0.017993, Validation loss=0.017501 \n",
      "Epoch 29: Train loss=0.017912, Validation loss=0.016812 \n",
      "Epoch 30: Train loss=0.018028, Validation loss=0.016771 \n",
      "Epoch 31: Train loss=0.017369, Validation loss=0.016585 \n",
      "Epoch 32: Train loss=0.017178, Validation loss=0.015553 (saved)\n",
      "Epoch 33: Train loss=0.016577, Validation loss=0.015564 \n",
      "Epoch 34: Train loss=0.016342, Validation loss=0.017186 \n",
      "Epoch 35: Train loss=0.015896, Validation loss=0.020994 \n",
      "Epoch 36: Train loss=0.022120, Validation loss=0.021610 \n",
      "Epoch 37: Train loss=0.020264, Validation loss=0.019396 \n",
      "Epoch 38: Train loss=0.019296, Validation loss=0.017885 \n",
      "Epoch 39: Train loss=0.017847, Validation loss=0.016855 \n",
      "Epoch 40: Train loss=0.017096, Validation loss=0.016145 \n",
      "Epoch 41: Train loss=0.016580, Validation loss=0.015724 \n",
      "Epoch 42: Train loss=0.015929, Validation loss=0.014993 (saved)\n",
      "Epoch 43: Train loss=0.015213, Validation loss=0.014213 (saved)\n",
      "Epoch 44: Train loss=0.015518, Validation loss=0.016119 \n",
      "Epoch 45: Train loss=0.017653, Validation loss=0.016676 \n",
      "Epoch 46: Train loss=0.015612, Validation loss=0.014700 \n",
      "Epoch 47: Train loss=0.015170, Validation loss=0.013862 (saved)\n",
      "Epoch 48: Train loss=0.014426, Validation loss=0.013884 \n",
      "Epoch 49: Train loss=0.019877, Validation loss=0.023946 \n",
      "Epoch 50: Train loss=0.019216, Validation loss=0.017220 \n",
      "Epoch 51: Train loss=0.017319, Validation loss=0.016868 \n",
      "Epoch 52: Train loss=0.016898, Validation loss=0.015493 \n",
      "Epoch 53: Train loss=0.015720, Validation loss=0.014664 \n",
      "Epoch 54: Train loss=0.015087, Validation loss=0.014030 \n",
      "Epoch 55: Train loss=0.014744, Validation loss=0.014086 \n",
      "Epoch 56: Train loss=0.013947, Validation loss=0.012946 (saved)\n",
      "Epoch 57: Train loss=0.013221, Validation loss=0.012870 (saved)\n",
      "Epoch 58: Train loss=0.012724, Validation loss=0.012433 (saved)\n",
      "Epoch 59: Train loss=0.014572, Validation loss=0.011743 (saved)\n",
      "Epoch 60: Train loss=0.012852, Validation loss=0.011860 \n",
      "Epoch 61: Train loss=0.012210, Validation loss=0.014917 \n",
      "Epoch 62: Train loss=0.013473, Validation loss=0.012882 \n",
      "Epoch 63: Train loss=0.011949, Validation loss=0.011650 (saved)\n",
      "Epoch 64: Train loss=0.014138, Validation loss=0.013300 \n",
      "Epoch 65: Train loss=0.012410, Validation loss=0.011466 (saved)\n",
      "Epoch 66: Train loss=0.011508, Validation loss=0.014549 \n",
      "Epoch 67: Train loss=0.013220, Validation loss=0.014765 \n",
      "Epoch 68: Train loss=0.015127, Validation loss=0.016888 \n",
      "Epoch 69: Train loss=0.013368, Validation loss=0.012050 \n",
      "Epoch 70: Train loss=0.012570, Validation loss=0.011628 \n",
      "Epoch 71: Train loss=0.011799, Validation loss=0.011129 (saved)\n",
      "Epoch 72: Train loss=0.011107, Validation loss=0.012234 \n",
      "Epoch 73: Train loss=0.011902, Validation loss=0.015453 \n",
      "Epoch 74: Train loss=0.014868, Validation loss=0.010556 (saved)\n",
      "Epoch 75: Train loss=0.014600, Validation loss=0.011378 \n",
      "Epoch 76: Train loss=0.013005, Validation loss=0.012659 \n",
      "Epoch 77: Train loss=0.012363, Validation loss=0.012649 \n",
      "Epoch 78: Train loss=0.012455, Validation loss=0.013077 \n",
      "Epoch 79: Train loss=0.011494, Validation loss=0.011371 \n",
      "Epoch 80: Train loss=0.010777, Validation loss=0.010022 (saved)\n",
      "Epoch 81: Train loss=0.010705, Validation loss=0.016154 \n",
      "Epoch 82: Train loss=0.013757, Validation loss=0.017699 \n",
      "Epoch 83: Train loss=0.012780, Validation loss=0.010314 \n",
      "Epoch 84: Train loss=0.010633, Validation loss=0.010300 \n",
      "Epoch 85: Train loss=0.011695, Validation loss=0.010744 \n",
      "Epoch 86: Train loss=0.011064, Validation loss=0.012490 \n",
      "Epoch 87: Train loss=0.011017, Validation loss=0.009738 (saved)\n",
      "Epoch 88: Train loss=0.010523, Validation loss=0.010300 \n",
      "Epoch 89: Train loss=0.010478, Validation loss=0.011771 \n",
      "Epoch 90: Train loss=0.010682, Validation loss=0.010381 \n",
      "Epoch 91: Train loss=0.010546, Validation loss=0.009638 (saved)\n",
      "Epoch 92: Train loss=0.011622, Validation loss=0.009589 (saved)\n",
      "Epoch 93: Train loss=0.011040, Validation loss=0.010350 \n",
      "Epoch 94: Train loss=0.010859, Validation loss=0.013834 \n",
      "Epoch 95: Train loss=0.012429, Validation loss=0.009670 \n",
      "Epoch 96: Train loss=0.011628, Validation loss=0.009895 \n",
      "Epoch 97: Train loss=0.010007, Validation loss=0.010021 \n",
      "Epoch 98: Train loss=0.010384, Validation loss=0.009945 \n",
      "Epoch 99: Train loss=0.009907, Validation loss=0.009713 \n",
      "Epoch 100: Train loss=0.009514, Validation loss=0.009188 (saved)\n",
      "Epoch 101: Train loss=0.009428, Validation loss=0.009239 \n",
      "Epoch 102: Train loss=0.009378, Validation loss=0.009212 \n",
      "Epoch 103: Train loss=0.009237, Validation loss=0.008954 (saved)\n",
      "Epoch 104: Train loss=0.009120, Validation loss=0.009042 \n",
      "Epoch 105: Train loss=0.009178, Validation loss=0.009104 \n",
      "Epoch 106: Train loss=0.009410, Validation loss=0.009066 \n",
      "Epoch 107: Train loss=0.009210, Validation loss=0.008815 (saved)\n",
      "Epoch 108: Train loss=0.009035, Validation loss=0.008944 \n",
      "Epoch 109: Train loss=0.009296, Validation loss=0.009769 \n",
      "Epoch 110: Train loss=0.009392, Validation loss=0.008791 (saved)\n",
      "Epoch 111: Train loss=0.009213, Validation loss=0.009502 \n",
      "Epoch 112: Train loss=0.009204, Validation loss=0.008911 \n",
      "Epoch 113: Train loss=0.008962, Validation loss=0.008644 (saved)\n",
      "Epoch 114: Train loss=0.008851, Validation loss=0.008656 \n",
      "Epoch 115: Train loss=0.008862, Validation loss=0.009029 \n",
      "Epoch 116: Train loss=0.009121, Validation loss=0.009367 \n",
      "Epoch 117: Train loss=0.009013, Validation loss=0.008530 (saved)\n",
      "Epoch 118: Train loss=0.008939, Validation loss=0.010346 \n",
      "Epoch 119: Train loss=0.009353, Validation loss=0.009273 \n",
      "Epoch 120: Train loss=0.009076, Validation loss=0.009151 \n",
      "Epoch 121: Train loss=0.009080, Validation loss=0.008459 (saved)\n",
      "Epoch 122: Train loss=0.008827, Validation loss=0.008798 \n",
      "Epoch 123: Train loss=0.008710, Validation loss=0.008589 \n",
      "Epoch 124: Train loss=0.008917, Validation loss=0.008505 \n",
      "Epoch 125: Train loss=0.009512, Validation loss=0.008364 (saved)\n",
      "Epoch 126: Train loss=0.008673, Validation loss=0.008400 \n",
      "Epoch 127: Train loss=0.008687, Validation loss=0.009778 \n",
      "Epoch 128: Train loss=0.009281, Validation loss=0.008903 \n",
      "Epoch 129: Train loss=0.008993, Validation loss=0.008263 (saved)\n",
      "Epoch 130: Train loss=0.008717, Validation loss=0.008254 (saved)\n",
      "Epoch 131: Train loss=0.008567, Validation loss=0.008272 \n",
      "Epoch 132: Train loss=0.008392, Validation loss=0.009045 \n",
      "Epoch 133: Train loss=0.008682, Validation loss=0.008758 \n",
      "Epoch 134: Train loss=0.008619, Validation loss=0.008645 \n",
      "Epoch 135: Train loss=0.008688, Validation loss=0.008756 \n",
      "Epoch 136: Train loss=0.008735, Validation loss=0.008123 (saved)\n",
      "Epoch 137: Train loss=0.008849, Validation loss=0.008556 \n",
      "Epoch 138: Train loss=0.009269, Validation loss=0.008096 (saved)\n",
      "Epoch 139: Train loss=0.009215, Validation loss=0.008114 \n",
      "Epoch 140: Train loss=0.008630, Validation loss=0.008324 \n",
      "Epoch 141: Train loss=0.008685, Validation loss=0.008999 \n",
      "Epoch 142: Train loss=0.008437, Validation loss=0.008304 \n",
      "Epoch 143: Train loss=0.008290, Validation loss=0.008188 \n",
      "Epoch 144: Train loss=0.008227, Validation loss=0.007992 (saved)\n",
      "Epoch 145: Train loss=0.008132, Validation loss=0.007902 (saved)\n",
      "Epoch 146: Train loss=0.008245, Validation loss=0.008145 \n",
      "Epoch 147: Train loss=0.009143, Validation loss=0.009095 \n",
      "Epoch 148: Train loss=0.008889, Validation loss=0.008185 \n",
      "Epoch 149: Train loss=0.008536, Validation loss=0.007911 \n",
      "Epoch 150: Train loss=0.008030, Validation loss=0.007772 (saved)\n",
      "Epoch 151: Train loss=0.007929, Validation loss=0.007757 (saved)\n",
      "Epoch 152: Train loss=0.007952, Validation loss=0.007738 (saved)\n",
      "Epoch 153: Train loss=0.007924, Validation loss=0.007714 (saved)\n",
      "Epoch 154: Train loss=0.007872, Validation loss=0.007704 (saved)\n",
      "Epoch 155: Train loss=0.007849, Validation loss=0.007640 (saved)\n",
      "Epoch 156: Train loss=0.007808, Validation loss=0.007692 \n",
      "Epoch 157: Train loss=0.007797, Validation loss=0.007630 (saved)\n",
      "Epoch 158: Train loss=0.007778, Validation loss=0.007626 (saved)\n",
      "Epoch 159: Train loss=0.007781, Validation loss=0.007586 (saved)\n",
      "Epoch 160: Train loss=0.007763, Validation loss=0.007581 (saved)\n",
      "Epoch 161: Train loss=0.007787, Validation loss=0.007814 \n",
      "Epoch 162: Train loss=0.007858, Validation loss=0.007568 (saved)\n",
      "Epoch 163: Train loss=0.007751, Validation loss=0.007592 \n",
      "Epoch 164: Train loss=0.007834, Validation loss=0.007983 \n",
      "Epoch 165: Train loss=0.007822, Validation loss=0.007519 (saved)\n",
      "Epoch 166: Train loss=0.007798, Validation loss=0.007906 \n",
      "Epoch 167: Train loss=0.007983, Validation loss=0.007834 \n",
      "Epoch 168: Train loss=0.007842, Validation loss=0.007583 \n",
      "Epoch 169: Train loss=0.007824, Validation loss=0.007789 \n",
      "Epoch 170: Train loss=0.007907, Validation loss=0.007762 \n",
      "Epoch 171: Train loss=0.007767, Validation loss=0.007431 (saved)\n",
      "Epoch 172: Train loss=0.007709, Validation loss=0.007418 (saved)\n",
      "Epoch 173: Train loss=0.007676, Validation loss=0.007400 (saved)\n",
      "Epoch 174: Train loss=0.007619, Validation loss=0.007489 \n",
      "Epoch 175: Train loss=0.007629, Validation loss=0.007425 \n",
      "Epoch 176: Train loss=0.007597, Validation loss=0.007402 \n",
      "Epoch 177: Train loss=0.007643, Validation loss=0.007561 \n",
      "Epoch 178: Train loss=0.007646, Validation loss=0.007363 (saved)\n",
      "Epoch 179: Train loss=0.007750, Validation loss=0.007440 \n",
      "Epoch 180: Train loss=0.007630, Validation loss=0.007780 \n",
      "Epoch 181: Train loss=0.007631, Validation loss=0.007409 \n",
      "Epoch 182: Train loss=0.007546, Validation loss=0.007380 \n",
      "Epoch 183: Train loss=0.007544, Validation loss=0.007391 \n",
      "Epoch 184: Train loss=0.007597, Validation loss=0.007376 \n",
      "Epoch 185: Train loss=0.007519, Validation loss=0.007398 \n",
      "Epoch 186: Train loss=0.007495, Validation loss=0.007353 (saved)\n",
      "Epoch 187: Train loss=0.007545, Validation loss=0.007428 \n",
      "Epoch 188: Train loss=0.007559, Validation loss=0.007284 (saved)\n",
      "Epoch 189: Train loss=0.007796, Validation loss=0.007809 \n",
      "Epoch 190: Train loss=0.008087, Validation loss=0.008120 \n",
      "Epoch 191: Train loss=0.007983, Validation loss=0.007650 \n",
      "Epoch 192: Train loss=0.008230, Validation loss=0.007390 \n",
      "Epoch 193: Train loss=0.008413, Validation loss=0.007359 \n",
      "Epoch 194: Train loss=0.007858, Validation loss=0.007338 \n",
      "Epoch 195: Train loss=0.007528, Validation loss=0.007279 (saved)\n",
      "Epoch 196: Train loss=0.007513, Validation loss=0.007234 (saved)\n",
      "Epoch 197: Train loss=0.007512, Validation loss=0.007337 \n",
      "Epoch 198: Train loss=0.007476, Validation loss=0.007257 \n",
      "Epoch 199: Train loss=0.007530, Validation loss=0.007444 \n",
      "Finished training with best train loss: 0.007394 and validation loss: 0.007234\n"
     ]
    }
   ],
   "source": [
    "x_ood_test = x_ood_test.to(device)\n",
    "start = time.time()\n",
    "model.fit(train_loader, valid_loader, x_test=x_ood_test, epochs=epochs, lr=lr, step_size=step_size, gamma=gamma, tpred = torch.tensor(tpred).to(device), dataset_class = dataset_class, t=t.to(device), grid_train=grid.to(device))\n",
    "stop = time.time()\n",
    "# print(stop-start)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "4f58dc93-0b91-4195-b51e-126ad1212b6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here\n",
      "Here\n",
      "Here\n",
      "Here\n",
      "In-domain results\n",
      "MSE: 0.001702072210609913\n",
      "n-MeRCI: 0.6595087051391602\n",
      "RMSCE: 0.19499680399894714\n",
      "ProbConserv Results\n",
      "MSE: 0.0017020720243453979\n",
      "n-MeRCI: 0.661049485206604\n",
      "RMSCE: 0.19554202258586884\n",
      "Cerr: 3.8770957644373993e-07\n",
      "Prob_Cerr: 3.6441721817936923e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 0.0018642107583582402\n",
      "n-MeRCI: 0.6958135366439819\n",
      "RMSCE: 0.19636096060276031\n",
      "ProbConserv Results\n",
      "MSE: 0.0018642106652259826\n",
      "n-MeRCI: 0.6939332485198975\n",
      "RMSCE: 0.19674597680568695\n",
      "Cerr: 3.7319958323678293e-07\n",
      "Prob_Cerr: 3.6658718727267114e-07\n"
     ]
    }
   ],
   "source": [
    "is_probconserv = True\n",
    "\n",
    "train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "if is_train:\n",
    "    train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "    train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "    id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "    print(\"In-domain results\")\n",
    "    print(f\"MSE: {id_results['mse']}\")\n",
    "    print(f\"n-MeRCI: {id_results['nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {id_results['rmsce_all']}\")\n",
    "\n",
    "    if is_probconserv:\n",
    "        print(\"ProbConserv Results\")\n",
    "        print(f\"MSE: {id_results['pc.mse']}\")\n",
    "        print(f\"n-MeRCI: {id_results['pc.nMeRCI_all']}\")\n",
    "        print(f\"RMSCE: {id_results['pc.rmsce_all']}\")\n",
    "        print(f\"Cerr: {id_results['mcerr']}\")\n",
    "        print(f\"Prob_Cerr: {id_results['pc.mcerr']}\")\n",
    "        \n",
    "\n",
    "ood_results = test(model, ood_test_loader, test_type=\"ood\")\n",
    "\n",
    "print(\"\\n\")\n",
    "print(\"Out-of-domain results\")\n",
    "print(f\"MSE: {ood_results['mse']}\")\n",
    "print(f\"n-MeRCI: {ood_results['nMeRCI_all']}\")\n",
    "print(f\"RMSCE: {ood_results['rmsce_all']}\")\n",
    "\n",
    "if is_probconserv:\n",
    "    print(\"ProbConserv Results\")\n",
    "    print(f\"MSE: {ood_results['pc.mse']}\")\n",
    "    print(f\"n-MeRCI: {ood_results['pc.nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {ood_results['pc.rmsce_all']}\")\n",
    "    print(f\"Cerr: {ood_results['mcerr']}\")\n",
    "    print(f\"Prob_Cerr: {ood_results['pc.mcerr']}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "d3c74561-cafe-4068-b5ec-92d2c4634cc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0017020720243453979"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "c29252c6-3147-4b6a-b320-ee566b03e910",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.probconserv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "d3c1bdb4-7418-4ecf-9309-5639193fa8d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_train.to(device))\n",
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "6d7837ba-f720-43d2-b8d0-8252c41e8ad3",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "cb722479-afdf-4b05-a156-c8a2bbbf245a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_train[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_train[parameter_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "ad73c5e5-51d1-41a9-868b-aa0a101bd2b2",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "    mu=mu[:, :, :, 0], \n",
    "    std=std[:, :, :, 0], \n",
    "    mass_rhs_func=mass_rhs_func, \n",
    "    t=t, \n",
    "    tpred=tpred, \n",
    "    grid_train=grid, \n",
    "    precis_g=np.inf,\n",
    "    second_deriv_alpha=None,\n",
    ")\n",
    "new_mu = new_mu[:, :, :, None]\n",
    "new_std = new_std[:, :, :, None]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "4e1d8ff4-50fc-4cdc-b824-ea2e4d850060",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.2593)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_train[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_train[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "a48dcabf-7ee7-4671-9050-8e8e5340a020",
   "metadata": {},
   "outputs": [],
   "source": [
    "e2e_stats_train = utils.compute_all_metrics_avg((mu, torch.square(std)), y_train, {})\n",
    "e2e_stats_train[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, torch.square(std), y_train).item()\n",
    "e2e_stats_train[\"rmsce_all\"] = utils.compute_rmsce(mu, torch.square(std), y_train).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "1bf0a238-c09a-4d2d-b666-01b025ab0f3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "e2e_probconserv_stats_train = utils.compute_all_metrics_avg((new_mu, torch.square(new_std)), y_train, {})\n",
    "e2e_probconserv_stats_train[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, torch.square(new_std), y_train).item()\n",
    "e2e_probconserv_stats_train[\"rmsce_all\"] = utils.compute_rmsce(new_mu, torch.square(new_std), y_train).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "d75eddde-47c9-434f-ab24-e999e03cb312",
   "metadata": {},
   "outputs": [],
   "source": [
    "cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "e2e_stats_train[\"cerr_by_example\"] = cerr.tolist()\n",
    "e2e_stats_train[\"mcerr\"] = cerr.mean().item()\n",
    "e2e_probconserv_stats_train[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "e2e_probconserv_stats_train[\"mcerr\"] = new_cerr.mean().item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "50627394-b489-4944-a427-98f04dde6b82",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_ood_test.to(device))\n",
    "\n",
    "x = ood_test_loader.dataset.tensors[0]\n",
    "y = ood_test_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "3639a00a-4839-4317-98f9-549ba4ab4656",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "d1eddcf4-0349-4c22-819c-d8bf5fd81cdf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_ood_test[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_ood_test[parameter_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "ee646529-35a6-40d2-898a-288fd1c8240b",
   "metadata": {},
   "outputs": [],
   "source": [
    "x = ood_test_loader.dataset.tensors[0]\n",
    "y = ood_test_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "    mu=mu[:, :, :, 0], \n",
    "    std=std[:, :, :, 0], \n",
    "    mass_rhs_func=mass_rhs_func, \n",
    "    t=t, \n",
    "    tpred=tpred, \n",
    "    grid_train=grid, \n",
    "    precis_g=np.inf,\n",
    "    second_deriv_alpha=None,\n",
    ")\n",
    "new_mu = new_mu[:, :, :, None]\n",
    "new_std = new_std[:, :, :, None]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "dd8c116a-f7e0-4af0-a6d3-b506dee7945b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.2553)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_ood_test[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_ood_test[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_ood_test[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "463e36f8-0ccd-4319-a639-b3bccdc998a3",
   "metadata": {},
   "outputs": [],
   "source": [
    "e2e_stats_test = utils.compute_all_metrics_avg((mu, torch.square(std)), y_ood_test, {})\n",
    "e2e_stats_test[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, torch.square(std), y_ood_test).item()\n",
    "e2e_stats_test[\"rmsce_all\"] = utils.compute_rmsce(mu, torch.square(std), y_ood_test).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "052adf56-3cac-4fd5-a5d8-83ca0e91a969",
   "metadata": {},
   "outputs": [],
   "source": [
    "e2e_probconserv_stats_test = utils.compute_all_metrics_avg((new_mu, torch.square(new_std)), y_ood_test, {})\n",
    "e2e_probconserv_stats_test[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, torch.square(new_std), y_ood_test).item()\n",
    "e2e_probconserv_stats_test[\"rmsce_all\"] = utils.compute_rmsce(new_mu, torch.square(new_std), y_ood_test).item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "ef17475e-fdca-446c-9b90-1f90beec49d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "e2e_stats_test[\"cerr_by_example\"] = cerr.tolist()\n",
    "e2e_stats_test[\"mcerr\"] = cerr.mean().item()\n",
    "e2e_probconserv_stats_test[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "e2e_probconserv_stats_test[\"mcerr\"] = new_cerr.mean().item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "c8f87a91-2bad-44c5-9633-1f6a03f77d68",
   "metadata": {},
   "outputs": [],
   "source": [
    "from decimal import Decimal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "82377954-2227-47c4-bbc3-7c1c95682b6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.17'"
      ]
     },
     "execution_count": 82,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    " f\"{ucons_stats_train['mcerr']:.2}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "bd09fb69-7adb-4f8f-811a-45a934dc46d0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.0008871903410181403,\n",
       "  0.0014397024642676115,\n",
       "  0.0008721628692001104,\n",
       "  0.001304957433603704,\n",
       "  0.0013794475235044956,\n",
       "  0.0019607176072895527,\n",
       "  0.0014604022726416588,\n",
       "  0.0012508237268775702,\n",
       "  0.001170564559288323,\n",
       "  0.0014657838037237525,\n",
       "  0.002107087289914489,\n",
       "  0.0013862764462828636,\n",
       "  0.0011359796626493335,\n",
       "  0.001032818341627717,\n",
       "  0.0011943643912672997,\n",
       "  0.0016129764262586832,\n",
       "  0.0008715707226656377,\n",
       "  0.0015831952914595604,\n",
       "  0.0011493428610265255,\n",
       "  0.0015802120324224234,\n",
       "  0.0015747554134577513,\n",
       "  0.0015383597929030657,\n",
       "  0.002032892545685172,\n",
       "  0.0015799790853634477,\n",
       "  0.0018455812241882086,\n",
       "  0.003761925967410207,\n",
       "  0.001444810419343412,\n",
       "  0.0015245710965245962,\n",
       "  0.0014448084402829409,\n",
       "  0.0008881270769052207,\n",
       "  0.0021294341422617435,\n",
       "  0.00246421922929585,\n",
       "  0.00512494845315814,\n",
       "  0.0015094293048605323,\n",
       "  0.0015670235734432936,\n",
       "  0.0011768762487918139,\n",
       "  0.0024322443641722202,\n",
       "  0.005134328734129667,\n",
       "  0.0035652117803692818,\n",
       "  0.002594488672912121,\n",
       "  0.0013052283320575953,\n",
       "  0.0010434937430545688,\n",
       "  0.0030034566298127174,\n",
       "  0.0014406347181648016,\n",
       "  0.0010291992221027613,\n",
       "  0.003755166195333004,\n",
       "  0.0014151253271847963,\n",
       "  0.0014544654404744506,\n",
       "  0.00131415284704417,\n",
       "  0.001215446973219514,\n",
       "  0.0010438248282298446,\n",
       "  0.002605484565719962,\n",
       "  0.0013640138786286116,\n",
       "  0.0011796231847256422,\n",
       "  0.0014427175046876073,\n",
       "  0.0011582773877307773,\n",
       "  0.0010929666459560394,\n",
       "  0.0014077117666602135,\n",
       "  0.0015742729883641005,\n",
       "  0.001313084620051086,\n",
       "  0.0015546780778095126,\n",
       "  0.004164289217442274,\n",
       "  0.002068178029730916,\n",
       "  0.002619967795908451,\n",
       "  0.0013946230756118894,\n",
       "  0.004239097703248262,\n",
       "  0.0028507921379059553,\n",
       "  0.002966713160276413,\n",
       "  0.0015592280542477965,\n",
       "  0.0013788287760689855,\n",
       "  0.0013930762652307749,\n",
       "  0.0018470105715095997,\n",
       "  0.0019801449961960316,\n",
       "  0.000887108501046896,\n",
       "  0.004081100691109896,\n",
       "  0.000910279166419059,\n",
       "  0.003006505547091365,\n",
       "  0.002998646581545472,\n",
       "  0.0022077278699725866,\n",
       "  0.002457443857565522,\n",
       "  0.0036094363313168287,\n",
       "  0.0012362075503915548,\n",
       "  0.001232416951097548,\n",
       "  0.003614890156313777,\n",
       "  0.0011655802372843027,\n",
       "  0.005134614650160074,\n",
       "  0.0013641128316521645,\n",
       "  0.0015101280296221375,\n",
       "  0.0010443257633596659,\n",
       "  0.0014209095388650894,\n",
       "  0.0015540330205112696,\n",
       "  0.0012711611343547702,\n",
       "  0.000909151160158217,\n",
       "  0.0009085512720048428,\n",
       "  0.002002118155360222,\n",
       "  0.0016156610799953341,\n",
       "  0.0020800300408154726,\n",
       "  0.001471123076044023,\n",
       "  0.0009145418298430741,\n",
       "  0.0024587069638073444],\n",
       " 'mse': 0.0018642106652259826,\n",
       " 'nll_by_example': [-7432.46923828125,\n",
       "  -7631.67724609375,\n",
       "  -7418.26806640625,\n",
       "  -7617.0693359375,\n",
       "  -7627.7744140625,\n",
       "  -5149.6220703125,\n",
       "  -7635.2060546875,\n",
       "  -6639.7412109375,\n",
       "  -6684.9853515625,\n",
       "  -7665.216796875,\n",
       "  -5123.53271484375,\n",
       "  -7670.1044921875,\n",
       "  -7563.69677734375,\n",
       "  -7462.9130859375,\n",
       "  -6692.0380859375,\n",
       "  -5311.02490234375,\n",
       "  -7417.150390625,\n",
       "  -7662.140625,\n",
       "  -6676.65380859375,\n",
       "  -7653.443359375,\n",
       "  -7652.63427734375,\n",
       "  -7644.1279296875,\n",
       "  -5136.1806640625,\n",
       "  -7653.4091796875,\n",
       "  -5262.98388671875,\n",
       "  -4810.16015625,\n",
       "  -5377.71240234375,\n",
       "  -7642.3232421875,\n",
       "  -5446.1611328125,\n",
       "  -7430.86376953125,\n",
       "  -5119.85888671875,\n",
       "  -5064.3935546875,\n",
       "  -4194.43310546875,\n",
       "  -5342.021484375,\n",
       "  -5246.95458984375,\n",
       "  -6687.03369140625,\n",
       "  -5143.994140625,\n",
       "  -4191.78173828125,\n",
       "  -4855.81494140625,\n",
       "  -5103.67724609375,\n",
       "  -7660.5126953125,\n",
       "  -7465.546875,\n",
       "  -5001.8505859375,\n",
       "  -5396.45947265625,\n",
       "  -7370.16845703125,\n",
       "  -4812.568359375,\n",
       "  -5440.232421875,\n",
       "  -5404.455078125,\n",
       "  -5276.693359375,\n",
       "  -7593.8935546875,\n",
       "  -7465.61376953125,\n",
       "  -5097.5341796875,\n",
       "  -7667.623046875,\n",
       "  -6687.88134765625,\n",
       "  -7632.2431640625,\n",
       "  -6669.66748046875,\n",
       "  -7466.1025390625,\n",
       "  -5438.4990234375,\n",
       "  -5245.052734375,\n",
       "  -7618.6748046875,\n",
       "  -5250.544921875,\n",
       "  -4269.8798828125,\n",
       "  -5130.07763671875,\n",
       "  -5089.8349609375,\n",
       "  -5410.74560546875,\n",
       "  -4611.50732421875,\n",
       "  -5033.63671875,\n",
       "  -4979.1064453125,\n",
       "  -5249.15478515625,\n",
       "  -7669.52734375,\n",
       "  -5267.8388671875,\n",
       "  -5261.48779296875,\n",
       "  -5145.83056640625,\n",
       "  -7430.359375,\n",
       "  -4277.82861328125,\n",
       "  -7394.533203125,\n",
       "  -5000.44189453125,\n",
       "  -5004.10107421875,\n",
       "  -5199.58837890625,\n",
       "  -5128.65234375,\n",
       "  -4839.333984375,\n",
       "  -7471.37451171875,\n",
       "  -6633.32421875,\n",
       "  -4837.35400390625,\n",
       "  -7571.51220703125,\n",
       "  -4191.703125,\n",
       "  -5425.1015625,\n",
       "  -5350.599609375,\n",
       "  -7465.7109375,\n",
       "  -5441.50341796875,\n",
       "  -7646.38232421875,\n",
       "  -7659.41064453125,\n",
       "  -7396.4921875,\n",
       "  -7397.7431640625,\n",
       "  -5141.72119140625,\n",
       "  -5307.0576171875,\n",
       "  -5221.55859375,\n",
       "  -7666.287109375,\n",
       "  -7389.0576171875,\n",
       "  -5127.94287109375],\n",
       " 'nll': -6171.38375,\n",
       " 'piw_by_example': [0.04597929120063782,\n",
       "  0.045579325407743454,\n",
       "  0.046001724898815155,\n",
       "  0.04554878920316696,\n",
       "  0.045569244772195816,\n",
       "  0.04613729193806648,\n",
       "  0.045587219297885895,\n",
       "  0.045431382954120636,\n",
       "  0.04544943943619728,\n",
       "  0.04576345905661583,\n",
       "  0.04618436470627785,\n",
       "  0.04578053206205368,\n",
       "  0.04547855257987976,\n",
       "  0.04590800032019615,\n",
       "  0.04545918107032776,\n",
       "  0.04528764262795448,\n",
       "  0.04600335657596588,\n",
       "  0.045681558549404144,\n",
       "  0.04543882980942726,\n",
       "  0.04564026743173599,\n",
       "  0.045637164264917374,\n",
       "  0.04561228305101395,\n",
       "  0.04616386443376541,\n",
       "  0.04564014449715614,\n",
       "  0.04527178779244423,\n",
       "  0.045147232711315155,\n",
       "  0.045334432274103165,\n",
       "  0.04560677334666252,\n",
       "  0.045406755059957504,\n",
       "  0.045981720089912415,\n",
       "  0.04618977755308151,\n",
       "  0.04620881751179695,\n",
       "  0.0450897254049778,\n",
       "  0.04530628025531769,\n",
       "  0.04610608518123627,\n",
       "  0.04545218497514725,\n",
       "  0.04523433372378349,\n",
       "  0.04508854076266289,\n",
       "  0.04516316577792168,\n",
       "  0.04522262513637543,\n",
       "  0.04582592099905014,\n",
       "  0.045899566262960434,\n",
       "  0.04519498348236084,\n",
       "  0.0453508161008358,\n",
       "  0.046051714569330215,\n",
       "  0.04514847695827484,\n",
       "  0.0453970730304718,\n",
       "  0.04535994306206703,\n",
       "  0.04606691002845764,\n",
       "  0.04551484063267708,\n",
       "  0.04589933156967163,\n",
       "  0.045218680053949356,\n",
       "  0.04579610377550125,\n",
       "  0.04545334354043007,\n",
       "  0.045580532401800156,\n",
       "  0.045431654900312424,\n",
       "  0.04589283466339111,\n",
       "  0.045394424349069595,\n",
       "  0.04611050710082054,\n",
       "  0.045551519840955734,\n",
       "  0.04609719663858414,\n",
       "  0.04628606513142586,\n",
       "  0.046174176037311554,\n",
       "  0.045213840901851654,\n",
       "  0.04536240175366402,\n",
       "  0.045125123113393784,\n",
       "  0.04520689323544502,\n",
       "  0.04622901603579521,\n",
       "  0.04610074311494827,\n",
       "  0.04578501358628273,\n",
       "  0.04608067870140076,\n",
       "  0.045270632952451706,\n",
       "  0.04614551365375519,\n",
       "  0.04598257690668106,\n",
       "  0.04627359285950661,\n",
       "  0.04603105038404465,\n",
       "  0.045194145292043686,\n",
       "  0.04519635811448097,\n",
       "  0.045257821679115295,\n",
       "  0.04522419348359108,\n",
       "  0.04515434801578522,\n",
       "  0.04584214836359024,\n",
       "  0.04542294144630432,\n",
       "  0.04515330493450165,\n",
       "  0.04548845440149307,\n",
       "  0.045088496059179306,\n",
       "  0.045375797897577286,\n",
       "  0.04531414061784744,\n",
       "  0.045898985117673874,\n",
       "  0.04539906233549118,\n",
       "  0.045618265867233276,\n",
       "  0.04583171010017395,\n",
       "  0.04602859541773796,\n",
       "  0.04602701961994171,\n",
       "  0.0461537204682827,\n",
       "  0.04528443142771721,\n",
       "  0.04526076093316078,\n",
       "  0.045756176114082336,\n",
       "  0.0460376963019371,\n",
       "  0.04522373527288437],\n",
       " 'piw': 0.04562509059906006,\n",
       " 'crps_by_example': [0.005529153626412153,\n",
       "  0.006505785044282675,\n",
       "  0.0055636330507695675,\n",
       "  0.0063082571141421795,\n",
       "  0.006417969241738319,\n",
       "  0.00783568061888218,\n",
       "  0.006535945925861597,\n",
       "  0.006303689908236265,\n",
       "  0.006155167240649462,\n",
       "  0.0063960668630898,\n",
       "  0.00827381107956171,\n",
       "  0.006255330052226782,\n",
       "  0.006074449513107538,\n",
       "  0.00564730865880847,\n",
       "  0.006181425880640745,\n",
       "  0.007305556908249855,\n",
       "  0.00556733924895525,\n",
       "  0.006674722768366337,\n",
       "  0.006135647650808096,\n",
       "  0.006697803270071745,\n",
       "  0.006691322196274996,\n",
       "  0.006647499278187752,\n",
       "  0.008067077025771141,\n",
       "  0.006697527598589659,\n",
       "  0.007738072425127029,\n",
       "  0.011312494054436684,\n",
       "  0.006854251958429813,\n",
       "  0.0066281091421842575,\n",
       "  0.006648372393101454,\n",
       "  0.005536471493542194,\n",
       "  0.008332513272762299,\n",
       "  0.008953068405389786,\n",
       "  0.013648577965795994,\n",
       "  0.007064744830131531,\n",
       "  0.007062877994030714,\n",
       "  0.006161788944154978,\n",
       "  0.00882644671946764,\n",
       "  0.01366752665489912,\n",
       "  0.010931679047644138,\n",
       "  0.009135980159044266,\n",
       "  0.006080124992877245,\n",
       "  0.005659584887325764,\n",
       "  0.009908990003168583,\n",
       "  0.006790352985262871,\n",
       "  0.005978407338261604,\n",
       "  0.011296004988253117,\n",
       "  0.006623266264796257,\n",
       "  0.006782477255910635,\n",
       "  0.006496247369796038,\n",
       "  0.0061792475171387196,\n",
       "  0.005660003982484341,\n",
       "  0.009173360653221607,\n",
       "  0.006201259791851044,\n",
       "  0.006164755206555128,\n",
       "  0.00651019299402833,\n",
       "  0.006159152369946241,\n",
       "  0.005731815006583929,\n",
       "  0.006617849692702293,\n",
       "  0.007093207444995642,\n",
       "  0.006320194341242313,\n",
       "  0.0070055583491921425,\n",
       "  0.011990401893854141,\n",
       "  0.008168022148311138,\n",
       "  0.009220857173204422,\n",
       "  0.006682984530925751,\n",
       "  0.01214709971100092,\n",
       "  0.009613338857889175,\n",
       "  0.009850314818322659,\n",
       "  0.007027759682387114,\n",
       "  0.006238125264644623,\n",
       "  0.006677223369479179,\n",
       "  0.007745763286948204,\n",
       "  0.0079027209430933,\n",
       "  0.005536944139748812,\n",
       "  0.011817899532616138,\n",
       "  0.005715005099773407,\n",
       "  0.009918123483657837,\n",
       "  0.009894486516714096,\n",
       "  0.008362902328372002,\n",
       "  0.00891741830855608,\n",
       "  0.0110437897965312,\n",
       "  0.005967129487544298,\n",
       "  0.00628861878067255,\n",
       "  0.011057328432798386,\n",
       "  0.00611431710422039,\n",
       "  0.013668103143572807,\n",
       "  0.006597439292818308,\n",
       "  0.007033336441963911,\n",
       "  0.005660638213157654,\n",
       "  0.00662775756791234,\n",
       "  0.006668242625892162,\n",
       "  0.0060244593769311905,\n",
       "  0.0057050324976444244,\n",
       "  0.005698864813894033,\n",
       "  0.007973691448569298,\n",
       "  0.00732429651543498,\n",
       "  0.0081520089879632,\n",
       "  0.0064143952913582325,\n",
       "  0.005744473543018103,\n",
       "  0.008921755477786064],\n",
       " 'crps': 0.007515162825584411,\n",
       " 'nMeRCI_all': 0.6958132982254028,\n",
       " 'rmsce_all': 0.19635950028896332,\n",
       " 'cerr_by_example': [2.684537321329117e-07,\n",
       "  2.2398307919502258e-07,\n",
       "  5.217734724283218e-07,\n",
       "  4.0279701352119446e-07,\n",
       "  2.2421590983867645e-07,\n",
       "  3.878958523273468e-07,\n",
       "  3.580935299396515e-07,\n",
       "  3.129243850708008e-07,\n",
       "  5.671754479408264e-07,\n",
       "  4.780013114213943e-07,\n",
       "  3.5832636058330536e-07,\n",
       "  3.2852403819561005e-07,\n",
       "  4.6193599700927734e-07,\n",
       "  5.520414561033249e-07,\n",
       "  7.010530680418015e-07,\n",
       "  4.3259933590888977e-07,\n",
       "  2.8405338525772095e-07,\n",
       "  2.2444874048233032e-07,\n",
       "  5.220063030719757e-07,\n",
       "  4.323665052652359e-07,\n",
       "  2.838205546140671e-07,\n",
       "  3.2852403819561005e-07,\n",
       "  5.227047950029373e-07,\n",
       "  2.0884908735752106e-07,\n",
       "  3.8836151361465454e-07,\n",
       "  2.0908191800117493e-07,\n",
       "  4.023313522338867e-07,\n",
       "  2.093147486448288e-07,\n",
       "  3.280583769083023e-07,\n",
       "  2.3865140974521637e-07,\n",
       "  4.3213367462158203e-07,\n",
       "  3.878958523273468e-07,\n",
       "  4.628673195838928e-07,\n",
       "  6.707850843667984e-07,\n",
       "  2.9848888516426086e-07,\n",
       "  4.621688276529312e-07,\n",
       "  3.580935299396515e-07,\n",
       "  3.8836151361465454e-07,\n",
       "  5.217734724283218e-07,\n",
       "  2.2421590983867645e-07,\n",
       "  2.3865140974521637e-07,\n",
       "  1.9418075680732727e-07,\n",
       "  4.624016582965851e-07,\n",
       "  4.919711500406265e-07,\n",
       "  3.580935299396515e-07,\n",
       "  2.9872171580791473e-07,\n",
       "  3.5855919122695923e-07,\n",
       "  3.2852403819561005e-07,\n",
       "  2.980232238769531e-07,\n",
       "  3.2782554626464844e-07,\n",
       "  3.725290298461914e-07,\n",
       "  4.477333277463913e-07,\n",
       "  2.98256054520607e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  2.980232238769531e-07,\n",
       "  3.4319236874580383e-07,\n",
       "  4.172325134277344e-07,\n",
       "  3.580935299396515e-07,\n",
       "  4.6263448894023895e-07,\n",
       "  4.4726766645908356e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  2.100132405757904e-07,\n",
       "  4.917383193969727e-07,\n",
       "  4.3259933590888977e-07,\n",
       "  3.587920218706131e-07,\n",
       "  4.3259933590888977e-07,\n",
       "  4.032626748085022e-07,\n",
       "  3.578606992959976e-07,\n",
       "  4.6193599700927734e-07,\n",
       "  2.3888424038887024e-07,\n",
       "  5.515757948160172e-07,\n",
       "  5.220063030719757e-07,\n",
       "  4.0279701352119446e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  4.4750049710273743e-07,\n",
       "  4.773028194904327e-07,\n",
       "  3.727618604898453e-07,\n",
       "  3.8766302168369293e-07,\n",
       "  4.172325134277344e-07,\n",
       "  4.176981747150421e-07,\n",
       "  2.980232238769531e-07,\n",
       "  2.980232238769531e-07,\n",
       "  3.282912075519562e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  2.537854015827179e-07,\n",
       "  2.980232238769531e-07,\n",
       "  1.9418075680732727e-07,\n",
       "  3.280583769083023e-07,\n",
       "  2.9872171580791473e-07,\n",
       "  3.282912075519562e-07,\n",
       "  5.515757948160172e-07,\n",
       "  6.26780092716217e-07,\n",
       "  1.7974525690078735e-07,\n",
       "  4.624016582965851e-07,\n",
       "  3.5855919122695923e-07,\n",
       "  3.7299469113349915e-07,\n",
       "  3.8766302168369293e-07,\n",
       "  4.770699888467789e-07,\n",
       "  5.369074642658234e-07,\n",
       "  3.5855919122695923e-07],\n",
       " 'mcerr': 3.8162804116836924e-07}"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "e2e_stats_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "ffa40a8c-b09f-4f57-bbb9-67b241d88629",
   "metadata": {},
   "outputs": [],
   "source": [
    "def dump_to_latex(ucons_stats_train, ucons_stats_test,  probconserv_stats_train, probconserv_stats_test, e2e_stats_train, e2e_stats_test, e2e_probconserv_stats_train, e2e_probconserv_stats_test):\n",
    "    table_str = f\"\"\"\n",
    "    Unconstrained (VarianceNO) & {ucons_stats_train['mse']:.2E} & {ucons_stats_train['nMeRCI_all']:.2E} & {ucons_stats_train['rmsce_all']:.2E} & {ucons_stats_train['mcerr']:.2E} & {ucons_stats_train['crps']:.2E} & {ucons_stats_test['mse']:.2E} & {ucons_stats_test['nMeRCI_all']:.2E} & {ucons_stats_test['rmsce_all']:.2E} & {ucons_stats_test['mcerr']:.2E} & {ucons_stats_test['crps']:.2E} \\\\\\\\\n",
    "    \\\\texttt{{ProbConserv}} & {probconserv_stats_train['mse']:.2E} & {probconserv_stats_train['nMeRCI_all']:.2E} & {probconserv_stats_train['rmsce_all']:.2E} & {probconserv_stats_train['mcerr']:.2E} & {probconserv_stats_train['crps']:.2E} & {probconserv_stats_test['mse']:.2E} & {probconserv_stats_test['nMeRCI_all']:.2E} & {probconserv_stats_test['rmsce_all']:.2E} & {probconserv_stats_test['mcerr']:.2E} & {probconserv_stats_test['crps']:.2E} \\\\\\\\\n",
    "    \\\\ourmethod{{}} & {e2e_stats_train['mse']:.2E} & {e2e_stats_train['nMeRCI_all']:.2E} & {e2e_stats_train['rmsce_all']:.2E} & {e2e_stats_train['mcerr']:.2E} & {e2e_stats_train['crps']:.2E} & {e2e_stats_test['mse']:.2E} & {e2e_stats_test['nMeRCI_all']:.2E} & {e2e_stats_test['rmsce_all']:.2E} & {e2e_stats_test['mcerr']:.2E} & {e2e_stats_test['crps']:.2E} \\\\\\\\\n",
    "    \\\\ourmethod{{}} + \\\\texttt{{ProbConserv}} & {e2e_probconserv_stats_train['mse']:.2E} & {e2e_probconserv_stats_train['nMeRCI_all']:.2E} & {e2e_probconserv_stats_train['rmsce_all']:.2E} & {e2e_probconserv_stats_train['mcerr']:.2E} & {e2e_probconserv_stats_train['crps']:.2E} & {e2e_probconserv_stats_test['mse']:.2E} & {e2e_probconserv_stats_test['nMeRCI_all']:.2E} & {e2e_probconserv_stats_test['rmsce_all']:.2E} & {e2e_probconserv_stats_test['mcerr']:.2E} & {e2e_probconserv_stats_test['crps']:.2E} \\\\\\\\\n",
    "    \"\"\"\n",
    "    return table_str"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "c95a912a-bd68-459a-abf7-1c5f03b5661a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "    Unconstrained (VarianceNO) & 3.93E-03 & 7.95E-01 & 1.46E-01 & 1.67E-01 & 9.02E-03 & 4.25E-03 & 7.64E-01 & 1.70E-01 & 1.80E-01 & 9.51E-03 \\\\\n",
      "    \\texttt{ProbConserv} & 2.91E-03 & 7.15E-01 & 1.40E-01 & 3.80E-07 & 7.52E-03 & 3.03E-03 & 7.05E-01 & 1.64E-01 & 3.68E-07 & 7.85E-03 \\\\\n",
      "    \\ourmethod{} & 1.82E-03 & 7.36E-01 & 1.90E-01 & 3.52E-07 & 7.39E-03 & 1.86E-03 & 6.96E-01 & 1.96E-01 & 3.82E-07 & 7.52E-03 \\\\\n",
      "    \\ourmethod{} + \\texttt{ProbConserv} & 1.82E-03 & 7.34E-01 & 1.91E-01 & 3.50E-07 & 7.44E-03 & 1.86E-03 & 6.94E-01 & 1.97E-01 & 3.80E-07 & 7.56E-03 \\\\\n",
      "    \n"
     ]
    }
   ],
   "source": [
    "print(dump_to_latex(ucons_stats_train, ucons_stats_test,  probconserv_stats_train, probconserv_stats_test, e2e_stats_train, e2e_stats_test, e2e_probconserv_stats_train, e2e_probconserv_stats_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "654cef07-235c-492e-9960-9b3d236949dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_statistics(\n",
    "    model, \n",
    "    x_data, \n",
    "    y_data, \n",
    "    t, \n",
    "    tpred, \n",
    "    grid, \n",
    "    dataset_class, \n",
    "    apply_probconserv=False, \n",
    "    plot=False,\n",
    "    x_data_test=None, \n",
    "    y_data_test=None,\n",
    "    return_latex=False,\n",
    "    name=\"Model\"\n",
    "):\n",
    "    import torch\n",
    "    import utils\n",
    "    import probconserv\n",
    "    import matplotlib.pyplot as plt\n",
    "\n",
    "    device = next(model.parameters()).device\n",
    "    x_data = x_data.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        out = model(x_data)\n",
    "\n",
    "    if isinstance(out, tuple):\n",
    "        mu, var = out[0].cpu(), out[1].cpu()\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        mu = out.cpu()\n",
    "        std = torch.zeros_like(mu)\n",
    "        var = torch.square(std)\n",
    "\n",
    "    x_cpu = x_data.cpu()\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_cpu)\n",
    "\n",
    "    if apply_probconserv:\n",
    "        new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "            mu=mu[:, :, :, 0],\n",
    "            std=std[:, :, :, 0],\n",
    "            mass_rhs_func=mass_rhs_func,\n",
    "            t=t,\n",
    "            tpred=tpred,\n",
    "            grid_train=grid,\n",
    "            precis_g=float('inf'),\n",
    "            second_deriv_alpha=None,\n",
    "        )\n",
    "        mu = new_mu.unsqueeze(-1)\n",
    "        std = new_std.unsqueeze(-1)\n",
    "        var = torch.square(std)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "    else:\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs_func(rearrange(x_cpu, \"nf nx nt 1-> nf nt nx 1\"))).abs().sum(dim=-1)\n",
    "\n",
    "    stats = utils.compute_all_metrics_avg((mu, var), y_data, {})\n",
    "    stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y_data).item()\n",
    "    stats[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y_data).item()\n",
    "    stats[\"cerr_by_example\"] = cerr.tolist()\n",
    "    stats[\"mcerr\"] = cerr.mean().item()\n",
    "\n",
    "    # --- Test dataset ---\n",
    "    test_stats = None\n",
    "    if x_data_test is not None and y_data_test is not None:\n",
    "        x_data_test = x_data_test.to(device)\n",
    "        with torch.no_grad():\n",
    "            test_out = model(x_data_test)\n",
    "\n",
    "        if isinstance(test_out, tuple):\n",
    "            mu_test, var_test = test_out[0].cpu(), test_out[1].cpu()\n",
    "            std_test = torch.sqrt(var_test)\n",
    "        else:\n",
    "            mu_test = test_out.cpu()\n",
    "            std_test = torch.zeros_like(mu_test)\n",
    "            var_test = torch.square(std_test)\n",
    "\n",
    "        x_test_cpu = x_data_test.cpu()\n",
    "        test_mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_test_cpu)\n",
    "\n",
    "        if apply_probconserv:\n",
    "            new_mu_test, new_std_test, _, test_mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu_test[:, :, :, 0],\n",
    "                std=std_test[:, :, :, 0],\n",
    "                mass_rhs_func=test_mass_rhs_func,\n",
    "                t=t,\n",
    "                tpred=tpred,\n",
    "                grid_train=grid,\n",
    "                precis_g=float('inf'),\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            mu_test = new_mu_test.unsqueeze(-1)\n",
    "            std_test = new_std_test.unsqueeze(-1)\n",
    "            var_test = torch.square(std_test)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs).abs().sum(dim=-1)\n",
    "        else:\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs_func(rearrange(x_test_cpu, \"nf nx nt 1-> nf nt nx 1\"))).abs().sum(dim=-1)\n",
    "\n",
    "        test_stats = utils.compute_all_metrics_avg((mu_test, var_test), y_data_test, {})\n",
    "        test_stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"rmsce_all\"] = utils.compute_rmsce(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"cerr_by_example\"] = cerr_test.tolist()\n",
    "        test_stats[\"mcerr\"] = cerr_test.mean().item()\n",
    "\n",
    "    # --- Optional plot ---\n",
    "    if plot:\n",
    "        t_idx = 1\n",
    "        param_idx = 0\n",
    "        with torch.no_grad():\n",
    "            plt.ylabel(f\"u(x, t={t[slice(*tpred)][t_idx]:.2f})\")\n",
    "            plt.xlabel(\"x\")\n",
    "            plt.title(f\"Predicted vs True (param = {x_data[param_idx,0,0,0].item():.2f})\")\n",
    "            mu_plot = mu[param_idx, :, t_idx, 0]\n",
    "            std_plot = std[param_idx, :, t_idx, 0]\n",
    "            y_true_plot = y_data[param_idx, :, t_idx, 0]\n",
    "            plt.plot(grid, mu_plot, '--', lw=2, label=\"μ ± 3σ\")\n",
    "            plt.fill_between(grid, mu_plot + 3*std_plot, mu_plot - 3*std_plot, alpha=0.2)\n",
    "            plt.plot(grid, y_true_plot, color=\"green\", label=\"true\")\n",
    "            plt.legend()\n",
    "            plt.show()\n",
    "\n",
    "    # --- Optional LaTeX row ---\n",
    "    latex_row = None\n",
    "    if return_latex and test_stats:\n",
    "        latex_row = (\n",
    "            f\"{name} & \"\n",
    "            f\"{stats['mse']:.2E} & {stats['nMeRCI_all']:.2E} & {stats['rmsce_all']:.2E} & {stats['mcerr']:.2E} & {stats['crps']:.2E} & \"\n",
    "            f\"{test_stats['mse']:.2E} & {test_stats['nMeRCI_all']:.2E} & {test_stats['rmsce_all']:.2E} & {test_stats['mcerr']:.2E} & {test_stats['crps']:.2E} \\\\\\\\\"\n",
    "        )\n",
    "\n",
    "    return (stats, test_stats, latex_row) if return_latex else (stats, test_stats)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "47db742d-7441-4c5f-a60c-a7c6bfd76632",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_stats, test_stats, latex = compute_statistics(\n",
    "    model,\n",
    "    x_train, y_train,\n",
    "    x_data_test=x_ood_test, \n",
    "    y_data_test=y_ood_test,\n",
    "    t=t, tpred=tpred, grid=grid,\n",
    "    dataset_class=dataset_class,\n",
    "    apply_probconserv=True,\n",
    "    plot=False,\n",
    "    return_latex=True,\n",
    "    name=\"ProbConserv\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "a6a1914c-1c99-4c23-9fe7-fafe7a2a5d7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'ProbConserv & 1.82E-03 & 7.36E-01 & 1.90E-01 & 3.52E-07 & 7.39E-03 & 1.86E-03 & 6.96E-01 & 1.96E-01 & 3.82E-07 & 7.52E-03 \\\\\\\\'"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "optprobconserv",
   "language": "python",
   "name": "optprobconserv"
  },
  "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.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
