{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "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": 2,
   "id": "3f650c83-1845-4ef1-9b8b-2aaf18d83d08",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'2.6.0+cu118'"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.__version__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "dabd741a-54b6-4556-8585-7ed8dfaff61c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Tesla V100S-PCIE-32GB'"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.cuda.get_device_name()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5fdcc8cd-82d9-4cec-888d-806541259f2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1d5eb530-ab43-4054-8953-9efdb86b3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "args = {'--batch_size': '20',\n",
    " '--dataset': 'PME_1D',\n",
    " '--dataset_params': '2,3',\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': '2,3'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "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": 7,
   "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": 8,
   "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": 9,
   "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": 10,
   "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)\n",
    "    model = ProbHardE2ETVD(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": 11,
   "id": "4333d6f8-fe2c-4caa-a889-efae589c31ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "96aa9ee0-a30e-458b-85e2-5e7dbbd89dc4",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_true = torch.mean(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "fc1ac32d-6fb2-4293-8ea7-f90486a32dce",
   "metadata": {},
   "outputs": [],
   "source": [
    "var_true = torch.var(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "f07c25ce-49e4-4331-81a3-ee678808a6b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100, 20, 1])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu_true.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "0f4d18b3-1988-4417-9122-3a8709048fc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.0632, 0.0618, 0.0597, 0.0563, 0.0498, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000, 0.0000,\n",
      "        0.0000])\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABK4klEQVR4nO3deXiU5d328XNmkkwSSMISCAFSIlBZRA0mEoMLLtG4VEGrBrCCca2AVVN9FbUE0RrqVtQiVBTwoSooLm0V8dEUnorSoixuCCq7YAIIJEhClpnr/QNnYMjCzGSWZPL9HMccB9xzL7+5k5CTa7stxhgjAACACGENdwEAAACBRLgBAAARhXADAAAiCuEGAABEFMINAACIKIQbAAAQUQg3AAAgohBuAABARCHcAACAiEK4QUgtXbpUFotFS5cuDcn1Jk+eLIvFEpJrIXDOPvtsnX322eEuw4PFYtHkyZPDXUazlZWV6corr1Tnzp1lsVg0bdq0cJcEBBzhBgExd+5cWSwW9ys2NlbHH3+8JkyYoLKysoBcY9GiRQ3+cqmsrNTkyZNDFpiA1uzOO+/Ue++9p4kTJ2revHm68MILg3q9I/9dsFqt6t69uy644IJ6P6/p6emyWCzKzc1t8DyzZs1yn+fTTz91b3f9B6axV2lpqde1rlixQuPGjVNmZqaio6Mb/Y/R5s2bPa4RHR2t5ORkDR06VPfdd5+2bt3q9TURHFHhLgCRZcqUKTruuON08OBBLVu2TDNmzNCiRYv05ZdfKj4+vlnnXrRokaZPn14v4FRWVurBBx+UpHr/23/ggQd07733Nuu6gCRVVVUpKqr1/5P5r3/9S8OHD9ddd90Vsmuef/75GjNmjIwx2rRpk5599lmde+65euedd3TRRRe594uNjdWSJUtUWlqqbt26eZzjpZdeUmxsrA4ePNjgNWbMmKH27dvX296hQwev61y0aJGef/55nXTSSerdu7e++eabJvcfNWqULr74YjmdTu3du1effPKJpk2bpqeeekovvPCCRo4c6fW1EVit/ycVLcpFF12krKwsSdKNN96ozp0768knn9Tf//53jRo1KuT1REVFRcQvJISH0+lUTU2NYmNjFRsbG+5yAmLnzp0+/cI/loMHDyomJkZWa+MdAccff7x+85vfuP9++eWX66STTtK0adM8ws3pp5+uTz75RAsWLNDtt9/u3v7999/rww8/1OWXX67XX3+9wWtceeWVSk5ObtZnufXWW3XPPfcoLi5OEyZMOGa4OeWUUzw+lyRt2bJFF1xwgcaOHasBAwbo5JNPblZN8A/dUgiqc889V5K0adOmJvd77bXXlJmZqbi4OCUnJ+s3v/mNtm/f7n7/uuuu0/Tp0yV5NnNv3rxZXbp0kSQ9+OCD7u2u1p2GxtxYLBZNmDBBb731lgYNGiS73a4TTjhBixcvrlfX0qVLlZWVpdjYWPXp00d//etfvR7Hc/bZZ2vQoEH6/PPPNWzYMMXHx6tv375auHChJOn//u//lJ2drbi4OPXr108ffPBBvXNs375d119/vVJSUtx1zp4922OfmpoaTZo0SZmZmUpKSlK7du105plnasmSJR77uZrSH3/8cT333HPq06eP7Ha7Tj31VH3yySfH/Dx79uzRXXfdpRNPPFHt27dXYmKiLrroIn322Wf17pnFYtGrr76qP/7xj+rZs6diY2N13nnn6bvvvqt3XlctcXFxGjJkiD788MNj1iJJgwYN0jnnnFNvu9PpVI8ePXTllVe6tz3++OMaOnSoOnfurLi4OGVmZrq/DkdyfW+89NJLOuGEE2S3293fF0ePudmyZYvGjRunfv36KS4uTp07d9ZVV12lzZs3e5zT1WX70UcfqbCwUF26dFG7du10+eWXa9euXfVqePfddzVs2DAlJCQoMTFRp556ql5++WWPff773//qwgsvVFJSkuLj4zVs2DB99NFHTd4vVx3GGE2fPt39s+KyceNGXXXVVerUqZPi4+N12mmn6Z133vE4h+trO3/+fD3wwAPq0aOH4uPjVVFR0eS1j3biiScqOTm53r8LsbGxuuKKK+p93ldeeUUdO3ZUXl6eT9fxVUpKiuLi4pp1jl69emnu3LmqqanRo48+GqDK4Cv+S4ug2rBhgySpc+fOje4zd+5cFRQU6NRTT1VxcbHKysr01FNP6aOPPtLq1avVoUMH3XLLLdqxY4fef/99zZs3z31sly5dNGPGDN166626/PLLdcUVV0iSTjrppCbrWrZsmd544w2NGzdOCQkJevrpp/XrX/9aW7dudde6evVqXXjhhUpNTdWDDz4oh8OhKVOmuMOUN/bu3atf/epXGjlypK666irNmDFDI0eO1EsvvaQ77rhDv/3tbzV69Gg99thjuvLKK7Vt2zYlJCRIOjTw87TTTnP/wu3SpYveffdd3XDDDaqoqNAdd9whSaqoqNDzzz+vUaNG6aabbtL+/fv1wgsvKC8vTytWrFBGRoZHTS+//LL279+vW265RRaLRY8++qiuuOIKbdy4UdHR0Y1+lo0bN+qtt97SVVddpeOOO05lZWX661//qmHDhmnt2rXq3r27x/5Tp06V1WrVXXfdpfLycj366KO65ppr9N///te9zwsvvKBbbrlFQ4cO1R133KGNGzfqsssuU6dOnZSWltbkvc3Pz9fkyZPrdWEsW7ZMO3bs8OgSeOqpp3TZZZfpmmuuUU1NjebPn6+rrrpKb7/9ti655BKP8/7rX//Sq6++qgkTJig5OVnp6ekNXv+TTz7Rxx9/rJEjR6pnz57avHmzZsyYobPPPltr166t1w172223qWPHjioqKtLmzZs1bdo0TZgwQQsWLHDvM3fuXF1//fU64YQTNHHiRHXo0EGrV6/W4sWLNXr0aHd9F110kTIzM1VUVCSr1ao5c+bo3HPP1YcffqghQ4Y0WO9ZZ52lefPm6dprr3V3E7mUlZVp6NChqqys1O9+9zt17txZL774oi677DItXLhQl19+uce5HnroIcXExOiuu+5SdXW1YmJimvhK1bd3717t3btXffv2rffe6NGjdcEFF2jDhg3q06ePpEPfs1deeWWT35979uypty0qKiqgrVTeysnJUZ8+ffT++++H/Nr4mQECYM6cOUaS+eCDD8yuXbvMtm3bzPz5803nzp1NXFyc+f77740xxixZssRIMkuWLDHGGFNTU2O6du1qBg0aZKqqqtzne/vtt40kM2nSJPe28ePHm4a+ZXft2mUkmaKionrvFRUV1TtGkomJiTHfffede9tnn31mJJlnnnnGve3SSy818fHxZvv27e5t3377rYmKimqwjqMNGzbMSDIvv/yye9u6deuMJGO1Ws1//vMf9/b33nvPSDJz5sxxb7vhhhtMamqq2b17t8d5R44caZKSkkxlZaUxxpi6ujpTXV3tsc/evXtNSkqKuf76693bNm3aZCSZzp07mz179ri3//3vfzeSzD//+c8mP8/BgweNw+Hw2LZp0yZjt9vNlClT3NtcX+MBAwZ41PXUU08ZSeaLL74wxhz+2mdkZHjs99xzzxlJZtiwYU3Ws379+npfM2OMGTdunGnfvr37/hhjPP7suvagQYPMueee67Hd9bX56quv6l3v6O+xo89pjDHLly83ksz//M//uLe5fjZyc3ON0+l0b7/zzjuNzWYz+/btM8YYs2/fPpOQkGCys7M9fhaMMe7jnE6n+eUvf2ny8vI8zlVZWWmOO+44c/7559erqaHPMX78eI9td9xxh5FkPvzwQ/e2/fv3m+OOO86kp6e7v+6ur23v3r0b/PyNXe+GG24wu3btMjt37jT//e9/zXnnnWckmSeeeMK9X69evcwll1xi6urqTLdu3cxDDz1kjDFm7dq1RpL5v//7P/e9/OSTT9zHuX7GG3r169fPqxob0ti/N8Yc/ll67LHHGj1++PDhRpIpLy/3uwb4j24pBFRubq66dOmitLQ0jRw5Uu3bt9ebb76pHj16NLj/p59+qp07d2rcuHEeYxouueQS9e/fv16zeCDrdP2vUDrU0pOYmKiNGzdKkhwOhz744AONGDHCo0Wib9++HmMEjqV9+/YeLQj9+vVThw4dNGDAAGVnZ7u3u/7sur4xRq+//rouvfRSGWO0e/du9ysvL0/l5eVatWqVJMlms7n/5+x0OrVnzx7V1dUpKyvLvc+R8vPz1bFjR/ffzzzzTI9rN8Zut7vHVTgcDv34449q3769+vXr1+B1CgoKPP5Hf/R1XF/73/72tx77XXfddUpKSmqyFunQOI6MjAyPlg+Hw6GFCxfq0ksv9eheOPLPe/fuVXl5uc4888wG6x42bJgGDhx4zOsfec7a2lr9+OOP6tu3rzp06NDgeW+++WaPbqAzzzxTDodDW7ZskSS9//772r9/v+69995643tcx61Zs0bffvutRo8erR9//NH9PXHgwAGdd955+ve//y2n03nM2o+2aNEiDRkyRGeccYZ7W/v27XXzzTdr8+bNWrt2rcf+Y8eO9an75oUXXlCXLl3UtWtXZWdnu7voXK2PR7LZbLr66qv1yiuvSDo0kDgtLc39/dOY119/Xe+//77Ha86cOV7XGGiuwc379+8PWw1tGd1SCKjp06fr+OOPV1RUlFJSUtSvX78mBxq6/mHv169fvff69++vZcuWBaXOX/ziF/W2dezYUXv37pV0aNBlVVVVg83mDW1rTM+ePeuNz0lKSqrX5eL6Ze66/q5du7Rv3z4999xzeu655xo8986dO91/fvHFF/XEE09o3bp1qq2tdW8/7rjj6h139Gd3BR3XtRvjdDr11FNP6dlnn9WmTZvkcDjc7zXU7Xis67i+9r/85S899ouOjlbv3r2brMUlPz9f9913n7Zv364ePXpo6dKl2rlzp/Lz8z32e/vtt/Xwww9rzZo1qq6udm9vaOxUQ/esIVVVVSouLtacOXO0fft2GWPc75WXl9fb/1j3w9WFO2jQoEav+e2330o6FC4aU15e7hFevbFlyxaPsO0yYMAA9/tH1uXtPXIZPny4JkyYIIvFooSEBJ1wwglq165do/uPHj1aTz/9tD777DO9/PLLGjly5DHHuZ111lnNHlAcSD/99JMkubuZEVqEGwTUkCFD3LOlWjKbzdbg9iN/QQXzOse6vut/37/5zW8a/UXmGlf0t7/9Tdddd51GjBihu+++W127dpXNZlNxcbH7F6Yv127MI488oj/84Q+6/vrr9dBDD6lTp06yWq264447GmwtCMU9zs/P18SJE/Xaa6/pjjvu0KuvvqqkpCSPtVs+/PBDXXbZZTrrrLP07LPPKjU1VdHR0ZozZ069gauSvG6RuO222zRnzhzdcccdysnJUVJSkiwWi0aOHBm0++E672OPPVZvLJVLQ9OhA83XQbc9e/ZsdP2ahmRnZ6tPnz664447tGnTJvd4o9bkyy+/VNeuXZWYmBjuUtokwg3CqlevXpKk9evXu2dWuaxfv979vtTw/7Kb2t4cXbt2VWxsbIOzexraFmhdunRRQkKCHA7HMX8pLFy4UL1799Ybb7zhcS+KiooCWtPChQt1zjnn6IUXXvDYvm/fPr/+x+z62n777bceX/va2lpt2rTJqym0xx13nIYMGaIFCxZowoQJeuONNzRixAjZ7Xb3Pq+//rpiY2P13nvveWxvbpfFwoULNXbsWD3xxBPubQcPHtS+ffv8Op+rm/TLL79stHXQtU9iYqJPYeFYevXqpfXr19fbvm7dOvf7oTZq1Cg9/PDDGjBgQKNBrqVavny5NmzYUG+aOEKHMTcIq6ysLHXt2lUzZ8706C5499139fXXX3vMZHE1Yx/9y8M1K8XfXyoNsdlsys3N1VtvvaUdO3a4t3/33Xd69913A3adpq7/61//Wq+//rq+/PLLeu8fOYXY1SJwZAvAf//7Xy1fvjzgNR3dyvDaa695TNn3RVZWlrp06aKZM2eqpqbGvX3u3Lk+fS3z8/P1n//8R7Nnz9bu3bvrdUnZbDZZLBaPbrTNmzfrrbfe8qvuI8979P145plnPK7jiwsuuEAJCQkqLi6ut1Cd6zqZmZnq06ePHn/8cXe3x5EamlrujYsvvlgrVqzw+J45cOCAnnvuOaWnp3s1BinQbrzxRhUVFXmEx9Zgy5Ytuu666xQTE6O777473OW0WbTcIKyio6P1pz/9SQUFBRo2bJhGjRrlngqenp6uO++8071vZmamJOl3v/ud8vLyZLPZNHLkSMXFxWngwIFasGCBjj/+eHXq1EmDBg1qcuyCNyZPnqz//d//1emnn65bb71VDodDf/nLXzRo0CCtWbOmWef2xtSpU7VkyRJlZ2frpptu0sCBA7Vnzx6tWrVKH3zwgXvq669+9Su98cYbuvzyy3XJJZdo06ZNmjlzpgYOHNjgL0B//epXv9KUKVNUUFCgoUOH6osvvtBLL73k9fiYo0VHR+vhhx/WLbfconPPPVf5+fnatGmT5syZ49M5r776at11112666671KlTp3otGpdccomefPJJXXjhhRo9erR27typ6dOnq2/fvvr888/9ql06dD/mzZunpKQkDRw4UMuXL9cHH3zQ5LIHTUlMTNSf//xn3XjjjTr11FM1evRodezYUZ999pkqKyv14osvymq16vnnn9dFF12kE044QQUFBerRo4e2b9+uJUuWKDExUf/85z99vva9996rV155RRdddJF+97vfqVOnTnrxxRe1adMmvf76602OmwuWXr16+fQsr4ULFzbYJXf++ecrJSXFq3Ns2bLFvdSE6xEPDz/8sLuea6+91mP/VatW6W9/+5ucTqf27dunTz75RK+//rosFovmzZt3zCUpEEThmaSFSNPQFM2GHD0V3GXBggVm8ODBxm63m06dOplrrrnGPX3cpa6uztx2222mS5cuxmKxeEzT/Pjjj01mZqaJiYnxmLLb2FTwo6fCGnNoKurYsWM9tpWUlJjBgwebmJgY06dPH/P888+b3//+9yY2NvYYd+TQVPATTjihwetccskl9bY3VFdZWZkZP368SUtLM9HR0aZbt27mvPPOM88995x7H6fTaR555BHTq1cvY7fbzeDBg83bb79txo4da3r16uXer6npq0fes8YcPHjQ/P73vzepqakmLi7OnH766Wb58uVm2LBhHtO2XV/j1157zeN41/WPnO5ujDHP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tXv3bp1xxhkyxqiurk6//e1vdd9994Wi5Dajsd+DFRUVqqqqUlxcXFCuS8sNIsrUqVM1f/58vfnmm4qNjQ13ORFj//79uvbaazVr1iwlJyeHu5yI5nQ61bVrVz333HPKzMxUfn6+7r//fs2cOTPcpUWUpUuX6pFHHtGzzz6rVatW6Y033tA777yjhx56KNylIQBoufFScnKybDabysrKPLaXlZWpW7duDR7TrVs3n/aHf/fZ5fHHH9fUqVP1wQcf6KSTTgpmma2er/d5w4YN2rx5sy699FL3NqfTKUmKiorS+vXr1adPn+AW3Qr58/2cmpqq6Oho2Ww297YBAwaotLRUNTU1iomJCWrNrZE/9/kPf/iDrr32Wt14442SpBNPPFEHDhzQzTffrPvvv19WK//3D4TGfg8mJiYGrdVGouXGazExMcrMzFRJSYl7m9PpVElJiXJycho8Jicnx2N/SXr//fcb3R/+3WdJevTRR/XQQw9p8eLFysrKCkWprZqv97l///764osvtGbNGvfrsssu0znnnKM1a9YoLS0tlOW3Gv58P59++un67rvv3OFRkr755hulpqYSbBrhz32urKysF2BcgdLwyMWACdvvwaAOV44w8+fPN3a73cydO9esXbvW3HzzzaZDhw6mtLTUGGPMtddea+699173/h999JGJiooyjz/+uPn6669NUVERU8G94Ot9njp1qomJiTELFy40P/zwg/u1f//+cH2EVsHX+3w0Zkt5x9f7vHXrVpOQkGAmTJhg1q9fb95++23TtWtX8/DDD4frI7QKvt7noqIik5CQYF555RWzceNG87//+7+mT58+5uqrrw7XR2gV9u/fb1avXm1Wr15tJJknn3zSrF692mzZssUYY8y9995rrr32Wvf+rqngd999t/n666/N9OnTmQreEj3zzDPmF7/4hYmJiTFDhgwx//nPf9zvDRs2zIwdO9Zj/1dffdUcf/zxJiYmxpxwwgnmnXfeCXHFrZMv97lXr15GUr1XUVFR6AtvZXz9fj4S4cZ7vt7njz/+2GRnZxu73W569+5t/vjHP5q6uroQV936+HKfa2trzeTJk02fPn1MbGysSUtLM+PGjTN79+4NfeGtyJIlSxr899Z1b8eOHWuGDRtW75iMjAwTExNjevfubebMmRP0Oi3G0P4GAAAiB2NuAABARCHcAACAiEK4AQAAEYVwAwAAIgrhBgAARBTCDQAAiCiEGwAAEFEINwAAIKIQbgAAQEQh3AAAgIhCuAHQ6u3atUvdunXTI4884t728ccfKyYmpt4TiQFEPp4tBSAiLFq0SCNGjNDHH3+sfv36KSMjQ8OHD9eTTz4Z7tIAhBjhBkDEGD9+vD744ANlZWXpiy++0CeffCK73R7usgCEGOEGQMSoqqrSoEGDtG3bNq1cuVInnnhiuEsCEAaMuQEQMTZs2KAdO3bI6XRq8+bN4S4HQJjQcgMgItTU1GjIkCHKyMhQv379NG3aNH3xxRfq2rVruEsDEGKEGwAR4e6779bChQv12WefqX379ho2bJiSkpL09ttvh7s0ACFGtxSAVm/p0qWaNm2a5s2bp8TERFmtVs2bN08ffvihZsyYEe7yAIQYLTcAACCi0HIDAAAiCuEGAABEFMINAACIKIQbAAAQUQg3AAAgohBuAABARCHcAACAiEK4AQAAEYVwAwAAIgrhBgAARBTCDQAAiCiEGwAAEFH+Pz1o6hz7NtO5AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\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": 16,
   "id": "6fd587e6-4cf8-4cc4-92bd-ac09c7be790a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function datasets.PME_1D.get_mass_rhs_func.<locals>.mass_rhs_func(inputs)>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func(x=x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "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": 18,
   "id": "b339b6e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "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": 20,
   "id": "b202791b-cc81-4a0a-b82b-db3c5a831a77",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function datasets.PME_1D.get_mass_rhs_func.<locals>.mass_rhs_func(inputs)>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mass_rhs_func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "d71ec298-4bbc-4186-a938-8675f0526890",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "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": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "2165975d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, -1, 5]"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tpred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "1ad2c532",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0, -1,  5])"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.tensor(tpred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "18a1c208-a4df-4f27-8dad-f2466164e855",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "6ff40f4d-d8b7-45f7-8e3a-8115564540df",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=-13.477332, Validation loss=-297.353540 (saved)\n",
      "Epoch 1: Train loss=-611.099890, Validation loss=-1136.079004 (saved)\n",
      "Epoch 2: Train loss=-1724.897766, Validation loss=-2883.520312 (saved)\n",
      "Epoch 3: Train loss=-4904.418945, Validation loss=-7513.643359 (saved)\n",
      "Epoch 4: Train loss=-5162.409424, Validation loss=-8602.163281 (saved)\n",
      "Epoch 5: Train loss=-6967.420410, Validation loss=-7119.462109 \n",
      "Epoch 6: Train loss=-6706.914648, Validation loss=-6763.138281 \n",
      "Epoch 7: Train loss=-7042.635156, Validation loss=-7422.469922 \n",
      "Epoch 8: Train loss=-7960.102832, Validation loss=-8711.162891 (saved)\n",
      "Epoch 9: Train loss=-9503.144727, Validation loss=-10531.161719 (saved)\n",
      "Epoch 10: Train loss=-11335.750781, Validation loss=-9790.692188 \n",
      "Epoch 11: Train loss=2654.446484, Validation loss=-5738.425000 \n",
      "Epoch 12: Train loss=-5749.891943, Validation loss=-5934.845703 \n",
      "Epoch 13: Train loss=-5743.726367, Validation loss=-5529.789453 \n",
      "Epoch 14: Train loss=-5520.197070, Validation loss=-5562.233594 \n",
      "Epoch 15: Train loss=-5682.321533, Validation loss=-5846.889844 \n",
      "Epoch 16: Train loss=-6012.516211, Validation loss=-6220.214453 \n",
      "Epoch 17: Train loss=-6403.267090, Validation loss=-6631.959766 \n",
      "Epoch 18: Train loss=-6846.702051, Validation loss=-7122.287891 \n",
      "Epoch 19: Train loss=-7367.009277, Validation loss=-7674.850781 \n",
      "Epoch 20: Train loss=-7950.159668, Validation loss=-8305.712109 \n",
      "Epoch 21: Train loss=-8618.900488, Validation loss=-9028.531250 \n",
      "Epoch 22: Train loss=-9387.359863, Validation loss=-9858.593750 \n",
      "Epoch 23: Train loss=-10272.653125, Validation loss=-10820.898828 (saved)\n",
      "Epoch 24: Train loss=-11286.093262, Validation loss=-11906.397266 (saved)\n",
      "Epoch 25: Train loss=-12407.344238, Validation loss=-13125.166016 (saved)\n",
      "Epoch 26: Train loss=-8098.364746, Validation loss=522.189212 \n",
      "Epoch 27: Train loss=-6313.608643, Validation loss=-7289.071875 \n",
      "Epoch 28: Train loss=-8192.831836, Validation loss=-8371.116016 \n",
      "Epoch 29: Train loss=-8315.268262, Validation loss=-8250.154297 \n",
      "Epoch 30: Train loss=-8536.063379, Validation loss=-8799.614844 \n",
      "Epoch 31: Train loss=-9016.203516, Validation loss=-9387.674609 \n",
      "Epoch 32: Train loss=-9677.648926, Validation loss=-10093.663672 \n",
      "Epoch 33: Train loss=-10460.946875, Validation loss=-10942.288672 \n",
      "Epoch 34: Train loss=-11374.665918, Validation loss=-11937.865234 \n",
      "Epoch 35: Train loss=-12428.835742, Validation loss=-13080.922266 \n",
      "Epoch 36: Train loss=-13558.189453, Validation loss=-13942.160938 (saved)\n",
      "Epoch 37: Train loss=-8312.329932, Validation loss=-7041.254687 \n",
      "Epoch 38: Train loss=-10728.606152, Validation loss=-11324.848438 \n",
      "Epoch 39: Train loss=-11163.549414, Validation loss=-11235.921094 \n",
      "Epoch 40: Train loss=-11423.536621, Validation loss=-11673.508594 \n",
      "Epoch 41: Train loss=-12027.304883, Validation loss=-12502.939062 \n",
      "Epoch 42: Train loss=-12981.131738, Validation loss=-13625.172656 \n",
      "Epoch 43: Train loss=-14149.966406, Validation loss=-14889.282031 (saved)\n",
      "Epoch 44: Train loss=15264.889648, Validation loss=7228.841797 \n",
      "Epoch 45: Train loss=-2746.521362, Validation loss=-5460.215625 \n",
      "Epoch 46: Train loss=-4854.451611, Validation loss=-4435.837891 \n",
      "Epoch 47: Train loss=-4428.526514, Validation loss=-4490.203516 \n",
      "Epoch 48: Train loss=-4575.733252, Validation loss=-4672.589648 \n",
      "Epoch 49: Train loss=-4742.511035, Validation loss=-4828.524023 \n",
      "Epoch 50: Train loss=-4870.008057, Validation loss=-4919.376172 \n",
      "Epoch 51: Train loss=-4963.977881, Validation loss=-5014.080078 \n",
      "Epoch 52: Train loss=-5056.992041, Validation loss=-5103.037891 \n",
      "Epoch 53: Train loss=-5144.499121, Validation loss=-5188.978711 \n",
      "Epoch 54: Train loss=-5230.090771, Validation loss=-5273.676758 \n",
      "Epoch 55: Train loss=-5314.425879, Validation loss=-5357.528125 \n",
      "Epoch 56: Train loss=-5397.893262, Validation loss=-5440.594336 \n",
      "Epoch 57: Train loss=-5480.731738, Validation loss=-5523.309180 \n",
      "Epoch 58: Train loss=-5563.459375, Validation loss=-5606.054688 \n",
      "Epoch 59: Train loss=-5646.305566, Validation loss=-5689.168945 \n",
      "Epoch 60: Train loss=-5729.681201, Validation loss=-5772.838672 \n",
      "Epoch 61: Train loss=-5813.709619, Validation loss=-5857.294141 \n",
      "Epoch 62: Train loss=-5898.541895, Validation loss=-5942.758203 \n",
      "Epoch 63: Train loss=-5984.519434, Validation loss=-6029.320508 \n",
      "Epoch 64: Train loss=-6071.600342, Validation loss=-6117.186914 \n",
      "Epoch 65: Train loss=-6160.074854, Validation loss=-6206.445703 \n",
      "Epoch 66: Train loss=-6249.996240, Validation loss=-6297.254297 \n",
      "Epoch 67: Train loss=-6341.497217, Validation loss=-6389.749609 \n",
      "Epoch 68: Train loss=-6434.745020, Validation loss=-6484.035547 \n",
      "Epoch 69: Train loss=-6529.852539, Validation loss=-6580.243359 \n",
      "Epoch 70: Train loss=-6626.950195, Validation loss=-6678.566016 \n",
      "Epoch 71: Train loss=-6726.215137, Validation loss=-6779.147656 \n",
      "Epoch 72: Train loss=-6827.798242, Validation loss=-6882.108203 \n",
      "Epoch 73: Train loss=-6931.883691, Validation loss=-6987.666406 \n",
      "Epoch 74: Train loss=-7038.625586, Validation loss=-7096.130859 \n",
      "Epoch 75: Train loss=-7148.454395, Validation loss=-7207.728125 \n",
      "Epoch 76: Train loss=-7261.430469, Validation loss=-7322.696484 \n",
      "Epoch 77: Train loss=-7378.016113, Validation loss=-7441.409766 \n",
      "Epoch 78: Train loss=-7498.519238, Validation loss=-7564.282812 \n",
      "Epoch 79: Train loss=-7623.388184, Validation loss=-7691.950781 \n",
      "Epoch 80: Train loss=-7753.322852, Validation loss=-7825.018750 \n",
      "Epoch 81: Train loss=-7889.019434, Validation loss=-7964.263281 \n",
      "Epoch 82: Train loss=-8031.427441, Validation loss=-8110.989844 \n",
      "Epoch 83: Train loss=-8181.695215, Validation loss=-8266.757812 \n",
      "Epoch 84: Train loss=-8342.464844, Validation loss=-8434.039453 \n",
      "Epoch 85: Train loss=-8515.734961, Validation loss=-8616.356641 \n",
      "Epoch 86: Train loss=-8706.155078, Validation loss=-8818.326172 \n",
      "Epoch 87: Train loss=-8921.065527, Validation loss=-9051.658984 \n",
      "Epoch 88: Train loss=-9170.151074, Validation loss=-9326.796094 \n",
      "Epoch 89: Train loss=-9471.198047, Validation loss=-9667.206250 \n",
      "Epoch 90: Train loss=-9848.840137, Validation loss=-10101.304297 \n",
      "Epoch 91: Train loss=-10331.806152, Validation loss=-10596.003906 \n",
      "Epoch 92: Train loss=-10754.200098, Validation loss=-10520.630859 \n",
      "Epoch 93: Train loss=-10898.995996, Validation loss=-11501.533203 \n",
      "Epoch 94: Train loss=-11515.529590, Validation loss=-11912.235937 \n",
      "Epoch 95: Train loss=-12017.275684, Validation loss=-12263.991797 \n",
      "Epoch 96: Train loss=-12249.909863, Validation loss=-12903.645313 \n",
      "Epoch 97: Train loss=-12901.431445, Validation loss=-12943.955078 \n",
      "Epoch 98: Train loss=-12557.493750, Validation loss=-12601.671094 \n",
      "Epoch 99: Train loss=-13135.844043, Validation loss=-13707.785938 \n",
      "Epoch 100: Train loss=-14009.341602, Validation loss=-14278.340625 \n",
      "Epoch 101: Train loss=-14330.076172, Validation loss=-14643.651562 \n",
      "Epoch 102: Train loss=-14828.801758, Validation loss=-15080.475000 (saved)\n",
      "Epoch 103: Train loss=-14945.781055, Validation loss=-13932.008594 \n",
      "Epoch 104: Train loss=-13483.355762, Validation loss=-15002.189062 \n",
      "Epoch 105: Train loss=-14253.566992, Validation loss=-14354.435938 \n",
      "Epoch 106: Train loss=-14892.675391, Validation loss=-14821.220312 \n",
      "Epoch 107: Train loss=-15319.514258, Validation loss=-15207.335938 (saved)\n",
      "Epoch 108: Train loss=-15385.880859, Validation loss=-15758.851562 (saved)\n",
      "Epoch 109: Train loss=-15818.153906, Validation loss=-16252.266406 (saved)\n",
      "Epoch 110: Train loss=-16168.500391, Validation loss=-16274.792187 (saved)\n",
      "Epoch 111: Train loss=-15081.217578, Validation loss=-8888.685938 \n",
      "Epoch 112: Train loss=-14499.260352, Validation loss=-16435.357812 (saved)\n",
      "Epoch 113: Train loss=-15938.048633, Validation loss=-15927.037500 \n",
      "Epoch 114: Train loss=-16194.520117, Validation loss=-16614.266406 (saved)\n",
      "Epoch 115: Train loss=-16581.300195, Validation loss=-16887.658594 (saved)\n",
      "Epoch 116: Train loss=-16512.732617, Validation loss=-16159.605469 \n",
      "Epoch 117: Train loss=-14129.633691, Validation loss=-8926.664844 \n",
      "Epoch 118: Train loss=-13333.396680, Validation loss=-14732.946094 \n",
      "Epoch 119: Train loss=-14778.806152, Validation loss=-13884.439844 \n",
      "Epoch 120: Train loss=-15348.499805, Validation loss=-15434.321875 \n",
      "Epoch 121: Train loss=-15719.976367, Validation loss=-15939.026562 \n",
      "Epoch 122: Train loss=-16063.594531, Validation loss=-16045.965625 \n",
      "Epoch 123: Train loss=-16362.312109, Validation loss=-16534.433594 \n",
      "Epoch 124: Train loss=-16751.801563, Validation loss=-16899.631250 (saved)\n",
      "Epoch 125: Train loss=-17068.838867, Validation loss=-17314.750000 (saved)\n",
      "Epoch 126: Train loss=-17370.710352, Validation loss=-17547.545312 (saved)\n",
      "Epoch 127: Train loss=-17652.980859, Validation loss=-16830.065625 \n",
      "Epoch 128: Train loss=-7172.339551, Validation loss=153558.806250 \n",
      "Epoch 129: Train loss=27502.175122, Validation loss=-10889.758984 \n",
      "Epoch 130: Train loss=-8065.469922, Validation loss=-11942.660938 \n",
      "Epoch 131: Train loss=-11752.190039, Validation loss=-11409.900391 \n",
      "Epoch 132: Train loss=-11962.368164, Validation loss=-12008.285938 \n",
      "Epoch 133: Train loss=-11967.312891, Validation loss=-12120.550000 \n",
      "Epoch 134: Train loss=-12204.226758, Validation loss=-12211.858594 \n",
      "Epoch 135: Train loss=-12263.416016, Validation loss=-12335.565234 \n",
      "Epoch 136: Train loss=-12372.434473, Validation loss=-12411.408594 \n",
      "Epoch 137: Train loss=-12469.937988, Validation loss=-12522.456641 \n",
      "Epoch 138: Train loss=-12571.434375, Validation loss=-12622.401172 \n",
      "Epoch 139: Train loss=-12674.692090, Validation loss=-12725.617969 \n",
      "Epoch 140: Train loss=-12779.366699, Validation loss=-12832.091797 \n",
      "Epoch 141: Train loss=-12885.940625, Validation loss=-12939.650391 \n",
      "Epoch 142: Train loss=-12994.908105, Validation loss=-13049.382031 \n",
      "Epoch 143: Train loss=-13105.435840, Validation loss=-13161.700000 \n",
      "Epoch 144: Train loss=-13218.537793, Validation loss=-13275.499219 \n",
      "Epoch 145: Train loss=-13333.601758, Validation loss=-13391.978125 \n",
      "Epoch 146: Train loss=-13450.973047, Validation loss=-13510.158594 \n",
      "Epoch 147: Train loss=-13570.408398, Validation loss=-13630.952344 \n",
      "Epoch 148: Train loss=-13691.770703, Validation loss=-13754.420313 \n",
      "Epoch 149: Train loss=-13815.787500, Validation loss=-13879.992969 \n",
      "Epoch 150: Train loss=-13914.908984, Validation loss=-13943.798437 \n",
      "Epoch 151: Train loss=-13979.320898, Validation loss=-14008.350781 \n",
      "Epoch 152: Train loss=-14044.391992, Validation loss=-14074.138281 \n",
      "Epoch 153: Train loss=-14110.241797, Validation loss=-14140.558594 \n",
      "Epoch 154: Train loss=-14177.154883, Validation loss=-14208.011719 \n",
      "Epoch 155: Train loss=-14244.961914, Validation loss=-14275.937500 \n",
      "Epoch 156: Train loss=-14313.334766, Validation loss=-14344.829687 \n",
      "Epoch 157: Train loss=-14382.330469, Validation loss=-14415.021875 \n",
      "Epoch 158: Train loss=-14452.964648, Validation loss=-14484.905469 \n",
      "Epoch 159: Train loss=-14523.820508, Validation loss=-14557.178125 \n",
      "Epoch 160: Train loss=-14595.222656, Validation loss=-14629.792969 \n",
      "Epoch 161: Train loss=-14666.789258, Validation loss=-14702.578125 \n",
      "Epoch 162: Train loss=-14742.196484, Validation loss=-14777.256250 \n",
      "Epoch 163: Train loss=-14816.631055, Validation loss=-14850.850781 \n",
      "Epoch 164: Train loss=-14891.571875, Validation loss=-14928.190625 \n",
      "Epoch 165: Train loss=-14967.191797, Validation loss=-15004.496094 \n",
      "Epoch 166: Train loss=-15044.148438, Validation loss=-15082.632812 \n",
      "Epoch 167: Train loss=-15121.949219, Validation loss=-15161.017969 \n",
      "Epoch 168: Train loss=-15201.697656, Validation loss=-15240.636719 \n",
      "Epoch 169: Train loss=-15281.684375, Validation loss=-15321.217188 \n",
      "Epoch 170: Train loss=-15361.774414, Validation loss=-15402.710938 \n",
      "Epoch 171: Train loss=-15442.517578, Validation loss=-15484.863281 \n",
      "Epoch 172: Train loss=-15525.604492, Validation loss=-15567.532812 \n",
      "Epoch 173: Train loss=-15607.610352, Validation loss=-15646.885156 \n",
      "Epoch 174: Train loss=-15689.730078, Validation loss=-15727.089062 \n",
      "Epoch 175: Train loss=-15767.928320, Validation loss=-15814.310156 \n",
      "Epoch 176: Train loss=-15861.325781, Validation loss=-15907.487500 \n",
      "Epoch 177: Train loss=-15945.396094, Validation loss=-15994.397656 \n",
      "Epoch 178: Train loss=-16034.891016, Validation loss=-16078.946094 \n",
      "Epoch 179: Train loss=-16121.295313, Validation loss=-16167.107031 \n",
      "Epoch 180: Train loss=-16209.553320, Validation loss=-16240.665625 \n",
      "Epoch 181: Train loss=-16280.178125, Validation loss=-16349.554688 \n",
      "Epoch 182: Train loss=-16371.505078, Validation loss=-16419.595313 \n",
      "Epoch 183: Train loss=-16469.625586, Validation loss=-16501.757031 \n",
      "Epoch 184: Train loss=-16552.058984, Validation loss=-16619.412500 \n",
      "Epoch 185: Train loss=-16638.869922, Validation loss=-16711.145313 \n",
      "Epoch 186: Train loss=-16751.204102, Validation loss=-16803.130469 \n",
      "Epoch 187: Train loss=-16835.171094, Validation loss=-16867.447656 \n",
      "Epoch 188: Train loss=-16919.155078, Validation loss=-16990.556250 \n",
      "Epoch 189: Train loss=-17003.477344, Validation loss=-17047.721094 \n",
      "Epoch 190: Train loss=-17070.526562, Validation loss=-17126.207031 \n",
      "Epoch 191: Train loss=-17168.155469, Validation loss=-17245.190625 \n",
      "Epoch 192: Train loss=-17289.106445, Validation loss=-17360.988281 \n",
      "Epoch 193: Train loss=-17390.065234, Validation loss=-17413.761719 \n",
      "Epoch 194: Train loss=-17457.856641, Validation loss=-17540.402344 \n",
      "Epoch 195: Train loss=-17567.010156, Validation loss=-17588.787500 (saved)\n",
      "Epoch 196: Train loss=-17575.513281, Validation loss=-17672.593750 (saved)\n",
      "Epoch 197: Train loss=-17676.095703, Validation loss=-17694.269531 (saved)\n",
      "Epoch 198: Train loss=-17780.783398, Validation loss=-17895.842969 (saved)\n",
      "Epoch 199: Train loss=-17903.226953, Validation loss=-18004.464062 (saved)\n",
      "Finished training with best train loss: -17993.575195 and validation loss: -18004.464062\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": 27,
   "id": "61efde5e-a31a-4ec9-87ee-17cf2402b98d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.save(model.state_dict(), \"./pme_e2e_var_update_crps.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "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": 29,
   "id": "41b11e17-4840-42fe-9a5b-34d65f0a77d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from nonlinear_projection import project_and_stats\n",
    "\n",
    "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",
    "            # nf,nx,nt,_ = _mu.shape\n",
    "\n",
    "            # _mu = _mu.view(nf, -1)\n",
    "            # _var = _var.view(nf, -1)\n",
    "            # _m = x.view(nf, -1)\n",
    "\n",
    "            # # print(_m)\n",
    "\n",
    "            # u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "\n",
    "            # # print(u_proj, u_var)\n",
    "\n",
    "            # if  u_proj.isnan().any().item() or  u_var.isnan().any().item():\n",
    "            #     print(\"any NaN in new_mu?\", u_proj.isnan().any().item())\n",
    "            #     # print(\"min new_var before clamp:\", u_var.min().item())\n",
    "            #     print(\"any NaN in new_var before clamp?\", u_var.isnan().any().item())\n",
    "            #     # new_var = new_var.clamp(min=eps)\n",
    "            #     # print(\"min new_var after clamp:\", new_var.min().item())\n",
    "\n",
    "            # out = (u_proj.view(nf,nx,nt,1), u_var.view(nf,nx,nt,1))\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": 60,
   "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: 8.150137728080153e-05\n",
      "n-MeRCI: 0.7598856687545776\n",
      "RMSCE: 0.19964216649532318\n",
      "Cerr: 0.031460557132959366\n",
      "In-domain results\n",
      "MSE: 8.00728495232761e-05\n",
      "n-MeRCI: 0.5658753514289856\n",
      "RMSCE: 0.20721453428268433\n",
      "ProbConserv Results\n",
      "MSE: 8.63672886043787e-05\n",
      "n-MeRCI: 0.5186362862586975\n",
      "RMSCE: 0.21403154730796814\n",
      "Cerr: 0.030506158247590065\n",
      "Prob_Cerr: 2.6053245960611093e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 8.921212633140385e-05\n",
      "n-MeRCI: 0.8005278706550598\n",
      "RMSCE: 0.19954480230808258\n",
      "ProbConserv Results\n",
      "MSE: 9.446778334677219e-05\n",
      "n-MeRCI: 0.7335586547851562\n",
      "RMSCE: 0.20897170901298523\n",
      "Cerr: 0.028508849442005157\n",
      "Prob_Cerr: 2.832791210494179e-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": 61,
   "id": "00406482-eb2b-41df-b458-1d230c92ff1a",
   "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']:.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": 62,
   "id": "a48efcc2-03a0-47c2-8af5-62cd2fd6e4e4",
   "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=\"Unconstrained\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "aa075212-97ba-4823-bac0-e43558b27ce2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "9.446777403354645e-05"
      ]
     },
     "execution_count": 63,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "ca88a17e-fc02-4347-8c26-74fa8bd4d1d2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Unconstrained & 8.81E-05 & 6.90E-01 & 2.07E-01 & 2.68E-07 & 3.72E-03 & 9.45E-05 & 7.34E-01 & 2.09E-01 & 2.83E-07 & 3.67E-03 \\\\\\\\'"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "98acb797",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8.63672886043787e-05"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "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\n",
    "nf,nx,nt,_ = mu.shape\n",
    "\n",
    "# _mu = mu.view(nf, -1)\n",
    "# _var = var.view(nf, -1)\n",
    "# _m = x.view(nf, -1).to(device)\n",
    "\n",
    "# # print(_m)\n",
    "\n",
    "# u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "\n",
    "# out = (u_proj.view(nf,nx,nt,1), u_var .view(nf,nx,nt,1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()\n",
    "\n",
    "std = torch.sqrt(var)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "fa65af1d-7356-4892-acff-81125e64347f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0479, grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(utils.compute_crps_by_example(mu, var, y_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "11e418ff-cbf6-4455-a062-676e2df0a1cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# u_proj, u_var = project_and_stats(nmu.view(nf,-1).to(device), nvar.view(nf,-1).to(device), _m, model.full_residual, max_iter=30)\n",
    "# nmu, nvar = (u_proj.view(nf,nx,nt,1), u_var.view(nf,nx,nt,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "b4d043cc-dd31-4a21-ad06-663438462c21",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.norm(utils.compute_crps_by_example(mu.cpu(), nvar.cpu(), y_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "a2ecdfcd-84ec-49f2-9d09-51549d332c28",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.func import vmap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "5e96a231-5af5-4a84-af56-f3069403e0b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.norm(vmap(model.full_residual)(torch.relu(mu.to(device)), _m),dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "4cd9a8f9-b2d7-43c3-982b-f4e547fcaf20",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(8.3125e-05, grad_fn=<MseLossBackward0>)"
      ]
     },
     "execution_count": 72,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.nn.MSELoss()(y_train[0,:,1,:],mu[0,:,1,:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "995e5a6f-63e8-4cf3-85f9-73f8d7d30009",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0912)\n"
     ]
    },
    {
     "data": {
      "image/png": "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evToAQB488038ec//xl6vb7eY549e9ZrmU6n86tqLFiysrLQo0cPbNy4sd5t+vXrh9dffx133nknOnXqhL///e8AgJSUFFRVVWHs2LE4ePAg5s6di27duuHdd9/F9OnTUVxcjNtvv93jWA1dH3XZsmUL1qxZg9tuuw1GoxEvvPACLr30UuzYsQMDBw4EAHz77bf46quvcM0116BTp044fPgwli9fjrFjx2Lfvn2IjIz0OObs2bORkpKChQsXoqKiIqBj3HrrrUhPT8fDDz+Mr7/+Gi+++CLi4+Px1VdfoUuXLnjiiSewfv16/OMf/8DAgQMxdepU17433XQTVq1ahRkzZuC2225Dbm4u/vnPf2L37t3Ytm0b9Ho9li5diltvvRXR0dGudi5paWkA7NVOY8aMwYkTJ3DTTTehS5cu+Oqrr7BgwQKcOnUKS5cuDficl5SUwGq1NvieAPYfAnVV7zbG2Q4uOTnZ733r2//TTz8FABiNRowYMQI7d+6EwWDAFVdcgRdeeKHRa4yaUahTUtR++VI1NnPmTJGRkSFOnz7tsfyaa64RcXFxrhSzzWbzSqUXFRWJtLQ08be//c21zFkFExsbKwoKCjy2d1YJuW8vhBBXXHGFSEpK8ljWtWtXMW3aNK/XMn78eKFpmmv5nXfeKRRFEcXFxUIIe1WRTqcTkydP9jjeQw89JAB4HLM+AMTMmTNFYWGhKCgoEN98840YN26cACCefvppjzJedtllwmazifT0dPHoo48KIYTYt2+fACC2bNlS53vgPA91Pfr06dNo+eoTaNWY06RJkwQAUVJS0uDzOF+3u6VLlwoA4o033nAts1gsIisrS0RHR4vS0lKPctR1fdTHeW6+++4717IjR44Ik8kkrrjiCteyuqpDtm/fLgCIf//7365lzvdk9OjRwmazeWzv7zGys7M9rsesrCwhSZK4+eabXctsNpvo1KmTR/XWl19+KQCI1atXezzXhg0bvJbXVzX26KOPiqioKPHrr796LL/33nuFoiji6NGjQojAzvmYMWPqvUbdH758nuoyfvx4ERsbK4qKivze12w2i/79+4tu3boJq9XqWv7HP/5RABBJSUniuuuuE2vXrhUPPvig0Ol04vzzz/d4n6hlsWqMWi0hBN577z1cfvnlEELg9OnTrkd2djZKSkqwa9cuAICiKDAYDADsKf2z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iLfeekv89ttv4pNPPhE9evQQV111VaheQlgoKysTu3fvFrt37xYAxDPPPCN2794tjhw5IoQQ4t577xXXX3+9a3tn9/n58+eLn3/+WTz//PPsPh/OnnvuOdGlSxdhMBjEyJEjxddff+1aN2bMGDFt2jSP7d955x3Ru3dvYTAYxIABA8S6detauMThy59z3bVrVwHA67Fo0aKWL3iY8feadsdAyHf+nuevvvpKjBo1ShiNRtG9e3fx+OOPC5vN1sKlDj/+nGer1Soeeugh0aNHD2EymUTnzp3F7NmzRVFRUcsXPIx8/vnndX7fOs/ttGnTxJgxY7z2GTp0qDAYDKJ79+7i1VdfbdYySkIwp0dERETtE9sIERERUbvFQIiIiIjaLQZCRERE1G4xECIiIqJ2i4EQERERtVsMhIiIiKjdYiBERERE7RYDISIiImq3GAgRERFRu8VAiIiIiNotBkJE1K4UFhYiPT0dTzzxhGvZV199BYPB4DXrNRG1fZxrjIjanfXr12Py5Mn46quv0KdPHwwdOhSTJk3CM888E+qiEVELYyBERO3SnDlz8Omnn2LEiBH44Ycf8O2338JoNIa6WETUwhgIEVG7VFVVhYEDB+LYsWPYuXMnBg0aFOoiEVEIsI0QEbVLhw4dwsmTJ6FpGg4fPhzq4hBRiDAjRETtjsViwciRIzF06FD06dMHS5cuxQ8//IDU1NRQF42IWhgDISJqd+bPn4+1a9di7969iI6OxpgxYxAXF4f//e9/oS4aEbUwVo0RUbuyefNmLF26FK+//jpiY2MhyzJef/11fPnll1i+fHmoi0dELYwZISIiImq3mBEiIiKidouBEBEREbVbDISIiIio3WIgRERERO0WAyEiIiJqtxgIERERUbvFQIiIiIjaLQZCRERE1G4xECIiIqJ2i4EQERERtVsMhIiIiKjdYiBERERE7db/B4rbYixfpjicAAAAAElFTkSuQmCC",
      "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$ (probconserv)\")\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",
    "        \n",
    "        plt.plot(grid, mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (probharde2e)\")\n",
    "        plt.fill_between(grid, mu[parameters_idx,:,t_idx,0]+3*std[parameters_idx,:,t_idx,0], mu[parameters_idx,:,t_idx,0]-3*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",
    "        \n",
    "        print(torch.norm(y_train[parameters_idx,:,t_idx,0] - mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "4dfa6e03-c09a-406f-abf8-d41d68afa9f6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "6376bd34-380d-43f0-b9ae-e21dfa77d686",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 75,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "var.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "1824da2b-18e6-4b1f-80d5-4e5d7e167a9d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100])"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "01feae7c-7aba-49ca-9723-f00545566493",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "slice(0, -1, 5)"
      ]
     },
     "execution_count": 77,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "slice(*tpred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "67a10613-e7ed-48d3-bd48-3cd1f6ace4b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0505, 0.1010, 0.1515, 0.2020, 0.2525, 0.3030, 0.3535, 0.4040,\n",
       "        0.4545, 0.5051, 0.5556, 0.6061, 0.6566, 0.7071, 0.7576, 0.8081, 0.8586,\n",
       "        0.9091, 0.9596])"
      ]
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t[slice(*tpred)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "eecfe6c0-2ee6-4918-b2b8-7856bf097fdf",
   "metadata": {},
   "outputs": [],
   "source": [
    "dt = t[slice(*tpred)][1] - t[slice(*tpred)][0]\n",
    "dx = grid[1] - grid[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "7e3bc062-c816-49f6-bc44-103fa68cadbc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def conservation_residual_all_times(u_flat, m):\n",
    "    u = u_flat.view(nx, nt)\n",
    "\n",
    "    # Initial mass\n",
    "    mass_0 = torch.sum(u[:, 0]) * dx  # shape: scalar\n",
    "\n",
    "    # Compute u^m * ∂u/∂x at left and right boundary for all time steps\n",
    "    um = u ** m\n",
    "    ux_left = (u[1, :] - u[0, :]) / dx         # shape: (nt,)\n",
    "    ux_right = (u[-1, :] - u[-2, :]) / dx      # shape: (nt,)\n",
    "    \n",
    "    flux_left = um[0, :] * ux_left             # u^m * u_x at x = 0\n",
    "    flux_right = um[-1, :] * ux_right          # u^m * u_x at x = 1\n",
    "\n",
    "    net_flux = torch.cumsum(flux_right - flux_left, dim=0) * dt  # ∫₀^t (flux_right - flux_left)\n",
    "\n",
    "    # Total mass at each time\n",
    "    mass_t = torch.sum(u, dim=0) * dx          # shape: (nt,)\n",
    "\n",
    "    # Conservation residual\n",
    "    residue = mass_t - mass_0 + net_flux       # sign flipped because outflow reduces mass\n",
    "\n",
    "    return residue  # shape: (nt,)\n",
    "\n",
    "# Combine\n",
    "def full_residual(u_flat):\n",
    "    return torch.cat([conservation_residual_all_times(u_flat)])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "7567e79a-911c-4214-8d55-f2e05643e4e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.func import vmap, jacrev\n",
    "\n",
    "# --- Projection code ---\n",
    "def fast_project_batched(xi_batch, h_func, max_iter=30):\n",
    "    B, n = xi_batch.shape\n",
    "\n",
    "    def newton_step(u, xi):\n",
    "        h_val = h_func(u)\n",
    "        if h_val.ndim == 1:\n",
    "            h_val = h_val.unsqueeze(-1)\n",
    "        J = jacrev(h_func)(u)\n",
    "        if J.ndim == 1:\n",
    "            J = J.unsqueeze(0)\n",
    "        delta = (xi - u).unsqueeze(-1)\n",
    "        JJt = J @ J.transpose(-2, -1)\n",
    "        rhs = J @ delta + h_val\n",
    "        lambda_ = torch.linalg.solve(JJt, rhs)\n",
    "        du = delta - J.transpose(-2, -1) @ lambda_\n",
    "        return u + du.squeeze(-1)\n",
    "\n",
    "    def loop(xi):\n",
    "        u = xi.clone()\n",
    "        for _ in range(max_iter):\n",
    "            u = newton_step(u, xi)\n",
    "        return u\n",
    "\n",
    "    return vmap(loop)(xi_batch)\n",
    "\n",
    "def fast_project_weighted(xi_batch, sigma_batch, h_func, max_iter=30):\n",
    "    \"\"\"\n",
    "    Solve: argmin_u ||u - xi||^2_{sigma^{-1}} s.t. h(u) = 0\n",
    "    Args:\n",
    "        xi_batch: (B, n)\n",
    "        sigma_batch: (B, n)\n",
    "        h_func: function u → ℝ^m\n",
    "    Returns:\n",
    "        u_proj: (B, n)\n",
    "    \"\"\"\n",
    "    B, n = xi_batch.shape\n",
    "\n",
    "    def newton_step(u, xi, sigma):\n",
    "        sigma_inv = 1.0 / (sigma)         # shape (n,)\n",
    "        h_val = h_func(u)\n",
    "        if h_val.ndim == 1:\n",
    "            h_val = h_val.unsqueeze(-1)\n",
    "        J = jacrev(h_func)(u)\n",
    "        if J.ndim == 1:\n",
    "            J = J.unsqueeze(0)\n",
    "\n",
    "        delta = (xi - u).unsqueeze(-1)           # shape (n, 1)\n",
    "\n",
    "        # Use elementwise weighting: JW = J * sigma_inv[None, :]\n",
    "        JW = J * sigma_inv.unsqueeze(0)              # shape (m, n)\n",
    "        JJt = JW @ J.transpose(-2, -1)               # (m, m)\n",
    "        rhs = JW @ delta + h_val                     # (m, 1)\n",
    "\n",
    "        lambda_ = torch.linalg.solve(JJt, rhs)       # (m, 1)\n",
    "        Jt_lambda = J.transpose(-2, -1) @ lambda_    # (n, 1)\n",
    "\n",
    "        du = sigma_inv.unsqueeze(-1) * (delta - Jt_lambda)  # elementwise multiply\n",
    "\n",
    "\n",
    "        return u + du.squeeze(-1)\n",
    "\n",
    "    def loop(xi, sigma):\n",
    "        u = xi.clone()\n",
    "        for _ in range(max_iter):\n",
    "            u = newton_step(u, xi, sigma)\n",
    "        return u\n",
    "\n",
    "    return vmap(loop)(xi_batch, sigma_batch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "7ab81cad-a983-472d-a561-627d397b2938",
   "metadata": {},
   "outputs": [],
   "source": [
    "nf,nx,nt, _ = mu.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "5d8bdf1f-e427-4098-87bb-11017ac65088",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_flat = mu.view(nf, -1).to(device)\n",
    "var_flat = var.view(nf, -1).to(device)\n",
    "m_flat = x_train.view(nf, -1).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "5d9cbb76-f1a6-4bd0-8a1f-1808abb5539e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 2000])"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu_flat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "27fa38f0-9d5f-49b6-bcc8-0f455cd0ff99",
   "metadata": {},
   "outputs": [],
   "source": [
    "# def conservation_residual_all_times(u_flat, m_flat):\n",
    "#     u = u_flat.view(nx, nt)\n",
    "#     m = m_flat.view(nx, nt)\n",
    "\n",
    "#     # Initial mass\n",
    "#     mass_0 = torch.sum(u[:, 0]) * dx  # shape: scalar\n",
    "\n",
    "#     # Compute u^m * ∂u/∂x at left and right boundary for all time steps\n",
    "#     um = u ** m\n",
    "#     ux_left = (u[1, :] - u[0, :]) / dx         # shape: (nt,)\n",
    "#     ux_right = (u[-1, :] - u[-2, :]) / dx      # shape: (nt,)\n",
    "    \n",
    "#     flux_left = um[0, :] * ux_left             # u^m * u_x at x = 0\n",
    "#     flux_right = um[-1, :] * ux_right          # u^m * u_x at x = 1\n",
    "\n",
    "#     net_flux = torch.cumsum(flux_right - flux_left, dim=0) * dt  # ∫₀^t (flux_right - flux_left)\n",
    "\n",
    "#     # Total mass at each time\n",
    "#     mass_t = torch.sum(u, dim=0) * dx          # shape: (nt,)\n",
    "\n",
    "#     # Conservation residual\n",
    "#     residue = mass_t - mass_0 + net_flux       # sign flipped because outflow reduces mass\n",
    "\n",
    "#     return residue[1:]  # shape: (nt,)\n",
    "\n",
    "def conservation_residual_all_times(u_flat, m_flat):\n",
    "    u = u_flat.view(nx, nt)\n",
    "    m = m_flat.view(nx, nt)\n",
    "\n",
    "    def trapz_space(u):\n",
    "        weight = torch.ones_like(u)\n",
    "        weight[0, ...] *= 0.5\n",
    "        weight[-1, ...] *= 0.5\n",
    "        return torch.sum(weight * u, dim=0) * dx\n",
    "\n",
    "    # Initial mass\n",
    "    mass_0 = trapz_space(u[:, 0])  # scalar\n",
    "\n",
    "    # Compute u^m * u_x at both ends using backward differences\n",
    "    um = u ** m\n",
    "    ux_left = (u[0, :] - u[1, :]) / dx\n",
    "    ux_right = (u[-2, :] - u[-1, :]) / dx\n",
    "\n",
    "    flux_diff = um[-1, :] * ux_right - um[0, :] * ux_left  # shape: (nt,)\n",
    "\n",
    "    # Left Riemann sum: net flux up to each time step\n",
    "    flux_increments = torch.cat([\n",
    "        torch.zeros(1, device=u.device),        # net_flux[0] = 0\n",
    "        flux_diff[:-1] * dt\n",
    "    ], dim=0)\n",
    "\n",
    "    net_flux = torch.cumsum(flux_increments, dim=0)\n",
    "\n",
    "    # Mass at each time\n",
    "    mass_t = trapz_space(u)\n",
    "\n",
    "    # Residual = mass_t - mass_0 + net_flux (should be ≈ 0)\n",
    "    residue = mass_t - mass_0 + net_flux\n",
    "\n",
    "    return residue[1:]  # skip t=0\n",
    "\n",
    "\n",
    "def ic_residual(u_flat, u0):\n",
    "    u = u_flat.view(nx, nt)           # shape: (nx, nt)\n",
    "    return u[1:-1, 0]              # shape: (nx,)\n",
    "\n",
    "\n",
    "t_grid = t[slice(*tpred)].clone().to(device)\n",
    "def bc_residual_dirichlet(u_flat, m_flat):\n",
    "    u = u_flat.view(nx, nt)\n",
    "    m = m_flat[0] # for broadcasting\n",
    "\n",
    "    # Construct target boundary profile for left boundary\n",
    "    # t_grid = torch.linspace(0, 1, nt, device=u.device)  # shape: (nt,)\n",
    "    left_bc_target = (m * t_grid) ** (1.0 / m)  # shape: (nt,)\n",
    "    \n",
    "    left_bc_actual = u[0, :]                               # u(x=0, t)\n",
    "    right_bc_actual = u[-1, :]                             # u(x=1, t)\n",
    "\n",
    "    h_left = left_bc_actual - left_bc_target               # (nt,)\n",
    "    h_right = right_bc_actual                              # (nt,)\n",
    "\n",
    "    return torch.cat([h_left, h_right], dim=0)             # shape: (2 × nt,)\n",
    "\n",
    "# Combine\n",
    "def full_residual(u_flat, m_flat):\n",
    "    return torch.cat([ic_residual(u_flat, m_flat),\n",
    "                      conservation_residual_all_times(u_flat, m_flat),                          # (nx,)\n",
    "                      bc_residual_dirichlet(u_flat, m_flat),\n",
    "                     ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "5f9489c5-b02d-4719-b675-af1c38df18fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fast_project_weighted_with_m(xi_batch, sigma_batch, m_batch, h_func, max_iter=30):\n",
    "    def newton_step(u, xi, sigma, m):\n",
    "        sigma_inv = 1.0 / (sigma +1e-6)\n",
    "        sigma_inv = torch.ones_like(sigma)\n",
    "        h_val = h_func(u,m)\n",
    "        if h_val.ndim == 1:\n",
    "            h_val = h_val.unsqueeze(-1)\n",
    "        J = jacrev(lambda u_: h_func(u_, m))(u)  # (nt, n)\n",
    "        if J.ndim == 1:\n",
    "            J = J.unsqueeze(0)\n",
    "\n",
    "        # print(J)\n",
    "\n",
    "        delta = (xi - u).unsqueeze(-1)           # shape (n, 1)\n",
    "\n",
    "        # Use elementwise weighting: JW = J * sigma_inv[None, :]\n",
    "        JW = J * sigma_inv.unsqueeze(0)              # shape (m, n)\n",
    "        JJt = JW @ J.transpose(-2, -1)               # (m, m)\n",
    "        rhs = JW @ delta + h_val                     # (m, 1)\n",
    "\n",
    "        lambda_ = torch.linalg.solve(JJt, rhs)       # (m, 1)\n",
    "        Jt_lambda = J.transpose(-2, -1) @ lambda_    # (n, 1)\n",
    "        \n",
    "        du = sigma_inv.unsqueeze(-1) * (delta - Jt_lambda)\n",
    "\n",
    "        # return u + du.squeeze(-1)\n",
    "        return torch.clamp(u + du.squeeze(-1),min=0.0)\n",
    "\n",
    "    def loop(xi, sigma, m):\n",
    "        u = xi.clone()\n",
    "        for _ in range(max_iter):\n",
    "            u = newton_step(u, xi, sigma, m)\n",
    "        return u\n",
    "\n",
    "    return vmap(loop)(xi_batch, sigma_batch, m_batch)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "681dc3a6-49ef-40ad-b78c-a359b0aa81af",
   "metadata": {},
   "outputs": [],
   "source": [
    "def fast_project_weighted_with_m(xi_batch, sigma_batch, m_batch, h_func, max_iter=30):\n",
    "    def newton_step(u_tilde, xi_tilde, sqrt_sigma, m):\n",
    "        # back-transform: u = Σ^{1/2} ũ\n",
    "        u = u_tilde * sqrt_sigma\n",
    "\n",
    "        h_val = h_func(u, m)\n",
    "        if h_val.ndim == 1:\n",
    "            h_val = h_val.unsqueeze(-1)\n",
    "\n",
    "        # J: dh/dũ = dh/du × du/dũ = J_u × diag(sqrt_sigma)\n",
    "        J_u = jacrev(lambda u_: h_func(u_, m))(u)  # (k, p)\n",
    "        J = J_u * sqrt_sigma.unsqueeze(0)          # chain rule\n",
    "\n",
    "        delta = (xi_tilde - u_tilde).unsqueeze(-1)\n",
    "\n",
    "        JJt = J @ J.transpose(-2, -1)\n",
    "        rhs = J @ delta + h_val\n",
    "\n",
    "        #I = torch.eye(JJt.shape[-1], device=JJt.device, dtype=JJt.dtype)\n",
    "        # + 1e-6 * I\n",
    "        lambda_ = torch.linalg.solve(JJt, rhs)\n",
    "\n",
    "        du = delta - J.transpose(-2, -1) @ lambda_\n",
    "        u_tilde_next = u_tilde + du.squeeze(-1)\n",
    "        \n",
    "        return torch.clamp(u_tilde_next,min=0.0)\n",
    "\n",
    "    def loop(xi, sigma, m):\n",
    "        eps = 1e-6\n",
    "        sigma = sigma.clamp(min=eps)\n",
    "        # sigma = torch.ones_like(sigma)\n",
    "        sqrt_sigma = sigma.sqrt()\n",
    "        sqrt_sigma_inv = 1.0 / sqrt_sigma\n",
    "\n",
    "        xi_tilde = xi * sqrt_sigma_inv\n",
    "        u_tilde = xi_tilde.clone()\n",
    "\n",
    "        for _ in range(max_iter):\n",
    "            u_tilde = newton_step(u_tilde, xi_tilde, sqrt_sigma, m)\n",
    "\n",
    "        u_proj = u_tilde * sqrt_sigma  # back-transform\n",
    "        return torch.clamp(u_proj, min=0.0)\n",
    "\n",
    "    return vmap(loop)(xi_batch, sigma_batch, m_batch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "e883c9c9-bb46-4702-baf8-26e3b24a989c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[7.6131e-04, 1.2382e-04, 1.7764e-04,  ..., 7.6366e-04, 2.4439e-04,\n",
       "         1.2300e-03],\n",
       "        [6.2288e-04, 8.6210e-05, 1.2333e-04,  ..., 6.0096e-04, 1.7957e-04,\n",
       "         9.8001e-04],\n",
       "        [1.0770e-03, 2.2141e-04, 3.2271e-04,  ..., 1.1799e-03, 4.2065e-04,\n",
       "         1.8423e-03],\n",
       "        ...,\n",
       "        [1.0568e-03, 2.1480e-04, 3.1275e-04,  ..., 1.1516e-03, 4.0824e-04,\n",
       "         1.8012e-03],\n",
       "        [8.2538e-04, 1.4247e-04, 2.0497e-04,  ..., 8.4323e-04, 2.7700e-04,\n",
       "         1.3492e-03],\n",
       "        [8.9437e-04, 1.6329e-04, 2.3572e-04,  ..., 9.3183e-04, 3.1393e-04,\n",
       "         1.4803e-03]], device='cuda:0', grad_fn=<ToCopyBackward0>)"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "var_flat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "6dfe6a62-07b8-4f10-9815-58ee606220b8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4515"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import gc\n",
    "gc.collect()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "9decf451-14e0-4e6f-8f4f-bdd4fc1821e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "51f5fde6-fd55-4c0b-8d1e-d1883f63600d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([157])"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_residual(mu_flat[0,:], m_flat[0,:]).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "fc460f0d-5920-4f3e-886d-657a7d747b65",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[2.4963, 2.4963, 2.4963,  ..., 2.4963, 2.4963, 2.4963],\n",
       "        [2.7682, 2.7682, 2.7682,  ..., 2.7682, 2.7682, 2.7682],\n",
       "        [2.0885, 2.0885, 2.0885,  ..., 2.0885, 2.0885, 2.0885],\n",
       "        ...,\n",
       "        [2.1087, 2.1087, 2.1087,  ..., 2.1087, 2.1087, 2.1087],\n",
       "        [2.3943, 2.3943, 2.3943,  ..., 2.3943, 2.3943, 2.3943],\n",
       "        [2.2973, 2.2973, 2.2973,  ..., 2.2973, 2.2973, 2.2973]],\n",
       "       device='cuda:0')"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "m_flat"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "3be0869f-f0db-41df-94f4-814aaf315d79",
   "metadata": {},
   "outputs": [],
   "source": [
    "u_proj = fast_project_weighted_with_m(torch.relu(mu_flat), var_flat, m_flat, full_residual)\n",
    "u_proj_reshaped = u_proj.view(nf, nx, nt, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "id": "e8ce1384-f11f-4d5a-8f9d-b96339ac6788",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.0484e-08, 4.3622e-01, 5.7584e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         2.0904e-09],\n",
       "        [1.4876e-09, 4.9128e-01, 6.3107e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        [1.9560e-09, 3.4062e-01, 4.7469e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        ...,\n",
       "        [5.8129e-09, 3.4575e-01, 4.8030e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         2.5297e-09],\n",
       "        [2.6221e-09, 4.1381e-01, 5.5275e-01,  ..., 0.0000e+00, 4.1859e-14,\n",
       "         2.1893e-09],\n",
       "        [0.0000e+00, 3.9156e-01, 5.2946e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00]], device='cuda:0', grad_fn=<ClampBackward1>)"
      ]
     },
     "execution_count": 94,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "fb3a9c7e-06bc-49b6-898c-21ea991483c9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([], device='cuda:0', grad_fn=<IndexBackward0>)"
      ]
     },
     "execution_count": 95,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj[torch.isnan(u_proj)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "957e7c15-a613-4e67-a9cb-1856e51e8dd1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1.0484e-08, 5.9480e-09, 0.0000e+00, 3.9687e-09, 0.0000e+00, 5.3262e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.7356e-10, 3.9090e-09, 4.4401e-10,\n",
       "        7.8932e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 5.3999e-09,\n",
       "        0.0000e+00, 2.1664e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 6.5507e-10,\n",
       "        7.3377e-10, 0.0000e+00, 1.0952e-08, 4.0464e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.0003e-09, 1.5254e-09, 3.1635e-10,\n",
       "        1.6429e-09, 4.2208e-09, 0.0000e+00, 4.3772e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.4994e-09, 0.0000e+00, 2.5921e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 2.4799e-09, 2.7676e-09, 1.2348e-09,\n",
       "        0.0000e+00, 8.0131e-09, 4.9510e-09, 1.4688e-09, 2.2915e-09, 0.0000e+00,\n",
       "        0.0000e+00, 1.0899e-10, 0.0000e+00, 2.0342e-10, 0.0000e+00, 0.0000e+00,\n",
       "        5.4163e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 3.9067e-09, 1.1649e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 1.0398e-09, 0.0000e+00, 0.0000e+00,\n",
       "        3.0736e-09, 1.0828e-09, 4.7503e-09, 1.0701e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 1.0854e-08, 0.0000e+00, 9.1632e-09, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 5.6610e-09, 1.7019e-08], device='cuda:0',\n",
       "       grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 96,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj_reshaped[0,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "1ccd11e3-69f6-435f-8a39-0dcc9acb9003",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 3.3478e-03, -6.4292e-03, -1.0439e-02, -9.2754e-03, -4.7766e-03,\n",
       "        -1.1656e-04,  2.5992e-03,  2.9951e-03,  1.5453e-03, -6.5829e-04,\n",
       "        -1.9780e-03, -1.2915e-03,  7.6249e-04,  1.9755e-03,  6.9804e-04,\n",
       "        -1.8375e-03, -2.5996e-03, -7.9941e-04,  1.0917e-03,  8.0764e-04,\n",
       "        -9.9171e-04, -2.0422e-03, -1.2533e-03,  4.0847e-04,  1.1536e-03,\n",
       "         3.4991e-04, -8.1418e-04, -1.0573e-03, -5.6732e-04, -1.5488e-04,\n",
       "        -6.5453e-06,  9.8366e-05,  2.8320e-04,  5.3449e-04,  6.9533e-04,\n",
       "         6.1502e-04,  3.0897e-04, -1.9315e-04, -7.7360e-04, -9.6760e-04,\n",
       "        -3.8850e-04,  5.8768e-04,  1.1114e-03,  8.0241e-04,  4.7099e-05,\n",
       "        -5.9531e-04, -9.3988e-04, -1.0521e-03, -8.4193e-04, -1.1433e-04,\n",
       "         9.0014e-04,  1.4542e-03,  1.0147e-03, -1.5332e-04, -1.2618e-03,\n",
       "        -1.6562e-03, -1.2109e-03, -3.0033e-04,  5.7400e-04,  1.0755e-03,\n",
       "         1.0269e-03,  5.1856e-04, -3.2350e-05, -3.4222e-04, -5.4040e-04,\n",
       "        -6.8380e-04, -4.2166e-04,  4.6145e-04,  1.4442e-03,  1.5984e-03,\n",
       "         6.1567e-04, -6.7985e-04, -1.1339e-03, -4.8561e-04,  5.2710e-04,\n",
       "         1.1316e-03,  1.2429e-03,  1.1882e-03,  9.7803e-04,  3.2800e-04,\n",
       "        -6.3072e-04, -1.2583e-03, -1.0809e-03, -3.1785e-04,  2.4220e-04,\n",
       "         1.8175e-04, -3.4139e-05, -1.0752e-04, -4.1971e-04, -1.0205e-03,\n",
       "        -1.4245e-03, -1.4118e-03, -9.9081e-04, -5.7268e-04, -1.2046e-03,\n",
       "        -2.8105e-03, -3.4526e-03, -1.6224e-03,  1.6471e-04, -4.6232e-03],\n",
       "       grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu[0,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "id": "2b9e3bb2-41d7-49f0-916c-246826661660",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 5.9480e-09,  0.0000e+00,  3.9687e-09,  0.0000e+00,  5.3262e-09,\n",
       "         0.0000e+00,  0.0000e+00,  0.0000e+00,  5.7356e-10,  3.9090e-09,\n",
       "         4.4401e-10,  7.8932e-09,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         0.0000e+00,  5.3999e-09,  0.0000e+00,  2.1664e-09,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  6.5507e-10,  7.3377e-10,  0.0000e+00,\n",
       "         1.0952e-08,  4.0464e-09,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  5.0003e-09,  1.5254e-09,  3.1635e-10,\n",
       "         1.6429e-09,  4.2208e-09,  0.0000e+00,  4.3772e-09,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,  5.4994e-09,\n",
       "         0.0000e+00,  2.5921e-09,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         2.4799e-09,  2.7676e-09,  1.2348e-09,  0.0000e+00,  8.0131e-09,\n",
       "         4.9510e-09,  1.4688e-09,  2.2915e-09,  0.0000e+00,  0.0000e+00,\n",
       "         1.0899e-10,  0.0000e+00,  2.0342e-10,  0.0000e+00,  0.0000e+00,\n",
       "         5.4163e-09,  0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  0.0000e+00,  3.9067e-09,  1.1649e-09,\n",
       "         0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         1.0398e-09,  0.0000e+00,  0.0000e+00,  3.0736e-09,  1.0828e-09,\n",
       "         4.7503e-09,  1.0701e-09,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         0.0000e+00,  1.0854e-08,  0.0000e+00,  9.1632e-09,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  5.6610e-09,  1.2020e-02,  1.1317e-04,\n",
       "         4.2692e-06,  8.9407e-08,  7.4506e-08,  1.2368e-06, -4.4703e-08,\n",
       "         3.1590e-06,  3.5763e-07,  0.0000e+00,  8.9407e-07,  1.7881e-07,\n",
       "         1.2517e-06,  3.5763e-07,  1.0729e-06,  2.6226e-06,  9.5367e-07,\n",
       "         8.3447e-07, -3.7551e-06,  1.0484e-08,  2.9802e-08,  0.0000e+00,\n",
       "        -5.9605e-08,  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,\n",
       "         0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,  0.0000e+00,\n",
       "         0.0000e+00, -1.1921e-07,  1.7019e-08,  0.0000e+00,  0.0000e+00,\n",
       "         1.2259e-12,  2.1368e-12,  1.8700e-12,  1.2728e-12,  0.0000e+00,\n",
       "         0.0000e+00,  0.0000e+00,  4.8148e-12,  0.0000e+00,  0.0000e+00,\n",
       "         1.7894e-12,  5.4642e-12,  0.0000e+00,  2.6895e-12,  0.0000e+00,\n",
       "         0.0000e+00,  2.0904e-09], device='cuda:0', grad_fn=<CatBackward0>)"
      ]
     },
     "execution_count": 98,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "full_residual(u_proj_reshaped[0,...].flatten().to(device), m_flat[0,...])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "9e7908c2-1b72-40eb-922f-35bfab9a071e",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)\n",
    "\n",
    "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": 100,
   "id": "cedca976-7263-4789-aeaf-1850bca3d083",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([5.9480e-09, 0.0000e+00, 3.9687e-09, 0.0000e+00, 5.3262e-09, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 5.7356e-10, 3.9090e-09, 4.4401e-10, 7.8932e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 5.3999e-09, 0.0000e+00,\n",
       "        2.1664e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 6.5507e-10, 7.3377e-10,\n",
       "        0.0000e+00, 1.0952e-08, 4.0464e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 5.0003e-09, 1.5254e-09, 3.1635e-10, 1.6429e-09,\n",
       "        4.2208e-09, 0.0000e+00, 4.3772e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 5.4994e-09, 0.0000e+00, 2.5921e-09, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 2.4799e-09, 2.7676e-09, 1.2348e-09, 0.0000e+00,\n",
       "        8.0131e-09, 4.9510e-09, 1.4688e-09, 2.2915e-09, 0.0000e+00, 0.0000e+00,\n",
       "        1.0899e-10, 0.0000e+00, 2.0342e-10, 0.0000e+00, 0.0000e+00, 5.4163e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 3.9067e-09, 1.1649e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 1.0398e-09, 0.0000e+00, 0.0000e+00, 3.0736e-09,\n",
       "        1.0828e-09, 4.7503e-09, 1.0701e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 1.0854e-08, 0.0000e+00, 9.1632e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 5.6610e-09], device='cuda:0', grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 100,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ic_residual(u_proj[0,...].to(device), m_flat[0,...])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "ac4ef7b7-025a-439c-b21a-8fbd9f037f80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([5.6453e-03, 9.4878e-03, 8.1567e-03, 3.6227e-03, 8.8358e-04, 3.3416e-03,\n",
       "        3.5031e-03, 1.9001e-03, 3.8108e-04, 1.7233e-03, 1.0169e-03, 1.0955e-03,\n",
       "        2.4007e-03, 1.2312e-03, 1.2203e-03, 1.9644e-03, 2.1785e-04, 1.5844e-03,\n",
       "        1.2162e-03, 6.4354e-04, 1.7276e-03, 9.4640e-04, 7.3301e-04, 1.5211e-03,\n",
       "        7.8086e-04, 3.1447e-04, 5.0539e-04, 4.0183e-06, 3.9972e-04, 5.0397e-04,\n",
       "        5.5540e-04, 6.9648e-04, 9.2626e-04, 1.0924e-03, 1.0420e-03, 7.8128e-04,\n",
       "        3.2380e-04, 2.3197e-04, 4.3388e-04, 1.0787e-04, 1.0352e-03, 1.5183e-03,\n",
       "        1.1886e-03, 4.3385e-04, 1.9153e-04, 5.1183e-04, 6.0423e-04, 3.8828e-04,\n",
       "        3.2943e-04, 1.3258e-03, 1.8642e-03, 1.4181e-03, 2.5320e-04, 8.4780e-04,\n",
       "        1.2391e-03, 8.0244e-04, 8.6937e-05, 9.3522e-04, 1.4177e-03, 1.3672e-03,\n",
       "        8.7889e-04, 3.6835e-04, 1.0968e-04, 4.4415e-05, 1.7203e-04, 6.7194e-05,\n",
       "        9.0024e-04, 1.8312e-03, 1.9529e-03, 9.6549e-04, 3.0753e-04, 7.2030e-04,\n",
       "        2.8276e-05, 1.0089e-03, 1.6042e-03, 1.6776e-03, 1.5772e-03, 1.3344e-03,\n",
       "        6.7611e-04, 2.6445e-04, 8.5332e-04, 6.3186e-04, 1.5712e-04, 7.0689e-04,\n",
       "        6.0504e-04, 3.4188e-04, 2.3987e-04, 7.0057e-05, 6.3704e-04, 9.8689e-04,\n",
       "        9.2649e-04, 5.0002e-04, 1.3570e-04, 8.5480e-04, 2.5365e-03, 3.2152e-03,\n",
       "        1.3659e-03, 5.3848e-04], device='cuda:0', grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ic_residual(torch.abs(new_mu[0,...]).flatten().to(device), m_flat[0,...])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "id": "66fe7479-1fa6-4b3a-9603-43c98c62b13e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(8.1501e-05, grad_fn=<MseLossBackward0>)"
      ]
     },
     "execution_count": 102,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.nn.MSELoss()(mu,y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "840f0465-2661-4b3e-81b6-04a03a432fcb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(8.7352e-05, grad_fn=<MseLossBackward0>)"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.nn.MSELoss()(u_proj_reshaped.cpu(), y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "5ae9a844-eb88-48d7-a4f0-411d7cb8fb9b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(8.8072e-05, grad_fn=<MseLossBackward0>)"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.nn.MSELoss()(new_mu.cpu(), y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "48c8eb7f-8a71-4fb9-b007-12fb7d0aa798",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[5.9480e-09, 0.0000e+00, 3.9687e-09,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         5.6610e-09],\n",
       "        [1.1739e-09, 0.0000e+00, 5.3509e-09,  ..., 4.1087e-09, 0.0000e+00,\n",
       "         9.3714e-09],\n",
       "        [5.0112e-10, 8.6861e-09, 5.3865e-09,  ..., 0.0000e+00, 2.8103e-09,\n",
       "         0.0000e+00],\n",
       "        ...,\n",
       "        [0.0000e+00, 8.6200e-09, 2.4574e-09,  ..., 7.0377e-09, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        [0.0000e+00, 0.0000e+00, 0.0000e+00,  ..., 1.9931e-09, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        [4.6096e-10, 0.0000e+00, 0.0000e+00,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00]], device='cuda:0', grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 105,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "vmap(ic_residual)(u_proj,m_flat)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "1197d13e-3821-4d20-a7fc-9c4a313ce623",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 3.7083e-03, -5.6453e-03, -9.4878e-03, -8.1567e-03, -3.6227e-03,\n",
       "         8.8358e-04,  3.3416e-03,  3.5031e-03,  1.9001e-03, -3.8108e-04,\n",
       "        -1.7233e-03, -1.0169e-03,  1.0955e-03,  2.4007e-03,  1.2312e-03,\n",
       "        -1.2203e-03, -1.9644e-03, -2.1785e-04,  1.5844e-03,  1.2162e-03,\n",
       "        -6.4354e-04, -1.7276e-03, -9.4640e-04,  7.3301e-04,  1.5211e-03,\n",
       "         7.8086e-04, -3.1447e-04, -5.0539e-04,  4.0183e-06,  3.9972e-04,\n",
       "         5.0397e-04,  5.5540e-04,  6.9648e-04,  9.2626e-04,  1.0924e-03,\n",
       "         1.0420e-03,  7.8128e-04,  3.2380e-04, -2.3197e-04, -4.3388e-04,\n",
       "         1.0787e-04,  1.0352e-03,  1.5183e-03,  1.1886e-03,  4.3385e-04,\n",
       "        -1.9153e-04, -5.1183e-04, -6.0423e-04, -3.8828e-04,  3.2943e-04,\n",
       "         1.3258e-03,  1.8642e-03,  1.4181e-03,  2.5320e-04, -8.4780e-04,\n",
       "        -1.2391e-03, -8.0244e-04,  8.6937e-05,  9.3522e-04,  1.4177e-03,\n",
       "         1.3672e-03,  8.7889e-04,  3.6835e-04,  1.0968e-04, -4.4415e-05,\n",
       "        -1.7203e-04,  6.7194e-05,  9.0024e-04,  1.8312e-03,  1.9529e-03,\n",
       "         9.6549e-04, -3.0753e-04, -7.2030e-04, -2.8276e-05,  1.0089e-03,\n",
       "         1.6042e-03,  1.6776e-03,  1.5772e-03,  1.3344e-03,  6.7611e-04,\n",
       "        -2.6445e-04, -8.5332e-04, -6.3186e-04,  1.5712e-04,  7.0689e-04,\n",
       "         6.0504e-04,  3.4188e-04,  2.3987e-04, -7.0057e-05, -6.3704e-04,\n",
       "        -9.8689e-04, -9.2649e-04, -5.0002e-04, -1.3570e-04, -8.5480e-04,\n",
       "        -2.5365e-03, -3.2152e-03, -1.3659e-03,  5.3848e-04, -4.2371e-03],\n",
       "       grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_mu[0,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "31182cc9-f3fa-4b1d-aa63-5f91b505463e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.,\n",
       "        0., 0., 0., 0.])"
      ]
     },
     "execution_count": 107,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train[0,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "53fd25a7-c6b3-4d3e-943c-39e0e2c5ad11",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([1.0484e-08, 5.9480e-09, 0.0000e+00, 3.9687e-09, 0.0000e+00, 5.3262e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.7356e-10, 3.9090e-09, 4.4401e-10,\n",
       "        7.8932e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 5.3999e-09,\n",
       "        0.0000e+00, 2.1664e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 6.5507e-10,\n",
       "        7.3377e-10, 0.0000e+00, 1.0952e-08, 4.0464e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.0003e-09, 1.5254e-09, 3.1635e-10,\n",
       "        1.6429e-09, 4.2208e-09, 0.0000e+00, 4.3772e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 5.4994e-09, 0.0000e+00, 2.5921e-09,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 2.4799e-09, 2.7676e-09, 1.2348e-09,\n",
       "        0.0000e+00, 8.0131e-09, 4.9510e-09, 1.4688e-09, 2.2915e-09, 0.0000e+00,\n",
       "        0.0000e+00, 1.0899e-10, 0.0000e+00, 2.0342e-10, 0.0000e+00, 0.0000e+00,\n",
       "        5.4163e-09, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 3.9067e-09, 1.1649e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 0.0000e+00, 1.0398e-09, 0.0000e+00, 0.0000e+00,\n",
       "        3.0736e-09, 1.0828e-09, 4.7503e-09, 1.0701e-09, 0.0000e+00, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 1.0854e-08, 0.0000e+00, 9.1632e-09, 0.0000e+00,\n",
       "        0.0000e+00, 0.0000e+00, 5.6610e-09, 1.7019e-08], device='cuda:0',\n",
       "       grad_fn=<SelectBackward0>)"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj_reshaped[0,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "5e51ff78-8e4f-40e9-8457-27dcacdafbaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.func import vmap, jacrev\n",
    "\n",
    "class ProjectWeightedImplicit(torch.autograd.Function):\n",
    "    @staticmethod\n",
    "    def forward(ctx, xi_batch, sigma_batch, m_batch, h_func, max_iter=30):\n",
    "        \"\"\"\n",
    "        Batched Newton‐projection with implicit‐diff backward pass.\n",
    "        \n",
    "        Args:\n",
    "            xi_batch:   Tensor of shape (B, p), unconstrained points\n",
    "            sigma_batch: Tensor of shape (B, p), positive weights\n",
    "            m_batch:    Tensor of extra parameters per sample (e.g. (B, …))\n",
    "            h_func:     callable h(u, m) → Tensor of shape (k,) or scalar\n",
    "            max_iter:   number of Newton steps\n",
    "        \n",
    "        Returns:\n",
    "            u_proj: Tensor of shape (B, p), projections s.t. h(u_proj, m)=0\n",
    "        \"\"\"\n",
    "        B, p = xi_batch.shape\n",
    "\n",
    "        def project_one(xi, sigma, m):\n",
    "            # ensure positivity\n",
    "            eps = 1e-6\n",
    "            sigma = sigma.clamp(min=eps)\n",
    "            sqrt_sigma = sigma.sqrt()\n",
    "            inv_sqrt = 1.0 / sqrt_sigma\n",
    "\n",
    "            # transform to tilde‐space\n",
    "            xi_tilde = xi * inv_sqrt\n",
    "            u_tilde  = xi_tilde.clone()\n",
    "\n",
    "            def newton_step(u_tilde):\n",
    "                # back to u‐space\n",
    "                u = u_tilde * sqrt_sigma\n",
    "                h = h_func(u, m)\n",
    "                # make h a vector of shape (k,)\n",
    "                if h.ndim == 0:\n",
    "                    h = h.unsqueeze(0)\n",
    "\n",
    "                # Jacobian ∂h/∂u at u: shape (k, p)\n",
    "                J_u = jacrev(lambda u_: h_func(u_, m))(u)\n",
    "                if J_u.ndim == 1:\n",
    "                    J_u = J_u.unsqueeze(0)\n",
    "                # chain‐rule for tilde: dh/dũ = J_u * diag(sqrt_sigma)\n",
    "                J = J_u * sqrt_sigma.unsqueeze(0)\n",
    "\n",
    "                # compute Newton update in tilde‐space\n",
    "                δ = (xi_tilde - u_tilde).unsqueeze(-1)        # (p,1)\n",
    "                JJt = J @ J.transpose(-2, -1)                  # (k,k)\n",
    "                rhs = J @ δ + h.unsqueeze(-1)                  # (k,1)\n",
    "                I   = torch.eye(JJt.shape[-1], device=JJt.device)\n",
    "                λ   = torch.linalg.solve(JJt + 1e-6*I, rhs)    # (k,1)\n",
    "\n",
    "                du = δ - J.transpose(-2, -1) @ λ               # (p,1)\n",
    "                return torch.clamp(u_tilde + du.squeeze(-1), min=0.0)\n",
    "\n",
    "            # run Newton iterations\n",
    "            for _ in range(max_iter):\n",
    "                u_tilde = newton_step(u_tilde)\n",
    "\n",
    "            # back to original space and clamp\n",
    "            return torch.clamp(u_tilde * sqrt_sigma, min=0.0)\n",
    "\n",
    "        # vectorize over batch\n",
    "        u_proj = vmap(project_one)(xi_batch, sigma_batch, m_batch)\n",
    "\n",
    "        # save for backward\n",
    "        ctx.save_for_backward(xi_batch, sigma_batch, m_batch, u_proj)\n",
    "        ctx.h_func = h_func\n",
    "        return u_proj\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, grad_u):\n",
    "        \"\"\"\n",
    "        Implicit differentiation via KKT system:\n",
    "          A = [[Σ⁻¹,    Jᵀ],\n",
    "               [  J,      0]]\n",
    "        Stationarity & primal feasibility → solve Aᵀ w = [grad_u; 0],\n",
    "        then ∂u/∂xi^T g = Σ⁻¹ w_u.\n",
    "        \"\"\"\n",
    "        xi_batch, sigma_batch, m_batch, u_proj = ctx.saved_tensors\n",
    "        h_func = ctx.h_func\n",
    "\n",
    "        B, p = xi_batch.shape\n",
    "        grad_xi_list = []\n",
    "\n",
    "        for i in range(B):\n",
    "            xi    = xi_batch[i]    # (p,)\n",
    "            sigma = sigma_batch[i] # (p,)\n",
    "            u     = u_proj[i]      # (p,)\n",
    "            m     = m_batch[i]\n",
    "            g     = grad_u[i]      # (p,)\n",
    "\n",
    "            # compute J_u = ∂h/∂u at the solution\n",
    "            h = h_func(u, m)\n",
    "            if h.ndim == 0:\n",
    "                h = h.unsqueeze(0)\n",
    "            J_u = jacrev(lambda u_: h_func(u_, m))(u)\n",
    "            if J_u.ndim == 1:\n",
    "                J_u = J_u.unsqueeze(0)\n",
    "            k = J_u.shape[0]\n",
    "\n",
    "            # build KKT matrix A and solve Aᵀ w = [g; 0]\n",
    "            σ_inv = 1.0 / sigma\n",
    "            # top block: [Σ⁻¹, Jᵀ]\n",
    "            top    = torch.cat([torch.diag(σ_inv), J_u.transpose(0,1)], dim=1)  # (p, p+k)\n",
    "            # bottom: [J, 0]\n",
    "            bottom = torch.cat([J_u, torch.zeros(k, k, device=u.device)], dim=1)  # (k, p+k)\n",
    "            A      = torch.cat([top, bottom], dim=0)                             # (p+k, p+k)\n",
    "\n",
    "            # right‐hand side\n",
    "            rhs = torch.cat([g, torch.zeros(k, device=g.device)], dim=0)         # (p+k,)\n",
    "\n",
    "            # solve Aᵀ w = rhs\n",
    "            w = torch.linalg.solve(A.transpose(0,1), rhs)                        # (p+k,)\n",
    "\n",
    "            # gradient wrt xi: Σ⁻¹ * w_u\n",
    "            w_u       = w[:p]\n",
    "            grad_xi   = σ_inv * w_u\n",
    "            grad_xi_list.append(grad_xi)\n",
    "\n",
    "        grad_xi_batch = torch.stack(grad_xi_list, dim=0)\n",
    "\n",
    "        # return gradients for each forward argument\n",
    "        return grad_xi_batch, None, None, None, None\n",
    "\n",
    "\n",
    "# ------------------------------------------------------------------------------\n",
    "# Usage example:\n",
    "\n",
    "# Suppose:\n",
    "#   xi_batch   = torch.randn(B, p, requires_grad=True)\n",
    "#   sigma_batch= torch.rand(B, p)\n",
    "#   m_batch    = some tensor of shape (B, …)\n",
    "#   def full_residual(u, m):  return ...  # returns a vector (k,) constraint\n",
    "\n",
    "# Then project + differentiate:\n",
    "# u_proj = ProjectWeightedImplicit.apply(xi_batch, sigma_batch, m_batch, full_residual, 30)\n",
    "# loss = some_loss(u_proj)\n",
    "# loss.backward()\n",
    "# ------------------------------------------------------------------------------\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "4b1fc975-ec2a-42bd-b41d-23cb58640675",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.0484e-08, 4.3622e-01, 5.7584e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         2.0904e-09],\n",
       "        [1.4876e-09, 4.9128e-01, 6.3107e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        [1.9560e-09, 3.4062e-01, 4.7469e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00],\n",
       "        ...,\n",
       "        [5.8129e-09, 3.4575e-01, 4.8030e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         2.5297e-09],\n",
       "        [2.6221e-09, 4.1381e-01, 5.5275e-01,  ..., 0.0000e+00, 4.1859e-14,\n",
       "         2.1893e-09],\n",
       "        [0.0000e+00, 3.9156e-01, 5.2946e-01,  ..., 0.0000e+00, 0.0000e+00,\n",
       "         0.0000e+00]], device='cuda:0', grad_fn=<ClampBackward1>)"
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "7406d28a-ad26-4a4c-a2b9-6e1f27a7c48f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "new_u_proj = ProjectWeightedImplicit.apply(torch.relu(mu_flat), var_flat, m_flat, full_residual, 30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "a26ec383-d9da-43b4-bee8-f6253b0c39e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.7936, device='cuda:0', grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(u_proj - new_u_proj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "id": "170963ba-2e5c-4ab8-be48-3eb9a5156e14",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.func import vmap, jacrev\n",
    "\n",
    "def diag_JSigmaJT(sigma: torch.Tensor, J_u: torch.Tensor, eps: float = 1e-6) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    Compute diag(J Σ J^T) efficiently for one sample, given:\n",
    "      - sigma: Tensor (p,) forming Σ = diag(sigma)\n",
    "      - J_u:   Tensor (k, p) = ∂h/∂u at u*\n",
    "    Returns:\n",
    "      Tensor (p,) containing the diagonal of J Σ J^T.\n",
    "    \"\"\"\n",
    "    # 1) build S = J_u Σ J_u^T  (shape k×k)\n",
    "    S = (J_u * sigma.unsqueeze(0)) @ J_u.T\n",
    "    S = S + eps * torch.eye(S.shape[0], device=S.device)  # regularize\n",
    "\n",
    "    # 2) invert S  (k×k)  — cheap if k ≪ p\n",
    "    S_inv = torch.linalg.inv(S)\n",
    "\n",
    "    # 3) compute vᵢ = J_u[:,i], then vᵢᵀ S⁻¹ vᵢ for each i\n",
    "    #    but we can do it all at once:\n",
    "    T = S_inv @ J_u          # (k, p)\n",
    "    quad = (J_u * T).sum(dim=0)  # (p,)\n",
    "\n",
    "    # diag(J Σ J^T) = sigma - sigma² * quad\n",
    "    return sigma - sigma**2 * quad\n",
    "\n",
    "\n",
    "def batch_diag_JSigmaJT(u_proj: torch.Tensor,\n",
    "                        sigma_batch: torch.Tensor,\n",
    "                        m_batch: torch.Tensor,\n",
    "                        h_func,\n",
    "                        eps: float = 1e-6) -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    Vectorized: for each sample in the batch, compute diag(J Σ J^T).\n",
    "    \n",
    "    Args:\n",
    "      u_proj:      (B, p)  — projected outputs u*\n",
    "      sigma_batch: (B, p)  — weight diagonals\n",
    "      m_batch:     (B, …)  — extra per-sample params\n",
    "      h_func:      callable h(u, m) → Tensor (k,) or scalar\n",
    "    Returns:\n",
    "      Tensor (B, p) of diag(J Σ J^T) for each batch element.\n",
    "    \"\"\"\n",
    "    def one(sigma, u, m):\n",
    "        # 1) build Jacobian of constraints J_u at u*\n",
    "        J_u = jacrev(lambda u_: h_func(u_, m))(u)  # (k,p) or (p,) if k=1\n",
    "        if J_u.ndim == 1:\n",
    "            J_u = J_u.unsqueeze(0)\n",
    "        # 2) compute diag(J Σ J^T)\n",
    "        return diag_JSigmaJT(sigma, J_u, eps)\n",
    "\n",
    "    # vmap over batch\n",
    "    return vmap(one)(sigma_batch, u_proj, m_batch)\n",
    "\n",
    "\n",
    "# -----------------------------------------------\n",
    "# Example usage, after your forward‐pass:\n",
    "\n",
    "# u_proj = ProjectWeightedImplicit.apply(xi_batch, sigma_batch, m_batch, h_func, max_iter)\n",
    "\n",
    "# Now get the variances:\n",
    "# variances = batch_diag_JSigmaJT(u_proj, sigma_batch, m_batch, h_func)\n",
    "\n",
    "# `variances[b,i]` is (J Σ J^T)_{ii} for sample b and dimension i.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "id": "c4af1764-71b4-4c60-8959-f4f08cf5fe42",
   "metadata": {},
   "outputs": [],
   "source": [
    "variances = batch_diag_JSigmaJT(new_u_proj, var_flat, m_flat, full_residual)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "0845b57b-0aeb-4ed6-a197-ee3afa9bd03d",
   "metadata": {},
   "outputs": [],
   "source": [
    "variances = variances.view(nf, nx, nt, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "1f791304-76ea-4e1f-8a8c-ce2d2937821b",
   "metadata": {},
   "outputs": [],
   "source": [
    "stds = torch.sqrt(variances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "5825100a-2722-4f1b-b053-eed6dd9098e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "stds = stds.detach().cpu()\n",
    "u_proj_reshaped = u_proj_reshaped.detach().cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "31f5f22d-34f1-4b5a-819d-c553113c7722",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0730)\n"
     ]
    },
    {
     "data": {
      "image/png": "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I0eO4OOPP8Yrr7yCv/zlLwCc7XXeeOMNPPPMM+jevTtiY2Nx9dVXY+7cufjvf/+LG2+8ERMnTkRSUhJKSkrw888/Y926dcjKymp0GzRvtREqKipCamoqLly4gLlz52L9+vUe67t164aUlBT38z59+mDEiBHu6Wz27NmDsWPHYuzYsejevTvKysrw6aefYtu2bZg6dSr+8Ic/uPdNTk7GX//6V8ybNw9nzpxB9+7dsWrVKmRlZVVpcE0ti4kQ+Vzl0hGXiRMnokOHDti5cyeeeuopfPLJJ3j99dfRtm1b9OvXz2Ncn4kTJyInJwdvvvkmvvjiC/Tt2xcffPABPv744ypzcPnac889h5CQEHdjypSUFHz55ZcYPny4uwdJa1BTY9FNmzbVOxHKzMzEE0884bHM9XzEiBFVEqGPPvoIH330ETQaDSIiItCjRw/MmjUL9913X5WGvw1hNBqxefNmPProo1i1ahUKCwvRq1cvvPvuu16ZGmLEiBFISUnBwoULkZ2djb59+2LlypUeidsrr7wCRVGwevVqmM1mXH755fj6668bNKilN45RX8uWLUNSUhLefPNNPPbYY9BoNOjcuTPuvPNOXH755e7t5s+fjxMnTuD5559HUVERRowYgauvvhohISHYsmULFi1ahI8//hjvvfceIiIi0LNnTyxcuLDebXea07lz59wDGT766KNV1k+YMMEjEaqsU6dO7l6lOTk5kGUZffr0wbJlyzwGTnR577338MQTT+D999/HhQsXMGDAAHz22We48sorvfemqMEk4e1WnETUYPn5+YiKisIzzzzjHpiO/IMkSZg+fXqLVG8SkfexjRBRC6tuvBDXKLsVpycgIqLmx6oxoha2du1a96zTYWFh2Lp1Kz766CNce+21HlUOrVleXl6tDXR1Ol2d01IQEbUGTISIWtiAAQOg0Wjw/PPPo7Cw0N2A2tWI2B9ceumlVQYhrKhig1IiotaMbYSIqMG2bdtW65QAUVFRzTb6LxGRNzERIiIioqDFxtJEREQUtNhGqA6qquL3339HeHh4sw52R0RERN4jhEBRURESEhKqTLhcEROhOvz+++8c+pyIiMhPnTx5Eh06dKhxPROhOriG3j958mSLzHpNRERETVdYWIjExMQ6p9Dxu0TotddewwsvvICcnBwMHDgQS5cuxWWXXVbj9vn5+Xj88cfx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c+fOYdOmTe5l58+fx8aNGzFu3DgADTtvla/DuiiKgkWLFmHp0qX47bffqt3m/Pnz+OKLLzBt2jT3qNAu8fHxGDduHNauXYuKo/pcdtll2LlzJywWS73iaBRBtSooKBAAREFBgVePu/nXXKGZ307gSYgRrz3h1WMTBaqysjJx4MABUVZW5rF8+bfHRPKzX9f5mLxyZ5VjTl65s177Lv/2WJNiHzFihOjTp49QVdW97JFHHhF9+vRxrx88eLDHPmazWYSEhIjt27d7xjx5shg7dqwQQoiioiKh0+nEv/71L/f6c+fOCaPRKB588EH3sV3/LiwsFHq9XixfvrzWWF3bezOO6txzzz1i/PjxHsvmz58vRo4cWeM+leXl5QkA4ueff/Z4D8OHD/fY7tJLLxWPPPJIk+J99tlnRWhoqPshy7LQ6/Uey06cOOHe/qeffhKhoaFCURRhMpnE+vXrPY535ZVXus+hy/Tp08XQoUNrjOHmm28Wd999d53L33zzTZGQkCAcDke1x6npvFW+DidMmCAURfF4j3/5y1881t98881CCCGGDh3qjuHTTz8VFdOM77//XgAQn376abXxvPzyywKAyM3NdS/78ccfBQCRlZVV7T41fScIUf/7t1+NLB1ILu8ejTjNH3FKXYEduf9GfunfERnCaQOIGqPIbEdOobnO7dpFVh2E8VyJtV77FpntjYqtoqFDh3o0Hk1JScFLL73knjqk8q/8o0ePorS0FNdcc43HcqvVisGDBwMAjh07BqvViuTkZPf6Nm3aoFevXtXGcPDgQVgsFowaNarecTdHHC779u3D3/72N49le/fuxaBBg2rc58iRI5g/fz527NiBs2fPuks0srOz0b9/f/d2AwYM8NivXbt27kk6Gxvvfffdh9tvv939fNy4cbjtttvw5z//2b0sISHB/e9evXph3759KCgowLp16zBhwgRs2bIFffv2RW5uLrZu3epRqgYAoaGhtY6YXFZWVu2AouPGjcOUKVPw+uuvQ6/XY/Xq1bjjjjvcMy7U97xVvg4B4KqrrsIbb7zhEWN1nnvuOVx99dV46KGHaoxfNGAcZ1fJUWlpab33aSgmQj6iUWSM7XcXXvxpJczyAbydsRUPjbra12ER+aVwgwbxEXWPNN02tOqPjbahunrtG25o/q/LyjeX4uJiAMD69evRvn17j3V6vb5R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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 = 2\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, u_proj_reshaped[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, u_proj_reshaped[parameters_idx,:,t_idx,0]+3*stds[parameters_idx,:,t_idx,0], u_proj_reshaped[parameters_idx,:,t_idx,0]-3*stds[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] - u_proj_reshaped[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "9f02c9bc-41d9-42b5-b108-ab8af7c7bf6a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABYEAAANrCAYAAAAQwFdrAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAC4jAAAuIwF4pT92AAEAAElEQVR4nOzdeXxU1f3/8de9syWZmWSyAmERFBcWRcUVtSJo1VoViws/bStfF6qtVb+1i0vdqqXa1rbqV4ta61Kr1ap1Q1uqKCoILiwKuIBsgQDZ98ls9/7+iBkTMjNJIEMW3s/HIw9n5p577vlkcobxM2c+x7Bt20ZEREREREREREREBiSztwcgIiIiIiIiIiIiIumjJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmJLCIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgA5uztAYj0hJqaGhYsWBC/P3z4cDweTy+OSERERERERERE5GuhUIiSkpL4/eOPP55AILBbrq0ksAwICxYsYNq0ab09DBERERERERERkS554YUXOPPMM3fLtVQOQkRERERERERERGQAUxJYREREREREREREZABTOQgZEIYPH97u/gsvvMDo0aN7aTQiIiIiIiIiIiLtrV27tl050x3zWemkJLAMCDtuAjd69GjGjRvXS6MRERERERERERFJbcd8VjqpHISIiIiIiIiIiIjIAKYksIiIiIiIiIiIiMgApiSwiIiIiIiIiIiIyACmmsAifVwkEqGsrCx+v6ioCJfL1YsjEhl4NM9E0k/zTCT9NM9E0k/zTCT9NM/SQ0lgkT7Otm0ikUi7+yLSszTPRNJP80wk/TTPRNJP80wk/TTP0kPlIEREREREREREREQGMCWBRURERERERERERAYwJYFFREREREREREREBjAlgUVEREREREREREQGMCWBRURERERERERERAYwJYFFREREREREREREBjAlgUVEREREREREREQGMCWBRURERERERERERAYwJYFFREREREREREREBjAlgUVEREREREREREQGMGdvD0BEUnM4HAQCgXb3RaRnaZ6JpJ/mmUj6aZ6JpJ/mmUj6aZ6lh5LAIn3cji9+ItLzNM9E0k/zTCT9NM9E0k/zTCT9NM/SQ+UgRERERERERERERAYwJYFFREREREREREREBjAlgUVEREREREREREQGMNUEFunjbNsmEonE77tcLgzD6MURiQw8mmci6ad5JpJ+mmci6ad5JpJ+mmfpoSSwSB8XiUQoLS2N3y8uLsbtdvfiiEQGHs0zkfTTPBNJP80zkfTTPBNJP82z9FA5CBEREREREREREZEBTElgERERERERERGJ27BhA4Zh7PLPyJEjezsUEfmKksAiIiIiIiIiIiIiA5hqAouIiIiIiIiISNzQoUP55JNPkh7/5S9/yYsvvgjAX//6Vw4//PCE7VTHVaTvUBK4H6upqeH+++/nX//6F+vWrSMYDFJcXMwJJ5zAZZddxsSJE3v0euvXr+fRRx/ltddeY8OGDdTW1pKXl0dxcTFHH300J598MqeffnqPXlNa2NEohMLg0T+gIiIiIiIikl4ul4vx48cnPR4IBOK3R40albKtiPQNSgL3U++//z7Tp09n8+bN7R7/8ssv+fLLL3nkkUe4+eabufHGG3f5WrZtc9tttzF79mxCoVC7Y9u2bWPbtm0sXbqUV155RUngNLAbmrDWlYBlgcOBXVAI+jRVRERERERERES6SDWB+6F169Zx2mmnsXnzZgzD4Ac/+AGvv/46ixcv5u6772bIkCHEYjFuuukm7r333l26lm3bXHzxxdx8882EQiH23XdffvOb3/DGG2+wbNky3n77bR544AGmTZtGVlZWD0UobVll5WBZ2LYFsRjWmnW9PSQRERERERGRpEaOHIlhGEyePBmAkpISfvGLXzB+/HgCgQCGYfCnP/0p3r51I7mZM2em7Pett96Kt3300UdTtt28eTM33HADRxxxBAUFBbjdbgYNGsRJJ53E/fff32GRm8hAp5XA/dBPfvITKioqAJgzZw6zZs2KHzvyyCM566yzmDhxIuXl5Vx77bVMnz6d4uLinbrWPffcwyOPPALAZZddxj333IPL5WrX5rjjjmPWrFmEw+GdjEhSisRa/tsYxPZmYtc2YG2vwBxU0LvjEhEREREREenEf/7zH8477zxqa2t32zXvvvtufvGLX3RI9JaVlfH666/z+uuv86c//YmXXnqJAw44YLeNS6Q3KQncz6xevTpefP3YY49tlwBuNXz4cGbPns2ll15KU1MTd999N3feeWe3r7V161auv/56ACZPnsz999+PYRhJ26vge5pFY1DXAPkZxNZuwCjIxXA4entUIiIiIiIivSoajXYolZgu4XCYsrKydvf7wv8LDxs2DKez76V4SkpKOPfcc4GWzeSmTJlCdnY2X375JYWFhWm55m233cZNN90EtNQr/uEPf8iYMWMYMmQIZWVlzJ07lwceeIA1a9Zw4okn8tFHHzFo0KC0jEWkL+l7rxCS0rPPPhu/femllyZtd8EFF3DVVVfR1NTEs88+u1NJ4AcffJCmpiYAbr755pQJYNk97IZGbH8OGCbWxi049h7R20MSERERERHpVZs3b2bUqFG9PYxetX79ekaOHNnbw+hg3bp1FBQUsHDhQvbbb7/44z29kX2rRYsWccsttwBw5ZVXctddd3VIjp9yyinMmDGDE088kS1btvDLX/6Shx56KC3jEelLVBO4n1mwYEH89pQpU5K2y8zM5KijjgJaXnRLSkq6fa2nnnoKgNzcXI4//vj449XV1axZs4by8vJu9ym7yLKxtrf83q2Nm7GbVcNIRERERERE+q7f/OY37RLA6fTrX/8ay7IYP348f/jDH5Kujj7mmGP44Q9/CMDf/vY3mpubd8v4RHqTksD9zKpVqwDIzs5m2LBhKduOHTs2fnv16tXduk5VVRVffPEFABMmTMAwDB5++GHGjx9PXl4e++23H0VFRQwdOpSrr76a7du3dzMS6SqnaTLE6WZwxGZQYwhHdR1WQyNYNrG1G3p7eCIDgsvlori4OP6zY+1zEdl1mmci6ad5JiJ9jcvl4vzzz98t12poaGDevHkAnHvuuTg6KZ94wgknABAKhfjwww/TPj7pOv17lh4qB9GPhEKheLJ1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oR2O33333SxfvpxDDjmEK664gvHjxxOJRFi8eHE8kbdo0SJOO+00otEohmHwve99j/POO4/BgwezadMmHnnkEV566SU2bdrE5MmTWbp0KaNGjUo6phUrVvDUU0/h8/n46U9/yvHHH4/D4eCDDz7gt7/9LSUlJTz//PPMmjWrwwZun3/+OaWlpQDss88+jBs3btd/ScDvfvc7rrvuOgB8Ph9XXXUVJ510El6vl08++YQ//elPfPzxx7z11lucfPLJLFy4MGWi869//SvvvPMOhx56KD/60Y8YP348lmXxxhtvcMcdd9DQ0MAtt9zCCSecwHHHHdfu3JUrV/KjH/2IWCxGXl4es2bN4vjjj6ewsJBYLEZpaSkfffQRr776atK/9VmzZvHwww8DcNBBBzFr1ixGjx5NYWEhmzdv5tlnn+WJJ57g/fff59RTT+W9994jKyvxN5gBpk2bxhdffMH3v/99pk2bxogRIygvL6esrAxoWTX8k5/8hMrKSubOnctZZyXOfwA89thj8dszZ85M2m5PYNgqBCoDwKpVq9oVp1+5cmWPvTj3tuAnn1G6ZQt2TR12fQNDMrw4MjO578V6/jX23ITnVH36Mlcf4mK/4SMIxUyaLAfNloNgzEHEannRtrFbagJHLfYusMnMyWTEICejjttvd4Yn0ieEw+H4mzuA4uLilG+yRKT7NM9E0k/zTCT99sR5tmHDhniS9fjjj+ett95K2G7NmjUccsghNDY2ArB48WKOPPJI3nrrLU444YR4u+985zs8/fTT7VYNt4rFYhxwwAGsXbsWgCeeeIILLrigQ7vbb7+dG2+8EYATTzyR//73vx3atE1YDh48mEWLFnVIFldVVXHsscfy6aefAvDGG28wZcqU+PGnnnqK888/H4AZM2bw1FNPJYy9O7788kvGjBlDJBIhNzeXt99+u8Nme+FwmDPPPDNexuH222/nhhtuaNdmx9/r+eefz+OPP96hVvG8efM4+eSTAZg+fTrPPvtsu+M33XQTt912GwDLli3j4IMPTjr2yspK8vPz2z32j3/8g//3//4f0JLcvuaaaxImi5999lnOPfdcbNtOGM/MmTPjCVvDMLj//vs55ZRTgI7zrKysjKFDhxKNRjnzzDN54YUXEo43HA4zZMgQqqqqmDBhQrsPKXpLb+avtBJYpB9y5mbzrTFV/LupgmBWQYfjgf1O5u8fPc4FeWNJ9DGPx7TIdMRo9rppqm2mvCbG8BybLWURhlbX487174YoREREREREel7w7r8SuveRHukrsPadlMebxk6lqQeu4/nx/5B51UVJjyeKqbNzdodYLMa2bdt49dVXufHGG+MJ4JNOOokjjzyyQ3ufz8df/vKXhAlggJdffjmeAD7//PMTJoABbrjhBl555RWWLFnC66+/zscff8xBBx2UdJx33XVXwtXCeXl5PPTQQxx77LFAy0rltkngioqK+O1BgwYl7b877r333vhq8jvvvLNDAhjA7Xbz2GOPsc8++9DQ0MA999zDL37xi6S/t6KiIh566KGEm9V985vfZOLEiXz00UcJE/jbtm0DIBAIpEwAAx0SwEA8gXzKKafw05/+NOm5Z599NmeddRbPP/88Dz30UIckcFszZsyIJ4ATKSoq4tRTT+Xll1/m1VdfpaKigoKCjrmRl19+uV095z2dNoYT6adGHDaSKfWfJDxmOtxUew9gw7ZtOA0bnzNKoTvMiMwg+3kb2DuriSGeEINzDXCY1EedhOqaidkGWz/dtpsjERERERERkf5gwYIF8U25DMPA6XQybNgwZs2axfbt2wE47LDDkq6YPeOMM8jNzU3a/7x58+K3L7vssqTtDMPg8ssvT3jejnJyclJuznbMMccwZswYoGUlcNuatnV1dfHbPp8vaR/d0TpWr9fLd7/73aTtioqKOPvss4GWla+pVrGec845KcsrtCbkKysrqa2tbXds2LBhANTU1PDPf/6zSzG0+uyzz1i9ejVAfMV0Kq0rlzdu3MjmzZuTtkv1e2nVmtSNRCI8+eSTCds8/vjjQEut6mQfKOxJlAQW6ac8Djjl8Awymtu/gNuWRX3JEqo/f4233/oHo72NDM9opsAdxuuI4WjzrYxMh43f3/JJYkVNFBvYsi1MrK5xN0YiIiIiIiIi/ZnH42HSpEnMmTOH9957L+GKUaDTlaYff/wx0JK0O+KII1K2nTRpUvz2ihUrkrY79NBDO90MrDVJ2tjYGF+JDJCdnR2/3dDQkLKPrgiHw/FNyg455BAyMzNTtu9qjK1J7GTaPh9tE9vQknBtHce5557Lsccey5133sm7774bX9mdzPvvvx+//f3vf7/dBwSJfn784x/H22/dujVpv13Z7O/000+Pb5jXtu5vq/Lycl577TUAvvWtb1FUVNRpnwOdksAi/djIAoPjM7YAYFsxGkqXseHfP2fzm7fTtP1jPt2whlXrv0zZR0G2CaZJXcRFuD5IxDIo/UyrgUVERERERKS9ww47jE8++ST+s3r1akpKSqivr2fhwoX84Ac/SFqyAIgn7ZKprKwEWkoTeDyelG2HDBnS4bxEulLGYfDgrzddb1sCom2JgdaVzruiurqa1q252l4zma7G6PV6U/Zjml+n/9qudAbYe++9efnll+MrghcuXMi1117LcccdRyAQ4Oijj+b3v/89NTU1Hfpt3ahtZzQ1JS+k0tnfCbSUzGitRbx06VJWrlzZ7viTTz4ZL7uxp28I10o1gUX6Mb8zxpT9LDa8s5h5K17CdGawY/n1Zxe8yfhR+yTtI8sFXp+TxrowFTVRiv2weXOQ4rFNOHzJv04iIiIiIiIiexav15uwhm1XJapZ25cdcsgh8dsffPBBL44kvaZOncratWt56aWXeO2113j33XdZs2YN0WiUxYsXs3jxYn7zm9/w5JNPxjeZA4hGo/Hb9913H9/4xje6fM1ENZpbdfXvZObMmdx3331Ay2rg3/3ud/FjrauD8/PzOe2007o8roFMSWCRfm5UZpDvH+rmy2XVrLeH4MjIxnRmYkWDAKz4cg1fbN7EfsNGJO2jIOCgscGgNuyksKEZw5fB9s+3Uzwx+YuyiIiIiIhIX5R51UW7bcO0rNVv4Ha7036d3RlTb2otW1BTU0MoFEq5Grh1Q7O25yXSlRW8bftqu/r3gAMOYMiQIWzdupUvv/ySVatWMW7cuE77SyY3NxfDMLBtu901uzKuVDH2BI/HwznnnBOvn1xeXs78+fN5/PHHefXVV6mqqmL69OmsXbs2voq5sLAwfn5mZuYufUCwMw477DDGjRvHqlWr+Pvf/84dd9yBw+Fg5cqVLFu2DGipVbw75mh/oHIQIv1cgTuMy+vhvNO/TbS5BgCXr32tm38ueDNlHz6XTabXhY1BZU3LJ3mbNzViNTWnZcwiIiIiIiIiOzrooIOAlhWmbevNJrJo0aL47VQ1ZJcuXRovC5DMkiVLgJaVzqNHj2537NJLL43f/u1vf5uyn8643W4OOOAAAJYtW0YwGEzZvqsxpkNhYSHnnXcec+fO5Yc//CHQUjP5xRdfjLeZOHFi/Pbbb7+9W8fXqnWDuK1bt8Y33WtbI1ilIL6mJLBIP2caMMgTYtzIUYwKtHy65fQWgPH11yc+/Gw167eVpuynMMcBpkFNyEGkKUQwZlL+hWoDi4iIiIiIyO5xyimnxG//+c9/Ttl2zpw58dttSxTsqLa2ln/+859Jjy9cuJBPP/0UaCmLsGMpgquuuorc3FwAHn/8cZ577rmU42qrrq6OZ599tt1jrTE2Njbyt7/9Lem5FRUV8XMHDRrU6aZ66dT291teXh6/PWHCBPbZp6X85NNPP01JScluH9t3v/vd+HP22GOPEYvF+Pvf/w7AgQceyKGHHrrbx9RXKQksMgAM9rSs2D3nmKOwIkEMw8TlLWjX5rkFb6Xsw++xychyYWFQVRMGYNPGBuxQKC1jFhEREREREWnr29/+Nvvuuy8ATz31FE8++WTCdr/5zW947733ADjppJM48MADU/Z7zTXXsH79+g6PV1VVtVvpe9VVV3Vok5eXx9///vf45mozZszg3nvv7bDB2o5eeOEFDj30UF555ZV2j19xxRW4XC4Arr32WlatWtXh3EgkwsyZM6mvrwfgyiuvTLnh3q54/vnn222Gl8hrr70Wv92a9AUwDINbb70VgGAwyJlnnklpaeoFaJ9++in/+Mc/dmHE7Q0ZMoRvfvObALz44os888wzbN26Ffh6lbC0UE1gkQHAY9rku8McvO9+DHn3A7aHweUbRKTh69pHi1Z9zObykxjWpmbPjgoCDjY3GVQ1O8lvDtOEm4ovtlF44F67IwwRERERERHZg5mmyaOPPsrxxx9PNBrlu9/9Lv/9738599xzGTRoECUlJTz66KO88MILAAQCAR544IGUfR588MGsXr2aww47jJ/97Gccf/zxOBwOPvjgA+6888746tULL7yQKVOmJOzj1FNP5ZFHHmHWrFmEQiGuvPJK7r33Xs455xyOPvpoiopaSjJu27aNJUuW8OKLL8aTu8cee2y7vvbee29+/etf8/Of/5zq6mqOOuoo/vd//5cTTzyRrKwsVq1axR//+EdWrFgBEB93utxzzz2cf/75nHjiiUydOpVx48ZRUFBAKBRi48aNPPXUU7z00ksA7LXXXpxxxhntzr/gggt45513eOCBB1i2bBljx47loosuYsqUKRQXFxONRtm+fTvLly9n7ty5LFmyhAsuuIAZM2b0WAwXXnghr732Gs3NzfHSFU6nk+9+97s9do2B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T20pJsWUimJKTDElp5iSU0yJKabkFFNyiikxxZScYkqur8cEdOn/tdtKdM1kMU2dOpU///nPANx3333xDcwSxTRnzpz47SlTpiQdV21tLU899RQzZsxIGNO7777Lp59+CsAJJ5zQYWxtn0PLsgiHw91+nnYcWygUit9ubGxsd6zt8/TMM8+0y8ckijHR7zfZ396UKVN46aWX+Pzzz3nzzTc55phj4sfaxvTMM89QW1ub8rptY41Go4TD4V362/vJT37CfffdB7QkgOfPn09h4deLz7oyn6w2ZShbr9nX59PupCRwP1JfXx+/7fN1/v0Pv9+f8NyuMgyDSZMmce6553LccccxevRosrKyqKioYNGiRfzxj3/k3XffpaysjNNPP50333yz0x0mu+L+++/n1ltv3aU+ysrKuvRVOJfLxdChQxOe351/rFvrQbUViUQoLS3tch8AxcXFuN3udo/V19dTU1PT5T7axmTk50JWBkZTM1WFOYRqoTrYRCgjiwbLQ1nExt5hM7gMZwPDM+opafZ36Ns/4mhcvkG8tXwp35p6It7MzOQDyYRGjwszZBNpCGH4MqhYX07RBO8uxdTWQHme2lJMiikVxZSYYkpOMSWnmBJTTMkppuQUU2KKKTnFlFxfj8m27W7HFI123IA8WUyHHHIII0eOZMOGDTz99NMcffTRnHnmmR1i+s1vfsN7770HwLHHHkteXl7Kcf30pz9l1KhRHHjgge1iqqqqarff0v/7f/+vQz9tN1RramqitLS0W89TNBrt0Gfb1a0PP/wwRx99dPx+6/P06aefcuWVV7Y7L1GMiRKayf72zjvvPF566SUAZs2axT//+c/476M1pvXr1/PTn/600+u2zTPV1NRQWlq60397t912G3/9618B2HffffnXv/5FUVH7bxJ3ZT613TyvsrKSSCTSp+fT7qYkcD8SDAbjt3f8I06kbe2ctud21Te+8Q0WLlzY4fHBgwfzne98h7POOouf/OQn/OlPfyIYDHLppZeyfPlyTFP7DfYk27bb/aPpcDg6fJKVjGEYmMOLsT5fB9k+suqaqA5F8HjCgIeQlfhTqEMD5ZRs65gENkwHuQecTtmHf+G95cs48ehJSa+d4YAMt4EVMqipC1Pky6C0pIHCcR3fAIj0Ntu227156s48E5Gua7uKJNEKGhHZdTv7vlFEukbvG9PL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t2crB4vAxoA70yhntghcnZ5/PhERERERERGRTqEisMgSlyQJvu83frTCfa6+1QXwXMpOBJ5LJfGIpqvzxm3etIHayDNNz7Ft/9x2D95Mz/lgpvZbm9ZK4OVOeSaSPeWZSPaUZyLZU56JZE95lo1luTGcyHISBAH79u1r3F+3bh2e57VxRkvLyi6wesoU/BG8vINf85muhPSsmDvujLXr8R96isKq5807x56gCzhY6HWcdHM4P0xXAteqzVcQy/KhPBPJnvJMJHvKM5HsKc9Esqc8y0Zbi8CXX355Jud96qmnMjmviCw9rg3dq0uMDY5QLloMj8Nk3aI7DDHOwUucY1v0xsM0+/ywUliDH4/hWemznpsWgYMwvV+rqB2EiIiIiIiIiHSuthaB77rrLowx7ZyCiCwDfad2MbbdpuQlDHsuU/WYeLqK3VOeM+7McsCOZicwFrurOc7qSttCuO7sSuD06bqfkEQRxrYzjEJEREREREREJBtLoidwkiQL/iMiJ4++LgPdZYp2hJ1zibCoVOa3cHjh2h6i+lTTczx+oN647c20gwgSQxLH1GOLpFJvepyIiIiIiIiIyFLX1pXArusShiHGGN7//vfT29u7IOe95ZZb6O/vX5BzicjSV/Cg1NfF1MgYpaLF+ARM1aAUxRj74Gdd52w8jerPn6C07qJ553hy3AbSwrFnG7AswhjiIMRYHvXpGoVycbFCEhERERERERFZMG0tAr/whS/k/vvvxxjD61//el73utctyHm//e1vqwgscpLpW1tiaodFdw7GXZupwCOpVjGlrsaYcrGAV9kBzC8CD7unAPsBcKwEY1skcUwQJNg5qE37FBYpFhERERERERGRhdTWdhAveclLGrd//vOft3EmItLp+rptKHfR5YRYuRw+NrVpf964tV7zdhBRfgUT4cHPxdyZm0Ewsznc1PxziYiIiIiIiIh0grYWgS+55JLGbRWBReRElPOQX1nCBrqK6aVtqjq/R/jmla03d3ty9ODtRl/gMAagVgkWdsIiIiIiIiIiIotEK4FFZNnoW1sGA+W8AcdiMnZJqrU5Y164aS3+5P6mxz+y/+DYgyuBZ4vA8zeaExERERERERHpBG0tAm/evJlisUiSJPT397Nnz54FOe/atWs57bTT2LRp04Kcb6kaGxtjy5YtvOQlL6Gvr49iscjZZ5/Ndddd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lcq8Y7Jw++23N26/6EUvyvS1RI5FqTftoZ3PpZe6WmhI4oOrgXuc1gXdXePpxoreTAHZn2kbUatGx9T3R0RERERERESk3ZZcETiOY+666y5uvPFGrr32Wi644ALWr19PT08PnufR09PD+vXrueCCC7j22mu58cYbueuuu4jj+LlPvgxs3ryZ3/iN3wDgJz/5Cbfeeuu8Mbt37+YjH/kIAIVCgT/8wz+cN+bmm2/GGIMxhptvvnne80NDQ9x+++3P+ef6/e9/n7/4i79o3D/RfsAiC6mrNw+WoeAk4FjUEwf8g4XfshNCi4Ju/3TaKN5z0stkGEMC1CMLmvQnEhERERERERFZqpbMxnATExN86lOf4ktf+hIjIyNznjt01d3k5CSTk5McOHCg0fP2L/7iL1i5ciXvfve7uf766+nu7l7UuS+2z3zmM/z0pz9lZGSE97znPTz44INce+21lEol7rvvPrZs2cLAwAAAW7ZsYf369cf8GlNTU7ztbW/j+uuv55prruGlL30pp512GqVSiampKR5//HG+/e1v80//9E+NYz7wgQ/wyle+csHiFDlRpYIF+TxeXAXXJQxjgnqAl097AdsGvKSCb7rmHTsa2MRJgutaYBn8xIYwJHAcwuk6bq55P2ERERERERERkaVmSRSB77rrLq699lpGRkaO+mvWh48bHh7mE5/4BLfeeit///d/z2te85oMZro0nH322fzzP/8z11xzDfv27eOWW27hlltumTPGsixuuOEGPvCBD5zQa+3Zs4fPfe5zRxxTKBS46aab+NCHPnRCryWy0Aou2IUcVKrkXEO9CtVajNdzcEzZDhhudtnxehgcG2NV7wqwLOIwIQwiXMehPlXHXbloYYiIiIiIiIiInJC2F4G///3v8+Y3v5kgCBqF3VKpxMte9jIuuugiNm3axKmnnkqhUCCXy1Gv16lWqxw4cIBdu3bxwAMPcM899zA5OUmSJAwNDfG6172O73znO7z+9a9vc3TZufTSS9m6dStf+MIX+Na3vsWOHTuo1WqsXbuWyy67jPe+971ccsklx33+TZs28dOf/pQf/vCH/PznP+eZZ55hcHCQkZER8vk8fX19nH/++VxxxRW89a1vZc2aNQsYnRzKGIPrunPuy9ExJt0cbnw43RyuDtQP2xxuVR6Gq/OPdbpWsXugnzUrVmDbhiiEMEhwC1Cr+JQWJwRZJMozkewpz0SypzwTyZ7yTCR7yrNsmKSNOxwNDw+zefPmRuuCM888k49//ONcc8015I7hq9a+7/PNb36Tm266iaeeegqA1atXs23bNlau1HK9k8HWrVs5//zzG/cfffRRNm/e3MYZyVLx5NPT7HvgWYZqFv17K5StOhtP7278JfJ/B9bws/G+ecdN7b2fy+z7ePOrXs3TByKq0wEbe2O6+4qcdXqRDZecvsiRiIiIiIiIiEgna2f9qq0bw33ta19jYGAAYwxXXHEFDz/8MG9729uOqQAM4Hkeb33rW3nooYe44oorABgcHORrX/taBrMWkU5SWpEHA3nXgG1Rj505G7v1OGHT45xiH7sG+gFwZ74zUQ/SjRJrlaDpMSIiIiIiIiIiS1Fbi8D/+I//CKQ9Zf/2b/+WYrF4QucrFArcfvvtjfN885vfPOE5ikhnKxdsyOXIWzE4Dj42Ye1gEbfbaV7QdYtpOwgA10kvlUGUPletqggsIiIiIiIiIp2jrUXgZ555prEKeKHaNvT19XHFFVeQJAlPP/30gpxTRDpXMQemkMcxCa6bXvJq9bjxfHeLlcB2rsTesQniJMGbaUUUzAytV6Oj3sRSRERERERERKTd2loEHh0dBeCUU05Z0PPOnm9sbGxBzysinccy0NWdtpjJe2kf4EM3h+tpsRIYIHbKDIyONIrHfgQJCbXIglo9w1mLiIiIiIiIiCwcp50vvmbNGnbv3s2OHTsW9Lyz51uzZs2CnlekHYIgaGyeCOmmh4fukinPrdSTYwrI5wyTQC2AJEkwxrRcCQxpX+DdgwO8sHcVWIYwtiEIiVyXYLqGV8gvWgySLeWZSPaUZyLZU56JZE95JpI95Vk22roSePPmzSRJwo9//GMeffTRBTnnI488wt13340xZtF21xPJUpIkBEHQ+FEbgmPXtaIAQN6zwDLUErvR28G1EopWq77Afewe6Mc1CVgWMYZwZnO4+pTf9BjpTMozkewpz0SypzwTyZ7yTCR7yrNstLUI/Du/8ztA+ua+6U1vYtu2bSd0vscee4yrr7668R/HW9/61hOeo4h0vnKXA56bbg7nOviJTVQ/WMTtcZuvBnaKq9jd349lwHHSVhLBTBG4Oq0isIiIiIiIiIh0hrYXgV/0ohcBsHPnTi6++GLe+973cu+99xLH8XMcnYrjmPvuu4/3ve99XHzxxezcuRNjDBdeeGGjyCwiJ7euHFAs4FkxtmOTYPBrB68xPS1aQrhdq9g12J/ettMisB+mHzLVplv3EhYRERERERERWUra2hPYdV1uv/12Xvva17J//37q9Tq33nort956K11dXVxwwQWcdtpprFmzhkKhgOd5+L5PtVqlv7+fZ599lkceeYTp6WmAxgrgtWvXcvvtt+M4bQ1PRJYIx4ZCyaM6BnkPpqeh5scUZ57vbrE5nFPsY8/gAHGS4LlQ5eBK4HpVK4FFREREREREpDO0vUp6zjnncN999/HWt76Vf//3f28Ucqemprjnnnu45557jnj84X1BXvWqV/H1r3+d9evXZzZnEek8pd481T2Qz9lMAzU/IQEMR1gJXFyFHwT0j47gOiuARithapVoUeYtIiIiIiIiInKi2toOYtb69ev58Y9/zD/90z9x1VVXkcvlgLTA+1w/ALlcjquuuop/+qd/4u6771YBWETmKfXmAch7Zt7mcD1HWAkMsHugH89NL5f+bBG4FpEcZdsaEREREREREZF2avtK4ENdddVVXHXVVUxPT/Mf//EfPPbYY2zfvp3h4WGmpqao1Wrk83lKpRJ9fX284AUv4Nxzz+XlL385XV1d7Z6+iCxh5bIHjkMhjsG2qQcOcT3Adh26W6wEdgq9GMtlV38/5521GYAghiSOqRsLanUoFhYzDBERERERERGRY7akisCzurq6uPLKK7nyyivbPRURWSaKOaCQwwunsVyHOAgJ/AAb6HN9XmT2snXrL9gzuY+gMkxYGSaYHiKJA3YP9uPZgGUIYhuiiMhyCaZreCoCi4iIiIiIiMgStySLwCIiCy3ngFfK409Ok/MM1QpUazF5YIUbcO2avVR/9jMeeWLrvGP3DAzgmARj2yRxQuBHeK5LbcrHO2XxYxERERERERERORZLoiewiMhiKPWk/cbzOQNA3T+4saRVLnHa+ZubHrdncIAkiXGc9LggSI+rTvlZTldEREREREREZEGoCCwiJ43G5nA5CwzUYoskihrPb1qzpulxfhjQPzqatoQAgjAtAtcqzTeUExERERERERFZStQOQmSJs22b3t7eOffl+JR68mDbFKIYnHRzOOp+Y3O3DaeswRhDkiTzjt090M/61b0A+LNF4GrzDeWk8yjPRLKnPBPJnvJMJHvKM5HsKc+yoSKw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UCjw3e9+l3e+850AVCoVrr76ar72ta8B8G//9m9ccskl/M7v/A5PPvkkSZKQJAmnnnoq/+t//S+eeOKJNs5eZGFEUcTY2FjjRy1OsufNFIEde7YInLRcCWzn0yJwtV7HdWZWAieQxDF+bEGtvggzlhOlPBPJnvJMJHvKM5HsKc9Esqc8y8aS3BjuUJZlcdttt7FhwwY+9rGPEYYh73znO/nsZz/LI488AtBY+XvKKafwoQ99iPe9733k8/l2Tltkwcxe/GYVi0Vs227fhE4CjSLwTFE3OuJK4F4AqvUarg1YhjCxIYoILZew6uMW5/cSlqVFeSaSPeWZSPaUZyLZU56JZE95lo0lXwSeddNNN2FZFjfddBNJkvDwww83nluxYgV/8id/wvvf/366urraOEsRWQ7cfPqXS6O9QwSl5+oJXKvjmAQsizhMiIIYxwV/uo7btzjzFhERERERERFppiOKwAcOHGDLli18+ctfxhgz57mLLrqIO+64g3K53KbZichykyu4wMGN4UIMZRM0HWt7XRg7R9WvYxuwbIs4jAjDGAeoV0P00ZSIiIiIiIiItNOS7gk8ODjIH//xH3PWWWfxhS98gXq9TpIkWNbBaT/wwAPcfPPN7ZukiCw7XsEDwDU02juUTOvevk6hl2o9fd6dKRwHUdqmpl7xM52riIiIiIiIiMhzWZJF4JGRET70oQ9x5pln8tnPfpZqtdrY9O3Nb34zjzzyCH/913+N46QLmT/72c/ytre9jSBovlJPRORYeI4Bx8GxANsiwlBKjlQEXkG1VgPAnd1MLpwpAteat5EQEREREREREVksS7IdxOmnn8709HRjwzeAyy67jE9+8pO85CUvAeCcc85h9erVvOUtb2Fqaoq/+7u/Y2BggG9961tqDSEiJ8RzANfGDkOwbBIirDjENTFBMv+zM6ewgkp9Ir2ddpIgCGaKwFUVgUVERERERESkvZbkSuCpqanG7UsuuYR/+7d/40c/+lGjADzryiuv5M4772T16tUkScKdd97Jq171Kvbv37/YUxaRZcS1AcfBAmY3II2jmLLTenO4qj/TDsJKVwIHcVoE9mtR1tMVERERERERETmiJVkEBnje857H3//933PfffdxxRVXtBx30UUX8R//8R+cffbZJEnCww8/zMtf/nIef/zxRZytiCwnlgE3l35Rwp25SoYhlO3mRWA7f0g7CG+mHcRMd5p6PSaJ42wnLCIiIiIiIiJyBEuyCHzbbbexdetW3vKWtxzV+DPOOIOf/exnjZXCzz77LK94xSv46U9/muU0RWQZ83LpEmDHPriyt9RqJXBxBZWZjeEa4xNDkiT4iQV1bQ4nIiIiIiIiIu2zJIvA73znO7Fnv4N9lPr6+rjzzjt5wxveAMDo6Ci/9mu/lsX0ROQkMFsEtmeKulGYtFwJ7ORXUJ0pAnuOAcsQYkMYEsSGqNp6UzkRERERERERkawtySLw8SoWi3z3u9/l7W9/OwC1ma9ni4gcKy+ftoNwnJmVvRGtVwIf0hPYMTFYFlFiiMK0DYRf0UpgEREREREREWkfp90TWGi2bfOVr3yFdevW8YlPfKLd0xE5YcYYXNedc1+y5+bTP3N35ksJUXSElcCFXmp+nSiOsS0Ly7aIw4gwjHGA+rRPcZHmLcdHeSaSPeWZSPaUZyLZU56JZE95lo1lVwSe9ed//uds2LCh3dMQOWGu67J+/fp2T+Okkyukl0d7ZiVwmBhKVtB0rJPvBQxVv04pX8CxwQfCMAGgXmtePJalQ3kmkj3lmUj2lGci2VOeiWRPeZaNZdUO4nDvec972j0FEelQXiH91NGxZ3r8JjYl07ytg7Fd7Fyp0Rd4dvVwowhcaV48FhERERERERFZDG0rAu/bt2/RX3P//v2L/poi0plyng22hWuStMcvFmVab/BmH7I5nDuzetgPZlcCR9lPWERERERERESkhbYVgZ///Ofz3//7f2d0dDTz1xodHeUjH/kIz3/+8zN/LRFZHlwHcBwck4BtEWHIJ603eHOKK6gcvhI4nikCV9UOQkRERERERETap21F4Eqlwic+8QlOO+00/uRP/oQdO3Ys+Gvs2LGDP/qjP+K0007jL//yL6lUKgv+GiKyPHk24DrYJsFYM03o44ii1WJzuPwKqrVaettNL63BzFDfj0niOOspi4iIiIiIiIg01baN4d7//vfzxS9+kampKf7n//yffPazn+VXf/VX+e3f/m2uvvpq1qxZc1zn7e/v59vf/jZ/93d/x9133w1AkiQ4jsPv//7vL2QIIosiCAIGBgYa91evXj1nl0zJhmOD5TrEgGsZfCAKE8pOSMWfe+lM4gjbK1L157aDCGNDQoIfG/ADyOcWOQo5Wsozkewpz0SypzwTyZ7yTCR7yrNstK0I/NnPfpb/9t/+G9dffz3/8i//QpIk3H333dx99928733v45xzzuFVr3oVL3zhCznnnHPYsGEDfX19FItFkiShWq0yNDTEnj172L59Ow899BD//u//zuOPP954jSRJv4r9hje8gU996lNs3ry5XeGKHLckSQiCYM59WRy5nE2VtCDsA0EY85qVQ3z5299idGqQsDpKWB0jqk9AElM99y0AuDObyQWJBUGI77pE1TqOisBLlvJMJHvKM5HsKc9Esqc8E8me8iwbbSsCA5x//vl873vf46c//Smf/OQn+d73vtd4Yx9//PE5Bd2jNXu8MYZf//Vf50//9E952ctetqDzFpGTgztTBLbtmZW9EbyoPIHZ/R9MV6fmjZ/tCexYcbqZXJgQhzG2C8F0HWfFYs5eRERERERERCTV1iLwrFe84hX83//7f3nqqaf4yle+wte//nV27dp1XOfatGkTv/u7v8s73vEOzj777AWeqYicTLx8eol0Zq6UYZT+u+B5UJ0/frYdhGPA2BZJGBGGMTZQqwQUFmHOIiIiIiIiIiKHWxJF4Flnn302W7ZsYcuWLTzyyCP84Ac/4N577+Xhhx/m2WefpTaz6dKsfD7P6aefzgtf+EJe+tKXcuWVV3LBBRe0afYistx4eRuYae/AwSJw0Wve1qFaqzduu1Yy00IiIQf41eYbyomIiIiIiIiIZG1JFYEPdcEFF8wr6I6PjzM9PQ1AV1cXPT097ZiaiJwkvLwHgD2z0VsUpy1nivl80/GV+sEPqlwn3UwuDGMA6pV602NERERERERERLK2ZIvAzfT09KjwKyKLxivMtIOwDRgIMRDF5HPPXQR2XAuAIEiLwLUpFYFFREREREREpD2sdk9ARGSpyhVcsAyuScCyCBMboohiV7Hp+Frdb9z2vLSVhB+km1VWKxFJFGU/aRERERERERGRw6gILCLSgmsDjoNjpUXgCIs4jCh2dTUdf+hKYM9LW0jUIpskipgKHag02U1ORERERERERCRjS7II/Ed/9Ef89V//NQ8//DBhqM2URKQ9PAdwHGyTgG2RAFEUU+wuNx1fqR9s+VC0Y3Bs6olD5IeEiaEyWlmciYuIiIiIiIiIHGJJ9gT+7Gc/izHpKjrXdTn33HN50YtexIUXXsiFF17Ii170IlasWNHmWYrIcufagOtgAY5lCIEo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Z2+99ZYZMmTIYT87jhgxwpSXl8cgMiDxTjzxxA5/37ds2RLT/l566SWTk5MTtT+/328WLFgQ0z5TGTOBAQdt3rxZ5513nrZv3y7LsnTddddp+fLlWrt2rR5++GHl5eUpHA7rzjvv1G9+85se9fXII4/ozjvvVDgcVl5enh555BGtXbtWy5cv13XXXSfLsrR9+3add9552rx5c4wiBBIvHnnW0NCg3bt3S5KOPvpo/fCHP9TSpUu1bt06rVu3TqWlpRo5cqQkaf369Ro3bpzdHnCDeL6fHSoSieiqq65SfX29jjrqqJieG0gm8cwzY4y+973vqaSkRA0NDTrmmGP085//XK+++qo2bNigN954Q6WlpbrggguUmZkZowiBxItXnu3YsUPf+ta3VFFRIUkqKirSwoULtWrVKq1YsUKPPvqoCgsLJUkbN27UWWedpZqampjECCSSMcbe7tOnj4qLizVw4EBH+nrrrbc0ZcoUVVdXKz09XbfffrtWrlyp1atX62c/+5l69+6t+vp6XXvttVq2bJkjY0g5ia5CA242adIk+z9QpaWlbZ6vqKgwAwYMMJJMZmam2bFjR7f62bFjh8nMzDSSTDAYNBUVFW3aPP744/ZYLrjggm71AySjeOTZ9u3bTXFxsXn11VejtmloaGg1lhkzZnS5HyBZxev9rD2/+tWvjCSTn59vHnroIWYCw7XimWctc+n66683jY2NUds2NDR0ux8g2cQrz26++Wa7n6lTp5pIJNKmTUNDgznzzDPtdg899FC3+gKSycMPP2wWL15sNm3aZP/ejx07NuYzgSORiDnppJOMJGNZlvnrX//aps2GDRvsK8ny8/NNTU1NTPpOZRSBAYds3LjR/kM3ZsyYqO3mz59vt7vtttu61dett95qn6OjSx3GjBljtysrK+tWX0AyiWeedUZVVZVJT083kkxubm67H/iBVJPIPPvggw9MIBAwksyyZcvMwoULKQLDleKZZzt37rQnDxQXF/NehSNGPPNs1KhR9jk2bdoUtd3f/vY3u93kyZO71ReQ7JwoAr/88sv2OadNmxa13ezZs+128+bNi0nfqYzlIACHLFmyxN6+5pprorb77ne/a19m1/KY7vSVmZmpqVOnRm03ffp0e/uZZ57pVl9AMolnnnXGgAED9NWvflWStGfPHn322WeO9QXES6LyLBKJ6Oqr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",
      "text/plain": [
       "<Figure size 1350x840 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L2 error: 0.07299107313156128\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "t_idx = 2\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        # Set compact figure size and high DPI\n",
    "        fig = plt.figure(figsize=(4.5, 2.8), dpi=300)\n",
    "\n",
    "        time_label = t[slice(*tpred)][t_idx].item()\n",
    "        param_val = x_ood_test[parameters_idx, 0, 0, 0].item()\n",
    "        true_vals = y_train[parameters_idx, :, t_idx, 0]\n",
    "        pred_mu_conserv = new_mu[parameters_idx, :, t_idx, 0]\n",
    "        pred_std_conserv = new_std[parameters_idx, :, t_idx, 0]\n",
    "        pred_mu_e2e = u_proj_reshaped[parameters_idx, :, t_idx, 0]\n",
    "        pred_std_e2e = stds[parameters_idx, :, t_idx, 0]\n",
    "\n",
    "        # Plot true solution\n",
    "        plt.plot(grid, true_vals, color=\"black\", lw=1.5, label=\"True\", zorder=3)\n",
    "\n",
    "        # ProbConserv\n",
    "        plt.plot(grid, pred_mu_conserv, '--', lw=1.2, color=\"#ef233c\",\n",
    "                 label=r\"ProbConserv\", zorder=2)\n",
    "        plt.fill_between(grid,\n",
    "                         pred_mu_conserv + 3 * pred_std_conserv,\n",
    "                         pred_mu_conserv - 3 * pred_std_conserv,\n",
    "                         color=\"#ef233c\", alpha=0.3, label=\"_nolegend_\", zorder=1)\n",
    "\n",
    "        # ProbHardE2E\n",
    "        plt.plot(grid, pred_mu_e2e, '--', lw=1.5, color=\"#3a86ff\",\n",
    "                 label=r\"ProbHardE2E\", zorder=4)\n",
    "        plt.fill_between(grid,\n",
    "                         pred_mu_e2e + 3 * pred_std_e2e,\n",
    "                         pred_mu_e2e - 3 * pred_std_e2e,\n",
    "                         color=\"#3a86ff\", alpha=0.3, label=\"_nolegend_\", zorder=3)\n",
    "\n",
    "        # Labels\n",
    "        plt.xlabel(\"x\", fontsize=8)\n",
    "        plt.ylabel(r\"$u(x, t={:.2f})$\".format(time_label), fontsize=8)\n",
    "\n",
    "        # Ticks and grid\n",
    "        plt.xticks(fontsize=7)\n",
    "        plt.yticks(fontsize=7)\n",
    "        plt.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "\n",
    "        # Legend\n",
    "        plt.legend(fontsize=7, loc=\"upper right\", frameon=False)\n",
    "\n",
    "        # Layout for Overleaf\n",
    "        plt.tight_layout(pad=0.3)\n",
    "        plt.show()\n",
    "\n",
    "        print(\"L2 error:\", torch.norm(true_vals - pred_mu_e2e).item())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "id": "e2918b7b-cab2-4da1-8179-9d49cdd14170",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0797)\n"
     ]
    },
    {
     "data": {
      "image/png": "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v81vfvMb7HZ7tcc8cOBApWU2m61OVWMNZeTIkfTu3ZtPPvmk2m369+/PG2+8we23307Xrl35wx/+AEB6ejo+n4/Ro0ezdetWpkyZQs+ePXnvvfeYOHEihYWF3HbbbTHHqun6qMrSpUt59913ufXWW3E6nTz//PP86le/YuXKlQwcOBCAb775hq+++orLL7+crl27kpOTwwsvvMDo0aPZsGEDHo8n5pg333wz6enpzJgxg7Kysnod45ZbbqFjx448+OCDfP3117z00kskJyfz1Vdf0b17dx577DE++OADnnzySQYOHMj48eOj+95www3Mnz+fSZMmceutt5Kdnc1f//pXvvvuO7788kvsdjuzZ8/mlltuIT4+PtrOJTMzE4hUO40aNYpdu3Zxww030L17d7766iumT5/Onj17mD17dr2f86KiIkKhUI2vCUR+CFRVvXskFe3g0tLS6rxvdft/+umnADidToYNG8aqVatwOBxcdNFFPP/880e8xkQjau4iKdF+1aZq7JprrlGdOnVS+/fvj1l++eWXq6SkpGgRczgcrlSUXlBQoDIzM9XVV18dXVZRBZOYmKj27t0bs31FldCh2yul1EUXXaQ6dOgQs6xHjx5qwoQJlR7LmWeeqSzLii6//fbblWEYqrCwUCkVqSqy2WzqwgsvjDneAw88oICYY1YHUNdcc43at2+f2rt3r1qxYoUaM2aMAtTTTz8dE+M555yjwuGw6tixo3r44YeVUkpt2LBBAWrp0qVVvgYVz0NVt379+h0xvurUt2qswgUXXKAAVVRUVON5Kh73oWbPnq0A9eabb0aXBYNBNXLkSBUfH6+Ki4tj4qjq+qhOxXPz7bffRpdt375duVwuddFFF0WXVVUdsnz5cgWo119/Pbqs4jU59dRTVTgcjtm+rscYN25czPU4cuRIpWmauvHGG6PLwuGw6tq1a0z11hdffKEA9dZbb8Wca9GiRZWWV1c19vDDD6u4uDi1efPmmOX33HOPMgxD7dixQylVv+d81KhR1V6jh95q836qyplnnqkSExNVQUFBnfcNBAJqwIABqmfPnioUCkWXn3/++QpQHTp0UFdeeaVasGCBuv/++5XNZlMnn3xyzOskmpZUjYkWSynFP//5T8477zyUUuzfvz96GzduHEVFRaxevRoAwzBwOBxApEj/wIEDhMNhhg0bFt3mUJdccgnp6elVnvfGG2+MuX/aaaeRn59PcXHxEWO+/vrrYxpXnnbaaZimyfbt2wFYvHgx4XCYm2++OWa/W2655YjHPtTf/vY30tPTycjIYPjw4dEquaq6ihuGwaWXXsrf//53INJIulu3bpx22mk1nuOf//wnn3zySczt1VdfrVOcDanil31JSUmd9/3ggw/o2LEjV1xxRXSZ3W7n1ltvpbS0lKVLl8ZsX9P1UZWRI0cydOjQ6P3u3btzwQUX8NFHH0WrPw6tIgyFQuTn59OnTx+Sk5OrvEavu+46DMOIWVbXY1xzzTUx1+Pw4cNRSnHNNddElxmGwbBhw/jpp5+iy9577z2SkpI466yzYt53Q4cOJT4+vlKVc1Xee+89TjvtNFJSUmKOceaZZ2KaZqWqw7o8508//XSla7Oq21133VWr4x3qscce49NPP+Xxxx+vV+nnlClT2LBhA3/961+x2Q5WupSWlgJw4okn8uabb3LJJZfw0EMP8fDDD/PVV1+xePHiOp9LNAypGhMt1r59+ygsLOSll17ipZdeqnKbvXv3Rv9/7bXXePrpp9m4cWNMsXnPnj0r7VfVsgrdu3ePuZ+SkgJEqp8SExNrjLmmfYFoQnR4FVZqamp029q44IILmDJlCpqmkZCQwHHHHUdcXFy12//ud7/j2Wef5fvvv+ftt9/m8ssvr7E3DMDpp59e76qBxlDxRZKQkFDnfbdv307fvn0r9fTr379/dP2haro+qtK3b99Ky4455hi8Xi/79u2jY8eO+Hw+Zs2axauvvsquXbti2uQUFRVV2r+qGOp6jMOvx6SkJAC6detWafmhbX+2bNlCUVERGRkZVT7eQ9931dmyZQtr166tNrk5/Bh1ec4PTTob0rvvvssf//hHrrnmGm666aY67//kk08yb948Hn74Yc4+++yYdRVJ7KHJOETem9OnT+err76qdqgL0bgkERItVkWDyquuuooJEyZUuc0JJ5wAwJtvvsnEiRO58MILufPOO8nIyMAwDGbNmsW2bdsq7VdTA97Df4VXUIc1Jm3ofeuia9eudfrQHD58OL1792bq1KlkZ2fzu9/9rkHjaQrr1q0jIyPjiMloQzjaBt5VueWWW3j11VeZOnUqI0eOJCkpCU3TuPzyy2MaD9cUQ12PUd31WNXyQ69Ry7LIyMjgrbfeqnL/2pTcWJbFWWedVW2pzDHHHBNzvy7P+YEDBwgGg0fczu12R5O/I/nkk08YP34855xzDnPnzq11LBXmz5/P3XffzY033sgf//jHSus7d+4MHGxDVaEi2Tw0ERVNSxIh0WKlp6eTkJCAaZpH/NJfsGABvXr14v33348p6WhpY8n06NEDgK1bt8b8As7Pz2/0D8IrrriCRx55hP79+1dqPN7SLV++nG3btnHVVVfVa/8ePXqwdu1aLMuKKRXauHFjdP3R2LJlS6VlmzdvxuPxRJOGBQsWMGHCBJ5++unoNn6/n8LCwlqfpyGOURu9e/fm008/5ZRTTjliglJdyWLv3r0pLS1tlFKOiy++uFJ1ZlUmTJhQq8EeV6xYwUUXXcSwYcP4xz/+EVOlVRv/+c9/uPbaa7n44ot57rnnqtxm6NChzJs3j127dsUs3717N1C75FI0DmkjJFoswzC45JJL+Oc//8m6desqrT+0W3rFL9xDf9WuWLGC5cuXN36gdTBmzBhsNhsvvPBCzPK//vWvjX7ua6+9lpkzZ8Z8ibYG27dvZ+LEiTgcDu688856HePss88mNzc3pvdeOBxmzpw5xMfHM2rUqKOKcfny5TFtdHbu3Ml//vMfxo4dG702DcOoVDI4Z86cOnWhbohj1Mall16KaZo8/PDDldaFw+GYxCsuLq7KROzSSy9l+fLlfPTRR5XWFRYWEg6H6x1fQ7YR+vHHHznnnHPIysriv//9b42J38aNGyuNcv75559z+eWXc/rpp/PWW29VO9DqBRdcgNPp5NVXX40pvXv55ZeByCCponlIiZBodq+88gqLFi2qtPy2227j8ccf57PPPmP48OFcd911DBgwgAMHDrB69Wo+/fTTaBfvc889l/fff5+LLrqIc845h+zsbObOncuAAQOibUtagszMTG677Taefvppzj//fH71q1/x/fff8+GHH5KWlnbEdjtHo0ePHjzwwAO13n7BggVVdj0+66yzKhXvV2f79u288cYbANFpPB555JFoPIdPf7F69WrefPNNLMuisLCQb775hn/+859omsYbb7wRrQqtq+uvv54XX3yRiRMnsmrVKrKysliwYAFffvkls2fPrle7o0MNHDiQcePGxXSfB3jwwQej25x77rm88cYbJCUlMWDAAJYvX86nn35Khw4dan2ehjhGbYwaNYobbriBWbNmsWbNGsaOHYvdbmfLli289957PPPMM/zmN78BIiUdL7zwAo888gh9+vQhIyODM844gzvvvJP/+7//49xzz2XixIkMHTqUsrIyfvjhBxYsWEBOTk6926A1VBuhkpISxo0bR0FBAXfeeScLFy6MWd+7d29GjhwZvd+/f39GjRoVnc5m+/btnH/++Wiaxm9+8xvee++9mP1POOGE6DXbsWNH7rvvPmbMmMGvfvUrLrzwQr7//nvmzZvHFVdcwYknntggj0nUnSRCotkdXjpSYeLEiXTt2pWVK1fy0EMP8f777/P888/ToUMHjjvuuJhxfSZOnEhubi4vvvgiH330EQMGDODNN9/kvffeqzQHV3P705/+hMfjYd68eXz66aeMHDmSjz/+mFNPPRWXy9Xc4UVV11j0s88+q3UilJ2dzf333x+zrOL+qFGjKiVCf//73/n73/+OzWYjMTGRvn37MnXqVG688cZKDX/rwu12s2TJEu655x5ee+01iouL6devH6+++mqDTA0xatQoRo4cyYMPPsiOHTsYMGAA8+fPj0ncnnnmGQzD4K233sLv93PKKafw6aef1mlQy4Y4Rm3NnTuXoUOH8uKLL3Lvvfdis9nIysriqquu4pRTToluN2PGDLZv384TTzxBSUkJo0aN4owzzsDj8bB06VIee+wx3nvvPV5//XUSExM55phjePDBB2vddqcx5efnR6e3uOeeeyqtnzBhQkwidLjs7OxoI/XJkydXWj9z5syYa+CPf/wjKSkpzJkzh6lTp8YkR6L5aKqhW3EKIeqssLCQlJQUHnnkEZmAsZXRNI3Jkyc3SfWmEKLhSRshIZqYz+ertKxilN1DpycQQgjR+KRqTIgm9u677zJ//nzOPvts4uPjWbZsGX//+98ZO3ZsTJVDS7Zv374aG+g6HA6ZMkAI0SpIIiREEzvhhBOw2Ww88cQTFBcXRxtQVzQibg1OPPHESoMQHurQBqVCCNGSSRshIUSdffnll1VW8VVISUlptNF/hRCiIUkiJIQQQoh2SxpLCyGEEKLdkjZCR2BZFrt37yYhIaFRB7sTQgghRMNRSlFSUkLnzp2rHfEbJBE6ot27d1eaqVkIIYQQrcPOnTvp2rVrteslETqCiqH3d+7c2SSzXgshhBDi6BUXF9OtW7cjTqEjidARVFSHJSYmSiIkhBBCtDJHatYijaWFEEII0W5JIiSE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yzlHFfuoUaNU//79lWVZ0WV333236t+/f3T9kCFDYvbx+/3K4/Gor776Kmb5Nddco6644gqllFIlJSXK4XCof/zjH9H1+fn5yu12q9tuuy167Ir/i4uLldPpVPPmzasx1ortGzKOqlx77bVq/PjxMctmzJihRo8eXe0+h9u3b58C1A8//BDzGE499dSY7U488UR19913H1W8jz76qIqLi4vedF1XTqczZtn27duj269du1bFxcUpwzBUUlKSWrhwYczxTj/99OhzWGHy5MlqxIgR1cZwwQUXqKuvvrrS8iNdYxXbHHqdlZaWKrvdrt56663osmAwqDp37qyeeOKJOh+7puf8cNW9boe/D470WtXm+jycaZrqnHPOUaecckp0WW2P8/333ytA5eTkVHlspWr4rFK1//62NW6a1XD279+PaZqVSnQyMzPZuHFjlfv069ePV155hRNOOIGioiKeeuopTj75ZNavX0/Xrl2r3CcQCMRkn1UVlza2eKcNQ490odfMSCzFXUZzZfZanifEz6H9HAgUkupMju5TWnSAjE7dmjxW0c4ESqBk95G3S+pSeZl3f+32DRz9iOkjRoxA0w4OUjpy5EiefvppTNMEqPQrf+vWrXi9Xs4666yY5cFgkCFDhgCwbds2gsEgw4cPj65PTU2lX79+Vcbw448/EggEGDNmTK3jbow4KqxZs4bf/e53Mcu+++47Bg8eXO0+W7ZsYcaMGaxYsYL9+/dHSxR27NjBwIEDo9udcMIJMft16tQp2mShvvHeeOONXHrppdH7V155JZdccgkXX3xxdFnnzp2j//fr1481a9ZQVFTEggULmDBhAkuXLmXAgAHk5eWxbNmySqUWcXFxMdfJ4Xw+X7XtSmu6xgzDAGKvs23bthEKhTjllFOiy+x2OyeddBI//vhjnY9d03Ne29ft8PfBkV6r2lyfh5s8eTLr1q1j2bKDc2bW9jhud2R8Pa/XW+WxG0qrSYTqY+TIkTFFoyeffDL9+/fnxRdfrLZnx6xZs3jwwQebKsQqaZpGksdOcYkLnUgiltTvNHpkv0iW8pGjKZ7/8S3+OHhydB/TX4w/EMDldDZX2KI9cCZAQucjb+dJq3pZbfZ1Nn5j47i4uJj7paWlACxcuJAuXWKTOGc931MVH+J10RhxQKS6aN26dZW+rFavXs0ll1xS7X7nnXcePXr0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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 = 2\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$ (probconserv)\")\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",
    "        \n",
    "        plt.plot(grid, u_proj_reshaped[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (probharde2e)\")\n",
    "        plt.fill_between(grid, u_proj_reshaped[parameters_idx,:,t_idx,0]+3*stds[parameters_idx,:,t_idx,0], u_proj_reshaped[parameters_idx,:,t_idx,0]-3*stds[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        \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": 121,
   "id": "2614e9d3-c4bb-4f3a-8ed6-bb81c2881208",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 2000])"
      ]
     },
     "execution_count": 121,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "var_flat.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "a35cc21f-5ab7-47a0-9460-ac32a0975993",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 122,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "variances.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "id": "6659e913-9ab1-45fd-8c9b-e22aac0f3134",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "u_proj_reshaped.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 124,
   "id": "f53de336-182c-4ed7-9bde-3a493a1f3ddc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Rx99lN9++42OHTtyxx13FFj+dFq0aHFS2++//87o0aPZunUrGRkZOBwO8vLyyMnJISgo6JTbiY6O9gSR4/Ud//w7duwgJyeH6667rsA6NpuNZs2aAbBlyxbatGlT4P3jweV802kaL4vt9yy1f1/Cpqu74jAMACqnOxj21y+MW/sMjfM2ArArOZs7xy/hxV836WJpIlL8/EMhtMp/P4LKn7xuUPnCresfevK6hWSxWE6abWi32wu8/nfQMAwDl8s99i4wMJDi8M99GMd+Zx/fx0MPPcSuXbu477772LBhAy1btuS99977z20GBwcXeL1nzx46d+5MkyZNmDp1KqtWrfL0zpxpgOuZPv/x8SYzZsxg7dq1nsfmzZtPGjfiDUXuGfnzzz954403WLVqFYcOHeKnn36ia9euZ1xnwYIFDBw4kE2bNhEVFcULL7zgGbwjEBYRyp0fjmb1wjvZPWIodQ65x45E73US2uELbjLqMO9ob/JNfz5fvId5W5J49Y7GtK19il8KIiJno22/sz+F8u/TNudBhQoVOHTokOd1RkYGu3fvLvT6TZo0YeLEidjt9pO+tMPCwqhSpQqLFy+mffv2nvbFixfTunXrItUZFRXFI488wiOPPMKzzz7LhAkTePzxx/Hzc1/iwel0/uc2Vq1ahcvlYsyYMVgs7j6D77//vkh1/FuDBg3w9/cnISGhwGf8p5iYmJMG/S5duvSc9ltYRe4Zyc7OJjY2tsA5tDPZvXs3N998M1dffTVr165lwIABPPTQQ8yZM6fIxV7qmrdvwfW//cKBO27GEWiypKnJhso+/FVpN82ih9I84G/AfTfgeyYs47mfNpCVr14SEbn0XXPNNXz11Vf89ddfbNiwgfvvvx+rtfDj6Pr160dGRgbdu3dn5cqVbN++na+++or4+HgAnn76aV577TW+++474uPjGTJkCGvXrqV///6F3seAAQOYM2cOu3fvZvXq1cyfP5+YmBgAatSogWEYTJ8+neTk5AIzY/7tsssuw263895777Fr1y6++uorz8DWsxUaGsqgQYN48sknmThxIjt37mT16tW89957TJzovu7VI488wvbt23n66aeJj49n0qRJfPHFF+e038Iqchi58cYbefnll7ntttsKtfz48eOpWbMmY8aMISYmhn79+nHnnXfy1ltvFbnY0iDA14eOr7yJ7ze/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ZRISEhg4cCDx8fF8++23vPfee/Tv3/+0yz/11FPMmzePkSNHsm3bNiZOnMj777/PoEGDCiy3ePFiXn/9dbZt28a4ceP44YcfPNtt3749V111FXfccQdz58719GDMnj27SPs4k7Fjx/Ltt9+ydetWtm3bxg8//EClSpWIiIigY8eOxMXF0bVrV3777Tf27NnD33//zfPPP8/KlSv/c9s9e/ZkxowZfPbZZxfkwNXjFEbEIyLEn5ve/ZS0R74keN9DOHKiMaz5BFb+nj77xxKV676/zbS1B+n8rq5JIiIlq1evXuTm5tK6dWv69u1L//79PVN4T6V58+Z8//33TJ48mUaNGjFs2DBeeuklevfuXWC5p556ynNH+pdffpmxY8cWuLP81KlTadWqFT169KBBgwYMHjzYMx6ksPs4k9DQUF5//XVatmxJq1at2LNnDzNnzsRisWAYBjNnzuSqq66iT58+1K1bl+7du7N3714iI/97csE111xD2bJliY+P55577il0TSVNs2nklHYkZdLv29Xssv3Mzft/439znOT6wZyWDfioonuOup/VwgudY7jv8ho6bSNyEbiY79rboUMHmjZtqku3X4A0m0bOm8sqhjLtsSvoUft+bljq/gEKtEHXvzfz1ubnKes4is3pYtjPm+g7aTUZeXYvVywiIhcrhRE5rQBfKy/eHot17Iek1TgxUrv+tnzeXfQK12T9BcDMDYl0fneRTtuIiMhZURiR/9SxXSxRk/9kfYfLcfq6z+qVS4MB83/m6QPvgekiITWH2z/4m6+W7i3yVRVFRP7LggULdIrmEqYwIoVSrUwQt4/7lJX9h5Ff1j0+xNcJ16zYy/sbnqOiPQWb08XQaRvpP3kt2ZptIyIihaQwIoXma7XQ+6F7SPvgVw7VLe9pr73Lwdt/vcp1GQsA+GXdQW4dt5jthzO9VKmIiFxMFEakyDo0rU3MV7+x/Pprcfq5T8mUyYDHF07nlv3TwDTZkZTFLe8vZtqaA94tVkRELngKI3JWKocH0vOtd1k+8GXyyp04bfPoykU8v34MQfYccu1OBny3lmE/b8TmcP3HFkVEpLRSGJGz5mO18EDvOzk6bgbT613pab9idyLvLxrJFVnuSyx/uWQv3T5ewqH0XG+VKiIiFzCFETln1zStSffP32biTY+RdexmUJXT7Ty9YAr9Dk8AYE1CGp3fXcTfO1O8WaqIiFyAFEakWESVDeLF1x9j3oC32F+mDAB+DtgeuZ3byo3BDxtHsm3c+8kyPlq4U9N/ReSCEB0d/Z9Thg3DYNq0aSVSz549ezAMg7Vr15bI/i4UCiNSbPx9rAx58Fry3vqCw7UjWN/Mwd8xFn6vmMzV1UYQaRzCZcLoWVvp9+0acmya/isicq5Gjx5Nq1atCA0NpWLFinTt2pX4+Hhvl1UkCiNS7LpcXpdKn85hV6O7GHAkA6tp8neoi8haY+lomwfAjPWHuG3c3+xJyfZytSJyKbLZbN4u4YyKs76FCxfSt29fli5dyty5c7Hb7Vx//fVkZ188v18VRuS8qF8pjL5PvciB0FcZddBGOYeT6lsN+s+exaCD7qu2xh/O5Jb3FzF/a5K3yxWRC1yHDh3o168f/fr1Izw8nPLlyzN06FDPKd/o6GhGjhxJr169CAsL89zNd+rUqTRs2BB/f3+io6MZM2bMSdvOzMykR48eBAcHU7VqVcaNG3fSMikpKdx2220EBQVRp04dfvnlF897TqeTBx98kJo1axIYGEi9evV45513Cqzfu3dvunbtyiuvvEKVKlWoV68eAMuXL6dZs2YEBATQsmVL1qxZc9K+N27cyI033khISAiRkZHcd999pKScGH83e/ZsevfuTcOGDYmNjeWLL74gISGBVatWeZZJS0vjoYceokKFCoSFhXHNNdewbt26ovwTnFcKI3LehAX48sKD3TnU6lue2RjK/8124uOCa5fv5VHHq/hiJyPPwQMTV/DBgh0aRyIiZzRx4kR8fHxYvnw577zzDmPHjuWTTz7xvP/mm28SGxvLmjVrGDp0KKtWreLuu++me/fubNiwgREjRjB06FC++OKLAtt94403POsNGTKE/v37M3fu3ALLvPjii9x9992sX7+em266iZ49e5KamgqAy+WiWrVq/PDDD2zevJlhw4bx3HPP8f333xfYxrx584iPj2fu3LlMnz6drKwsOnfuTIMGDVi1ahUjRoxg0KBBBdZJS0vjmmuuoVmzZqxcuZLZs2dz+PBh7r777tMep/R0933CypYt62m76667SEpKYtasWaxatYrmzZtz7bXXej6DtxnmRfANUNhbEMuF689NB8h//h6qbU1idnODzzpZMdOakpV4J5g+AHRuUpk37owl0M/q5WpFLk1nutX7kc+/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SR/ri2IAq4iIiFy6SnXPiIiIiHifwoiIiIh4lcKIiIiIeJXCiIiIiHhVqQ4j48aNIzo6moCAANq0acPy5cu9XdJFb/To0bRq1YrQ0FAqVqxI165diY+PL7BMXl4effv2pVy5coSEhHDHHXdw+PBhL1V8aXj11VcxDIMBAwZ42nSci9eBAwe49957KVeuHIGBgTRu3JiVK1d63jdNk2HDhlG5cmUCAwPp2LEj27dv92LFFyen08nQoUOpWbMmgYGB1K5dm5EjRxa4t4mO9dn5888/6dKlC1WqVMEwDKZNm1bg/cIc19TUVHr27ElYWBgRERE8+OCDZGVlnXtxZik1efJk08/Pz/zss8/MTZs2mQ8//LAZERFhHj582NulXdQ6depkfv755+bGjRvNtWvXmjfddJNZvXp1Mysry7PMI488YkZFRZnz5s0zV65caV5++eVm27ZtvVj1xW358uVmdHS02aRJE7N///6edh3n4pOammrWqFHD7N27t7ls2TJz165d5pw5c8wdO3Z4lnn11VfN8PBwc9q0aea6devMW265xaxZs6aZm5vrxcovPq+88opZrlw5c/r06ebu3bvNH374wQwJCTHfeecdzzI61mdn5syZ5vPPP2/++OOPJmD+9NNPBd4vzHG94YYbzNjYWHPp0qXmX3/9ZV522WVmjx49zrm2UhtGWrdubfbt29fz2ul0mlWqVDFHjx7txaouPUlJSSZgLly40DRN00xLSzN9fX3NH374wbPMli1bTMBcsmSJt8q8aGVmZpp16tQx586da7Zv394TRnSci9czzzxjXnHFFad93+VymZUqVTLfeOMNT1taWprp7+9vfvvttyVR4iXj5ptvNh944IECbbfffrvZs2dP0zR1rIvLv8NIYY7r5s2bTcBcsWKFZ5lZs2aZhmGYBw4cOKd6SuVpGpvNxqpVq+jYsaOnzWKx0LFjR5YsWeLFyi496enpAJQtWxaAVatWYbfbCxz7+vXrU716dR37s9C3b19uvvnmAscTdJyL2y+//ELLli256667qFixIs2aNWPChAme93fv3k1iYmKB4x0eHk6bNm10vIuobdu2zJs3j23btgGwbt06Fi1axI033gjoWJ8vhTmuS5YsISIigpYtW3qW6dixIxaLhWXLlp3T/i+KG+UVt5SUFJxOJ5GRkQXaIyMj2bp1q5equvS4XC4GDBhAu3btaNSoEQCJiYn4+fkRERFRYNnIyEgSExO9UOXFa/LkyaxevZoVK1ac9J6Oc/HatWsXH374IQMHDuS5555jxYoVPPHEE/j5+XH//fd7jumpfqfoeBfNkCFDyMjIoH79+litVpxOJ6+88go9e/YE0LE+TwpzXBMTE6lYsWKB9318fChbtuw5H/tSGUakZPTt25eNGzeyaNEib5dyydm3bx/9+/dn7ty5BAQEeLucS57L5aJly5aMGjUKgGbNmrFx40bGjx/P/fff7+XqLi3ff/8933zzDZMmTaJhw4asXbuWAQMGUKVKFR3rS1ipPE1Tvnx5rFbrSTMLDh8+TKVKlbxU1aWlX79+TJ8+nfnz51OtWjVPe6VKlbDZbKSlpRVYXse+aFatWkVSUhLNmzfHx8cHHx8fFi5cyLvvvouPjw+RkZE6zsWocuXKNGjQoEBbTEwMCQkJAJ5jqt8p5+7pp59myJAhdO/encaNG3Pffffx5JNPMnr0aEDH+nwpzHGtVKkSSUlJBd53OBykpqae87EvlWHEz8+PFi1aMG/ePE+by+Vi3rx5xMXFebGyi59pmvTr14+ffvqJP/74g5o1axZ4v0WLFvj6+hY49vHx8SQkJOjYF8G1117Lhg0bWLt2refRsmVLevbs6Xmu41x82rVrd9IU9W3btlGjRg0AatasSaVKlQoc74yMDJYtW6bjXUQ5OTlYLAW/mqxWKy6XC9CxPl8Kc1zj4uJIS0tj1apVnmX++OMPXC4Xbdq0ObcCzmn460Vs8uTJpr+/v/nFF1+YmzdvNv/3v/+ZERERZmJiordLu6g9+uijZnh4uLlgwQLz0KFDnkdOTo5nmUceecSsXr26+ccff5grV6404+LizLi4OC9WfWn452wa09RxLk7Lly83fXx8zFdeecXcvn27+c0335hBQUHm119/7Vnm1VdfNSMiIsyff/7ZXL9+vXnrrbdquulZuP/++82qVat6pvb++OOPZvny5c3Bgwd7ltGxPjuZmZnmmjVrzDVr1piAOXbsWHPNmjXm3r17TdMs3HG94YYbzGbNmpnLli0zFy1aZNapU0dTe8/Ve++9Z1avXt308/MzW7dubS5dutTbJV30gFM+Pv/8c88yubm55mOPPWaWKVPGDAoKMm+77Tbz0KFD3iv6EvHvMKLjXLx+/fVXs1GjRqa/v79Zv3598+OPPy7wvsvlMocOHWpGRkaa/v7+5rXXXmvGx8d7qdqLV0ZGhtm/f3+zevXqZkBAgFmrVi3z+eefN/Pz8z3L6Fifnfnz55/y9/P9999vmmbhjuuRI0fMHj16mCEhIWZYWJjZp08fMzMz85xrM0zzH5e1ExERESlhpXLMiIiIiFw4FEZERETEqxRGRERExKsURkRERMSrFEZERETEqxRGRERExKsURkRERMSrFEZERETEqxRGRERExKsURkRERMSrFEZERETEqxRGRERExKv+H+gsTAgv9uhdAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 10\n",
    "plt.plot(y_train[0,:,t_idx,0],lw=4,label=\"true solution\")\n",
    "plt.plot(mu[0,:,t_idx,0].cpu().detach(),'--',lw=2,label=\"unconstrained\")\n",
    "plt.plot(new_mu[0,:,t_idx,0].cpu().detach(),label=\"probconserv\")\n",
    "plt.plot(u_proj_reshaped[0,:,t_idx,0].cpu().detach(),'-.',lw=2,label=\"probharde2e\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "93b5f5a1-f5a7-4b0c-9b69-f963d3756103",
   "metadata": {},
   "outputs": [],
   "source": [
    "# t_idx = 2\n",
    "# plt.plot(y_train[0,:,t_idx,0],lw=4,label=\"true solution\")\n",
    "# plt.plot(mu[0,:,t_idx,0].cpu().detach(),'--',lw=2,label=\"unconstrained\")\n",
    "# plt.plot(new_mu[0,:,t_idx,0].cpu().detach(),label=\"probconserv\")\n",
    "# plt.plot(new_u_proj_reshaped[0,:,t_idx,0].cpu().detach(),'-.',lw=2,label=\"probharde2e\")\n",
    "# plt.legend()\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "e995547a-8fdd-4a15-9096-fdd970b9b220",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.7936, device='cuda:0', grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 126,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(new_u_proj - u_proj)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16a81126-a48a-4424-8290-6a9cd29b85f6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "b5f2258f-3c7f-4302-b420-fca2acb5541a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# --- Constraint function ---\n",
    "def h(u):\n",
    "    return u[0]**2 + u[1]**2 - 1.0\n",
    "\n",
    "# Check backprop\n",
    "xi_batch = torch.tensor([[2.0, 1.0],\n",
    "                         [0.1, 0.1],\n",
    "                         [-1.5, -0.5]], dtype=torch.float32, device=device)\n",
    "xi_leaf = xi_batch.clone().detach().requires_grad_(True)\n",
    "\n",
    "u_projected = fast_project_batched(mu_flat, h)\n",
    "u_proj = fast_project_weighted(mu_flat, var_flat, h_func=h)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "321130f8-924f-4198-8715-49e8f4797d4b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0480, grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 128,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(utils.compute_sampling_crps_by_example(mu, var, y,nbins=500))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 129,
   "id": "6df72eff-6964-4de7-9326-6b9458282089",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0474, grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 129,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(utils.compute_sampling_crps_by_example(new_mu, new_std.square(), y,nbins=500))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "260d83c1-f32c-4693-8694-35b22ab1e6a4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0429, grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 130,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(utils.compute_sampling_crps_by_example(u_proj_reshaped, variances.cpu(), y,nbins=500))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 131,
   "id": "0a2ba91c-01a6-4903-8b3d-89cd9dc39757",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0505, 0.1010, 0.1515, 0.2020, 0.2525, 0.3030, 0.3535, 0.4040,\n",
       "        0.4545, 0.5051, 0.5556, 0.6061, 0.6566, 0.7071, 0.7576, 0.8081, 0.8586,\n",
       "        0.9091, 0.9596], device='cuda:0')"
      ]
     },
     "execution_count": 131,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t_grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 132,
   "id": "633aa3b5-ea6a-4acf-9b78-63adc39d6418",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.6847, grad_fn=<LinalgVectorNormBackward0>)"
      ]
     },
     "execution_count": 132,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(mu-u_proj_reshaped)"
   ]
  },
  {
   "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": null,
   "id": "f3f1485f-07fb-4039-a0c4-d0480edbd8bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.loss_func(out, y.to(device))/len(out[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f826c2e-eee5-4b4a-abc0-daf2e505aa50",
   "metadata": {},
   "outputs": [],
   "source": [
    "out[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dd27a2af-c705-4621-b36b-614bf61fc40c",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "id": "400f807a-3676-42a2-82fd-f0ee6999c64e",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.mean(crps_by_sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "913e8446-4753-427f-8d64-d69dbed2b866",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "id": "64b75faa-0ce0-47f9-ae71-2aae64386daf",
   "metadata": {},
   "outputs": [],
   "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": null,
   "id": "fbeef4c3-208f-490b-9f76-24ba47485adc",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "id": "bbc1aeab-f5a3-45e5-8f17-c47458e866f2",
   "metadata": {},
   "outputs": [],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "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": null,
   "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": null,
   "id": "39e9bde3-2eba-4801-aa30-88c2c043ec20",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2384c2df-e413-4a42-8107-977afa42306e",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "id": "6b809290-3cb4-4d19-a03a-ed6435a705a7",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "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": null,
   "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": null,
   "id": "da438412-1398-430d-ba74-82db34174f39",
   "metadata": {},
   "outputs": [],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09f0df61-ed39-4fe8-8463-87a363b11ef6",
   "metadata": {},
   "source": [
    "## E2E Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "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": 24,
   "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": 25,
   "id": "95fa4119-7947-412c-9c9b-e79e9d97f6b1",
   "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": 26,
   "id": "e13b2903-c201-478d-b374-b1b80f813d72",
   "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)\n",
    "    model = ProbHardE2ETVD(base_model_class=FNO2d, probconserv=False, base_model_params=FNO2d_params, constraint_context=constraint_context, noneq_constraint_e2e=True)\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": 27,
   "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": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "11c859b7-92f8-4125-b562-fad7c2a4683c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d1e8d19-c876-4e02-a95c-36987cb27c62",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=-69.273093, Validation loss=-2217.779004 (saved)\n",
      "Epoch 1: Train loss=-684.839154, Validation loss=-2996.319922 (saved)\n",
      "Epoch 2: Train loss=-1798.807056, Validation loss=-4728.829297 (saved)\n",
      "Epoch 3: Train loss=-5285.613232, Validation loss=-4754.669922 (saved)\n",
      "Epoch 4: Train loss=-7585.868994, Validation loss=-10096.897656 (saved)\n",
      "Epoch 5: Train loss=-9156.845605, Validation loss=-11297.518750 (saved)\n",
      "Epoch 6: Train loss=-11099.082129, Validation loss=-7792.713672 \n",
      "Epoch 7: Train loss=-7375.553955, Validation loss=-10439.826563 \n",
      "Epoch 8: Train loss=-8573.159766, Validation loss=-10001.512891 \n",
      "Epoch 9: Train loss=-9078.737012, Validation loss=-10917.153906 \n",
      "Epoch 10: Train loss=-10551.385937, Validation loss=-12793.732031 (saved)\n",
      "Epoch 11: Train loss=-13072.434961, Validation loss=-13787.797656 (saved)\n",
      "Epoch 12: Train loss=-15568.326758, Validation loss=-15325.767969 (saved)\n",
      "Epoch 13: Train loss=-9543.878076, Validation loss=-13694.511719 \n",
      "Epoch 14: Train loss=-12197.558008, Validation loss=-11938.094531 \n",
      "Epoch 15: Train loss=-11034.854883, Validation loss=-12430.418359 \n",
      "Epoch 16: Train loss=-12248.887598, Validation loss=-13955.295313 \n",
      "Epoch 17: Train loss=-14870.518359, Validation loss=-15369.721094 (saved)\n",
      "Epoch 18: Train loss=-17994.903320, Validation loss=-16655.595313 (saved)\n",
      "Epoch 19: Train loss=-21727.101562, Validation loss=-17602.966406 (saved)\n",
      "Updating Sigma now\n",
      "Epoch 20: Train loss=-18111.901562, Validation loss=-18628.752344 (saved)\n",
      "Epoch 21: Train loss=-18856.599414, Validation loss=-19068.272656 (saved)\n",
      "Epoch 22: Train loss=-19011.125195, Validation loss=-19556.316406 (saved)\n",
      "Epoch 23: Train loss=-19666.690820, Validation loss=-19855.829688 (saved)\n",
      "Epoch 24: Train loss=-19868.789648, Validation loss=-16524.532813 \n",
      "Epoch 25: Train loss=-18332.812695, Validation loss=-19119.762500 \n",
      "Epoch 26: Train loss=-19167.464062, Validation loss=-19086.329688 \n",
      "Epoch 27: Train loss=-19265.562500, Validation loss=-19501.635937 \n",
      "Epoch 28: Train loss=-19723.049219, Validation loss=-20040.185937 (saved)\n",
      "Epoch 29: Train loss=-20300.051953, Validation loss=-20677.894531 (saved)\n",
      "Epoch 30: Train loss=-20656.697070, Validation loss=15812.103125 \n",
      "Epoch 31: Train loss=2865.733807, Validation loss=-14455.432031 \n",
      "Epoch 32: Train loss=-12889.489258, Validation loss=-11491.491016 \n",
      "Epoch 33: Train loss=-11325.360059, Validation loss=-11454.142187 \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": null,
   "id": "fea6bf3c-dd2f-4877-b902-345a59828a3f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#torch.save(model.state_dict(), \"./pme_e2e_var_update_crps_04_29.pt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "221859cb-662e-4e38-ad03-cd466b1c3e74",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.load_state_dict(torch.load(\"./pme_e2e_var_update_nll_04_29.pt\", weights_only=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "e82f2228-6888-4796-8b40-f13e419d3ff7",
   "metadata": {},
   "outputs": [],
   "source": [
    "from nonlinear_projection import project_and_stats\n",
    "\n",
    "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",
    "            nf,nx,nt,_ = _mu.shape\n",
    "\n",
    "            _mu = _mu.view(nf, -1)\n",
    "            _var = _var.view(nf, -1)\n",
    "            _m = x.view(nf, -1)\n",
    "\n",
    "            if model.noneq_constraint_e2e:\n",
    "                u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "                out = (u_proj.view(nf,nx,nt,1), u_var.view(nf,nx,nt,1))\n",
    "\n",
    "\n",
    "            # out = model.base_model._apply_constraints(_mu, _std, x, t, tpred, grid, dataset_class)\n",
    "\n",
    "\n",
    "            # nf,nx,nt,_ = _mu.shape\n",
    "\n",
    "            # _mu = _mu.view(nf, -1)\n",
    "            # _var = _var.view(nf, -1)\n",
    "            # _m = x.view(nf, -1)\n",
    "\n",
    "            # # print(_m)\n",
    "\n",
    "            # u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "\n",
    "            # # print(u_proj, u_var)\n",
    "\n",
    "            # if  u_proj.isnan().any().item() or  u_var.isnan().any().item():\n",
    "            #     print(\"any NaN in new_mu?\", u_proj.isnan().any().item())\n",
    "            #     # print(\"min new_var before clamp:\", u_var.min().item())\n",
    "            #     print(\"any NaN in new_var before clamp?\", u_var.isnan().any().item())\n",
    "            #     # new_var = new_var.clamp(min=eps)\n",
    "            #     # print(\"min new_var after clamp:\", new_var.min().item())\n",
    "\n",
    "            # out = (u_proj.view(nf,nx,nt,1), u_var.view(nf,nx,nt,1))\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": 152,
   "id": "4f58dc93-0b91-4195-b51e-126ad1212b6f",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "Expected value argument (Tensor of shape (20, 100, 20, 1)) to be within the support (Real()) of the distribution Normal(loc: torch.Size([20, 100, 20, 1]), scale: torch.Size([20, 100, 20, 1])), but found invalid values:\ntensor([[[[-1.9063e-02],\n          [ 2.5312e+00],\n          [-1.5962e-02],\n          ...,\n          [ 2.1601e-02],\n          [ 2.5827e-02],\n          [ 5.4881e-02]],\n\n         [[-3.6012e-02],\n          [ 1.6799e+00],\n          [ 1.0673e+02],\n          ...,\n          [ 2.7738e-01],\n          [ 2.2492e+00],\n          [ 8.5078e+00]],\n\n         [[-3.5813e-02],\n          [ 1.1779e+01],\n          [ 1.5620e-01],\n          ...,\n          [ 5.1473e+00],\n          [ 5.7365e+00],\n          [ 8.6592e+00]],\n\n         ...,\n\n         [[-1.1472e-01],\n          [ 0.0000e+00],\n          [-1.6456e-03],\n          ...,\n          [-2.6066e+00],\n          [ 0.0000e+00],\n          [-3.3810e+00]],\n\n         [[-1.0095e+00],\n          [ 0.0000e+00],\n          [-1.6456e-03],\n          ...,\n          [-3.4304e+00],\n          [-1.0940e+00],\n          [-1.9190e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-5.8157e-04],\n          ...,\n          [-1.2633e-02],\n          [-3.8933e-03],\n          [-3.6999e-03]]],\n\n\n        [[[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         ...,\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]]],\n\n\n        [[[-1.2025e-02],\n          [ 4.4231e-02],\n          [-1.9963e+01],\n          ...,\n          [ 1.5018e-02],\n          [ 1.7150e-02],\n          [ 2.8994e-02]],\n\n         [[-2.3678e-02],\n          [ 1.2814e+00],\n          [-1.0826e+01],\n          ...,\n          [ 1.6522e-01],\n          [ 2.5032e+00],\n          [ 6.0131e+00]],\n\n         [[-2.3668e-02],\n          [ 6.1652e+00],\n          [ 1.8206e-01],\n          ...,\n          [ 4.1572e+00],\n          [ 4.5294e+00],\n          [ 6.1085e+00]],\n\n         ...,\n\n         [[-4.2063e-02],\n          [ 0.0000e+00],\n          [-1.0457e-03],\n          ...,\n          [-1.4949e+00],\n          [ 0.0000e+00],\n          [-2.4839e+00]],\n\n         [[-1.1203e-01],\n          [ 0.0000e+00],\n          [-2.1145e-03],\n          ...,\n          [-2.7186e+00],\n          [-6.6573e-01],\n          [-1.4052e+00]],\n\n         [[-7.4362e-02],\n          [ 0.0000e+00],\n          [-3.6970e-04],\n          ...,\n          [-8.1338e-03],\n          [-2.9107e-03],\n          [-2.5092e-03]]],\n\n\n        ...,\n\n\n        [[[-2.1765e-02],\n          [ 5.7141e-02],\n          [-2.7621e+00],\n          ...,\n          [ 2.7834e-02],\n          [ 3.4340e-02],\n          [ 8.5746e-02]],\n\n         [[-4.3643e-02],\n          [ 1.7146e+00],\n          [ 1.6556e+02],\n          ...,\n          [ 3.3337e-01],\n          [ 2.0847e+00],\n          [ 1.0720e+01]],\n\n         [[-4.3664e-02],\n          [ 1.7825e+01],\n          [ 1.2556e-01],\n          ...,\n          [ 5.8273e+00],\n          [ 6.5869e+00],\n          [ 1.0918e+01]],\n\n         ...,\n\n         [[-4.5178e-02],\n          [ 0.0000e+00],\n          [-2.2192e-03],\n          ...,\n          [-3.6491e+00],\n          [ 0.0000e+00],\n          [-4.1297e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-2.2192e-03],\n          ...,\n          [-4.0571e+00],\n          [-1.4771e+00],\n          [-2.3489e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-7.8150e-04],\n          ...,\n          [-1.7614e-02],\n          [-4.7509e-03],\n          [-4.7532e-03]]],\n\n\n        [[[-1.2970e-02],\n          [-4.4244e-02],\n          [ 2.7055e+01],\n          ...,\n          [ 1.6221e-02],\n          [ 1.8515e-02],\n          [ 3.2533e-02]],\n\n         [[-2.6013e-02],\n          [ 1.3724e+00],\n          [-2.5262e+00],\n          ...,\n          [ 1.8414e-01],\n          [ 2.4162e+00],\n          [ 6.4194e+00]],\n\n         [[-2.5922e-02],\n          [ 6.9871e+00],\n          [ 1.7407e-01],\n          ...,\n          [ 4.3404e+00],\n          [ 4.7479e+00],\n          [ 6.5243e+00]],\n\n         ...,\n\n         [[-2.1903e-02],\n          [ 0.0000e+00],\n          [-1.1497e-03],\n          ...,\n          [-1.6683e+00],\n          [ 0.0000e+00],\n          [-2.6354e+00]],\n\n         [[-1.1158e-02],\n          [ 0.0000e+00],\n          [-1.9534e-03],\n          ...,\n          [-2.8376e+00],\n          [-7.3277e-01],\n          [-1.4908e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-4.0647e-04],\n          ...,\n          [-8.7606e-03],\n          [-3.0558e-03],\n          [-2.7018e-03]]],\n\n\n        [[[-1.4288e-02],\n          [-4.1589e-01],\n          [-8.0453e+00],\n          ...,\n          [ 1.8329e-02],\n          [ 2.0516e-02],\n          [ 3.9538e-02]],\n\n         [[-2.9873e-02],\n          [ 1.1594e+00],\n          [ 3.6617e+00],\n          ...,\n          [ 2.0551e-01],\n          [ 2.2668e+00],\n          [ 7.1337e+00]],\n\n         [[-2.9815e-02],\n          [ 8.5222e+00],\n          [ 1.5698e-01],\n          ...,\n          [ 4.6397e+00],\n          [ 5.1101e+00],\n          [ 7.2549e+00]],\n\n         ...,\n\n         [[-4.5160e-02],\n          [ 0.0000e+00],\n          [-1.3383e-03],\n          ...,\n          [-1.9821e+00],\n          [ 0.0000e+00],\n          [-2.8963e+00]],\n\n         [[-2.1864e-01],\n          [ 0.0000e+00],\n          [-1.7096e-03],\n          ...,\n          [-3.0429e+00],\n          [-8.5441e-01],\n          [-1.6397e+00]],\n\n         [[-7.4439e+00],\n          [ 0.0000e+00],\n          [-4.7309e-04],\n          ...,\n          [-9.9698e-03],\n          [-3.3398e-03],\n          [-3.0210e-03]]]], device='cuda:0')",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[152], line 4\u001b[0m\n\u001b[1;32m      1\u001b[0m is_probconserv \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[1;32m      3\u001b[0m train_loader_no_shuffle \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mutils\u001b[38;5;241m.\u001b[39mdata\u001b[38;5;241m.\u001b[39mDataLoader(train_loader\u001b[38;5;241m.\u001b[39mdataset, batch_size\u001b[38;5;241m=\u001b[39mbatch_size, shuffle\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n\u001b[0;32m----> 4\u001b[0m train_results \u001b[38;5;241m=\u001b[39m \u001b[43mtest\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmodel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtrain_loader_no_shuffle\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtest_type\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mtrain\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m      5\u001b[0m id_results \u001b[38;5;241m=\u001b[39m test(model, id_test_loader, test_type\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mid\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m is_train:\n",
      "Cell \u001b[0;32mIn[151], line 74\u001b[0m, in \u001b[0;36mtest\u001b[0;34m(model, test_loader, **test_params)\u001b[0m\n\u001b[1;32m     33\u001b[0m \u001b[38;5;66;03m# out = model.base_model._apply_constraints(_mu, _std, x, t, tpred, grid, dataset_class)\u001b[39;00m\n\u001b[1;32m     34\u001b[0m \n\u001b[1;32m     35\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     70\u001b[0m \u001b[38;5;66;03m#                                                     )\u001b[39;00m\n\u001b[1;32m     71\u001b[0m \u001b[38;5;66;03m#     out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\u001b[39;00m\n\u001b[1;32m     73\u001b[0m results[\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mloss\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m model\u001b[38;5;241m.\u001b[39mloss_func(out, y)\u001b[38;5;241m.\u001b[39mitem()\n\u001b[0;32m---> 74\u001b[0m \u001b[43mutils\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcompute_all_metrics\u001b[49m\u001b[43m(\u001b[49m\u001b[43mout\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mresults\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     76\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m uq:\n\u001b[1;32m     77\u001b[0m     mu\u001b[38;5;241m.\u001b[39mappend(out[\u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mcpu())\n",
      "File \u001b[0;32m~/e2e-hardconstraints/utils.py:295\u001b[0m, in \u001b[0;36mcompute_all_metrics\u001b[0;34m(out, y, results, metrics)\u001b[0m\n\u001b[1;32m    293\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m metric \u001b[38;5;129;01min\u001b[39;00m metrics:\n\u001b[1;32m    294\u001b[0m     metric_fn \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mglobals\u001b[39m()[\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcompute_\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mmetric\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m_by_example\u001b[39m\u001b[38;5;124m\"\u001b[39m]\n\u001b[0;32m--> 295\u001b[0m     results_[\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mmetric\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m_by_example\u001b[39m\u001b[38;5;124m\"\u001b[39m] \u001b[38;5;241m=\u001b[39m \u001b[43mmetric_fn\u001b[49m\u001b[43m(\u001b[49m\u001b[43mmu\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mvar\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241m.\u001b[39mdetach()\u001b[38;5;241m.\u001b[39mcpu()\n\u001b[1;32m    296\u001b[0m     results_[metric] \u001b[38;5;241m=\u001b[39m results_[\u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;132;01m{\u001b[39;00mmetric\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m_by_example\u001b[39m\u001b[38;5;124m\"\u001b[39m]\u001b[38;5;241m.\u001b[39msum()\u001b[38;5;241m.\u001b[39mitem()\n\u001b[1;32m    298\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m key \u001b[38;5;129;01min\u001b[39;00m results_\u001b[38;5;241m.\u001b[39mkeys():\n",
      "File \u001b[0;32m~/e2e-hardconstraints/utils.py:222\u001b[0m, in \u001b[0;36mcompute_crps_by_example\u001b[0;34m(mu, var, y)\u001b[0m\n\u001b[1;32m    220\u001b[0m dist \u001b[38;5;241m=\u001b[39m Normal(torch\u001b[38;5;241m.\u001b[39mzeros_like(mu), torch\u001b[38;5;241m.\u001b[39mones_like(sigma))\n\u001b[1;32m    221\u001b[0m z \u001b[38;5;241m=\u001b[39m (y \u001b[38;5;241m-\u001b[39m mu) \u001b[38;5;241m/\u001b[39m sigma  \u001b[38;5;66;03m# Standardized value\u001b[39;00m\n\u001b[0;32m--> 222\u001b[0m cdf_z \u001b[38;5;241m=\u001b[39m \u001b[43mdist\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcdf\u001b[49m\u001b[43m(\u001b[49m\u001b[43mz\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    223\u001b[0m pdf_z \u001b[38;5;241m=\u001b[39m dist\u001b[38;5;241m.\u001b[39mlog_prob(z)\u001b[38;5;241m.\u001b[39mexp()\n\u001b[1;32m    225\u001b[0m \u001b[38;5;66;03m# Compute the CRPS\u001b[39;00m\n",
      "File \u001b[0;32m~/anaconda3/envs/optprobconserv2/lib/python3.9/site-packages/torch/distributions/normal.py:96\u001b[0m, in \u001b[0;36mNormal.cdf\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m     94\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcdf\u001b[39m(\u001b[38;5;28mself\u001b[39m, value):\n\u001b[1;32m     95\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_validate_args:\n\u001b[0;32m---> 96\u001b[0m         \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_validate_sample\u001b[49m\u001b[43m(\u001b[49m\u001b[43mvalue\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     97\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;241m0.5\u001b[39m \u001b[38;5;241m*\u001b[39m (\n\u001b[1;32m     98\u001b[0m         \u001b[38;5;241m1\u001b[39m \u001b[38;5;241m+\u001b[39m torch\u001b[38;5;241m.\u001b[39merf((value \u001b[38;5;241m-\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mloc) \u001b[38;5;241m*\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mscale\u001b[38;5;241m.\u001b[39mreciprocal() \u001b[38;5;241m/\u001b[39m math\u001b[38;5;241m.\u001b[39msqrt(\u001b[38;5;241m2\u001b[39m))\n\u001b[1;32m     99\u001b[0m     )\n",
      "File \u001b[0;32m~/anaconda3/envs/optprobconserv2/lib/python3.9/site-packages/torch/distributions/distribution.py:316\u001b[0m, in \u001b[0;36mDistribution._validate_sample\u001b[0;34m(self, value)\u001b[0m\n\u001b[1;32m    314\u001b[0m valid \u001b[38;5;241m=\u001b[39m support\u001b[38;5;241m.\u001b[39mcheck(value)\n\u001b[1;32m    315\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m valid\u001b[38;5;241m.\u001b[39mall():\n\u001b[0;32m--> 316\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\n\u001b[1;32m    317\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mExpected value argument \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    318\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m(\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mtype\u001b[39m(value)\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m of shape \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mtuple\u001b[39m(value\u001b[38;5;241m.\u001b[39mshape)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    319\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mto be within the support (\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mrepr\u001b[39m(support)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m) \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    320\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mof the distribution \u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mrepr\u001b[39m(\u001b[38;5;28mself\u001b[39m)\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m, \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    321\u001b[0m         \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mbut found invalid values:\u001b[39m\u001b[38;5;130;01m\\n\u001b[39;00m\u001b[38;5;132;01m{\u001b[39;00mvalue\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    322\u001b[0m     )\n",
      "\u001b[0;31mValueError\u001b[0m: Expected value argument (Tensor of shape (20, 100, 20, 1)) to be within the support (Real()) of the distribution Normal(loc: torch.Size([20, 100, 20, 1]), scale: torch.Size([20, 100, 20, 1])), but found invalid values:\ntensor([[[[-1.9063e-02],\n          [ 2.5312e+00],\n          [-1.5962e-02],\n          ...,\n          [ 2.1601e-02],\n          [ 2.5827e-02],\n          [ 5.4881e-02]],\n\n         [[-3.6012e-02],\n          [ 1.6799e+00],\n          [ 1.0673e+02],\n          ...,\n          [ 2.7738e-01],\n          [ 2.2492e+00],\n          [ 8.5078e+00]],\n\n         [[-3.5813e-02],\n          [ 1.1779e+01],\n          [ 1.5620e-01],\n          ...,\n          [ 5.1473e+00],\n          [ 5.7365e+00],\n          [ 8.6592e+00]],\n\n         ...,\n\n         [[-1.1472e-01],\n          [ 0.0000e+00],\n          [-1.6456e-03],\n          ...,\n          [-2.6066e+00],\n          [ 0.0000e+00],\n          [-3.3810e+00]],\n\n         [[-1.0095e+00],\n          [ 0.0000e+00],\n          [-1.6456e-03],\n          ...,\n          [-3.4304e+00],\n          [-1.0940e+00],\n          [-1.9190e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-5.8157e-04],\n          ...,\n          [-1.2633e-02],\n          [-3.8933e-03],\n          [-3.6999e-03]]],\n\n\n        [[[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         ...,\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]],\n\n         [[        nan],\n          [        nan],\n          [        nan],\n          ...,\n          [        nan],\n          [        nan],\n          [        nan]]],\n\n\n        [[[-1.2025e-02],\n          [ 4.4231e-02],\n          [-1.9963e+01],\n          ...,\n          [ 1.5018e-02],\n          [ 1.7150e-02],\n          [ 2.8994e-02]],\n\n         [[-2.3678e-02],\n          [ 1.2814e+00],\n          [-1.0826e+01],\n          ...,\n          [ 1.6522e-01],\n          [ 2.5032e+00],\n          [ 6.0131e+00]],\n\n         [[-2.3668e-02],\n          [ 6.1652e+00],\n          [ 1.8206e-01],\n          ...,\n          [ 4.1572e+00],\n          [ 4.5294e+00],\n          [ 6.1085e+00]],\n\n         ...,\n\n         [[-4.2063e-02],\n          [ 0.0000e+00],\n          [-1.0457e-03],\n          ...,\n          [-1.4949e+00],\n          [ 0.0000e+00],\n          [-2.4839e+00]],\n\n         [[-1.1203e-01],\n          [ 0.0000e+00],\n          [-2.1145e-03],\n          ...,\n          [-2.7186e+00],\n          [-6.6573e-01],\n          [-1.4052e+00]],\n\n         [[-7.4362e-02],\n          [ 0.0000e+00],\n          [-3.6970e-04],\n          ...,\n          [-8.1338e-03],\n          [-2.9107e-03],\n          [-2.5092e-03]]],\n\n\n        ...,\n\n\n        [[[-2.1765e-02],\n          [ 5.7141e-02],\n          [-2.7621e+00],\n          ...,\n          [ 2.7834e-02],\n          [ 3.4340e-02],\n          [ 8.5746e-02]],\n\n         [[-4.3643e-02],\n          [ 1.7146e+00],\n          [ 1.6556e+02],\n          ...,\n          [ 3.3337e-01],\n          [ 2.0847e+00],\n          [ 1.0720e+01]],\n\n         [[-4.3664e-02],\n          [ 1.7825e+01],\n          [ 1.2556e-01],\n          ...,\n          [ 5.8273e+00],\n          [ 6.5869e+00],\n          [ 1.0918e+01]],\n\n         ...,\n\n         [[-4.5178e-02],\n          [ 0.0000e+00],\n          [-2.2192e-03],\n          ...,\n          [-3.6491e+00],\n          [ 0.0000e+00],\n          [-4.1297e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-2.2192e-03],\n          ...,\n          [-4.0571e+00],\n          [-1.4771e+00],\n          [-2.3489e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-7.8150e-04],\n          ...,\n          [-1.7614e-02],\n          [-4.7509e-03],\n          [-4.7532e-03]]],\n\n\n        [[[-1.2970e-02],\n          [-4.4244e-02],\n          [ 2.7055e+01],\n          ...,\n          [ 1.6221e-02],\n          [ 1.8515e-02],\n          [ 3.2533e-02]],\n\n         [[-2.6013e-02],\n          [ 1.3724e+00],\n          [-2.5262e+00],\n          ...,\n          [ 1.8414e-01],\n          [ 2.4162e+00],\n          [ 6.4194e+00]],\n\n         [[-2.5922e-02],\n          [ 6.9871e+00],\n          [ 1.7407e-01],\n          ...,\n          [ 4.3404e+00],\n          [ 4.7479e+00],\n          [ 6.5243e+00]],\n\n         ...,\n\n         [[-2.1903e-02],\n          [ 0.0000e+00],\n          [-1.1497e-03],\n          ...,\n          [-1.6683e+00],\n          [ 0.0000e+00],\n          [-2.6354e+00]],\n\n         [[-1.1158e-02],\n          [ 0.0000e+00],\n          [-1.9534e-03],\n          ...,\n          [-2.8376e+00],\n          [-7.3277e-01],\n          [-1.4908e+00]],\n\n         [[ 0.0000e+00],\n          [ 0.0000e+00],\n          [-4.0647e-04],\n          ...,\n          [-8.7606e-03],\n          [-3.0558e-03],\n          [-2.7018e-03]]],\n\n\n        [[[-1.4288e-02],\n          [-4.1589e-01],\n          [-8.0453e+00],\n          ...,\n          [ 1.8329e-02],\n          [ 2.0516e-02],\n          [ 3.9538e-02]],\n\n         [[-2.9873e-02],\n          [ 1.1594e+00],\n          [ 3.6617e+00],\n          ...,\n          [ 2.0551e-01],\n          [ 2.2668e+00],\n          [ 7.1337e+00]],\n\n         [[-2.9815e-02],\n          [ 8.5222e+00],\n          [ 1.5698e-01],\n          ...,\n          [ 4.6397e+00],\n          [ 5.1101e+00],\n          [ 7.2549e+00]],\n\n         ...,\n\n         [[-4.5160e-02],\n          [ 0.0000e+00],\n          [-1.3383e-03],\n          ...,\n          [-1.9821e+00],\n          [ 0.0000e+00],\n          [-2.8963e+00]],\n\n         [[-2.1864e-01],\n          [ 0.0000e+00],\n          [-1.7096e-03],\n          ...,\n          [-3.0429e+00],\n          [-8.5441e-01],\n          [-1.6397e+00]],\n\n         [[-7.4439e+00],\n          [ 0.0000e+00],\n          [-4.7309e-04],\n          ...,\n          [-9.9698e-03],\n          [-3.3398e-03],\n          [-3.0210e-03]]]], device='cuda:0')"
     ]
    }
   ],
   "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": 153,
   "id": "d3c74561-cafe-4068-b5ec-92d2c4634cc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8.63672886043787e-05"
      ]
     },
     "execution_count": 153,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "c29252c6-3147-4b6a-b320-ee566b03e910",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "False"
      ]
     },
     "execution_count": 154,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.probconserv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 155,
   "id": "b13f9495-85ed-4ba9-91fd-301557685c8a",
   "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\n",
    "nf,nx,nt,_ = mu.shape\n",
    "\n",
    "_mu = mu.view(nf, -1)\n",
    "_var = var.view(nf, -1)\n",
    "_m = x.view(nf, -1).to(device)\n",
    "\n",
    "# print(_m)\n",
    "\n",
    "u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "\n",
    "out = (u_proj.view(nf,nx,nt,1), u_var .view(nf,nx,nt,1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()\n",
    "\n",
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 156,
   "id": "6d7837ba-f720-43d2-b8d0-8252c41e8ad3",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "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 = 10\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": 158,
   "id": "12ad8111-5f71-46be-94fa-2095c3e81dab",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.258765935897827"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "param_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "70f6d09c-1fb6-4295-b33b-4000e11722d0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.2588, device='cuda:0')"
      ]
     },
     "execution_count": 159,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    " x_ood_test[parameters_idx, 0, 0, 0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 160,
   "id": "a2b9fc32-f85d-4ea2-80b9-2019a23d48da",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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4CTi8Xh04MABHThwQGvXrtX48eM1ZMgQTZgwQQ6HI9LDK3MrV67U/fffr2XLlgXcf/ToUe3evVtz587VqFGj1LNnT7344otq27btiR0ogJMaRVpEhM3GShsIj91uV1JSkt99IBzkEKwgf2AVOQSryCFY0bFjR40bN853PyYmRunp6frqq680fvx45ebm6p133pHT6dRbb70VwZGWvXfffVfDhw9XTk6OJOm0007T1VdfrfPPP1/JycmSpD179mjZsmWaMWOGfv75Z82fP1+vvPKKpkyZEsGRVyy8B8Eq6kChUaRFRPCGjnAV/lAAhIscghXkD6wih2AVOQQr4uPj1blz5yKP9+nTR/3791evXr3kdrs1ceJEjRw5UmeccUYERln2/vvf/+rmm2+W1+tVVFSUXn75Zd19990Bfx+98sor9fzzz+vzzz/Xww8/HIHRVmy8B8Eq6kChUcYGAAAAAOAklZqaqquvvlqSZJqm5syZE+ERlY0DBw7o+uuvl9frlSR9+OGHuu+++4otFBmGoQEDBmjVqlXq27fviRoqAEiiSAsAAAAAwEmtS5cuvu3t27dLkhYtWiTDMGQYhu9r/3PnztU111yjU045RdHR0TIMQ5mZmX59HThwQKNHj1bnzp1Vp04dOZ1O1a1bVz169NCrr76q7OzssMa2du1a3XrrrWratKliYmJUp04d9e7dWx9//HGxx40bN0779++XJA0ZMkQDBgwo8TmrVaumgQMHBt3/yy+/aMSIEWrdurWqV6+umJgYNWrUSFdffbU+//zzYvsO9Lx+9913Gjx4sBo3bqzo6GjVqVNHffv21X//+9+QY920aZNGjBihtm3bqnr16nI4HKpdu7ZOP/109e7dWy+88IJ+/vnnYvvYvHmz/va3v6lNmzaqWbOmoqOjlZKSossvv1zvv/++PB5P0GOHDh3qi0eSsrOzNXbsWHXu3FnJycmy2Wzq16+f1qxZ42t37733hoxLklq2bCnDMJScnCyXy1WiY4BKzQROgPXr15uSfLf169dHekgAAAAAUGVt377d9/tXt27dim37n//8x9f2zjvvNE3TNBcuXOh7bPLkyeYdd9zh9ztd/u3AgQO+fv73v/+ZNWrUCNgu/9a4cWNzzZo1QceS327IkCHmu+++azqdzqB9XXXVVWZOTk7AflJSUsrl98/nnnvOjIqKKjbG1NRUc9++fQGPL/y8/vOf/zRtNlvQvp566qmgYxk/fnzIsUgyr7/++oDHezwe8+GHHzbtdnuxx3fq1Mn8/fffA/YxZMgQX7sdO3aYLVq0KHL8lVdeaZqmaZ599tmmJLNWrVpBX7d833//ve/4ESNGFNsWlQN1odBYkxYRYZpmpIeASsY0Tb+/njocDt9fa4GSIIdgBfkDq8ghWEUOwarc3FzfduH8WbNmjW+7QYMGRY4dN26c1qxZo3bt2umee+5R69at5XK5tHz5cjmdTknSsmXL1LdvX7ndbhmGoRtvvFHXXnut6tWrp507d2ry5MmaOXOmdu7cqdTUVK1atUpNmzYNOt61a9dq2rRpSkhI0AMPPKBu3brJbrdr5cqVeuGFF7Rr1y59/vnnGj58eJELfP38889KS0uTJJ166qlq1apVaZ6yIl588UU98sgjkqSEhASNGDFCvXr1Unx8vH766Se98sorWrdunRYtWqTevXtr6dKlvucnkLffflvffvut2rdvr7vvvlutW7eW1+vV119/reeff15HjhzRqFGjdNFFF6lr165+x65fv1533323PB6PatasqeHDh6tbt26qU6eOPB6P0tLS9OOPP+rLL78M+l4xfPhwTZo0SZJ09tlna/jw4WrevLnq1Kmj3bt369NPP9X777+vFStW6JJLLtHixYsVFxcnKfB7UL9+/fTLL79o6NChGjBggFJSUpSenq709HRJebNu/+///k/79u3TnDlz1L9//6DPzTvvvOPbHjp0aNB2qDyoA5VABAvEOIkU/ovJ6tWrIz0kVDI5OTnm9u3bfbdQf3kFCiOHYAX5A6vIIVhFDiFcBWfSXnjhhUHz55dffjHj4+N9bZcvX26apv+MTx2ftepyuQKey+12m82bN/e1ff/99wO2e/rpp31tevbsGbBNwXPWq1fP3LZtW5E2+/btM1u2bOlr9/XXX/vtnzp1qm/foEGDSvR8hbJlyxbT4XCYkswaNWqYP/30U5E2OTk5Zp8+fXznfuaZZ4q0Kfy8Dh482HS73UXa/e9///O1GTBgQJH9jz/+eIl/v87IyCjy2LRp03zHv/jii6bX6w147CeffGIahmFKMkeOHFkkhwrOpDUMw/zss8+CjuPPP//0zfzNn10bSE5OjlmzZk1TktmmTZtiY0PlsXr1ambShsBMWgAAAABARGWPe1s5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Z06ER4SqIr9AK0lOpzOCIwEqB4q0AAAAAACcxLp06eLb3r59uyT/C2/lX2Bq7ty5uuaaa3TKKacoOjpahmEoMzPTr68DBw5o9OjR6ty5s+rUqSOn06m6deuqR48eevXVV5WdnR3W2NauXatbb71VTZs2VUxMjOrUqaPevXvr448/thSzFatXr9Y///lPXXzxxWrcuLFiY2MVExOjBg0a6LLLLtPbb7+t3NzcYvtITU31u0DZ/v379c9//lMdOnRQrVq1ZBiG7r///iLHffTRR7r44otVp04dxcbGqlmzZrrtttv0008/lUlsBS84N2rUKEnShg0bdOedd+rCCy/UGWecobZt26p3796aOnVqwGUPhg4dKsMw1LRpU99jTz31lN/F64JdmG337t169NFH1alTJ9WuXduXP7169dIbb7zhV/gtrOBF0Xbs2CGPx6MJEyaoR48eql+/vux2u9q2bVvkuKNHj+rVV1/VxRdfrJSUFEVHR6tmzZo655xz9Pjjj+vPP/8Mes5APyffffedBg8erMaNGys6Olp16tRR37599d///jdoP4H6HTZsmFq2bKmkpCQ5HA7VqVNHXbt21aOPPqr169cXe/y8efM0dOhQnXbaaUpISFBcXJxOPfVU3XTTTfr2229LPA6cWCx3AAAAAADASSwq6q/SgMfjCdjmzjvv1Pjx44vtZ+7cuRo0aJAOHDjg93h6eroWLFigBQsW6OWXX9bMmTPVpk2bkON67733dNttt/kVPHNycjR37lzNnTtXH330kaZNm3ZCZ2lOnz5d/fv3D7gvLS1NaWlpmjNnjl599VXNnDlTjRs3DtnnqlWrdPnllystLS1om9zcXA0aNEhffPGF3+Pbt2/XpEmT9P7772vixInhBVMCb7/9tu666y6/4mhubq4WLVqkRYsWaf78+Xr77bfL5Fzjxo3Tww8/XKQQm56ervnz52v+/Pl65ZVXNHPmTLVo0aLYvjIzM3Xddddp+fLlxbZbtGiRrrvuOu3Zs8fv8dzcXP3www/64YcfNG7cOL377rvq169fyBiefvppjRo1Sl6v1/dYRkaGvvzyS3355Zd66qmn9MQTTwQ9ft++fbrhhhsCFnQzMjK0ZMkSLVmyRB988IF27NhRpM2BAwc0ePDggMdv27ZN27Zt03vvvadbb71Vb7zxBjOcKxiKtGXs0KFDWr16te+H+ccff9SWLVt8f13avn170L8YlVZaWppef/11zZo1S7/99ps8Ho8aNWqk3r1766677tLpp59epucDAAAAgLL0R2b59V2nmhRVgu+Qph+SPN7Q7UqjZoIUXYF/+16zZo1vu0GDBkX2jxs3TmvWrFG7du10zz33qHXr1nK5XFq+fLmvyLNs2TL17dtXbrdbhmHoxhtv1LXXXqt69epp586dmjx5smbOnKmdO3cqNTVVq1at8ptpWdjatWs1bdo0JSQk6IEHHlC3bt1kt9u1cuVKvfDCC9q1a5c+//xzDR8+3DeD8URwu91KSEjQJZdcotTUVLVo0UI1atTQwYMHtWPHDr377rtauHCh1q5dq379+un777+Xw+EI2t+RI0fUr18/7du3TyNGjNCll16q2rVra/fu3X4F8+HDh/sKtA0bNtTDDz+sc845Rx6PR4sXL9ZLL72kW2+9VWeeeWaZxTpv3jwtX75czZo10913363GjRvLbrdr1apV+s9//qO9e/dq8uTJ6tGjh66//nrfcaNHj9YDDzygtLQ09e7dW1Jekf+uu+7ytSlcHHz66ad9xcumTZvqrrvuUsuWLVW/fn2lp6drzpw5evPNN/Xrr7+qZ8+e+vHHH1W3bt2gY7/55pu1Zs0a9e/fXzfccIOaNGmizMxMbd682ddmwYIF6tOnj1wul6pVq6Y77rhDnTp10imnnKKjR49qyZIlGjdunNLT0zVw4EDNmzdPqampQc/59ttv69tvv1X79u119913q3Xr1vJ6vfr666/1/PPP68iRIxo1apQuuugide3atcjxhw4dUteuXbVp0yZJUvPmzXX77bfrnHPOUbVq1XTgwAGtXr1as2fP1m+//Vbk+KysLKWmpmrdunWSpL59+2rgwIFq0qSJ4uPjtXnzZr355ptasmSJJk2aJEnlUthH6VXg/yYqp27duvn9B1fe5syZoxtuuKHIV0w2b97s+wF87bXXdOutt56wMQEAAABAOK7+T/n1/emdUv2k0O3ufF/ac7B8xvDvwVL7U8qnb6t+/fVXvf/++777PXv2LNJmzZo1uuqqq/TRRx/5zbrNXybB4/FoyJAhcrvdkvJmwBYs2rVv3179+vXTM888o8cff1yZmZkaPny45s2bF3Rca9asUb169bRs2TK/Yu65556rwYMH64ILLtCmTZv0zjvv6KabblL3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G3IIVpA/sIocglXkEKwgf2AVOQSrqAOFRpEWEeH1eiM9BFQyHo9HmZmZvvtxcXF8KEBYyCFYQf7AKnIIVpFDsIL8gVXkEKyiDhQayx0AAAAAAAAAQARRpAUAAAAAAACACKJICwAAAAAAAAARRJEWAAAAAAAAACKIIi0AAAAAAKgQDMOQYRgaOnRopIdSKQ0dOtT3HAKoXCjSAgAAAABQxezYscNXrIuOjlbTpk19t7i4ONWsWVNt27bVnXfeqeXLl0d6uGVu0aJFpSr45h/TpEmTchtbJI0aNcoXY0lvSUlJAfvaunWrXn/9dV177bVq2bKlEhMT5XQ6lZycrNTUVD377LP6888/Q46pYGG5pLe2bduW7RMDVABRkR4AAAAAAAA4cTwejw4cOKADBw5o7dq1Gj9+vIYMGaIJEybI4XBEenioBG677Ta99957Afft3btXixcv1uLFizVmzBi9/vrruuGGG07wCIHKhyItAAAAAABVWIcOHTR69Gjf/Vq1aikjI0NfffWVxo8fr9zcXL3zzjtyOp166623IjhSnEjPPPOMrrzyypDt7HZ7kcd2794tSYqPj9fll1+u7t2764wzzlBiYqJ27dqlTz75RB988IEOHTqkm266SQ6HQ9dee23Ic7399ts655xzQraLjY0N2QaobCjSAgAAAABQhcXHx+uMM87w3U9JSZHT6VSfPn3Uv39/9erVS263WxMnTtTIkSP92qLqatCggVq3bl2itrm5uX73U1JS9Morr+jWW29VQkKC37527drpiiuuUN++fXXdddfJNE3dc889uvzyyxUXF1fseZo2bVriMQFVDWvSAgAAAABwkkpNTdXVV18tSTJNU3PmzInwiFAZvP322xoxYkSRAm1BgwYNUr9+/SRJGRkZmj9//gkaHVA5UaQFUCkYhiGHw+G7cbVShIscghXkD6wih2AVOQSrisufLl26+La3b98uyf/CW1OmTJEkzZ07V9dcc41OOeUURUdHyzAMZWZm+vV14MABjR49Wp07d1adOnXkdDpVt25d9ejRQ6+++qqys7PDGvfatWt16623qmnTpoqJiVGdOnXUu3dvffzxx+E/CWVk9erV+uc//6mLL75YjRs3VmxsrGJiYtSgQQNddtllevvtt4vMPC0sNTXV7wJl+/fv1z//+U916NBBtWrVkmEYuv/++4sc99FHH+niiy9WnTp1FBsbq2bNmum2227TTz/9VA6R/qW070E9evTwbf/yyy/lNTygSmC5A0QEi9EjXA6HQw0aNIj0MFCJkUOwgvyBVeQQrCKHYIVhGMXmT1TUX6UBj8cTsM2dd96p8ePHF3ueuXPnatCgQTpw4IDf4+np6VqwYIEWLFigl19+WTNnzlSbNm1Cjvu9997Tbbfd5lfwzMnJ0dy5czV37lx99NFHmjZtmpxOZ8i+ysr06dPVv3//gPvS0tKUlpamOXPm6NVXX9XMmTPVuHHjkH2uWrVKl19+udLS0oK2yc3N1aBBg/TFF1/4Pb59+3ZNmjRJ77//viZOnBheMGEo7XtQwdcu0Nq2OHlQBwqNIi0AAAAAIKJ25B4J+Hi9qFjF2EIXdg55crXfU3TmotOwKcVR/BqY+Xa7suQ2zSKP146KVoItdHHhqNetdPexIo/bDKmxI/hXwiuCNWvW+LYDFeLGjRunNWvWqF27drrnnnvUunVruVwuLV++3FcgXbZsmfr27Su32y3DMHTjjTfq2muvVb169bRz505NnjxZM2fO1M6dO5WamqpVq1apadOmQce0du1aTZs2TQkJCXrggQfUrVs32e12rVy5Ui+88IJ27dqlzz//XMOHD/fN9D0R3G63EhISdMkllyg1NVUtWrRQjRo1dPDgQe3YsUPvvvuuFi5cqLVr16pfv376/vvviy1OHTlyRP369dO+ffs0YsQIXXrppapdu7Z2797tVzAfPny4r0DbsGFDPfzwwzrnnHPk8Xi0ePFivfTSS7r11lt15plnlvtzEI6FCxf6tlu1ahXBkQAVH0VaAAAAAEBEnbH1s4CPz23cW93i64U8fsrBLXrwz5VFHj87uoZWNruiRGPo/ttX+s2VVeTxCfW76Kak5iGPn5eVpmt2LyzyeHWbQ+lnDC7RGCLh119/1fvvv++737NnzyJt1qxZo6uuukofffSR36zb/GUSPB6PhgwZIrfbLSlvBuz111/va9e+fXv169dPzzzzjB5//HFlZmZq+PDhmjdvXtBxrVmzRvXq1dOyZcv8irnnnnuuBg8erAsuuECbNm3SO++8o5tuukndu3cP2ldmZqbWr19fgmcjtAsuuEC///67qlWrFnD/0KFDNWHCBA0fPlyrV6/WRx99pBtuuCFof/v27VNWVpYWLlyo888/3/d4+/btfdsLFy7UO++8I0lq2bKlvv32W9WqVcu3v3Pnzho0aJA6d+7sV3AP5ffffy/R85KcnKzk5OQS95vvhx9+0FdffSUpr/h/0UUXhTxm+/btql27dsh2DRs2VFJSUthjAioyirQAAAAAAJxEPB6P9uzZoy+//FKPP/64srLyitO9evXSueeeW6R9QkKCJk6c6FegLWjWrFnasmWLJGnw4MF+BdqCHn30Uc2ePVvff/+95s+fr3Xr1unss88OOs6XX3454GzbmjVrasKECbrgggsk5c30La5IO2PGDM2YMSPo/nDUqxf6jwbDhg3TG2+8oTVr1uizzz4rtkgrSSNHjvQr0Bb26quv+rbfeustvwJtvqZNm+qll14Kea6CHnvsMT322GMh2z355JMaNWpUifuV8mYIDx061Dcb+LnnnivR191vueWWEvU/efJkDR06NKwxARUdRVoAAAAAAKqwxYsXh7zQU8eOHTVt2rSA+6644grVqFEj6LFz5871bd9xxx1B2xmGoTvvvFPff/+977hgRdrq1atr4MCBQfvq0qWLWrZsqU2bNunrr7+Wx+OJyJqnLpdL6enpOnz4sG8msZQ3c3TNmjVatWpVyD6GDBkSdJ/H49H8+fMlSWeccYavMB3IwIEDdffdd+vgwYNhRFD2vF6vrr/+em3YsEGSNGjQIN14440RHRNQGVCkRUS4XK5IDwGVTP6Hn3zJycksPI6wkEOwgvyBVeQQrCKHUB6io6PVoUMH3XTTTbr11luDzpRt27Ztsf2sW7dOUt4FyDp16lRs286dO/u2165dG7Rd+/btQ+b4ueeeq02bNikrK0tbtmzRGWecEbDdkCFDSrxubahitiQdPnxYr732mj755BOtX7++2N9vMzIyiu0rPj5ep512WtD927Zt05EjeWs2B5rlXJDT6VS7du20aNGiYtvlC2c2aknfg0zT1LBhwzRz5kzfmMO5oNnChQuVmppa4vaoPKgDhUaRFkClYJqm35u6GeCiDkBxyCFYQf7AKnIIVpFDsKJDhw4aPXq07369evVUq1Yt1a1bt0TF/po1axa7f9++fZKkpKQkRUdHF9u2fv36RY4LpG7duiHHVXDpgYyMjKBF2rK0ceNG9e7dW7t37y5R+6NHjxa7v7gZypL/cxTuc1KWSvIeZJqm7rrrLr399tuSpHbt2um///2v4uPjy2VMQFVj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Qx6UvBKdSx84cEDLli3TlClTVFBQoGAwqMGDB2vSpEm644479Prrr3fYR5/NhQxSWlFRkRk6dKiRFPPh9XrNww8/3Cv7/uyzz0xaWlqz/S1btqzD9+3du9eMHTu2zTFLMrfeeqsJhULt9hMKhcytt97abj9jx441e/fu7aEjTj1uip8f/OAHxrKsds+3JBMIBMx//Md/tLvvLVu2dNhP9KOioqJnDz6FuCmGjDFmxowZnT7vd911V4djePjhh43X622zj6FDh5qioqKeOeAU5aYYWrZsWZeuHZJMbm6uqampadUX16GekYj46elzRR6UXNwUQ+RCyclNMWQMuVCycVP8kAclp0Tm0uFw2Dz00EMmGAy2e76GDx/ebj99ORfyCSlr//79uuaaa1RWVibLsvQP//APmjdvnrKyslRUVKQf/ehHOnr0qB588EHl5ubqzjvv7LF9h8NhLVy4ULW1tRo4cKBKSko69b6KigpdddVV2rdvnyRp3rx5Wrhwoc477zx99NFH+vGPf6y9e/dq1apVyszM1IoVK9rs6+6779aqVaskSRdeeKHuvfdeXXzxxSorK9O6deu0fv16ffrpp7rqqqv0wQcfKC8vL/4DTyFui58jR47IGKNAIKCrr75aV155pSZMmKDc3FyVlpbq9ddf13PPPaf6+notXbpUxhgtXbq0w37/9V//VbNnz263TU5OTqePrS9xWwxFKyws1Ntvv91um/POO6/d1x9//HE9+OCDkqTBgwfr/vvv15QpU1RdXa3169frueee0+HDh3XNNdeoqKhIo0aN6tIY+wK3xdA//uM/au7cuR22W7VqlZ588klJ0g033KC0tLR223Md6h4n4ifec0UelFzcFkPkQsnHbTEUjVzIeW6LH/Kg5JPIGDLG6Dvf+Y7WrVsnKZJ73HLLLZoyZYry8/N16tQpffrpp3rrrbe0e/fuNvvp87mQoyVi9KrZs2fbnw6sWrWq1euHDh0yAwYMMJJMRkaG+fLLL3ts3z/96U+NJFNYWGhWrlxpj6OjWWx33XWX3fb+++9v9XpFRYW56KKLjCRjWZb54x//GLOfHTt22DMJxo4dG/OTtXvvvdfe15IlS7pzmCnNbfFz9913m+XLl5uysrI227z77rv2p3rBYNAcOnQoZrvoT27XrVsX59H0XW6LIWPOzR7p6NPdjnz55ZcmIyPD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",
      "text/plain": [
       "<Figure size 1350x840 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "L2 error: 2.4134345054626465\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "t_idx = 10\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        # Set compact figure size and high DPI\n",
    "        fig = plt.figure(figsize=(4.5, 2.8), dpi=300)\n",
    "\n",
    "        time_label = t[slice(*tpred)][t_idx].item()\n",
    "        param_val = x_ood_test[parameters_idx, 0, 0, 0].item()\n",
    "        true_vals = y_train[parameters_idx, :, t_idx, 0]\n",
    "        pred_mu_conserv = new_mu[parameters_idx, :, t_idx, 0]\n",
    "        pred_std_conserv = new_std[parameters_idx, :, t_idx, 0]\n",
    "        pred_mu_inf = u_proj_reshaped[parameters_idx, :, t_idx, 0]\n",
    "        pred_std_inf = stds[parameters_idx, :, t_idx, 0]\n",
    "\n",
    "        pred_mu_e2e = mu[parameters_idx, :, t_idx, 0]\n",
    "        pred_std_e2e = std[parameters_idx, :, t_idx, 0]\n",
    "\n",
    "    \n",
    "\n",
    "        # Plot true solution\n",
    "        plt.plot(grid, true_vals, color=\"black\", lw=1.5, label=\"True\", zorder=3)\n",
    "\n",
    "        # ProbConserv\n",
    "        plt.plot(grid, pred_mu_conserv, '--', lw=1.2, color=\"#ef233c\",\n",
    "                 label=r\"ProbConserv\", zorder=2)\n",
    "        plt.fill_between(grid,\n",
    "                         pred_mu_conserv + 3 * pred_std_conserv,\n",
    "                         pred_mu_conserv - 3 * pred_std_conserv,\n",
    "                         color=\"#ef233c\", alpha=0.3, label=\"_nolegend_\", zorder=1)\n",
    "\n",
    "        # ProbHardE2E\n",
    "        plt.plot(grid, pred_mu_inf, '--', lw=1.5, color=\"#3a86ff\",\n",
    "                 label=r\"ProbHardInference\", zorder=4)\n",
    "        plt.fill_between(grid,\n",
    "                         pred_mu_inf + 3 * pred_std_inf,\n",
    "                         pred_mu_inf - 3 * pred_std_inf,\n",
    "                         color=\"#3a86ff\", alpha=0.3, label=\"_nolegend_\", zorder=3)\n",
    "\n",
    "        # ProbHardE2E\n",
    "        plt.plot(grid, pred_mu_e2e, ':', lw=1.5, color=\"#06d6a0\",\n",
    "                 label=r\"ProbHardE2E\", zorder=4)\n",
    "        plt.fill_between(grid,\n",
    "                         pred_mu_e2e + 3 * pred_std_e2e,\n",
    "                         pred_mu_e2e - 3 * pred_std_e2e,\n",
    "                         color=\"#06d6a0\", alpha=0.2, label=\"_nolegend_\", zorder=4)\n",
    "\n",
    "        # Labels\n",
    "        plt.xlabel(\"x\", fontsize=8)\n",
    "        plt.ylabel(r\"$u(x, t={:.2f})$\".format(time_label), fontsize=8)\n",
    "\n",
    "        # Ticks and grid\n",
    "        plt.xticks(fontsize=7)\n",
    "        plt.yticks(fontsize=7)\n",
    "        plt.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "        plt.xlim((0.4,0.6))\n",
    "\n",
    "        # Legend\n",
    "        plt.legend(fontsize=7, loc=\"upper right\", frameon=False)\n",
    "\n",
    "        # Layout for Overleaf\n",
    "        plt.tight_layout(pad=0.3)\n",
    "        plt.savefig(\"nonlinear_PME_CRPS.pdf\")\n",
    "        plt.show()\n",
    "        print(\"L2 error:\", torch.norm(true_vals - pred_mu_e2e).item())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "3a4babe7-d69b-4f4e-92a3-4c19c8527702",
   "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",
    "        nf,nx,nt, _ = mu.shape\n",
    "        _mu = mu.view(nf, -1).to(device)\n",
    "        _var = var.view(nf, -1).to(device)\n",
    "        _m = x_data.view(nf, -1).to(device)\n",
    "        \n",
    "        # print(_m)\n",
    "        \n",
    "        u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "        \n",
    "        out = (u_proj.view(nf,nx,nt,1), u_var .view(nf,nx,nt,1))\n",
    "        \n",
    "        mu, var, = out[0].cpu(), out[1].cpu()\n",
    "\n",
    "        std = torch.sqrt(var)\n",
    "        var = torch.square(std)\n",
    "\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",
    "    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",
    "            nf,nx,nt, _ = mu_test.shape\n",
    "            _mu = mu_test.view(nf, -1).to(device)\n",
    "            _var = var_test.view(nf, -1).to(device)\n",
    "            _m = x_data_test.view(nf, -1).to(device)\n",
    "            \n",
    "            # print(_m)\n",
    "            \n",
    "            u_proj, u_var = project_and_stats(torch.relu(_mu), _var, _m, model.full_residual, max_iter=30)\n",
    "            \n",
    "            out = (u_proj.view(nf,nx,nt,1), u_var .view(nf,nx,nt,1))\n",
    "            \n",
    "            mu_test, var_test, = out[0].cpu(), out[1].cpu()\n",
    "    \n",
    "            std_test = torch.sqrt(var_test)\n",
    "            var_test = torch.square(std_test)\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",
    "        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']:.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": 52,
   "id": "5e892f52-ecfa-4592-88ef-08d411f65be9",
   "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=\"ProbHardE2E\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "6119a5a8-6ac8-4d29-809a-25c3218a9c4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import gc\n",
    "gc.collect()\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "68075082-916d-4758-9598-cc9d0f6eec43",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function __main__.compute_statistics(model, x_data, y_data, t, tpred, grid, dataset_class, apply_probconserv=False, plot=False, x_data_test=None, y_data_test=None, return_latex=False, name='Model')>"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "compute_statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "1c2eb841-f9bc-4b49-81de-58620aee2a4a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "7.747865747660398e-05"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "train_stats['mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "fa62601e-6198-464e-99e7-5b2efa38e8eb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8.61472450196743e-05"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "1c54d2f0-cfae-4b5a-ac1f-6d323f0d3d00",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'ProbHardE2E & 7.75E-05 & 8.47E-01 & 2.14E-01 & 3.08E-02 & 3.33E-03 & 8.61E-05 & 8.97E-01 & 2.14E-01 & 2.82E-02 & 3.30E-03 \\\\\\\\'"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f44a1aec-0c82-40ef-b406-13f57d0bb081",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "3c9f4d06-2687-4058-8c02-941af51595a7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.1478, device='cuda:0', grad_fn=<MeanBackward0>)"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.mean(torch.norm(vmap(full_residual)(torch.relu(new_mu.reshape(nf,-1)).to(device), _m), dim=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "id": "4e1d8ff4-50fc-4cdc-b824-ea2e4d850060",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "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": null,
   "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": null,
   "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": null,
   "id": "3639a00a-4839-4317-98f9-549ba4ab4656",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d1eddcf4-0349-4c22-819c-d8bf5fd81cdf",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "id": "dd8c116a-f7e0-4af0-a6d3-b506dee7945b",
   "metadata": {},
   "outputs": [],
   "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": null,
   "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": null,
   "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": null,
   "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": null,
   "id": "c8f87a91-2bad-44c5-9633-1f6a03f77d68",
   "metadata": {},
   "outputs": [],
   "source": [
    "from decimal import Decimal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82377954-2227-47c4-bbc3-7c1c95682b6c",
   "metadata": {},
   "outputs": [],
   "source": [
    " f\"{ucons_stats_train['mcerr']:.2}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd09fb69-7adb-4f8f-811a-45a934dc46d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "e2e_stats_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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": null,
   "id": "c95a912a-bd68-459a-abf7-1c5f03b5661a",
   "metadata": {},
   "outputs": [],
   "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": 172,
   "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",
    "            t_sliced = t[slice(*tpred)]\n",
    "            ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu.shape[0])\n",
    "            xs = repeat(grid_train, \"nx -> nf nx\", nf=mu.shape[0])\n",
    "            inputs = meshgrid(ts, xs)\n",
    "            inputs = inputs.to(mu.device)\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": null,
   "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": null,
   "id": "a6a1914c-1c99-4c23-9fe7-fafe7a2a5d7c",
   "metadata": {},
   "outputs": [],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af0c8f58-4cae-495a-8cfb-ee81163a961c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "optprobconserv2",
   "language": "python",
   "name": "optprobconserv2"
  },
  "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
}
