{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 191,
   "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": 192,
   "id": "5fdcc8cd-82d9-4cec-888d-806541259f2c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "1d5eb530-ab43-4054-8953-9efdb86b3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "args = {'--batch_size': '20',\n",
    " '--dataset': 'StefanPME_1D',\n",
    " '--dataset_params': '0.6,0.65',\n",
    " '--epochs': '200',\n",
    " '--fno_modes': '12',\n",
    " '--fno_width': '32',\n",
    " '--grid_len': '100',\n",
    " '--lr': '1e-3',\n",
    " '--m.drop_prob': '0.1',\n",
    " '--m.n_models': '10',\n",
    " '--m.n_regularize': '5',\n",
    " '--m.reg_strength': '1',\n",
    " '--m.reg_type': 'weights_l2',\n",
    " '--model': 'OutputVarFNO2d',\n",
    " '--n_samples': '200',\n",
    " '--no_train': False,\n",
    " '--ood_dataset_params': None,\n",
    " '--predict_time': '0,-1,5',\n",
    " '--seed': '0',\n",
    " '--time_len': '100',\n",
    " '--tplot': '0.5',\n",
    " '--train_ood_dataset_params': '0.55,0.6'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "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": 195,
   "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": 196,
   "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": 197,
   "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": 198,
   "id": "a7e5c61c-2b59-466f-9b4a-6157fa29ad4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=False, base_model_params=FNO2d_params, constraint_context=constraint_context)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "id": "4333d6f8-fe2c-4caa-a889-efae589c31ff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 199,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "id": "96aa9ee0-a30e-458b-85e2-5e7dbbd89dc4",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_true = torch.mean(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "id": "fc1ac32d-6fb2-4293-8ea7-f90486a32dce",
   "metadata": {},
   "outputs": [],
   "source": [
    "var_true = torch.var(y_train, dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 202,
   "id": "f07c25ce-49e4-4331-81a3-ee678808a6b4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100, 20, 1])"
      ]
     },
     "execution_count": 202,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu_true.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "0f4d18b3-1988-4417-9122-3a8709048fc2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([0.0000e+00, 2.1284e-04, 4.2556e-04, 6.3808e-04, 8.5027e-04, 1.0620e-03,\n",
      "        1.2733e-03, 1.4838e-03, 1.6937e-03, 1.9027e-03, 2.1107e-03, 2.3178e-03,\n",
      "        2.5236e-03, 2.7282e-03, 2.9315e-03, 3.1333e-03, 3.3337e-03, 3.5324e-03,\n",
      "        3.7294e-03, 3.9246e-03, 4.1180e-03, 4.3094e-03, 4.4988e-03, 4.6861e-03,\n",
      "        4.8712e-03, 5.0541e-03, 5.2348e-03, 5.4130e-03, 5.5889e-03, 5.7623e-03,\n",
      "        5.9331e-03, 2.7728e-01, 3.0200e-01, 1.1456e-01, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00,\n",
      "        0.0000e+00, 0.0000e+00, 0.0000e+00, 0.0000e+00])\n"
     ]
    },
    {
     "data": {
      "image/png": "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iPj4ePHll18alDl27Jj4+9//LgIDA4VCoRCNGzcWgwcPFrt377Zwpkwf44ULF8STTz4p/Pz8hFKpFPHx8WLbtm1G63z379aUixcvitmzZ4sHHnhAhISECDc3NxEcHCwGDBgg9uzZY1DW3OtbiMopJeLi4oSHh4fw9vYWbdu2Fa+88oq4fv26voypqQO+/fZb0a5dO6FUKkVUVJR4++23xapVqwQAkZ6eri9n6rVp7d/43cy95u5k69QBtn486/7Wjd3u/JvW/a3qbnK5XISFhYmHH35YfPDBB0KlUtn0vPcKiRAOHu1K5AIGDRqEP/74Q39lEhER3bs4ZonueSUlJQY/nzt3Dtu3bze5ajcREd1b2LJE97zw8HCMGjUK0dHRuHz5MpYtWwa1Wo1jx45VmR+IiKi2aDQaiwP6vby8amUqiXsdB3jTPa9v37748ssvkZWVBYVCgc6dO2PBggUMSkRUpzIyMixODpqcnGwwiJ5qBluWiIiI6qHS0lKLKxxER0fbfbUqWY9hiYiIiMgMDvAmIiIiMoNjlhxAq9Xi+vXr8Pb2rpFlOYiIiMjxhBAoKChARESE2YlZGZYc4Pr161VWmCciIiLnkJGRgUaNGpm8n2HJAby9vQFUnmwfH586rg0RERFZQ6VSITIyUv85bgrDkgPout58fHwYloiIiJyMpSE0HOBNREREZAbDEhEREZEZDEtEREREZjAsEREREZnBsERERERkBsMSERERkRkMS0RERERmMCwRERERmcGwRERERGQGwxIRERGRGQxLRERERGYwLBERERGZwbBEREREZAbDEhEREZEZDEtELkZdoanrKhARuRSGJSIXU1LGsERE5EgMS0QupohhiYjIoZwqLO3btw8DBw5EREQEJBIJtm7darb8li1b8PDDDyM4OBg+Pj7o3LkzfvzxR4Myc+bMgUQiMbjFxsbW4FEQ1axidUVdV4GIyKU4VVgqKirC/fffj6VLl1pVft++fXj44Yexfft2HDlyBA899BAGDhyIY8eOGZRr3bo1MjMz9bf9+/fXRPWJakWZRouyCm1dV4OIyGW41XUFbNGvXz/069fP6vKLFy82+HnBggX45ptv8N1336FDhw767W5ubggLC3NUNYnqlBBAaYUGcjen+i5ERFRv3VPvplqtFgUFBQgICDDYfu7cOURERCA6OhrDhw/HlStX6qiGRNUjhKgMSxy3RETkME7VslRdixYtQmFhIQYPHqzflpCQgDVr1qBFixbIzMzE3Llz0b17d5w8eRLe3t5G96NWq6FWq/U/q1SqGq87kTW0ovLf0nJ2wxEROco9E5bWr1+PuXPn4ptvvkFISIh++53deu3atUNCQgIaN26Mr776CmPGjDG6r4ULF2Lu3Lk1XmciW2lFZVoqKWfLEhGRo9wT3XAbNmzA888/j6+++gqJiYlmy/r5+aF58+Y4f/68yTKzZs1Cfn6+/paRkeHoKhPZRReWyiq00OqamYiIqFpcPix9+eWXGD16NL788ksMGDDAYvnCwkJcuHAB4eHhJssoFAr4+PgY3IjqA3FHPirlTN5ERA7hVGGpsLAQaWlpSEtLAwCkp6cjLS1NPyB71qxZGDFihL78+vXrMWLECLz33ntISEhAVlYWsrKykJ+fry8zY8YM/Pzzz7h06RIOHDiAxx9/HDKZDMOGDavVYyNyBO0daYkzeRMROYZThaXffvsNHTp00F/2P336dHTo0AGzZ88GAGRmZhpcybZixQpUVFRg4sSJCA8P19/+8Y9/6MtcvXoVw4YNQ4sWLTB48GAEBgbiv//9L4KDg2v34IgcQGvQssRB3kREjiARQnBgQzWpVCr4+voiPz+fXXJUp/JLynHlZjEAwEMuQ9MQrzquERFR/WXt57dTtSwRkXl3fvcp5RVxREQOwbBE5ELu7IYTAlBzkDcRUbUxLBG5EO1dveqlZRy3RERUXQxLRC6kSlhiyxIRUbUxLBG5kLsv1+D0AURE1cewRORC2LJEROR4DEtELuTuFU7KKwQqNBy3RERUHQxLRC7E2HpwnJySiKh6GJaIXMjd3XAAxy0REVUXwxKRCzHSsMTJKYmIqolhiciFGGtZ4sSURETVw7BE5EKMLfXI8d1ERNXDsETkQox1wwlwrWwioupgWCJyIca64bRsWSIiqhaGJSIXojHStGQsQBERkfUYlohciLFcxKxERFQ9DEtELkIIYTIYGRv4TURE1mFYInIRxgZ3W3MfERGZx7BE5CLMjU1iyxIRkf0YlohchLmwxJYlIiL7MSwRuQhzjUe8Io6IyH4MS0Quwnw3XC1WhIjIxTAsEbkIc11tnMWbiMh+DEtELsLYhJQ6HLNERGQ/hiUiF2HuijeOWSIish/DEpGLMNsNx/XhiIjsxrBE5CLMDvDmmCUiIrsxLBG5CM6zRERUMxiWiFwE51kiIqoZDEtELoLzLBER1QyGJSIXYXaAN9MSEZHdGJaIXISW8ywREdUIpwpL+/btw8CBAxEREQGJRIKtW7dafExKSgr+9re/QaFQoGnTplizZk2VMkuXLkVUVBSUSiUSEhJw6NAhx1eeqIaZH+DNtEREZC+nCktFRUW4//77sXTpUqvKp6enY8CAAXjooYeQlpaGqVOn4vnnn8ePP/6oL7Nx40ZMnz4dycnJOHr0KO6//34kJSUhJyenpg6DqEaYX+6EiIjsJRFOOphBIpHg66+/xqBBg0yWefXVV/H999/j5MmT+m1Dhw5FXl4eduzYAQBISEhAp06d8NFHHwEAtFotIiMjMXnyZMycOdOquqhUKvj6+iI/Px8+Pj72HxRRNVy4UYhitcbofX6e7ogM8KzlGhER1W/Wfn47VcuSrVJTU5GYmGiwLSkpCampqQCAsrIyHDlyxKCMVCpFYmKivkxd+jz1EnaczDI7FoVIx9z3Huf8SkREVD+41XUFalJWVhZCQ0MNtoWGhkKlUqGkpAS3b9+GRqMxWubMmTMm96tWq6FWq/U/q1Qqx1YcwO2iMiz84QyKyzRoHuqFiQ81xSPtIiCTShz+XOQazGVqjlkiIrKfS7cs1ZSFCxfC19dXf4uMjHT4c8hkEozp1gTeCjf8mV2If2xIQ+L7P+Or3zJQruFCX1SV+eVOiIjIXi4dlsLCwpCdnW2wLTs7Gz4+PvDw8EBQUBBkMpnRMmFhYSb3O2vWLOTn5+tvGRkZDq+7j9IdL/Vpgf0ze+Glh5vDz8Md6blFeGXz73jw3RR88d/LUFcYH59C9yaN2akDGJeIiOzl0mGpc+fO2L17t8G2nTt3onPnzgAAuVyOuLg4gzJarRa7d+/WlzFGoVDAx8fH4FZTfD3cMbl3M/w6sxde6x+LIC85ruWV4PWtJ9Hjnb1YuT8dJWUMTWR+XJKTXsdBRFQvOFVYKiwsRFpaGtLS0gBUTg2QlpaGK1euAKhs8RkxYoS+/AsvvICLFy/ilVdewZkzZ/Dxxx/jq6++wrRp0/Rlpk+fjk8++QRr167F6dOn8eKLL6KoqAijR4+u1WOzpIHCDeN6xGD/q70wZ2ArhPkoka1SY/62U+j69h4sS7mAQnVFXVeT6ogQwsLacLVXFyIiV+NUUwekpKTgoYceqrJ95MiRWLNmDUaNGoVLly4hJSXF4DHTpk3DqVOn0KhRI7zxxhsYNWqUweM/+ugjvPvuu8jKykL79u2xZMkSJCQkWF2vupg6QF2hwZaj1/Dx3vPIuF0CoLIV6rmuTTCqSxR8Pd1rpR5UP2i0Aqeum77QQO4mRYsw71qsERFR/Wft57dThaX6qi7nWSrXaPFt2nUs3XseF3OLAAANFDKM7ByFMd2aINBLUav1obpRrtHiTGaByfvdZBK0DOccYEREd2JYqkX1YVJKjVZg+4lMfLjnHP7MLgQAKN2lGJ7QGON6RCPUR1kn9aLaoa7Q4M+sQpP3S6VA6wjfWqwREVH9x7BUi+pDWNLRagV2nc7Gh3vO48S1fACAu0yCwR0j8ULPGM7i7KJKyzU4l206LEkkQJuGDEtERHdiWKpF9Sks6Qgh8Mu5XCzZfQ6/Xb4NAJBJJBjUIQITH2qK6GCvOq4hOVJxWQUu5BSZLdO2EcMSEdGdGJZqUX0MS3c6ePEmPtxzHvvP5wIAJAD6tw3H5N5NERtW/+pLtitUVyD9hvmw1DrCB1LOAE9EpGft57dLL3dClRKiA5EQHYi0jDx8uPscdp/JwfcnMvH9iUz0ig3BlN7N0D7Sr66rSdVgbkJKHX4rIiKyD1uWHKC+tyzd7dR1FT7aew4/nMjSf4B2iQnElN7NkNAkABIJWx+cTV5xGTJulZgtExvuDXeZU02tRkRUo9gNV4ucLSzpnM8pxNK95/Ft2nVo/voz6BDphymJzfBg82CGJidyq6gM126bD0vNw7ygcJPVUo2IiOo/hqVa5KxhSSfjVjE+TjmPzUeuolxT+efQMswbU3o3Q1LrMI5zcQK5hWpk5pWaLdMs1AtKd4YlIiIdhqVa5OxhSSdbVYrlP1/Al4euoLRcCwBoEuSJiQ81w6D2EXBjF069lVNQiux8tdkyTUO84CFnWCIi0mFYqkWuEpZ0bhWV4dNfLuKz1Mv69eYi/JQY3yMGQzpFsnWiHspWlSJHZT4sRQc3QAMFr+kgItJhWKpFrhaWdApKy7Hm10tY+Ws68orLAQCBDeQY060JRnaJ4gdvPZKZX4LcgjKzZaKCPOGt5JqBREQ6DEu1yFXDkk5JmQbrDl7Gin0XkVNQ2Xrho3TDMw9ULqXi5ymv4xrStbwS3Co0H5YaB3nCh2GJiEiPYakWuXpY0imr0GLTbxlY9vMFXP3ryisPdxkGd2yECQ/GINTXo45reO/KuFWsb/0z5b4AT/h6MiwREekwLNWieyUs6Wi0At8dv46P9p7H+ZzK9cjcZRIMvD8Ck7iUSp24fLMIqpIKs2Ua+XvAvwFbAYmIdBiWatG9FpZ0hBD46VQ2PtpzDieuqQAAUgnQu2UopvRuirYN/eq2gveQ9NwiFJaaD0sRfkoEeilqqUZERPUfw1ItulfDko4QAgfO38QHe87hUPot/fbOMYGY+GAMujULrsPa3Rsu3ChEsVpjtky4nxJBDEtERHpcG45qjUQiQddmQejaLAjHrtzGB7vP4eezN5B64SZSL9xEu4a+eKFnDPq2CYVUyrmaaoI133m0/F5ERGQXtiw5wL3esmTMmUwVPtp7HjtOZqHir0VeY4IbYEy3JngyLhJyN4YmR/ozuwDqvyYSNSXER4FQH2Ut1YiIqP5jN1wtYlgy7crNIixNuYCtx65BXVH5YR7uq8SIzo3xTEJjeHvw6ixHOJOlQnmF+ZdykLcc4bxikYhIj2GpFjEsWZatKsWKfRfx1W8ZKPhrILK/pzsGd4zEc92iEOrDD/Hq+ON6PrTmG5YQ6CVHhB/PMxGRDsNSLWJYsl5+SRlW/3oJX/z3MnL/mkTRUy7Do/dHYGz3aEQHN4BEwoV7bXXyWj4svZL9G7ijkb9n7VSIiMgJMCzVIoYl2xWpK7DhUAbWHEhHxl8TXLrLJEhsGYrnu0ejfaQfZFKGJmsIIXDyr6kbzPHzdEdkAMMSEZEOw1ItYliyX1m5BluPX8eq/ek4k1UAAJAA6NI0EKO7NkH3ZkFQuHHhXnM0WoFT1y2HJV8Pd9wXyLBERKTDsFSLGJaqr0Kjxa7T2Vi5Px2HL93Wb2/X0BfPdL4P/dqEcxFYE8o1WpzJLLBYzlvphqigBrVQIyIi58CwVIsYlhxHoxU4lH4Tn/6SjpQ/b0Dz17QDUYGeGNwxEk/GNUKQlwJSdtHpqSs0+DOr0GK5BgoZl6IhIroDw1ItYlhyPK1W4I9MFVbvT8cPJ7NQUl45O3WQlwKD2kfg6YT7EBngCXcZ52sqLdfgXLblsOQhl6FpCMMSEZEOw1ItYliqOVqtwOWbRVibehlb064hr7gcANBALkO/NuEYnnAfYsN94CG/d8c1FZdV4EJOkcVyHnIpmoZ410KNiIicA8NSLWJYqnlCCGSrSvHloQxsPnIV1/Iqr6Bzk0rwYItgDO10HzpFBcDHw+2em3qgUF2B9BuWw5LCXYrmoQxLREQ6DEu1iGGp9gghcLu4DN8dz8TGwxk4lfm/q8A6NvbHk3GN8FCLYAR6KeB2j3TR5ZeU48rNYovl3N0kiA3j3ycRkQ7DUi1iWKob+SXl+PlsDjYczkDqhZvQ/SHHBDfA4x0aYkDbcIT5erh8F11ecRkybpVYLCeTStAqgn+fREQ6DEu1iGGpbhWqK3Ds8m1sOJyBnaezUfbXGnRBXgoMbBeOxzo0RFSgJ3w93F2yi+5WURmu3bYclqRSoHWEby3UiIjIOTAs1SKGpfqhuKwC53MK8dXhDGw7kakfDO7hLkOfVqF4/G8N0TLcBwEN5C51FV1uoRqZeaUWy0kkQJuGDEtERDrWfn473SfG0qVLERUVBaVSiYSEBBw6dMhk2QcffBASiaTKbcCAAfoyo0aNqnJ/3759a+NQyME85W5o18gPrz/SCptf6IwpvZsiMsATJeUafHP8Op5bcxgvfXUc36ZdR8atYhSpK+q6yg6htfL7jhCVY76IiMg2bnVdAVts3LgR06dPx/Lly5GQkIDFixcjKSkJZ8+eRUhISJXyW7ZsQVlZmf7nmzdv4v7778dTTz1lUK5v375YvXq1/meFQlFzB0E1TukuQ9MQb0x8qCkGd4zErlPZ2Jp2HWkZedh/Phf7z+eiZZg3HmvfEA+2CEaIjxJ+Hu5OO9GlLflHiMoWJiIisp5TdcMlJCSgU6dO+OijjwAAWq0WkZGRmDx5MmbOnGnx8YsXL8bs2bORmZmJBg0ql30YNWoU8vLysHXrVrvrxW64+q1co8XNwjL8dvkWvj56DT//eQMVf80MHuKtwMB2EUhqE4rIAE8ENJA73Vp0mfklyC0os1wQQMtw73vmKkEiIktcrhuurKwMR44cQWJion6bVCpFYmIiUlNTrdrHypUrMXToUH1Q0klJSUFISAhatGiBF198ETdv3nRo3aluucukCPNVol+bcLz1RDusfS4eQzpGwlvphpwCNVb+mo6Rqw5jwfen8fPZG0jPLUJ+SbnTdFlpbaimLWWJiKiS03TD5ebmQqPRIDQ01GB7aGgozpw5Y/Hxhw4dwsmTJ7Fy5UqD7X379sXf//53NGnSBBcuXMBrr72Gfv36ITU1FTKZ8RYGtVoNtVqt/1mlsrziO9U9mVSCYG8FgrzkaBnug2c634cfT2bjm+OVY5i++z0T237PRHyTADx2fwQ6NPZDYAMF/Ov5gHCtDQlIgGmJiMhWThOWqmvlypVo27Yt4uPjDbYPHTpU//+2bduiXbt2iImJQUpKCnr37m10XwsXLsTcuXNrtL5UcyQSCQIayOHv6Y77AhrgsfYROHD+Jr79/TqOXL6Ng+m3cDD9FqICPfHo/RF4sEUIgrwUCPCSw0tR/14y1g7wBmwb30RERJXq79fluwQFBUEmkyE7O9tge3Z2NsLCwsw+tqioCBs2bMCYMWMsPk90dDSCgoJw/vx5k2VmzZqF/Px8/S0jI8O6g6B6RSKRwNfDHc1CvfFEx0Z476n78fHwv6FfmzAo3KS4dLMYS/acx6jVh/DR3vP4Lf0W/swuQG6hGpp61J9lWzdc/ak3EZGzqH9fk02Qy+WIi4vD7t27MWjQIACVA7x3796NSZMmmX3spk2boFar8cwzz1h8nqtXr+LmzZsIDw83WUahUPCKORfjpXCDl8INYb5KtG3oi5Gdo7Djjyx8fyITNwrU+Oq3DPzn6FV0jQnEI+0i0DLcG36ecgR6yeEpr9uXkS0BqB5lPCIip+E0YQkApk+fjpEjR6Jjx46Ij4/H4sWLUVRUhNGjRwMARowYgYYNG2LhwoUGj1u5ciUGDRqEwMBAg+2FhYWYO3cunnjiCYSFheHChQt45ZVX0LRpUyQlJdXacVH9oXSXITLAE6E+SjQO8sTf/9YQB87fxHe/X8cf11XYdy4X+87lommwFx5pF47uzYLh4+GGgAZy+HnKIauD6QdsGYjuLIPWiYjqE6cKS0OGDMGNGzcwe/ZsZGVloX379tixY4d+0PeVK1cglRr2LJ49exb79+/HTz/9VGV/MpkMv//+O9auXYu8vDxERESgT58+mD9/PluO7nFyNynCfT0Q4q1EuK8HHowNxpnMAmz7/Tp+/vMGzt8oxOLd57D6wCUktQ5DvzZhCPZWwM/THQENare1iVfDERHVLKeaZ6m+4jxLrk8IgfyScuQWqpGVr8ZPf2Rh+8lM5BZWzm8klQAPRFd20bWJ8IGnQgZ/z9ppbTqTpUJ5hXUv48gAD/h5ymu0PkREzsLaz2+nalkiqisSiQR+f4WfMF8PNPL3wN//1gj/vXgT35/IxIlr+Thw4SYOXLiJxgGeGNAuHA82D4GnohS+HpWtTQ1q6Eo6Wwabs2WJiMh2bFlyALYs3ZtKyzXILVQjr7gc6TeK8P2JTOw9mwN1hRYA4CmXoVdsCPq3DUekvycU7lL4e1ZOWeDIWbRPXsu3ekqACD8lAr3YxUxEBFj/+c2w5AAMS/e2Co0Wt4rKkFtYhvyScuw5k43tJ7JwLa9EX6ZdI1/0bxOOhCYBcHeTwkfpDv8G7vBWulfruYUQOHnN+klRw3yVCPZmWCIiAtgNR1Rr3GRShPgoEeSlQH5JOYK85HikXQSOZ+Th+xOZOHzpFn6/mo/fr+YjwFOOpNahSGodhsASBdzdJH+1Nskhd7O9tcnWbjV+NyIish3DEpGDSKUS+DeQw7+BHIXqCvh6uKPDff7IKSjFj39k46c/snCruAxfHs7Axt8ykNAkEP3ahOH+SD/kqNTwUrrB39MdPkp3SK0cFG7rJJOMSkREtmNYIqoBukku1RUaBHrJEeqjxNBOkfoB4X9cVyH14k2kXryJcF8l+rYOQ++WoSgsrYBUWgK/v8Y2WZqCwNawxBm8iYhsxzFLDsAxS2SJRitwq6gMt4rKUFahxeWbRdjxRxb2nslBUZkGAOAmlaBLTCD6tg5Dm4a+kEgkULpL/7oKz93oYr6l5Rqcyy60uh4BXnI09PNw2HERETkzDvCuRQxLZC0hBFSlFbhZqEaRWoPScg1+OXcD209m4XzO/0JPQz8PJLUORa/YUPh6uEMiqWyt8veUw8fDDRJJZTddcVkFLuQUWf38fp7uiAzwdPhxERE5I4alWsSwRPYoLdfgZlEZbheVQQjgfE4hfvwjCz//eQMl5YatTX1ah6FtQ19IJRJIpdB302kFkH6DYYmIyB4MS7WIYYmq4+4uuuKyCvxyLhc7Tmbh/I3/tTaF+yrxcKtQJMaGwr9B5SzcMqnEpkkpfTzc0DiwgcOPgYjIGTEs1SKGJXIEIQQK1BW4VViGgtIKAMCFG5WtTSln/9faJJUAnaIC0KdVGOIa+9u0nIqX0g1NghiWiIgAhqVaxbBEjqau0Ohbm7Tayi67/edy8dOpLJzOKtCXC2ggxws9otE5Jsiq/XoqZIgJ9qqpahMRORVOSknkxBRuMoT7eiDUW4m8knLcKlIjsVUoEluF4sqtYuw8lYU9Z3Jwq6gMXx25anVY4lcjIiLbOW6BKiJyOKlUgoAGcjQN8UZMSAP4ebqjcaAnxnSLxoLH2wIArueVWD0zNxuSiYhsx5YlIifhKXeDZ4AbwjVa3C4uBwBIABSXaZBXXK4f9G2OrcujEBERW5aInI6bTIpgbwXaNvJFxF8TTN65aK85ggueEBHZjGGJyIlFBVXOmWRtWNJqa7I2RESuiWGJyIlF/TVn0nVrwxLHLBER2YxhiciJ2dqyxKxERGQ7hiUiJxYdVDlnkrUtSwCviCMishXDEpETi/prNu7M/FKrlz3hFXFERLZhWCJyYhG+SrjLJKjQCuQUlFr1GI5bIiKyDcMSkRNzk0kR4Wvj9AHMSkRENmFYInJiEkA/1xKviCMiqhkMS0ROTCqRoKF+YkrruuGYlYiIbMOwROTEJBKgoT9bloiIahLDEpETkxi0LFm75AkREdmCYYnIyelalm4UqFFarrFYni1LRES2YVgicnK+Hm7wUrgBqJxvyRLB9eGIiGzCsETk5KQSqb4rzppxS4IdcURENmFYInJyUikQ4acEYN24Jc7gTURkG4YlIicngW2DvDlmiYjINjaHpdOnTyM5ORm9evVCTEwMwsPD0a5dO4wcORLr16+HWq2uiXrqLV26FFFRUVAqlUhISMChQ4dMll2zZg0kEonBTalUGpQRQmD27NkIDw+Hh4cHEhMTce7cuRo9BiJHqpw+wBOAdd1wDEtERLaxOiwdPXoUiYmJ6NChA/bv34+EhARMnToV8+fPxzPPPAMhBP75z38iIiICb7/9do2Epo0bN2L69OlITk7G0aNHcf/99yMpKQk5OTkmH+Pj44PMzEz97fLlywb3v/POO1iyZAmWL1+OgwcPokGDBkhKSkJpqXUT/BHVNakEaKjrhrttxfQBzEpERDZxs7bgE088gZdffhmbN2+Gn5+fyXKpqan44IMP8N577+G1115zRB313n//fYwdOxajR48GACxfvhzff/89Vq1ahZkzZxp9jEQiQVhYmNH7hBBYvHgxXn/9dTz22GMAgM8++wyhoaHYunUrhg4d6tD6E9UMCcL/Wh+uQF0BVUk5fDzcTZbmmCUiIttYHZb+/PNPuLubfgPW6dy5Mzp37ozy8vJqVexuZWVlOHLkCGbNmqXfJpVKkZiYiNTUVJOPKywsROPGjaHVavG3v/0NCxYsQOvWrQEA6enpyMrKQmJior68r68vEhISkJqayrBETkEiAZTuMgR5yZFbWIbreSUWwhLTEhGRLazuhrMmKFWnvCW5ubnQaDQIDQ012B4aGoqsrCyjj2nRogVWrVqFb775Bl988QW0Wi26dOmCq1evAoD+cbbsEwDUajVUKpXBjaiuSCUSAP9bUNfSIG+GJSIi21jdsqSTm5uLVatWITU1VR8owsLC0KVLF4waNQrBwcEOr6S9dK1cOl26dEHLli3xf//3f5g/f77d+124cCHmzp3riCoSVZvkr38b+nng96v5FsMSsxIRkW1suhru8OHDaN68OZYsWQJfX1/06NEDPXr0gK+vL5YsWYLY2Fj89ttvNVLRoKAgyGQyZGdnG2zPzs42OSbpbu7u7ujQoQPOnz8PAPrH2brPWbNmIT8/X3/LyMiw5VCIHOqvhiV9y5KlK+IYloiIbGNTy9LkyZPx1FNPYfny5ZDo3qH/IoTACy+8gMmTJ5sdQ2QvuVyOuLg47N69G4MGDQIAaLVa7N69G5MmTbJqHxqNBidOnED//v0BAE2aNEFYWBh2796N9u3bAwBUKhUOHjyIF1980eR+FAoFFApFtY6HyFF03XCN2A1HRFQjbApLx48f189ddDeJRIJp06ahQ4cODqvc3aZPn46RI0eiY8eOiI+Px+LFi1FUVKS/Om7EiBFo2LAhFi5cCACYN28eHnjgATRt2hR5eXl49913cfnyZTz//PP6Ok+dOhVvvvkmmjVrhiZNmuCNN95ARESEPpAROQt9y1J+KbRC6EPU3RiViIhsY1NYCgsLw6FDhxAbG2v0/kOHDlUZLO1IQ4YMwY0bNzB79mxkZWWhffv22LFjh/45r1y5Aqn0fz2Lt2/fxtixY5GVlQV/f3/ExcXhwIEDaNWqlb7MK6+8gqKiIowbNw55eXno1q0bduzYUWXySqL6SiqtDEWhPkrIpBKUVWiRW6hGiLfxv2G2LBER2UYihPXvnEuXLsVLL72E8ePHo3fv3vqQkp2djd27d+OTTz7BokWLMGHChBqrcH2kUqng6+uL/Px8+Pj41HV16B5zPa8ENwvLAAAvfHEE1/JKMP+xNmgf6We0vIdciqYh3rVYQyKi+snaz2+bWpYmTpyIoKAg/Pvf/8bHH38MjUYDAJDJZIiLi8OaNWswePDg6tWciGxyZ29bmK8S1/JKkK0yPQM9J6UkIrKNzVMHDBkyBEOGDEF5eTlyc3MBVF6p5uh5lYjIOneOTQrxrrzwIKfA9HJD7IUjIrKNzWFJx93dHeHh4Y6sCxHZ4c5h3LpxSjkF5lqWmJaIiGxh0zxLlly4cAG9evVy5C6JyJI70pK+ZUllumWJYYmIyDYODUuFhYX4+eefHblLIrKA3XBERDXLpm64JUuWmL3/2rVr1aoMEdnOoBvOp7Ib7laRGhUaLdxkVb8PMSwREdnGprA0depUhIeHQy6XG72/rKzMIZUiIuvd2bLk5+kON6kEFVqBm0VlCPUxMdeSVujnZyIiIvNsCkuNGzfG22+/bXJ6gLS0NMTFxTmkYkRknTunDpBKJAj2ViAzvxQ5BWrTYUkISMGwRERkDZvGLMXFxeHIkSMm75dIJLBhjksicgDJXaHnf4O8TV8Rx1cpEZH1bGpZmjdvHoqLi03e36pVK6Snp1e7UkRkPcldX3kqpw/INzvIm1fEERFZz6awdOeaasa4u7ujcePG1aoQEdnm7s60EJ/KlqUbvCKOiMghHDp1ABHVPonERDecmYkpGZaIiKzn0LD02muv4bnnnnPkLonIgrsvagvWz+LNbjgiIkewe7kTY65du4aMjAxH7pKILDA1wPtGgbryqjdJ1aveGJaIiKzn0LC0du1aR+6OiKxwdxYK8lJAKgEqtAK3i8oQ6KWo8hgtsxIRkdU4ZonIyd0dlmRSiT4gmRzkzbBERGQ1m1uWcnNzsWrVKqSmpiIrKwsAEBYWhi5dumDUqFEIDg52eCWJyLS7u+GAyq64GwVq5BSoERte9THshiMisp5NLUuHDx9G8+bNsWTJEvj6+qJHjx7o0aMHfH19sWTJEsTGxuK3336rqboSkRHGVi0JtrCgbgX74YiIrGZTy9LkyZPx1FNPYfny5VUuVxZC4IUXXsDkyZORmprq0EoSkWl3vxYB3cSUpqcPYMsSEZH1bApLx48fx5o1a4y+OUskEkybNg0dOnRwWOWIyDJjK7yFsGWJiMhhbOqGCwsLw6FDh0zef+jQIYSGhla7UkRkPamRfjhLYUmjYVgiIrKWTS1LM2bMwLhx43DkyBH07t1bH4yys7Oxe/dufPLJJ1i0aFGNVJSITJNIDGfl1nXD3SgohRCiSmtwhVZbm9UjInJqNoWliRMnIigoCP/+97/x8ccfQ6PRAABkMhni4uKwZs0aDB48uEYqSkTW0w3wLi3XoqC0Aj4e7gb3c8wSEZH1bJ46YMiQIRgyZAjKy8uRm5sLAAgKCoK7u7uFRxJRTZFKJNDcEYDkblL4ebojr7gcOQXqKmGJY5aIiKxn96SU7u7uCA8PR3h4OIMSUR0zcs0FQs1cEVfBMUtERFazOyy99dZbyMvLq/J/Iqp9xsKSubmWhKic7oOIiCyzOywtWLAAt27dqvJ/Iqp9xhbLvXNBXWPYFUdEZB27w9Kd30r5DZWobpmfa8n4xJQahiUiIqtwIV0iF2CsGy7ERzdmycRcSwxLRERWYVgicgHGlzz5q2VJxW44IqLqYFgicgHGuuF0A7wL1RUoLquocj9bloiIrMOwROQCjA3w9pS7wUtROZWasUHeDEtERNZxSFgy1gVQU5YuXYqoqCgolUokJCSYXavuk08+Qffu3eHv7w9/f38kJiZWKT9q1ChIJBKDW9++fWv6MIgcytRL0NwacQxLRETWcUhYqq2r4TZu3Ijp06cjOTkZR48exf3334+kpCTk5OQYLZ+SkoJhw4Zh7969SE1NRWRkJPr06YNr164ZlOvbty8yMzP1ty+//LI2DofIYSRGO+KAEB/TYYnrwxERWcfusHTq1ClERUXp/9+4cWNH1cmk999/H2PHjsXo0aPRqlUrLF++HJ6enli1apXR8uvWrcOECRPQvn17xMbG4tNPP4VWq8Xu3bsNyikUCoSFhelv/v7+NX4sRI5kumXpryviVFWnD2BWIiKyjt1hKTIyElKpVP9/mUzmsEoZU1ZWhiNHjiAxMVG/TSqVIjExEampqVbto7i4GOXl5QgICDDYnpKSgpCQELRo0QIvvvgibt686dC6E9U0U2HJ3CzebFkiIrKOXWFJJpMZ7fq6efNmjYWm3NxcaDQahIaGGmwPDQ1FVlaWVft49dVXERERYRC4+vbti88++wy7d+/G22+/jZ9//hn9+vWDRqMxuR+1Wg2VSmVwI6pLpsYNmpvFm2OWiIis42bPg0yNUVKr1ZDL5dWqUE156623sGHDBqSkpECpVOq3Dx06VP//tm3bol27doiJiUFKSgp69+5tdF8LFy7E3Llza7zORNaSWuqGM7aYLsMSEZFVbApLS5YsAVD5LfbTTz+Fl5eX/j6NRoN9+/YhNjbWsTX8S1BQEGQyGbKzsw22Z2dnIywszOxjFy1ahLfeegu7du1Cu3btzJaNjo5GUFAQzp8/bzIszZo1C9OnT9f/rFKpEBkZaeWREDmeqQHeum6428XlKNdo4S77X2MyW5aIiKxjU1j697//DaCyZWn58uUGXW5yuRxRUVFYvny5Y2t4x/7j4uKwe/duDBo0CAD0g7UnTZpk8nHvvPMO/vWvf+HHH39Ex44dLT7P1atXcfPmTYSHh5sso1AooFAobD4GoppiasySj9INcjcpyiq0yC1UI9zXQ3+fEIBWKyA11SxFREQAbAxL6enpAICHHnoIW7ZsqfWrxqZPn46RI0eiY8eOiI+Px+LFi1FUVITRo0cDAEaMGIGGDRti4cKFAIC3334bs2fPxvr16xEVFaUf2+Tl5QUvLy8UFhZi7ty5eOKJJxAWFoYLFy7glVdeQdOmTZGUlFSrx0ZUHabCkkQiQYi3AldvlyCnwDAsAZVdcXKGJSIis+was7R3715H18MqQ4YMwY0bNzB79mxkZWWhffv22LFjh37Q95UrV/RX6AHAsmXLUFZWhieffNJgP8nJyZgzZw5kMhl+//13rF27Fnl5eYiIiECfPn0wf/58thyRUzHVDQcAwV6VYcnYIG9tLc2RRkTkzCTCwTNKzps3Dw899BC6d+/uyN3WayqVCr6+vsjPz4ePj09dV4fuQTcL1bieV3UQNwB8tOccfjyVjafj78Ow+PsM7msS3EC/JAoR0b3G2s9vh68Nt3r1aiQlJWHgwIGO3jURmWBuyaFgc9MHaNiyRERkicO/Uqanp6OkpKTOuuqI7kXmRh3pw1KhkbDEbjgiIosc3rIEAB4eHujfv39N7JqIjJCabVkyveQJZ/EmIrLMrrA0Z84caI28yebn52PYsGHVrhQR2chM09KdLUt3D1HkXEtERJbZFZZWrlyJbt264eLFi/ptKSkpaNu2LS5cuOCwyhGRdcw0LCGogRwSAOUagbyScoP7GJaIiCyzKyz9/vvvaNSoEdq3b49PPvkEL7/8Mvr06YNnn30WBw4ccHQdicgCc91wbjIpAhpULkN09yBvhiUiIsvsGuDt7++Pr776Cq+99hrGjx8PNzc3/PDDDyaXByGimmVpWslgbwVuFpXhRoEazUO99du5PhwRkWV2D/D+8MMP8cEHH2DYsGGIjo7GlClTcPz4cUfWjYisZK5lCQBCTEwfwJYlIiLL7ApLffv2xdy5c7F27VqsW7cOx44dQ48ePfDAAw/gnXfecXQdicgCC1nJ5PQBDEtERJbZFZY0Gg1+//13/TIiHh4eWLZsGTZv3qxfbJeI6o9gr8qwlFNgOH0AwxIRkWV2jVnauXOn0e0DBgzAiRMnqlUhIrKdpW443VxLd3fDCQFotQJSLqZLRGSS1S1L1i4hFxQUZHdliMg+VnfDGVnyhIO8iYjMszostW7dGhs2bEBZWZnZcufOncOLL76It956q9qVIyLrWGoX0g3wVpVWoLRcY3Afu+KIiMyzuhvuww8/xKuvvooJEybg4YcfRseOHREREQGlUonbt2/j1KlT2L9/P/744w9MmjQJL774Yk3Wm4juYKkbroHCDZ5yGYrLNLhRqEakv6f+vsolT2Q1XEMiIudldVjq3bs3fvvtN+zfvx8bN27EunXrcPnyZZSUlCAoKAgdOnTAiBEjMHz4cPj7+9dknYnoLpa64YDKQd6XbxXjhsowLHF5OCIi82we4N2tWzd069atJupCRHaSWJGWgr3/Ckt3TR/AxXSJiMyz62q4efPmmb1/9uzZdlWGiOwnkVRe3WaKqUHeHLNERGSeXWHp66+/Nvi5vLwc6enpcHNzQ0xMDMMSUR2wFJZC/po+oMpcS1Ze6UpEdK+yKywdO3asyjaVSoVRo0bh8ccfr3aliMh2EkgAmA4+plqWKjQMS0RE5ti9NtzdfHx8MHfuXLzxxhuO2iUR2UBq4dXMJU+IiOzjsLAEAPn5+cjPz3fkLonIShILsy3p5lrKLSwzCEiclJKIyDy7uuGWLFli8LMQApmZmfj888/Rr18/h1SMiGxj6YI4f085ZFIJNFqBvOIyBP61XpyWY5aIiMyyKyzdvViuVCpFcHAwRo4ciVmzZjmkYkRkG0vLu8mkEgQ2kCOnQI2cArU+LHHMEhGReXaFpfT0dEfXg4iqzbq5lnIK1LhRoEbL8MptHLNERGSeQ8csEVHdsdSyBHCQNxGRPRiWiFyENbN4/2+uJc7iTURkLYYlIhdhRcMSgr10cy3dNTElW5aIiExiWCJyEVKrWpa45AkRka0YlohchBVZievDERHZgWGJ6B6iC0tFZRoUqSv02zkxJRGRaQxLRC5CasXlcEp3GbyVlTOG3Nm6pGVYIiIyiWGJyEVYM8AbMD59AFuWiIhMc7qwtHTpUkRFRUGpVCIhIQGHDh0yW37Tpk2IjY2FUqlE27ZtsX37doP7hRCYPXs2wsPD4eHhgcTERJw7d64mD4GoRlgzwBsAwn0qpw/YeDgDt4vLAHDMEhGROU4VljZu3Ijp06cjOTkZR48exf3334+kpCTk5OQYLX/gwAEMGzYMY8aMwbFjxzBo0CAMGjQIJ0+e1Jd55513sGTJEixfvhwHDx5EgwYNkJSUhNLSUqP7JKqvrMxKeDIuEl4KN5zNLsCMTcdx+WYRW5aIiMyQCOE8q2gmJCSgU6dO+OijjwAAWq0WkZGRmDx5MmbOnFml/JAhQ1BUVIRt27bptz3wwANo3749li9fDiEEIiIi8NJLL2HGjBkAgPz8fISGhmLNmjUYOnSoVfVSqVTw9fVFfn4+fHx8HHCkRLbLUZUiW6W2XBDAtdslmLftD1zPL4WnXIY3HmmFYfH31XANiYjqF2s/v+1aG64ulJWV4ciRIwYL9UqlUiQmJiI1NdXoY1JTUzF9+nSDbUlJSdi6dSuAyjXusrKykJiYqL/f19cXCQkJSE1NNRmW1Go11Or/fSipVCp7D4vIYayZwVunob8H3n3yfiz44TT+uK7CP78+gbQrefCQy2qwhkRE9nt9QEu4yeqmQ8xpwlJubi40Gg1CQ0MNtoeGhuLMmTNGH5OVlWW0fFZWlv5+3TZTZYxZuHAh5s6da/MxENUkG7ISAMDHwx3zH2uDj/aex54zOdj4W0bNVIyIyAFe69+yzp7bacJSfTJr1iyDFiuVSoXIyMg6rBGR9VfD3cldJsXU3s2QEB2AgpIKyw8gIqoj1iwWXlOcJiwFBQVBJpMhOzvbYHt2djbCwsKMPiYsLMxsed2/2dnZCA8PNyjTvn17k3VRKBRQKBT2HAZRjbH2ari7SSQSJLYMRUywl4NrRETkGpzmaji5XI64uDjs3r1bv02r1WL37t3o3Lmz0cd07tzZoDwA7Ny5U1++SZMmCAsLMyijUqlw8OBBk/skqq/szEoAALe6/MpGRFTPOU3LEgBMnz4dI0eORMeOHREfH4/FixejqKgIo0ePBgCMGDECDRs2xMKFCwEA//jHP9CzZ0+89957GDBgADZs2IDffvsNK1asAFD5jXrq1Kl488030axZMzRp0gRvvPEGIiIiMGjQoLo6TCK7SOzqiKskY1giIjLJqcLSkCFDcOPGDcyePRtZWVlo3749duzYoR+gfeXKFUil/2ss69KlC9avX4/XX38dr732Gpo1a4atW7eiTZs2+jKvvPIKioqKMG7cOOTl5aFbt27YsWMHlEplrR8fUXVIqtFO7F5HV5gQETkDp5pnqb7iPEtUHxSUluNSbrFdjw33UyLIi+PwiOjeYu3nN79OErkIewd4AxyzRERkDsMSkYuozgBvjlkiIjKNYYnIRVRngDfHLBERmcZ3SCIXwZYlIqKawbBE5CI4zxIRUc1gWCJyEfZ2w0mlti3CS0R0r2FYInIR9jYOuUn5NkBEZA7fJYlchL2tQxyvRERkHsMSkYuwN/O4yxiWiIjMYVgichFsWSIiqhkMS0QuxJ68xDFLRETm8V2S6B7HliUiIvMYlohciD3rw3HMEhGReQxLRC7Enm44tiwREZnHsETkQuxpWeKYJSIi8/guSeRC2LJEROR4DEtELsSe2MN14YiIzGNYInIhts61JJUCUoYlIiKzGJaIXIit3XAcr0REZBnfKYlciK1tRByvRERkGcMSkQux9Wo4jlciIrKMYYnIhdjaDceWJSIiyxiWiFyIxMaOOHcZ3wKIiCzhOyWRC2HLEhGR4zEsEbkQ26+GY1giIrKEYYnIhdg6wFvGRXSJiCxiWCJyIba2LLlzniUiIov4TknkQmwd4M0xS0REljEsEbkQW7MPxywREVnGsETkSmzIPhIJ14UjIrIGwxKRC7GlG86Ng7uJiKzCsETkQmxpKGIXHBGRdZwmLN26dQvDhw+Hj48P/Pz8MGbMGBQWFpotP3nyZLRo0QIeHh647777MGXKFOTn5xuUk0gkVW4bNmyo6cMhqhESGy6Hc+OVcEREVnGr6wpYa/jw4cjMzMTOnTtRXl6O0aNHY9y4cVi/fr3R8tevX8f169exaNEitGrVCpcvX8YLL7yA69evY/PmzQZlV69ejb59++p/9vPzq8lDIaoxtjQW8Uo4IiLrSIQQoq4rYcnp06fRqlUrHD58GB07dgQA7NixA/3798fVq1cRERFh1X42bdqEZ555BkVFRXBzq8yJEokEX3/9NQYNGmR3/VQqFXx9fZGfnw8fHx+790NUXfnF5bhyq9iqskHecoT7etRwjYiI6i9rP7+doh0+NTUVfn5++qAEAImJiZBKpTh48KDV+9GdDF1Q0pk4cSKCgoIQHx+PVatWwVJ+VKvVUKlUBjeieoEtS0REDucU3XBZWVkICQkx2Obm5oaAgABkZWVZtY/c3FzMnz8f48aNM9g+b9489OrVC56envjpp58wYcIEFBYWYsqUKSb3tXDhQsydO9f2AyGqYbbkH87eTURknTp9t5w5c6bRAdZ33s6cOVPt51GpVBgwYABatWqFOXPmGNz3xhtvoGvXrujQoQNeffVVvPLKK3j33XfN7m/WrFnIz8/X3zIyMqpdRyJHsGWAN9eFIyKyTp22LL300ksYNWqU2TLR0dEICwtDTk6OwfaKigrcunULYWFhZh9fUFCAvn37wtvbG19//TXc3d3Nlk9ISMD8+fOhVquhUCiMllEoFCbvI6pLtsQfTh1ARGSdOg1LwcHBCA4Otliuc+fOyMvLw5EjRxAXFwcA2LNnD7RaLRISEkw+TqVSISkpCQqFAt9++y2USqXF50pLS4O/vz/DEDklqS0tSwxLRERWcYoxSy1btkTfvn0xduxYLF++HOXl5Zg0aRKGDh2qvxLu2rVr6N27Nz777DPEx8dDpVKhT58+KC4uxhdffGEwEDs4OBgymQzfffcdsrOz8cADD0CpVGLnzp1YsGABZsyYUZeHS2Q3G7ISxywREVnJKcISAKxbtw6TJk1C7969IZVK8cQTT2DJkiX6+8vLy3H27FkUF1deNn306FH9lXJNmzY12Fd6ejqioqLg7u6OpUuXYtq0aRBCoGnTpnj//fcxduzY2jswojrAdeGIiKznFPMs1XecZ4nqi7IKLc5mFVgs5+4mQWwY/1aJ6N7mUvMsEZF1rO2G4+BuIiLrMSwRuRBrB3jLOF6JiMhqfMckciHWthexZYmIyHoMS0QuxOpuOE5ISURkNYYlIhdi7QzenGOJiMh6DEtELsaavOTGMUtERFbjOyaRi7EmLLFliYjIegxLRC7GmiviOMCbiMh6DEtELoYtS0REjsWwRORiJFZMIMCWJSIi6zEsEbkYa3IQW5aIiKzHsETkYix1w8mkEqunGCAiIoYlIhdkPghxQkoiItswLBG5GEs9bOyCIyKyDcMSkYuxFIY4uJuIyDYMS0Quxk1m/mXNliUiItswLBG5GHeLLUt82RMR2YLvmkQuxlLLEVuWiIhsw7BE5GIsdcNxzBIRkW0YlohcjLuFqQFknDqAiMgmDEtELoZXwxERORbDEpGLcbcwgJtjloiIbMOwRORipFKJ2SVPeDUcEZFt+K5J5ILcTQzylkjYskREZCuGJSIXZGr9NwYlIiLbMSwRuSBTg7g5uJuIyHYMS0QuyNRcS2xZIiKyHcMSkQsyteQJB3cTEdmO75xELshUCxInpCQish3DEpELMtUNxzFLRES2Y1gickGmljzhmCUiItsxLBG5IFOhiC1LRES2c5qwdOvWLQwfPhw+Pj7w8/PDmDFjUFhYaPYxDz74ICQSicHthRdeMChz5coVDBgwAJ6enggJCcHLL7+MioqKmjwUohpnaskTtiwREdnOra4rYK3hw4cjMzMTO3fuRHl5OUaPHo1x48Zh/fr1Zh83duxYzJs3T/+zp6en/v8ajQYDBgxAWFgYDhw4gMzMTIwYMQLu7u5YsGBBjR0LUU3TLXkihOF2Xg1HRGQ7p3jnPH36NHbs2IFPP/0UCQkJ6NatGz788ENs2LAB169fN/tYT09PhIWF6W8+Pj76+3766SecOnUKX3zxBdq3b49+/fph/vz5WLp0KcrKymr6sIhqlLElT9iyRERkO6cIS6mpqfDz80PHjh312xITEyGVSnHw4EGzj123bh2CgoLQpk0bzJo1C8XFxQb7bdu2LUJDQ/XbkpKSoFKp8Mcff5jcp1qthkqlMrgR1TfGljzhmCUiIts5RTdcVlYWQkJCDLa5ubkhICAAWVlZJh/39NNPo3HjxoiIiMDvv/+OV199FWfPnsWWLVv0+70zKAHQ/2xuvwsXLsTcuXPtPRyiWnF3MJJIKrvniIjINnUalmbOnIm3337bbJnTp0/bvf9x48bp/9+2bVuEh4ejd+/euHDhAmJiYuze76xZszB9+nT9zyqVCpGRkXbvj6gm3D3XkqnFdYmIyLw6DUsvvfQSRo0aZbZMdHQ0wsLCkJOTY7C9oqICt27dQlhYmNXPl5CQAAA4f/48YmJiEBYWhkOHDhmUyc7OBgCz+1UoFFAoFFY/L1FduHvJE3bBERHZp07DUnBwMIKDgy2W69y5M/Ly8nDkyBHExcUBAPbs2QOtVqsPQNZIS0sDAISHh+v3+69//Qs5OTn6br6dO3fCx8cHrVq1svFoiOqXuwdzy3glHBGRXZzi3bNly5bo27cvxo4di0OHDuHXX3/FpEmTMHToUERERAAArl27htjYWH1L0YULFzB//nwcOXIEly5dwrfffosRI0agR48eaNeuHQCgT58+aNWqFZ599lkcP34cP/74I15//XVMnDiRLUfk9Kp0w7FliYjILk4RloDKq9piY2PRu3dv9O/fH926dcOKFSv095eXl+Ps2bP6q93kcjl27dqFPn36IDY2Fi+99BKeeOIJfPfdd/rHyGQybNu2DTKZDJ07d8YzzzyDESNGGMzLROSs7l7yhNMGEBHZRyLE3dPWka1UKhV8fX2Rn59vMI8TUV1SV2jwZ9b/ZrkP9VEgxEdZhzUiIqpfrP38dpqWJSKyzd1LnrBliYjIPgxLRC5Kt+SJDpc6ISKyD989iVzYnUueyDjPEhGRXRiWiFzYnRNR8mo4IiL7MCwRubA7AxLHLBER2YdhiciF3TnXEluWiIjsw7BE5MJ0S55IpYBEwrBERGQPhiUiF6breuOVcERE9uM7KJEL03XDcbwSEZH9GJaIXJhuyROOVyIish/DEpEL07UosWWJiMh+DEtELky35IkbJ6QkIrIbwxKRC9MtecKWJSIi+zEsEbk4d5mUV8MREVUD30GJXJybTMKWJSKiamBYInJxblIJr4YjIqoGhiUiF+cmk7JliYioGhiWiFycO1uWiIiqhWGJyMWxZYmIqHoYlohcnMJNykV0iYiqgWGJyMUp3PgyJyKqDr6LErk43WK6RERkH76LEhEREZnBsERERERkBsMSERERkRkMS0RERERmMCwRERERmcGwRERERGQGwxIRERGRGQxLRERERGYwLBERERGZwbBEREREZIbThKVbt25h+PDh8PHxgZ+fH8aMGYPCwkKT5S9dugSJRGL0tmnTJn05Y/dv2LChNg6JiIiInIBbXVfAWsOHD0dmZiZ27tyJ8vJyjB49GuPGjcP69euNlo+MjERmZqbBthUrVuDdd99Fv379DLavXr0affv21f/s5+fn8PoTERGRc3KKsHT69Gns2LEDhw8fRseOHQEAH374Ifr3749FixYhIiKiymNkMhnCwsIMtn399dcYPHgwvLy8DLb7+flVKUtEREQEOEk3XGpqKvz8/PRBCQASExMhlUpx8OBBq/Zx5MgRpKWlYcyYMVXumzhxIoKCghAfH49Vq1ZBCGF2X2q1GiqVyuBGRERErskpWpaysrIQEhJisM3NzQ0BAQHIysqyah8rV65Ey5Yt0aVLF4Pt8+bNQ69eveDp6YmffvoJEyZMQGFhIaZMmWJyXwsXLsTcuXNtPxAiIiJyOnUalmbOnIm3337bbJnTp09X+3lKSkqwfv16vPHGG1Xuu3Nbhw4dUFRUhHfffddsWJo1axamT5+u/zk/Px/33XcfW5iIiIiciO5z21KPUp2GpZdeegmjRo0yWyY6OhphYWHIyckx2F5RUYFbt25ZNdZo8+bNKC4uxogRIyyWTUhIwPz586FWq6FQKIyWUSgUBvfpTnZkZKTF/RMREVH9UlBQAF9fX5P312lYCg4ORnBwsMVynTt3Rl5eHo4cOYK4uDgAwJ49e6DVapGQkGDx8StXrsSjjz5q1XOlpaXB39/fZFAyJiIiAhkZGfD29oZEIrH6cZaoVCpERkYiIyMDPj4+DtsvGeJ5rh08z7WH57p28DzXjpo8z0IIFBQUGL1Q7E5OMWapZcuW6Nu3L8aOHYvly5ejvLwckyZNwtChQ/UHeO3aNfTu3RufffYZ4uPj9Y89f/489u3bh+3bt1fZ73fffYfs7Gw88MADUCqV2LlzJxYsWIAZM2bYVD+pVIpGjRpV7yDN8PHx4QuxFvA81w6e59rDc107eJ5rR02dZ3MtSjpOEZYAYN26dZg0aRJ69+4NqVSKJ554AkuWLNHfX15ejrNnz6K4uNjgcatWrUKjRo3Qp0+fKvt0d3fH0qVLMW3aNAgh0LRpU7z//vsYO3ZsjR8PEREROQeJsDSqieqMSqWCr68v8vPz+a2lBvE81w6e59rDc107eJ5rR304z04xz9K9SqFQIDk52abxU2Q7nufawfNce3iuawfPc+2oD+eZLUtEREREZrBliYiIiMgMhiUiIiIiMxiWiIiIiMxgWCIiIiIyg2Gpji1duhRRUVFQKpVISEjAoUOHzJbftGkTYmNjoVQq0bZtW6OTbVJVtpznTz75BN27d4e/vz/8/f2RmJho8fdClWz9e9bZsGEDJBIJBg0aVLMVdBG2nue8vDxMnDgR4eHhUCgUaN68Od87rGTruV68eDFatGgBDw8PREZGYtq0aSgtLa2l2jqnffv2YeDAgYiIiIBEIsHWrVstPiYlJQV/+9vfoFAo0LRpU6xZs6ZmKymozmzYsEHI5XKxatUq8ccff4ixY8cKPz8/kZ2dbbT8r7/+KmQymXjnnXfEqVOnxOuvvy7c3d3FiRMnarnmzsXW8/z000+LpUuXimPHjonTp0+LUaNGCV9fX3H16tVarrlzsfU866Snp4uGDRuK7t27i8cee6x2KuvEbD3ParVadOzYUfTv31/s379fpKeni5SUFJGWllbLNXc+tp7rdevWCYVCIdatWyfS09PFjz/+KMLDw8W0adNquebOZfv27eKf//yn2LJliwAgvv76a7PlL168KDw9PcX06dPFqVOnxIcffihkMpnYsWNHjdWRYakOxcfHi4kTJ+p/1mg0IiIiQixcuNBo+cGDB4sBAwYYbEtISBDjx4+v0Xo6O1vP890qKiqEt7e3WLt2bU1V0SXYc54rKipEly5dxKeffipGjhzJsGQFW8/zsmXLRHR0tCgrK6utKroMW8/1xIkTRa9evQy2TZ8+XXTt2rVG6+lKrAlLr7zyimjdurXBtiFDhoikpKQaqxe74epIWVkZjhw5gsTERP02qVSKxMREpKamGn1MamqqQXkASEpKMlme7DvPdysuLkZ5eTkCAgJqqppOz97zPG/ePISEhGDMmDG1UU2nZ895/vbbb9G5c2dMnDgRoaGhaNOmDRYsWACNRlNb1XZK9pzrLl264MiRI/quuosXL2L79u3o379/rdT5XlEXn4VOszacq8nNzYVGo0FoaKjB9tDQUJw5c8boY7KysoyWz8rKqrF6Ojt7zvPdXn31VURERFR5cdL/2HOe9+/fj5UrVyItLa0Wauga7DnPFy9exJ49ezB8+HBs374d58+fx4QJE1BeXo7k5OTaqLZTsudcP/3008jNzUW3bt0ghEBFRQVeeOEFvPbaa7VR5XuGqc9ClUqFkpISeHh4OPw52bJEZMZbb72FDRs24Ouvv4ZSqazr6riMgoICPPvss/jkk08QFBRU19VxaVqtFiEhIVixYgXi4uIwZMgQ/POf/8Ty5cvrumouJyUlBQsWLMDHH3+Mo0ePYsuWLfj+++8xf/78uq4aVRNblupIUFAQZDIZsrOzDbZnZ2cjLCzM6GPCwsJsKk/2nWedRYsW4a233sKuXbvQrl27mqym07P1PF+4cAGXLl3CwIED9du0Wi0AwM3NDWfPnkVMTEzNVtoJ2fP3HB4eDnd3d8hkMv22li1bIisrC2VlZZDL5TVaZ2dlz7l+44038Oyzz+L5558HALRt2xZFRUUYN24c/vnPf0IqZfuEI5j6LPTx8amRViWALUt1Ri6XIy4uDrt379Zv02q12L17Nzp37mz0MZ07dzYoDwA7d+40WZ7sO88A8M4772D+/PnYsWMHOnbsWBtVdWq2nufY2FicOHECaWlp+tujjz6Khx56CGlpaYiMjKzN6jsNe/6eu3btivPnz+vDKAD8+eefCA8PZ1Ayw55zXVxcXCUQ6UKq4DKsDlMnn4U1NnScLNqwYYNQKBRizZo14tSpU2LcuHHCz89PZGVlCSGEePbZZ8XMmTP15X/99Vfh5uYmFi1aJE6fPi2Sk5M5dYAVbD3Pb731lpDL5WLz5s0iMzNTfysoKKirQ3AKtp7nu/FqOOvYep6vXLkivL29xaRJk8TZs2fFtm3bREhIiHjzzTfr6hCchq3nOjk5WXh7e4svv/xSXLx4Ufz0008iJiZGDB48uK4OwSkUFBSIY8eOiWPHjgkA4v333xfHjh0Tly9fFkIIMXPmTPHss8/qy+umDnj55ZfF6dOnxdKlSzl1gKv78MMPxX333SfkcrmIj48X//3vf/X39ezZU4wcOdKg/FdffSWaN28u5HK5aN26tfj+++9rucbOyZbz3LhxYwGgyi05Obn2K+5kbP17vhPDkvVsPc8HDhwQCQkJQqFQiOjoaPGvf/1LVFRU1HKtnZMt57q8vFzMmTNHxMTECKVSKSIjI8WECRPE7du3a7/iTmTv3r1G33N153bkyJGiZ8+eVR7Tvn17IZfLRXR0tFi9enWN1lEiBNsGiYiIiEzhmCUiIiIiMxiWiIiIiMxgWCIiIiIyg2GJiIiIyAyGJSIiIiIzGJaIiIiIzGBYIiIiIjKDYYmIiIjIDIYlIiIiIjMYloiIiIjMYFgiIrrLjRs3EBYWhgULFui3HThwAHK5vMpq50Tk+rg2HBGREdu3b8egQYNw4MABtGjRAu3bt8djjz2G999/v66rRkS1jGGJiMiEiRMnYteuXejYsSNOnDiBw4cPQ6FQ1HW1iKiWMSwREZlQUlKCNm3aICMjA0eOHEHbtm3rukpEVAc4ZomIyIQLFy7g+vXr0Gq1uHTpUl1Xh4jqCFuWiIiMKCsrQ3x8PNq3b48WLVpg8eLFOHHiBEJCQuq6akRUyxiWiIiMePnll7F582YcP34cXl5e6NmzJ3x9fbFt27a6rhoR1TJ2wxER3SUlJQWLFy/G559/Dh8fH0ilUnz++ef45ZdfsGzZsrquHhHVMrYsEREREZnBliUiIiIiMxiWiIiIiMxgWCIiIiIyg2GJiIiIyAyGJSIiIiIzGJaIiIiIzGBYIiIiIjKDYYmIiIjIDIYlIiIiIjMYloiIiIjMYFgiIiIiMoNhiYiIiMiM/weNKZXxh0I0pwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 2\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Plotting mean and variance for {dataset}\".format(k = np.mean(dataset_params), dataset = dataset))\n",
    "    plt.xlabel(\"x\")\n",
    "    mu =  mu_true[:,t_idx,:].squeeze(-1)\n",
    "    plt.plot(grid, mu)\n",
    "    std = torch.sqrt(var_true[:,t_idx,:]).squeeze(-1)\n",
    "    print(std)\n",
    "    plt.fill_between(grid, mu + 3*std, mu - 3*std, alpha = 0.2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ac0b8967",
   "metadata": {},
   "source": [
    "## Running VarianceNO out of the box"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 204,
   "id": "6fd587e6-4cf8-4cc4-92bd-ac09c7be790a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function datasets.StefanPME_1D.get_mass_rhs_func.<locals>.mass_rhs_func(inputs)>"
      ]
     },
     "execution_count": 204,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func(x=x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 205,
   "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": 206,
   "id": "b339b6e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 206,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 207,
   "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": 208,
   "id": "d71ec298-4bbc-4186-a938-8675f0526890",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 209,
   "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": 209,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "id": "2165975d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, -1, 5]"
      ]
     },
     "execution_count": 210,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tpred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 211,
   "id": "1ad2c532",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0, -1,  5])"
      ]
     },
     "execution_count": 211,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.tensor(tpred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 212,
   "id": "18a1c208-a4df-4f27-8dad-f2466164e855",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 212,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 213,
   "id": "6ff40f4d-d8b7-45f7-8e3a-8115564540df",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=16.109852, Validation loss=-294.001013 (saved)\n",
      "Epoch 1: Train loss=-558.559494, Validation loss=-905.707178 (saved)\n",
      "Epoch 2: Train loss=-1243.330542, Validation loss=-1750.230078 (saved)\n",
      "Epoch 3: Train loss=-2382.025244, Validation loss=-3684.852344 (saved)\n",
      "Epoch 4: Train loss=-5612.254980, Validation loss=-8276.633594 (saved)\n",
      "Epoch 5: Train loss=-8251.977588, Validation loss=-8590.890625 (saved)\n",
      "Epoch 6: Train loss=-9634.434570, Validation loss=-10985.526172 (saved)\n",
      "Epoch 7: Train loss=-9857.734570, Validation loss=-10068.766406 \n",
      "Epoch 8: Train loss=-11060.187695, Validation loss=-12285.321484 (saved)\n",
      "Epoch 9: Train loss=-9683.133923, Validation loss=-5351.347070 \n",
      "Epoch 10: Train loss=-9369.853027, Validation loss=-9717.238672 \n",
      "Epoch 11: Train loss=-9448.533301, Validation loss=-9560.705469 \n",
      "Epoch 12: Train loss=-9997.585254, Validation loss=-10616.091016 \n",
      "Epoch 13: Train loss=-11505.741504, Validation loss=-12617.497656 (saved)\n",
      "Epoch 14: Train loss=-12426.182666, Validation loss=46890.792188 \n",
      "Epoch 15: Train loss=7609.768213, Validation loss=-6310.899219 \n",
      "Epoch 16: Train loss=-6202.454150, Validation loss=-6183.077734 \n",
      "Epoch 17: Train loss=-6010.627100, Validation loss=-5827.142578 \n",
      "Epoch 18: Train loss=-5779.718799, Validation loss=-5774.749805 \n",
      "Epoch 19: Train loss=-5831.574609, Validation loss=-5929.213477 \n",
      "Epoch 20: Train loss=-6025.809570, Validation loss=-6158.161523 \n",
      "Epoch 21: Train loss=-6267.134424, Validation loss=-6413.819141 \n",
      "Epoch 22: Train loss=-6534.601709, Validation loss=-6697.730078 \n",
      "Epoch 23: Train loss=-6829.728223, Validation loss=-7007.451563 \n",
      "Epoch 24: Train loss=-7149.673340, Validation loss=-7342.400781 \n",
      "Epoch 25: Train loss=-7497.005371, Validation loss=-7707.017969 \n",
      "Epoch 26: Train loss=-7874.979492, Validation loss=-8104.087891 \n",
      "Epoch 27: Train loss=-8288.237988, Validation loss=-8541.443359 \n",
      "Epoch 28: Train loss=-8744.833203, Validation loss=-9026.926172 \n",
      "Epoch 29: Train loss=-9254.328906, Validation loss=-9573.677344 \n",
      "Epoch 30: Train loss=-9832.200098, Validation loss=-10201.434766 \n",
      "Epoch 31: Train loss=-10504.380957, Validation loss=-10942.194922 \n",
      "Epoch 32: Train loss=-11309.211523, Validation loss=-11851.515625 \n",
      "Epoch 33: Train loss=-12315.101660, Validation loss=-13018.414844 (saved)\n",
      "Epoch 34: Train loss=-13631.967188, Validation loss=-14490.036719 (saved)\n",
      "Epoch 35: Train loss=-2500.608801, Validation loss=-10014.932812 \n",
      "Epoch 36: Train loss=-9606.659180, Validation loss=-9702.233594 \n",
      "Epoch 37: Train loss=-9342.532617, Validation loss=-8908.196875 \n",
      "Epoch 38: Train loss=-9065.934180, Validation loss=-9291.832813 \n",
      "Epoch 39: Train loss=-9349.169531, Validation loss=-9501.132422 \n",
      "Epoch 40: Train loss=-9716.012207, Validation loss=-9971.356250 \n",
      "Epoch 41: Train loss=-10179.359961, Validation loss=-10498.612109 \n",
      "Epoch 42: Train loss=-10735.463281, Validation loss=-11086.453516 \n",
      "Epoch 43: Train loss=-11357.156934, Validation loss=-11749.294141 \n",
      "Epoch 44: Train loss=-12054.692969, Validation loss=-12492.019922 \n",
      "Epoch 45: Train loss=-12837.092480, Validation loss=-13332.653906 \n",
      "Epoch 46: Train loss=-13718.680859, Validation loss=-14282.403125 \n",
      "Epoch 47: Train loss=-14700.900391, Validation loss=-15323.432031 (saved)\n",
      "Epoch 48: Train loss=11068.570398, Validation loss=51424.190625 \n",
      "Epoch 49: Train loss=1861.729932, Validation loss=-6276.054688 \n",
      "Epoch 50: Train loss=-6075.529785, Validation loss=-6104.144336 \n",
      "Epoch 51: Train loss=-6234.085742, Validation loss=-6382.467383 \n",
      "Epoch 52: Train loss=-6460.457275, Validation loss=-6548.528125 \n",
      "Epoch 53: Train loss=-6601.448242, Validation loss=-6668.140234 \n",
      "Epoch 54: Train loss=-6713.737988, Validation loss=-6773.317578 \n",
      "Epoch 55: Train loss=-6815.219336, Validation loss=-6870.757422 \n",
      "Epoch 56: Train loss=-6910.413672, Validation loss=-6963.946875 \n",
      "Epoch 57: Train loss=-7003.008008, Validation loss=-7056.577734 \n",
      "Epoch 58: Train loss=-7096.049023, Validation loss=-7150.455469 \n",
      "Epoch 59: Train loss=-7190.410840, Validation loss=-7245.678125 \n",
      "Epoch 60: Train loss=-7285.997852, Validation loss=-7341.997266 \n",
      "Epoch 61: Train loss=-7382.673535, Validation loss=-7439.543750 \n",
      "Epoch 62: Train loss=-7480.724707, Validation loss=-7538.588281 \n",
      "Epoch 63: Train loss=-7580.347949, Validation loss=-7639.398438 \n",
      "Epoch 64: Train loss=-7681.801074, Validation loss=-7742.128125 \n",
      "Epoch 65: Train loss=-7785.296582, Validation loss=-7846.862891 \n",
      "Epoch 66: Train loss=-7890.815527, Validation loss=-7953.793359 \n",
      "Epoch 67: Train loss=-7998.496484, Validation loss=-8063.084375 \n",
      "Epoch 68: Train loss=-8108.620508, Validation loss=-8174.770312 \n",
      "Epoch 69: Train loss=-8221.246387, Validation loss=-8288.945703 \n",
      "Epoch 70: Train loss=-8336.351953, Validation loss=-8405.841406 \n",
      "Epoch 71: Train loss=-8454.235352, Validation loss=-8525.551563 \n",
      "Epoch 72: Train loss=-8574.881055, Validation loss=-8648.296484 \n",
      "Epoch 73: Train loss=-8698.773242, Validation loss=-8774.053125 \n",
      "Epoch 74: Train loss=-8825.709570, Validation loss=-8903.084766 \n",
      "Epoch 75: Train loss=-8955.871973, Validation loss=-9035.703906 \n",
      "Epoch 76: Train loss=-9089.707227, Validation loss=-9171.920313 \n",
      "Epoch 77: Train loss=-9227.152051, Validation loss=-9312.003906 \n",
      "Epoch 78: Train loss=-9368.633105, Validation loss=-9456.032812 \n",
      "Epoch 79: Train loss=-9514.083301, Validation loss=-9604.346094 \n",
      "Epoch 80: Train loss=-9663.859473, Validation loss=-9757.184375 \n",
      "Epoch 81: Train loss=-9818.361621, Validation loss=-9914.670313 \n",
      "Epoch 82: Train loss=-9977.553125, Validation loss=-10077.192578 \n",
      "Epoch 83: Train loss=-10141.845117, Validation loss=-10245.053906 \n",
      "Epoch 84: Train loss=-10311.701855, Validation loss=-10418.555859 \n",
      "Epoch 85: Train loss=-10487.182910, Validation loss=-10598.131641 \n",
      "Epoch 86: Train loss=-10668.951465, Validation loss=-10784.025781 \n",
      "Epoch 87: Train loss=-10857.092969, Validation loss=-10976.865234 \n",
      "Epoch 88: Train loss=-11052.443945, Validation loss=-11176.939062 \n",
      "Epoch 89: Train loss=-11255.071191, Validation loss=-11384.954687 \n",
      "Epoch 90: Train loss=-11466.365430, Validation loss=-11601.169141 \n",
      "Epoch 91: Train loss=-11685.463965, Validation loss=-11826.842969 \n",
      "Epoch 92: Train loss=-11914.786621, Validation loss=-12062.059375 \n",
      "Epoch 93: Train loss=-12153.970703, Validation loss=-12308.122656 \n",
      "Epoch 94: Train loss=-12404.498633, Validation loss=-12565.621094 \n",
      "Epoch 95: Train loss=-12666.603125, Validation loss=-12835.961719 \n",
      "Epoch 96: Train loss=-12941.988184, Validation loss=-13119.984766 \n",
      "Epoch 97: Train loss=-13231.424219, Validation loss=-13419.757812 \n",
      "Epoch 98: Train loss=-13537.626953, Validation loss=-13735.990625 \n",
      "Epoch 99: Train loss=-13859.094531, Validation loss=-14066.664844 \n",
      "Epoch 100: Train loss=-14123.188867, Validation loss=-14244.222656 \n",
      "Epoch 101: Train loss=-14301.426953, Validation loss=-14428.496875 \n",
      "Epoch 102: Train loss=-14486.690430, Validation loss=-14615.741406 \n",
      "Epoch 103: Train loss=-14678.554297, Validation loss=-14807.290625 \n",
      "Epoch 104: Train loss=-14875.330859, Validation loss=-15012.782031 \n",
      "Epoch 105: Train loss=-15076.242188, Validation loss=-15217.147656 \n",
      "Epoch 106: Train loss=-15287.913867, Validation loss=-15430.629688 (saved)\n",
      "Epoch 107: Train loss=-15508.724414, Validation loss=-15661.779688 (saved)\n",
      "Epoch 108: Train loss=-15730.615625, Validation loss=-15879.101562 (saved)\n",
      "Epoch 109: Train loss=-15960.733008, Validation loss=-16111.343750 (saved)\n",
      "Epoch 110: Train loss=-16197.358398, Validation loss=-16344.475000 (saved)\n",
      "Epoch 111: Train loss=-16370.908008, Validation loss=-16555.585938 (saved)\n",
      "Epoch 112: Train loss=-15006.558594, Validation loss=-16735.270313 (saved)\n",
      "Epoch 113: Train loss=-15356.784961, Validation loss=-16077.614844 \n",
      "Epoch 114: Train loss=-16288.064258, Validation loss=-16791.234375 (saved)\n",
      "Epoch 115: Train loss=-16773.576758, Validation loss=-16959.967187 (saved)\n",
      "Epoch 116: Train loss=-16889.670508, Validation loss=-16857.492969 \n",
      "Epoch 117: Train loss=-17055.869727, Validation loss=-17223.330469 (saved)\n",
      "Epoch 118: Train loss=-17263.093555, Validation loss=-16607.945312 \n",
      "Epoch 119: Train loss=-16844.793945, Validation loss=-17627.192969 (saved)\n",
      "Epoch 120: Train loss=-17714.550391, Validation loss=-17846.444531 (saved)\n",
      "Epoch 121: Train loss=-15457.829102, Validation loss=-16185.579687 \n",
      "Epoch 122: Train loss=-16261.438867, Validation loss=-15842.396094 \n",
      "Epoch 123: Train loss=-16790.735938, Validation loss=-17243.303906 \n",
      "Epoch 124: Train loss=-17655.286914, Validation loss=-17926.194531 (saved)\n",
      "Epoch 125: Train loss=-17708.896484, Validation loss=-17679.367969 \n",
      "Epoch 126: Train loss=-17862.752148, Validation loss=-18192.286719 (saved)\n",
      "Epoch 127: Train loss=-18239.791211, Validation loss=-18140.342187 \n",
      "Epoch 128: Train loss=-16143.217773, Validation loss=-16388.888281 \n",
      "Epoch 129: Train loss=-17446.883398, Validation loss=-18177.660156 \n",
      "Epoch 130: Train loss=-17426.625195, Validation loss=-16602.273438 \n",
      "Epoch 131: Train loss=-16302.926563, Validation loss=-18473.866406 (saved)\n",
      "Epoch 132: Train loss=-17169.274414, Validation loss=-17009.992969 \n",
      "Epoch 133: Train loss=-17084.429297, Validation loss=-17360.535938 \n",
      "Epoch 134: Train loss=-17596.499023, Validation loss=-17955.182031 \n",
      "Epoch 135: Train loss=-17464.659570, Validation loss=-17792.645313 \n",
      "Epoch 136: Train loss=-18128.278125, Validation loss=-17865.202344 \n",
      "Epoch 137: Train loss=-18192.287109, Validation loss=-17510.181250 \n",
      "Epoch 138: Train loss=-18239.684961, Validation loss=-18794.260156 (saved)\n",
      "Epoch 139: Train loss=-18617.586914, Validation loss=-19010.646094 (saved)\n",
      "Epoch 140: Train loss=-16876.654687, Validation loss=-15536.122656 \n",
      "Epoch 141: Train loss=-17557.590820, Validation loss=-18975.671094 \n",
      "Epoch 142: Train loss=-18409.798242, Validation loss=-18394.191406 \n",
      "Epoch 143: Train loss=-18255.185742, Validation loss=-18217.646875 \n",
      "Epoch 144: Train loss=-17141.932422, Validation loss=-19106.696094 (saved)\n",
      "Epoch 145: Train loss=-17948.017969, Validation loss=-17484.373437 \n",
      "Epoch 146: Train loss=-17804.610352, Validation loss=-18414.695312 \n",
      "Epoch 147: Train loss=-17829.378711, Validation loss=-18386.805469 \n",
      "Epoch 148: Train loss=-18713.281250, Validation loss=-19039.755469 \n",
      "Epoch 149: Train loss=-18728.672656, Validation loss=-18890.955469 \n",
      "Epoch 150: Train loss=-19077.602734, Validation loss=-19333.639062 (saved)\n",
      "Epoch 151: Train loss=-19263.063867, Validation loss=-19315.783594 \n",
      "Epoch 152: Train loss=-19291.484180, Validation loss=-19355.426563 (saved)\n",
      "Epoch 153: Train loss=-19359.570508, Validation loss=-19543.700781 (saved)\n",
      "Epoch 154: Train loss=-19506.730664, Validation loss=-19690.749219 (saved)\n",
      "Epoch 155: Train loss=-19654.078906, Validation loss=-19754.090625 (saved)\n",
      "Epoch 156: Train loss=-19794.783008, Validation loss=-19901.198437 (saved)\n",
      "Epoch 157: Train loss=-19856.099414, Validation loss=-20017.452344 (saved)\n",
      "Epoch 158: Train loss=-19890.283203, Validation loss=-20037.457813 (saved)\n",
      "Epoch 159: Train loss=-19716.933203, Validation loss=-18032.234375 \n",
      "Epoch 160: Train loss=-19412.954102, Validation loss=-19608.380469 \n",
      "Epoch 161: Train loss=-19734.256836, Validation loss=-19377.195312 \n",
      "Epoch 162: Train loss=-18979.190430, Validation loss=-18950.954688 \n",
      "Epoch 163: Train loss=-18275.601758, Validation loss=-18678.878906 \n",
      "Epoch 164: Train loss=-18691.881445, Validation loss=-19148.135156 \n",
      "Epoch 165: Train loss=-19689.219141, Validation loss=-19447.500781 \n",
      "Epoch 166: Train loss=-19956.428320, Validation loss=-20204.146875 (saved)\n",
      "Epoch 167: Train loss=-20188.493555, Validation loss=-19778.428906 \n",
      "Epoch 168: Train loss=-19694.871094, Validation loss=-20254.325781 (saved)\n",
      "Epoch 169: Train loss=-19768.963477, Validation loss=-19592.171094 \n",
      "Epoch 170: Train loss=-19830.222656, Validation loss=-20378.360938 (saved)\n",
      "Epoch 171: Train loss=-20314.956641, Validation loss=-20550.019531 (saved)\n",
      "Epoch 172: Train loss=-20310.419531, Validation loss=-19998.898438 \n",
      "Epoch 173: Train loss=-19349.902539, Validation loss=-13061.860156 \n",
      "Epoch 174: Train loss=-17354.351855, Validation loss=-19869.144531 \n",
      "Epoch 175: Train loss=-19136.266797, Validation loss=-20353.428125 \n",
      "Epoch 176: Train loss=-19715.356055, Validation loss=-20482.569531 \n",
      "Epoch 177: Train loss=-20165.557031, Validation loss=-20405.894531 \n",
      "Epoch 178: Train loss=-20384.957227, Validation loss=-20103.744531 \n",
      "Epoch 179: Train loss=-20127.862305, Validation loss=-20647.234375 (saved)\n",
      "Epoch 180: Train loss=-20566.392578, Validation loss=-20527.416406 \n",
      "Epoch 181: Train loss=-20522.062500, Validation loss=-20670.761719 (saved)\n",
      "Epoch 182: Train loss=-20421.891016, Validation loss=-20781.455469 (saved)\n",
      "Epoch 183: Train loss=-20386.647852, Validation loss=-20760.615625 \n",
      "Epoch 184: Train loss=-18598.892773, Validation loss=-20708.471094 \n",
      "Epoch 185: Train loss=-19691.237109, Validation loss=-18934.996094 \n",
      "Epoch 186: Train loss=-18465.955078, Validation loss=-20668.178125 \n",
      "Epoch 187: Train loss=-18785.846680, Validation loss=-19846.107031 \n",
      "Epoch 188: Train loss=-19295.220703, Validation loss=-19867.177344 \n",
      "Epoch 189: Train loss=-20199.477148, Validation loss=-20518.100781 \n",
      "Epoch 190: Train loss=-20233.307812, Validation loss=-20395.592187 \n",
      "Epoch 191: Train loss=-20382.110547, Validation loss=-20658.421094 \n",
      "Epoch 192: Train loss=-20011.358789, Validation loss=-20481.614063 \n",
      "Epoch 193: Train loss=-19922.860938, Validation loss=-19887.220313 \n",
      "Epoch 194: Train loss=-20057.607812, Validation loss=-20088.885156 \n",
      "Epoch 195: Train loss=-20531.582617, Validation loss=-20161.390625 \n",
      "Epoch 196: Train loss=-20551.873437, Validation loss=-20955.533594 (saved)\n",
      "Epoch 197: Train loss=-20625.428125, Validation loss=-21003.979687 (saved)\n",
      "Epoch 198: Train loss=-20209.928906, Validation loss=-19076.142969 \n",
      "Epoch 199: Train loss=-18727.257617, Validation loss=-19479.459375 \n",
      "Finished training with best train loss: -20929.045508 and validation loss: -21003.979687\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": 274,
   "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": 275,
   "id": "41b11e17-4840-42fe-9a5b-34d65f0a77d7",
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(model, test_loader, **test_params):\n",
    "    test_type = test_params.get(\"test_type\", \"id\")\n",
    "    mu = []\n",
    "    var = []\n",
    "    results = {}\n",
    "    results[\"loss\"] = 0.0\n",
    "\n",
    "    model = model.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for batch_idx, batch in enumerate(test_loader):\n",
    "            x, y = batch\n",
    "            x, y = x.to(device), y.to(device)\n",
    "\n",
    "            out = model(x)\n",
    "\n",
    "            # _mu, _var = out\n",
    "            # _std = torch.sqrt(_var)\n",
    "\n",
    "            # out = model.base_model._apply_constraints(_mu, _std, x, t, tpred, grid, dataset_class)\n",
    "\n",
    "\n",
    "\n",
    "            if model.probconserv:\n",
    "                _mu, _var = out\n",
    "                _std = torch.sqrt(_var)\n",
    "                mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "                new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                                mu=_mu[:, :, :, 0], \n",
    "                                                                std=_std[:, :, :, 0], \n",
    "                                                                mass_rhs_func=mass_rhs_func, \n",
    "                                                                t=t, \n",
    "                                                                tpred=tpred, \n",
    "                                                                grid_train=grid, \n",
    "                                                                precis_g=np.inf,\n",
    "                                                                second_deriv_alpha=None,\n",
    "                                                                )\n",
    "                out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "            results[\"loss\"] += model.loss_func(out, y).item()\n",
    "            utils.compute_all_metrics(out, y, results)\n",
    "\n",
    "            if uq:\n",
    "                mu.append(out[0].detach().cpu())\n",
    "                var.append(out[1].detach().cpu())\n",
    "            else:\n",
    "                mu.append(out.detach().cpu())\n",
    "\n",
    "    # print(results['mse'])\n",
    "    # print(len(test_loader.dataset))\n",
    "\n",
    "    for key in results.keys():\n",
    "        if not key.endswith(\"by_example\"):\n",
    "            results[key] /= len(test_loader.dataset)\n",
    "        if type(results[key]) == torch.Tensor:\n",
    "            results[key] = results[key].tolist()\n",
    "\n",
    "    # Plot\n",
    "    mu = torch.cat(mu, dim=0)\n",
    "    if uq:\n",
    "        var = torch.cat(var, dim=0)\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        var = None\n",
    "        std = None\n",
    "    x = test_loader.dataset.tensors[0]\n",
    "    y = test_loader.dataset.tensors[1]\n",
    "\n",
    "    if uq:\n",
    "        results[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y).item()\n",
    "        results[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y).item()\n",
    "\n",
    "        if is_probconserv:\n",
    "            print(\"Here\")\n",
    "            mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "            new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu[:, :, :, 0], \n",
    "                std=std[:, :, :, 0], \n",
    "                mass_rhs_func=mass_rhs_func, \n",
    "                t=t, \n",
    "                tpred=tpred, \n",
    "                grid_train=grid, \n",
    "                precis_g=np.inf,\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            new_mu = new_mu[:, :, :, None]\n",
    "            new_std = new_std[:, :, :, None]\n",
    "            new_var = new_std**2\n",
    "\n",
    "            probconserv_results = utils.compute_all_metrics((new_mu, new_var), y, {})\n",
    "            for key in probconserv_results.keys():\n",
    "                if not key.endswith(\"by_example\"):\n",
    "                    probconserv_results[key] /= len(test_loader.dataset)\n",
    "                if type(probconserv_results[key]) == torch.Tensor:\n",
    "                    probconserv_results[key] = probconserv_results[key].tolist()\n",
    "\n",
    "            probconserv_results[\"nMeRCI_all\"] = utils.compute_nMeRCI(new_mu, new_var, y).item()\n",
    "            probconserv_results[\"rmsce_all\"] = utils.compute_rmsce(new_mu, new_var, y).item()\n",
    "\n",
    "            cerr = (probconserv.get_empirical_mass_rhs(mu[:, :,  :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "            new_cerr = (probconserv.get_empirical_mass_rhs(new_mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "\n",
    "            results[\"cerr_by_example\"] = cerr.tolist()\n",
    "            results[\"mcerr\"] = cerr.mean().item()\n",
    "            probconserv_results[\"cerr_by_example\"] = new_cerr.tolist()\n",
    "            probconserv_results[\"mcerr\"] = new_cerr.mean().item()\n",
    "\n",
    "            for key in probconserv_results.keys():\n",
    "                results[f\"pc.{key}\"] = probconserv_results[key]\n",
    "    \n",
    "    # results[\"time\"] = utils.compute_forward_time(model, x[:batch_size].to(device), repetitions=10)\n",
    "    results[\"n_params\"] = utils.compute_n_params(model)\n",
    "    results[\"n_flops\"] = utils.compute_n_flops(model_name, Np=n_x*n_t, fno_modes=fno_modes, fno_width=fno_width, n_layers=4, n_models=n_models)\n",
    "\n",
    "    dataset_params_correct_type = dataset_params if test_type == \"id\" or test_type == \"train\" else ood_dataset_params\n",
    "\n",
    "    mse_by_example = torch.tensor(results[\"mse_by_example\"])\n",
    "    random_idx = np.random.choice(mse_by_example.shape[0])\n",
    "    _, worst_idx = mse_by_example.max(dim=0)\n",
    "    _, best_idx = mse_by_example.min(dim=0)\n",
    "    _, median_idx = mse_by_example.median(dim=0)\n",
    "\n",
    "    for example_name, example_idx in zip([\"random\", \"worst\", \"best\", \"median\"], [random_idx, worst_idx, best_idx, median_idx]):\n",
    "        if uq:\n",
    "            results[f\"examples.{example_name}\"] = (mu[example_idx].tolist(), var[example_idx].tolist(), y[example_idx].tolist(), x[example_idx].tolist())\n",
    "            if is_probconserv:\n",
    "                results[f\"pc.examples.{example_name}\"] = (new_mu[example_idx].tolist(), new_var[example_idx].tolist(), y[example_idx].tolist(), x[example_idx].tolist())\n",
    "        else:\n",
    "            results[f\"examples.{example_name}\"] = (mu[example_idx].tolist(), None, y[example_idx].tolist(), x[example_idx].tolist())\n",
    "\n",
    "        # prefix = f\"{test_type}_{example_name}_params={dataset_params_correct_type}\"\n",
    "        # plot_and_save(prefix, example_idx, x.squeeze(-1), y.squeeze(-1), mu.squeeze(-1), std.squeeze(-1) if std is not None else None)\n",
    "\n",
    "    # utils.dict_to_file({\"test_type\": test_type, \"params\": dataset_params_correct_type, \"results\": results}, \n",
    "    #                    f\"{run_folder}/results_{test_type}_params={dataset_params_correct_type}.json\")\n",
    "\n",
    "    return results\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 276,
   "id": "58fe7954-8db9-47db-ba7c-39fde51a4146",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here\n",
      "Here\n",
      "Here\n",
      "Here\n",
      "Train results\n",
      "MSE: 0.004342679679393768\n",
      "n-MeRCI: 0.8530463576316833\n",
      "RMSCE: 0.14743271470069885\n",
      "Cerr: 0.17254941165447235\n",
      "In-domain results\n",
      "MSE: 0.004074377566576004\n",
      "n-MeRCI: 0.6310175061225891\n",
      "RMSCE: 0.1515580117702484\n",
      "ProbConserv Results\n",
      "MSE: 0.0026088947057723998\n",
      "n-MeRCI: 0.620262086391449\n",
      "RMSCE: 0.1460617184638977\n",
      "Cerr: 0.1613001674413681\n",
      "Prob_Cerr: 3.560867867236084e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 0.015564156174659729\n",
      "n-MeRCI: 0.8489077091217041\n",
      "RMSCE: 0.4179133176803589\n",
      "ProbConserv Results\n",
      "MSE: 0.02660393238067627\n",
      "n-MeRCI: 0.8486756682395935\n",
      "RMSCE: 0.4148367643356323\n",
      "Cerr: 0.6340492367744446\n",
      "Prob_Cerr: 4.880595838585577e-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": 277,
   "id": "98acb797",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0026088947057723998"
      ]
     },
     "execution_count": 277,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 301,
   "id": "1ec3729e-d8e6-454f-8e4e-6b05f44a94f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_train.to(device))\n",
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 302,
   "id": "a79d0c9c-0631-48de-a30f-71c30dcad40d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_statistics(\n",
    "    model, \n",
    "    x_data, \n",
    "    y_data, \n",
    "    t, \n",
    "    tpred, \n",
    "    grid, \n",
    "    dataset_class, \n",
    "    apply_probconserv=False, \n",
    "    plot=False,\n",
    "    x_data_test=None, \n",
    "    y_data_test=None,\n",
    "    return_latex=False,\n",
    "    name=\"Model\"\n",
    "):\n",
    "    import torch\n",
    "    import utils\n",
    "    import probconserv\n",
    "    import matplotlib.pyplot as plt\n",
    "\n",
    "    device = next(model.parameters()).device\n",
    "    x_data = x_data.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        out = model(x_data)\n",
    "\n",
    "    if isinstance(out, tuple):\n",
    "        mu, var = out[0].cpu(), out[1].cpu()\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        mu = out.cpu()\n",
    "        std = torch.zeros_like(mu)\n",
    "        var = torch.square(std)\n",
    "\n",
    "    x_cpu = x_data.cpu()\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_cpu)\n",
    "\n",
    "    if apply_probconserv:\n",
    "        new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "            mu=mu[:, :, :, 0],\n",
    "            std=std[:, :, :, 0],\n",
    "            mass_rhs_func=mass_rhs_func,\n",
    "            t=t,\n",
    "            tpred=tpred,\n",
    "            grid_train=grid,\n",
    "            precis_g=float('inf'),\n",
    "            second_deriv_alpha=None,\n",
    "        )\n",
    "        mu = new_mu.unsqueeze(-1)\n",
    "        std = new_std.unsqueeze(-1)\n",
    "        var = torch.square(std)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "    else:\n",
    "        t_sliced = t[slice(*tpred)]\n",
    "        ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu.shape[0])\n",
    "        xs = repeat(grid, \"nx -> nf nx\", nf=mu.shape[0])\n",
    "        inputs = meshgrid(ts, xs)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs_func(inputs)).abs().sum(dim=-1)\n",
    "\n",
    "    stats = utils.compute_all_metrics_avg((mu, var), y_data, {})\n",
    "    stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y_data).item()\n",
    "    stats[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y_data).item()\n",
    "    stats[\"cerr_by_example\"] = cerr.tolist()\n",
    "    stats[\"mcerr\"] = cerr.mean().item()\n",
    "\n",
    "    # --- Test dataset ---\n",
    "    test_stats = None\n",
    "    if x_data_test is not None and y_data_test is not None:\n",
    "        x_data_test = x_data_test.to(device)\n",
    "        with torch.no_grad():\n",
    "            test_out = model(x_data_test)\n",
    "\n",
    "        if isinstance(test_out, tuple):\n",
    "            mu_test, var_test = test_out[0].cpu(), test_out[1].cpu()\n",
    "            std_test = torch.sqrt(var_test)\n",
    "        else:\n",
    "            mu_test = test_out.cpu()\n",
    "            std_test = torch.zeros_like(mu_test)\n",
    "            var_test = torch.square(std_test)\n",
    "\n",
    "        x_test_cpu = x_data_test.cpu()\n",
    "        test_mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_test_cpu)\n",
    "\n",
    "        if apply_probconserv:\n",
    "            new_mu_test, new_std_test, _, test_mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu_test[:, :, :, 0],\n",
    "                std=std_test[:, :, :, 0],\n",
    "                mass_rhs_func=test_mass_rhs_func,\n",
    "                t=t,\n",
    "                tpred=tpred,\n",
    "                grid_train=grid,\n",
    "                precis_g=float('inf'),\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            mu_test = new_mu_test.unsqueeze(-1)\n",
    "            std_test = new_std_test.unsqueeze(-1)\n",
    "            var_test = torch.square(std_test)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs).abs().sum(dim=-1)\n",
    "        else:\n",
    "            t_sliced = t[slice(*tpred)]\n",
    "            ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu_test.shape[0])\n",
    "            xs = repeat(grid, \"nx -> nf nx\", nf=mu_test.shape[0])\n",
    "            inputs = meshgrid(ts, xs)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs_func(inputs)).abs().sum(dim=-1)\n",
    "\n",
    "        test_stats = utils.compute_all_metrics_avg((mu_test, var_test), y_data_test, {})\n",
    "        test_stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"rmsce_all\"] = utils.compute_rmsce(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"cerr_by_example\"] = cerr_test.tolist()\n",
    "        test_stats[\"mcerr\"] = cerr_test.mean().item()\n",
    "\n",
    "    # --- Optional plot ---\n",
    "    if plot:\n",
    "        t_idx = 1\n",
    "        param_idx = 0\n",
    "        with torch.no_grad():\n",
    "            plt.ylabel(f\"u(x, t={t[slice(*tpred)][t_idx]:.2f})\")\n",
    "            plt.xlabel(\"x\")\n",
    "            plt.title(f\"Predicted vs True (param = {x_data[param_idx,0,0,0].item():.2f})\")\n",
    "            mu_plot = mu[param_idx, :, t_idx, 0]\n",
    "            std_plot = std[param_idx, :, t_idx, 0]\n",
    "            y_true_plot = y_data[param_idx, :, t_idx, 0]\n",
    "            plt.plot(grid, mu_plot, '--', lw=2, label=\"μ ± 3σ\")\n",
    "            plt.fill_between(grid, mu_plot + 3*std_plot, mu_plot - 3*std_plot, alpha=0.2)\n",
    "            plt.plot(grid, y_true_plot, color=\"green\", label=\"true\")\n",
    "            plt.legend()\n",
    "            plt.show()\n",
    "\n",
    "    # --- Optional LaTeX row ---\n",
    "    latex_row = None\n",
    "    if return_latex and test_stats:\n",
    "        latex_row = (\n",
    "            f\"{name} & \"\n",
    "            f\"{stats['mse']:.3E} & {stats['nMeRCI_all']:.3E} & {stats['rmsce_all']:.3E} & {stats['mcerr']:.3E} & {stats['crps']:.3E} & \"\n",
    "            f\"{test_stats['mse']:.3E} & {test_stats['nMeRCI_all']:.3E} & {test_stats['rmsce_all']:.3E} & {test_stats['mcerr']:.3E} & {test_stats['crps']:.3E} \\\\\\\\\"\n",
    "        )\n",
    "\n",
    "    return (stats, test_stats, latex_row) if return_latex else (stats, test_stats)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 303,
   "id": "db6f209f-6714-4ba7-b97a-b583407fc622",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_stats, test_stats, latex = compute_statistics(\n",
    "    model,\n",
    "    x_train, y_train,\n",
    "    x_data_test=x_ood_test, \n",
    "    y_data_test=y_ood_test,\n",
    "    t=t, tpred=tpred, grid=grid,\n",
    "    dataset_class=dataset_class,\n",
    "    apply_probconserv=False,\n",
    "    plot=False,\n",
    "    return_latex=True,\n",
    "    name=\"Unconstrained\"\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 304,
   "id": "5dd8a74e-ed48-4729-b03f-5b2479cb2b80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.015564155578613282"
      ]
     },
     "execution_count": 304,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 305,
   "id": "cf825126-4de6-4fbc-a562-0ba92a03117d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.6340492367744446"
      ]
     },
     "execution_count": 305,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['mcerr']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 306,
   "id": "aa38b7e2-b371-44c0-b8b2-d9b9e007af2c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.029609107971191408"
      ]
     },
     "execution_count": 306,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_stats['crps']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 307,
   "id": "beca3af8-a7aa-4108-9d1f-34e99c4c2fd2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'Unconstrained & 4.343E-03 & 8.530E-01 & 1.474E-01 & 1.725E-01 & 1.013E-02 & 1.556E-02 & 8.489E-01 & 4.179E-01 & 6.340E-01 & 2.961E-02 \\\\\\\\'"
      ]
     },
     "execution_count": 307,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3daaebb7-8bc5-4fc0-9488-cbc03fb52b4e",
   "metadata": {},
   "source": [
    "'ProbConserv & 2.10E-03 & 7.83E-01 & 1.73E-01 & 3.61E-07 & 7.83E-03 & 2.26E-02 & 8.72E-01 & 4.19E-01 & 4.97E-07 & 3.41E-02 \\\\\\\\'\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "45271205-293d-4a07-8c1f-3fa249cfe744",
   "metadata": {},
   "source": [
    "## Experiments to check CRPS (sampling) and CRPS without sampling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 308,
   "id": "f3f1485f-07fb-4039-a0c4-d0480edbd8bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(-20929.0469, device='cuda:0', grad_fn=<DivBackward0>)"
      ]
     },
     "execution_count": 308,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.loss_func(out, y.to(device))/len(out[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 309,
   "id": "7f826c2e-eee5-4b4a-abc0-daf2e505aa50",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 100, 20, 1])"
      ]
     },
     "execution_count": 309,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "out[0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 310,
   "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": 311,
   "id": "400f807a-3676-42a2-82fd-f0ee6999c64e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0101, grad_fn=<MeanBackward0>)"
      ]
     },
     "execution_count": 311,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.mean(crps_by_sample)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 312,
   "id": "913e8446-4753-427f-8d64-d69dbed2b866",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 313,
   "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": 315,
   "id": "64b75faa-0ce0-47f9-ae71-2aae64386daf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB5ZklEQVR4nO3dd3xT5f4H8M85Wd2LbiiUvREEQZaAgGWIwFVBQJaMnwoqICioyFApchVBQFFkObigKF4vIBsUBEFZInuUbVtKobtJkzy/P9KkTZN00UGSz/v1itKT55x8c5KcfPNMSQghQEREROSG5MoOgIiIiKiyMBEiIiIit8VEiIiIiNwWEyEiIiJyW0yEiIiIyG0xESIiIiK3xUSIiIiI3BYTISIiInJbTISIiIjIbTERIpcSHR2NESNGVHYYVAFWrVoFSZJw+fLlCn9svV6P1157DVFRUZBlGf369avwGIiobDARIhvmL5g///yzskNxKpIkYfz48Xbvq4hzevPmTcycORPHjh0rVnlzTI5uv//+e7nFWhJz5szBjz/+WNlhWFmxYgX+/e9/46mnnsLq1asxceLEyg7Jpa1ZswYLFiyo7DDuyY0bNzBgwAAEBATAz88Pffv2xaVLl4q9v06nw5w5c9CgQQN4eHggLCwMvXv3xvXr1y1l/vjjD4wfPx6NGzeGt7c3qlevjgEDBuDcuXPl8ZRchrKyAyAqS2fPnoUsu2d+f/PmTcyaNQvR0dFo3rx5sfebPXs2atasabO9Tp06ZRhd6c2ZMwdPPfWUTa3L0KFD8cwzz0Cj0VR4TLt27ULVqlXx0UcfVfhju6M1a9bg77//xoQJEyo7lFJJT09Hly5dkJKSgjfeeAMqlQofffQROnXqhGPHjqFKlSqF7p+Tk4PevXtj//79GDNmDJo1a4Y7d+7g4MGDSElJQbVq1QAA77//Pn777Tc8/fTTaNasGeLj47F48WI8+OCD+P3339GkSZOKeLpOh4kQ3bf0ej2MRiPUanWx96mML0Vn17NnT7Rq1aqywygxhUIBhUJRKY+dmJiIgICAMjue0WiETqeDh4dHmR2zpLKzs6FWq93mh0RFnvNPPvkE58+fx6FDh/DQQw8BMH3umjRpgg8//BBz5swpdP+PPvoIv/zyC/bt24fWrVs7LDdp0iSsWbPG6po5cOBANG3aFHPnzsXXX39dNk/IxbjHO57KxY0bN/Dcc88hLCwMGo0GjRs3xooVK6zK6HQ6vP3222jZsiX8/f3h7e2Njh07Yvfu3VblLl++DEmS8MEHH2DBggWoXbs2NBoNTp06hZkzZ0KSJFy4cAEjRoxAQEAA/P39MXLkSGRmZlodp2AfIXPzz2+//YZJkyYhJCQE3t7e6N+/P27dumW1r9FoxMyZMxEZGQkvLy906dIFp06dKtd+R2fOnMFTTz2FoKAgeHh4oFWrVvjpp5+syiQnJ2Py5Mlo2rQpfHx84Ofnh549e+L48eOWMnv27LFcYEeOHGlp3lq1alWZxHn37l2MGDEC/v7+CAgIwPDhw3Hs2DGbx+jcuTM6d+5ss/+IESMQHR1tte2DDz5Au3btUKVKFXh6eqJly5ZYv369VRlJkpCRkYHVq1dbnpP5tXDUR+iTTz5B48aNodFoEBkZiXHjxuHu3btWZTp37owmTZrg1KlT6NKlC7y8vFC1alXMmzev0PNgfp/u3r0bJ0+etMS0Z88eAEBGRgZeffVVREVFQaPRoH79+vjggw8ghLB5XuPHj8c333xjiXXLli0OHzc6OhqPP/44tm3bhubNm8PDwwONGjXCDz/8YFWuOO8VwPR+kSQJa9euxVtvvYWqVavCy8sLqampJT7Gt99+i1mzZqFq1arw9fXFU089hZSUFGi1WkyYMAGhoaHw8fHByJEjodVqbZ7b119/jZYtW8LT0xNBQUF45plncO3aNavXatOmTbhy5YrlfOd/L2m1WsyYMQN16tSBRqNBVFQUXnvtNZvHKuk5L0vr16/HQw89ZPmMAkCDBg3QtWtXfPvtt4XuazQasXDhQvTv3x+tW7eGXq+3ue6ZtWvXzuaHY926ddG4cWOcPn363p+Ii2KNEJVKQkICHn74YcvFJSQkBD///DNGjRqF1NRUSxV2amoqvvjiCwwaNAhjxoxBWloali9fjpiYGBw6dMimCWflypXIzs7G2LFjodFoEBQUZLlvwIABqFmzJmJjY3HkyBF88cUXCA0Nxfvvv19kvC+99BICAwMxY8YMXL58GQsWLMD48eOxbt06S5lp06Zh3rx56NOnD2JiYnD8+HHExMQgOzu72OclOzsbSUlJNtvT09Nttp08eRLt27dH1apVMXXqVHh7e+Pbb79Fv3798P3336N///4AgEuXLuHHH3/E008/jZo1ayIhIQGfffYZOnXqhFOnTiEyMhINGzbE7Nmz8fbbb2Ps2LHo2LEjANOFsSgpKSk2MUuSZKmuF0Kgb9++2LdvH55//nk0bNgQGzZswPDhw4t9XuxZuHAhnnjiCQwZMgQ6nQ5r167F008/jY0bN6J3794AgK+++gqjR49G69atMXbsWABA7dq1HR5z5syZmDVrFrp164YXXngBZ8+exaeffoo//vgDv/32G1QqlaXsnTt30KNHD/zrX//CgAEDsH79erz++uto2rQpevbsaff4ISEh+Oqrr/Dee+8hPT0dsbGxAICGDRtCCIEnnngCu3fvxqhRo9C8eXNs3boVU6ZMwY0bN2ya0Xbt2oVvv/0W48ePR3BwsE2iWND58+cxcOBAPP/88xg+fDhWrlyJp59+Glu2bEH37t0BFO+9kt8777wDtVqNyZMnQ6vVQq1W49SpUyU6RmxsLDw9PTF16lRcuHABixYtgkqlgizLuHPnDmbOnInff/8dq1atQs2aNfH2229b9n3vvfcwffp0DBgwAKNHj8atW7ewaNEiPPLIIzh69CgCAgLw5ptvIiUlBdevX7ecQx8fHwCmJOGJJ57Avn37MHbsWDRs2BAnTpzARx99hHPnztn0LSvJOU9PTy/WZ1+lUsHf39/h/UajEX/99Reee+45m/tat26Nbdu2IS0tDb6+vnb3P3XqFG7evIlmzZph7NixWL16NXQ6HZo2bYqFCxeiS5cuhcYnhEBCQgIaN25c5HNxW4KogJUrVwoA4o8//nBYZtSoUSIiIkIkJSVZbX/mmWeEv7+/yMzMFEIIodfrhVartSpz584dERYWJp577jnLtri4OAFA+Pn5icTERKvyM2bMEACsygshRP/+/UWVKlWsttWoUUMMHz7c5rl069ZNGI1Gy/aJEycKhUIh7t69K4QQIj4+XiiVStGvXz+r482cOVMAsDqmIwCKvOU/p127dhVNmzYV2dnZlm1Go1G0a9dO1K1b17ItOztbGAwGq8eKi4sTGo1GzJ4927Ltjz/+EADEypUri4w1/7mxd9NoNJZyP/74owAg5s2bZ9mm1+tFx44dbR6vU6dOolOnTjaPNXz4cFGjRg2rbeb3iJlOpxNNmjQRjz76qNV2b29vu+ffHH9cXJwQQojExEShVqvFY489ZnW+Fi9eLACIFStWWMUJQHz55ZeWbVqtVoSHh4snn3zS5rEK6tSpk2jcuLHVNvN5evfdd622P/XUU0KSJHHhwgXLNgBClmVx8uTJIh9LCNP7GoD4/vvvLdtSUlJERESEaNGihWVbcd8ru3fvFgBErVq1bF6Hkh6jSZMmQqfTWbYPGjRISJIkevbsaXWMtm3bWr0HLl++LBQKhXjvvfesyp04cUIolUqr7b1797Z5/wghxFdffSVkWRZ79+612r506VIBQPz222+WbSU958OHDy/WZ9re+z2/W7duCQBW585syZIlAoA4c+aMw/1/+OEHAUBUqVJF1K1bV6xcuVKsXLlS1K1bV6jVanH8+PFCH/+rr74SAMTy5cuL9bzdEZvGqMSEEPj+++/Rp08fCCGQlJRkucXExCAlJQVHjhwBYOrHYa6qNRqNSE5Ohl6vR6tWrSxl8nvyyScREhJi93Gff/55q787duyI27dvIzU1tciYx44dC0mSrPY1GAy4cuUKAGDnzp3Q6/V48cUXrfZ76aWXijx2fn379sX27dttblOmTLEql5ycjF27dmHAgAFIS0uznL/bt28jJiYG58+fx40bNwCY+j2Z+20YDAbcvn0bPj4+qF+/vt1zWFJLliyxiffnn3+23L9582YolUq88MILlm0KhaLE56YgT09Py7/v3LmDlJQUdOzYsdTPaceOHdDpdJgwYYJVP5cxY8bAz88PmzZtsirv4+ODZ5991vK3Wq1G69atSzSSJ7/NmzdDoVDg5Zdfttr+6quvQghhdU4BoFOnTmjUqFGxjx8ZGWmpJQQAPz8/DBs2DEePHkV8fDyAkr9Xhg8fbvU6lOYYw4YNs6ppa9OmDYQQNjUgbdq0wbVr16DX6wEAP/zwA4xGIwYMGGB1DQkPD0fdunVtms/t+e6779CwYUM0aNDA6hiPPvooANgcoyTn/LXXXrP7WS54+/DDDws9TlZWFgD7/RfN/ZPMZewx1yanpaVh586dGDFiBEaMGIEdO3ZACFFoc+6ZM2cwbtw4tG3b9p5rcF0Zm8aoxG7duoW7d+/i888/x+eff263TGJiouXfq1evxocffogzZ84gJyfHst3eSCV728yqV69u9XdgYCAA05eon59foTEXti8AS0JUcKRUUFCQpWxxVKtWDd26dbPZnn+IKwBcuHABQghMnz4d06dPt3usxMREVK1a1dJH4JNPPkFcXBwMBoOlTFGjTYqjdevWhXaWvnLlCiIiIizNEWb169e/p8fduHEj3n33XRw7dsyqP0f+hLUkzK9hwbjUajVq1aplud+sWrVqNo8VGBiIv/76q9SPHxkZadPE0bBhQ6v4zAp7r9tTp04dm3jr1asHwNR3KTw8vMTvFXsxlPQYBT9b5maiqKgom+1GoxEpKSmoUqUKzp8/DyEE6tata/f55k+uHDl//jxOnz7t8MdT/usQULJz3qhRoxIlqo6YE017/aPMTW8Fk1F7+7dv397qnFavXh0dOnTA/v377e4XHx+P3r17w9/fH+vXr6+0gQXOgIkQlZjRaAQAPPvssw5/ZTRr1gyAqSPkiBEj0K9fP0yZMgWhoaFQKBSIjY3FxYsXbfYr7ILg6IMsCnRELet9y4P5HE6ePBkxMTF2y5iTsjlz5mD69Ol47rnn8M477yAoKAiyLGPChAmW49wvJEmye07zf5kCwN69e/HEE0/gkUcewSeffIKIiAioVCqsXLkSa9asqZBYK/s9Udh7vbRK+l6xF0NJj+HoPBZ1fo1GIyRJws8//2y3bMHE2x6j0YimTZti/vz5du8vmIyV5JynpKQUWlNjplarrfoyFhQUFASNRoN//vnH5j7ztoL9rvIz3xcWFmZzX2hoKI4ePWo39p49e+Lu3bvYu3dvoccnJkJUCiEhIfD19YXBYLBb+5Hf+vXrUatWLfzwww9Wv2ZnzJhR3mGWSI0aNQCYamry/2q8ffu2pdaoLNWqVQuA6Vdvcc5hly5dsHz5cqvtd+/eRXBwsOXv0takFKVGjRrYuXMn0tPTrb6czp49a1M2MDDQbtNSwdqQ77//Hh4eHti6datVk8HKlStt9i3u8zK/hmfPnrWcX8A0cjEuLq7I83yvatSogR07dth0fD1z5oxVfKVlrkXMfz7ME+WZO/0W971SmLI4RnHUrl0bQgjUrFnTUrPliKP3QO3atXH8+HF07dq1zN//r7zyClavXl1kuU6dOllGDdojyzKaNm1qdzLVgwcPolatWg47SgNA06ZNoVKpLE3l+d28edOmNiw7Oxt9+vTBuXPnsGPHjjKp1XJ17CNEJaZQKPDkk0/i+++/x99//21zf/5h6eZfevl/ZR88eBAHDhwo/0BLoGvXrlAqlfj000+tti9evLhcHi80NBSdO3fGZ599ZveXYsFzWLCW4rvvvrO5MHp7ewOAzVDxe9WrVy/o9Xqrc2MwGLBo0SKbsrVr18aZM2es4j9+/Dh+++03q3IKhQKSJFnVFF2+fNnuDNLe3t7Fek7dunWDWq3Gxx9/bHW+li9fjpSUFMtItPLSq1cvGAwGm/fMRx99BEmSHI5EK66bN29iw4YNlr9TU1Px5Zdfonnz5ggPDwdQ/PdKYcriGMXxr3/9CwqFArNmzbJ5PCEEbt++bfnb29sbKSkpNscYMGAAbty4gWXLltncl5WVhYyMjFLHV1Z9hADgqaeewh9//GGVDJ09exa7du3C008/bVX2zJkzuHr1quVvX19f9OrVC/v377ck1QBw+vRp7N+/3zJiEDB9LgcOHIgDBw7gu+++Q9u2bUv9/N0Ja4TIoRUrVtidZ+OVV17B3LlzsXv3brRp0wZjxoxBo0aNkJycjCNHjmDHjh1ITk4GADz++OP44Ycf0L9/f/Tu3RtxcXFYunQpGjVqZHdIeWUJCwvDK6+8gg8//BBPPPEEevTogePHj+Pnn39GcHBwudS2LFmyBB06dEDTpk0xZswY1KpVCwkJCThw4ACuX79umbfl8ccfx+zZszFy5Ei0a9cOJ06cwDfffGNV6wGYkpCAgAAsXboUvr6+8Pb2Rps2bYrsF/Hzzz9bXWDN2rVrh1q1aqFPnz5o3749pk6disuXL1vmr7H3xfTcc89h/vz5iImJwahRo5CYmIilS5eicePGVp3ae/fujfnz56NHjx4YPHgwEhMTsWTJEtSpU8emj07Lli2xY8cOzJ8/H5GRkahZsybatGlj89ghISGYNm0aZs2ahR49euCJJ57A2bNn8cknn+Chhx6y6hhdHvr06YMuXbrgzTffxOXLl/HAAw9g27Zt+O9//4sJEyYUOuy/OOrVq4dRo0bhjz/+QFhYGFasWIGEhASrWrTivlcKUxbHKI7atWvj3XffxbRp03D58mX069cPvr6+iIuLw4YNGzB27FhMnjwZgOk9sG7dOkyaNAkPPfQQfHx80KdPHwwdOhTffvstnn/+eezevRvt27eHwWDAmTNn8O2332Lr1q2lniy0rPoIAcCLL76IZcuWoXfv3pg8eTJUKhXmz5+PsLAwvPrqq1ZlGzZsaFPLNGfOHOzcuROPPvqopTP+xx9/jKCgILzxxhuWcq+++ip++ukn9OnTB8nJyTYTKJb3Z8BpVegYNXIKhQ2rBiCuXbsmhBAiISFBjBs3TkRFRQmVSiXCw8NF165dxeeff245ltFoFHPmzBE1atQQGo1GtGjRQmzcuNFmOLV5+Py///1vm3jMw+dv3bplN07z8GkhHA+fLzgVgHno7+7duy3b9Hq9mD59uggPDxeenp7i0UcfFadPnxZVqlQRzz//fJHnDYAYN26c3fscxXHx4kUxbNgwER4eLlQqlahatap4/PHHxfr16y1lsrOzxauvvioiIiKEp6enaN++vThw4IDdoer//e9/RaNGjYRSqSxyKH1Rr3P+fW/fvi2GDh0q/Pz8hL+/vxg6dKg4evSo3cf4+uuvRa1atYRarRbNmzcXW7dutTt8fvny5aJu3bpCo9GIBg0aiJUrV1pe6/zOnDkjHnnkEeHp6Wk1lYG9118I03D5Bg0aCJVKJcLCwsQLL7wg7ty5Y1XG3vB3IewP87fH0f5paWli4sSJIjIyUqhUKlG3bl3x73//22rqBiEKf6/YU6NGDdG7d2+xdetW0axZM8s5++6776zKFfe9Yn7/F9y/LI7h6L3u6HP8/fffiw4dOghvb2/h7e0tGjRoIMaNGyfOnj1rKZOeni4GDx4sAgICBACr10in04n3339fNG7cWGg0GhEYGChatmwpZs2aJVJSUizlSnrOy9q1a9fEU089Jfz8/ISPj494/PHHxfnz523KwcGQ/MOHD4tu3boJb29v4evrK/r27SvOnTtnVcY8LYSjG9knCVFJvUWJnMDdu3cRGBiId999F2+++WZlh3NfuXz5MmrWrImVK1eW28zbZBIdHY0mTZpg48aNlR0KkcthHyGiXPZGiJhXvLa3bAQRETk/9hEiyrVu3TqsWrUKvXr1go+PD/bt24f//Oc/eOyxx9C+ffvKDo+IiMoBEyGiXM2aNYNSqcS8efOQmppq6UD97rvvVnZoRERUTthHiIiIiNwW+wgRERGR22IiRERERG6LfYSKYDQacfPmTfj6+pbbEgZERERUtoQQSEtLQ2RkJGTZcb0PE6Ei3Lx502bhPiIiInIO165dQ7Vq1Rzez0SoCObF8K5duwY/P79KjoaIiIiKIzU1FVFRUYUuagswESqSuTnMz8+PiRAREZGTKapbCztLExERkdtiIkRERERui4kQERERuS32ESIip2M0GqHT6So7DCKqRCqVCgqF4p6Pw0SIiJyKTqdDXFwcjEZjZYdCRJUsICAA4eHh9zTPHxMhInIaQgj8888/UCgUiIqKKnSSNCJyXUIIZGZmIjExEQAQERFR6mMxESIip6HX65GZmYnIyEh4eXlVdjhEVIk8PT0BAImJiQgNDS11Mxl/ThGR0zAYDAAAtVpdyZEQ0f3A/IMoJyen1MdgIkRETofr/hERUDbXAiZCRERE5LaYCBEREZHbYiJEREREbouJEBGRC+rcuTMmTJhg8+/KjMMZOEu8t2/fRmhoKC5fvlzZoZSbZ555Bh9++GG5P45TJUK//vor+vTpg8jISEiShB9//LHIffbs2YMHH3wQGo0GderUwapVq8o9TiKi+8kPP/yAd955p9jlnSUZuN99+umnaNasGfz8/ODn54e2bdvi559/LpNjv/fee+jbty+io6PL5HiFGTFiBCRJsrlduHDB6v65c+da7ffjjz/a7cx87do1PPfcc4iMjIRarUaNGjXwyiuv4Pbt21bl3nrrLbz33ntISUkpvycHJ0uEMjIy8MADD2DJkiXFKh8XF4fevXujS5cuOHbsGCZMmIDRo0dj69at5Rxp8SSlayGEqOwwiOg+VJZLiAQFBcHX17fMjkd5Onfu7PAHdrVq1TB37lwcPnwYf/75Jx599FH07dsXJ0+evKfHzMzMxPLlyzFq1Kh7Ok5xmN+HPXr0wD///GN1q1mzpqWch4cH3n//fdy5c6fQ4126dAmtWrXC+fPn8Z///AcXLlzA0qVLsXPnTrRt2xbJycmWsk2aNEHt2rXx9ddfl8+Ty+VUiVDPnj3x7rvvon///sUqv3TpUtSsWRMffvghGjZsiPHjx+Opp57CRx99VM6RFk+GVo9/UrIrOwwiqgCdO3fG+PHjMX78ePj7+yM4OBjTp0+3/Bgy3z9hwgQEBwcjJiYGgGldtdjYWNSsWROenp544IEHsH79eqtjZ2RkYNiwYfDx8UFERIRNc0LBGh6j0Yh58+ahTp060Gg0qF69Ot577z0Apl/3v/zyCxYuXGj55X/58uUyicOeffv2QaVSITs771p4+fJlSJKEK1eu2N1ny5Yt6NChAwICAlClShU8/vjjuHjxos1zfvnll/Haa68hKCgI4eHhmDlz5j3HWxJ9+vRBr169ULduXdSrVw/vvfcefHx88Pvvv1uV+/3339G1a1dUqVLFptYlNTXV5ribN2+GRqPBww8/bNn2+eefIzIy0mbpmb59++K5554DUPzzZu99qNFoEB4ebnXLP4Fht27dEB4ejtjY2ELPybhx46BWq7Ft2zZ06tQJ1atXR8+ePbFjxw7cuHEDb775ps05XLt2baHHvFdOlQiV1IEDB9CtWzerbTExMThw4EAlRZTnTNIZvLH7FRy+cgt3Mrh4JJE7WL16NZRKJQ4dOoSFCxdi/vz5+OKLL6zuV6vV+O2337B06VIAQGxsLL788kssXboUJ0+exMSJE/Hss8/il19+sew3ZcoU/PLLL/jvf/+Lbdu2Yc+ePThy5IjDOKZNm4a5c+di+vTpOHXqFNasWYOwsDAAwMKFC9G2bVuMGTPG8ss/KiqqXOIAgGPHjqFhw4bw8PCwbDt69CgCAwNRo0YNu/tkZGRg0qRJ+PPPP7Fz507Isoz+/fvbJAGrV6+Gt7c3Dh48iHnz5mH27NnYvn37PcVbWgaDAWvXrkVGRgbatm1r2X78+HF07twZLVq0wN69e7FlyxYEBQWha9euWLduHfz8/GyOtXfvXrRs2dJq29NPP43bt29j9+7dlm3JycnYsmULhgwZAqBk563g+7AoCoUCc+bMwaJFi3D9+nW7ZZKTk7F161a8+OKLllmhzcLDwzFkyBCsW7fOqqWkdevWOHToELRabbHiKA2XXmIjPj7e8uE2CwsLQ2pqKrKysmxeCADQarVWJ9xeNn6vdAYden7TE5fvXsZPJ05jccwqDGhVC57qe19Fl8gdfbH3Er7YG1dkuSZV/fDF8Iesto1e/Qf+vlH053x0x5oY3bFWqWMEgKioKHz00UeQJAn169fHiRMn8NFHH2HMmDEAgLp162LevHmW8lqtFnPmzMGOHTssX561atXCvn378Nlnn6FTp05IT0/H8uXL8fXXX6Nr164ATF9k1apVsxtDWloaFi5ciMWLF2P48OEAgNq1a6NDhw4AAH9/f6jVanh5eSE8PLzc4jA7fvw4WrRoYbXt2LFjeOCBBxzu8+STT1r9vWLFCoSEhODUqVNo0qSJZXuzZs0wY8YMAKZzu3jxYuzcuRPdu3cvdbxz5szBnDlzLH9nZWXh999/x/jx4y3bTp06herVqwMATpw4gbZt2yI7Oxs+Pj7YsGEDGjVqZCn78ssv41//+hc++OADAECjRo0waNAgHD58GAMGDLAbw5UrVxAZGWm1LTAwED179sSaNWssz2f9+vUIDg5Gly5dSnTeCr4PAWDjxo3w8fGx/N2zZ0989913VmX69++P5s2bY8aMGVi+fLlN3OfPn4cQAg0bNrT7vBo2bIg7d+7g1q1bCA0NBQBERkZCp9MhPj7eYWJ8r1w6ESqN2NhYzJo1q1wfQ61Q45m6szD30Giky/sxbuswCKzGs23qQKlw6Uo6onKRlq1HfGrRzcwRAR42225n6Iq1b1q2vlSx5ffwww9bdR5t27YtPvzwQ8vSIQV/5V+4cAGZmZno3r271XadTmdJHi5evAidToc2bdpY7g8KCkL9+vXtxnD69GlotVrLl2VxlEccZseOHcPgwYOtth09ehTNmzd3uM/58+fx9ttv4+DBg0hKSrLUaFy9etUmEcovIiLCskhnaeN9/vnnrRKUIUOG4Mknn8S//vUvy7b8SUr9+vVx7NgxpKSkYP369Rg+fDh++eUXNGrUCAkJCdi3b59VrRoAeHt7FzpjclZWllUNWv5YxowZg08++QQajQbffPMNnnnmGcvixMU9bwXfhwDQpUsXfPrpp1Yx2vP+++/j0UcfxeTJkx3GX5K+seYKi8zMzGLvU1IunQiFh4cjISHBaltCQgL8/Pzs1gYBpirjSZMmWf5OTU1FVFRUmcc287Eh+P1SMvYkvYYM+XeM2zIURvElRrarx+UDiErI10OJcD/bL4aCqnjbrlFWxVtdrH19Pcr/clnwyyU9PR0AsGnTJlStWtXqPo1GU6rHcHTtK0x5xAGYmov+/vtvmxqhI0eO2NRe5NenTx/UqFEDy5Yts/SLadKkiU0Hc5VKZfW3JEk2zUAlFRQUhKCgIMvfnp6eCA0NRZ06deyWV6vVlvtatmyJP/74AwsXLsRnn32Gw4cPw2g02tR+HT58GK1atXIYQ3BwsN1OyX369IEQAps2bcJDDz2EvXv3WvWJLe55s5fkeHt7O3yO+T3yyCOIiYnBtGnTMGLECKv76tSpA0mScPr0abt9fU+fPo3AwECEhIRYtpk7T+ffVtZcOhFq27YtNm/ebLVt+/btVu2zBWk0mnv6YBeXRqnAFwNGYcy3MvYkTUGm4hBe2joMBuOXGN2ByRBRSYzuWKvUzVYFm8rK08GDB63+/v3331G3bl2Hq2Y3atQIGo0GV69eRadOneyWqV27NlQqFQ4ePGhpjrlz5w7OnTtnd5+6devC09MTO3fuxOjRo+0eU61WW2qpyisOADh79iyys7OtalAOHDiAGzduOKwRun37Ns6ePYtly5ahY8eOAEwdrkuqNPGWBaPRaOl+YU7KMjIyLKP6/vrrL/z666949913HR6jRYsWdkdSeXh44F//+he++eYbXLhwAfXr18eDDz4IoOzOW3HMnTsXzZs3t6ldq1KlCrp3745PPvkEEydOtErK4+Pj8c0332DYsGFW339///03qlWrhuDg4HKJFXCyRCg9Pd0ybwFgGh5/7NgxBAUFoXr16pg2bRpu3LiBL7/8EoCpCnPx4sV47bXX8Nxzz2HXrl349ttvsWnTpsp6Claq+GjwUd9heO1/ErYnTkam4hBe2f4shPgKYx9pUNnhEVEZu3r1KiZNmoT/+7//w5EjR7Bo0aJCRyr5+vpi8uTJmDhxIoxGIzp06ICUlBT89ttv8PPzw/Dhw+Hj44NRo0ZhypQpqFKlCkJDQ/Hmm29amkMK8vDwwOuvv47XXnsNarUa7du3x61bt3Dy5EnLcOzo6GgcPHgQly9fho+PD4KCgso8DsDULAYAixYtwssvv4wLFy7g5ZdfBuB4+oDAwEBUqVIFn3/+OSIiInD16lVMnTq1OKffSmniBUzfQ+YaMgCWEU3x8fGWbSEhIVAoFJg2bRp69uyJ6tWrIy0tDWvWrMGePXssU7i0adMGnp6emDJlCt58801cvHgR48aNw7hx46xGhBVkrnG5c+cOAgMDre4bMmQIHn/8cZw8eRLPPvusZXtZnbfiaNq0KYYMGYKPP/7Y5r7FixejXbt2iImJwbvvvouaNWvi5MmTmDJlCqpWrWoZvWi2d+9ePPbYY+USp4VwIrt37xYAbG7Dhw8XQggxfPhw0alTJ5t9mjdvLtRqtahVq5ZYuXJliR4zJSVFABApKSll8yQKyM7Ri/MJqaLX0iVCmqERmAnhOb2l+GLvmXJ5PCJnlpWVJU6dOiWysrIqO5QS69Spk3jxxRfF888/L/z8/ERgYKB44403hNFotNz/yiuv2OxnNBrFggULRP369YVKpRIhISEiJiZG/PLLL5YyaWlp4tlnnxVeXl4iLCxMzJs3z+p4BY9tMBjEu+++K2rUqCFUKpWoXr26mDNnjuX+s2fPiocfflh4enoKACIuLq5M4ihoypQpIiYmRvTq1UtoNBrRokUL8c033wg/Pz/x7LPPOjyX27dvFw0bNhQajUY0a9ZM7NmzRwAQGzZssDrfBR+3b9++lu+L0sQrhBAzZsyw+z2U/xYXFyeEEOK5554TNWrUEGq1WoSEhIiuXbuKbdu2WR3vf//7n6hXr55QqVSidu3a4t///rcwGAwOH9+sdevWYunSpTbbDQaDiIiIEADExYsXy+S8DR8+XPTt29dhLPbuj4uLE2q1WthLMy5fviyGDx8uwsLChEqlElFRUeKll14SSUlJVuWysrKEv7+/OHDggMPHLuyaUNzvb0kIzuhXmNTUVPj7+yMlJcXuMMaykpiWjVH/WYVNNydASFp4Glrii8f/g8Gt65bbYxI5m+zsbMTFxaFmzZp2O4vezzp37ozmzZtjwYIFlR3KfSMmJgYPPfRQoc1AZN+mTZswZcoU/P3330XWYjmrTz/9FBs2bMC2bdsclinsmlDc72/XPHtOKNTXA9+OGI3Hqy6EJDTIUhzGR0fH4vqdu5UdGhFRuTh+/DiaNm1a2WE4pd69e2Ps2LG4ceNGZYdSblQqFRYtWlTuj8NE6D7iqVbiuxGjMbj2p/BQeOLP+D0YsP5fTIaIyOXEx8cjISGBidA9mDBhQrmMar5fjB49usjpDMqCU3WWdgcalQKrBg9H7xORGLXpSRy4uRtPre+HdU/+gBr5hmwSkXPZs2dPZYdwXwkPD+dai3RfYI3QfUipkDGg2WNY2ecHeKl8cPDmL3hoaXes2n+mskMjIiJyKUyE7lMKWcLTTbrji14boJS8cCvnCF7Y+jSW/3a6skMjIiJyGUyE7mOyLOHpJo+iT+RiSMIT2fLfGLftaSzbe6qyQyMiInIJTITuc0qljO9GDseT1T+FJLyglU/ipR1PY8kvJyo7NCIiIqfHRMgJKBQy1g4figE1PoMkvKGVT+HVnQOwcNexyg6NiIjIqTERchIKhYw1wwdjUM3PIAtvaBVn8Novz+CDbUcqOzQiIiKnxUTIiciyjK+GDsLQOsshC1/o5LN487dnELvlz8oOjYiIyCkxEXIysixjxeCnMar+SsjCDzr5PN4//CxOxrvu7KJERETlhYmQE5JlGZ898y+80Hg11FIAUvRn8dR3PXGKyRAREVGJMBFyUpIkYfHT/bBp0DYEeYTgTPIJ9Pv2Mfz9z7XKDo2ICujcuTMmTJhQ2WEQkR1MhJxct7oP4ccB2xDsGYbzd06hz9rueOPHvTAaOXU9kbMQQkCv11d2GERuiYmQC+hYszn+98wOBHuG43LqWfz76GCM/nobDEyGiCrdiBEj8Msvv2DhwoWQJAmSJGHVqlWQJAk///wzWrZsCY1Gg3379mHEiBHo16+f1f4TJkxA586dLX8bjUbExsaiZs2a8PT0xAMPPID169dX7JMiciFcdNVFPFy9CWY8/C0m7HoSevk6vro4CjlfLsOqYT2gkKXKDo+oXAghkJmTWSmP7aXygiQV/dlauHAhzp07hyZNmmD27NkAgJMnTwIApk6dig8++AC1atVCYGBgsR43NjYWX3/9NZYuXYq6devi119/xbPPPouQkBB06tSp9E+IyE0xEXIh4x/pCAkbMGHXv6CXb2Bt3CgYVn2OL4f3glLByj9yPZk5mfCJ9amUx06flg5vtXeR5fz9/aFWq+Hl5YXw8HAAwJkzpgWUZ8+eje7duxf7MbVaLebMmYMdO3agbdu2AIBatWph3759+Oyzz5gIEZUCEyEXM+6R9lArf8KL2/pCL/+Db6+Mhn7FUnzz3BNQMRkiuq+0atWqROUvXLiAzMxMm+RJp9OhRYsWZRkakdtgIuSCxrRrA7ViI8Zs7osc+SZ+uD4WA5cbsPa5/lArmQyR6/BSeSF9WnqlPfa98va2rlGSZRlCWPfty8nJsfw7Pd30XDdt2oSqVataldNoNPccD5E7YiLkooa3aQW1YhOGb+yDHPk6fro5Fk9/YcC3o5+ERqmo7PCIyoQkScVqnqpsarUaBoOhyHIhISH4+++/rbYdO3YMKpUKANCoUSNoNBpcvXqVzWBEZYTVAy5sUKvmWNP3Z6iNNWCQkrEx/v/w3tZtlR0WkduJjo7GwYMHcfnyZSQlJcFoNNot9+ijj+LPP//El19+ifPnz2PGjBlWiZGvry8mT56MiRMnYvXq1bh48SKOHDmCRYsWYfXq1RX1dIhcChMhF/dUiyb49snN0IhaMEp3sfjvodhz6Y/KDovIrUyePBkKhQKNGjVCSEgIrl69ardcTEwMpk+fjtdeew0PPfQQ0tLSMGzYMKsy77zzDqZPn47Y2Fg0bNgQPXr0wKZNm1CzZs2KeCpELkcSBRukyUpqair8/f2RkpICPz+/yg6n1A7EXcaYzf1xMukY/NQB+GHAZnSt3baywyIqkezsbMTFxaFmzZrw8PCo7HCIqJIVdk0o7vc3a4TcRNua0dgzYheahz2EVN1d9P+2B1b8sRXZOUX3WyAiInJVTITcSLB3IHYN245WEe2QpkvFmE390ePTz5Gp49T+RETknpgIuZlAL39sHrQZflILGKUs/Jo8Ed2WLEa6lskQERG5HyZCbijE1x+bBv8PPqIVhKTFgZTX0GXxfKRk5RS9MxERkQthIuSmOtSpip0jNsJXtAWkHPyZ9iY6L34fdzN1lR0aUZE4xoOIgLK5FjARcmOto8Pw66if4I9OgKTHsYwZaP/xO0hMza7s0IjsUihMk4HqdEzYiQjIzDQtumyedLQ0OLO0m2seFYz9ozeg4xcDkSxtx6ns99B+URZ2vTAbUUH3voQAUVlSKpXw8vLCrVu3oFKpIMv8LUfkjoQQyMzMRGJiIgICAiw/kkqD8wgVwVXmESrKuYQUdPjsWdwSGwEA1eVx+GvyfPh7qis5MiJrOp0OcXFxDmdnJiL3ERAQgPDwcEiSZHNfcb+/mQgVwV0SIQC4lpyBhz8ZgZuG9QCASa1n4r1ub8FDxbXJ6P5iNBrZPEbk5lQqVaE1QcX9/mbTGFlEBXnjyEtfYuSGcPx8ZTHmH5qJzJxM/Puxd+HjUfr2V6KyJssyZ5YmojLBBnayEubviU3DP8bUtrMBAEuPzsOLmybgQkJaJUdGRERU9pgIkQ1JkjCn+1uY/ciHAICv/v4ELT95Gv85FFfJkREREZUtJkJklyRJeKvzRLza6iNAyEiVt2LMxpH4dM9ZzuFCREQug4kQOSRJEmJjXkK38DmAUCBD8Qte3TUc7289AaORyRARETk/JkJUKJVSgS1jpqB/9QWQhBpZioOYtX8YZvzvTxiYDBERkZNjIkRFUihkrB/xIobVXQpJeCJbcRzzjgzFtA37kWPgXC5EROS8nC4RWrJkCaKjo+Hh4YE2bdrg0KFDhZZfsGAB6tevD09PT0RFRWHixInIzuYSEiUlyzJWDh6B5xuvgCx8oJPPYsFfz2Ly978gS8eV64mIyDk5VSK0bt06TJo0CTNmzMCRI0fwwAMPICYmBomJiXbLr1mzBlOnTsWMGTNw+vRpLF++HOvWrcMbb7xRwZG7BkmSsOSpgZjQ7BsoRCBy5Mv45OQQTNmwE9k5hsoOj4iIqMScKhGaP38+xowZg5EjR6JRo0ZYunQpvLy8sGLFCrvl9+/fj/bt22Pw4MGIjo7GY489hkGDBhVZi0SOSZKED/r3wZQWa6EwhkIv/4P/xI3EjvNHkaVjMkRERM7FaRIhnU6Hw4cPo1u3bpZtsiyjW7duOHDggN192rVrh8OHD1sSn0uXLmHz5s3o1auXw8fRarVITU21upE1SZLwXp/ueKv1d4jwqo1k7T8Y9r8e2HhmHzLZTEZERE7EaRKhpKQkGAwGhIWFWW0PCwtDfHy83X0GDx6M2bNno0OHDlCpVKhduzY6d+5caNNYbGws/P39LbeoqKgyfR6uQpYlTO/ZET8O2IFGwc1xJ/s2Rm7sg3V/bUV6dk5lh1diRqPA7XRtZYdBREQVzGkSodLYs2cP5syZg08++QRHjhzBDz/8gE2bNuGdd95xuM+0adOQkpJiuV27dq0CI3YuCllCy6ga+PqJjWgV3h4ZOWkYu/lJDPn6E6RmOdeCmLfStchk0x4RkdtxmkQoODgYCoUCCQkJVtsTEhIQHh5ud5/p06dj6NChGD16NJo2bYr+/ftjzpw5iI2NhdFof9i3RqOBn5+f1Y0cU8gSmkZGYPnjP6CuX2fohRY/XZ+EAV/Ow90M50iGsnMMuJWmhZ7zIhERuR2nSYTUajVatmyJnTt3WrYZjUbs3LkTbdu2tbtPZmYmZNn6KSoUCgDgMhFlSKmQ0TA8GM83XQJv/aOAZMTW+OnotWIaEtPu76kKhBC4ficLQgAGB8kxERG5LqdJhABg0qRJWLZsGVavXo3Tp0/jhRdeQEZGBkaOHAkAGDZsGKZNm2Yp36dPH3z66adYu3Yt4uLisH37dkyfPh19+vSxJERUNlQKGeM7N8A7jyyBr/4JAMCB5Pno/NnzuHI7vZKjc+x2hs4y2o01QkRE7kdZ2QGUxMCBA3Hr1i28/fbbiI+PR/PmzbFlyxZLB+qrV69a1QC99dZbpsVD33oLN27cQEhICPr06YP33nuvsp6CS1MrZYzrUg+eqg/x5k5/JCu/wumM1ej4+R38PHwVGkcGVnaIVnR6I+JT8mqs9AYmQkRE7kYSbCMqVGpqKvz9/ZGSksL+QsWk1Ruw4egNTPjfB0iQFwOSQBW5I34avA5ta4VDkqTKDhEAEJeUgfRs6+H+jSP9IMv3R3xERFR6xf3+dqqmMXIOGqUCTz5YDasGTEO09CYglLht3IuYr3vhx+MX7ovFWlOycmySIAAw8HcBEZFbYSJE5UKlkPFYo3CsGfIKGqnmQBKeSMcxvP7rkzh45SJ0+srrmCyEsGoSy+9+SNKIiKjiMBGiciPLEh6uXQXfjhyLLkFL4K8Jxvk7JzBwQ3fsunC80tYnu52hc5iIscM0EZF7YSJE5UqSJDSO9MfakYPxzRPbUM03GtfTLmPIf2Ow7tgvFT6bs8EokJjq+DEN7DBNRORWmAhRhQjx1aBT7ab4+oltaBDUFMnZtzBq8+OI+XQxbtzJrLA4EtOyC23+0nMuISIit8JEiCqMj0aJdjVrY03/Lajm1RoGZOFwxuvo+ul7uJCYVu6Pr9UbcDu98Nmu2UeIiMi9MBGiCqVSyGheNQIreq9HADoDkgFnc+bg0c9exfFrd8r1sRNTtShqUBj7CBERuRcmQlThJElC90ZR2DXye4TLTwIArhmXoduK57D/QmK5PGamTo+7mTlFlmONEBGRe2EiRJWmRfUg7Ht+FWqpXgAAJOFH9Pj6SWw/fa1MHyc7x4BryVnFKssaISIi98JEiCpV7RAf7Bv3IR7wmgEIJdKkfei7rgd+PH6mTI6fkpmDC4npxZ63iAuvEhG5FyZCVOki/D2x68VpaOc/H7LwRpZ0CgM3dMe6I3+W+pjmSROvJmcW2S8oP9YIERG5FyZCdF8I8tbg5+efR6fAT6EwhkAnXccL23th4+l90BtKVkuTYzAiLikDt9JKPkcRF14lInIvTITovuHnqcKGMc9gVP2vUTewCe5k38LTP8Tgs0Pf4W5m4cPeAVNH54TUbJyNT0OGtnSzVgthqk0iIiL3wESI7iv+Xip8PKArvun7M9pVfRTZ+ky8vH0wZu2aj7hb9vv6CCFwO12LcwlpxRoiXxQ2jxERuQ9J8OdvoVJTU+Hv74+UlBT4+flVdjhuIzvHgHOJdzHr10n44dyXAIAmfoOwsv/H8PFQQ5YkyBIASNAbjcjRl93buG6YDzxUijI7HhERVbzifn+zRojuSx4qBeqFBmBGh4Wo5zEWAPB36n/w+Jp/4fqdu9DmGJGlMyJLZyjTJAhgjRARkTthIkT3LQ+VAvXCffHSQ1MQpn8dECok5OzFE992x5o/jyOnhJ2oi4sLrxIRuQ8mQnRf81ApMLpjTXzSfzzqSO9DFn7Iwjn8++hTGPrVd9hxKqHMZ4PmwqtERO6DiRDd9zxUCvRqGoHlg55Fr7AvoDRWhUG+hdP6CZi7Zw3GrTmCE9fvltnjcZkNIiL3wUSInIKHSoGHooPwft8YrOi5FcGqByGkLCSq38HptG/x721nodWXbsh8QewjRETkPpgIkdPwVCtQM9gbD1avhq1DtqBLtYGAZMQd9WcIqvo1FHLZJDCsESIich9MhMipeKoVqBXsA41KjQWPLcUrrWZCgoRd17/Ci1ufQqr27j0/BmuEiIjcBxMhcjrmZEihkDDqgQlY0O1reCq98fvNPRjyv264knIRV26XbokNgAuvEhG5EyZC5JTMzWSyDHSp0RtfPr4F4d7VcCXlAvqv74xR61Zi4183S3Vs1ggREbkPJkLktLzUSksyVL9KU6x5YicaV2kFPdKQqH4b351ZXuIFWwH2ESIicidMhMipeamVCPPzAAAEe4Vh1eMbUcOjByAZcR2LMXH7i8gxFL1ga35GIxdeJSJyF0yEyOkFeamhVEgAAI3SA9PaLEJAznOAkPDLjbUY/XNf3M66VaJjsnmMiMg9MBEipyfLEoJ9NJa/H6pZBdUUAxCqexuy8MLRhAMY/N8uOHP7r2Ifk81jRETugYkQuYQq3mooTMvRQ6WQ8Ui9EHgaH0K49kMEe9TAPxnXMex/Mdh8cX2xjscaISIi98BEiFyCLEsI8c2rFXq0QSgAQCWi0ELzCTpU645sQxam7hmNDw9Nh96oL/R4XHiViMg9MBEil5G/VqhuqA+qBXoCAM7FC7zZZhVGPTAJALD6xCKM2/o0UrR3HB6LC68SEbkHJkLkMmRZQrCvGgAgSZKlVggAfj13G6+0ehsfPLoKHkovHLi5G8/8t7PDfkPsI0RE5B6YCJFLqeKtsdQKdakfCpVCQttaVdAwwg8A8FjNfvi6z3ZU843GjbQrGPq/x/C/82ttjsM+QkRE7kESnDClUKmpqfD390dKSgr8/PwqOxwqhsTUbCSkmpbXyNTp4aVW2pRJ1d7FtD1jsff6NgDAoEZjMLn1e1ApTDVKAV4qRAV5VVzQRERUpor7/c0aIXI5gd5qy7/tJUEA4KcJwKLH1uL5Fq8DAP5zahlGbe6Du9nJAFgjRETkLpgIkctRKWTIxXhny5KMFx+chkXd18JX7YdjiQex5tRnANhHiIjIXTARIpfkoVJY/a3VG3DldobdBKdT9R54tvGLAIDbWYkAmAgREbkL++0GRE5Oo5SRqTUAABbtOo9tpxIAAMuGtkK4v4ed8qah9jqDqW8Rh88TEbkH1giRS9Io82qEfD1Uln/fTMmyW14tm/oVaXMTIS68SkTkHpwuEVqyZAmio6Ph4eGBNm3a4NChQ4WWv3v3LsaNG4eIiAhoNBrUq1cPmzdvrqBoqbJoVHlv7Yh8NUD/3LWfCGmUpjI5uYkQwA7TRETuwKmaxtatW4dJkyZh6dKlaNOmDRYsWICYmBicPXsWoaGhNuV1Oh26d++O0NBQrF+/HlWrVsWVK1cQEBBQ8cFThfLIVyMUmS8RupmSbbd8wRohwNRPqEBXIyIicjFOlQjNnz8fY8aMwciRIwEAS5cuxaZNm7BixQpMnTrVpvyKFSuQnJyM/fv3Q6UyNY9ER0dXZMhUSdRKGZIECAFEBnhatt90UCOkVpiSJR1rhIiI3IrTNI3pdDocPnwY3bp1s2yTZRndunXDgQMH7O7z008/oW3bthg3bhzCwsLQpEkTzJkzBwaDweHjaLVapKamWt3IOXnkNo8FequhVpr+/Y+jGqHciRTzJ0JceJWIyPU5TSKUlJQEg8GAsLAwq+1hYWGIj4+3u8+lS5ewfv16GAwGbN68GdOnT8eHH36Id9991+HjxMbGwt/f33KLiooq0+dBFcfcYVqWJEvzWEJqtt2h8WqFaeV6nTF/jRBHjhERuTqnSYRKw2g0IjQ0FJ9//jlatmyJgQMH4s0338TSpUsd7jNt2jSkpKRYbteuXavAiKksWXeYNjWP6Y0Ct9K1NmXNiZBWb91HiIiIXJvT9BEKDg6GQqFAQkKC1faEhASEh4fb3SciIgIqlQoKRV6P14YNGyI+Ph46nQ5qtdpmH41GA41GU7bBU6XIP4Q+MsB65Fi4n/VcQuZEKMfIPkJERO7EaWqE1Go1WrZsiZ07d1q2GY1G7Ny5E23btrW7T/v27XHhwgUY8zVxnDt3DhEREXaTIHItGqVtjRAAy4KsVmUtnaV1lm2sESIicn1OkwgBwKRJk7Bs2TKsXr0ap0+fxgsvvICMjAzLKLJhw4Zh2rRplvIvvPACkpOT8corr+DcuXPYtGkT5syZg3HjxlXWU6AKpMkdOQYAraOD8MFTD2DN6Dbo0cS2BlFlGT6f15maiRARketzmqYxABg4cCBu3bqFt99+G/Hx8WjevDm2bNli6UB99epVyPlW24yKisLWrVsxceJENGvWDFWrVsUrr7yC119/vbKeAlUgSZKgVsrQ5hgR6K22WpW+oLwJFfNqhNg0RkTk+iTBdQQKlZqaCn9/f6SkpMDPz6+yw6ESuno7EylZOUWWi0+/jsfWNYFKVuPwSNPCq2qljPrhvuUdIhERlYPifn87VdMYUUnlHzlWGPOEijlGnWWNMQ6fJyJyfU7VNEZUUvk7TJ9LSMOpf1Jx824WBraKQhWfvNGB5gkVAdOkihqlh2XhVcnc0YiIiFwOEyFyaR75Fgv77UISfjh6AwDQrnZwgUQo7986oxYamGqI9EYBlYKJEBGRq2LTGLk0tcL+EPqCa46ZR40B1kPojexCR0Tk0pgIkUuTZcmyzpjVpIop1omQJEl5y2zkG0LPbkJERK6NiRC5PHM/IesaIdvFVzWWRIg1QkRE7oKJELk888ixKj5qS1NZwRohAFDJueuN5Z9UkYkQEZFLYyJELs8j3yr04bmr0P+TYrsKvblGKP+kioJNY0RELo2JELk861Xo80aD3S6wCr1lBXrWCBERuQ0mQuTyrFehz9dPKMW6n5DK3EfIyD5CRETugokQuTyFLEGZOxeQuUYIsO0nZOksrc8/aoyJEBGRK+OEiuQWPFQKpBv0qB7khTohPogI8ECIr8aqjGX4vDGvyYx5EBGRa2MiRG7BPJdQ40h/fDSwuf0ydobPs48QEZFrY9MYuQVFMdYLU8v2JlRkIkRE5MqYCJFbUMjFSISUnFCRiMjdMBEit2AvEdIbjFZzCantTKjICiEiItfGPkLkFvI3jW09GY/vj1xHQmo2Zj/RBA9EBQCwP6FiwUkXiYjItTARIrcg56v71BsF/smdQyghLa/2R2VnQkXBpjEiIpfGpjFyC8p8mVCgl8ry77uZOZZ/qxVqANYTKnLUGBGRa2MiRG4hf41QoJfa8u+7mXlJj0Zhmmwxx5A3jxCbxoiIXBsTIXIL+fsIBeSvEcrKqxFS5dYIafMlQqwQIiJybUyEyC3kHzUW4Jm/RigvETLXCOkKJELsJ0RE5LpK3Fn67t272LBhA/bu3YsrV64gMzMTISEhaNGiBWJiYtCuXbvyiJPonkiSBEkyJTaeagU0ShlavRF38jWNqeXcPkIG61XpDUZhWauMiIhcS7FrhG7evInRo0cjIiIC7777LrKystC8eXN07doV1apVw+7du9G9e3c0atQI69atK8+YiUolfzJjbh6z7ixtWyMEcC4hIiJXVuwaoRYtWmD48OE4fPgwGjVqZLdMVlYWfvzxRyxYsADXrl3D5MmTyyxQonulkCTkwJTVBHqpkZCqRbpWjxyDESqFbBk1ln/4PMDZpYmIXFmxE6FTp06hSpUqhZbx9PTEoEGDMGjQINy+ffuegyMqS7Jsv8N0SlYOgn00lkVX80+oCDARIiJyZcVOhIpKgu61PFF5yz9yrHfTSLSrHYwATxV8NKaPgblprGCNEIfQExG5rnuaWVoIgT179uDChQuIiIhATEwMVCpV0TsSVYL8I8ea5y6rkZ+9CRUBwGgs17CIiKgSlSgR6tWrF/7zn//A398fycnJ6NWrFw4dOoTg4GDcvn0b9erVw6+//oqQkJDyipeo1Ipagd7ehIoAm8aIiFxZieYR2rJlC7Ra05fEW2+9hbS0NFy8eBGJiYm4cuUKvL298fbbb5dLoET3qqhESCXbTqgIcJkNIiJXVuoJFXft2oXY2FjUrFkTAFCtWjW8//772Lp1a5kFR1SW5Hx9hHIMRsQlpePI1Ts4n5AGANAoHQ2fZyJEROSqStxHSMr9Mrlz5w5q165tdV+dOnVw8+bNsomMqIzlrxG6labFy2uPAQAeqRuMKTENHE6oyD5CRESuq8SJ0IgRI6DRaJCTk4O4uDg0btzYcl98fDwCAgLKMj6iMpM/EbJeeNU0qaLjCRVZI0RE5KpKlAgNHz7c8u++ffsiMzPT6v7vv/8ezZs3L5PAiMpa/kTI3jIbllFjdpbYICIi11SiRGjlypWF3j9jxgwoFIp7CoiovOSfRwgwTaqYkKrNVyNkmlBRZ7ROhFghRETkusp09Xlvb294eHiU5SGJyoxc4N1uXoU+TauH3mC0DJ83CiP0Rr2lHEeNERG5rhInQqdOncKLL76IFi1aICIiAhEREWjRogVefPFFnDp1qjxiJCoTygKZUKC39TIbKkVevyFdvtml2UeIiMh1lahp7Oeff0a/fv3w4IMPom/fvggLCwMAJCQkYPv27XjwwQfx3//+FzExMeUSLNG9KDiNkLlGCADuZOYgwMvT8rfOoIN5OTIj+wgREbmsEiVCU6dOxeuvv47Zs2fb3Ddz5kzMnDkTU6ZMYSJE9yVJkiDLecPh8y+8ejdTB4XsA6WkhF7ordYbYx5EROS6StQ0du7cOQwZMsTh/YMGDcL58+fvOajCLFmyBNHR0fDw8ECbNm1w6NChYu23du1aSJKEfv36lWt8dH9TWK1Ab2cIvdK8zEbeemMcNUZE5LpKlAhFR0dj06ZNDu/ftGkTatSocc9BObJu3TpMmjQJM2bMwJEjR/DAAw8gJiYGiYmJhe53+fJlTJ48GR07diy32Mg55B85FphbI6RWytAaTNVEassyG+wjRETkDkrUNDZ79mwMHjwYe/bsQbdu3az6CO3cuRNbtmzBmjVryiVQAJg/fz7GjBmDkSNHAgCWLl2KTZs2YcWKFZg6dardfQwGA4YMGYJZs2Zh7969uHv3brnFR/e//DVCrWoEYd3Yh+GpUlhmTLc3qaIQgBDCUoaIiFxHiRKhp59+GlWrVsXHH3+MDz/8EPHx8QCA8PBwtG3bFnv27EHbtm3LJVCdTofDhw9j2rRplm2yLKNbt244cOCAw/1mz56N0NBQjBo1Cnv37i3ycbRarWVhWQBITU29t8DpvpI/EVIrZagLVIo6mlTRKAAF8yAiIpdT4iU22rVrh3bt2pVHLIVKSkqCwWCw1EKZhYWF4cyZM3b32bdvH5YvX45jx44V+3FiY2Mxa9asewmV7mNyEbU6jiZVNBhFkavXExGR8ynTCRXvJ2lpaRg6dCiWLVuG4ODgYu83bdo0pKSkWG7Xrl0rxyipohWVzFgSoXydpQH2EyIiclUlrhEqzBtvvIH4+HisWLGiLA8LAAgODoZCoUBCQoLV9oSEBISHh9uUv3jxIi5fvow+ffpYthlzx00rlUqcPXsWtWvXttlPo9FAo9GUcfR0vyiYCG366yau3slCts6Aid3rQS2bE6Fsq3JMhIiIXFOZ1gjduHEDly9fLstDWqjVarRs2RI7d+60bDMajdi5c6fdfkkNGjTAiRMncOzYMcvtiSeeQJcuXXDs2DFERUWVS5x0fyuYCO0+ewubT/yDXWcTTctsKB3VCFVYiEREVIHKtEZo9erVZXk4G5MmTcLw4cPRqlUrtG7dGgsWLEBGRoZlFNmwYcNQtWpVxMbGwsPDA02aNLHaPyAgAABstpP7KLjwqs0yG7k1QtoCNUKcS4iIyDWVaSJU3gYOHIhbt27h7bffRnx8PJo3b44tW7ZYOlBfvXoVcsGVNYnykQvUCBVcZkPjoI+QYNMYEZFLKnEilJSUhBUrVuDAgQNWw+fbtWuHESNGICQkpMyDzG/8+PEYP3683fv27NlT6L6rVq0q+4DIqRRsGiu4zEZeZ2nWCBERuYMSVZ/88ccfqFevHj7++GP4+/vjkUcewSOPPAJ/f398/PHHaNCgAf7888/yipXoniltEiHrZTbMK9DrjOwjRETkDkpUI/TSSy/h6aefxtKlS21m2RVC4Pnnn8dLL71U6ASHRJWp4DxCgflqhO5k6aCxM7M0wFFjRESuqkSJ0PHjx7Fq1Sq7Sw1IkoSJEyeiRYsWZRYcUVmzbRqzrhFSK80zS7NpjIjIHZSoaSw8PLzQ1d4PHTpkM/Mz0f3EJhHyLNhHyFwjxAkViYjcQYlqhCZPnoyxY8fi8OHD6Nq1q82iq8uWLcMHH3xQLoESlRVZBnLn1izQWToH4VUcTKhorLDwiIioApUoERo3bhyCg4Px0Ucf4ZNPPoHBYAAAKBQKtGzZEqtWrcKAAQPKJVCisqKUZehyMxtPlQIPVg+Aj0aJmsE+SJa5xAYRkTsp8fD5gQMHYuDAgcjJyUFSUhIA0/IXKpWqiD2J7g+KfA3CkiRh1hN5E2yu/MvBhIpMhIiIXFKpJ1RUqVSIiIgoy1iIKkRhK9CbJ1TM4YSKRERuodTTMM+dOxd37961+TfR/a6wFejNEyraLrFRriEREVElKXUiNGfOHCQnJ9v8m+h+56hGSAgBheRoQkXWCBERuaJSN43lbypgswE5E6XCOhH6+e9/sO6Pa0jJykH3lnoAthMqch4hIiLX5FSLrhKVhYIr0BsFcDvDVAOkzVEAsE2EmOsTEbkmLtVObsd2Bfq8EY/ZOaaPRMFECGCtEBGRK2IiRG6nYI1Q/kkVs3WOEyH2EyIicj1MhMjtKBQFF17NW28sS2u/aQxgjRARkSsqk0TI3iKsRPerwmqEcrsKQWsnEWKFEBGR6ymTRIijxsiZFJxHyFOlgFpp+iikZ5vuyzHaqRHi+5yIyOWUOhE6deoUoqOjLf+uUaNGWcVEVK4KziMkSZKlw3R6lum+gmuNAewjRETkikqdCEVFRUGWZcu/FQpFmQVFVJ7szSwd5G3qJ5SpNb2nC84sDQBG9hEiInI5pUqEFAoFEhMTbbbfvn2bCRHd9xSyhILd2swdpiWYaob0xhwYhfW6GsyDiIhcT6kmVHTUJ0ir1UKtVtu9j+h+IkuSVZ+f3s0i0L5OMDw1OozeYdqmM2jhofS0lOGoMSIi11OiROjjjz8GYOpT8cUXX8DHx8dyn8FgwK+//ooGDRqUbYRE5UAhS1aJzQPVAgAAOcYcy7aCiRAHBRARuZ4SJUIfffQRANMXwtKlS62awdRqNaKjo7F06dKyjZCoHCgcNAorJSUkSBAQtuuNMREiInI5JUqE4uLiAABdunTBDz/8gMDAwHIJiqi8OVqBXpIkaBQeyDZk2SRCbBkjInI9peojtHv37rKOg6hCKWUZgMHyt95gxJXkTNzJ0EEhqQBk2UyqyFFjRESup8xXn589eza6dOmCjh07lvWhicqMXKBpLE2rx4R1xwAAem/Tx6LgpIqcR4iIyPWU+VpjK1euRExMDPr06VPWhyYqMwXnEvL3VMG8SRKmIfQFJ1XkqDEiItdT5jVCcXFxyMrKYvMZ3dcKrjcmSxICvNRIztBB5CZCBSdVZI0QEZHrKZfV5z09PdGrV6/yODRRmbA7u3TupIrCmNs0VqBGiBVCRESup1SJ0MyZM2E0Gm22p6SkYNCgQfccFFF5s5cIBXqbV6G3XyPEpjEiItdTqkRo+fLl6NChAy5dumTZtmfPHjRt2hQXL14ss+CIyotcSI2QJEz/tx0+z0SIiMjVlCoR+uuvv1CtWjU0b94cy5Ytw5QpU/DYY49h6NCh2L9/f1nHSFTmCvYRAoBAb+v1xmwSIdtKUCIicnKl6iwdGBiIb7/9Fm+88Qb+7//+D0qlEj///DO6du1a1vERlYvCVqC3JEIFhs8DprmE7NUmERGRcyp1Z+lFixZh4cKFGDRoEGrVqoWXX34Zx48fL8vYiMqN3T5CXgVrhHQ2ZbjMBhGRaylVItSjRw/MmjULq1evxjfffIOjR4/ikUcewcMPP4x58+aVdYxEZc5e05i5RkgpmfsIZduUYT8hIiLXUqpEyGAw4K+//sJTTz0FwDRc/tNPP8X69estC7MS3c/sNW/VDvHBd//XFl0bVANgv0aI/YSIiFxLqfoIbd++3e723r1748SJE/cUEFFFkSQgfwWPQpagkBVQyRoAtsPnAdYIERG5mmLXCIlifgEEBweXOhiiiuRoBXqNwpQIFZxQEWAfISIiV1PsRKhx48ZYu3YtdDrbL4f8zp8/jxdeeAFz58695+DsWbJkCaKjo+Hh4YE2bdrg0KFDDssuW7YMHTt2RGBgIAIDA9GtW7dCy5N7Kbjwqpla4bhGSLBpjIjIpRS7aWzRokV4/fXX8eKLL6J79+5o1aoVIiMj4eHhgTt37uDUqVPYt28fTp48ifHjx+OFF14o82DXrVuHSZMmYenSpWjTpg0WLFiAmJgYnD17FqGhoTbl9+zZg0GDBqFdu3bw8PDA+++/j8ceewwnT55E1apVyzw+ci4KSUIOrGt49pxNxLFrGQCADJ1tIsQaISIi1yKJ4rZ55dq3bx/WrVuHvXv34sqVK8jKykJwcDBatGiBmJgYDBkyBIGBgeUSbJs2bfDQQw9h8eLFAACj0YioqCi89NJLmDp1apH7GwwGBAYGYvHixRg2bFixHjM1NRX+/v5ISUmBn5/fPcVP95cLienI0hmstn204xw2XFiCu6rV6FZ9IOZ3/8zq/ogADwT7aCoyTCIiKoXifn+XuLN0hw4d0KFDh3sKrjR0Oh0OHz6MadOmWbbJsoxu3brhwIEDxTpGZmYmcnJyEBQUVF5hkhOxNy9ikJcaUu7q8/ZqhIxcb4yIyKWUatTY7NmzC73/7bffLlUwhUlKSoLBYEBYWJjV9rCwMJw5c6ZYx3j99dcRGRmJbt26OSyj1Wqh1ebNKJyamlq6gOm+Z6+zdKC3GhJM8whl5tgbNVbuYRERUQUqVSK0YcMGq79zcnIQFxcHpVKJ2rVrl0sidK/mzp2LtWvXYs+ePfDw8HBYLjY2FrNmzarAyKiy2EuEgrzVkHI/Fpk5WTb3s48QEZFrKVUidPToUZttqampGDFiBPr373/PQdkTHBwMhUKBhIQEq+0JCQkIDw8vdN8PPvgAc+fOxY4dO9CsWbNCy06bNg2TJk2y/J2amoqoqKjSB073LXuj5wO9VJYaoWy9/bXGiIjIdZR6rbGC/Pz8MGvWLEyfPr2sDmlFrVajZcuW2Llzp2Wb0WjEzp070bZtW4f7zZs3D++88w62bNmCVq1aFfk4Go0Gfn5+VjdyTQ4XXs3tI5Stt20a0xk4fp6IyJWUqkbIkZSUFKSkpJTlIa1MmjQJw4cPR6tWrdC6dWssWLAAGRkZGDlyJABg2LBhqFq1KmJjYwEA77//Pt5++22sWbMG0dHRiI+PBwD4+PjAx8en3OIk52C3j5BXXh8hncG2RiiHiRARkUspVSL08ccfW/0thMA///yDr776Cj179iyTwOwZOHAgbt26hbfffhvx8fFo3rw5tmzZYulAffXqVcj5Zsn79NNPodPpLGuimc2YMQMzZ84stzjJOdgbNeahUsBTmTuztNFOIqQXEEJAcjArNREROZcSzyMEADVr1rT6W5ZlhISE4NFHH8W0adPg6+tbZgFWNs4j5LpupWkRn2Lb/DXkq1U4oZsAtaiKP0eftLm/frgv1Moya1UmIqJyUG7zCAFAXFxcqQMjul/YqxECgEbhwThxFdCoDDAYhU1fIp3ByESIiMhF8GpObsteZ2kAeLplNABArTLaLZOjZz8hIiJXwUSI3Jajfj5qhWmeKXudpU3bmQgREbkKJkLkthw1jallx6PGAEDHGiEiIpfBRIjclr3h8wCgUebVCGXn6G3u5xB6IiLXwUSI3JajROjqbR0AQEDg64OXbO5n0xgRketgIkRuy9FUQH4aL8u/kzLSbe7XG0xzCRERkfNjIkRuy9GosRDfvFnHb9tJhIQAcgxMhIiIXAETIXJbjprGfDUqQJim2ErOsl2BHmDzGBGRq2AiRG7L0agxSZIgS6aRY3czM+yW4VxCRESugYkQuS1Jkhz2E1JIphXo03VZdofLc+QYEZFrYCJEbs1RIqSSTAuvCuTgTqbO5n4ta4SIiFwCEyFya476CSkVpqYxIeXgToZtIsQaISIi18BEiNyaw0kVc5fZAHKQbKdGiKPGiIhcAxMhcmsKB58AjcLcNKZzWCPEuYSIiJwfEyFya44WXvXVeAIARravhu6Nwm3u51xCRESugYkQuTVHTWM+uYlQkI8EtdL+x4T9hIiInB8TIXJrDlegz20a0xntr0APcBV6IiJXwESI3JrjztKmRCjHYNs/yIw1QkREzo+JELk1R/MIqWVTInThVjK+O3wN5xLSbMpwmQ0iIuenrOwAiCqTo4VX1UpTIrT55DX4669g0ENG1AvztSrDpjEiIufHGiFya46axsw1QgKmprFLSbZrjnHUGBGR82MiRG7NYdNYbh8hpcIAAIizmwhxLiEiImfHRIjcmsMaodxEyM/TlOgkpmmRnq23KsO5hIiInB8TIXJrjhMh01pjPh552+KS0m3KceQYEZFzYyJEbs3xPEKmDMhLk5fo2O8nxESIiMiZMREityY7GjWW2zTmoS48EeLIMSIi58ZEiNxaURMqqpUGS62RvQ7TnEuIiMi5MREit+aoaUyVO3w+x6hFVKAXAOBacqZNUxg7SxMROTdOqEhuragaIZ1Bh0bhvlAqJNQK9kGWzgCVZ97vBzaNERE5NyZC5NaKmkdIZ8jGy4/Wdbg/O0sTETk3No2RWytqHiFdIYuuAua5hJgMERE5KyZC5NYURSZC2UUeIzUrp0xjIiKiisNEiNya4+HzpgkVdUbrGqEMrd5mWY341Gz2FSIiclJMhMjt2asUMk+oqDNoAQDf/XkNY778E88s+x230rRWZY1G4ObdrHKPk4iIyh4TIXJ79voJqeXcGqHcRChbb0R8qqmZzN7EimnZeqRksomMiMjZMBEityfb+RRolNY1QrWCvS332ZtYEQBu3M2Cnh2niYicChMhcnv2a4RMnaW1uYlQzXyJ0CU7i68CgMEo8E9K0Z2riYjo/sFEiNyevf7S5lFjObmJULi/BzxVCgDAhcQMGIX9GaXvZuYgLZtNZERExZGlM1T6YBOnS4SWLFmC6OhoeHh4oE2bNjh06FCh5b/77js0aNAAHh4eaNq0KTZv3lxBkZKzsFsjlJsI6YUeBqMBsiShVoipVigpXYtley/ZjB4zu5achcS07DKfX8hoFEjX6pGcoUN8Sjau3s7E+YQ0nIlPtbqdjU/DhcR0XLmdgRt3s5CYmo3kDB3SsnOQnWOA0chlQYiocmXnGHDldgYuJKZX+lxsTjWz9Lp16zBp0iQsXboUbdq0wYIFCxATE4OzZ88iNDTUpvz+/fsxaNAgxMbG4vHHH8eaNWvQr18/HDlyBE2aNKmEZ0D3o8ISIQDQGbXwlL3wzEPVMeOnv2EUwMa//kGglxoDWkXZ7GswCiSkaJGYqoWfhwpBPmr4aEr2URNCQKs3IktnQGaOAZlaPbJzinuxMCU6hY1jUyokqBQy1AoZaqUMlUKCSilDJZv+rVTc+28kIQT0RgG9QUBvNMJgFMgxCBiMpr+NRsAgTH8bhekmhGmSSgHTvwHT6yNJptF9EiQoZNM2hSxZ/q+UJci5/zf9LUOWAaUsQ+FoQblyZDSanrvBKCzPEbnPyyhM5ybveZn+L0sSFJIEWTbNb6WQJUiOpj53Y0KYzqH5/WJ6X8DqfN5PhBCVGpPRKJBjNOZ+DgX0BiMMuefOKKzfj6ab6Rwqcj9LKoXp82T+jN1rLFk5BiSla5GapS+jZ3jvJOHoZ+19qE2bNnjooYewePFiAIDRaERUVBReeuklTJ061ab8wIEDkZGRgY0bN1q2Pfzww2jevDmWLl1arMdMTU2Fv78/UlJS4OfnVzZPhO4rV29nIqXApIh6ox4PrgwGAOx79jL8NAEAgB2nE7Bw53lLufFd6iCmcXiRjyFLgKdaAY1KAY1ShkYpQ5Yk04XIaLogGYRAdo4B2TkGZOoMyNIZoM0xWi5iOQYjPFQKhPl5lMnzTs/W41JSOnIMAjqDEUajgCxLuV/CgFppSpI0ShmNIv2gVigsSUVadg4ydaaaMgFAbzAiR2+Ezmg0HU9v+lujVKBqoKfV415OyoBWb7R8+cvm/8sSJACQABkS/DyV8PVQWfYz9cHKgkBuspR76cqr4MpLniIDPOGR25QpSab5n+5k5liSKPMNEFbJiEKSUDPYx7IfANxO1yE7x2D5YgBgSlJgOpYh94vGtL9s+YIGTLWH+twkyIqUl+woZAleagVU+ZJPY27yJCAgQQIkARlS7nMVpgOYnjFCfD2gUkiQYDqX2XrTe0ghyZBlydL0mz+BMBhNf3uqFfkSUeBWuhbZOoMpcct9npabZP5iNCXLaqXCkoQAAlp97uuRm/yZkl5TAmxOYiUJCPHRQKNSWM6v3iigzTFCMr9+Eixf0jqDEbocI7QGI/QGI0J8PZD/G+t2uhYZOkO+BFjKS/KVuYm+yvRZU+Ymzub3WVp2DvQGU6x6g9GSEIjc829+/kHe6rz3oQB0BqPleiGEgN4Ay2fUYDRaEmC90YgwXw8o8o3GyNDpkZqVA6UsQ6WUoM790aFWyLmJr/mcy/D1UCL3EwFJApLStKYaXfNraTS9/sj9PEAChBHwUMnw8VBBnxuTEKb3ISzvmrxk0fx5gzC9Dn6eSmiUCku8KVk5uHQrHTqD6XMtAVDIgEKWoZCR+14wXSM61guBOvc9bBQC15IzEZ+aDW2OEelaPdK1emTqDNAbjAj0UiMywBPBPhooZFNtu3cJfywWR3G/v52mRkin0+Hw4cOYNm2aZZssy+jWrRsOHDhgd58DBw5g0qRJVttiYmLw448/OnwcrVYLrTZvnpjU1NR7C5zue/Z+rCllJWRJhlEYMfrnJ6CU876Q9VV0uJV7YfnoLw1WXzQNtc/U6pGWrYdWb4BB5H3xmC+u5i99pSyhehVvq8e7laZFhlZv+aJy1AfJz0OFcH/rROjSrXQYBSwJhWT54surXTEKINLfA175LjaZWj2uF3P+ozohPla/BpPStEjOLHz5EQDwUitQLdDLatuV26ZEqCjBPhoEeastfxuMAhdv2e+oXlCNIC9oVHkX9LSsHPyTWnRHdoUkoXaoj9W2+JRspBaj35e91+ZiYjoMxfitGe7nAT/PvPeYNseAK8mZRe4HALVDfKxqvZIzdJYvvsJ4KBWoXsX6tbmWnImsHEOR+wZ5qRHsm1drKoTA+cTivTZRgV7wVOe9NhlaPW4U430oA6gT5mu1LTE1G3eLMbO7j0aJyADrhPzSrXRTklqEUF8PBHjlvTY5eiPibtsfOVpQrWBvq9rVu5k6JKYV/dqoFTKig62vETfuZCJDV/RrE+CpQmiBH0vnE9JscnF7qgV4Wl0jivvaAEDdUB+rmq9baVrcKeIaIQHwUitRO8Qbi3stQptqbYr1WGXNaRKhpKQkGAwGhIWFWW0PCwvDmTNn7O4THx9vt3x8fLzDx4mNjcWsWbPuPWByGo6qe6N8a+JK6kWcuf2XnZ1M/7uZabo5JCHvZ5iZEfj7Vgn3yZWkA5Ls7WsuL2Bb+5B7/yV7OX0xW8BO3S7dvjo9cNdevMXY1+65LWa85++W7jEBB69NMfa1+9oU8lrmdzUdQME8opjxni7ta+PofViMfeOzTbeS7gcAF1NK95hA6eNNzgGSS7nv9QzTraT7AcCZ5NI9pk6U/rkmaoHEgvsWM957uUacTCrdvlo98Oc/QIrW3hujYjhNIlRRpk2bZlWLlJqaiqgo234g5DocNXuvenwL/r51uNjHuZqciVX7L0OWAA+VIrcPjqmaXpIAnd4Ird4IH40SozvWstr3v8du4NQ/qbnNZgp4qGRoVAqocvu4KBQSlLkdthtH+lv2E0Jg+b44aPVG5BiMpiap3KYIpbmpQJahVEjo2jAM9fP9ok7J0uHPy3ehlAGFQoYswVKDZamZMgJ6oxGPNQqz+rV34kYKzsanWpqlLH0LZAkyTMmlDAlVfNR4uFYVq+e6/2KSZX02I0zV+UYIU81ZviSuYYQf6uWLV6s3YMvfph8x5qYWWJpm8v4rSUD7OsHwz1fDcv1OJo5eu5t38LzWJSsapWzT1HkoLhnXkjPz1daZz1FezZ0kSYiu4o0OdYKt9t34103o9EabPiJW51gAD9eqguh8tTNJ6Vps/OsfKHITKUmScp9bbn8i5PWbeuKBSKvmjJM3U/DX9RRTnLnnNT9zLEHeavRqEmF136/nb+F2et6vePNzNDffmm9Nq/qjeVSgpZzBKLDm4BVTs2Zu85NCyuvDlf9cd6wdbFWbdDU5E3vP38pt8rSOVZZy3/8yoFTI6N+8qtX9x6/dxZXkDBhEbpOc0XQ+Tf83wpAbd40gb3RtaN2PdONfN5GhzWvyNDfz5e9nZDQKPBAVgOh8Nbip2Tn4+US8JV5zLayc284kSxIk2ZQDdG0YZtU/8GJiOv66kZKvf46pac5YoILUz1OJPs0i871mps9NQmpeE5ck5f7mEfl+/wigdog3mlULsDre+sPXrfrdmeX/WyEDbWsHo2q+mrO7mTocvXYXSoUMhaXGObc5WzY9nvl9/FijcEszm4DAqZupuJiUYWlClnObgyVJQmp2Dm6n65CcqUO9UF8Mebg6WoS3QGVxmkQoODgYCoUCCQkJVtsTEhIQHm6/j0Z4eHiJygOARqOBRqNxeD+5HkcLr1bxDEGn6j2KfRxdpBGtwzNQo4qXpX8KYLpg+WiUps69li+IvP0EgKca5/ULMYq8jrY6vdHm4lVQ5xrFDtFG/4YSPFQyPFQKU6fpAp2MzXHm/yI3N/Xl79RsvrCb+1eYv5TMF/n8naW71zL1dypN78THatluM/c1Uiry+onY69uS/8tZzu0rZLlIF9IJ9MWHrTuWml8nQ77nmX97/sShV13r5lFz/yF7TZ8S8uKSJWBYiwLPw85zMTeJWToKm18jy2tl3fE8f1Np/tcRuTENfiAvxuLEbH5sWZIwqFleJ1vTF2Xe+c7/EbPXdCu6551f5HsvFXyvmZ+ceduTjfP6yOSPTsr3OObzmv/cyZKE0Q/lJWqyBJtktaD8yeurj+S9xpZzZLSN2xyb/fOWP8GFJS5F/s7z+WIb19ZxbEZjXlJlNSjBYPph1Ke+qY9P/n5Djpj7KZn7B/5fGwU0qtz+Vgq5+B2m7eQ1Or0R2XoDbt7NQo4+L4jy6iNUXE6TCKnVarRs2RI7d+5Ev379AJg6S+/cuRPjx4+3u0/btm2xc+dOTJgwwbJt+/btaNu2kHcUuZ2yGtGhVsqoH55XgyFJpl/dwT4aqJWlH4Wl1RuQnWOENsf0/8wcvdVFpLik3Joqb40C3holPFXWHXRLcKRS7GMr/8gq8ygy85d0/g7H+b8wZMlUO2YeXVURo8Ly18KQ+5IkCQoJUNyH7wNzDWxxv9DNHdrzj9SsiM+TeQCGV4gCV5MzkaEtus9TRXCaRAgAJk2ahOHDh6NVq1Zo3bo1FixYgIyMDIwcORIAMGzYMFStWhWxsbEAgFdeeQWdOnXChx9+iN69e2Pt2rX4888/8fnnn1fm06D7TFl/7iXJ1NE32EddJsPQNUqFqekjX1NPjsGITK0BmTmmYfXm0SrmX3v5f9Fpcmt8vNXKShlK7ogsS1Bb4lEUWpaIyo45caosSoWMmsHeiE/NRlJa0YMuyj2eyg6gJAYOHIhbt27h7bffRnx8PJo3b44tW7ZYOkRfvXoVcr6hiu3atcOaNWvw1ltv4Y033kDdunXx448/cg4hsmJvHqF7Ee7vgWCf8m1eVSlk+HvJ8IfK5j7zMHgiovuVJEmI8PeEl0pZ5tfgEsfiTPMIVQbOI+T6UjJzcLWYQ5WLolJKqBfqy0SEiKiSFff72+mW2CAqa1IZfgpCfT2YBBEROREmQuT2HI0aKym1Ukagl21TFRER3b+YCJHbK6v26VBfzX23zhERERWOiRC5vbLIXTQq2WoafiIicg5MhMjtlUWNEGuDiIicExMhcnv32rfZQyUjwEtddEEiIrrvMBEit3evkwyG+noUXYiIiO5LTITI7d1rk5aPh1PNS0pERPkwESJC7krKpaBSSvfVshVERFQyTISIUPoO0xol18giInJmTISIUPpEyEPFjxARkTPjVZwIpR855sEaISIip8ZEiAil7zDtoWIiRETkzJgIEaH0NUIaJT9CRETOjFdxIpRuLiG1UuZK80RETo6JEBFK11maHaWJiJwfr+REKN3Cq+wfRETk/JgIEaF0NULsH0RE5Px4JSdCaZvGWCNEROTsmAgRoeRLbEgSa4SIiFwBr+REKHmNkFop3/NirUREVPmYCBGh5IkQZ5QmInINTISIUPIJFTl0nojINfBqToSSL7GhYUdpIiKXwESICCWvEWJHaSIi18CrORFKtsQGR4wREbkOXs2JULLO0h4qjhgjInIVTISIULIlNjQcMUZE5DKYCBGhZDVCGo4YIyJyGbyiE6GkTWOsESIichVMhIhQslFjnEyRiMh1MBEigmkeoeJUCkmSaXkNIiJyDbyiE+UqTvMYm8WIiFwLEyGiXMVZgZ7zBxERuRZe1YlyFadGiM1iRESuhVd1olzF6TCtLOlaHEREdF9jIkSUqzizRSsV/MgQEbkSXtWJchWraYyJEBGRS+FVnSiXolg1QmwaIyJyJU6TCCUnJ2PIkCHw8/NDQEAARo0ahfT09ELLv/TSS6hfvz48PT1RvXp1vPzyy0hJSanAqMmZFJUHSRKgYo0QEZFLcZqr+pAhQ3Dy5Els374dGzduxK+//oqxY8c6LH/z5k3cvHkTH3zwAf7++2+sWrUKW7ZswahRoyowanImchEdoVkbRETkeiQhhKjsIIpy+vRpNGrUCH/88QdatWoFANiyZQt69eqF69evIzIysljH+e677/Dss88iIyMDSqWyWPukpqbC398fKSkp8PPzK/VzoPvfPylZSErTObzfU61AnVCfCoyIiIhKq7jf305RI3TgwAEEBARYkiAA6NatG2RZxsGDB4t9HPPJKCwJ0mq1SE1NtbqReyiqs7SKNUJERC7HKRKh+Ph4hIaGWm1TKpUICgpCfHx8sY6RlJSEd955p9DmNACIjY2Fv7+/5RYVFVXquMm5FDVHEPsHERG5nkq9sk+dOjV3sUvHtzNnztzz46SmpqJ3795o1KgRZs6cWWjZadOmISUlxXK7du3aPT8+OYeiZo1mHyEiItdTvI4y5eTVV1/FiBEjCi1Tq1YthIeHIzEx0Wq7Xq9HcnIywsPDC90/LS0NPXr0gK+vLzZs2ACVSlVoeY1GA41GU6z4ybUUVeOjKs5iZERE5FQqNREKCQlBSEhIkeXatm2Lu3fv4vDhw2jZsiUAYNeuXTAajWjTpo3D/VJTUxETEwONRoOffvoJHh4eZRY7uZ6iFlRVcZ0xIiKX4xRX9oYNG6JHjx4YM2YMDh06hN9++w3jx4/HM888YxkxduPGDTRo0ACHDh0CYEqCHnvsMWRkZGD58uVITU1FfHw84uPjYTAYKvPp0H1KkiSolI6bv7jOGBGR66nUGqGS+OabbzB+/Hh07doVsizjySefxMcff2y5PycnB2fPnkVmZiYA4MiRI5YRZXXq1LE6VlxcHKKjoyssdnIeaoWMHL39RJmdpYmIXI9TzCNUmTiPkHu5ficTdzJybLbLMtA40r8SIiIiotJwqXmEiCqKo5FjrA0iInJNvLoT5eNodXn2DyIick1MhIjyYY0QEZF74dWdKB9HNUJMhIiIXBOv7kT5KBUy7M2byFmliYhcExMhogLsTazIGiEiItfEqztRAWqFwmYbV54nInJNTISICrDXYVrJdcaIiFwSr+5EBdir/WGNEBGRa2IiRFRAwRohpUKCJDERIiJyRUyEiAoomAixNoiIyHUxESIqQK2Qkb8CiCPGiIhcF6/wRAVIkmSV/CiZCBERuSxe4YnsyN88puI6Y0RELouJEJEdVokQa4SIiFwWr/BEduTvIM3lNYiIXBcTISI7NPlml2aNEBGR6+IVnsgONo0REbkHXuGJ7DAnQpIEKNhZmojIZSkrOwCi+5FCliw3IiJyXUyEiBxQK2UwDyIicm1MhIgc0NhZhZ6IiFwLEyEiB1QKGQKissMgIqJyxESIyAG1UoZRMBEiInJlTISIHFArZRgMTISIiFwZEyEiB9QKGTkwVnYYRERUjpgIETmgUkiQJHaYJiJyZUyEiByQJMlqzTEiInI9/LlLREREbouJEBEREbktJkJERETktpgIERERkdtiIkRERERui4kQERERuS0mQkREROS2mAgRERGR22IiRERERG6LiRARERG5LadJhJKTkzFkyBD4+fkhICAAo0aNQnp6erH2FUKgZ8+ekCQJP/74Y/kGSkRERE7DaRKhIUOG4OTJk9i+fTs2btyIX3/9FWPHji3WvgsWLIAkcc0oIiIisuYUi66ePn0aW7ZswR9//IFWrVoBABYtWoRevXrhgw8+QGRkpMN9jx07hg8//BB//vknIiIiKipkIiIicgJOUSN04MABBAQEWJIgAOjWrRtkWcbBgwcd7peZmYnBgwdjyZIlCA8Pr4hQiYiIyIk4RY1QfHw8QkNDrbYplUoEBQUhPj7e4X4TJ05Eu3bt0Ldv32I/llarhVartfydmppa8oCJiIjIKVRqIjR16lS8//77hZY5ffp0qY79008/YdeuXTh69GiJ9ouNjcWsWbNstjMhIiIich7m720hRKHlJFFUiXJ069Yt3L59u9AytWrVwtdff41XX30Vd+7csWzX6/Xw8PDAd999h/79+9vsN2HCBHz88ceQ5bzWP4PBAFmW0bFjR+zZs8fu4xWsEbpx4wYaNWpUwmdGRERE94Nr166hWrVqDu+v1ESouE6fPo1GjRrhzz//RMuWLQEA27ZtQ48ePXD9+nW7naXj4+ORlJRkta1p06ZYuHAh+vTpg5o1axbrsY1GI27evAlfX98yHXmWmpqKqKgoXLt2DX5+fmV2XLLFc10xeJ4rBs9zxeB5rhjleZ6FEEhLS0NkZKRVpUhBTtFHqGHDhujRowfGjBmDpUuXIicnB+PHj8czzzxjSYJu3LiBrl274ssvv0Tr1q0RHh5ut4N09erVi50EAYAsy4VmkvfKz8+PH7IKwnNdMXieKwbPc8Xgea4Y5XWe/f39iyzjFKPGAOCbb75BgwYN0LVrV/Tq1QsdOnTA559/brk/JycHZ8+eRWZmZiVGSURERM7EKWqEACAoKAhr1qxxeH90dHSRHaKcoBWQiIiIKpDT1Ai5Go1GgxkzZkCj0VR2KC6P57pi8DxXDJ7nisHzXDHuh/PsFJ2liYiIiMoDa4SIiIjIbTERIiIiIrfFRIiIiIjcFhMhIiIicltMhMrRkiVLEB0dDQ8PD7Rp0waHDh0qtPx3332HBg0awMPDA02bNsXmzZsrKFLnVpLzvGzZMnTs2BGBgYEIDAxEt27dinxdKE9J39Nma9euhSRJ6NevX/kG6CJKep7v3r2LcePGISIiAhqNBvXq1eP1oxhKep4XLFiA+vXrw9PTE1FRUZg4cSKys7MrKFrn9Ouvv6JPnz6IjIyEJEn48ccfi9xnz549ePDBB6HRaFCnTh2sWrWqfIMUVC7Wrl0r1Gq1WLFihTh58qQYM2aMCAgIEAkJCXbL//bbb0KhUIh58+aJU6dOibfeekuoVCpx4sSJCo7cuZT0PA8ePFgsWbJEHD16VJw+fVqMGDFC+Pv7i+vXr1dw5M6npOfaLC4uTlStWlV07NhR9O3bt2KCdWIlPc9arVa0atVK9OrVS+zbt0/ExcWJPXv2iGPHjlVw5M6lpOf5m2++ERqNRnzzzTciLi5ObN26VURERIiJEydWcOTOZfPmzeLNN98UP/zwgwAgNmzYUGj5S5cuCS8vLzFp0iRx6tQpsWjRIqFQKMSWLVvKLUYmQuWkdevWYty4cZa/DQaDiIyMFLGxsXbLDxgwQPTu3dtqW5s2bcT//d//lWuczq6k57kgvV4vfH19xerVq8srRJdRmnOt1+tFu3btxBdffCGGDx/ORKgYSnqeP/30U1GrVi2h0+kqKkSXUNLzPG7cOPHoo49abZs0aZJo3759ucbpSoqTCL322muicePGVtsGDhwoYmJiyi0uNo2VA51Oh8OHD6Nbt26WbbIso1u3bjhw4IDdfQ4cOGBVHgBiYmIclqfSneeCMjMzkZOTg6CgoPIK0yWU9lzPnj0boaGhGDVqVEWE6fRKc55/+ukntG3bFuPGjUNYWBiaNGmCOXPmwGAwVFTYTqc057ldu3Y4fPiwpfns0qVL2Lx5M3r16lUhMbuLyvgudJolNpxJUlISDAYDwsLCrLaHhYXhzJkzdveJj4+3Wz4+Pr7c4nR2pTnPBb3++uuIjIy0+eCRtdKc63379mH58uU4duxYBUToGkpzni9duoRdu3ZhyJAh2Lx5My5cuIAXX3wROTk5mDFjRkWE7XRKc54HDx6MpKQkdOjQAUII6PV6PP/883jjjTcqImS34ei7MDU1FVlZWfD09Czzx2SNELmtuXPnYu3atdiwYQM8PDwqOxyXkpaWhqFDh2LZsmUIDg6u7HBcmtFoRGhoKD7//HO0bNkSAwcOxJtvvomlS5dWdmguZc+ePZgzZw4++eQTHDlyBD/88AM2bdqEd955p7JDo3vEGqFyEBwcDIVCgYSEBKvtCQkJCA8Pt7tPeHh4icpT6c6z2QcffIC5c+dix44daNasWXmG6RJKeq4vXryIy5cvo0+fPpZtRqMRAKBUKnH27FnUrl27fIN2QqV5T0dEREClUkGhUFi2NWzYEPHx8dDpdFCr1eUaszMqzXmePn06hg4ditGjRwMAmjZtioyMDIwdOxZvvvkmZJn1CmXB0Xehn59fudQGAawRKhdqtRotW7bEzp07LduMRiN27tyJtm3b2t2nbdu2VuUBYPv27Q7LU+nOMwDMmzcP77zzDrZs2YJWrVpVRKhOr6TnukGDBjhx4gSOHTtmuT3xxBPo0qULjh07hqioqIoM32mU5j3dvn17XLhwwZJoAsC5c+cQERHBJMiB0pznzMxMm2THnHwKLtlZZirlu7DcumG7ubVr1wqNRiNWrVolTp06JcaOHSsCAgJEfHy8EEKIoUOHiqlTp1rK//bbb0KpVIoPPvhAnD59WsyYMYPD54uhpOd57ty5Qq1Wi/Xr14t//vnHcktLS6usp+A0SnquC+KoseIp6Xm+evWq8PX1FePHjxdnz54VGzduFKGhoeLdd9+trKfgFEp6nmfMmCF8fX3Ff/7zH3Hp0iWxbds2Ubt2bTFgwIDKegpOIS0tTRw9elQcPXpUABDz588XR48eFVeuXBFCCDF16lQxdOhQS3nz8PkpU6aI06dPiyVLlnD4vDNbtGiRqF69ulCr1aJ169bi999/t9zXqVMnMXz4cKvy3377rahXr55Qq9WicePGYtOmTRUcsXMqyXmuUaOGAGBzmzFjRsUH7oRK+p7Oj4lQ8ZX0PO/fv1+0adNGaDQaUatWLfHee+8JvV5fwVE7n5Kc55ycHDFz5kxRu3Zt4eHhIaKiosSLL74o7ty5U/GBO5Hdu3fbveaaz+3w4cNFp06dbPZp3ry5UKvVolatWmLlypXlGqMkBOv0iIiIyD2xjxARERG5LSZCRERE5LaYCBEREZHbYiJEREREbouJEBEREbktJkJERETktpgIERERkdtiIkRERERui4kQERERuS0mQkREROS2mAgRkVu5desWwsPDMWfOHMu2/fv3Q61W26x6TUSuj2uNEZHb2bx5M/r164f9+/ejfv36aN68Ofr27Yv58+dXdmhEVMGYCBGRWxo3bhx27NiBVq1a4cSJE/jjjz+g0WgqOywiqmBMhIjILWVlZaFJkya4du0aDh8+jKZNm1Z2SERUCdhHiIjc0sWLF3Hz5k0YjUZcvny5ssMhokrCGiEicjs6nQ6tW7dG8+bNUb9+fSxYsAAnTpxAaGhoZYdGRBWMiRARuZ0pU6Zg/fr1OH78OHx8fNCpUyf4+/tj48aNlR0aEVUwNo0RkVvZs2cPFixYgK+++gp+fn6QZRlfffUV9u7di08//bSywyOiCsYaISIiInJbrBEiIiIit8VEiIiIiNwWEyEiIiJyW0yEiIiIyG0xESIiIiK3xUSIiIiI3BYTISIiInJbTISIiIjIbTERIiIiIrfFRIiIiIjcFhMhIiIicltMhIiIiMht/T82FKZimD7xaQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_train[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_train[parameter_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 316,
   "id": "fbeef4c3-208f-490b-9f76-24ba47485adc",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6p0lEQVR4nO3deZzN1f8H8Nfn7rMvZmcYS/Y1+xZlmSKhTSJDaEEL3xSJEUJSP5KIslRElFKkJEJE2ZIty9jNMMy+3e38/rhz79w7c+9sZrv3vp6Px30wn/v5fO77fubOve97zvucIwkhBIiIiIjckKyyAyAiIiKqLEyEiIiIyG0xESIiIiK3xUSIiIiI3BYTISIiInJbTISIiIjIbTERIiIiIrfFRIiIiIjcFhMhIiIicltMhMhlREVFYfjw4ZUdRoV47733UKdOHcjlcrRs2bKyw3FbZ8+eRe/eveHn5wdJkvDdd99VdkhEVEJMhMjGqlWrIEkS/v7778oOxamkp6cjNjYWTZs2hZeXF6pVq4aWLVvilVdewfXr1y37bd26FdOnT7+rx/rll1/w+uuvo3Pnzli5ciVmz559l9Hbt2vXLkiSZLkplUrUqVMHw4YNw4ULFyz7Xbx40bLPrFmz7J5ryJAhkCQJ3t7eNtu7d+9u8xjWt4YNG5Yo3vXr12Po0KG45557IEkSunfvbnc/82vcfNNoNIiIiEB0dDQ+/PBDpKWlFfsxY2JicPz4cbzzzjv44osv0KZNmxLFTMWXmZmJ6dOnY9euXZUdyl3ZvHkz7r33Xmg0GtSsWROxsbHQ6/XFPv78+fN4+umnERISAg8PD9xzzz2YMmWK5X6j0YhVq1bhkUceQWRkJLy8vNC0aVPMmjUL2dnZ5fGUnJ6isgMgKitnzpyBTFbxub1Op8N9992H06dPIyYmBi+99BLS09Nx4sQJrF27FgMHDkRERAQAUyK0ePHiu0qGfvvtN8hkMnz22WdQqVRl9Cwce/nll9G2bVvodDocPnwYy5Ytw5YtW3D8+HHL8wIAjUaDr776Cm+99ZbN8RkZGfj++++h0Wjsnr9GjRqYM2dOge1+fn4linPJkiU4dOgQ2rZti9u3bxe5/4wZM1C7dm3odDrEx8dj165dePXVV/HBBx9g8+bNaN68eaHHZ2VlYf/+/ZgyZQrGjRtXolip5DIzM/H2228DgMMkt6r76aefMGDAAHTv3h2LFi3C8ePHMWvWLNy8eRNLliwp8vijR4+ie/fuqF69Ov73v/+hWrVquHz5Mq5cuWLZJzMzEyNGjECHDh3wwgsvICQkBPv370dsbCx27NiB3377DZIklefTdD6CyMrKlSsFAPHXX39Vahw6nU7k5ORUagzF9fXXXwsAYs2aNQXuy8rKEikpKZafx44dK+72z27EiBHCy8vrrs5RHDt37hQAxIYNG2y2f/jhhwKAmD17thBCiLi4OAFAPProowKAOHr0qM3+a9asEUqlUvTr169A3N26dRNNmjQpk3gvX74sDAaDEEKIJk2aiG7dutndr7DX+I4dO4SHh4eoVauWyMzMLPTxLl26JACI9957765jN0tPTy+zczlzDPbcunVLABCxsbFlet6KfL6NGzcWLVq0EDqdzrJtypQpQpIkcerUqUKPNRgMomnTpqJ9+/aFvjZzcnLEH3/8UWD722+/LQCI7du3l/4JuCh2jVGpXLt2Dc8++yxCQ0OhVqvRpEkTrFixwmYfrVaLadOmoXXr1vDz84OXlxe6du2KnTt32uxn7lqZP38+FixYgLp160KtVuPkyZOYPn06JEnCuXPnMHz4cPj7+8PPzw8jRoxAZmamzXny1wiZu0D++OMPTJgwAcHBwfDy8sLAgQNx69Ytm2ONRiOmT5+OiIgIeHp64v7778fJkyeLVXd0/vx5AEDnzp0L3KfRaODr6wsAGD58OBYvXgwANl0z1jEsWLAATZo0gUajQWhoKJ5//nkkJSVZ9pEkCStXrkRGRobl+FWrVgEAVq5ciQceeAAhISFQq9Vo3Lix3W+ZUVFRePjhh7F37160a9cOGo0GderUweeff17o8zR74IEHAABxcXE22zt27IjatWtj7dq1NtvXrFmDBx98EIGBgcU6f2lFRkbedYvgAw88gKlTp+LSpUv48ssvHe43ffp01KpVCwAwceJESJKEqKgoy/1HjhzBQw89BF9fX3h7e6NHjx74888/bc5hfn3+/vvvGDNmDEJCQlCjRg2Hj2nuqly/fj3efPNNhIWFwcvLC4888ohNiwAA7NmzB0888QRq1qwJtVqNyMhIjB8/HllZWTb7DR8+HN7e3jh//jz69OkDHx8fDBkypFTnuHz5Mh5++GF4e3ujevXqltf68ePH8cADD8DLywu1atUq8PoAgOTkZLz66quIjIyEWq1GvXr18O6778JoNAIwvUcEBwcDAN5++23La9+6ZfX06dN4/PHHERgYCI1GgzZt2mDz5s13dc3L0smTJ3Hy5Ek899xzUCjyOmPGjBkDIQQ2btxY6PG//PIL/v33X8TGxsLDwwOZmZkwGAwF9lOpVOjUqVOB7QMHDgQAnDp16i6fieth1xiVWEJCAjp06ABJkjBu3DgEBwfjp59+wsiRI5GamopXX30VAJCamopPP/0UgwcPxujRo5GWlobPPvsM0dHROHjwYIEi35UrVyI7OxvPPfcc1Gq1zQfnk08+idq1a2POnDk4fPgwPv30U4SEhODdd98tMt6XXnoJAQEBiI2NxcWLF7FgwQKMGzcO69evt+wzefJkzJs3D/369UN0dDSOHTuG6OjoYvWpmz8QP//8c7z11lsOm52ff/55XL9+Hdu3b8cXX3xh9/5Vq1ZhxIgRePnllxEXF4ePPvoIR44cwR9//AGlUokvvvgCy5Ytw8GDB/Hpp58CgOVNb8mSJWjSpAkeeeQRKBQK/PDDDxgzZgyMRiPGjh1r81jnzp3D448/jpEjRyImJgYrVqzA8OHD0bp1azRp0qTQ52tO/KpVq1bgvsGDB+PLL7/E3LlzIUkSEhMT8csvv+CLL77Atm3b7J7PYDAgMTGxwHYPDw94eXkVGkt5eOaZZ/Dmm2/il19+wejRo+3u8+ijj8Lf3x/jx4/H4MGD0adPH0v904kTJ9C1a1f4+vri9ddfh1KpxCeffILu3bvj999/R/v27W3ONWbMGAQHB2PatGnIyMgoMr533nkHkiThjTfewM2bN7FgwQL07NkTR48ehYeHBwBgw4YNyMzMxIsvvohq1arh4MGDWLRoEa5evYoNGzbYnE+v1yM6OhpdunTB/Pnz4enpWeJzGAwGPPTQQ7jvvvswb948rFmzBuPGjYOXlxemTJmCIUOG4NFHH8XSpUsxbNgwS9IMmLpyunXrhmvXruH5559HzZo1sW/fPkyePBk3btzAggULEBwcjCVLluDFF1/EwIED8eijjwKApfvyxIkT6Ny5M6pXr45JkybBy8sLX3/9NQYMGIBvvvnGkgSU5prbe23a4+PjA7Va7fD+I0eOAECBOrKIiAjUqFHDcr8jv/76KwBArVajTZs2OHToEFQqFQYOHIiPP/64yC8a8fHxAICgoKAin4vbqewmKapaitM1NnLkSBEeHi4SExNttj/11FPCz8/P0myr1+sLdG8lJSWJ0NBQ8eyzz1q2mbtWfH19xc2bN232j42NFQBs9hdCiIEDB4pq1arZbKtVq5aIiYkp8Fx69uwpjEajZfv48eOFXC4XycnJQggh4uPjhUKhEAMGDLA53/Tp0wUAm3Pak5mZKRo0aCAAiFq1aonhw4eLzz77TCQkJBTY11HX2J49e+x2r23btq3A9piYGLtdY/aay6Ojo0WdOnVsttWqVUsAELt377Zsu3nzplCr1eJ///ufZZu5a2zFihXi1q1b4vr162LLli0iKipKSJJkeY2Yf3/vvfee+PfffwUAsWfPHiGEEIsXLxbe3t4iIyPDbtzdunUTAOzenn/++QLPp7hK2zVm5ufnJ1q1alXoY1g/b2sDBgwQKpVKnD9/3rLt+vXrwsfHR9x3330F4ujSpYvQ6/VFPifz76N69eoiNTXVst3cNbtw4ULLNnuvhTlz5ghJksSlS5cs22JiYgQAMWnSpAL7l/Qc5q5SIUx/5x4eHkKSJLFu3TrL9tOnTxfo3po5c6bw8vIS//33n81jTZo0ScjlcnH58mUhROFdYz169BDNmjUT2dnZlm1Go1F06tRJ3HPPPZZtJb3mQgiHr8/8t5UrVxZ6nvfee08AsDwfa23bthUdOnQo9PhHHnlEABDVqlUTQ4YMERs3bhRTp04VCoVCdOrUyeY9zp6ePXsKX19fkZSUVNRTdjvsGqMSEULgm2++Qb9+/SCEQGJiouUWHR2NlJQUHD58GAAgl8stxbxGoxF37tyBXq9HmzZtLPtYe+yxxyzN3/m98MILNj937doVt2/fRmpqapExP/fcczatNF27doXBYMClS5cAADt27IBer8eYMWNsjnvppZeKPDdgark4cOAAJk6cCMDU/D5y5EiEh4fjpZdeQk5OTpHn2LBhA/z8/NCrVy+ba9q6dWt4e3sX6E50FIdZSkoKEhMT0a1bN1y4cAEpKSk2+zZu3Bhdu3a1/BwcHIwGDRrYjAYze/bZZxEcHIyIiAj07dsXGRkZWL16td0RUk2aNEHz5s3x1VdfAQDWrl2L/v37W1oZ7ImKisL27dsL3Mwti5XB29u7RKPHzAwGA3755RcMGDAAderUsWwPDw/H008/jb179xZ4zY4ePRpyubzYjzFs2DD4+PhYfn788ccRHh6OrVu3WrZZvxYyMjKQmJiITp06QQhht+XhxRdfLLCtpOcYNWqU5f/+/v5o0KABvLy88OSTT1q2N2jQAP7+/javsw0bNqBr164ICAiwee337NkTBoMBu3fvLvR63LlzB7/99huefPJJpKWlWY6/ffs2oqOjcfbsWVy7ds3mmJJcc3uvTXu36OjoQs9j7lK012qk0WgKdDnml56eDgBo27YtvvzySzz22GOYMWMGZs6ciX379mHHjh0Oj509ezZ+/fVXzJ07F/7+/kU8Y/fDrjEqkVu3biE5ORnLli3DsmXL7O5z8+ZNy/9Xr16N999/H6dPn4ZOp7NsNzeLW7O3zaxmzZo2PwcEBAAAkpKSLDU4pTkWgCUhqlevns1+gYGBln2L4ufnh3nz5mHevHm4dOkSduzYgfnz5+Ojjz6Cn5+fw2HlZmfPnkVKSgpCQkLs3m99TR35448/EBsbi/379xeon0pJSbEZhZX/mgCm62Jdj2Q2bdo0dO3aFXK5HEFBQWjUqJFNjUN+Tz/9NN5//32MHz8e+/btw5tvvllo3F5eXujZs2dRT69CpaenO/xdFObWrVvIzMxEgwYNCtzXqFEjGI1GXLlyxab7sbDXvT333HOPzc+SJKFevXq4ePGiZdvly5cxbdo0bN68ucDvNH9SrFAo7NbJlOQcGo2mwJcYPz8/1KhRo0BXsZ+fn835zp49i3/++cfhl6CiXvvnzp2DEAJTp07F1KlTHZ6jevXqlp9Lcs3L6rVpTiztfTHKzs62STwLO37w4ME2259++mlMnjwZ+/btsxvr+vXr8dZbb2HkyJF2E15iIkQlZC5eHDp0KGJiYuzuY+63//LLLzF8+HAMGDAAEydOREhICORyOebMmWOpM7FW2BuBo29vQogiY76bY0ujVq1aePbZZzFw4EDUqVMHa9asKTIRMhqNCAkJwZo1a+ze7+hDwuz8+fPo0aMHGjZsiA8++ACRkZFQqVTYunUr/u///s/yezMryTVp1qxZiT4MBg8ejMmTJ2P06NGoVq0aevfuXexjq4KrV68iJSWlQGJcXor6ACwpg8GAXr164c6dO3jjjTfQsGFDeHl54dq1axg+fHiB14JarS5QZF7Sczh6PRXndWY0GtGrVy+8/vrrdvetX79+oc/XHMtrr73msFUm/++yJNfcXFtTFD8/v0LPGx4eDgC4ceMGIiMjbe67ceMG2rVrV+j5zVNVhIaG2mw3J+z2vsRs374dw4YNQ9++fbF06dKin4SbYiJEJRIcHAwfHx8YDIYiPxw3btyIOnXq4Ntvv7X5VhgbG1veYZaIudj53LlzNt8Ub9++bffNpbgCAgJQt25d/Pvvv5Ztjgqp69ati19//RWdO3cu1QfjDz/8gJycHGzevNmmtac4XWplrWbNmujcuTN27dqFF198sdDWo6rIXMheVFeHPcHBwfD09MSZM2cK3Hf69GnIZLICH4IldfbsWZufhRA4d+6c5QvI8ePH8d9//2H16tUYNmyYZb/t27cX+zHK4hzFVbduXaSnpxf5fuLob8fcBalUKsulZdGcwBRl5cqVhY4wNQ8O+fvvv22SnuvXr+Pq1at47rnnCj1/69atsXz58gLdfOYJW/N/WTpw4AAGDhyINm3a4Ouvv3a6v8OKxBohKhG5XI7HHnsM33zzjc0HvJn1sHTzt0Hrb38HDhzA/v37yz/QEujRowcUCkWBoeYfffRRsY4/duyY3ZElly5dwsmTJ226ScyjoJKTk232ffLJJ2EwGDBz5swC59Hr9QX2z8/etU5JScHKlSuL9RzK2qxZsxAbG1vsOquq4rfffsPMmTNRu3ZtyzDykpDL5ejduze+//57m66qhIQErF27Fl26dCmyK7con3/+uU390saNG3Hjxg089NBDlhgA29eCEAILFy4s0fO423MU15NPPon9+/fj559/LnBfcnKyZdZlc51Z/r+FkJAQdO/eHZ988glu3LhR4Bz5p8ooqbKqEWrSpAkaNmyIZcuW2Qx7X7JkCSRJwuOPP27ZlpKSgtOnT9t0Qfbv3x9qtRorV660aZEzjx7t1auXZdupU6fQt29fREVF4ccffyzzVkdXwxSR7FqxYoXd4c6vvPIK5s6di507d6J9+/YYPXo0GjdujDt37uDw4cP49ddfcefOHQDAww8/jG+//RYDBw5E3759ERcXh6VLl6Jx48aWwr+qIDQ0FK+88gref/99PPLII3jwwQdx7Ngx/PTTTwgKCipyFtbt27cjNjYWjzzyCDp06ABvb29cuHABK1asQE5Ojs1cJ61btwZgmq05OjoacrkcTz31FLp164bnn38ec+bMwdGjR9G7d28olUqcPXsWGzZswMKFC23eKPPr3bs3VCoV+vXrh+effx7p6elY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/DiOHj1quT3yyCO4//77cfToUURGRlZk+E6jNK/pzp0749y5c5ZEEwD+++8/hIeHMwlyoDTXOTMzs0CyY04+BZfsLDOV8llYbmXYbm7dunVCrVaLVatWiZMnT4rnnntO+Pv7i/j4eCGEEM8884yYNGmSZf8//vhDKBQKMX/+fHHq1CkRGxvL4fPFUNLrPHfuXKFSqcTGjRvFjRs3LLe0tLTKegpOo6TXOj+OGiuekl7ny5cvCx8fHzFu3Dhx5swZ8eOPP4qQkBAxa9asynoKTqGk1zk2Nlb4+PiIr776Sly4cEH88ssvom7duuLJJ5+srKfgFNLS0sSRI0fEkSNHBADxwQcfiCNHjohLly4JIYSYNGmSeOaZZyz7m4fPT5w4UZw6dUosXryYw+ed2aJFi0TNmjWFSqUS7dq1E3/++aflvm7duomYmBib/b/++mtRv359oVKpRJMmTcSWLVsqOGLnVJLrXKtWLQGgwC02NrbiA3dCJX1NW2MiVHwlvc779u0T7du3F2q1WtSpU0e88847Qq/XV3DUzqck11mn04np06eLunXrCo1GIyIjI8WYMWNEUlJSxQfuRHbu3Gn3Pdd8bWNiYkS3bt0KHNOyZUuhUqlEnTp1xMqVK8s1RkkItukRERGRe2KNEBEREbktJkJERETktpgIERERkdtiIkRERERui4kQERERuS0mQkREROS2mAgRERGR22IiRERERG6LiRARERG5LSZCRERE5LaYCBGRW7l16xbCwsIwe/Zsy7Z9+/ZBpVIVWPWaiFwf1xojIrezdetWDBgwAPv27UODBg3QsmVL9O/fHx988EFlh0ZEFYyJEBG5pbFjx+LXX39FmzZtcPz4cfz1119Qq9WVHRYRVTAmQkTklrKystC0aVNcuXIFhw4dQrNmzSo7JCKqBKwRIiK3dP78eVy/fh1GoxEXL16s7HCIqJKwRYiI3I5Wq0W7du3QsmVLNGjQAAsWLMDx48cREhJS2aERUQVjIkREbmfixInYuHEjjh07Bm9vb3Tr1g1+fn748ccfKzs0Iqpg7BojIreya9cuLFiwAF988QV8fX0hk8nwxRdfYM+ePViyZEllh0dEFYwtQkREROS22CJEREREbouJEBEREbktJkJERETktpgIERERkdtiIkRERERui4kQERERuS0mQkREROS2mAgRERGR22IiRERERG6LiRARERG5LSZCRERE5LaYCBEREZHb+n840Og8TeHjXQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_train[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")        \n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 317,
   "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": 318,
   "id": "bbc1aeab-f5a3-45e5-8f17-c47458e866f2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.0022263741120696068,\n",
       "  0.0031321141868829727,\n",
       "  0.006980760954320431,\n",
       "  0.00701024429872632,\n",
       "  0.004128856118768454,\n",
       "  0.0019955842290073633,\n",
       "  0.0022249286994338036,\n",
       "  0.004744536709040403,\n",
       "  0.002445796737447381,\n",
       "  0.0019953360315412283,\n",
       "  0.003527431981638074,\n",
       "  0.002956877928227186,\n",
       "  0.008906910195946693,\n",
       "  0.006303565576672554,\n",
       "  0.0042670187540352345,\n",
       "  0.0022146650590002537,\n",
       "  0.002305206609889865,\n",
       "  0.003335517831146717,\n",
       "  0.006455746479332447,\n",
       "  0.004622090142220259,\n",
       "  0.002167843282222748,\n",
       "  0.005190900526940823,\n",
       "  0.0029553119093179703,\n",
       "  0.004582589492201805,\n",
       "  0.002883901121094823,\n",
       "  0.0020189411006867886,\n",
       "  0.005788077134639025,\n",
       "  0.008284150622785091,\n",
       "  0.005996551364660263,\n",
       "  0.0032918984070420265,\n",
       "  0.004127808380872011,\n",
       "  0.00564827723428607,\n",
       "  0.00617081206291914,\n",
       "  0.004615959711372852,\n",
       "  0.006449174601584673,\n",
       "  0.008280749432742596,\n",
       "  0.004981655161827803,\n",
       "  0.005648133344948292,\n",
       "  0.0027930354699492455,\n",
       "  0.003028087317943573,\n",
       "  0.0021583326160907745,\n",
       "  0.004829916171729565,\n",
       "  0.0019629481248557568,\n",
       "  0.008281844668090343,\n",
       "  0.007014803122729063,\n",
       "  0.00482918880879879,\n",
       "  0.0034606417175382376,\n",
       "  0.003335089422762394,\n",
       "  0.004620107356458902,\n",
       "  0.0022379152942448854,\n",
       "  0.0034609145950526,\n",
       "  0.006531164050102234,\n",
       "  0.0023052857723087072,\n",
       "  0.0020086115691810846,\n",
       "  0.0035955721978098154,\n",
       "  0.004980345256626606,\n",
       "  0.001953274244442582,\n",
       "  0.0069968742318451405,\n",
       "  0.006450933869928122,\n",
       "  0.004828920587897301,\n",
       "  0.002944197505712509,\n",
       "  0.002305556321516633,\n",
       "  0.0049794260412454605,\n",
       "  0.0020310513209551573,\n",
       "  0.0032268601935356855,\n",
       "  0.0026654168032109737,\n",
       "  0.0021567437797784805,\n",
       "  0.0019904726650565863,\n",
       "  0.0034603106323629618,\n",
       "  0.006336815655231476,\n",
       "  0.006998459808528423,\n",
       "  0.004002582747489214,\n",
       "  0.0023050878662616014,\n",
       "  0.0051908427849411964,\n",
       "  0.005648478399962187,\n",
       "  0.0056488774716854095,\n",
       "  0.001954215345904231,\n",
       "  0.007806530687958002,\n",
       "  0.0020460516680032015,\n",
       "  0.005997736472636461,\n",
       "  0.008282509632408619,\n",
       "  0.005649081896990538,\n",
       "  0.004582961555570364,\n",
       "  0.009067557752132416,\n",
       "  0.001953335478901863,\n",
       "  0.0028826924972236156,\n",
       "  0.0028833404649049044,\n",
       "  0.0046165925450623035,\n",
       "  0.002304656896740198,\n",
       "  0.004979439079761505,\n",
       "  0.0023037497885525227,\n",
       "  0.003028770675882697,\n",
       "  0.004304446280002594,\n",
       "  0.0023041176609694958,\n",
       "  0.008892924524843693,\n",
       "  0.006170652806758881,\n",
       "  0.003028561593964696,\n",
       "  0.001954982988536358,\n",
       "  0.0069952551275491714,\n",
       "  0.004983707796782255,\n",
       "  0.006148495711386204,\n",
       "  0.003725792281329632,\n",
       "  0.004621951840817928,\n",
       "  0.0032921796664595604,\n",
       "  0.00890803337097168,\n",
       "  0.002225144300609827,\n",
       "  0.007004419807344675,\n",
       "  0.006998212542384863,\n",
       "  0.0022356300614774227,\n",
       "  0.0019852202385663986,\n",
       "  0.004267638549208641,\n",
       "  0.003335309447720647,\n",
       "  0.0054587507620453835,\n",
       "  0.005788139533251524,\n",
       "  0.0038635656237602234,\n",
       "  0.007154760882258415,\n",
       "  0.0030773719772696495,\n",
       "  0.002157508162781596,\n",
       "  0.0019848616793751717,\n",
       "  0.001993428450077772,\n",
       "  0.0023050580639392138,\n",
       "  0.0020770712289959192,\n",
       "  0.004836255218833685,\n",
       "  0.003027719911187887,\n",
       "  0.00890531949698925,\n",
       "  0.004979334305971861,\n",
       "  0.003077120054513216,\n",
       "  0.004836464766412973,\n",
       "  0.0038506989367306232,\n",
       "  0.0069819120690226555,\n",
       "  0.0029541412368416786,\n",
       "  0.0019891769625246525,\n",
       "  0.006169802974909544,\n",
       "  0.0022360840812325478,\n",
       "  0.004304445348680019,\n",
       "  0.0026327967643737793,\n",
       "  0.0022136028856039047,\n",
       "  0.002446128986775875,\n",
       "  0.0019544658716768026,\n",
       "  0.0034607970155775547,\n",
       "  0.006148724351078272,\n",
       "  0.0034607721026986837,\n",
       "  0.00614880071952939,\n",
       "  0.002233572071418166,\n",
       "  0.008113098330795765,\n",
       "  0.004612583201378584,\n",
       "  0.003863430814817548,\n",
       "  0.002226492390036583,\n",
       "  0.004833918064832687,\n",
       "  0.006999919191002846,\n",
       "  0.008281020447611809,\n",
       "  0.0071545131504535675,\n",
       "  0.002955813892185688,\n",
       "  0.003226842498406768,\n",
       "  0.0031322503928095102,\n",
       "  0.00890321098268032,\n",
       "  0.0034604177344590425,\n",
       "  0.00699443556368351,\n",
       "  0.0029543619602918625,\n",
       "  0.0042685759253799915],\n",
       " 'mse': 0.004342679679393768,\n",
       " 'nll_by_example': [-9048.599609375,\n",
       "  -8786.0546875,\n",
       "  -8230.1767578125,\n",
       "  -8362.84375,\n",
       "  -8848.1171875,\n",
       "  -9008.984375,\n",
       "  -9046.783203125,\n",
       "  -8330.6875,\n",
       "  -9029.822265625,\n",
       "  -9010.5322265625,\n",
       "  -8915.2392578125,\n",
       "  -8984.2705078125,\n",
       "  -7703.83837890625,\n",
       "  -8502.53125,\n",
       "  -8823.236328125,\n",
       "  -9052.93359375,\n",
       "  -8931.2119140625,\n",
       "  -8710.705078125,\n",
       "  -8473.3720703125,\n",
       "  -8798.1826171875,\n",
       "  -8955.373046875,\n",
       "  -8220.5078125,\n",
       "  -8979.53125,\n",
       "  -8422.921875,\n",
       "  -9001.0888671875,\n",
       "  -9052.2705078125,\n",
       "  -7998.26513671875,\n",
       "  -7853.6025390625,\n",
       "  -8551.078125,\n",
       "  -8949.708984375,\n",
       "  -8844.12890625,\n",
       "  -8093.12890625,\n",
       "  -8524.4453125,\n",
       "  -8774.150390625,\n",
       "  -8444.900390625,\n",
       "  -7838.02880859375,\n",
       "  -8632.125,\n",
       "  -8101.2021484375,\n",
       "  -8876.765625,\n",
       "  -8838.578125,\n",
       "  -9053.6328125,\n",
       "  -8715.49609375,\n",
       "  -9042.171875,\n",
       "  -7843.056640625,\n",
       "  -8382.1259765625,\n",
       "  -8712.412109375,\n",
       "  -8668.91015625,\n",
       "  -8726.826171875,\n",
       "  -8790.541015625,\n",
       "  -9043.8623046875,\n",
       "  -8657.8974609375,\n",
       "  -7411.3369140625,\n",
       "  -8930.0908203125,\n",
       "  -9048.5947265625,\n",
       "  -8610.060546875,\n",
       "  -8626.0234375,\n",
       "  -9037.9716796875,\n",
       "  -8304.3994140625,\n",
       "  -8452.599609375,\n",
       "  -8711.267578125,\n",
       "  -8868.2705078125,\n",
       "  -8926.2373046875,\n",
       "  -8621.708984375,\n",
       "  -8992.65625,\n",
       "  -8771.345703125,\n",
       "  -9016.6708984375,\n",
       "  -9053.2265625,\n",
       "  -9023.6162109375,\n",
       "  -8682.1640625,\n",
       "  -7658.12353515625,\n",
       "  -8311.4833984375,\n",
       "  -8864.275390625,\n",
       "  -8932.876953125,\n",
       "  -8223.7314453125,\n",
       "  -8081.65478515625,\n",
       "  -8058.90478515625,\n",
       "  -9034.4453125,\n",
       "  -8034.98095703125,\n",
       "  -9053.146484375,\n",
       "  -8556.0947265625,\n",
       "  -7846.11083984375,\n",
       "  -8047.2822265625,\n",
       "  -8404.0478515625,\n",
       "  -7511.2607421875,\n",
       "  -9037.751953125,\n",
       "  -8997.859375,\n",
       "  -8999.603515625,\n",
       "  -8776.6884765625,\n",
       "  -8938.8505859375,\n",
       "  -8621.76953125,\n",
       "  -8951.0029296875,\n",
       "  -8818.6396484375,\n",
       "  -8500.296875,\n",
       "  -8946.140625,\n",
       "  -7641.68212890625,\n",
       "  -8523.771484375,\n",
       "  -8824.810546875,\n",
       "  -9031.328125,\n",
       "  -8297.125,\n",
       "  -8641.595703125,\n",
       "  -7795.88525390625,\n",
       "  -8600.669921875,\n",
       "  -8797.6533203125,\n",
       "  -8950.6171875,\n",
       "  -7708.73828125,\n",
       "  -9047.07421875,\n",
       "  -8337.73046875,\n",
       "  -8310.369140625,\n",
       "  -9039.8447265625,\n",
       "  -9046.0859375,\n",
       "  -8825.6552734375,\n",
       "  -8718.576171875,\n",
       "  -8592.2158203125,\n",
       "  -7994.57763671875,\n",
       "  -8577.974609375,\n",
       "  -8172.185546875,\n",
       "  -8954.8056640625,\n",
       "  -9053.474609375,\n",
       "  -9046.8671875,\n",
       "  -9021.5947265625,\n",
       "  -8933.29296875,\n",
       "  -9053.9013671875,\n",
       "  -8741.68359375,\n",
       "  -8849.025390625,\n",
       "  -7696.87451171875,\n",
       "  -8621.283203125,\n",
       "  -8953.9267578125,\n",
       "  -8742.529296875,\n",
       "  -8878.109375,\n",
       "  -8235.609375,\n",
       "  -8975.8720703125,\n",
       "  -9029.7646484375,\n",
       "  -8520.13671875,\n",
       "  -9040.701171875,\n",
       "  -8500.326171875,\n",
       "  -9025.099609375,\n",
       "  -9052.4296875,\n",
       "  -9030.55078125,\n",
       "  -9033.451171875,\n",
       "  -8662.666015625,\n",
       "  -7782.5830078125,\n",
       "  -8663.6787109375,\n",
       "  -7778.1181640625,\n",
       "  -9035.587890625,\n",
       "  -7937.9296875,\n",
       "  -8760.4091796875,\n",
       "  -8584.1044921875,\n",
       "  -9048.7353515625,\n",
       "  -8732.1669921875,\n",
       "  -8317.9609375,\n",
       "  -7839.27294921875,\n",
       "  -8171.00732421875,\n",
       "  -8981.0693359375,\n",
       "  -8771.9560546875,\n",
       "  -8781.6484375,\n",
       "  -7687.60205078125,\n",
       "  -8677.919921875,\n",
       "  -8293.4296875,\n",
       "  -8976.5693359375,\n",
       "  -8829.287109375],\n",
       " 'nll': -8626.6453125,\n",
       " 'piw_by_example': [0.07832533866167068,\n",
       "  0.07845541089773178,\n",
       "  0.07813312858343124,\n",
       "  0.07815350592136383,\n",
       "  0.07823590934276581,\n",
       "  0.07839109003543854,\n",
       "  0.0783224105834961,\n",
       "  0.07851724326610565,\n",
       "  0.07830604910850525,\n",
       "  0.07839023321866989,\n",
       "  0.07825550436973572,\n",
       "  0.0782805010676384,\n",
       "  0.07810225337743759,\n",
       "  0.07817074656486511,\n",
       "  0.07822953909635544,\n",
       "  0.0783359482884407,\n",
       "  0.07842154055833817,\n",
       "  0.07847069948911667,\n",
       "  0.07816707342863083,\n",
       "  0.0782240629196167,\n",
       "  0.07841385155916214,\n",
       "  0.07852631062269211,\n",
       "  0.0782783031463623,\n",
       "  0.0785064622759819,\n",
       "  0.07828888297080994,\n",
       "  0.07835233211517334,\n",
       "  0.078544482588768,\n",
       "  0.07810871303081512,\n",
       "  0.07817842811346054,\n",
       "  0.07826709747314453,\n",
       "  0.07823481410741806,\n",
       "  0.07853445410728455,\n",
       "  0.07817403972148895,\n",
       "  0.07821819931268692,\n",
       "  0.07816223800182343,\n",
       "  0.07810664176940918,\n",
       "  0.0781891793012619,\n",
       "  0.07853338867425919,\n",
       "  0.07843372970819473,\n",
       "  0.07844297587871552,\n",
       "  0.07833965867757797,\n",
       "  0.07820586860179901,\n",
       "  0.0783674493432045,\n",
       "  0.07810729742050171,\n",
       "  0.07815663516521454,\n",
       "  0.07820521295070648,\n",
       "  0.07847816497087479,\n",
       "  0.07846742123365402,\n",
       "  0.07822216302156448,\n",
       "  0.07831856608390808,\n",
       "  0.07848023623228073,\n",
       "  0.07856597006320953,\n",
       "  0.07842190563678741,\n",
       "  0.07835931330919266,\n",
       "  0.07848770171403885,\n",
       "  0.0781879872083664,\n",
       "  0.07837153226137161,\n",
       "  0.07814426720142365,\n",
       "  0.0781635195016861,\n",
       "  0.07820496708154678,\n",
       "  0.07843524217605591,\n",
       "  0.07842317223548889,\n",
       "  0.07818715274333954,\n",
       "  0.07839921116828918,\n",
       "  0.07845843583345413,\n",
       "  0.07829717546701431,\n",
       "  0.0783362165093422,\n",
       "  0.07838237285614014,\n",
       "  0.07847562432289124,\n",
       "  0.07855774462223053,\n",
       "  0.07814536988735199,\n",
       "  0.07824033498764038,\n",
       "  0.0784209817647934,\n",
       "  0.0785258486866951,\n",
       "  0.07853593677282333,\n",
       "  0.07853889465332031,\n",
       "  0.07837455719709396,\n",
       "  0.07812226563692093,\n",
       "  0.0783490315079689,\n",
       "  0.07817935198545456,\n",
       "  0.07810769975185394,\n",
       "  0.0785403624176979,\n",
       "  0.0785093829035759,\n",
       "  0.07809243351221085,\n",
       "  0.07837174087762833,\n",
       "  0.07828713953495026,\n",
       "  0.07828807085752487,\n",
       "  0.07821880280971527,\n",
       "  0.07841894775629044,\n",
       "  0.07818716764450073,\n",
       "  0.07841463387012482,\n",
       "  0.07844801992177963,\n",
       "  0.07849861681461334,\n",
       "  0.07841639965772629,\n",
       "  0.0780942440032959,\n",
       "  0.0781739354133606,\n",
       "  0.07844648510217667,\n",
       "  0.07837701588869095,\n",
       "  0.0781431570649147,\n",
       "  0.07819102704524994,\n",
       "  0.07855302095413208,\n",
       "  0.07848851382732391,\n",
       "  0.07822392880916595,\n",
       "  0.07826744765043259,\n",
       "  0.07810289412736893,\n",
       "  0.07832285761833191,\n",
       "  0.07814948260784149,\n",
       "  0.07814520597457886,\n",
       "  0.07831405103206635,\n",
       "  0.07836289703845978,\n",
       "  0.07823015004396439,\n",
       "  0.07846910506486893,\n",
       "  0.0781833603978157,\n",
       "  0.07854495197534561,\n",
       "  0.07849127799272537,\n",
       "  0.0781283900141716,\n",
       "  0.07826811075210571,\n",
       "  0.07833787798881531,\n",
       "  0.0783618912100792,\n",
       "  0.0783836767077446,\n",
       "  0.07842084020376205,\n",
       "  0.07834139466285706,\n",
       "  0.0782117024064064,\n",
       "  0.07844021171331406,\n",
       "  0.07810135930776596,\n",
       "  0.07818706333637238,\n",
       "  0.07826776802539825,\n",
       "  0.07821188122034073,\n",
       "  0.07824425399303436,\n",
       "  0.07813391834497452,\n",
       "  0.07827667146921158,\n",
       "  0.07837806642055511,\n",
       "  0.07817329466342926,\n",
       "  0.07831494510173798,\n",
       "  0.07849863171577454,\n",
       "  0.07830272614955902,\n",
       "  0.07833375781774521,\n",
       "  0.0783066377043724,\n",
       "  0.07837536931037903,\n",
       "  0.0784793496131897,\n",
       "  0.07855460047721863,\n",
       "  0.07847914844751358,\n",
       "  0.0785551443696022,\n",
       "  0.07830994576215744,\n",
       "  0.0781155452132225,\n",
       "  0.07821495831012726,\n",
       "  0.07849020510911942,\n",
       "  0.07832559943199158,\n",
       "  0.07820955663919449,\n",
       "  0.07814637571573257,\n",
       "  0.07810680568218231,\n",
       "  0.07812822610139847,\n",
       "  0.07827900350093842,\n",
       "  0.07845830172300339,\n",
       "  0.07845643907785416,\n",
       "  0.07810014486312866,\n",
       "  0.0784764438867569,\n",
       "  0.07814259827136993,\n",
       "  0.07827696949243546,\n",
       "  0.07823113352060318],\n",
       " 'piw': 0.07831646203994751,\n",
       " 'crps_by_example': [0.007397432345896959,\n",
       "  0.0089212441816926,\n",
       "  0.013124197721481323,\n",
       "  0.013020610436797142,\n",
       "  0.00905120000243187,\n",
       "  0.007302288431674242,\n",
       "  0.007396894507110119,\n",
       "  0.011602298356592655,\n",
       "  0.007572050206363201,\n",
       "  0.0072997091338038445,\n",
       "  0.008556635119020939,\n",
       "  0.007949021644890308,\n",
       "  0.01626875251531601,\n",
       "  0.011912507005035877,\n",
       "  0.009205959737300873,\n",
       "  0.007380275055766106,\n",
       "  0.007740267086774111,\n",
       "  0.009264129213988781,\n",
       "  0.012152129784226418,\n",
       "  0.009574386291205883,\n",
       "  0.007556975353509188,\n",
       "  0.012330113910138607,\n",
       "  0.007952463813126087,\n",
       "  0.01128701213747263,\n",
       "  0.007894827052950859,\n",
       "  0.007235228084027767,\n",
       "  0.013358545489609241,\n",
       "  0.015280253253877163,\n",
       "  0.01150595024228096,\n",
       "  0.008293618448078632,\n",
       "  0.009054555557668209,\n",
       "  0.013072400353848934,\n",
       "  0.01171984151005745,\n",
       "  0.00959466677159071,\n",
       "  0.01217501237988472,\n",
       "  0.015291735529899597,\n",
       "  0.010181847028434277,\n",
       "  0.013064319267868996,\n",
       "  0.008408257737755775,\n",
       "  0.00873424019664526,\n",
       "  0.007339095696806908,\n",
       "  0.009929048828780651,\n",
       "  0.007221403997391462,\n",
       "  0.015288029797375202,\n",
       "  0.013005469925701618,\n",
       "  0.009931663051247597,\n",
       "  0.009476827457547188,\n",
       "  0.00924484059214592,\n",
       "  0.009580815210938454,\n",
       "  0.0074076843447983265,\n",
       "  0.009489663876593113,\n",
       "  0.014652841724455357,\n",
       "  0.007741847075521946,\n",
       "  0.007238348945975304,\n",
       "  0.009728626348078251,\n",
       "  0.010187029838562012,\n",
       "  0.0072226617485284805,\n",
       "  0.013066388666629791,\n",
       "  0.012168826535344124,\n",
       "  0.009932635352015495,\n",
       "  0.00860006082803011,\n",
       "  0.00774726178497076,\n",
       "  0.010190694592893124,\n",
       "  0.007352339569479227,\n",
       "  0.009050575084984303,\n",
       "  0.007715898100286722,\n",
       "  0.007336391136050224,\n",
       "  0.007275313604623079,\n",
       "  0.009461290203034878,\n",
       "  0.014291941188275814,\n",
       "  0.013060850091278553,\n",
       "  0.008943547494709492,\n",
       "  0.007737916894257069,\n",
       "  0.012326814234256744,\n",
       "  0.013083850964903831,\n",
       "  0.013106434606015682,\n",
       "  0.007229545619338751,\n",
       "  0.01444593071937561,\n",
       "  0.0072603970766067505,\n",
       "  0.011501847766339779,\n",
       "  0.015285776928067207,\n",
       "  0.013117910362780094,\n",
       "  0.011307304725050926,\n",
       "  0.01660621352493763,\n",
       "  0.007223098538815975,\n",
       "  0.007896941155195236,\n",
       "  0.007895790971815586,\n",
       "  0.009592517279088497,\n",
       "  0.007729452569037676,\n",
       "  0.01019064337015152,\n",
       "  0.007712050341069698,\n",
       "  0.008759669028222561,\n",
       "  0.010819721035659313,\n",
       "  0.007719044107943773,\n",
       "  0.016313470900058746,\n",
       "  0.011720388196408749,\n",
       "  0.00875183381140232,\n",
       "  0.007235440891236067,\n",
       "  0.01307207252830267,\n",
       "  0.010173804126679897,\n",
       "  0.013969994150102139,\n",
       "  0.00991394929587841,\n",
       "  0.00957483146339655,\n",
       "  0.008292916230857372,\n",
       "  0.01626521348953247,\n",
       "  0.0073969499208033085,\n",
       "  0.013040305115282536,\n",
       "  0.013061721809208393,\n",
       "  0.007408345118165016,\n",
       "  0.0072267972864210606,\n",
       "  0.009203913621604443,\n",
       "  0.009254731237888336,\n",
       "  0.010782047174870968,\n",
       "  0.013362136669456959,\n",
       "  0.010127409361302853,\n",
       "  0.013416432775557041,\n",
       "  0.008061996661126614,\n",
       "  0.007337625604122877,\n",
       "  0.0072249555960297585,\n",
       "  0.007280824705958366,\n",
       "  0.007737329695373774,\n",
       "  0.007289285305887461,\n",
       "  0.009906909428536892,\n",
       "  0.008720781654119492,\n",
       "  0.016273781657218933,\n",
       "  0.0101910550147295,\n",
       "  0.008062693290412426,\n",
       "  0.009906197898089886,\n",
       "  0.008835414424538612,\n",
       "  0.013119980692863464,\n",
       "  0.007955175824463367,\n",
       "  0.00726421270519495,\n",
       "  0.011723343282938004,\n",
       "  0.007408140227198601,\n",
       "  0.010819688439369202,\n",
       "  0.007674692198634148,\n",
       "  0.007378818932920694,\n",
       "  0.007571730762720108,\n",
       "  0.007231441326439381,\n",
       "  0.00948411412537098,\n",
       "  0.013982643373310566,\n",
       "  0.009482934139668941,\n",
       "  0.013986877165734768,\n",
       "  0.007409729529172182,\n",
       "  0.014970233663916588,\n",
       "  0.009606335312128067,\n",
       "  0.010120492428541183,\n",
       "  0.007397493347525597,\n",
       "  0.009914941154420376,\n",
       "  0.013055785559117794,\n",
       "  0.015290818177163601,\n",
       "  0.013417339883744717,\n",
       "  0.007951337844133377,\n",
       "  0.009049825370311737,\n",
       "  0.008926709182560444,\n",
       "  0.016280468553304672,\n",
       "  0.009466277435421944,\n",
       "  0.013074957765638828,\n",
       "  0.007954655215144157,\n",
       "  0.00920084584504366],\n",
       " 'crps': 0.010129239410161972,\n",
       " 'nMeRCI_all': 0.8530460596084595,\n",
       " 'rmsce_all': 0.14743340015411377}"
      ]
     },
     "execution_count": 318,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 319,
   "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": 320,
   "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": 149,
   "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": 150,
   "id": "39e9bde3-2eba-4801-aa30-88c2c043ec20",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "2384c2df-e413-4a42-8107-977afa42306e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HQYREZUhJkJEhVDKmQgRETk6JkJEhVApZNDrmQgRETkyJkJEhVDJZciGoaLDICKiMsREiKgQSrkESWKHaSIiR8ZEiKgQkiRByXXGiIgcGr/uEhERkdNiIkREREROi4kQEREROS0mQkREROS0mAgRERGR02IiRERERE6LiRARERE5LSZCRERE5LSYCBEREZHTYiJERERETouJEBERETktJkJERETktJgIERERkdNiIkREREROi4kQEREROS1FRQfwsBNCAAA0Gk0FR0JERETWMn5uGz/HC8NEqBgpKSkAgNDQ0AqOhIiIiEoqJSUF3t7ehd4vieJSJSdnMBhw69YteHp6QpIkmx1Xo9EgNDQU169fh5eXl82OSwXxXJcPnufywfNcPniey0dZnmchBFJSUhAcHAyZrPCeQKwRKoZMJkPVqlXL7PheXl58k5UTnuvywfNcPnieywfPc/koq/NcVE2QETtLExERkdNiIkREREROi4lQBVGr1ZgwYQLUanVFh+LweK7LB89z+eB5Lh88z+XjYTjP7CxNRERETos1QkREROS0mAgRERGR02IiRERERE6LiRARERE5LSZCZWjevHkICwuDi4sLWrZsicOHDxdZ/tdff0X9+vXh4uKCJk2aYNOmTeUUqX0ryXleuHAhnnrqKfj6+sLX1xcdOnQo9u9C95X0NW20cuVKSJKEbt26lW2ADqKk5zkpKQlDhw5FUFAQ1Go16taty+uHFUp6nmfNmoV69erB1dUVoaGhGD58ODIzM8spWvu0Z88edOnSBcHBwZAkCevXry92n927d+Oxxx6DWq1G7dq1sXTp0rINUlCZWLlypVCpVGLx4sXizJkzYvDgwcLHx0fExcVZLL9//34hl8vFjBkzxNmzZ8Vnn30mlEqlOH36dDlHbl9Kep579eol5s2bJ06cOCHOnTsn+vfvL7y9vcWNGzfKOXL7U9JzbRQdHS1CQkLEU089Jbp27Vo+wdqxkp7nrKws0bx5c9GpUyexb98+ER0dLXbv3i1OnjxZzpHbl5Ke5+XLlwu1Wi2WL18uoqOjxZYtW0RQUJAYPnx4OUduXzZt2iTGjh0rfvvtNwFArFu3rsjyV65cEW5ubmLEiBHi7NmzYu7cuUIul4vNmzeXWYxMhMpIixYtxNChQ0239Xq9CA4OFlFRURbLd+/eXXTu3NlsW8uWLcVb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_ood_test[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_ood_test[parameter_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "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": 153,
   "id": "6b809290-3cb4-4d19-a03a-ed6435a705a7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.5372)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_ood_test[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_ood_test[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_ood_test[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "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": 155,
   "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": 156,
   "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": 157,
   "id": "da438412-1398-430d-ba74-82db34174f39",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.0022263741120696068,\n",
       "  0.0031321141868829727,\n",
       "  0.006980760954320431,\n",
       "  0.00701024429872632,\n",
       "  0.004128856118768454,\n",
       "  0.0019955842290073633,\n",
       "  0.0022249286994338036,\n",
       "  0.004744536709040403,\n",
       "  0.002445796737447381,\n",
       "  0.0019953360315412283,\n",
       "  0.003527431981638074,\n",
       "  0.002956877928227186,\n",
       "  0.008906910195946693,\n",
       "  0.006303565576672554,\n",
       "  0.0042670187540352345,\n",
       "  0.0022146650590002537,\n",
       "  0.002305206609889865,\n",
       "  0.003335517831146717,\n",
       "  0.006455746479332447,\n",
       "  0.004622090142220259,\n",
       "  0.002167843282222748,\n",
       "  0.005190900526940823,\n",
       "  0.0029553119093179703,\n",
       "  0.004582589492201805,\n",
       "  0.002883901121094823,\n",
       "  0.0020189411006867886,\n",
       "  0.005788077134639025,\n",
       "  0.008284150622785091,\n",
       "  0.005996551364660263,\n",
       "  0.0032918984070420265,\n",
       "  0.004127808380872011,\n",
       "  0.00564827723428607,\n",
       "  0.00617081206291914,\n",
       "  0.004615959711372852,\n",
       "  0.006449174601584673,\n",
       "  0.008280749432742596,\n",
       "  0.004981655161827803,\n",
       "  0.005648133344948292,\n",
       "  0.0027930354699492455,\n",
       "  0.003028087317943573,\n",
       "  0.0021583326160907745,\n",
       "  0.004829916171729565,\n",
       "  0.0019629481248557568,\n",
       "  0.008281844668090343,\n",
       "  0.007014803122729063,\n",
       "  0.00482918880879879,\n",
       "  0.0034606417175382376,\n",
       "  0.003335089422762394,\n",
       "  0.004620107356458902,\n",
       "  0.0022379152942448854,\n",
       "  0.0034609145950526,\n",
       "  0.006531164050102234,\n",
       "  0.0023052857723087072,\n",
       "  0.0020086115691810846,\n",
       "  0.0035955721978098154,\n",
       "  0.004980345256626606,\n",
       "  0.001953274244442582,\n",
       "  0.0069968742318451405,\n",
       "  0.006450933869928122,\n",
       "  0.004828920587897301,\n",
       "  0.002944197505712509,\n",
       "  0.002305556321516633,\n",
       "  0.0049794260412454605,\n",
       "  0.0020310513209551573,\n",
       "  0.0032268601935356855,\n",
       "  0.0026654168032109737,\n",
       "  0.0021567437797784805,\n",
       "  0.0019904726650565863,\n",
       "  0.0034603106323629618,\n",
       "  0.006336815655231476,\n",
       "  0.006998459808528423,\n",
       "  0.004002582747489214,\n",
       "  0.0023050878662616014,\n",
       "  0.0051908427849411964,\n",
       "  0.005648478399962187,\n",
       "  0.0056488774716854095,\n",
       "  0.001954215345904231,\n",
       "  0.007806530687958002,\n",
       "  0.0020460516680032015,\n",
       "  0.005997736472636461,\n",
       "  0.008282509632408619,\n",
       "  0.005649081896990538,\n",
       "  0.004582961555570364,\n",
       "  0.009067557752132416,\n",
       "  0.001953335478901863,\n",
       "  0.0028826924972236156,\n",
       "  0.0028833404649049044,\n",
       "  0.0046165925450623035,\n",
       "  0.002304656896740198,\n",
       "  0.004979439079761505,\n",
       "  0.0023037497885525227,\n",
       "  0.003028770675882697,\n",
       "  0.004304446280002594,\n",
       "  0.0023041176609694958,\n",
       "  0.008892924524843693,\n",
       "  0.006170652806758881,\n",
       "  0.003028561593964696,\n",
       "  0.001954982988536358,\n",
       "  0.0069952551275491714,\n",
       "  0.004983707796782255,\n",
       "  0.006148495711386204,\n",
       "  0.003725792281329632,\n",
       "  0.004621951840817928,\n",
       "  0.0032921796664595604,\n",
       "  0.00890803337097168,\n",
       "  0.002225144300609827,\n",
       "  0.007004419807344675,\n",
       "  0.006998212542384863,\n",
       "  0.0022356300614774227,\n",
       "  0.0019852202385663986,\n",
       "  0.004267638549208641,\n",
       "  0.003335309447720647,\n",
       "  0.0054587507620453835,\n",
       "  0.005788139533251524,\n",
       "  0.0038635656237602234,\n",
       "  0.007154760882258415,\n",
       "  0.0030773719772696495,\n",
       "  0.002157508162781596,\n",
       "  0.0019848616793751717,\n",
       "  0.001993428450077772,\n",
       "  0.0023050580639392138,\n",
       "  0.0020770712289959192,\n",
       "  0.004836255218833685,\n",
       "  0.003027719911187887,\n",
       "  0.00890531949698925,\n",
       "  0.004979334305971861,\n",
       "  0.003077120054513216,\n",
       "  0.004836464766412973,\n",
       "  0.0038506989367306232,\n",
       "  0.0069819120690226555,\n",
       "  0.0029541412368416786,\n",
       "  0.0019891769625246525,\n",
       "  0.006169802974909544,\n",
       "  0.0022360840812325478,\n",
       "  0.004304445348680019,\n",
       "  0.0026327967643737793,\n",
       "  0.0022136028856039047,\n",
       "  0.002446128986775875,\n",
       "  0.0019544658716768026,\n",
       "  0.0034607970155775547,\n",
       "  0.006148724351078272,\n",
       "  0.0034607721026986837,\n",
       "  0.00614880071952939,\n",
       "  0.002233572071418166,\n",
       "  0.008113098330795765,\n",
       "  0.004612583201378584,\n",
       "  0.003863430814817548,\n",
       "  0.002226492390036583,\n",
       "  0.004833918064832687,\n",
       "  0.006999919191002846,\n",
       "  0.008281020447611809,\n",
       "  0.0071545131504535675,\n",
       "  0.002955813892185688,\n",
       "  0.003226842498406768,\n",
       "  0.0031322503928095102,\n",
       "  0.00890321098268032,\n",
       "  0.0034604177344590425,\n",
       "  0.00699443556368351,\n",
       "  0.0029543619602918625,\n",
       "  0.0042685759253799915],\n",
       " 'mse': 0.004342679679393768,\n",
       " 'nll_by_example': [-9048.599609375,\n",
       "  -8786.0546875,\n",
       "  -8230.1767578125,\n",
       "  -8362.84375,\n",
       "  -8848.1171875,\n",
       "  -9008.984375,\n",
       "  -9046.783203125,\n",
       "  -8330.6875,\n",
       "  -9029.822265625,\n",
       "  -9010.5322265625,\n",
       "  -8915.2392578125,\n",
       "  -8984.2705078125,\n",
       "  -7703.83837890625,\n",
       "  -8502.53125,\n",
       "  -8823.236328125,\n",
       "  -9052.93359375,\n",
       "  -8931.2119140625,\n",
       "  -8710.705078125,\n",
       "  -8473.3720703125,\n",
       "  -8798.1826171875,\n",
       "  -8955.373046875,\n",
       "  -8220.5078125,\n",
       "  -8979.53125,\n",
       "  -8422.921875,\n",
       "  -9001.0888671875,\n",
       "  -9052.2705078125,\n",
       "  -7998.26513671875,\n",
       "  -7853.6025390625,\n",
       "  -8551.078125,\n",
       "  -8949.708984375,\n",
       "  -8844.12890625,\n",
       "  -8093.12890625,\n",
       "  -8524.4453125,\n",
       "  -8774.150390625,\n",
       "  -8444.900390625,\n",
       "  -7838.02880859375,\n",
       "  -8632.125,\n",
       "  -8101.2021484375,\n",
       "  -8876.765625,\n",
       "  -8838.578125,\n",
       "  -9053.6328125,\n",
       "  -8715.49609375,\n",
       "  -9042.171875,\n",
       "  -7843.056640625,\n",
       "  -8382.1259765625,\n",
       "  -8712.412109375,\n",
       "  -8668.91015625,\n",
       "  -8726.826171875,\n",
       "  -8790.541015625,\n",
       "  -9043.8623046875,\n",
       "  -8657.8974609375,\n",
       "  -7411.3369140625,\n",
       "  -8930.0908203125,\n",
       "  -9048.5947265625,\n",
       "  -8610.060546875,\n",
       "  -8626.0234375,\n",
       "  -9037.9716796875,\n",
       "  -8304.3994140625,\n",
       "  -8452.599609375,\n",
       "  -8711.267578125,\n",
       "  -8868.2705078125,\n",
       "  -8926.2373046875,\n",
       "  -8621.708984375,\n",
       "  -8992.65625,\n",
       "  -8771.345703125,\n",
       "  -9016.6708984375,\n",
       "  -9053.2265625,\n",
       "  -9023.6162109375,\n",
       "  -8682.1640625,\n",
       "  -7658.12353515625,\n",
       "  -8311.4833984375,\n",
       "  -8864.275390625,\n",
       "  -8932.876953125,\n",
       "  -8223.7314453125,\n",
       "  -8081.65478515625,\n",
       "  -8058.90478515625,\n",
       "  -9034.4453125,\n",
       "  -8034.98095703125,\n",
       "  -9053.146484375,\n",
       "  -8556.0947265625,\n",
       "  -7846.11083984375,\n",
       "  -8047.2822265625,\n",
       "  -8404.0478515625,\n",
       "  -7511.2607421875,\n",
       "  -9037.751953125,\n",
       "  -8997.859375,\n",
       "  -8999.603515625,\n",
       "  -8776.6884765625,\n",
       "  -8938.8505859375,\n",
       "  -8621.76953125,\n",
       "  -8951.0029296875,\n",
       "  -8818.6396484375,\n",
       "  -8500.296875,\n",
       "  -8946.140625,\n",
       "  -7641.68212890625,\n",
       "  -8523.771484375,\n",
       "  -8824.810546875,\n",
       "  -9031.328125,\n",
       "  -8297.125,\n",
       "  -8641.595703125,\n",
       "  -7795.88525390625,\n",
       "  -8600.669921875,\n",
       "  -8797.6533203125,\n",
       "  -8950.6171875,\n",
       "  -7708.73828125,\n",
       "  -9047.07421875,\n",
       "  -8337.73046875,\n",
       "  -8310.369140625,\n",
       "  -9039.8447265625,\n",
       "  -9046.0859375,\n",
       "  -8825.6552734375,\n",
       "  -8718.576171875,\n",
       "  -8592.2158203125,\n",
       "  -7994.57763671875,\n",
       "  -8577.974609375,\n",
       "  -8172.185546875,\n",
       "  -8954.8056640625,\n",
       "  -9053.474609375,\n",
       "  -9046.8671875,\n",
       "  -9021.5947265625,\n",
       "  -8933.29296875,\n",
       "  -9053.9013671875,\n",
       "  -8741.68359375,\n",
       "  -8849.025390625,\n",
       "  -7696.87451171875,\n",
       "  -8621.283203125,\n",
       "  -8953.9267578125,\n",
       "  -8742.529296875,\n",
       "  -8878.109375,\n",
       "  -8235.609375,\n",
       "  -8975.8720703125,\n",
       "  -9029.7646484375,\n",
       "  -8520.13671875,\n",
       "  -9040.701171875,\n",
       "  -8500.326171875,\n",
       "  -9025.099609375,\n",
       "  -9052.4296875,\n",
       "  -9030.55078125,\n",
       "  -9033.451171875,\n",
       "  -8662.666015625,\n",
       "  -7782.5830078125,\n",
       "  -8663.6787109375,\n",
       "  -7778.1181640625,\n",
       "  -9035.587890625,\n",
       "  -7937.9296875,\n",
       "  -8760.4091796875,\n",
       "  -8584.1044921875,\n",
       "  -9048.7353515625,\n",
       "  -8732.1669921875,\n",
       "  -8317.9609375,\n",
       "  -7839.27294921875,\n",
       "  -8171.00732421875,\n",
       "  -8981.0693359375,\n",
       "  -8771.9560546875,\n",
       "  -8781.6484375,\n",
       "  -7687.60205078125,\n",
       "  -8677.919921875,\n",
       "  -8293.4296875,\n",
       "  -8976.5693359375,\n",
       "  -8829.287109375],\n",
       " 'nll': -8626.6453125,\n",
       " 'piw_by_example': [0.07832533866167068,\n",
       "  0.07845541089773178,\n",
       "  0.07813312858343124,\n",
       "  0.07815350592136383,\n",
       "  0.07823590934276581,\n",
       "  0.07839109003543854,\n",
       "  0.0783224105834961,\n",
       "  0.07851724326610565,\n",
       "  0.07830604910850525,\n",
       "  0.07839023321866989,\n",
       "  0.07825550436973572,\n",
       "  0.0782805010676384,\n",
       "  0.07810225337743759,\n",
       "  0.07817074656486511,\n",
       "  0.07822953909635544,\n",
       "  0.0783359482884407,\n",
       "  0.07842154055833817,\n",
       "  0.07847069948911667,\n",
       "  0.07816707342863083,\n",
       "  0.0782240629196167,\n",
       "  0.07841385155916214,\n",
       "  0.07852631062269211,\n",
       "  0.0782783031463623,\n",
       "  0.0785064622759819,\n",
       "  0.07828888297080994,\n",
       "  0.07835233211517334,\n",
       "  0.078544482588768,\n",
       "  0.07810871303081512,\n",
       "  0.07817842811346054,\n",
       "  0.07826709747314453,\n",
       "  0.07823481410741806,\n",
       "  0.07853445410728455,\n",
       "  0.07817403972148895,\n",
       "  0.07821819931268692,\n",
       "  0.07816223800182343,\n",
       "  0.07810664176940918,\n",
       "  0.0781891793012619,\n",
       "  0.07853338867425919,\n",
       "  0.07843372970819473,\n",
       "  0.07844297587871552,\n",
       "  0.07833965867757797,\n",
       "  0.07820586860179901,\n",
       "  0.0783674493432045,\n",
       "  0.07810729742050171,\n",
       "  0.07815663516521454,\n",
       "  0.07820521295070648,\n",
       "  0.07847816497087479,\n",
       "  0.07846742123365402,\n",
       "  0.07822216302156448,\n",
       "  0.07831856608390808,\n",
       "  0.07848023623228073,\n",
       "  0.07856597006320953,\n",
       "  0.07842190563678741,\n",
       "  0.07835931330919266,\n",
       "  0.07848770171403885,\n",
       "  0.0781879872083664,\n",
       "  0.07837153226137161,\n",
       "  0.07814426720142365,\n",
       "  0.0781635195016861,\n",
       "  0.07820496708154678,\n",
       "  0.07843524217605591,\n",
       "  0.07842317223548889,\n",
       "  0.07818715274333954,\n",
       "  0.07839921116828918,\n",
       "  0.07845843583345413,\n",
       "  0.07829717546701431,\n",
       "  0.0783362165093422,\n",
       "  0.07838237285614014,\n",
       "  0.07847562432289124,\n",
       "  0.07855774462223053,\n",
       "  0.07814536988735199,\n",
       "  0.07824033498764038,\n",
       "  0.0784209817647934,\n",
       "  0.0785258486866951,\n",
       "  0.07853593677282333,\n",
       "  0.07853889465332031,\n",
       "  0.07837455719709396,\n",
       "  0.07812226563692093,\n",
       "  0.0783490315079689,\n",
       "  0.07817935198545456,\n",
       "  0.07810769975185394,\n",
       "  0.0785403624176979,\n",
       "  0.0785093829035759,\n",
       "  0.07809243351221085,\n",
       "  0.07837174087762833,\n",
       "  0.07828713953495026,\n",
       "  0.07828807085752487,\n",
       "  0.07821880280971527,\n",
       "  0.07841894775629044,\n",
       "  0.07818716764450073,\n",
       "  0.07841463387012482,\n",
       "  0.07844801992177963,\n",
       "  0.07849861681461334,\n",
       "  0.07841639965772629,\n",
       "  0.0780942440032959,\n",
       "  0.0781739354133606,\n",
       "  0.07844648510217667,\n",
       "  0.07837701588869095,\n",
       "  0.0781431570649147,\n",
       "  0.07819102704524994,\n",
       "  0.07855302095413208,\n",
       "  0.07848851382732391,\n",
       "  0.07822392880916595,\n",
       "  0.07826744765043259,\n",
       "  0.07810289412736893,\n",
       "  0.07832285761833191,\n",
       "  0.07814948260784149,\n",
       "  0.07814520597457886,\n",
       "  0.07831405103206635,\n",
       "  0.07836289703845978,\n",
       "  0.07823015004396439,\n",
       "  0.07846910506486893,\n",
       "  0.0781833603978157,\n",
       "  0.07854495197534561,\n",
       "  0.07849127799272537,\n",
       "  0.0781283900141716,\n",
       "  0.07826811075210571,\n",
       "  0.07833787798881531,\n",
       "  0.0783618912100792,\n",
       "  0.0783836767077446,\n",
       "  0.07842084020376205,\n",
       "  0.07834139466285706,\n",
       "  0.0782117024064064,\n",
       "  0.07844021171331406,\n",
       "  0.07810135930776596,\n",
       "  0.07818706333637238,\n",
       "  0.07826776802539825,\n",
       "  0.07821188122034073,\n",
       "  0.07824425399303436,\n",
       "  0.07813391834497452,\n",
       "  0.07827667146921158,\n",
       "  0.07837806642055511,\n",
       "  0.07817329466342926,\n",
       "  0.07831494510173798,\n",
       "  0.07849863171577454,\n",
       "  0.07830272614955902,\n",
       "  0.07833375781774521,\n",
       "  0.0783066377043724,\n",
       "  0.07837536931037903,\n",
       "  0.0784793496131897,\n",
       "  0.07855460047721863,\n",
       "  0.07847914844751358,\n",
       "  0.0785551443696022,\n",
       "  0.07830994576215744,\n",
       "  0.0781155452132225,\n",
       "  0.07821495831012726,\n",
       "  0.07849020510911942,\n",
       "  0.07832559943199158,\n",
       "  0.07820955663919449,\n",
       "  0.07814637571573257,\n",
       "  0.07810680568218231,\n",
       "  0.07812822610139847,\n",
       "  0.07827900350093842,\n",
       "  0.07845830172300339,\n",
       "  0.07845643907785416,\n",
       "  0.07810014486312866,\n",
       "  0.0784764438867569,\n",
       "  0.07814259827136993,\n",
       "  0.07827696949243546,\n",
       "  0.07823113352060318],\n",
       " 'piw': 0.07831646203994751,\n",
       " 'crps_by_example': [0.007397432345896959,\n",
       "  0.0089212441816926,\n",
       "  0.013124197721481323,\n",
       "  0.013020610436797142,\n",
       "  0.00905120000243187,\n",
       "  0.007302288431674242,\n",
       "  0.007396894507110119,\n",
       "  0.011602298356592655,\n",
       "  0.007572050206363201,\n",
       "  0.0072997091338038445,\n",
       "  0.008556635119020939,\n",
       "  0.007949021644890308,\n",
       "  0.01626875251531601,\n",
       "  0.011912507005035877,\n",
       "  0.009205959737300873,\n",
       "  0.007380275055766106,\n",
       "  0.007740267086774111,\n",
       "  0.009264129213988781,\n",
       "  0.012152129784226418,\n",
       "  0.009574386291205883,\n",
       "  0.007556975353509188,\n",
       "  0.012330113910138607,\n",
       "  0.007952463813126087,\n",
       "  0.01128701213747263,\n",
       "  0.007894827052950859,\n",
       "  0.007235228084027767,\n",
       "  0.013358545489609241,\n",
       "  0.015280253253877163,\n",
       "  0.01150595024228096,\n",
       "  0.008293618448078632,\n",
       "  0.009054555557668209,\n",
       "  0.013072400353848934,\n",
       "  0.01171984151005745,\n",
       "  0.00959466677159071,\n",
       "  0.01217501237988472,\n",
       "  0.015291735529899597,\n",
       "  0.010181847028434277,\n",
       "  0.013064319267868996,\n",
       "  0.008408257737755775,\n",
       "  0.00873424019664526,\n",
       "  0.007339095696806908,\n",
       "  0.009929048828780651,\n",
       "  0.007221403997391462,\n",
       "  0.015288029797375202,\n",
       "  0.013005469925701618,\n",
       "  0.009931663051247597,\n",
       "  0.009476827457547188,\n",
       "  0.00924484059214592,\n",
       "  0.009580815210938454,\n",
       "  0.0074076843447983265,\n",
       "  0.009489663876593113,\n",
       "  0.014652841724455357,\n",
       "  0.007741847075521946,\n",
       "  0.007238348945975304,\n",
       "  0.009728626348078251,\n",
       "  0.010187029838562012,\n",
       "  0.0072226617485284805,\n",
       "  0.013066388666629791,\n",
       "  0.012168826535344124,\n",
       "  0.009932635352015495,\n",
       "  0.00860006082803011,\n",
       "  0.00774726178497076,\n",
       "  0.010190694592893124,\n",
       "  0.007352339569479227,\n",
       "  0.009050575084984303,\n",
       "  0.007715898100286722,\n",
       "  0.007336391136050224,\n",
       "  0.007275313604623079,\n",
       "  0.009461290203034878,\n",
       "  0.014291941188275814,\n",
       "  0.013060850091278553,\n",
       "  0.008943547494709492,\n",
       "  0.007737916894257069,\n",
       "  0.012326814234256744,\n",
       "  0.013083850964903831,\n",
       "  0.013106434606015682,\n",
       "  0.007229545619338751,\n",
       "  0.01444593071937561,\n",
       "  0.0072603970766067505,\n",
       "  0.011501847766339779,\n",
       "  0.015285776928067207,\n",
       "  0.013117910362780094,\n",
       "  0.011307304725050926,\n",
       "  0.01660621352493763,\n",
       "  0.007223098538815975,\n",
       "  0.007896941155195236,\n",
       "  0.007895790971815586,\n",
       "  0.009592517279088497,\n",
       "  0.007729452569037676,\n",
       "  0.01019064337015152,\n",
       "  0.007712050341069698,\n",
       "  0.008759669028222561,\n",
       "  0.010819721035659313,\n",
       "  0.007719044107943773,\n",
       "  0.016313470900058746,\n",
       "  0.011720388196408749,\n",
       "  0.00875183381140232,\n",
       "  0.007235440891236067,\n",
       "  0.01307207252830267,\n",
       "  0.010173804126679897,\n",
       "  0.013969994150102139,\n",
       "  0.00991394929587841,\n",
       "  0.00957483146339655,\n",
       "  0.008292916230857372,\n",
       "  0.01626521348953247,\n",
       "  0.0073969499208033085,\n",
       "  0.013040305115282536,\n",
       "  0.013061721809208393,\n",
       "  0.007408345118165016,\n",
       "  0.0072267972864210606,\n",
       "  0.009203913621604443,\n",
       "  0.009254731237888336,\n",
       "  0.010782047174870968,\n",
       "  0.013362136669456959,\n",
       "  0.010127409361302853,\n",
       "  0.013416432775557041,\n",
       "  0.008061996661126614,\n",
       "  0.007337625604122877,\n",
       "  0.0072249555960297585,\n",
       "  0.007280824705958366,\n",
       "  0.007737329695373774,\n",
       "  0.007289285305887461,\n",
       "  0.009906909428536892,\n",
       "  0.008720781654119492,\n",
       "  0.016273781657218933,\n",
       "  0.0101910550147295,\n",
       "  0.008062693290412426,\n",
       "  0.009906197898089886,\n",
       "  0.008835414424538612,\n",
       "  0.013119980692863464,\n",
       "  0.007955175824463367,\n",
       "  0.00726421270519495,\n",
       "  0.011723343282938004,\n",
       "  0.007408140227198601,\n",
       "  0.010819688439369202,\n",
       "  0.007674692198634148,\n",
       "  0.007378818932920694,\n",
       "  0.007571730762720108,\n",
       "  0.007231441326439381,\n",
       "  0.00948411412537098,\n",
       "  0.013982643373310566,\n",
       "  0.009482934139668941,\n",
       "  0.013986877165734768,\n",
       "  0.007409729529172182,\n",
       "  0.014970233663916588,\n",
       "  0.009606335312128067,\n",
       "  0.010120492428541183,\n",
       "  0.007397493347525597,\n",
       "  0.009914941154420376,\n",
       "  0.013055785559117794,\n",
       "  0.015290818177163601,\n",
       "  0.013417339883744717,\n",
       "  0.007951337844133377,\n",
       "  0.009049825370311737,\n",
       "  0.008926709182560444,\n",
       "  0.016280468553304672,\n",
       "  0.009466277435421944,\n",
       "  0.013074957765638828,\n",
       "  0.007954655215144157,\n",
       "  0.00920084584504366],\n",
       " 'crps': 0.010129239410161972,\n",
       " 'nMeRCI_all': 0.8530460596084595,\n",
       " 'rmsce_all': 0.14743340015411377,\n",
       " 'cerr_by_example': [0.061089612543582916,\n",
       "  0.12046806514263153,\n",
       "  0.314481258392334,\n",
       "  0.28760045766830444,\n",
       "  0.17823420464992523,\n",
       "  0.03645046055316925,\n",
       "  0.06482560932636261,\n",
       "  0.20270556211471558,\n",
       "  0.08567426353693008,\n",
       "  0.03534794598817825,\n",
       "  0.1521109789609909,\n",
       "  0.1186862587928772,\n",
       "  0.3551044166088104,\n",
       "  0.264784574508667,\n",
       "  0.18673747777938843,\n",
       "  0.04757697507739067,\n",
       "  0.07614042609930038,\n",
       "  0.14053994417190552,\n",
       "  0.26964235305786133,\n",
       "  0.1940302550792694,\n",
       "  0.06609423458576202,\n",
       "  0.21519175171852112,\n",
       "  0.12161422520875931,\n",
       "  0.18789130449295044,\n",
       "  0.10751032829284668,\n",
       "  0.03063586726784706,\n",
       "  0.24026671051979065,\n",
       "  0.34662437438964844,\n",
       "  0.2546173930168152,\n",
       "  0.136614128947258,\n",
       "  0.17969520390033722,\n",
       "  0.22640573978424072,\n",
       "  0.260407954454422,\n",
       "  0.20182472467422485,\n",
       "  0.27605685591697693,\n",
       "  0.34935057163238525,\n",
       "  0.24036872386932373,\n",
       "  0.22493451833724976,\n",
       "  0.09209156781435013,\n",
       "  0.10417020320892334,\n",
       "  0.0435497872531414,\n",
       "  0.21820244193077087,\n",
       "  0.02179669216275215,\n",
       "  0.348472535610199,\n",
       "  0.2834640145301819,\n",
       "  0.21909230947494507,\n",
       "  0.15032429993152618,\n",
       "  0.13620993494987488,\n",
       "  0.19654753804206848,\n",
       "  0.06975255161523819,\n",
       "  0.15305526554584503,\n",
       "  0.26999014616012573,\n",
       "  0.07662538439035416,\n",
       "  0.025915635749697685,\n",
       "  0.1628606915473938,\n",
       "  0.2419452965259552,\n",
       "  0.02197798155248165,\n",
       "  0.29976123571395874,\n",
       "  0.2743358612060547,\n",
       "  0.21942134201526642,\n",
       "  0.09405237436294556,\n",
       "  0.07827786356210709,\n",
       "  0.2430514544248581,\n",
       "  0.047021765261888504,\n",
       "  0.12441840767860413,\n",
       "  0.09697885066270828,\n",
       "  0.04723184555768967,\n",
       "  0.025520630180835724,\n",
       "  0.1469801962375641,\n",
       "  0.2585963308811188,\n",
       "  0.2983170747756958,\n",
       "  0.17235785722732544,\n",
       "  0.0754130631685257,\n",
       "  0.214580237865448,\n",
       "  0.22847822308540344,\n",
       "  0.23253682255744934,\n",
       "  0.02220160886645317,\n",
       "  0.32879868149757385,\n",
       "  0.03388833999633789,\n",
       "  0.25339528918266296,\n",
       "  0.34793853759765625,\n",
       "  0.2345867156982422,\n",
       "  0.19189290702342987,\n",
       "  0.3679999113082886,\n",
       "  0.021992359310388565,\n",
       "  0.10976536571979523,\n",
       "  0.10852780938148499,\n",
       "  0.20101726055145264,\n",
       "  0.07276743650436401,\n",
       "  0.24303632974624634,\n",
       "  0.06714867800474167,\n",
       "  0.11078688502311707,\n",
       "  0.17738425731658936,\n",
       "  0.06943810731172562,\n",
       "  0.36562031507492065,\n",
       "  0.26056885719299316,\n",
       "  0.10877422243356705,\n",
       "  0.02238311991095543,\n",
       "  0.30123811960220337,\n",
       "  0.23790189623832703,\n",
       "  0.2520758807659149,\n",
       "  0.16391727328300476,\n",
       "  0.1942060887813568,\n",
       "  0.1361442357301712,\n",
       "  0.35425907373428345,\n",
       "  0.06426776945590973,\n",
       "  0.29289141297340393,\n",
       "  0.2985435426235199,\n",
       "  0.07550666481256485,\n",
       "  0.02365770936012268,\n",
       "  0.1858920156955719,\n",
       "  0.13844043016433716,\n",
       "  0.2480873316526413,\n",
       "  0.24089950323104858,\n",
       "  0.16756266355514526,\n",
       "  0.320710152387619,\n",
       "  0.1352596879005432,\n",
       "  0.045450352132320404,\n",
       "  0.02429446578025818,\n",
       "  0.026849858462810516,\n",
       "  0.0752316415309906,\n",
       "  0.041691046208143234,\n",
       "  0.21046391129493713,\n",
       "  0.10056012123823166,\n",
       "  0.3562970459461212,\n",
       "  0.24316158890724182,\n",
       "  0.13571693003177643,\n",
       "  0.21020811796188354,\n",
       "  0.1671222448348999,\n",
       "  0.31342634558677673,\n",
       "  0.12380673736333847,\n",
       "  0.02271806076169014,\n",
       "  0.26142752170562744,\n",
       "  0.074361652135849,\n",
       "  0.17737656831741333,\n",
       "  0.08991581946611404,\n",
       "  0.050386421382427216,\n",
       "  0.08492536842823029,\n",
       "  0.02226073108613491,\n",
       "  0.15187585353851318,\n",
       "  0.25425484776496887,\n",
       "  0.1516270637512207,\n",
       "  0.25498148798942566,\n",
       "  0.08071248233318329,\n",
       "  0.3376242518424988,\n",
       "  0.20612840354442596,\n",
       "  0.16616696119308472,\n",
       "  0.06078578531742096,\n",
       "  0.21331435441970825,\n",
       "  0.2969856858253479,\n",
       "  0.3491329252719879,\n",
       "  0.320933997631073,\n",
       "  0.12067520618438721,\n",
       "  0.12423960119485855,\n",
       "  0.12179161608219147,\n",
       "  0.3578830063343048,\n",
       "  0.1480584740638733,\n",
       "  0.30198609828948975,\n",
       "  0.12339244037866592,\n",
       "  0.18461783230304718],\n",
       " 'mcerr': 0.17254941165447235}"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ucons_stats_train"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "09f0df61-ed39-4fe8-8463-87a363b11ef6",
   "metadata": {},
   "source": [
    "## E2E Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "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": 159,
   "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": 160,
   "id": "e11c51cf-7916-4324-83b5-d62666a03138",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=True, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "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": 161,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 162,
   "id": "1db18c6a-1e20-4739-b76a-6b3cb5bf4d73",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<bound method StefanPME_1D.get_mass_rhs_func of <class 'datasets.StefanPME_1D'>>"
      ]
     },
     "execution_count": 162,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 163,
   "id": "7d1e8d19-c876-4e02-a95c-36987cb27c62",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=-553.673114, Validation loss=-704.837988 (saved)\n",
      "Epoch 1: Train loss=-892.080212, Validation loss=-1253.081445 (saved)\n",
      "Epoch 2: Train loss=-1940.543896, Validation loss=-3191.406543 (saved)\n",
      "Epoch 3: Train loss=-5139.535254, Validation loss=-7776.919531 (saved)\n",
      "Epoch 4: Train loss=-8200.925391, Validation loss=-8715.223438 (saved)\n",
      "Epoch 5: Train loss=-9036.837793, Validation loss=-9849.037109 (saved)\n",
      "Epoch 6: Train loss=-7814.692480, Validation loss=-8841.151562 \n",
      "Epoch 7: Train loss=-8288.514648, Validation loss=-8397.002344 \n",
      "Epoch 8: Train loss=-8730.630859, Validation loss=-9565.806250 \n",
      "Epoch 9: Train loss=-10179.861523, Validation loss=-11134.184766 (saved)\n",
      "Epoch 10: Train loss=-7120.864258, Validation loss=-8839.439844 \n",
      "Epoch 11: Train loss=-8751.749902, Validation loss=-8389.085156 \n",
      "Epoch 12: Train loss=-8372.763770, Validation loss=-8470.647656 \n",
      "Epoch 13: Train loss=-8771.496680, Validation loss=-9222.410938 \n",
      "Epoch 14: Train loss=-9595.219141, Validation loss=-10137.092578 \n",
      "Epoch 15: Train loss=-10478.601270, Validation loss=-11018.879297 \n",
      "Epoch 16: Train loss=-11302.895508, Validation loss=-11890.137500 (saved)\n",
      "Epoch 17: Train loss=-12289.030957, Validation loss=-13027.864844 (saved)\n",
      "Epoch 18: Train loss=417.932959, Validation loss=-9298.662109 \n",
      "Epoch 19: Train loss=-7885.908789, Validation loss=-6810.381641 \n",
      "Epoch 20: Train loss=-6527.910645, Validation loss=-6287.032031 \n",
      "Epoch 21: Train loss=-6245.356348, Validation loss=-6245.426758 \n",
      "Epoch 22: Train loss=-6304.263037, Validation loss=-6403.513086 \n",
      "Epoch 23: Train loss=-6505.521533, Validation loss=-6649.312891 \n",
      "Epoch 24: Train loss=-6773.568652, Validation loss=-6940.879687 \n",
      "Epoch 25: Train loss=-7075.524707, Validation loss=-7254.146484 \n",
      "Epoch 26: Train loss=-7393.641406, Validation loss=-7580.239844 \n",
      "Epoch 27: Train loss=-7722.162500, Validation loss=-7913.264063 \n",
      "Epoch 28: Train loss=-8056.387891, Validation loss=-8250.031641 \n",
      "Epoch 29: Train loss=-8390.035645, Validation loss=-8586.792187 \n",
      "Epoch 30: Train loss=-8719.870020, Validation loss=-8917.560547 \n",
      "Epoch 31: Train loss=-9040.817969, Validation loss=-9234.292969 \n",
      "Epoch 32: Train loss=-9343.979590, Validation loss=-9539.269922 \n",
      "Epoch 33: Train loss=-9635.445605, Validation loss=-9837.179688 \n",
      "Epoch 34: Train loss=-9928.499902, Validation loss=-10141.553125 \n",
      "Epoch 35: Train loss=-10236.683008, Validation loss=-10474.850000 \n",
      "Epoch 36: Train loss=-10577.804492, Validation loss=-10851.485937 \n",
      "Epoch 37: Train loss=-10969.382520, Validation loss=-11277.691406 \n",
      "Epoch 38: Train loss=-11440.328906, Validation loss=-11751.222656 \n",
      "Epoch 39: Train loss=-11944.202539, Validation loss=-12295.351953 \n",
      "Epoch 40: Train loss=-12510.152344, Validation loss=-12603.623047 \n",
      "Epoch 41: Train loss=-13037.078516, Validation loss=-13231.917187 (saved)\n",
      "Epoch 42: Train loss=-12572.498047, Validation loss=-11849.015625 \n",
      "Epoch 43: Train loss=-13026.009766, Validation loss=-14009.897656 (saved)\n",
      "Epoch 44: Train loss=-13678.557129, Validation loss=-12982.656250 \n",
      "Epoch 45: Train loss=-13429.444922, Validation loss=-14104.264063 (saved)\n",
      "Epoch 46: Train loss=-11134.724707, Validation loss=-10645.830469 \n",
      "Epoch 47: Train loss=-12729.806543, Validation loss=-12834.949219 \n",
      "Epoch 48: Train loss=-13072.608594, Validation loss=-13399.573437 \n",
      "Epoch 49: Train loss=-13502.149805, Validation loss=-14001.397656 \n",
      "Epoch 50: Train loss=-14094.380469, Validation loss=-14154.632812 (saved)\n",
      "Epoch 51: Train loss=-14499.678906, Validation loss=-14882.165625 (saved)\n",
      "Epoch 52: Train loss=-15080.956836, Validation loss=-15464.181250 (saved)\n",
      "Epoch 53: Train loss=-15665.442383, Validation loss=-15933.355469 (saved)\n",
      "Epoch 54: Train loss=184.182813, Validation loss=-6439.242578 \n",
      "Epoch 55: Train loss=-6508.558301, Validation loss=-8386.337891 \n",
      "Epoch 56: Train loss=-10441.701563, Validation loss=-11051.376953 \n",
      "Epoch 57: Train loss=-10678.452930, Validation loss=-10575.756641 \n",
      "Epoch 58: Train loss=-10766.235449, Validation loss=-10917.157031 \n",
      "Epoch 59: Train loss=-10923.070605, Validation loss=-10991.512500 \n",
      "Epoch 60: Train loss=-11076.554492, Validation loss=-11210.896094 \n",
      "Epoch 61: Train loss=-11300.480273, Validation loss=-11434.386328 \n",
      "Epoch 62: Train loss=-11528.001367, Validation loss=-11679.070312 \n",
      "Epoch 63: Train loss=-11776.305273, Validation loss=-11928.870703 \n",
      "Epoch 64: Train loss=-12029.702539, Validation loss=-12189.867578 \n",
      "Epoch 65: Train loss=-12293.597461, Validation loss=-12460.434766 \n",
      "Epoch 66: Train loss=-12565.847363, Validation loss=-12738.775781 \n",
      "Epoch 67: Train loss=-12846.154883, Validation loss=-13026.572266 \n",
      "Epoch 68: Train loss=-13136.502539, Validation loss=-13324.066406 \n",
      "Epoch 69: Train loss=-13435.958008, Validation loss=-13631.405469 \n",
      "Epoch 70: Train loss=-13746.912695, Validation loss=-13949.012500 \n",
      "Epoch 71: Train loss=-14066.598242, Validation loss=-14277.132031 \n",
      "Epoch 72: Train loss=-14403.791016, Validation loss=-14589.109375 \n",
      "Epoch 73: Train loss=-14732.507031, Validation loss=-14964.449219 \n",
      "Epoch 74: Train loss=-15089.942969, Validation loss=-15340.234375 \n",
      "Epoch 75: Train loss=-15444.146484, Validation loss=-15706.200000 \n",
      "Epoch 76: Train loss=-15844.418359, Validation loss=-16131.539844 (saved)\n",
      "Epoch 77: Train loss=-16224.240430, Validation loss=-16375.383594 (saved)\n",
      "Epoch 78: Train loss=-16590.877930, Validation loss=-16932.135937 (saved)\n",
      "Epoch 79: Train loss=-8235.509717, Validation loss=-15868.771094 \n",
      "Epoch 80: Train loss=-12428.357178, Validation loss=-12672.186719 \n",
      "Epoch 81: Train loss=-13967.430957, Validation loss=-13702.696094 \n",
      "Epoch 82: Train loss=-14315.216406, Validation loss=-14384.840625 \n",
      "Epoch 83: Train loss=-14576.066602, Validation loss=-14820.145313 \n",
      "Epoch 84: Train loss=-14856.771094, Validation loss=-15092.512500 \n",
      "Epoch 85: Train loss=-15178.819141, Validation loss=-15410.449219 \n",
      "Epoch 86: Train loss=-15506.787109, Validation loss=-15793.570312 \n",
      "Epoch 87: Train loss=-15873.956250, Validation loss=-16186.303125 \n",
      "Epoch 88: Train loss=-16290.676172, Validation loss=-16574.404687 \n",
      "Epoch 89: Train loss=-16705.686133, Validation loss=-16974.277344 (saved)\n",
      "Epoch 90: Train loss=-17061.803906, Validation loss=-17401.662500 (saved)\n",
      "Epoch 91: Train loss=-17512.361719, Validation loss=-16553.373437 \n",
      "Epoch 92: Train loss=16695.645898, Validation loss=5521.911523 \n",
      "Epoch 93: Train loss=-7601.623193, Validation loss=-10078.038672 \n",
      "Epoch 94: Train loss=-10891.868750, Validation loss=-11337.475781 \n",
      "Epoch 95: Train loss=-11363.074609, Validation loss=-11235.317188 \n",
      "Epoch 96: Train loss=-11238.420996, Validation loss=-11400.576172 \n",
      "Epoch 97: Train loss=-11453.169922, Validation loss=-11502.441406 \n",
      "Epoch 98: Train loss=-11554.200977, Validation loss=-11650.672656 \n",
      "Epoch 99: Train loss=-11709.059961, Validation loss=-11806.448047 \n",
      "Epoch 100: Train loss=-11838.005078, Validation loss=-11893.835156 \n",
      "Epoch 101: Train loss=-11921.640723, Validation loss=-11977.584766 \n",
      "Epoch 102: Train loss=-12005.823633, Validation loss=-12063.958203 \n",
      "Epoch 103: Train loss=-12092.928906, Validation loss=-12151.353516 \n",
      "Epoch 104: Train loss=-12180.752734, Validation loss=-12239.942188 \n",
      "Epoch 105: Train loss=-12269.473633, Validation loss=-12329.764844 \n",
      "Epoch 106: Train loss=-12359.622461, Validation loss=-12420.814062 \n",
      "Epoch 107: Train loss=-12450.379688, Validation loss=-12513.163672 \n",
      "Epoch 108: Train loss=-12543.043164, Validation loss=-12606.465625 \n",
      "Epoch 109: Train loss=-12636.799609, Validation loss=-12701.493750 \n",
      "Epoch 110: Train loss=-12732.035254, Validation loss=-12797.696094 \n",
      "Epoch 111: Train loss=-12828.176758, Validation loss=-12895.054688 \n",
      "Epoch 112: Train loss=-12925.847754, Validation loss=-12994.021094 \n",
      "Epoch 113: Train loss=-13025.057812, Validation loss=-13094.168750 \n",
      "Epoch 114: Train loss=-13125.308984, Validation loss=-13195.986719 \n",
      "Epoch 115: Train loss=-13227.516406, Validation loss=-13299.210938 \n",
      "Epoch 116: Train loss=-13330.968750, Validation loss=-13404.189062 \n",
      "Epoch 117: Train loss=-13436.522461, Validation loss=-13510.812500 \n",
      "Epoch 118: Train loss=-13542.466016, Validation loss=-13619.050781 \n",
      "Epoch 119: Train loss=-13651.685156, Validation loss=-13728.859375 \n",
      "Epoch 120: Train loss=-13761.762109, Validation loss=-13840.638281 \n",
      "Epoch 121: Train loss=-13872.942773, Validation loss=-13953.205469 \n",
      "Epoch 122: Train loss=-13986.480664, Validation loss=-14069.605469 \n",
      "Epoch 123: Train loss=-14102.472461, Validation loss=-14186.835156 \n",
      "Epoch 124: Train loss=-14218.739844, Validation loss=-14305.922656 \n",
      "Epoch 125: Train loss=-14340.156250, Validation loss=-14426.731250 \n",
      "Epoch 126: Train loss=-14461.863867, Validation loss=-14551.041406 \n",
      "Epoch 127: Train loss=-14585.367969, Validation loss=-14677.111719 \n",
      "Epoch 128: Train loss=-14712.268164, Validation loss=-14803.810938 \n",
      "Epoch 129: Train loss=-14840.040234, Validation loss=-14934.963281 \n",
      "Epoch 130: Train loss=-14970.720508, Validation loss=-15067.604687 \n",
      "Epoch 131: Train loss=-15103.580273, Validation loss=-15202.954687 \n",
      "Epoch 132: Train loss=-15227.649219, Validation loss=-15320.805469 \n",
      "Epoch 133: Train loss=-15374.008594, Validation loss=-15473.191406 \n",
      "Epoch 134: Train loss=-15511.496289, Validation loss=-15608.160938 \n",
      "Epoch 135: Train loss=-15650.830664, Validation loss=-15763.215625 \n",
      "Epoch 136: Train loss=-15798.963672, Validation loss=-15904.103906 \n",
      "Epoch 137: Train loss=-15943.498047, Validation loss=-16057.820312 \n",
      "Epoch 138: Train loss=-16096.297266, Validation loss=-16210.649219 \n",
      "Epoch 139: Train loss=-16248.245117, Validation loss=-16364.404688 \n",
      "Epoch 140: Train loss=-16389.112305, Validation loss=-16508.932031 \n",
      "Epoch 141: Train loss=-16543.613086, Validation loss=-16680.745312 \n",
      "Epoch 142: Train loss=-16711.354687, Validation loss=-16839.305469 \n",
      "Epoch 143: Train loss=-16872.090820, Validation loss=-16999.551563 \n",
      "Epoch 144: Train loss=-17021.232422, Validation loss=-17161.510156 \n",
      "Epoch 145: Train loss=-17152.983398, Validation loss=-17250.862500 \n",
      "Epoch 146: Train loss=-17224.012500, Validation loss=-17443.514844 (saved)\n",
      "Epoch 147: Train loss=-17466.833008, Validation loss=-17570.352344 (saved)\n",
      "Epoch 148: Train loss=-17632.883398, Validation loss=-17710.975000 (saved)\n",
      "Epoch 149: Train loss=-17742.151367, Validation loss=-17622.712500 \n",
      "Epoch 150: Train loss=-17813.028516, Validation loss=-17897.764062 (saved)\n",
      "Epoch 151: Train loss=-17945.306836, Validation loss=-17989.172656 (saved)\n",
      "Epoch 152: Train loss=-18002.374219, Validation loss=-18027.018750 (saved)\n",
      "Epoch 153: Train loss=-18126.290625, Validation loss=-18261.260937 (saved)\n",
      "Epoch 154: Train loss=-18248.103906, Validation loss=-18354.261719 (saved)\n",
      "Epoch 155: Train loss=-18341.406641, Validation loss=-18462.640625 (saved)\n",
      "Epoch 156: Train loss=-18438.297852, Validation loss=-18540.125781 (saved)\n",
      "Epoch 157: Train loss=-18519.907422, Validation loss=-18626.432812 (saved)\n",
      "Epoch 158: Train loss=-18541.074414, Validation loss=-18640.043750 (saved)\n",
      "Epoch 159: Train loss=-18672.180664, Validation loss=-18783.114063 (saved)\n",
      "Epoch 160: Train loss=-18710.376758, Validation loss=-18874.560937 (saved)\n",
      "Epoch 161: Train loss=-18537.694727, Validation loss=-18775.607812 \n",
      "Epoch 162: Train loss=-18697.116797, Validation loss=-18882.926563 (saved)\n",
      "Epoch 163: Train loss=-18859.721094, Validation loss=-19060.592969 (saved)\n",
      "Epoch 164: Train loss=-19057.765234, Validation loss=-19121.126563 (saved)\n",
      "Epoch 165: Train loss=-19101.617578, Validation loss=-19222.310937 (saved)\n",
      "Epoch 166: Train loss=-19133.934570, Validation loss=-19200.825000 \n",
      "Epoch 167: Train loss=-19244.707227, Validation loss=-19058.911719 \n",
      "Epoch 168: Train loss=-18651.218359, Validation loss=-18670.110938 \n",
      "Epoch 169: Train loss=-18393.104883, Validation loss=-18592.142969 \n",
      "Epoch 170: Train loss=-17861.835742, Validation loss=-18903.599219 \n",
      "Epoch 171: Train loss=-18516.725195, Validation loss=-19443.525000 (saved)\n",
      "Epoch 172: Train loss=-18956.919531, Validation loss=-19502.387500 (saved)\n",
      "Epoch 173: Train loss=-19188.926172, Validation loss=-19566.300781 (saved)\n",
      "Epoch 174: Train loss=-19247.738281, Validation loss=-19241.539062 \n",
      "Epoch 175: Train loss=-19335.743555, Validation loss=-19233.140625 \n",
      "Epoch 176: Train loss=-19456.838086, Validation loss=-19390.873437 \n",
      "Epoch 177: Train loss=-18797.471289, Validation loss=-19621.265625 (saved)\n",
      "Epoch 178: Train loss=-19584.541602, Validation loss=-19773.561719 (saved)\n",
      "Epoch 179: Train loss=-19327.692383, Validation loss=-19223.587500 \n",
      "Epoch 180: Train loss=-19204.341602, Validation loss=-19431.185937 \n",
      "Epoch 181: Train loss=-19247.128320, Validation loss=-19793.160938 (saved)\n",
      "Epoch 182: Train loss=-19228.096094, Validation loss=-19595.146875 \n",
      "Epoch 183: Train loss=-19511.005664, Validation loss=-19903.378125 (saved)\n",
      "Epoch 184: Train loss=-18276.371680, Validation loss=-19420.790625 \n",
      "Epoch 185: Train loss=-19104.682422, Validation loss=-19198.100000 \n",
      "Epoch 186: Train loss=-18151.153906, Validation loss=-18848.636719 \n",
      "Epoch 187: Train loss=-19036.603320, Validation loss=-19619.865625 \n",
      "Epoch 188: Train loss=-19117.211719, Validation loss=-18662.133594 \n",
      "Epoch 189: Train loss=-19166.233594, Validation loss=-19308.852344 \n",
      "Epoch 190: Train loss=-19245.226953, Validation loss=-19772.692188 \n",
      "Epoch 191: Train loss=-19735.463086, Validation loss=-19993.715625 (saved)\n",
      "Epoch 192: Train loss=-19579.444336, Validation loss=-19824.833594 \n",
      "Epoch 193: Train loss=-19573.277930, Validation loss=-19270.660938 \n",
      "Epoch 194: Train loss=-19680.747656, Validation loss=-19756.612500 \n",
      "Epoch 195: Train loss=-19383.042773, Validation loss=-19514.639062 \n",
      "Epoch 196: Train loss=-19943.132227, Validation loss=-20132.355469 (saved)\n",
      "Epoch 197: Train loss=-19480.575586, Validation loss=-19188.378125 \n",
      "Epoch 198: Train loss=-19682.169141, Validation loss=-18572.898438 \n",
      "Epoch 199: Train loss=-18758.068945, Validation loss=-18414.291406 \n",
      "Finished training with best train loss: -20068.062891 and validation loss: -20132.355469\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": 164,
   "id": "4f58dc93-0b91-4195-b51e-126ad1212b6f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here\n",
      "Here\n",
      "Here\n",
      "Here\n",
      "In-domain results\n",
      "MSE: 0.001939259022474289\n",
      "n-MeRCI: 0.6295455098152161\n",
      "RMSCE: 0.1764184832572937\n",
      "ProbConserv Results\n",
      "MSE: 0.001939258873462677\n",
      "n-MeRCI: 0.6289241909980774\n",
      "RMSCE: 0.17645494639873505\n",
      "Cerr: 3.782287194553646e-07\n",
      "Prob_Cerr: 3.695231782785413e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 0.022645184695720674\n",
      "n-MeRCI: 0.87217116355896\n",
      "RMSCE: 0.41860586404800415\n",
      "ProbConserv Results\n",
      "MSE: 0.022645184993743895\n",
      "n-MeRCI: 0.8712818026542664\n",
      "RMSCE: 0.4189075827598572\n",
      "Cerr: 4.980084327144141e-07\n",
      "Prob_Cerr: 4.7009439185785595e-07\n"
     ]
    }
   ],
   "source": [
    "is_probconserv = True\n",
    "\n",
    "train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "if is_train:\n",
    "    train_loader_no_shuffle = torch.utils.data.DataLoader(train_loader.dataset, batch_size=batch_size, shuffle=False)\n",
    "    train_results = test(model, train_loader_no_shuffle, test_type=\"train\")\n",
    "    id_results = test(model, id_test_loader, test_type=\"id\")\n",
    "\n",
    "    print(\"In-domain results\")\n",
    "    print(f\"MSE: {id_results['mse']}\")\n",
    "    print(f\"n-MeRCI: {id_results['nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {id_results['rmsce_all']}\")\n",
    "\n",
    "    if is_probconserv:\n",
    "        print(\"ProbConserv Results\")\n",
    "        print(f\"MSE: {id_results['pc.mse']}\")\n",
    "        print(f\"n-MeRCI: {id_results['pc.nMeRCI_all']}\")\n",
    "        print(f\"RMSCE: {id_results['pc.rmsce_all']}\")\n",
    "        print(f\"Cerr: {id_results['mcerr']}\")\n",
    "        print(f\"Prob_Cerr: {id_results['pc.mcerr']}\")\n",
    "        \n",
    "\n",
    "ood_results = test(model, ood_test_loader, test_type=\"ood\")\n",
    "\n",
    "print(\"\\n\")\n",
    "print(\"Out-of-domain results\")\n",
    "print(f\"MSE: {ood_results['mse']}\")\n",
    "print(f\"n-MeRCI: {ood_results['nMeRCI_all']}\")\n",
    "print(f\"RMSCE: {ood_results['rmsce_all']}\")\n",
    "\n",
    "if is_probconserv:\n",
    "    print(\"ProbConserv Results\")\n",
    "    print(f\"MSE: {ood_results['pc.mse']}\")\n",
    "    print(f\"n-MeRCI: {ood_results['pc.nMeRCI_all']}\")\n",
    "    print(f\"RMSCE: {ood_results['pc.rmsce_all']}\")\n",
    "    print(f\"Cerr: {ood_results['mcerr']}\")\n",
    "    print(f\"Prob_Cerr: {ood_results['pc.mcerr']}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 165,
   "id": "d3c74561-cafe-4068-b5ec-92d2c4634cc9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.001939258873462677"
      ]
     },
     "execution_count": 165,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 166,
   "id": "c29252c6-3147-4b6a-b320-ee566b03e910",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 166,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.probconserv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "d3c1bdb4-7418-4ecf-9309-5639193fa8d6",
   "metadata": {},
   "outputs": [],
   "source": [
    "out = model(x_train.to(device))\n",
    "x = train_loader.dataset.tensors[0]\n",
    "y = train_loader.dataset.tensors[1]\n",
    "mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "if model.probconserv:\n",
    "    _mu, _var, = out[0].cpu(), out[1].cpu()\n",
    "    _std = torch.sqrt(_var)\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x)\n",
    "    new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "                                                    mu=_mu[:, :, :, 0], \n",
    "                                                    std=_std[:, :, :, 0], \n",
    "                                                    mass_rhs_func=mass_rhs_func, \n",
    "                                                    t=t, \n",
    "                                                    tpred=tpred, \n",
    "                                                    grid_train=grid, \n",
    "                                                    precis_g=np.inf,\n",
    "                                                    second_deriv_alpha=None,\n",
    "                                                    )\n",
    "    out = (new_mu.unsqueeze(-1), torch.square(new_std).unsqueeze(-1))\n",
    "\n",
    "mu, var, = out[0].cpu(), out[1].cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "6d7837ba-f720-43d2-b8d0-8252c41e8ad3",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "cb722479-afdf-4b05-a156-c8a2bbbf245a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHHCAYAAABTMjf2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB6m0lEQVR4nO3deZxN9f8H8Nc5d5t9MzvD2LKLiCxFUVMkKpGUJZGiQhSVtUKbREop0uKLhPpFFFFEdsq+zSDMjDFmn7t/fn/cuXfmztyZuTNm5s6d+3o+HvNgzj3n3Pc9c5f3/Xzen89HEkIIEBEREXkg2dUBEBEREbkKEyEiIiLyWEyEiIiIyGMxESIiIiKPxUSIiIiIPBYTISIiIvJYTISIiIjIYzERIiIiIo/FRIiIiIg8FhMhqlFiY2MxbNgwV4dBVeCrr76CJElISEio8vs2Go145ZVXEBMTA1mW0a9fvyqPgYgqBhMhKsL6AbN//35Xh+JWJEnC2LFjHd5WFdf0ypUrmDFjBg4fPuzU/taYivv5+++/Ky3Wspg9ezbWr1/v6jDsLF26FO+99x769++P5cuXY/z48a4OqUZbsWIF5s+f7+owbsrly5cxYMAABAUFISAgAH379sX58+edPl6v12P27Nlo2rQpvLy8EBERgd69e+O///6z7bNv3z6MHTsWLVq0gK+vL+rWrYsBAwbg9OnTlfGQagylqwMgqkinTp2CLHtmfn/lyhXMnDkTsbGxaNOmjdPHzZo1C/Xr1y+yvVGjRhUYXfnNnj0b/fv3L9Lq8tRTT+Hxxx+HRqOp8ph+//131K5dGx9++GGV37cnWrFiBY4ePYpx48a5OpRyycrKwt1334309HS89tprUKlU+PDDD9GtWzccPnwYtWrVKvF4g8GA3r17Y9euXRg5ciRat26NGzduYM+ePUhPT0edOnUAAO+88w7++usvPPbYY2jdujUSExPx8ccf47bbbsPff/+Nli1bVsXDdTtMhKjaMhqNMJvNUKvVTh/jig9Fd/fAAw+gffv2rg6jzBQKBRQKhUvuOzk5GUFBQRV2PrPZDL1eDy8vrwo7Z1lptVqo1WqP+SJRldf8k08+wZkzZ7B3717cfvvtACyvu5YtW+KDDz7A7NmzSzz+ww8/xB9//IGdO3eiQ4cOxe43YcIErFixwu49c+DAgWjVqhXmzp2Lb7/9tmIeUA3jGc94qhSXL1/G008/jYiICGg0GrRo0QJLly6120ev12PatGlo164dAgMD4evrizvvvBPbtm2z2y8hIQGSJOH999/H/Pnz0bBhQ2g0Ghw/fhwzZsyAJEk4e/Yshg0bhqCgIAQGBmL48OHIycmxO0/hGiFr989ff/2FCRMmICwsDL6+vnj44Ydx7do1u2PNZjNmzJiB6Oho+Pj44O6778bx48crte7o5MmT6N+/P0JCQuDl5YX27dvjp59+stsnNTUVEydORKtWreDn54eAgAA88MADOHLkiG2f7du3295ghw8fbuve+uqrryokzrS0NAwbNgyBgYEICgrC0KFDcfjw4SL30b17d3Tv3r3I8cOGDUNsbKzdtvfffx+dO3dGrVq14O3tjXbt2mHNmjV2+0iShOzsbCxfvtz2mKx/i+JqhD755BO0aNECGo0G0dHRGDNmDNLS0uz26d69O1q2bInjx4/j7rvvho+PD2rXro133323xOtgfZ5u27YNx44ds8W0fft2AEB2djZefvllxMTEQKPRoEmTJnj//fchhCjyuMaOHYvvvvvOFuumTZuKvd/Y2Fg8+OCD+PXXX9GmTRt4eXmhefPmWLt2rd1+zjxXAMvzRZIkrFy5Em+88QZq164NHx8fZGRklPkcq1evxsyZM1G7dm34+/ujf//+SE9Ph06nw7hx4xAeHg4/Pz8MHz4cOp2uyGP79ttv0a5dO3h7eyMkJASPP/44Ll26ZPe32rBhAy5cuGC73gWfSzqdDtOnT0ejRo2g0WgQExODV155pch9lfWaV6Q1a9bg9ttvt71GAaBp06bo0aMHVq9eXeKxZrMZH330ER5++GF06NABRqOxyPueVefOnYt8cWzcuDFatGiBEydO3PwDqaHYIkTlkpSUhDvuuMP25hIWFoZffvkFI0aMQEZGhq0JOyMjA1988QUGDRqEkSNHIjMzE19++SXi4uKwd+/eIl04y5Ytg1arxahRo6DRaBASEmK7bcCAAahfvz7mzJmDgwcP4osvvkB4eDjeeeedUuN94YUXEBwcjOnTpyMhIQHz58/H2LFjsWrVKts+U6ZMwbvvvos+ffogLi4OR44cQVxcHLRardPXRavVIiUlpcj2rKysItuOHTuGLl26oHbt2pg8eTJ8fX2xevVq9OvXDz/88AMefvhhAMD58+exfv16PPbYY6hfvz6SkpLw2WefoVu3bjh+/Diio6PRrFkzzJo1C9OmTcOoUaNw5513ArC8MZYmPT29SMySJNma64UQ6Nu3L3bu3InRo0ejWbNmWLduHYYOHer0dXHko48+wkMPPYTBgwdDr9dj5cqVeOyxx/Dzzz+jd+/eAIBvvvkGzzzzDDp06IBRo0YBABo2bFjsOWfMmIGZM2eiZ8+eeO6553Dq1Cl8+umn2LdvH/766y+oVCrbvjdu3MD999+PRx55BAMGDMCaNWvw6quvolWrVnjggQccnj8sLAzffPMN3n77bWRlZWHOnDkAgGbNmkEIgYceegjbtm3DiBEj0KZNG2zevBmTJk3C5cuXi3Sj/f7771i9ejXGjh2L0NDQIoliYWfOnMHAgQMxevRoDB06FMuWLcNjjz2GTZs24d577wXg3HOloDfffBNqtRoTJ06ETqeDWq3G8ePHy3SOOXPmwNvbG5MnT8bZs2excOFCqFQqyLKMGzduYMaMGfj777/x1VdfoX79+pg2bZrt2LfffhtTp07FgAED8Mwzz+DatWtYuHAh7rrrLhw6dAhBQUF4/fXXkZ6ejv/++892Df38/ABYkoSHHnoIO3fuxKhRo9CsWTP8+++/+PDDD3H69OkitWVlueZZWVlOvfZVKhUCAwOLvd1sNuOff/7B008/XeS2Dh064Ndff0VmZib8/f0dHn/8+HFcuXIFrVu3xqhRo7B8+XLo9Xq0atUKH330Ee6+++4S4xNCICkpCS1atCj1sXgsQVTIsmXLBACxb9++YvcZMWKEiIqKEikpKXbbH3/8cREYGChycnKEEEIYjUah0+ns9rlx44aIiIgQTz/9tG1bfHy8ACACAgJEcnKy3f7Tp08XAOz2F0KIhx9+WNSqVctuW7169cTQoUOLPJaePXsKs9ls2z5+/HihUChEWlqaEEKIxMREoVQqRb9+/ezON2PGDAHA7pzFAVDqT8Fr2qNHD9GqVSuh1Wpt28xms+jcubNo3LixbZtWqxUmk8nuvuLj44VGoxGzZs2ybdu3b58AIJYtW1ZqrAWvjaMfjUZj22/9+vUCgHj33Xdt24xGo7jzzjuL3F+3bt1Et27ditzX0KFDRb169ey2WZ8jVnq9XrRs2VLcc889dtt9fX0dXn9r/PHx8UIIIZKTk4VarRb33Xef3fX6+OOPBQCxdOlSuzgBiK+//tq2TafTicjISPHoo48Wua/CunXrJlq0aGG3zXqd3nrrLbvt/fv3F5IkibNnz9q2ARCyLItjx46Vel9CWJ7XAMQPP/xg25aeni6ioqJE27Ztbducfa5s27ZNABANGjQo8nco6zlatmwp9Hq9bfugQYOEJEnigQcesDtHp06d7J4DCQkJQqFQiLfffttuv3///VcolUq77b179y7y/BFCiG+++UbIsix27Nhht33x4sUCgPjrr79s28p6zYcOHerUa9rR872ga9euCQB2185q0aJFAoA4efJkscevXbtWABC1atUSjRs3FsuWLRPLli0TjRs3Fmq1Whw5cqTE+//mm28EAPHll1869bg9EbvGqMyEEPjhhx/Qp08fCCGQkpJi+4mLi0N6ejoOHjwIwFLHYW2qNZvNSE1NhdFoRPv27W37FPToo48iLCzM4f2OHj3a7vc777wT169fR0ZGRqkxjxo1CpIk2R1rMplw4cIFAMDWrVthNBrx/PPP2x33wgsvlHrugvr27YvffvutyM+kSZPs9ktNTcXvv/+OAQMGIDMz03b9rl+/jri4OJw5cwaXL18GYKl7stZtmEwmXL9+HX5+fmjSpInDa1hWixYtKhLvL7/8Yrt948aNUCqVeO6552zbFApFma9NYd7e3rb/37hxA+np6bjzzjvL/Zi2bNkCvV6PcePG2dW5jBw5EgEBAdiwYYPd/n5+fnjyySdtv6vVanTo0KFMI3kK2rhxIxQKBV588UW77S+//DKEEHbXFAC6deuG5s2bO33+6OhoWyshAAQEBGDIkCE4dOgQEhMTAZT9uTJ06FC7v0N5zjFkyBC7lraOHTtCCFGkBaRjx464dOkSjEYjAGDt2rUwm80YMGCA3XtIZGQkGjduXKT73JHvv/8ezZo1Q9OmTe3Occ899wBAkXOU5Zq/8sorDl/LhX8++OCDEs+Tm5sLwHH9orU+ybqPI9bW5MzMTGzduhXDhg3DsGHDsGXLFgghSuzOPXnyJMaMGYNOnTrddAtuTcauMSqza9euIS0tDZ9//jk+//xzh/skJyfb/r98+XJ88MEHOHnyJAwGg227o5FKjrZZ1a1b1+734OBgAJYP0YCAgBJjLulYALaEqPBIqZCQENu+zqhTpw569uxZZHvBIa4AcPbsWQghMHXqVEydOtXhuZKTk1G7dm1bjcAnn3yC+Ph4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9Ho94uPjYTabXR0KEblYUFAQIiMjb2qePyZCROQ2hBC4evUqFAoFYmJiSpwkjYhqLiEEcnJykJycDACIiooq97mYCBGR2zAajcjJyUF0dDR8fHxcHQ4RuZC3tzcAIDk5GeHh4eXuJuPXKSJyGyaTCQCgVqtdHAkRVQfWL0QGg6Hc52AiRERuh+v+ERFQMe8FTISIiIjIYzERIiIiIo/FRIiIiIg8FhMhIqIaqHv37hg3blyR/7syDnfgLvFev34d4eHhSEhIcHUolebxxx/HBx98UOn3w0SIiKiGW7t2Ld58802n93eXZKC6+/TTT9G6dWsEBAQgICAAnTp1wi+//FIh53777bfRt29fxMbGVsj5SjJs2DBIklTk5+zZs3a3z5071+649evXOyxmvnTpEp5++mlER0dDrVajXr16eOmll3D9+nW7/d544w28/fbbSE9Pr7wHByZCLpWSpYMQwtVhEFE1VJFLiISEhMDf37/Czkf5unfvjq+++srhbXXq1MHcuXNx4MAB7N+/H/fccw/69u2LY8eO3dR95uTk4Msvv8SIESNu6jzOsD4P77//fly9etXup379+rb9vLy88M477+DGjRslnu/8+fNo3749zpw5g//97384e/YsFi9ejK1bt6JTp05ITU217duyZUs0bNgQ3377beU8uDxMhFwoW2dEYobW1WEQURXo3r07xo4di7FjxyIwMBChoaGYOnWq7cuQ9fZx48YhNDQUcXFxACzrqs2ZMwf169eHt7c3br31VqxZs8bu3NnZ2RgyZAj8/PwQFRVVpDuhcAuP2WzGu+++i0aNGkGj0aBu3bp4++23AVi+3f/xxx/46KOPbN/8ExISKiQOR3bu3AmVSgWtNv+9MCEhAZIk4cKFCw6P2bRpE7p27YqgoCDUqlULDz74IM6dO1fkMb/44ot45ZVXEBISgsjISMyYMeOm4y2LPn36oFevXmjcuDFuueUWvP322/Dz88Pff/9tt9/ff/+NHj16oFatWkVaXTIyMoqcd+PGjdBoNLjjjjts2z7//HNER0cXWXqmb9++ePrppwE4f90cPQ81Gg0iIyPtfgpOYNizZ09ERkZizpw5JV6TMWPGQK1W49dff0W3bt1Qt25dPPDAA9iyZQsuX76M119/vcg1XLlyZYnnvFlulQj9+eef6NOnD6KjoyFJEtavX1/qMdu3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fTcOHz6MmJiYqgzfbZTnOd2lSxecPXvWlmgCwOnTpxEVFcUkqBjluc45OTlFkh1r8im4ZGeFcclnYaWVYXu4lStXCo1GI7766itx/PhxMWrUKBEUFCQSExOFEEI89dRTYvLkybb9//rrL6FUKsX7778vTpw4IaZPn87h804o63WeO3euUKvVYs2aNeLq1au2n8zMTFc9BLdR1mtdGEeNOaes1/nixYvC399fjB07Vpw6dUr8/PPPIjw8XLz11luueghuoazXefr06cLf31/873//E+fPnxe//vqraNiwoRgwYICrHoJbyMzMFIcOHRKHDh0SAMS8efPEoUOHxIULF4QQQkyePFk89dRTtv2tw+cnTZokTpw4IRYtWsTh8+5s4cKFom7dukKtVosOHTqIv//+23Zbt27dxNChQ+32X716tbjllluEWq0WLVq0EBs2bKjiiN1TWa5zvXr1BIAiP9OnT6/6wN1QWZ/TBTERcl5Zr/OuXbtEx44dhUajEQ0aNBBvv/22MBqNVRy1+ynLdTYYDGLGjBmiYcOGwsvLS8TExIjnn39e3Lhxo+oDdyPbtm1z+J5rvbZDhw4V3bp1K3JMmzZthFqtFg0aNBDLli2r1BglIdimR0RERJ6JNUJERETksZgIERERkcdiIkREREQei4kQEREReSwmQkREROSxmAgRERGRx2IiRERERB6LiRARERF5LCZCRERE5LGYCBEREZHHYiJERB7l2rVriIyMxOzZs23bdu3aBbVaXWTVayKq+bjWGBF5nI0bN6Jfv37YtWsXmjRpgjZt2qBv376YN2+eq0MjoirGRIiIPNKYMWOwZcsWtG/fHv/++y/27dsHjUbj6rCIqIoxESIij5Sbm4uWLVvi0qVLOHDgAFq1auXqkIjIBVgjREQe6dy5c7hy5QrMZjMSEhJcHQ4RuQhbhIjI4+j1enTo0AFt2rRBkyZNMH/+fPz7778IDw93dWhEVMWYCBGRx5k0aRLWrFmDI0eOwM/PD926dUNgYCB+/vlnV4dGRFWMXWNE5FG2b9+O+fPn45tvvkFAQABkWcY333yDHTt24NNPP3V1eERUxdgiRERERB6LLUJERETksZgIERERkcdiIkREREQei4kQEREReSwmQkREROSxmAgRERGRx2IiRERERB6LiRARERF5LCZCRERE5LGYCBEREZHHYiJEREREHouJEBEREXms/wfNLJtq4XHW+AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_train[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_train[parameter_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 170,
   "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": 171,
   "id": "4e1d8ff4-50fc-4cdc-b824-ea2e4d850060",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.2566)\n"
     ]
    },
    {
     "data": {
      "image/png": "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8fHxwsvLS0yaNEmcPn1a/PDDDyI4OFi8/vrrjjoFp1Da6xwdHS28vLzEF198Ic6fPy9+/vln0aBBA/HYY4856hScQnp6uvj777/F33//LQCId955R/z999/i4sWLQgghpk+fLp588klrecvw+alTp4qTJ0+KZcuWcfi8M1u6dKmoU6eOUKlUokOHDuKPP/6wPta9e3cxcuRIm/JffvmlaNy4sVCpVKJ58+Ziy5YtVRyxcyrNda5bt64AUOAWHR1d9YE7odK+p/NjIlRypb3O+/btEx07dhRqtVrUr19fvPHGG8JgMFRx1M6nNNdZr9eLOXPmiAYNGgiNRiMiIiLEhAkTxM2bN6s+cCeya9cuu5+5lms7cuRI0b179wL7tG7dWqhUKlG/fn3xySefVGqMkhCs0yMiIiLXxD5CRERE5LKYCBEREZHLYiJERERELouJEBEREbksJkJERETkspgIERERkctiIkREREQui4kQERERuSwmQkREROSymAgRERGRy2IiREQuJSkpCaGhoZg/f7512759+6BSqQqsek1ENR/XGiMil7N161YMGjQI+/btQ5MmTdC6dWsMHDgQ77zzjqNDI6IqxkSIiFzSxIkT8csvv6Bdu3Y4duwY/vrrL6jVakeHRURVjIkQEbmk7OxstGjRApcuXcKhQ4fQsmVLR4dERA7APkJE5JLOnTuHq1evwmQy4cKFC44Oh4gchDVCRORydDodOnTogNatW6NJkyZYvHgxjh07huDgYEeHRkRVjIkQEbmcqVOnYtOmTTh69Cg8PT3RvXt3+Pj44IcffnB0aERUxdg0RkQuZffu3Vi8eDE+++wzeHt7QyaT4bPPPsOePXuwfPlyR4dHRFWMNUJERETkslgjRERERC6LiRARERG5LCZCRERE5LKYCBEREZHLYiJERERELouJEBEREbksJkJERETkspgIERERkctiIkREREQui4kQERERuSwmQkREROSymAgRERGRy/o/YyceoRlhdoIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_train[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_train[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 172,
   "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": 173,
   "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": 174,
   "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": 175,
   "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": 176,
   "id": "3639a00a-4839-4317-98f9-549ba4ab4656",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 177,
   "id": "d1eddcf4-0349-4c22-819c-d8bf5fd81cdf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_ood_test[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_ood_test[parameter_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "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": 179,
   "id": "dd8c116a-f7e0-4af0-a6d3-b506dee7945b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.5691)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# t_idx = len(t[slice(*tpred)])//2\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_ood_test[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx,0]+3*new_std[parameters_idx,:,t_idx,0], new_mu[parameters_idx,:,t_idx,0]-3*new_std[parameters_idx,:,t_idx,0], alpha=0.2)\n",
    "        plt.plot(grid, y_ood_test[parameters_idx,:,t_idx,0], color = \"green\", label = \"true\")\n",
    "        print(torch.norm(y_ood_test[parameters_idx,:,t_idx,0] - new_mu[parameters_idx,:,t_idx,0]))\n",
    "        plt.legend()\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 180,
   "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": 181,
   "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": 182,
   "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": 183,
   "id": "c8f87a91-2bad-44c5-9633-1f6a03f77d68",
   "metadata": {},
   "outputs": [],
   "source": [
    "from decimal import Decimal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 184,
   "id": "82377954-2227-47c4-bbc3-7c1c95682b6c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'0.17'"
      ]
     },
     "execution_count": 184,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    " f\"{ucons_stats_train['mcerr']:.2}\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 185,
   "id": "bd09fb69-7adb-4f8f-811a-45a934dc46d0",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'mse_by_example': [0.03511780500411987,\n",
       "  0.01945120096206665,\n",
       "  0.03601384535431862,\n",
       "  0.018625639379024506,\n",
       "  0.01923018880188465,\n",
       "  0.04238699749112129,\n",
       "  0.019626857712864876,\n",
       "  0.014134841039776802,\n",
       "  0.015071142464876175,\n",
       "  0.026377379894256592,\n",
       "  0.04428936913609505,\n",
       "  0.027003994211554527,\n",
       "  0.01653563790023327,\n",
       "  0.0322338342666626,\n",
       "  0.015585673041641712,\n",
       "  0.01049876306205988,\n",
       "  0.03606843575835228,\n",
       "  0.023274878039956093,\n",
       "  0.014269771985709667,\n",
       "  0.021782880648970604,\n",
       "  0.021547360345721245,\n",
       "  0.0208024550229311,\n",
       "  0.04337015002965927,\n",
       "  0.021779801696538925,\n",
       "  0.01011451706290245,\n",
       "  0.006622889544814825,\n",
       "  0.01202636118978262,\n",
       "  0.020676448941230774,\n",
       "  0.013533366844058037,\n",
       "  0.035197630524635315,\n",
       "  0.04449484497308731,\n",
       "  0.04566739872097969,\n",
       "  0.0057966201566159725,\n",
       "  0.011100305244326591,\n",
       "  0.041255880147218704,\n",
       "  0.01545565202832222,\n",
       "  0.008719077333807945,\n",
       "  0.005787841975688934,\n",
       "  0.00759565643966198,\n",
       "  0.008580540306866169,\n",
       "  0.028607113286852837,\n",
       "  0.0318174846470356,\n",
       "  0.008091473020613194,\n",
       "  0.012448200955986977,\n",
       "  0.03858227655291557,\n",
       "  0.00663452222943306,\n",
       "  0.013368169777095318,\n",
       "  0.012761671096086502,\n",
       "  0.039412613958120346,\n",
       "  0.017585936933755875,\n",
       "  0.031810346990823746,\n",
       "  0.008534863591194153,\n",
       "  0.02775838039815426,\n",
       "  0.015477067790925503,\n",
       "  0.019478103145956993,\n",
       "  0.014139845967292786,\n",
       "  0.03161110728979111,\n",
       "  0.013323542661964893,\n",
       "  0.041414108127355576,\n",
       "  0.018683720380067825,\n",
       "  0.04078635945916176,\n",
       "  0.0495886392891407,\n",
       "  0.043905291706323624,\n",
       "  0.008479474112391472,\n",
       "  0.01280042715370655,\n",
       "  0.006425652652978897,\n",
       "  0.00840127281844616,\n",
       "  0.0468938834965229,\n",
       "  0.04106414318084717,\n",
       "  0.02712833508849144,\n",
       "  0.03989593684673309,\n",
       "  0.010099547915160656,\n",
       "  0.042689431458711624,\n",
       "  0.03522597998380661,\n",
       "  0.04908929392695427,\n",
       "  0.037719544023275375,\n",
       "  0.008082331158220768,\n",
       "  0.008286011405289173,\n",
       "  0.009594744071364403,\n",
       "  0.00859884824603796,\n",
       "  0.0071491277776658535,\n",
       "  0.029396401718258858,\n",
       "  0.013984216377139091,\n",
       "  0.007139367517083883,\n",
       "  0.016726575791835785,\n",
       "  0.005787550937384367,\n",
       "  0.013015327975153923,\n",
       "  0.011385773308575153,\n",
       "  0.031799789518117905,\n",
       "  0.013401996344327927,\n",
       "  0.020940812304615974,\n",
       "  0.028933901339769363,\n",
       "  0.03763621300458908,\n",
       "  0.03758271038532257,\n",
       "  0.04299270734190941,\n",
       "  0.010455522686243057,\n",
       "  0.009631862863898277,\n",
       "  0.026019157841801643,\n",
       "  0.03794629126787186,\n",
       "  0.008593440987169743],\n",
       " 'mse': 0.022645184993743895,\n",
       " 'nll_by_example': [323206.34375,\n",
       "  40301.83203125,\n",
       "  331612.21875,\n",
       "  38930.734375,\n",
       "  40300.19921875,\n",
       "  459988.5625,\n",
       "  40303.3671875,\n",
       "  7577.138671875,\n",
       "  13849.419921875,\n",
       "  168626.34375,\n",
       "  469860.4375,\n",
       "  172627.515625,\n",
       "  28227.5546875,\n",
       "  286184.375,\n",
       "  19048.296875,\n",
       "  -2721.177001953125,\n",
       "  331563.625,\n",
       "  109473.140625,\n",
       "  7598.8125,\n",
       "  84526.46875,\n",
       "  78564.671875,\n",
       "  69124.9375,\n",
       "  458853.125,\n",
       "  84527.015625,\n",
       "  -3488.54736328125,\n",
       "  -6698.060546875,\n",
       "  1898.8731689453125,\n",
       "  69140.953125,\n",
       "  4806.4931640625,\n",
       "  323136.09375,\n",
       "  469623.53125,\n",
       "  503582.5625,\n",
       "  -7038.0380859375,\n",
       "  -583.7158813476562,\n",
       "  461330.0625,\n",
       "  19035.861328125,\n",
       "  -5071.98828125,\n",
       "  -7041.40673828125,\n",
       "  -5815.98779296875,\n",
       "  -5110.17626953125,\n",
       "  187045.265625,\n",
       "  260565.8125,\n",
       "  -5478.5029296875,\n",
       "  3119.759765625,\n",
       "  392606.4375,\n",
       "  -6694.23046875,\n",
       "  4776.91552734375,\n",
       "  4666.9228515625,\n",
       "  415582.25,\n",
       "  33296.7578125,\n",
       "  260571.015625,\n",
       "  -5122.9248046875,\n",
       "  187489.796875,\n",
       "  19037.875,\n",
       "  40302.015625,\n",
       "  7577.9453125,\n",
       "  260716.703125,\n",
       "  4768.91455078125,\n",
       "  461140.0,\n",
       "  38931.18359375,\n",
       "  447620.3125,\n",
       "  566677.3125,\n",
       "  470305.96875,\n",
       "  -5138.5,\n",
       "  4674.03857421875,\n",
       "  -6764.7119140625,\n",
       "  -5160.6787109375,\n",
       "  544247.625,\n",
       "  461560.9375,\n",
       "  172567.21875,\n",
       "  415055.125,\n",
       "  -3492.3466796875,\n",
       "  459636.53125,\n",
       "  323111.15625,\n",
       "  567342.5625,\n",
       "  378787.34375,\n",
       "  -5481.18408203125,\n",
       "  -5193.8798828125,\n",
       "  -3909.19921875,\n",
       "  -5105.0859375,\n",
       "  -6291.1005859375,\n",
       "  213517.890625,\n",
       "  7552.8779296875,\n",
       "  -6294.26806640625,\n",
       "  28237.236328125,\n",
       "  -7041.52001953125,\n",
       "  4713.22705078125,\n",
       "  201.67709350585938,\n",
       "  260578.609375,\n",
       "  4782.9951171875,\n",
       "  69107.4453125,\n",
       "  201323.40625,\n",
       "  378871.5625,\n",
       "  378926.125,\n",
       "  459285.6875,\n",
       "  -2731.6865234375,\n",
       "  -3899.587890625,\n",
       "  154691.546875,\n",
       "  378558.21875,\n",
       "  -5106.60205078125],\n",
       " 'nll': 153190.86,\n",
       " 'piw_by_example': [0.05673898383975029,\n",
       "  0.05715501308441162,\n",
       "  0.05671585723757744,\n",
       "  0.057187072932720184,\n",
       "  0.05716557428240776,\n",
       "  0.056576792150735855,\n",
       "  0.057146694511175156,\n",
       "  0.057310864329338074,\n",
       "  0.057291772216558456,\n",
       "  0.056962497532367706,\n",
       "  0.05652870610356331,\n",
       "  0.056944724172353745,\n",
       "  0.057261038571596146,\n",
       "  0.056812550872564316,\n",
       "  0.057281479239463806,\n",
       "  0.05746331810951233,\n",
       "  0.05671418830752373,\n",
       "  0.05704791098833084,\n",
       "  0.05730297043919563,\n",
       "  0.05709109082818031,\n",
       "  0.05709434673190117,\n",
       "  0.0571204274892807,\n",
       "  0.05654963478446007,\n",
       "  0.057091228663921356,\n",
       "  0.05748017877340317,\n",
       "  0.057613227516412735,\n",
       "  0.057413578033447266,\n",
       "  0.05712619051337242,\n",
       "  0.05733690783381462,\n",
       "  0.05673647299408913,\n",
       "  0.05652318149805069,\n",
       "  0.0565037727355957,\n",
       "  0.05767487362027168,\n",
       "  0.05744348093867302,\n",
       "  0.056608714163303375,\n",
       "  0.05728885903954506,\n",
       "  0.05752011388540268,\n",
       "  0.05767614766955376,\n",
       "  0.05759615823626518,\n",
       "  0.05753259360790253,\n",
       "  0.056897569447755814,\n",
       "  0.05682128295302391,\n",
       "  0.057562120258808136,\n",
       "  0.05739618092775345,\n",
       "  0.05666447430849075,\n",
       "  0.05761187523603439,\n",
       "  0.05734715983271599,\n",
       "  0.05738650634884834,\n",
       "  0.05664888024330139,\n",
       "  0.057222798466682434,\n",
       "  0.056821513921022415,\n",
       "  0.05753679573535919,\n",
       "  0.05692852661013603,\n",
       "  0.05728764459490776,\n",
       "  0.05715372413396835,\n",
       "  0.0573105625808239,\n",
       "  0.05682823807001114,\n",
       "  0.05734996125102043,\n",
       "  0.05660420283675194,\n",
       "  0.05718420073390007,\n",
       "  0.05661783367395401,\n",
       "  0.056425195187330246,\n",
       "  0.05653911456465721,\n",
       "  0.05754198506474495,\n",
       "  0.05738389492034912,\n",
       "  0.057636912912130356,\n",
       "  0.057549405843019485,\n",
       "  0.056483205407857895,\n",
       "  0.05661419779062271,\n",
       "  0.05694006010890007,\n",
       "  0.05663476511836052,\n",
       "  0.05748141184449196,\n",
       "  0.05656837671995163,\n",
       "  0.056735582649707794,\n",
       "  0.05643788352608681,\n",
       "  0.05668572336435318,\n",
       "  0.05756303668022156,\n",
       "  0.05756065994501114,\n",
       "  0.057495057582855225,\n",
       "  0.05753091350197792,\n",
       "  0.057605594396591187,\n",
       "  0.05688074976205826,\n",
       "  0.057319775223731995,\n",
       "  0.05760671943426132,\n",
       "  0.05725059658288956,\n",
       "  0.05767618864774704,\n",
       "  0.05736968293786049,\n",
       "  0.05743512883782387,\n",
       "  0.05682186782360077,\n",
       "  0.05734504014253616,\n",
       "  0.0571141317486763,\n",
       "  0.05689156800508499,\n",
       "  0.05668823793530464,\n",
       "  0.05668985843658447,\n",
       "  0.05656000226736069,\n",
       "  0.05746672302484512,\n",
       "  0.05749193951487541,\n",
       "  0.05697007477283478,\n",
       "  0.0566788874566555,\n",
       "  0.05753142759203911],\n",
       " 'piw': 0.05711012363433838,\n",
       " 'crps_by_example': [0.048005059361457825,\n",
       "  0.03207918256521225,\n",
       "  0.048730675131082535,\n",
       "  0.031232230365276337,\n",
       "  0.031891945749521255,\n",
       "  0.05437774956226349,\n",
       "  0.0322267971932888,\n",
       "  0.02540750242769718,\n",
       "  0.02674795314669609,\n",
       "  0.03973531350493431,\n",
       "  0.05560500919818878,\n",
       "  0.04034725949168205,\n",
       "  0.02882496826350689,\n",
       "  0.04549698904156685,\n",
       "  0.02748861350119114,\n",
       "  0.020726626738905907,\n",
       "  0.04876367747783661,\n",
       "  0.0364668034017086,\n",
       "  0.025538982823491096,\n",
       "  0.0348350815474987,\n",
       "  0.03449593484401703,\n",
       "  0.033742669969797134,\n",
       "  0.054918281733989716,\n",
       "  0.034832634031772614,\n",
       "  0.020195601508021355,\n",
       "  0.01505142729729414,\n",
       "  0.022903865203261375,\n",
       "  0.03363942727446556,\n",
       "  0.024692485108971596,\n",
       "  0.048054032027721405,\n",
       "  0.05571558326482773,\n",
       "  0.05690944567322731,\n",
       "  0.013821568340063095,\n",
       "  0.021593233570456505,\n",
       "  0.05374521017074585,\n",
       "  0.02736477740108967,\n",
       "  0.018133148550987244,\n",
       "  0.013808519579470158,\n",
       "  0.016578931361436844,\n",
       "  0.01796308346092701,\n",
       "  0.041802119463682175,\n",
       "  0.04505306854844093,\n",
       "  0.017284374684095383,\n",
       "  0.02346046455204487,\n",
       "  0.05128886550664902,\n",
       "  0.01506727747619152,\n",
       "  0.024525940418243408,\n",
       "  0.023899270221590996,\n",
       "  0.052136097103357315,\n",
       "  0.030045051127672195,\n",
       "  0.04504845291376114,\n",
       "  0.01790645718574524,\n",
       "  0.04121260717511177,\n",
       "  0.027385221794247627,\n",
       "  0.032101839780807495,\n",
       "  0.025412384420633316,\n",
       "  0.044918835163116455,\n",
       "  0.024480663239955902,\n",
       "  0.05383440852165222,\n",
       "  0.031282536685466766,\n",
       "  0.05329431965947151,\n",
       "  0.06009085848927498,\n",
       "  0.055397387593984604,\n",
       "  0.01783740147948265,\n",
       "  0.023940090090036392,\n",
       "  0.014778252691030502,\n",
       "  0.017739204689860344,\n",
       "  0.05812913179397583,\n",
       "  0.05363680422306061,\n",
       "  0.040435515344142914,\n",
       "  0.05241452157497406,\n",
       "  0.02017815038561821,\n",
       "  0.05454492196440697,\n",
       "  0.04807141795754433,\n",
       "  0.05983622744679451,\n",
       "  0.05059748888015747,\n",
       "  0.017272666096687317,\n",
       "  0.017592813819646835,\n",
       "  0.019433341920375824,\n",
       "  0.01798570342361927,\n",
       "  0.015887387096881866,\n",
       "  0.04268219694495201,\n",
       "  0.025259526446461678,\n",
       "  0.015874182805418968,\n",
       "  0.029001200571656227,\n",
       "  0.013808084651827812,\n",
       "  0.024164410308003426,\n",
       "  0.02200631983578205,\n",
       "  0.04504159465432167,\n",
       "  0.024560192599892616,\n",
       "  0.03385546803474426,\n",
       "  0.04219675809144974,\n",
       "  0.05054810643196106,\n",
       "  0.05051635205745697,\n",
       "  0.05471174418926239,\n",
       "  0.020677167922258377,\n",
       "  0.019477155059576035,\n",
       "  0.039311643689870834,\n",
       "  0.050731461495161057,\n",
       "  0.01797901652753353],\n",
       " 'crps': 0.034123303890228274,\n",
       " 'nMeRCI_all': 0.8721715807914734,\n",
       " 'rmsce_all': 0.41860461235046387,\n",
       " 'cerr_by_example': [4.922039806842804e-07,\n",
       "  7.601920515298843e-07,\n",
       "  4.76837158203125e-07,\n",
       "  4.621688276529312e-07,\n",
       "  5.960464477539062e-07,\n",
       "  5.811452865600586e-07,\n",
       "  6.263144314289093e-07,\n",
       "  5.073379725217819e-07,\n",
       "  2.9872171580791473e-07,\n",
       "  5.51808625459671e-07,\n",
       "  4.0279701352119446e-07,\n",
       "  6.263144314289093e-07,\n",
       "  4.3283216655254364e-07,\n",
       "  5.066394805908203e-07,\n",
       "  3.578606992959976e-07,\n",
       "  3.8743019104003906e-07,\n",
       "  5.369074642658234e-07,\n",
       "  6.265472620725632e-07,\n",
       "  4.17931005358696e-07,\n",
       "  5.816109478473663e-07,\n",
       "  4.919711500406265e-07,\n",
       "  5.667097866535187e-07,\n",
       "  4.919711500406265e-07,\n",
       "  3.280583769083023e-07,\n",
       "  4.023313522338867e-07,\n",
       "  5.51808625459671e-07,\n",
       "  4.0279701352119446e-07,\n",
       "  4.176981747150421e-07,\n",
       "  2.9872171580791473e-07,\n",
       "  5.667097866535187e-07,\n",
       "  6.558839231729507e-07,\n",
       "  5.960464477539062e-07,\n",
       "  2.0908191800117493e-07,\n",
       "  5.664769560098648e-07,\n",
       "  3.734603524208069e-07,\n",
       "  5.515757948160172e-07,\n",
       "  4.0302984416484833e-07,\n",
       "  6.109476089477539e-07,\n",
       "  3.578606992959976e-07,\n",
       "  4.172325134277344e-07,\n",
       "  7.008202373981476e-07,\n",
       "  3.8836151361465454e-07,\n",
       "  4.4726766645908356e-07,\n",
       "  4.76837158203125e-07,\n",
       "  4.917383193969727e-07,\n",
       "  2.2375024855136871e-07,\n",
       "  5.066394805908203e-07,\n",
       "  5.066394805908203e-07,\n",
       "  2.98256054520607e-07,\n",
       "  2.689193934202194e-07,\n",
       "  3.878958523273468e-07,\n",
       "  5.066394805908203e-07,\n",
       "  3.2782554626464844e-07,\n",
       "  5.96512109041214e-07,\n",
       "  4.6193599700927734e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  4.025641828775406e-07,\n",
       "  5.227047950029373e-07,\n",
       "  6.561167538166046e-07,\n",
       "  4.023313522338867e-07,\n",
       "  7.008202373981476e-07,\n",
       "  5.96512109041214e-07,\n",
       "  7.452908903360367e-07,\n",
       "  4.770699888467789e-07,\n",
       "  5.813781172037125e-07,\n",
       "  4.176981747150421e-07,\n",
       "  5.07105141878128e-07,\n",
       "  8.351635187864304e-07,\n",
       "  6.111804395914078e-07,\n",
       "  5.21540641784668e-07,\n",
       "  4.773028194904327e-07,\n",
       "  3.4319236874580383e-07,\n",
       "  6.561167538166046e-07,\n",
       "  4.3213367462158203e-07,\n",
       "  6.707850843667984e-07,\n",
       "  6.111804395914078e-07,\n",
       "  7.30389729142189e-07,\n",
       "  4.770699888467789e-07,\n",
       "  5.664769560098648e-07,\n",
       "  3.878958523273468e-07,\n",
       "  4.1746534407138824e-07,\n",
       "  4.76837158203125e-07,\n",
       "  3.8743019104003906e-07,\n",
       "  7.30389729142189e-07,\n",
       "  6.407499313354492e-07,\n",
       "  5.364418029785156e-07,\n",
       "  5.811452865600586e-07,\n",
       "  4.172325134277344e-07,\n",
       "  4.4726766645908356e-07,\n",
       "  3.8766302168369293e-07,\n",
       "  3.5762786865234375e-07,\n",
       "  2.9872171580791473e-07,\n",
       "  4.917383193969727e-07,\n",
       "  4.624016582965851e-07,\n",
       "  5.515757948160172e-07,\n",
       "  5.066394805908203e-07,\n",
       "  5.220063030719757e-07,\n",
       "  5.813781172037125e-07,\n",
       "  7.457565516233444e-07,\n",
       "  3.4319236874580383e-07],\n",
       " 'mcerr': 4.97112068842398e-07}"
      ]
     },
     "execution_count": 185,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "e2e_stats_test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 186,
   "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": 187,
   "id": "c95a912a-bd68-459a-abf7-1c5f03b5661a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "    Unconstrained (VarianceNO) & 4.34E-03 & 8.53E-01 & 1.47E-01 & 1.73E-01 & 1.01E-02 & 1.56E-02 & 8.49E-01 & 4.18E-01 & 6.34E-01 & 2.96E-02 \\\\\n",
      "    \\texttt{ProbConserv} & 2.77E-03 & 8.21E-01 & 1.42E-01 & 3.62E-07 & 8.26E-03 & 2.66E-02 & 8.49E-01 & 4.15E-01 & 4.96E-07 & 3.39E-02 \\\\\n",
      "    \\ourmethod{} & 2.10E-03 & 7.83E-01 & 1.73E-01 & 3.61E-07 & 7.83E-03 & 2.26E-02 & 8.72E-01 & 4.19E-01 & 4.97E-07 & 3.41E-02 \\\\\n",
      "    \\ourmethod{} + \\texttt{ProbConserv} & 2.10E-03 & 7.82E-01 & 1.73E-01 & 3.59E-07 & 7.81E-03 & 2.26E-02 & 8.71E-01 & 4.19E-01 & 5.01E-07 & 3.45E-02 \\\\\n",
      "    \n"
     ]
    }
   ],
   "source": [
    "print(dump_to_latex(ucons_stats_train, ucons_stats_test,  probconserv_stats_train, probconserv_stats_test, e2e_stats_train, e2e_stats_test, e2e_probconserv_stats_train, e2e_probconserv_stats_test))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 188,
   "id": "654cef07-235c-492e-9960-9b3d236949dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def compute_statistics(\n",
    "    model, \n",
    "    x_data, \n",
    "    y_data, \n",
    "    t, \n",
    "    tpred, \n",
    "    grid, \n",
    "    dataset_class, \n",
    "    apply_probconserv=False, \n",
    "    plot=False,\n",
    "    x_data_test=None, \n",
    "    y_data_test=None,\n",
    "    return_latex=False,\n",
    "    name=\"Model\"\n",
    "):\n",
    "    import torch\n",
    "    import utils\n",
    "    import probconserv\n",
    "    import matplotlib.pyplot as plt\n",
    "\n",
    "    device = next(model.parameters()).device\n",
    "    x_data = x_data.to(device)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        out = model(x_data)\n",
    "\n",
    "    if isinstance(out, tuple):\n",
    "        mu, var = out[0].cpu(), out[1].cpu()\n",
    "        std = torch.sqrt(var)\n",
    "    else:\n",
    "        mu = out.cpu()\n",
    "        std = torch.zeros_like(mu)\n",
    "        var = torch.square(std)\n",
    "\n",
    "    x_cpu = x_data.cpu()\n",
    "    mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_cpu)\n",
    "\n",
    "    if apply_probconserv:\n",
    "        new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(\n",
    "            mu=mu[:, :, :, 0],\n",
    "            std=std[:, :, :, 0],\n",
    "            mass_rhs_func=mass_rhs_func,\n",
    "            t=t,\n",
    "            tpred=tpred,\n",
    "            grid_train=grid,\n",
    "            precis_g=float('inf'),\n",
    "            second_deriv_alpha=None,\n",
    "        )\n",
    "        mu = new_mu.unsqueeze(-1)\n",
    "        std = new_std.unsqueeze(-1)\n",
    "        var = torch.square(std)\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs).abs().sum(dim=-1)\n",
    "    else:\n",
    "        cerr = (probconserv.get_empirical_mass_rhs(mu[:, :, :, 0]) - mass_rhs_func(rearrange(x_cpu, \"nf nx nt 1-> nf nt nx 1\"))).abs().sum(dim=-1)\n",
    "\n",
    "    stats = utils.compute_all_metrics_avg((mu, var), y_data, {})\n",
    "    stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu, var, y_data).item()\n",
    "    stats[\"rmsce_all\"] = utils.compute_rmsce(mu, var, y_data).item()\n",
    "    stats[\"cerr_by_example\"] = cerr.tolist()\n",
    "    stats[\"mcerr\"] = cerr.mean().item()\n",
    "\n",
    "    # --- Test dataset ---\n",
    "    test_stats = None\n",
    "    if x_data_test is not None and y_data_test is not None:\n",
    "        x_data_test = x_data_test.to(device)\n",
    "        with torch.no_grad():\n",
    "            test_out = model(x_data_test)\n",
    "\n",
    "        if isinstance(test_out, tuple):\n",
    "            mu_test, var_test = test_out[0].cpu(), test_out[1].cpu()\n",
    "            std_test = torch.sqrt(var_test)\n",
    "        else:\n",
    "            mu_test = test_out.cpu()\n",
    "            std_test = torch.zeros_like(mu_test)\n",
    "            var_test = torch.square(std_test)\n",
    "\n",
    "        x_test_cpu = x_data_test.cpu()\n",
    "        test_mass_rhs_func = dataset_class.get_mass_rhs_func(x=x_test_cpu)\n",
    "\n",
    "        if apply_probconserv:\n",
    "            new_mu_test, new_std_test, _, test_mass_rhs = probconserv.apply_constraint(\n",
    "                mu=mu_test[:, :, :, 0],\n",
    "                std=std_test[:, :, :, 0],\n",
    "                mass_rhs_func=test_mass_rhs_func,\n",
    "                t=t,\n",
    "                tpred=tpred,\n",
    "                grid_train=grid,\n",
    "                precis_g=float('inf'),\n",
    "                second_deriv_alpha=None,\n",
    "            )\n",
    "            mu_test = new_mu_test.unsqueeze(-1)\n",
    "            std_test = new_std_test.unsqueeze(-1)\n",
    "            var_test = torch.square(std_test)\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs).abs().sum(dim=-1)\n",
    "        else:\n",
    "            cerr_test = (probconserv.get_empirical_mass_rhs(mu_test[:, :, :, 0]) - test_mass_rhs_func(rearrange(x_test_cpu, \"nf nx nt 1-> nf nt nx 1\"))).abs().sum(dim=-1)\n",
    "\n",
    "        test_stats = utils.compute_all_metrics_avg((mu_test, var_test), y_data_test, {})\n",
    "        test_stats[\"nMeRCI_all\"] = utils.compute_nMeRCI(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"rmsce_all\"] = utils.compute_rmsce(mu_test, var_test, y_data_test).item()\n",
    "        test_stats[\"cerr_by_example\"] = cerr_test.tolist()\n",
    "        test_stats[\"mcerr\"] = cerr_test.mean().item()\n",
    "\n",
    "    # --- Optional plot ---\n",
    "    if plot:\n",
    "        t_idx = 1\n",
    "        param_idx = 0\n",
    "        with torch.no_grad():\n",
    "            plt.ylabel(f\"u(x, t={t[slice(*tpred)][t_idx]:.2f})\")\n",
    "            plt.xlabel(\"x\")\n",
    "            plt.title(f\"Predicted vs True (param = {x_data[param_idx,0,0,0].item():.2f})\")\n",
    "            mu_plot = mu[param_idx, :, t_idx, 0]\n",
    "            std_plot = std[param_idx, :, t_idx, 0]\n",
    "            y_true_plot = y_data[param_idx, :, t_idx, 0]\n",
    "            plt.plot(grid, mu_plot, '--', lw=2, label=\"μ ± 3σ\")\n",
    "            plt.fill_between(grid, mu_plot + 3*std_plot, mu_plot - 3*std_plot, alpha=0.2)\n",
    "            plt.plot(grid, y_true_plot, color=\"green\", label=\"true\")\n",
    "            plt.legend()\n",
    "            plt.show()\n",
    "\n",
    "    # --- Optional LaTeX row ---\n",
    "    latex_row = None\n",
    "    if return_latex and test_stats:\n",
    "        latex_row = (\n",
    "            f\"{name} & \"\n",
    "            f\"{stats['mse']:.2E} & {stats['nMeRCI_all']:.2E} & {stats['rmsce_all']:.2E} & {stats['mcerr']:.2E} & {stats['crps']:.2E} & \"\n",
    "            f\"{test_stats['mse']:.2E} & {test_stats['nMeRCI_all']:.2E} & {test_stats['rmsce_all']:.2E} & {test_stats['mcerr']:.2E} & {test_stats['crps']:.2E} \\\\\\\\\"\n",
    "        )\n",
    "\n",
    "    return (stats, test_stats, latex_row) if return_latex else (stats, test_stats)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "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": 190,
   "id": "a6a1914c-1c99-4c23-9fe7-fafe7a2a5d7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'ProbConserv & 2.10E-03 & 7.83E-01 & 1.73E-01 & 3.61E-07 & 7.83E-03 & 2.26E-02 & 8.72E-01 & 4.19E-01 & 4.97E-07 & 3.41E-02 \\\\\\\\'"
      ]
     },
     "execution_count": 190,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "latex"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "af0c8f58-4cae-495a-8cfb-ee81163a961c",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "    Unconstrained (VarianceNO) & 4.34E-03 & 8.53E-01 & 1.47E-01 & 1.73E-01 & 1.01E-02 & 1.56E-02 & 8.49E-01 & 4.18E-01 & 6.34E-01 & 2.96E-02 \\\\\n",
    "    \\texttt{ProbConserv} & 2.77E-03 & 8.21E-01 & 1.42E-01 & 3.62E-07 & 8.26E-03 & 2.66E-02 & 8.49E-01 & 4.15E-01 & 4.96E-07 & 3.39E-02 \\\\\n",
    "    \\ourmethod{} & 2.10E-03 & 7.83E-01 & 1.73E-01 & 3.61E-07 & 7.83E-03 & 2.26E-02 & 8.72E-01 & 4.19E-01 & 4.97E-07 & 3.41E-02 \\\\\n",
    "    \\ourmethod{} + \\texttt{ProbConserv} & 2.10E-03 & 7.82E-01 & 1.73E-01 & 3.59E-07 & 7.81E-03 & 2.26E-02 & 8.71E-01 & 4.19E-01 & 5.01E-07 & 3.45E-02 \\\\"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "optprobconserv",
   "language": "python",
   "name": "optprobconserv"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
