{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "9db4db74-5658-4ab3-aff5-3efc97ff9c53",
   "metadata": {},
   "source": [
    "## TVD constraint application to Hyperbolic PDEs\n",
    "\n",
    "---\n",
    "\n",
    "## What This Notebook Does   \n",
    "\n",
    "Creates the TVD plot in Figure 1 b)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "6b3ccdb8-4fd8-4224-b23e-979fa8228059",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "import os\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = '1'\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": 3,
   "id": "5fdcc8cd-82d9-4cec-888d-806541259f2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "1d5eb530-ab43-4054-8953-9efdb86b3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "args = {'--batch_size': '20',\n",
    " '--dataset': 'LinearAdvection_1D',\n",
    " '--dataset_params': '1,2',\n",
    " '--epochs': '200',\n",
    " '--fno_modes': '6',\n",
    " '--fno_width': '32',\n",
    " '--grid_len': '50',\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',\n",
    " '--seed': '0',\n",
    " '--time_len': '10',\n",
    " '--tplot': '0.5',\n",
    " '--train_ood_dataset_params': '1,2'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": 6,
   "id": "b02f6033-3977-4d51-8f39-024a376dbabf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here 160\n",
      "torch.Size([160, 50, 1]) torch.Size([160, 50, 9, 1])\n",
      "torch.Size([160, 50, 9, 1]) torch.Size([160, 50, 9, 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": 7,
   "id": "4bdba559-fae5-43f5-b6d0-bb20d33ad394",
   "metadata": {},
   "outputs": [],
   "source": [
    "constraint_context = {\n",
    "    \"t\": t.to(device),\n",
    "    \"tpred\": torch.tensor(tpred).to(device),\n",
    "    \"grid_train\": grid.to(device),\n",
    "    \"dataset_class\": dataset_class\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "a7e5c61c-2b59-466f-9b4a-6157fa29ad4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=False, base_model_params=FNO2d_params, constraint_context=constraint_context)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ac0b8967",
   "metadata": {},
   "source": [
    "## Running VarianceNO out of the box"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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": 10,
   "id": "b339b6e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "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": 12,
   "id": "d71ec298-4bbc-4186-a938-8675f0526890",
   "metadata": {},
   "outputs": [],
   "source": [
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "87e15df0-69a3-4d0e-82f0-f04540d1a1e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0204, 0.0408, 0.0612, 0.0816, 0.1020, 0.1224, 0.1429, 0.1633,\n",
       "        0.1837, 0.2041, 0.2245, 0.2449, 0.2653, 0.2857, 0.3061, 0.3265, 0.3469,\n",
       "        0.3673, 0.3878, 0.4082, 0.4286, 0.4490, 0.4694, 0.4898, 0.5102, 0.5306,\n",
       "        0.5510, 0.5714, 0.5918, 0.6122, 0.6327, 0.6531, 0.6735, 0.6939, 0.7143,\n",
       "        0.7347, 0.7551, 0.7755, 0.7959, 0.8163, 0.8367, 0.8571, 0.8776, 0.8980,\n",
       "        0.9184, 0.9388, 0.9592, 0.9796, 1.0000])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b19bb3fc-3fe5-4ec4-8e06-2f8d8b3a1d70",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.1111])"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t[slice(*[0,2])]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2165975d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, -1]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tpred"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "1ad2c532",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0, -1])"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.tensor(tpred)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "af0a1639-3942-4ef9-8e17-2c9e35391afd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 50, 9, 1])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_train.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "6ff40f4d-d8b7-45f7-8e3a-8115564540df",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 0: Train loss=0.539045, Validation loss=0.449740 (saved)\n",
      "Epoch 1: Train loss=0.351243, Validation loss=0.235317 (saved)\n",
      "Epoch 2: Train loss=0.240658, Validation loss=0.206665 (saved)\n",
      "Epoch 3: Train loss=0.203839, Validation loss=0.189977 (saved)\n",
      "Epoch 4: Train loss=0.179370, Validation loss=0.165247 (saved)\n",
      "Epoch 5: Train loss=0.155259, Validation loss=0.141098 (saved)\n",
      "Epoch 6: Train loss=0.126908, Validation loss=0.106592 (saved)\n",
      "Epoch 7: Train loss=0.088593, Validation loss=0.064754 (saved)\n",
      "Epoch 8: Train loss=0.056137, Validation loss=0.039430 (saved)\n",
      "Epoch 9: Train loss=0.041477, Validation loss=0.039808 \n",
      "Epoch 10: Train loss=0.035183, Validation loss=0.031070 (saved)\n",
      "Epoch 11: Train loss=0.028635, Validation loss=0.025158 (saved)\n",
      "Epoch 12: Train loss=0.026231, Validation loss=0.022062 (saved)\n",
      "Epoch 13: Train loss=0.024390, Validation loss=0.020907 (saved)\n",
      "Epoch 14: Train loss=0.023341, Validation loss=0.022208 \n",
      "Epoch 15: Train loss=0.021706, Validation loss=0.026859 \n",
      "Epoch 16: Train loss=0.022744, Validation loss=0.018959 (saved)\n",
      "Epoch 17: Train loss=0.023681, Validation loss=0.026573 \n",
      "Epoch 18: Train loss=0.023129, Validation loss=0.021235 \n",
      "Epoch 19: Train loss=0.019833, Validation loss=0.020630 \n",
      "Epoch 20: Train loss=0.018596, Validation loss=0.018723 (saved)\n",
      "Epoch 21: Train loss=0.018692, Validation loss=0.019730 \n",
      "Epoch 22: Train loss=0.019764, Validation loss=0.018470 (saved)\n",
      "Epoch 23: Train loss=0.017824, Validation loss=0.015376 (saved)\n",
      "Epoch 24: Train loss=0.017174, Validation loss=0.016025 \n",
      "Epoch 25: Train loss=0.017575, Validation loss=0.020633 \n",
      "Epoch 26: Train loss=0.017895, Validation loss=0.016601 \n",
      "Epoch 27: Train loss=0.016544, Validation loss=0.014405 (saved)\n",
      "Epoch 28: Train loss=0.016299, Validation loss=0.016597 \n",
      "Epoch 29: Train loss=0.016626, Validation loss=0.017811 \n",
      "Epoch 30: Train loss=0.016427, Validation loss=0.013976 (saved)\n",
      "Epoch 31: Train loss=0.015318, Validation loss=0.013084 (saved)\n",
      "Epoch 32: Train loss=0.015037, Validation loss=0.015438 \n",
      "Epoch 33: Train loss=0.016606, Validation loss=0.014279 \n",
      "Epoch 34: Train loss=0.014917, Validation loss=0.015823 \n",
      "Epoch 35: Train loss=0.014705, Validation loss=0.014991 \n",
      "Epoch 36: Train loss=0.014207, Validation loss=0.012123 (saved)\n",
      "Epoch 37: Train loss=0.013641, Validation loss=0.011860 (saved)\n",
      "Epoch 38: Train loss=0.013912, Validation loss=0.016939 \n",
      "Epoch 39: Train loss=0.015411, Validation loss=0.016451 \n",
      "Epoch 40: Train loss=0.017376, Validation loss=0.015430 \n",
      "Epoch 41: Train loss=0.015693, Validation loss=0.012971 \n",
      "Epoch 42: Train loss=0.014328, Validation loss=0.013016 \n",
      "Epoch 43: Train loss=0.014700, Validation loss=0.013271 \n",
      "Epoch 44: Train loss=0.013350, Validation loss=0.012295 \n",
      "Epoch 45: Train loss=0.013214, Validation loss=0.011478 (saved)\n",
      "Epoch 46: Train loss=0.012907, Validation loss=0.016130 \n",
      "Epoch 47: Train loss=0.013718, Validation loss=0.012943 \n",
      "Epoch 48: Train loss=0.012622, Validation loss=0.012066 \n",
      "Epoch 49: Train loss=0.012576, Validation loss=0.015788 \n",
      "Epoch 50: Train loss=0.012667, Validation loss=0.013886 \n",
      "Epoch 51: Train loss=0.012349, Validation loss=0.014716 \n",
      "Epoch 52: Train loss=0.014015, Validation loss=0.013370 \n",
      "Epoch 53: Train loss=0.012852, Validation loss=0.012807 \n",
      "Epoch 54: Train loss=0.012109, Validation loss=0.013315 \n",
      "Epoch 55: Train loss=0.012485, Validation loss=0.013281 \n",
      "Epoch 56: Train loss=0.012614, Validation loss=0.012277 \n",
      "Epoch 57: Train loss=0.011860, Validation loss=0.012574 \n",
      "Epoch 58: Train loss=0.012104, Validation loss=0.013314 \n",
      "Epoch 59: Train loss=0.012383, Validation loss=0.012837 \n",
      "Epoch 60: Train loss=0.011785, Validation loss=0.012608 \n",
      "Epoch 61: Train loss=0.011934, Validation loss=0.013417 \n",
      "Epoch 62: Train loss=0.012448, Validation loss=0.012513 \n",
      "Epoch 63: Train loss=0.011823, Validation loss=0.012428 \n",
      "Epoch 64: Train loss=0.011519, Validation loss=0.012976 \n",
      "Epoch 65: Train loss=0.012523, Validation loss=0.011910 \n",
      "Epoch 66: Train loss=0.011471, Validation loss=0.011616 \n",
      "Epoch 67: Train loss=0.011205, Validation loss=0.012246 \n",
      "Epoch 68: Train loss=0.011701, Validation loss=0.012958 \n",
      "Epoch 69: Train loss=0.011907, Validation loss=0.012114 \n",
      "Epoch 70: Train loss=0.011515, Validation loss=0.012106 \n",
      "Epoch 71: Train loss=0.011385, Validation loss=0.010949 (saved)\n",
      "Epoch 72: Train loss=0.010517, Validation loss=0.011290 \n",
      "Epoch 73: Train loss=0.010303, Validation loss=0.010362 (saved)\n",
      "Epoch 74: Train loss=0.009858, Validation loss=0.010047 (saved)\n",
      "Epoch 75: Train loss=0.009523, Validation loss=0.009288 (saved)\n",
      "Epoch 76: Train loss=0.009095, Validation loss=0.009384 \n",
      "Epoch 77: Train loss=0.009144, Validation loss=0.010149 \n",
      "Epoch 78: Train loss=0.009128, Validation loss=0.008740 (saved)\n",
      "Epoch 79: Train loss=0.009388, Validation loss=0.009215 \n",
      "Epoch 80: Train loss=0.009806, Validation loss=0.010301 \n",
      "Epoch 81: Train loss=0.009733, Validation loss=0.010908 \n",
      "Epoch 82: Train loss=0.009704, Validation loss=0.009132 \n",
      "Epoch 83: Train loss=0.009390, Validation loss=0.008995 \n",
      "Epoch 84: Train loss=0.009209, Validation loss=0.009845 \n",
      "Epoch 85: Train loss=0.009256, Validation loss=0.009218 \n",
      "Epoch 86: Train loss=0.009224, Validation loss=0.009214 \n",
      "Epoch 87: Train loss=0.009163, Validation loss=0.008497 (saved)\n",
      "Epoch 88: Train loss=0.008825, Validation loss=0.009548 \n",
      "Epoch 89: Train loss=0.008861, Validation loss=0.008076 (saved)\n",
      "Epoch 90: Train loss=0.008813, Validation loss=0.008541 \n",
      "Epoch 91: Train loss=0.008958, Validation loss=0.008611 \n",
      "Epoch 92: Train loss=0.009419, Validation loss=0.008980 \n",
      "Epoch 93: Train loss=0.008969, Validation loss=0.008676 \n",
      "Epoch 94: Train loss=0.008952, Validation loss=0.011104 \n",
      "Epoch 95: Train loss=0.009100, Validation loss=0.008365 \n",
      "Epoch 96: Train loss=0.008872, Validation loss=0.009330 \n",
      "Epoch 97: Train loss=0.008867, Validation loss=0.008944 \n",
      "Epoch 98: Train loss=0.008838, Validation loss=0.008222 \n",
      "Epoch 99: Train loss=0.008932, Validation loss=0.008636 \n",
      "Epoch 100: Train loss=0.008202, Validation loss=0.008567 \n",
      "Epoch 101: Train loss=0.008003, Validation loss=0.007710 (saved)\n",
      "Epoch 102: Train loss=0.007645, Validation loss=0.007577 (saved)\n",
      "Epoch 103: Train loss=0.007488, Validation loss=0.007477 (saved)\n",
      "Epoch 104: Train loss=0.007413, Validation loss=0.007464 (saved)\n",
      "Epoch 105: Train loss=0.007439, Validation loss=0.007590 \n",
      "Epoch 106: Train loss=0.007567, Validation loss=0.007341 (saved)\n",
      "Epoch 107: Train loss=0.007573, Validation loss=0.007622 \n",
      "Epoch 108: Train loss=0.007402, Validation loss=0.007272 (saved)\n",
      "Epoch 109: Train loss=0.007254, Validation loss=0.007248 (saved)\n",
      "Epoch 110: Train loss=0.007326, Validation loss=0.007271 \n",
      "Epoch 111: Train loss=0.007117, Validation loss=0.006989 (saved)\n",
      "Epoch 112: Train loss=0.007228, Validation loss=0.007196 \n",
      "Epoch 113: Train loss=0.007551, Validation loss=0.007003 \n",
      "Epoch 114: Train loss=0.007529, Validation loss=0.007374 \n",
      "Epoch 115: Train loss=0.007327, Validation loss=0.006939 (saved)\n",
      "Epoch 116: Train loss=0.007288, Validation loss=0.007755 \n",
      "Epoch 117: Train loss=0.007253, Validation loss=0.007286 \n",
      "Epoch 118: Train loss=0.007332, Validation loss=0.007053 \n",
      "Epoch 119: Train loss=0.007268, Validation loss=0.007169 \n",
      "Epoch 120: Train loss=0.007404, Validation loss=0.007294 \n",
      "Epoch 121: Train loss=0.007429, Validation loss=0.006900 (saved)\n",
      "Epoch 122: Train loss=0.007410, Validation loss=0.007806 \n",
      "Epoch 123: Train loss=0.007321, Validation loss=0.007732 \n",
      "Epoch 124: Train loss=0.007367, Validation loss=0.006898 (saved)\n",
      "Epoch 125: Train loss=0.007298, Validation loss=0.007860 \n",
      "Epoch 126: Train loss=0.007414, Validation loss=0.007220 \n",
      "Epoch 127: Train loss=0.007281, Validation loss=0.007826 \n",
      "Epoch 128: Train loss=0.007451, Validation loss=0.007466 \n",
      "Epoch 129: Train loss=0.007409, Validation loss=0.007621 \n",
      "Epoch 130: Train loss=0.007374, Validation loss=0.006730 (saved)\n",
      "Epoch 131: Train loss=0.006958, Validation loss=0.007068 \n",
      "Epoch 132: Train loss=0.007132, Validation loss=0.007537 \n",
      "Epoch 133: Train loss=0.007435, Validation loss=0.006847 \n",
      "Epoch 134: Train loss=0.007252, Validation loss=0.006975 \n",
      "Epoch 135: Train loss=0.007236, Validation loss=0.006702 (saved)\n",
      "Epoch 136: Train loss=0.006837, Validation loss=0.006942 \n",
      "Epoch 137: Train loss=0.007259, Validation loss=0.007151 \n",
      "Epoch 138: Train loss=0.007160, Validation loss=0.006917 \n",
      "Epoch 139: Train loss=0.007169, Validation loss=0.007406 \n",
      "Epoch 140: Train loss=0.007173, Validation loss=0.006748 \n",
      "Epoch 141: Train loss=0.007202, Validation loss=0.006846 \n",
      "Epoch 142: Train loss=0.007055, Validation loss=0.006765 \n",
      "Epoch 143: Train loss=0.007271, Validation loss=0.008925 \n",
      "Epoch 144: Train loss=0.008549, Validation loss=0.006918 \n",
      "Epoch 145: Train loss=0.010319, Validation loss=0.011098 \n",
      "Epoch 146: Train loss=0.010430, Validation loss=0.007158 \n",
      "Epoch 147: Train loss=0.007835, Validation loss=0.007239 \n",
      "Epoch 148: Train loss=0.007401, Validation loss=0.006774 \n",
      "Epoch 149: Train loss=0.006749, Validation loss=0.006511 (saved)\n",
      "Epoch 150: Train loss=0.006471, Validation loss=0.006404 (saved)\n",
      "Epoch 151: Train loss=0.006433, Validation loss=0.006340 (saved)\n",
      "Epoch 152: Train loss=0.006401, Validation loss=0.006340 (saved)\n",
      "Epoch 153: Train loss=0.006365, Validation loss=0.006321 (saved)\n",
      "Epoch 154: Train loss=0.006329, Validation loss=0.006256 (saved)\n",
      "Epoch 155: Train loss=0.006329, Validation loss=0.006356 \n",
      "Epoch 156: Train loss=0.006310, Validation loss=0.006206 (saved)\n",
      "Epoch 157: Train loss=0.006270, Validation loss=0.006216 \n",
      "Epoch 158: Train loss=0.006291, Validation loss=0.006177 (saved)\n",
      "Epoch 159: Train loss=0.006298, Validation loss=0.006315 \n",
      "Epoch 160: Train loss=0.006268, Validation loss=0.006189 \n",
      "Epoch 161: Train loss=0.006263, Validation loss=0.006182 \n",
      "Epoch 162: Train loss=0.006254, Validation loss=0.006166 (saved)\n",
      "Epoch 163: Train loss=0.006220, Validation loss=0.006173 \n",
      "Epoch 164: Train loss=0.006224, Validation loss=0.006285 \n",
      "Epoch 165: Train loss=0.006270, Validation loss=0.006451 \n",
      "Epoch 166: Train loss=0.006197, Validation loss=0.006144 (saved)\n",
      "Epoch 167: Train loss=0.006200, Validation loss=0.006096 (saved)\n",
      "Epoch 168: Train loss=0.006141, Validation loss=0.006073 (saved)\n",
      "Epoch 169: Train loss=0.006142, Validation loss=0.006011 (saved)\n",
      "Epoch 170: Train loss=0.006104, Validation loss=0.006006 (saved)\n",
      "Epoch 171: Train loss=0.006083, Validation loss=0.006018 \n",
      "Epoch 172: Train loss=0.006072, Validation loss=0.005980 (saved)\n",
      "Epoch 173: Train loss=0.006022, Validation loss=0.005945 (saved)\n",
      "Epoch 174: Train loss=0.005994, Validation loss=0.005931 (saved)\n",
      "Epoch 175: Train loss=0.005977, Validation loss=0.005908 (saved)\n",
      "Epoch 176: Train loss=0.006066, Validation loss=0.005953 \n",
      "Epoch 177: Train loss=0.006101, Validation loss=0.006046 \n",
      "Epoch 178: Train loss=0.005994, Validation loss=0.005877 (saved)\n",
      "Epoch 179: Train loss=0.006006, Validation loss=0.005864 (saved)\n",
      "Epoch 180: Train loss=0.005955, Validation loss=0.006133 \n",
      "Epoch 181: Train loss=0.006187, Validation loss=0.006155 \n",
      "Epoch 182: Train loss=0.006195, Validation loss=0.005919 \n",
      "Epoch 183: Train loss=0.006159, Validation loss=0.006079 \n",
      "Epoch 184: Train loss=0.006231, Validation loss=0.006156 \n",
      "Epoch 185: Train loss=0.006262, Validation loss=0.006062 \n",
      "Epoch 186: Train loss=0.005943, Validation loss=0.005858 (saved)\n",
      "Epoch 187: Train loss=0.005968, Validation loss=0.006347 \n",
      "Epoch 188: Train loss=0.006102, Validation loss=0.006141 \n",
      "Epoch 189: Train loss=0.006187, Validation loss=0.005909 \n",
      "Epoch 190: Train loss=0.005969, Validation loss=0.006094 \n",
      "Epoch 191: Train loss=0.006079, Validation loss=0.006379 \n",
      "Epoch 192: Train loss=0.006230, Validation loss=0.006088 \n",
      "Epoch 193: Train loss=0.006011, Validation loss=0.006323 \n",
      "Epoch 194: Train loss=0.006161, Validation loss=0.006613 \n",
      "Epoch 195: Train loss=0.006213, Validation loss=0.005799 (saved)\n",
      "Epoch 196: Train loss=0.006111, Validation loss=0.006286 \n",
      "Epoch 197: Train loss=0.006226, Validation loss=0.005895 \n",
      "Epoch 198: Train loss=0.006154, Validation loss=0.006228 \n",
      "Epoch 199: Train loss=0.006199, Validation loss=0.005998 \n",
      "Finished training with best train loss: 0.005855 and validation loss: 0.005799\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": 19,
   "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",
    "\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",
    "    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": 20,
   "id": "58fe7954-8db9-47db-ba7c-39fde51a4146",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here\n",
      "Here\n",
      "Here\n",
      "Here\n",
      "In-domain results\n",
      "MSE: 0.0021297815814614296\n",
      "n-MeRCI: 0.20997366309165955\n",
      "RMSCE: 0.21214281022548676\n",
      "ProbConserv Results\n",
      "MSE: 0.0018061284720897674\n",
      "n-MeRCI: 0.2402200549840927\n",
      "RMSCE: 0.20638200640678406\n",
      "Cerr: 0.01744166761636734\n",
      "Prob_Cerr: 1.662969566496031e-07\n",
      "Here\n",
      "\n",
      "\n",
      "Out-of-domain results\n",
      "MSE: 0.002034268341958523\n",
      "n-MeRCI: 0.22282110154628754\n",
      "RMSCE: 0.21100233495235443\n",
      "ProbConserv Results\n",
      "MSE: 0.0017240779101848603\n",
      "n-MeRCI: 0.24579602479934692\n",
      "RMSCE: 0.20584017038345337\n",
      "Cerr: 0.016788411885499954\n",
      "Prob_Cerr: 1.7553567488448607e-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": 21,
   "id": "98acb797",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0018061284720897674"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "id_results['pc.mse']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "cc667c1d-e1d1-43b2-ad5a-5d542828f7df",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu, var =  model(x_train.to(device))\n",
    "mu = mu.cpu()\n",
    "var = var.cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "6648c558-a342-46a2-a3fe-96cf7fc7736e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 50, 9, 1])"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "473b5c5e-0293-4259-8dc0-e7742cd1f2e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "05002ff0-2794-42a9-bd41-938203a559af",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(12.6366, grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(y_train - mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "64b75faa-0ce0-47f9-ae71-2aae64386daf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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6Hv11bhn0mQcP3kaZ86cRVJSkkfqAQAZGRno2LEjdDqdddvevXsRFRWF5ORku8eUlJRg9uzZ+PXXX7FlyxYoFArceOON1YKAd955ByEhIfj555+xfPlyLFq0CN9++2296usqk8mEDz/8ECUlJejXr591+759+zBkyBD06NED27dvx9dff43o6GgMGzYMH330EcLDw6uda/v27ejZs6fNtltuuQW5ubnYunWrddulS5fw9ddf48477wTg3H278jmsi1KpxJIlS7By5UqcPn3abplLly5h06ZNuP/++62zQlvEx8fjzjvvxEcffWTTGtmnTx/s3r0bFRUVDtXDJcJPARDr1693+rjBgweLu+66q8b95eXloqCgwPp16tQpAUAUFBTUo7ZE5A5lZWXi4MGDoqyszGb7Gz8cE30Xb67za/Ka3dXOOXnNboeOfeOHY/Wqe2pqqujYsaOQZdm67dFHHxUdO3a07u/Ro4fNMeXl5SI4OFj8+OOPtnWePFncfvvtQgghioqKhEajER9//LF1f25urggKChIPPvig9dyW7wsLC4VWqxVvvPGG3XqWVhjFoMGDxf0zHhAlFQZRWmEQxSWlbqmHPffee6+YMGGCzbbHH39cDBkypMZjrnThwgUBQOzfv9+6LTU1VQwcONCmXO/evcWjjz5ar/ouXrxYhISEWL8UCoXQarU2206cOGEt//vvv4uQkBChVCpFRESE2LBhg835Bg8ebL2HFtOnTxdXX311jXUYO3asmDRpUp3bX3vtNZGYmChMJpPd89R03658DtPT04VSqbR5jTfffLPN/rFjxwohhLj66qutdVi/fr2oGmb89NNPtb53P//88wKAyMnJsW7bt2+fACCysrLsHlPT3wQhhCgoKHDo/Tvg1hrr06cPduzYUeN+rVYLrVbbgDUiovoqKjciu7C8znIJkbpq23JL9A4dW1RudKluVV199dU2yaP9+vXDc889Z1065MpP+UePHkVpaSmuvfZam+16vR49evQAABw7dgx6vR59+/a17o+Ojkb79u3t1uHQoUOoqKjAsGHDqu2ThYCAbW6QAHDozz/dXg+LjIwM3HHHHTbb9u7di+7du9d4zF9//YXHH38cP//8My5evGht0Th58iS6dOliLdetWzeb4xISEqyLdLpa32nTpmH8+PHWn++8807cdNNN+Pvf/27dlpiY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N47IyMgAACQkJLhUXyKiQOdUixC7xcgP+MVT2rFjR4wYMQJTpkzB7t27sXPnTsyYMQO33XabdcTYmTNn0KFDB+zevRsAcOzYMTz55JPYs2cPsrKy8L///Q8TJkzA4MGD0a1bN2++HCIiv+XMemPBGr9IQ6UA5xeBEGAe/dWhQwcMGzYMo0aNwsCBA/H6669b9xsMBhw5csQ6Kkyj0WDz5s247rrr0KFDBzz00EO46aab8H//93/eeglERI2CI3MJNQ3XIohD58kPSEII4e1K+LLCwkJERESgoKAA4eHh3q4OEZHXHT1fhDK9XOP+iCA1WjTh5LXkXY6+f/tNixAREfmG2hKmdWoFmkcFNWBtiOqHgRARETmlpvXGlAoJLZoEc5FV8isMhIiIyCn2coQkCWjRJBhaziRNfoaBEBEROcVe11hChA6hWo4SI//DQIiIiJxy5VxCUSFqNAnlRLTknxgIERGRU6quNxasVaJZJJOjyX8xECIiIqdYWoTUKgktooMhOTrDIpEPYiBEREROUSkUkCQgOToEaiXfRsi/8QkmIiKnqBQSmkcFceZoahQYCBERkVMUCgmRwRpvV4PILRgIERERUcBiIEREREQBi4EQERERBSwGQkRERBSwGAgRERFRwGIgRERERAGLgRAREREFLAZCREREFLAYCBEREVHAYiBEREREAYuBEBEREQUsBkJEREQUsBgIERERUcBiIEREREQBi4EQERERBSyVtyvg64QQAIDCwkIv14SIiIgcZXnftryP14SBUB2KiooAAElJSV6uCRERETmrqKgIERERNe6XRF2hUoCTZRlnz55FWFgYJEly23kLCwuRlJSEU6dOITw83G3npep4rxsG73PD4H1uGLzPDcOT91kIgaKiIiQmJkKhqDkTiC1CdVAoFGjevLnHzh8eHs5/ZA2E97ph8D43DN7nhsH73DA8dZ9rawmyYLI0ERERBSwGQkRERBSwGAh5iVarxYIFC6DVar1dlUaP97ph8D43DN7nhsH73DB84T4zWZqIiIgCFluEiIiIKGAxECIiIqKAxUCIiIiIAhYDISIiIgpYDIQ86OWXX0bLli2h0+nQt29f7N69u9byn3zyCTp06ACdToeuXbti48aNDVRT/+bMfX7jjTcwaNAgREVFISoqCsOHD6/z90KXOftMW3z44YeQJAnjxo3zbAUb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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "parameter_idx = 0\n",
    "with torch.no_grad():\n",
    "    plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "    plt.title(\"Learning Heat Equation for parameter = {k:.2f}\".format(k = x_train[parameter_idx,0,0,0]))\n",
    "    plt.xlabel(\"x\")\n",
    "    plt.plot(grid, mu[parameter_idx,:,t_idx,0], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "    plt.fill_between(grid, mu[parameter_idx,:,t_idx,0]+3*std[parameter_idx,:,t_idx,0], mu[parameter_idx,:,t_idx,0]-3*std[parameter_idx,:,t_idx,0], alpha=0.2)\n",
    "    plt.plot(grid, y_id_test[parameter_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "    plt.legend(loc=\"upper right\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "9f8b7bc5-6147-492a-bd22-6fe91fe7eb2e",
   "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",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "c754ecef-61e1-4e16-88a8-6c06f362d614",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(11.5860, grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(new_mu.unsqueeze(-1) - y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "4e4c98b6-a59b-49e2-a903-7d6173f11246",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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mSszZ86ETCbD2LFjkZ+fj1mzZmHgwIHYtm2brcyPP/6IXr16oU2bNpg0aRJkMhmWLFmCrl274tdff0W7du0AAH/88Qe2bNmCAQMGoF69ejh+/DgWLFiAzp07Y//+/eX+En3qqacQHx+PiRMnoqioyO615cuX47777oNKpcKDDz6IBQsW4I8//rD7yzI7OxtdunSB0WjEiy++iLCwMHzwwQcICQmxO1b//v0xaNCgcvufOHECv//+O9544w3bttdeew0TJkxAv3798Pjjj+PChQuYN28ebr/9duzevdvWIrJ+/XrcddddSE5OxqhRo5CUlIQDBw7g22+/xahRo/Dvf/8bZ8+exfr16/HJJ59U+H3Yt28fOnbsiMjISDz//PNQKpV4//330blzZ/z888/lxm25c19VF7lcjgcffBATJkzA5s2b0bt3b4fl5syZg48//hirV6/GggULEB4ejlatWgGwfLBPmTIF3bt3x5NPPolDhw7Zvue//fabXffexYsX0atXLwwYMAAPP/wwEhMTXdbPZDKhZ8+euPXWWzFr1iysW7fONhZl6tSptnJz587F3XffjYEDB0Kv12PFihV44IEH8O2335Z7Tz/++CO++OILjBw5EnFxcWjYsKHHx/j111/xzTffYMSIEQCAGTNm4K677sLzzz+P9957D0899RQuX76MWbNm4dFHH8WPP/5od/6Kfibvu+8+/PPPP/j888/x9ttvIy4uDoAlUAXcv9c9veY6nQ4FBQUuvydW1jpVtS5duqCwsBAqlQqZmZl488030bRpU9vru3fvBoByfzilpKSgXr16tteDjqAaacmSJQKA+OOPP5yWeeyxx0RycrLIzc212z5gwAARFRUliouLhRBCGI1GodPp7MpcvnxZJCYmikcffdS2LSsrSwAQkZGR4vz583blJ02aJADYlRdCiHvvvVfUqVPHbluDBg3E4MGDy72X7t27C7PZbNv+7LPPCrlcLvLy8oQQQmRnZwuFQiH69u1rd7zJkycLAHbHdAaAGDFihMsynTp1Ep06dbI9/+mnnwQAcf3119tdp7lz5woAYu/evUIIIcxms2jatKnIzMy0ex/FxcUiLS1N3HHHHXbbrrV161YBQHz88ce2bdZr06FDB2E0Gsvts2PHDgFArF+/3laHevXqiVGjRtmVGz16tAAgtm3bZtt2/vx5ERUV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Mdzhyc+ks3vQ3XvdGytXrnS7y85fwf2xY8fshl1Yg84dO3bYBUZnz57F6dOnMXz48Oquok9wzFItJZfLcf/99+M///mP7S/ZsspOnbb+tVT2h3Hbtm3YunVr1VfUA926dYNCoSiX9Ozdd9/1U43stWnTBo0bN8bs2bNtXS1lXXvNr/3lN2/ePKfTda9VUlKCVatW4a677sL//d//lXuMHDkSBQUF+OabbwAAd955J37//Xds377drj7O0gz0798fZ8+exUcffYQ///wT/fv3t3v9vvvug1wux5QpU8q9DyEELl68CAC4+eabkZaWhjlz5pQLBMvuZ80bVVGwKJfL0aNHD/z3v/+16xbKycnBZ599hg4dOlTY3esvJpMJzzzzDA4cOIBnnnnGq3p2794dKpUK77zzjt31W7RoEfLz853OrvNE2Z8nIQTeffddKJVKdOvWDYDleyBJkt29evz4cXz99ddun8MXx3CHJz+Tzu5Bd+91b/hrzNK5c+fKDblwlE5j7dq12LlzJ3r27GnbdsMNN6B58+b44IMP7L5/CxYsgCRJ+L//+z+f1rW6sGWphlu8eLEtb0lZo0aNwsyZM/HTTz8hIyMDw4YNQ3p6Oi5duoRdu3Zhw4YNuHTpEgBLbp1Vq1bh3nvvRe/evZGVlYWFCxciPT3d4S8Yf0lMTMSoUaPw5ptv4u6770bPnj3x559/4rvvvkNcXJzbrRM7duzAq6++Wm57586dvfpr30omk+Gjjz5Cr169cMMNN2Do0KGoW7cuzpw5g59++gmRkZH43//+B8ByzT/55BNERUUhPT0dW7duxYYNG1CnTh23zvXNN9+goKAAd999t8PXb731VsTHx2P58uXo378/nn/+eXzyySfo2bMnRo0aZUsd0KBBA/z111/l9r/zzjsRERGBsWPH2gLvsho3boxXX30V48ePx/Hjx9G3b19EREQgKysLq1evxvDhwzF27FjIZDIsWLAAffr0QevWrTF06FAkJyfj4MGD2LdvH77//nsAlg81AHjmmWeQmZkJuVyOAQMGOHxvr776KtavX48OHTrgqaeegkKhwPvvvw+dTodZs2a5df288e677yIvLw9nz54FAPzvf//D6dOnAVi6Va3jZQDLOJhPP/0UgCUpoTWD99GjRzFgwABMmzbNqzrEx8dj/PjxmDJlCnr27Im7774bhw4d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Q4cOHRAdHY06dergrrvuwtGjR8u952eeeQbPP/88YmNjkZSUhMmTJ1e6vp7o06cP7rzzTjRt2hTXXXcdXnvtNYSHh+P333+3K/f777+jW7duqFOnTrnWG+uyQmWtXbsWarUat956q23bBx98gJSUFJjN9vl47rnnHjz66KMA3L9uju5DtVqNpKQku0fZvEbdu3dHUlISZsyY4fKajBgxAiqVCj/88AM6deqE+vXro1evXtiwYQPOnDmDl19+udw1XLFihctj1nSVXfKE3XAUaBgskUvLli2DQqHA9u3bMXfuXLz11lv46KOP7F5XqVT47bffsHDhQgDAjBkz8PHHH2PhwoXYt28fnn32WTz88MP4+eefbfuNGzcOP//8M/773//ihx9+wKZNm7Br1y6n9Rg/fjxmzpyJCRMmYP/+/fjss8+QmJgIAJg7dy7at2+PYcOG2VoQUlNTq6QegGWx5euvv95uYebdu3cjJiYGDRo0cLhPUVERxowZgx07dmDjxo2QyWS49957ywUKy5YtQ1hYGLZt24ZZs2Zh6tSpWL9+faXq6y2TyYQVK1agqKgI7du3t23/888/0blzZ9x000349ddfsW7dOsTGxqJbt25YuXKlwyy4v/76q20RbKsHHngAFy9exE8//WTbdunSJaxbtw4DBw4E4Nl1u/Y+rIhcLsf06dMxb948nD592mGZS5cu4fvvv8dTTz1lSyhplZSUhIEDB2LlypUouxBCu3btsH37duh0OrfqURMp5DJ4myHBsswJP5oosDCDt5989OsxfPRrVoXlWtSNxEeDb7Hb9viyP/D3mfJ/vV/r8Y5peLxjI6/rCACpqal4++23IUkSmjVrhr179+Ltt9+2rZ/XtGlTzJo1y1Zep9Nh+vTp2LBhg+0DtlGjRti8eTPef/99dOrUCYWFhVi0aBE+/fRTdOvWDYDlw65evXoO61BQUIC5c+fi3XffxeDBgwEAjRs3RocOHQAAUVFRUKlUCA0NRVJSUpXVw+rPP//ETTfdZLdtz549uPHGG53uc//999s9X7x4MeLj47F//360aNHCtr1Vq1aYNGkSAMu1fffdd7Fx40bccccdXtd3+vTpmD59uu15SUkJfv/9d4wcOdK2bf/+/ahfvz4AYO/evWjfvj1KS0sRHh6O1atXIz093Vb2mWeewX333YfZs2cDANLT0/Hggw9i586d6Nevn8M6nDhxwrbotVVMTAx69eqFzz77zPZ+vvrqK8TFxaFLly4eXbdr70MA+PbbbxEefnW5jF69euHLL7+0K3PvvfeidevWmDRpEhYtWlSu3ocPH4YQAtdff73D93X99dfj8uXLuHDhAhISEgAAKSkp0Ov1yM7Odho81wYKuQSD0fM1T9QKWa3IRUXBhcGSnxSUGpGtLa2wXHK0pty2i0V6t/YtKDV6Vbeybr31VrtfXO3bt8ebb74Jk8kEAOVaC44cOYLi4mLccccddtv1er0twDh69Cj0ej0yMjJsr8fGxqJZs2YO63DgwAHodDrbB6o7qqIeVnv27MFDDz1kt2337t1o3bq1030OHz6MiRMnYtu2bcjNzbW1jJw8ebJcsFRWcnIyzp8/X6n6PvHEE3ZBzMCBA3H//ffjvvvus20rG8g0a9YMe/bsQX5+Pr766isMHjwYP//8M9LT05GTk4PNmzfbtc4BQFhYmMsPuJKSEruWuLJ1GTZsGN577z2o1WosX74cAwYMgOzKbCp3r9u19yEAdOnSBQsWLLCroyOvv/46unbtirFjxzqtvydLaFpboKyLetdWCpkMBpg83o9dcBSIGCz5SYRGgaTI8h8e16oTpnK4zZ19IzRV/+299gOosLAQALBmzRrUrVvX7jW1Wu3VOa7t/nBHVdQDsHRN/f333+Valnbt2lWuFaSsPn36oEGDBvjwww9t43RatGhRblC8Uqm0ey5JUrkuJ0/FxsYiNjbW9jwkJAQJCQlo0qSJw/Iqlcr2Wps2bfDHH39g7ty5eP/997Fz506YzeZyrWg7d+5E27ZtndYhLi7O4UDqPn36QAiBNWvW4JZbbsGvv/6Kt99+2+51d66bo0AoLCzM6Xss6/bbb0dmZibGjx+PIUOG2L3WpEkTSJKEAwcO4N577y2374EDBxATE4P4+HjbNuuA77LbaiOlXEKJF/upOROOAhCDJT95vGMjr7vIru2Wq0rbtm2ze/7777+jadOmThcATU9Ph1qtxsmTJ9GpUyeHZRo3bgylUolt27bZun4uX76Mf/75x+E+TZs2RUhICDZu3IjHH3/c4TFVKpWttauq6gEAhw4dQmlpqV1LzNatW3HmzBmnLUsXL17EoUOH8OGHH6Jjx44ALIPEPeVNfX3BbDbbxt9YA7eioiLbbMW//voLv/zyC1599VWnx7jpppsczhDTaDS47777sHz5chw5cgTNmjXDzTffDMB3180dM2fOROvWrcu10tWpUwd33HEH3nvvPTz77LN2gXt2djaWL1+OQYMG2bWq/f3336hXrx7i4uKqpK7BwtukkmxZokDEYIlcOnnyJMaMGYN///vf2LVrF+bNm+dyBlZERATGjh2LZ599FmazGR06dEB+fj5+++03REZGYvDgwQgPD8djjz2GcePGoU6dOkhISMDLL79s63q5lkajwQsvvIDnn38eKpUK//rXv3DhwgXs27fPNhW9YcOG2LZtG44fP47w8HDExsb6vB6ApQsOAObNm4dnnnkGR44cwTPPPAPAeeqEmJgY1KlTBx988AGSk5Nx8uRJvPjii+5cfjve1BewtLJZW9oA2GZqZWdn27bFx8dDLpdj/Pjx6NWrF+rXr4+CggJ89tln2LRpE77//nsAQEZGBkJCQjBu3Di8/PLLOHr0KEaMGIERI0bYzXS7lrXl5vLly4iJibF7beDAgbjrrruwb98+PPzww7btvrpu7mjZsiUGDhyId955p9xr7777Lm677TZkZmbi1VdfRVpaGvbt24dx48ahbt26tlmZVr/++it69OhRJfUMJkovZ8RpFAyWKPAwWCKXBg0ahJKSErRr1w5yuRyjRo3C8OHDXe4zbdo0xMfHY8aMGTh27Biio6Nx880346WXXrKVeeONN1BYWIg+ffogIiICzz33nMtEfhMmTIBCocDEiRNx9uxZJCcn44knnrC9PnbsWAwePBjp6ekoKSlBVlZWldRjz549yMzMxLFjx9CyZUukp6djypQpePLJJ/HOO+/gk08+KbePTCbDihUr8Mwzz6BFixZo1qwZ3nnnHXTu3NnldXTE0/oCwOzZszFlyhSXZbKystCwYUOcP38egwYNwrlz5xAVFYVWrVrh+++/t439io+PxxdffIHnnnsOrVq1Qv369TFy5EiMGTPG5fFbtmyJm2++GV988QX+/e9/273WtWtXxMbG4tChQ3ZjwXx53dwxdepUrFy5stz2pk2bYseOHZg0aRL69euHS5cuISkpCX379sWkSZPsujhLS0vx9ddfY926dVVSx2DiTcuSTAaoOBOOApAkPBm5SA5ptVpERUUhPz/fbtp0aWkpsrKykJaW5nBwa6Dr3LkzWrdujTlz5vi7KgEjMzMTt9xyi8su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jhw5YgtGAeCff/5BcnIyAyUXvLnWxcXF5QIia5AquAyrz/jls7DKho5ThVasWCHUarVYunSp2L9/vxg+fLiIjo4W2dnZQgghHnnkEfHiiy/ayv/2229CoVCI2bNniwMHDohJkyYxdYAbPL3OM2fOFCqVSnz11Vfi3LlztkdBQYG/3kJQ8PQ6X4uz4dzj6XU+efKkiIiIECNHjhSHDh0S3377rUhISBCvvvqqv95C0PD0Wk+aNElERESIzz//XBw7dkz88MMPonHjxqJfv37+egtBoaCgQOzevVvs3r1bABBvvfWW2L17tzhx4oQQQogXX3xRPPLII7by1tQB48aNEwcOHBDz589n6oCabt68eaJ+/fpCpVKJdu3aid9//932WqdOncTgwYPtyn/xxRfiuuuuEyqVStxwww1izZo11Vzj4OTJdW7QoIEAUO4xadKk6q94kPH0fi6LwZL7PL3OW7ZsERkZGUKtVotGjRqJ1157TRiNxmqudXDy5FobDAYxefJk0bhxY6HRaERqaqp46qmnxOXLl6u/4kHkp59+cvg713ptBw8eLDp16lRun9atWwuVSiUaNWoklixZUqV1lIRg2yARERGRMxyzREREROQCgyUiIiIiFxgsEREREbnAYImIiIjIBQZLRERERC4wWCIiIiJygcESERERkQsMloiIiIhcYLBERERE5AKDJSIiIiIXGCwREV3jwoULSEpKwvTp023btmzZApVKVW61cyKq+bg2HBGRA2vXrkXfvn2xZcsWNGvWDK1bt8Y999yDt956y99VI6JqxmCJiMiJESNGYMOGDWjbti327t2LP/74A2q12t/VIqJqxmCJiMiJkpIStGjRAqdOncLOnTvRsmVLf1eJiPyAY5aIiJw4evQozp49C7PZjOPHj/u7OkTkJ2xZIiJyQK/Xo127dmjdujWaNWuGOXPmYO/evUhISPB31YiomjFYIiJyYNy4cfjqq6/w559/Ijw8HJ06dUJUVBS+/fZbf1eNiKoZu+GIiK6xadMmzJkzB5988gkiIyMhk8nwySef4Ndff8WCBQv8XT0iqmZsWSIiIiJygS1LRERERC4wWCIiIiJygcESERERkQsMloiIiIhcYLBERERE5AKDJSIiIiIXGCwRERERucBgiYiIiMgFBktERERELjBYIiIiInKBwRIRERGRCwyWiIiIiFz4fzh72KKGeDciAAAAAElFTkSuQmCC",
      "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], '--', lw=2, label = \"predicted $\\mu$ and $\\pm 3\\sigma$ (varFNO)\")\n",
    "        plt.fill_between(grid, new_mu[parameters_idx,:,t_idx]+3*new_std[parameters_idx,:,t_idx], new_mu[parameters_idx,:,t_idx]-3*new_std[parameters_idx,:,t_idx], alpha=0.2)\n",
    "        plt.plot(grid, y_id_test[parameters_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "        plt.legend(loc=\"lower left\")\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "23d782f6-1d92-4ede-be84-48ec124c9414",
   "metadata": {},
   "outputs": [],
   "source": [
    "t_sliced = t[slice(*tpred)]\n",
    "mu = x_train[:,:,:,0]\n",
    "grid_train = torch.clone(grid)\n",
    "ts = repeat(t_sliced, \"nt -> nf nt\", nf=mu.shape[0])\n",
    "xs = repeat(grid_train, \"nx -> nf nx\", nf=mu.shape[0])\n",
    "inputs = meshgrid(ts, xs)\n",
    "inputs = inputs.to(mu.device)\n",
    "\n",
    "target_inputs = torch.clone(inputs)\n",
    "nf, nt, nx, _ = target_inputs.shape\n",
    "\n",
    "input_grid = rearrange(target_inputs, \"nf nt nx d -> nf nt nx d\", nt=nt, nx=nx)\n",
    "x_inp = input_grid[:, :, :, 1]\n",
    "\n",
    "x_delta = probconserv._get_riemman_delta(x_inp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "ada62ce2-9242-461e-8a76-95c06054ed2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = rearrange(x_delta, \"nf nt nx -> nf nt 1 nx\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "f19b36e9-4720-40a8-b5b5-c1840e1bbe09",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9, 1, 50])"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "g.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "04a57f50-3a30-49c0-a627-78110bf0276f",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_train_t = rearrange(y_train, \"nf nx nt 1 -> nf nt nx 1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "42032c17-23ff-40db-8cbf-95996526c083",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9, 1, 1])"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(g@y_train_t).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "3c614d6c-032a-42f4-9bf6-93918beb21df",
   "metadata": {},
   "outputs": [],
   "source": [
    "b = dataset_class.get_mass_rhs_func(x_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "49c5569b-9971-465c-a83f-52a6c9ec9e55",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.5000, 0.6663, 0.8325,  ..., 1.0000, 1.0000, 1.0000],\n",
       "        [0.5000, 0.6965, 0.8929,  ..., 1.0000, 1.0000, 1.0000],\n",
       "        [0.5000, 0.6209, 0.7419,  ..., 1.0000, 1.0000, 1.0000],\n",
       "        ...,\n",
       "        [0.5000, 0.6232, 0.7464,  ..., 1.0000, 1.0000, 1.0000],\n",
       "        [0.5000, 0.6549, 0.8098,  ..., 1.0000, 1.0000, 1.0000],\n",
       "        [0.5000, 0.6441, 0.7883,  ..., 1.0000, 1.0000, 1.0000]])"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b(inputs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "01cbf0be-518f-403c-a87e-3bdff9a28308",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9])"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "b(inputs).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "2cf9e8c2-83a5-4c95-87ab-60ec0d5220ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "import cvxpy as cp\n",
    "import torch\n",
    "from cvxpylayers.torch import CvxpyLayer\n",
    "\n",
    "# n, m = 2, 3\n",
    "# x = cp.Variable(n)\n",
    "# A = cp.Parameter((m, n))\n",
    "# b = cp.Parameter(m)\n",
    "# constraints = [x >= 0]\n",
    "# objective = cp.Minimize(0.5 * cp.pnorm(A @ x - b, p=1))\n",
    "# problem = cp.Problem(objective, constraints)\n",
    "# assert problem.is_dpp()\n",
    "\n",
    "# cvxpylayer = CvxpyLayer(problem, parameters=[A, b], variables=[x])\n",
    "# A_tch = torch.randn(m, n, requires_grad=True)\n",
    "# b_tch = torch.randn(m, requires_grad=True)\n",
    "\n",
    "# # solve the problem\n",
    "# solution, = cvxpylayer(A_tch, b_tch)\n",
    "\n",
    "# # compute the gradient of the sum of the solution with respect to A, b\n",
    "# solution.sum().backward()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "903a6bdc-a23c-4237-bff3-8b05799cb9df",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9, 50])"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_delta.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "16791329-3ad1-4dd9-874b-ea200fab65d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "mat = torch.zeros((20,20))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "6c00c7c3-9c48-49a1-a832-34eae8c92c4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "tt = repeat(g, \"nf nt 1 nx -> nf c (nt nx)\", c = nt)[0,0,0:100]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "2fedab6c-bc38-4b5a-83f7-35eb7e4938ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "tt = torch.zeros((nf, nt, nt*nx))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "03976597-e3e5-479d-8b23-dd3f6fd37472",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(nt):\n",
    "    tt[:,i,nx*i:nx*i+nx] = x_delta[:,i,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "cb46b879-fb6e-4bf9-ac54-91bb0a18fc94",
   "metadata": {},
   "outputs": [],
   "source": [
    "tt = tt.requires_grad_(True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "8990baa2-6233-404b-b028-0c6c15e64d2a",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu, var = model(x_train.to(device))\n",
    "std = torch.sqrt(var)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "ea1db30d-5433-4b29-b541-09022e5a09b7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 50, 9, 1])"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "400aa953-720c-4203-8691-0e4726dd4c71",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_shaped = rearrange(mu, \"nf nx nt 1->nf nt nx 1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "902de5f1-05a8-4bc4-af4e-b863a9f5f93d",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = g.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "1e821970-b49d-4245-b9c9-5f02bab87055",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9, 1, 1])"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(g@mu_shaped).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "63323e76-3afd-48a4-8806-c8f8b62f2769",
   "metadata": {},
   "outputs": [],
   "source": [
    "mu_r = rearrange(mu, \"nf nx nt 1 -> nf (nt nx) 1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "a3c5cf8d-587c-4de9-86b5-39b288f51597",
   "metadata": {},
   "outputs": [],
   "source": [
    "tt = tt.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "3fbc4ebe-a1c7-4894-be7c-ea1e397688a9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 450, 1])"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mu_r.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "fce7c6a6-0e2f-428e-b978-aea4aea88660",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([160, 9, 450])"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tt.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "cf778fee-f55e-4300-baca-4275bd6012fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[[0.5001]],\n",
       "\n",
       "         [[0.6699]],\n",
       "\n",
       "         [[0.8339]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0001]],\n",
       "\n",
       "         [[1.0007]],\n",
       "\n",
       "         [[1.0008]]],\n",
       "\n",
       "\n",
       "        [[[0.5010]],\n",
       "\n",
       "         [[0.6957]],\n",
       "\n",
       "         [[0.8888]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0000]],\n",
       "\n",
       "         [[1.0005]],\n",
       "\n",
       "         [[1.0004]]],\n",
       "\n",
       "\n",
       "        [[[0.4998]],\n",
       "\n",
       "         [[0.6245]],\n",
       "\n",
       "         [[0.7450]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0002]],\n",
       "\n",
       "         [[1.0007]],\n",
       "\n",
       "         [[1.0008]]],\n",
       "\n",
       "\n",
       "        ...,\n",
       "\n",
       "\n",
       "        [[[0.4999]],\n",
       "\n",
       "         [[0.6268]],\n",
       "\n",
       "         [[0.7497]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0003]],\n",
       "\n",
       "         [[1.0009]],\n",
       "\n",
       "         [[1.0010]]],\n",
       "\n",
       "\n",
       "        [[[0.5000]],\n",
       "\n",
       "         [[0.6590]],\n",
       "\n",
       "         [[0.8125]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0003]],\n",
       "\n",
       "         [[1.0010]],\n",
       "\n",
       "         [[1.0011]]],\n",
       "\n",
       "\n",
       "        [[[0.5000]],\n",
       "\n",
       "         [[0.6482]],\n",
       "\n",
       "         [[0.7916]],\n",
       "\n",
       "         ...,\n",
       "\n",
       "         [[1.0005]],\n",
       "\n",
       "         [[1.0012]],\n",
       "\n",
       "         [[1.0013]]]], device='cuda:0', grad_fn=<UnsafeViewBackward0>)"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "g@mu_shaped"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "c71d3a2e-6a21-40be-850b-ba7cfdc1e1a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[0.5001],\n",
       "         [0.6699],\n",
       "         [0.8339],\n",
       "         ...,\n",
       "         [1.0001],\n",
       "         [1.0007],\n",
       "         [1.0008]],\n",
       "\n",
       "        [[0.5010],\n",
       "         [0.6957],\n",
       "         [0.8888],\n",
       "         ...,\n",
       "         [1.0000],\n",
       "         [1.0005],\n",
       "         [1.0004]],\n",
       "\n",
       "        [[0.4998],\n",
       "         [0.6245],\n",
       "         [0.7450],\n",
       "         ...,\n",
       "         [1.0002],\n",
       "         [1.0007],\n",
       "         [1.0008]],\n",
       "\n",
       "        ...,\n",
       "\n",
       "        [[0.4999],\n",
       "         [0.6268],\n",
       "         [0.7497],\n",
       "         ...,\n",
       "         [1.0003],\n",
       "         [1.0009],\n",
       "         [1.0010]],\n",
       "\n",
       "        [[0.5000],\n",
       "         [0.6590],\n",
       "         [0.8125],\n",
       "         ...,\n",
       "         [1.0003],\n",
       "         [1.0010],\n",
       "         [1.0011]],\n",
       "\n",
       "        [[0.5000],\n",
       "         [0.6482],\n",
       "         [0.7916],\n",
       "         ...,\n",
       "         [1.0005],\n",
       "         [1.0012],\n",
       "         [1.0013]]], device='cuda:0', grad_fn=<UnsafeViewBackward0>)"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tt@mu_r"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "7ee7ebca-ca87-405d-9142-15f1aaf1a13f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.9152e-06, device='cuda:0', grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 56,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(((g@mu_shaped)).squeeze(-1) - tt@mu_r)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "ff452222-c366-47a9-81da-aa284d153215",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "A = cp.Parameter((tt.shape[1], tt.shape[2]))\n",
    "x = cp.Variable(tt.shape[2])\n",
    "y = cp.Variable(tt.shape[2])\n",
    "b = cp.Parameter(tt.shape[1])\n",
    "eta = cp.Parameter(tt.shape[2])\n",
    "weight_mat = cp.Parameter(tt.shape[2])\n",
    "\n",
    "constraints = [A@x == b,\n",
    "               y == x - eta\n",
    "              ]\n",
    "objective = cp.Minimize(cp.norm(cp.multiply(weight_mat, y)))\n",
    "problem = cp.Problem(objective, constraints)\n",
    "problem.is_dpp()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "11f2061d-1576-43ad-b5c9-2d5d8779eaf8",
   "metadata": {},
   "outputs": [],
   "source": [
    "cvxpylayer = CvxpyLayer(problem, parameters=[A, b, eta, weight_mat], variables=[x, y])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "id": "d3dcc940-0689-4c2e-a14e-40244da2c85e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([160, 9, 450]) torch.Size([160, 9]) torch.Size([160, 450]) torch.Size([160, 450])\n"
     ]
    }
   ],
   "source": [
    "A_tch = tt.to(device)\n",
    "b_tch = dataset_class.get_mass_rhs_func(x_train)(inputs)\n",
    "b_tch = b_tch.requires_grad_(True)\n",
    "b_tch = b_tch.to(device)\n",
    "\n",
    "eta_tch = rearrange(mu, \"nf nx nt 1 -> nf (nt nx)\")\n",
    "weight_mat_tch = rearrange(1/std, \"nf nx nt 1 -> nf (nt nx)\")\n",
    "\n",
    "\n",
    "print(A_tch.shape, b_tch.shape, eta_tch.shape, weight_mat_tch.shape)\n",
    "\n",
    "solution, _ = cvxpylayer(A_tch, b_tch, eta_tch, weight_mat_tch)\n",
    "\n",
    "# %timeit solution, _ = cvxpylayer(A_tch, b_tch, eta_tch, weight_mat_tch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "3508db28-d035-49fa-b4cc-fa585e4d6f34",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.9998, 1.0002, 0.9995,  ..., 1.0008, 1.0008, 0.9998],\n",
       "        [0.9986, 1.0016, 1.0008,  ..., 1.0003, 1.0010, 0.9992],\n",
       "        [1.0007, 1.0008, 1.0000,  ..., 0.9980, 0.9960, 0.9941],\n",
       "        ...,\n",
       "        [1.0006, 1.0008, 1.0001,  ..., 0.9984, 0.9965, 0.9948],\n",
       "        [0.9996, 0.9999, 0.9994,  ..., 1.0008, 1.0005, 1.0001],\n",
       "        [0.9997, 1.0000, 0.9998,  ..., 1.0005, 0.9999, 0.9998]],\n",
       "       device='cuda:0', grad_fn=<_CvxpyLayerFnFnBackward>)"
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "d9a8f396-9cca-4076-91cf-e936f9af094c",
   "metadata": {},
   "outputs": [],
   "source": [
    "solution_t = rearrange(solution, \"nf (nt nx) -> nf nx nt\", nx = mu.shape[1], nt = mu.shape[2]).cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "e99f1e28-359a-411a-8e80-f7a6f6be5612",
   "metadata": {},
   "outputs": [],
   "source": [
    "new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(mu=mu[:, :, :, 0].cpu(), std=std[:, :, :, 0].cpu(), mass_rhs_func=mass_rhs_func, t=t, tpred=tpred, grid_train=grid, precis_g=np.inf, second_deriv_alpha=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "e2f50c62-d5b3-49e5-b2e0-dda3b9c59867",
   "metadata": {},
   "outputs": [],
   "source": [
    "# %timeit new_mu, new_std, _, mass_rhs = probconserv.apply_constraint(mu=mu[:, :, :, 0], std=std[:, :, :, 0], mass_rhs_func=mass_rhs_func, t=t, tpred=tpred, grid_train=grid, precis_g=np.inf, second_deriv_alpha=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "62344632-e78d-4d75-aab6-a6cc752e9212",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 9.9856e-01,  9.9956e-01,  9.9709e-01,  9.9979e-01,  1.0090e+00,\n",
       "          1.0028e+00,  1.0004e+00,  9.9966e-01,  9.9852e-01],\n",
       "        [ 1.0016e+00,  9.9790e-01,  9.9852e-01,  9.9882e-01,  1.0018e+00,\n",
       "          1.0016e+00,  1.0003e+00,  9.9894e-01,  9.9882e-01],\n",
       "        [ 1.0008e+00,  9.9871e-01,  1.0007e+00,  9.9986e-01,  9.9931e-01,\n",
       "          1.0001e+00,  1.0004e+00,  1.0008e+00,  1.0006e+00],\n",
       "        [ 9.9946e-01,  9.9964e-01,  1.0009e+00,  1.0001e+00,  9.9949e-01,\n",
       "          1.0001e+00,  1.0009e+00,  1.0021e+00,  1.0015e+00],\n",
       "        [ 9.9893e-01,  9.9932e-01,  9.9910e-01,  9.9983e-01,  1.0002e+00,\n",
       "          1.0007e+00,  1.0012e+00,  1.0017e+00,  1.0008e+00],\n",
       "        [ 9.9898e-01,  9.9855e-01,  9.9789e-01,  9.9975e-01,  1.0006e+00,\n",
       "          1.0010e+00,  1.0011e+00,  1.0007e+00,  1.0002e+00],\n",
       "        [ 9.9911e-01,  9.9841e-01,  9.9894e-01,  9.9961e-01,  1.0004e+00,\n",
       "          1.0006e+00,  1.0007e+00,  1.0004e+00,  1.0003e+00],\n",
       "        [ 9.9924e-01,  9.9892e-01,  1.0009e+00,  9.9930e-01,  9.9998e-01,\n",
       "          1.0002e+00,  1.0003e+00,  1.0004e+00,  1.0004e+00],\n",
       "        [ 9.9929e-01,  9.9953e-01,  1.0011e+00,  9.9904e-01,  9.9954e-01,\n",
       "          1.0000e+00,  9.9978e-01,  1.0000e+00,  9.9999e-01],\n",
       "        [ 9.9903e-01,  9.9990e-01,  9.9976e-01,  9.9924e-01,  9.9897e-01,\n",
       "          9.9969e-01,  9.9927e-01,  9.9923e-01,  9.9975e-01],\n",
       "        [ 9.9931e-01,  1.0000e+00,  9.9911e-01,  9.9998e-01,  9.9873e-01,\n",
       "          9.9927e-01,  9.9915e-01,  9.9858e-01,  9.9988e-01],\n",
       "        [ 1.0010e+00,  9.9993e-01,  1.0001e+00,  1.0006e+00,  9.9907e-01,\n",
       "          9.9927e-01,  9.9954e-01,  9.9874e-01,  1.0001e+00],\n",
       "        [ 1.0011e+00,  9.9993e-01,  1.0015e+00,  1.0004e+00,  9.9955e-01,\n",
       "          9.9953e-01,  9.9983e-01,  9.9956e-01,  1.0003e+00],\n",
       "        [ 9.9882e-01,  1.0003e+00,  1.0016e+00,  9.9970e-01,  9.9994e-01,\n",
       "          9.9964e-01,  9.9958e-01,  1.0003e+00,  1.0005e+00],\n",
       "        [ 9.9906e-01,  1.0003e+00,  1.0003e+00,  9.9941e-01,  1.0004e+00,\n",
       "          9.9974e-01,  9.9931e-01,  1.0004e+00,  1.0002e+00],\n",
       "        [ 1.0010e+00,  9.9935e-01,  9.9906e-01,  9.9994e-01,  1.0007e+00,\n",
       "          9.9991e-01,  9.9954e-01,  1.0001e+00,  1.0001e+00],\n",
       "        [ 1.0000e+00,  9.9830e-01,  9.9910e-01,  1.0008e+00,  1.0009e+00,\n",
       "          9.9987e-01,  9.9993e-01,  9.9999e-01,  1.0006e+00],\n",
       "        [ 9.9769e-01,  9.9843e-01,  9.9971e-01,  1.0009e+00,  1.0006e+00,\n",
       "          9.9973e-01,  9.9990e-01,  1.0001e+00,  1.0011e+00],\n",
       "        [ 9.9956e-01,  9.9974e-01,  9.9968e-01,  1.0003e+00,  1.0003e+00,\n",
       "          9.9986e-01,  9.9958e-01,  1.0002e+00,  1.0006e+00],\n",
       "        [ 1.0008e+00,  1.0001e+00,  9.9910e-01,  1.0001e+00,  1.0002e+00,\n",
       "          1.0002e+00,  9.9935e-01,  9.9999e-01,  1.0002e+00],\n",
       "        [ 9.9972e-01,  9.9866e-01,  9.9882e-01,  1.0005e+00,  1.0005e+00,\n",
       "          1.0003e+00,  9.9931e-01,  9.9958e-01,  1.0006e+00],\n",
       "        [ 1.0024e+00,  9.9881e-01,  9.9899e-01,  1.0007e+00,  1.0007e+00,\n",
       "          1.0003e+00,  9.9944e-01,  9.9928e-01,  1.0009e+00],\n",
       "        [ 9.9903e-01,  1.0008e+00,  9.9927e-01,  1.0002e+00,  1.0006e+00,\n",
       "          1.0002e+00,  9.9965e-01,  9.9936e-01,  1.0006e+00],\n",
       "        [ 1.0185e+00,  9.9923e-01,  9.9956e-01,  9.9940e-01,  1.0005e+00,\n",
       "          1.0002e+00,  9.9974e-01,  9.9971e-01,  1.0002e+00],\n",
       "        [ 8.4513e-01,  9.9864e-01,  9.9967e-01,  9.9878e-01,  1.0007e+00,\n",
       "          1.0003e+00,  9.9980e-01,  9.9999e-01,  1.0002e+00],\n",
       "        [ 1.4744e-01,  1.0006e+00,  9.9959e-01,  9.9901e-01,  1.0010e+00,\n",
       "          1.0003e+00,  1.0001e+00,  1.0000e+00,  1.0004e+00],\n",
       "        [-3.6457e-02,  1.0000e+00,  9.9961e-01,  1.0002e+00,  1.0012e+00,\n",
       "          1.0002e+00,  1.0006e+00,  9.9985e-01,  1.0004e+00],\n",
       "        [ 7.8184e-03,  9.9775e-01,  9.9912e-01,  1.0003e+00,  1.0006e+00,\n",
       "          1.0003e+00,  1.0007e+00,  9.9965e-01,  1.0003e+00],\n",
       "        [ 4.8298e-04,  1.0013e+00,  9.9860e-01,  9.9904e-01,  9.9935e-01,\n",
       "          1.0007e+00,  1.0004e+00,  9.9939e-01,  1.0000e+00],\n",
       "        [ 3.2161e-03,  9.9921e-01,  9.9847e-01,  9.9811e-01,  9.9881e-01,\n",
       "          1.0006e+00,  1.0000e+00,  9.9898e-01,  9.9937e-01],\n",
       "        [ 3.4151e-03,  9.9330e-01,  9.9895e-01,  9.9840e-01,  9.9944e-01,\n",
       "          1.0002e+00,  9.9976e-01,  9.9854e-01,  9.9871e-01],\n",
       "        [ 3.0349e-03,  1.0108e+00,  1.0001e+00,  9.9941e-01,  1.0002e+00,\n",
       "          9.9985e-01,  9.9967e-01,  9.9823e-01,  9.9856e-01],\n",
       "        [ 1.7837e-03,  1.0314e+00,  1.0010e+00,  1.0000e+00,  1.0000e+00,\n",
       "          1.0001e+00,  9.9961e-01,  9.9807e-01,  9.9867e-01],\n",
       "        [ 2.3280e-03,  9.1248e-01,  1.0009e+00,  9.9912e-01,  9.9945e-01,\n",
       "          1.0004e+00,  9.9948e-01,  9.9812e-01,  9.9850e-01],\n",
       "        [ 2.9164e-03,  5.5057e-01,  9.9956e-01,  9.9792e-01,  9.9980e-01,\n",
       "          1.0003e+00,  9.9950e-01,  9.9855e-01,  9.9814e-01],\n",
       "        [ 1.1054e-03,  1.5906e-01,  9.9787e-01,  9.9800e-01,  1.0006e+00,\n",
       "          1.0000e+00,  9.9993e-01,  9.9921e-01,  9.9803e-01],\n",
       "        [ 7.7544e-04, -3.7149e-03,  9.9703e-01,  9.9878e-01,  1.0003e+00,\n",
       "          9.9994e-01,  1.0006e+00,  9.9983e-01,  9.9840e-01],\n",
       "        [ 2.5660e-03, -1.0855e-02,  9.9708e-01,  9.9948e-01,  9.9970e-01,\n",
       "          1.0001e+00,  1.0012e+00,  1.0004e+00,  9.9906e-01],\n",
       "        [ 1.3072e-03,  4.1078e-03,  9.9680e-01,  9.9989e-01,  9.9990e-01,\n",
       "          1.0003e+00,  1.0014e+00,  1.0010e+00,  9.9961e-01],\n",
       "        [-8.1269e-05,  3.3013e-03,  9.9950e-01,  9.9962e-01,  1.0005e+00,\n",
       "          1.0005e+00,  1.0011e+00,  1.0016e+00,  9.9976e-01],\n",
       "        [ 1.8444e-03, -1.2566e-03,  1.0129e+00,  9.9880e-01,  1.0006e+00,\n",
       "          1.0005e+00,  1.0009e+00,  1.0020e+00,  9.9970e-01],\n",
       "        [ 2.5576e-03,  8.6088e-04,  1.0232e+00,  9.9862e-01,  9.9980e-01,\n",
       "          9.9993e-01,  1.0009e+00,  1.0020e+00,  9.9993e-01],\n",
       "        [ 2.7255e-04,  2.4714e-03,  9.7293e-01,  9.9962e-01,  9.9808e-01,\n",
       "          9.9937e-01,  1.0008e+00,  1.0017e+00,  1.0007e+00],\n",
       "        [-1.0231e-03,  4.8053e-04,  7.7291e-01,  9.9958e-01,  9.9709e-01,\n",
       "          9.9952e-01,  1.0003e+00,  1.0012e+00,  1.0016e+00],\n",
       "        [-8.4410e-04, -5.6438e-04,  4.0119e-01,  9.9713e-01,  9.9796e-01,\n",
       "          9.9967e-01,  9.9960e-01,  1.0010e+00,  1.0015e+00],\n",
       "        [-7.3520e-04, -1.0113e-03,  1.0172e-01,  9.9550e-01,  1.0000e+00,\n",
       "          9.9907e-01,  9.9924e-01,  1.0012e+00,  1.0004e+00],\n",
       "        [-7.6261e-04, -1.3618e-03,  1.7987e-03,  9.9995e-01,  1.0013e+00,\n",
       "          9.9848e-01,  9.9917e-01,  1.0011e+00,  9.9961e-01],\n",
       "        [-8.8946e-04, -1.7909e-03, -4.4861e-03,  1.0134e+00,  9.9920e-01,\n",
       "          9.9859e-01,  9.9898e-01,  1.0001e+00,  1.0003e+00],\n",
       "        [-8.5171e-04, -2.9221e-03, -1.5271e-03,  1.0239e+00,  9.9526e-01,\n",
       "          9.9872e-01,  9.9873e-01,  9.9847e-01,  1.0010e+00],\n",
       "        [-1.3973e-04, -7.7308e-04, -5.0785e-03,  9.7847e-01,  1.0031e+00,\n",
       "          9.9735e-01,  9.9871e-01,  9.9941e-01,  9.9917e-01]],\n",
       "       grad_fn=<SliceBackward0>)"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "solution_t[1,:,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "46a83396-68e1-4a19-84ae-aeaeef821d80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 9.9856e-01,  9.9956e-01,  9.9709e-01,  9.9979e-01,  1.0090e+00,\n",
       "          1.0028e+00,  1.0004e+00,  9.9966e-01,  9.9852e-01],\n",
       "        [ 1.0016e+00,  9.9790e-01,  9.9852e-01,  9.9882e-01,  1.0018e+00,\n",
       "          1.0016e+00,  1.0003e+00,  9.9894e-01,  9.9882e-01],\n",
       "        [ 1.0008e+00,  9.9871e-01,  1.0007e+00,  9.9986e-01,  9.9931e-01,\n",
       "          1.0001e+00,  1.0004e+00,  1.0008e+00,  1.0006e+00],\n",
       "        [ 9.9946e-01,  9.9964e-01,  1.0009e+00,  1.0001e+00,  9.9949e-01,\n",
       "          1.0001e+00,  1.0009e+00,  1.0021e+00,  1.0015e+00],\n",
       "        [ 9.9893e-01,  9.9932e-01,  9.9910e-01,  9.9983e-01,  1.0002e+00,\n",
       "          1.0007e+00,  1.0012e+00,  1.0017e+00,  1.0008e+00],\n",
       "        [ 9.9898e-01,  9.9855e-01,  9.9789e-01,  9.9975e-01,  1.0006e+00,\n",
       "          1.0010e+00,  1.0011e+00,  1.0007e+00,  1.0002e+00],\n",
       "        [ 9.9911e-01,  9.9841e-01,  9.9894e-01,  9.9961e-01,  1.0004e+00,\n",
       "          1.0006e+00,  1.0007e+00,  1.0004e+00,  1.0003e+00],\n",
       "        [ 9.9924e-01,  9.9892e-01,  1.0009e+00,  9.9930e-01,  9.9998e-01,\n",
       "          1.0002e+00,  1.0003e+00,  1.0004e+00,  1.0004e+00],\n",
       "        [ 9.9929e-01,  9.9953e-01,  1.0011e+00,  9.9904e-01,  9.9954e-01,\n",
       "          1.0000e+00,  9.9978e-01,  1.0000e+00,  9.9999e-01],\n",
       "        [ 9.9903e-01,  9.9990e-01,  9.9976e-01,  9.9924e-01,  9.9897e-01,\n",
       "          9.9969e-01,  9.9927e-01,  9.9923e-01,  9.9975e-01],\n",
       "        [ 9.9931e-01,  1.0000e+00,  9.9911e-01,  9.9998e-01,  9.9873e-01,\n",
       "          9.9927e-01,  9.9915e-01,  9.9858e-01,  9.9988e-01],\n",
       "        [ 1.0010e+00,  9.9993e-01,  1.0001e+00,  1.0006e+00,  9.9907e-01,\n",
       "          9.9927e-01,  9.9954e-01,  9.9874e-01,  1.0001e+00],\n",
       "        [ 1.0011e+00,  9.9993e-01,  1.0015e+00,  1.0004e+00,  9.9955e-01,\n",
       "          9.9953e-01,  9.9983e-01,  9.9956e-01,  1.0003e+00],\n",
       "        [ 9.9882e-01,  1.0003e+00,  1.0016e+00,  9.9970e-01,  9.9994e-01,\n",
       "          9.9964e-01,  9.9958e-01,  1.0003e+00,  1.0005e+00],\n",
       "        [ 9.9906e-01,  1.0003e+00,  1.0003e+00,  9.9941e-01,  1.0004e+00,\n",
       "          9.9974e-01,  9.9931e-01,  1.0004e+00,  1.0002e+00],\n",
       "        [ 1.0010e+00,  9.9935e-01,  9.9906e-01,  9.9994e-01,  1.0007e+00,\n",
       "          9.9991e-01,  9.9954e-01,  1.0001e+00,  1.0001e+00],\n",
       "        [ 1.0000e+00,  9.9830e-01,  9.9910e-01,  1.0008e+00,  1.0009e+00,\n",
       "          9.9987e-01,  9.9993e-01,  9.9999e-01,  1.0006e+00],\n",
       "        [ 9.9769e-01,  9.9843e-01,  9.9971e-01,  1.0009e+00,  1.0006e+00,\n",
       "          9.9973e-01,  9.9990e-01,  1.0001e+00,  1.0011e+00],\n",
       "        [ 9.9956e-01,  9.9974e-01,  9.9968e-01,  1.0003e+00,  1.0003e+00,\n",
       "          9.9986e-01,  9.9958e-01,  1.0002e+00,  1.0006e+00],\n",
       "        [ 1.0008e+00,  1.0001e+00,  9.9910e-01,  1.0001e+00,  1.0002e+00,\n",
       "          1.0002e+00,  9.9935e-01,  9.9999e-01,  1.0002e+00],\n",
       "        [ 9.9972e-01,  9.9866e-01,  9.9882e-01,  1.0005e+00,  1.0005e+00,\n",
       "          1.0003e+00,  9.9931e-01,  9.9958e-01,  1.0006e+00],\n",
       "        [ 1.0024e+00,  9.9881e-01,  9.9899e-01,  1.0007e+00,  1.0007e+00,\n",
       "          1.0003e+00,  9.9944e-01,  9.9928e-01,  1.0009e+00],\n",
       "        [ 9.9903e-01,  1.0008e+00,  9.9927e-01,  1.0002e+00,  1.0006e+00,\n",
       "          1.0002e+00,  9.9965e-01,  9.9936e-01,  1.0006e+00],\n",
       "        [ 1.0185e+00,  9.9923e-01,  9.9956e-01,  9.9940e-01,  1.0005e+00,\n",
       "          1.0002e+00,  9.9974e-01,  9.9971e-01,  1.0002e+00],\n",
       "        [ 8.4513e-01,  9.9864e-01,  9.9967e-01,  9.9878e-01,  1.0007e+00,\n",
       "          1.0003e+00,  9.9980e-01,  9.9999e-01,  1.0002e+00],\n",
       "        [ 1.4744e-01,  1.0006e+00,  9.9959e-01,  9.9901e-01,  1.0010e+00,\n",
       "          1.0003e+00,  1.0001e+00,  1.0000e+00,  1.0004e+00],\n",
       "        [-3.6457e-02,  1.0000e+00,  9.9961e-01,  1.0002e+00,  1.0012e+00,\n",
       "          1.0002e+00,  1.0006e+00,  9.9985e-01,  1.0004e+00],\n",
       "        [ 7.8184e-03,  9.9775e-01,  9.9912e-01,  1.0003e+00,  1.0006e+00,\n",
       "          1.0003e+00,  1.0007e+00,  9.9965e-01,  1.0003e+00],\n",
       "        [ 4.8298e-04,  1.0013e+00,  9.9860e-01,  9.9904e-01,  9.9935e-01,\n",
       "          1.0007e+00,  1.0004e+00,  9.9939e-01,  1.0000e+00],\n",
       "        [ 3.2161e-03,  9.9921e-01,  9.9847e-01,  9.9811e-01,  9.9881e-01,\n",
       "          1.0006e+00,  1.0000e+00,  9.9898e-01,  9.9937e-01],\n",
       "        [ 3.4151e-03,  9.9330e-01,  9.9895e-01,  9.9840e-01,  9.9944e-01,\n",
       "          1.0002e+00,  9.9976e-01,  9.9854e-01,  9.9871e-01],\n",
       "        [ 3.0349e-03,  1.0108e+00,  1.0001e+00,  9.9941e-01,  1.0002e+00,\n",
       "          9.9985e-01,  9.9967e-01,  9.9823e-01,  9.9856e-01],\n",
       "        [ 1.7837e-03,  1.0314e+00,  1.0010e+00,  1.0000e+00,  1.0000e+00,\n",
       "          1.0001e+00,  9.9961e-01,  9.9807e-01,  9.9867e-01],\n",
       "        [ 2.3280e-03,  9.1248e-01,  1.0009e+00,  9.9912e-01,  9.9945e-01,\n",
       "          1.0004e+00,  9.9948e-01,  9.9812e-01,  9.9850e-01],\n",
       "        [ 2.9164e-03,  5.5057e-01,  9.9956e-01,  9.9792e-01,  9.9980e-01,\n",
       "          1.0003e+00,  9.9950e-01,  9.9855e-01,  9.9814e-01],\n",
       "        [ 1.1054e-03,  1.5906e-01,  9.9787e-01,  9.9800e-01,  1.0006e+00,\n",
       "          1.0000e+00,  9.9993e-01,  9.9921e-01,  9.9803e-01],\n",
       "        [ 7.7544e-04, -3.7149e-03,  9.9703e-01,  9.9878e-01,  1.0003e+00,\n",
       "          9.9994e-01,  1.0006e+00,  9.9983e-01,  9.9840e-01],\n",
       "        [ 2.5660e-03, -1.0855e-02,  9.9708e-01,  9.9948e-01,  9.9970e-01,\n",
       "          1.0001e+00,  1.0012e+00,  1.0004e+00,  9.9906e-01],\n",
       "        [ 1.3072e-03,  4.1078e-03,  9.9680e-01,  9.9989e-01,  9.9990e-01,\n",
       "          1.0003e+00,  1.0014e+00,  1.0010e+00,  9.9961e-01],\n",
       "        [-8.1269e-05,  3.3013e-03,  9.9950e-01,  9.9962e-01,  1.0005e+00,\n",
       "          1.0005e+00,  1.0011e+00,  1.0016e+00,  9.9976e-01],\n",
       "        [ 1.8444e-03, -1.2566e-03,  1.0129e+00,  9.9880e-01,  1.0006e+00,\n",
       "          1.0005e+00,  1.0009e+00,  1.0020e+00,  9.9970e-01],\n",
       "        [ 2.5576e-03,  8.6088e-04,  1.0232e+00,  9.9862e-01,  9.9980e-01,\n",
       "          9.9993e-01,  1.0009e+00,  1.0020e+00,  9.9993e-01],\n",
       "        [ 2.7255e-04,  2.4714e-03,  9.7293e-01,  9.9962e-01,  9.9808e-01,\n",
       "          9.9937e-01,  1.0008e+00,  1.0017e+00,  1.0007e+00],\n",
       "        [-1.0231e-03,  4.8053e-04,  7.7291e-01,  9.9958e-01,  9.9709e-01,\n",
       "          9.9952e-01,  1.0003e+00,  1.0012e+00,  1.0016e+00],\n",
       "        [-8.4410e-04, -5.6438e-04,  4.0119e-01,  9.9713e-01,  9.9796e-01,\n",
       "          9.9967e-01,  9.9960e-01,  1.0010e+00,  1.0015e+00],\n",
       "        [-7.3520e-04, -1.0113e-03,  1.0172e-01,  9.9550e-01,  1.0000e+00,\n",
       "          9.9907e-01,  9.9924e-01,  1.0012e+00,  1.0004e+00],\n",
       "        [-7.6261e-04, -1.3618e-03,  1.7987e-03,  9.9995e-01,  1.0013e+00,\n",
       "          9.9848e-01,  9.9917e-01,  1.0011e+00,  9.9961e-01],\n",
       "        [-8.8946e-04, -1.7909e-03, -4.4861e-03,  1.0134e+00,  9.9920e-01,\n",
       "          9.9859e-01,  9.9898e-01,  1.0001e+00,  1.0003e+00],\n",
       "        [-8.5171e-04, -2.9221e-03, -1.5271e-03,  1.0239e+00,  9.9526e-01,\n",
       "          9.9872e-01,  9.9873e-01,  9.9847e-01,  1.0010e+00],\n",
       "        [-1.3973e-04, -7.7308e-04, -5.0785e-03,  9.7847e-01,  1.0031e+00,\n",
       "          9.9735e-01,  9.9871e-01,  9.9941e-01,  9.9917e-01]],\n",
       "       grad_fn=<SliceBackward0>)"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_mu[1,:,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "68d09dda-7580-4137-9955-cc47e5ab990d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(6.0761e-07, grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(solution_t.cpu() - new_mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "dcac6ddf-e4cb-402c-8d4c-06724a9e9f59",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = cp.Parameter((tt.shape[1], tt.shape[2]))\n",
    "x = cp.Variable(tt.shape[2])\n",
    "y = cp.Variable(tt.shape[2])\n",
    "b = cp.Parameter(tt.shape[1])\n",
    "eta = cp.Parameter(tt.shape[2])\n",
    "lbda = 5.0\n",
    "weight_mat = cp.Parameter(tt.shape[2])\n",
    "\n",
    "constraints = [A@x == b,\n",
    "               y == x - eta,\n",
    "               # cp.norm1(x[1] - x[:-1]) <=1e-15\n",
    "              ]\n",
    "# for i in range(20):\n",
    "#     xs1 = x[i*100:100*(i+1)]\n",
    "#     # xs2 = x[(i+1)*100:100*(i+2)]\n",
    "#     # tvd2 = cp.norm1(xs2[1:] - xs2[:-1])\n",
    "#     tvd1 = cp.norm1(xs1[1:] - xs1[:-1])\n",
    "#     constraints.append(tvd1 <= 1e-10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "9fe1c71d-159b-40ae-95ea-566afa90a9c7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "objective = cp.Minimize(cp.norm(cp.multiply(weight_mat, y)) \n",
    "                        + lbda*cp.norm1(x[1:] - x[:-1])\n",
    "                       )\n",
    "problem = cp.Problem(objective, constraints)\n",
    "problem.is_dpp()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "37f1d7f9-27ff-4fa7-8db8-353d27a851ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "cvxpylayer = CvxpyLayer(problem, parameters=[A, b, eta, weight_mat], variables=[x, y])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "e5b8067c-7f54-403e-bbca-46c067dd75b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([160, 9, 450]) torch.Size([160, 9]) torch.Size([160, 450]) torch.Size([160, 450])\n"
     ]
    }
   ],
   "source": [
    "A_tch = tt.to(device)\n",
    "b_tch = dataset_class.get_mass_rhs_func(x_train)(inputs)\n",
    "b_tch = b_tch.requires_grad_(True)\n",
    "b_tch = b_tch.to(device)\n",
    "\n",
    "eta_tch = rearrange(mu, \"nf nx nt 1 -> nf (nt nx)\")\n",
    "weight_mat_tch = rearrange(1/std, \"nf nx nt 1 -> nf (nt nx)\")\n",
    "\n",
    "\n",
    "print(A_tch.shape, b_tch.shape, eta_tch.shape, weight_mat_tch.shape)\n",
    "\n",
    "solution, _ = cvxpylayer(A_tch, b_tch, eta_tch, weight_mat_tch)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "996903ab-f46c-4aae-91b2-d4db9a64341e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.0000, 1.0000, 0.9995,  ..., 1.0008, 1.0008, 0.9999],\n",
       "        [0.9991, 1.0010, 1.0008,  ..., 1.0003, 1.0010, 0.9992],\n",
       "        [1.0007, 1.0007, 1.0000,  ..., 0.9980, 0.9960, 0.9960],\n",
       "        ...,\n",
       "        [1.0007, 1.0007, 1.0001,  ..., 0.9984, 0.9964, 0.9964],\n",
       "        [0.9997, 0.9997, 0.9995,  ..., 1.0006, 1.0005, 1.0004],\n",
       "        [0.9999, 0.9999, 0.9999,  ..., 1.0004, 1.0000, 1.0000]],\n",
       "       device='cuda:0', grad_fn=<_CvxpyLayerFnFnBackward>)"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "27970a91-ce3f-4138-9a9c-3df71313e3c2",
   "metadata": {},
   "outputs": [],
   "source": [
    "solution_t = rearrange(solution, \"nf (nt nx) -> nf nx nt\", nx = mu.shape[1], nt = mu.shape[2]).cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "10ba3674-f19b-421f-a7db-63f1d2b33d58",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(6.9086, grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(solution_t.cpu() - new_mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "a39f2af8-8d0f-4ec6-9234-015497432125",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "15.654989957809448\n"
     ]
    }
   ],
   "source": [
    "s = time.time()\n",
    "solution.sum().backward()\n",
    "e = time.time()\n",
    "print(e-s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "e951e32c-7e80-4f25-9a21-01905a23df7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# %%time \n",
    "# solution, _ = cvxpylayer(A_tch, b_tch, eta_tch, weight_mat_tch)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a7d4bad0-3d98-4465-a68d-ead3430acd08",
   "metadata": {},
   "source": [
    "# nn.MSELoss()(y_train[:,:,:,0], solution_t)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "708391cc-f819-4b82-9b44-56750ff5ce1b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0019, grad_fn=<MseLossBackward0>)"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nn.MSELoss()(y_train[:,:,:,0], new_mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "ae180450-5567-43aa-ab2c-e36f5cd43447",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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GKzlt86aL63MwvLmZxEcHAyg6J+XVqstM+ayjgVgfTO69cqRkJAQa92qVF58//zzDwAgMTGx1DaysrIQHByMgoICJCUlYeXKlbh48aJNImFvLoa9c24ymbB27Vrce++9SE5OtpbHx8dj7ty52LZtGx544AEARefO3mXijRs3LlE2YMAAfP3119i1axc6deqE06dPY9++fZg3b561zj///AMhhE13dXGWoZHTp08DAJo3b263XkVdvXoV+fn5duO+8847YTabcf78eTRr1sxaXt7vrbrl5uYCgM2bsqMsfwO3Pn+VSoX69euXSNhiY2MrNEFeJpOVmHN1xx13AIDN/JPvvvsOb775Jg4ePAidTmctt5ewlvb/oiJt3Po7DAwMBADExcXZLa/M32RpHH2tW1TknEdHRyM6Otqhuq7QuXNnxMfH201si//OLAoLC0sMdbsTJjduwPJp5Jlnnin1D9syhv/pp59i0KBB6NevHyZOnIiIiAjI5XIkJSVZ35yKK+vFa693AUCJCYnOPrY6lBef5Zy/8847JeYpWVg+tb/00ktYuXIlxo4di44dOyIwMBCSJOGJJ56w+0nS3jn/6aefcPnyZaxduxZr164tsX/NmjXW5KYi+vbtC19fX3z++efo1KkTPv/8c8hkMvz73/+21jGbzZAkCd9//73d82J5njVBTXtd/f333wBKJulVoSreaH799Vc8/PDD6Nq1Kz744ANER0dDqVRi5cqV+OyzzxyKoaJtlPY7dObfZGkq+lqvyDkvKCgoc2J5cc6aLFxRcXFxOHHihHXbkoxdvny5RHJ5+fJlm95hd8Pkxg2Eh4cjICAAJpMJPXv2LLPul19+ifr162P9+vU2n5pq2uXEderUAQCcOnXK5tPgtWvXXPYpvLgGDRoAKBraceScJyYmYu7cudaywsLCCi0gtmbNGkRERFivNCpu/fr12LBhA5YuXQofHx/UqVPH+im2uOL/tCz8/PzQp08ffPHFF3jvvfewbt06dOnSBTExMdY6DRo0gBAC9erVs36yt8dyTv7+++8yz4mjQ1Th4eHw9fW1G/fx48chk8lK/MOtSUwmEz777DP4+vqic+fOFT7e8jdw4sQJmx4WvV6P5OTkcl935TGbzThz5ozN7/TkyZMAYB0W+uqrr6DRaPDDDz/YDE2sXLnS4cdxRhuOqMjfZGmvQUdf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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        plt.ylabel(\"u(x,t={t:.2f})\".format(t=t[slice(*tpred)][t_idx]))\n",
    "        plt.title(\"Learning {dataset} for parameter = {k:.2f}\".format(k = x_train[parameters_idx,0,0,0], dataset = dataset))\n",
    "        plt.xlabel(\"x\")\n",
    "        plt.plot(grid, solution_t[parameters_idx,:,t_idx], '--', lw=3, label = \"predicted $\\mu$ (TVD, Nonlinear)\")\n",
    "        plt.plot(grid, new_mu[parameters_idx,:,t_idx], '--', lw=3, label = \"predicted $\\mu$\")\\\n",
    "        # plt.fill_between(grid, new_mu[parameters_idx,:,t_idx]+3*new_std[parameters_idx,:,t_idx], new_mu[parameters_idx,:,t_idx]-3*new_std[parameters_idx,:,t_idx], alpha=0.2)\n",
    "        plt.plot(grid, y_train[parameters_idx,:,t_idx,:], color = \"green\", label = \"true\")\n",
    "        plt.legend(loc=\"lower left\")\n",
    "        # plt.ylim(-1.0,1.5)\n",
    "        plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "191e957c-4b9c-487b-8e4c-00685d51d108",
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch.distributions import MultivariateNormal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "d179af31-01fd-424b-b96c-5659049aecae",
   "metadata": {},
   "outputs": [],
   "source": [
    "dist = torch.distributions.Normal(rearrange(mu, \"nf nx nt 1 -> nf (nt nx)\"), rearrange(std, \"nf nx nt 1 -> nf (nt nx)\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "id": "398e5533-f537-482f-a722-c9af6cd1f64d",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_samples = 50"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "215f431e-01a2-4feb-9535-004127c1a9e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "samples = dist.sample((n_samples,))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "42d0ee62-c22a-454b-a60a-24ab14a29b7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "r_samples = rearrange(samples, \"ns nf ntnx -> (ns nf) ntnx \")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "c89fd3a3-9fae-463e-8c4a-f7e5e619f969",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([8000, 450])"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "r_samples.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "887fce27-f7e6-4c33-9634-df5d617b81cf",
   "metadata": {},
   "outputs": [],
   "source": [
    "A_tch_1 = repeat(A_tch, \"nf nx nt -> (nf1 nf) nx nt\", nf1 = n_samples)\n",
    "b_tch_1 = repeat(b_tch, \"nf nx -> (nf1 nf) nx\", nf1 = n_samples)\n",
    "weight_mat_tch_1 = repeat(weight_mat_tch, \"nf nxnt -> (nf1 nf) nxnt\", nf1 = n_samples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "19b5a7ad-0891-4a13-b940-9e9c442d75c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "solutions, _ = cvxpylayer(A_tch_1, b_tch_1, r_samples, weight_mat_tch_1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "id": "964880ea-06da-4cea-a594-b343a5fd3922",
   "metadata": {},
   "outputs": [],
   "source": [
    "solutions_r = rearrange(solutions, \"(ns n1) n2 -> ns n1 n2\", ns = n_samples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "b8265651-a70b-4886-875c-e1bf9fcdf63e",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_mu = solutions_r.mean(dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "id": "19c4c2b7-aa2b-4acb-87cd-67746f7f4d1f",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_std = solutions_r.std(dim = 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "9cb6a78d-e5d5-4053-9397-d797a43c6a1e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.9998, 1.0002, 0.9994,  ..., 1.0006, 1.0009, 1.0001],\n",
       "        [0.9998, 1.0019, 1.0014,  ..., 1.0005, 1.0010, 0.9993],\n",
       "        [1.0007, 1.0006, 0.9999,  ..., 0.9980, 0.9964, 0.9929],\n",
       "        ...,\n",
       "        [1.0007, 1.0009, 1.0004,  ..., 0.9990, 0.9962, 0.9949],\n",
       "        [0.9996, 1.0000, 0.9997,  ..., 1.0005, 1.0007, 1.0003],\n",
       "        [0.9994, 1.0000, 0.9997,  ..., 1.0006, 0.9997, 1.0000]],\n",
       "       device='cuda:0', grad_fn=<MeanBackward1>)"
      ]
     },
     "execution_count": 89,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sample_mu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "1f91d6db-36fa-4974-aaf0-0414a90809ca",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[1.0000, 1.0000, 0.9995,  ..., 1.0008, 1.0008, 0.9999],\n",
       "        [0.9991, 1.0010, 1.0008,  ..., 1.0003, 1.0010, 0.9992],\n",
       "        [1.0007, 1.0007, 1.0000,  ..., 0.9980, 0.9960, 0.9960],\n",
       "        ...,\n",
       "        [1.0007, 1.0007, 1.0001,  ..., 0.9984, 0.9964, 0.9964],\n",
       "        [0.9997, 0.9997, 0.9995,  ..., 1.0006, 1.0005, 1.0004],\n",
       "        [0.9999, 0.9999, 0.9999,  ..., 1.0004, 1.0000, 1.0000]],\n",
       "       device='cuda:0', grad_fn=<_CvxpyLayerFnFnBackward>)"
      ]
     },
     "execution_count": 90,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "solution"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "id": "8c23b8ae-455f-4c18-93bc-485396199f13",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.6373, device='cuda:0', grad_fn=<NormBackward1>)"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.norm(sample_mu - solution)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "e23b8fb0-13fa-41ac-89ea-7fe56bd6d201",
   "metadata": {},
   "outputs": [],
   "source": [
    "sample_mu_r = rearrange(sample_mu, \"nf (nt nx) -> nf nx nt\", nx = mu.shape[1], nt = mu.shape[2]).cpu()\n",
    "sample_std_r = rearrange(sample_std, \"nf (nt nx) -> nf nx nt\", nx = mu.shape[1], nt = mu.shape[2]).cpu()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "57f06c78-d57c-4721-a59b-dcdbbec314e8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cuda', index=0)"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "std.device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "id": "38ced6c8-453b-47d1-85ab-e2a6bb3109db",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Evl8OjYSpgkhhBg3vu/n/UEebSdfISZD/yCtqQt8Xy0jrB3FjDQfcBwnb1tMLF1XgVosBbEkhKLQmYTZ5TKTcCy23nprXnrppYKua9s2zc3Nue3a2loJF4aw9dZbF3sIkyoSieTCsUKXUzY2No54nS233DJve+3atZMWpsn7GSHESCRME0IIIcSMMV5BmiieaEiFaYkMuJ46L5aCinBxxzUVlZWVseuuuxZ03UwmQ0NDQ2573rx5Y15yJ6aXqqqqXIi2bt26gm7zwgsvjHiduro6ttlmG1asWAHAE088wVFHHTX2gQohxDiSBgRCCCGEmBEkSJseAiaELPWz6+ppRCC1xYUomq222ip3upCQLB6Pc+eddxa07+OPPz53+uabb6atrW30AxRCiAkgYZoQQgghpr14WoK06SQaUt+7U2p5bTIDKSn5IkRR9F16+dRTT/Hhhx8Oe/0LL7wwr97kcM444wwqKioA6Orq4sQTT8xbXl+IVCo1qusLIUQhJEwTQgghxLQWT8O6dgnSppNIAAxdLfNMpNV5HTI7TYiiOOGEE3KnXdflhBNOGHQGWTqd5vzzz+e6665DK/CFt6qqimuvvTa3/c9//pN99tknt/RzKL7v88ILL3D66aez1157FXgkQghROKmZJoQQQohpKy9Iy0BTrHhBmpZIQCaDH42CYUzeHU9DmqZmp3Uk1FLPsiB0JWF2FEz5V7EQk2rbbbflqKOO4q677gLglVdeYauttuIrX/kKn/70p3Ech/fff5+77rqLtWvXYpomF110EZdddllB+z/55JNZsWIFV111FQDLly9n2223ZY899mDvvfdm4cKFlJWVEYvFaGxs5K233uKFF17INTno38hACCHGg4RpQgghhJiWSiVI05JJ9OZmtGRSndHSgrNgAYRCkzOAaao8pDp5pm3IOKqWWlcSZpUVe2RCzDzXXXcdK1as4L333gOgubmZq6++esD1AoEAv//979lkk00KDtMAfvKTn7B48WLOPvtsMpkMAM899xzPPffciLc15J8XQogJIP+7E0IIIcS0M1SQVhacxCDNtjEaGjA++UQFaZ4HmQy4LubatZBOT8Igpi9TV8Eo9GlEEFc/ZyHE5Kqvr+eZZ57h5JNPRtcH/4i511578fzzz3PSSSeN6T5OP/10Pv74Y04//XSqq6uHvW44HGb//ffnuuuu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qw8gvg+eo+NlDDxXQ9N9rDIbz9Zx0gZm0B1hrxvPr6jA83309na09nY0TcOvqMBoaMCdP3/KL6Edi0gATAMcV82CioagPS5hWilIZuCOl0a+3jMfwjsNsPW8iR9TKTvttNNyYRrADTfcMKowLZFI8Je//CW3vfXWW7P77rsD0NLSwh133MHdd9/N8uXLSSaHXg+91VZbceGFF3LyyScXFMAsXryY1atXA/DDH/6QSy65hNWrV3POOedw3333kclk8q5/0EEH5QK7J598Mq9e3MqVK4cM89asWcPtt9/O3//+d1566aW88KW/XXfdlf/5n//hiCOOGHH8wIAGEKeccgorV67kzDPP5IEHHsB1B76+/8d//AfXXHPNqMPH+++/n//93//lhRdeGLK4fjQa5dBDD+Wcc85ht912G3Z/6XSaX/3qV1x77bV88skng15n/vz5fO973+Mb3/gGhmGMarybbbYZX//613MdOf/617/yyiuvsMsuu4xqP0O5++67ee+993Lbe++9N9/85jdHvZ9f/epXPPbYY7RlSyH86U9/4tJLLx3XYFVMXxKmCSGEEGKjDRWkVWpJZrc2q+WcoJZ4trdDPK62dR2vslLNkJqCyzl9H3BNvEyQtBvOfeDwPQ3X1vEyei5Y6znfyxgYQRc7bmFYLtokHLZfWYnveWidnehtbXi6jl9ejrFuHe7ChfgbOeNjKuoJ0GLZMK07rcI1c3SfGae0ZAZWFdiTwnY0mlt708YuXcOagE8Sj76jmkIU4uqH4ZwDx38MG2vx7N6lxBNt6dKlLF26lNdeew1QocWvfvUrogXOOv3rX/+at7Stbx22X/3qVwXXu3rvvfc49dRTueeee7j11ltHvUz00Ucf5eijj6Yz2815vFx88cUF15J7+eWXOfLII/nGN77Bz3/+81Hf16OPPsoxxxxDxzDL6O+9915eeeUVnnzyST71qU+NuM+uri7+8z//M6/T6lBisRh/+ctfCIVCw4ZpH3744YCC/YNZt24dZ5xxBnfccQf33Xdfwc+pHj2PfSwWw/d9LrzwQh577LFR7WMoV199dd72ZZddNqZZdHV1dZxxxhlcdtllgJqBed111/GjH/1oXMYppjcJ04QQQgixUQYL0jTbZlaihWon+yHN89C7utA6O3NLPP1oFK+yEsawLKXYfA+1jDMexfeyaVgQPEfDzRh5yzs13cewPNB8nJSJkzHQLTWzwEmaWGXOYHcx7rzqanTfV/XTWlrwNA2/rAxj7VoVqIXDkzKOUhENqo6RGQdSDoRMVTutdgatfF3VAl8tuGa9BZTWNLB31o9m/JPn/06GT0/iQ3XaaadxxhlnAL0zzb761a8WdNsbbrghd9qyLE488cRBrzd37lz23HNPdtxxR2bPno1lWTQ2NvL888/zwAMP5DqB/v3vf+f0008fVTOElStXcu2119LZ2UkkEuHwww9n2bJlVFZW0tjYyP333z/m5YZ9bbrppuyxxx5su+221NTUoGkaDQ0NPP300zz++OO5enPXX389NTU1BT+GoMLE73znO3R1dVFTU8MXv/hFtt9+eyKRCB999BG33XZbbgZYQ0MDJ510EsuXL0cf5p9IXV1d7LXXXrz11lu580zTZN9992Xvvfdmzpw5OI5DQ0MDL7/8Mk888QTp9PDlA1asWME+++xDS5/OzkuWLOHwww9niy22IBAI8PHHH3PXXXflwrann36agw8+mKeeempUy0jr6uo499xzueSSSwDVOfPBBx/k4IMPLngfg2lra+O5557LbW+22WbsvffeY97fqaeeyuWXX577+d93330SpomCTL13r0IIIYQoGQOCtC4Pq6ON6mQbFaE+ddHa2yG75MUPhfCmaF00z9FwUqaqieZ4+F4GHw0cAzseQKN3WpNuehgBF83w6fkc6DkenqPjpAysiIOdsjBCLrox+qLhYxr/rFnonqd+Js3NaoZaOIyxdi3OwoUQCk3KOEqBrkNZUC3zjCUhFIXOJMwuh3H43C7EpPnyl7/MeeedRyqlOmr88Y9/LCgI6qmx1uM//uM/qK2tzW3rus4RRxzBWWedxd577z1k8LNq1SpOOOEEnn/+eQBuuukmTjnllLylmMO56aabANhjjz24/fbbWbhwYd7l3/ve9wraz2Asy+KUU07h9NNPZ9dddx3yem+88QbHHXcc77//PgA//vGP2X///QtejnnVVVfheV6uhl1lZWXe5RdffDFHHXUUDz74IAAvvPACDz74IIceeuiQ+zzttNPygrQ999yTP/zhD2y55ZaDXr+zs5Obb76ZDRs2DHp5Mpnk2GOPzQVplmXxs5/9jNNPP33AMs7LL7+cyy+/PDdj67nnnuP//b//x8UXXzzCI5Hv3HPP5Te/+Q2NjY2A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Hn/8cf73f/930OvF43G+/e1vc80115RUJ0/DMPJmd914443cdNNNg163tbWV4447jrvvvrtkjuHAAw/k+OOPz20/+eSTHHDAAbz//tBTOmOxGNdddx3f//73B738wgsvzNVjy2QyHHLIIfziF7/IWw47mJaWFv7whz+w8847c88994z+YIZQVlbGD3/4w9z2hg0bRnX73XbbjSuvvDK37bou//mf/8k3v/nNvNlm/X3wwQfsv//+ebPzQqEQf/7zn6XxgBiV0ix8IoQQQogxSdvZAuoJD72zE6OtjVTCoTsNTsbBjMUIJ2JETI9wGLAsvIoK/PLykuzS6Htq2aObMvBc9SHH97NdOTMGntP7wUfTfQzLQ7dKewbacPSAi2br+J46PjPoYiesonQa7csvL8fzffTWVrTOTnRNw6uqwmhsxNV1/D61b6aDaAgSGdXVsyqiOnzG0zO3oP14uvUFcCdptmXKhpufh7MOmJz7KzWnnXYaf/zjHwecv2jRIvbbb79hb3v22Wfz29/+NjcT6X/+53+48847+eIXv8jChQtJJBK8/fbb/O1vf8vV3/rRj37ERRddNP4HMkbf/e53uffee/F9H8/zOPnkk/nDH/7AIYccwpw5c+jq6uJf//oXf//73+ns7ATg8ssv53/+53+KPHLlt7/9Le+++y5vvPEGAM8++yzbbrstn//859l7772ZM2cOruvS0NDAK6+8wuOPP04ymeTkkwdv0VtWVsbdd9/N3nvvzfr160mlUpx99tlcccUVHHTQQey4447MmjULz/Po6Ojgww8/5PXXX+df//oXrutOyDF+9atf5eqrr87rpjkaZ599NqZpctZZZ+F5Hr7vc/3113PDDTdwwAEHsNtuuzF37lxs22bdunU88cQTvPDCC3nLgKurq7n33nv5zGc+M16HJWYICdOEEEKIaSDtqBkYXd0uemcnZlsbyaSrQrS0g9ndRTgeI2L5KkQLBlSIVlZWkiGa52g4KTM7Q6tPV07bwM3ouU6dALrpqdln5tSYgTYcTQMz5GAnLNy0gWGqmSR20iJQZhd1bH40iud56O3taB0dqrNnRQXG+vW4moYfjRZ1fOMpHADLUMs842kVrrUnJEzbWM0x+Odbk3uf97wGx+8Gc2bghJM999yTLbfccsBsplNPPXXEGViLFi3ixhtv5Ctf+QqOoxqkvP76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+/W2t71No6OjrV3I9Dme+MQn6r777ms8ZllWSwEhAABYfY4tZePh3zPTCxEUy+G8YN3ImLDibHxmvrOD0r4x6WAxXM207oerbUa98HUZykjb+qUtOak/FQ6Hde1wn3hE6kuGCwucuCEM0DZmpWyCajQAAFYDYVoPO+200/TiF7+46bHnPOc5+qu/+qumIKtWq+mTn/ykHvnIR2psbKzx+Omnn67nPe95bW9XpVLRX//1X2v79u264oor9MUvflH79u2bd9877rhDb33rW3XmmWfql7/8ZdO/vepVr9KuXbva3j4AANAe+eni8XgkrLIKTBgsdYMgCOc1G52UHhgPFwt4YFwanZ7vLDDhnHHxiJRLShuy0vb+sLosnwznQXOscJ9EJAzUtvVJJ20IK8+GMmF1GosLAACw+vjdVY/70Ic+pJ///Of62c9+JkkKgkDvfOc79b73vU/HHXecotGo9uzZo2Kx2HTcwMCAPve5z8l1V64LFYtFXXfddbruuuskSf39/RoaGlImk1GpVNL999+vAwcOzHvsM57xDH3wgx9csbYBAIDli7jhip7FSliddrAoTZTCkGi9qQfhPGeV6TnPqvW5+zh2WHkW98JhmJ4rWfPsE4+EAVrck2JeWI0GAAA6B2Faj0skEvrWt76lZzzjGfre977XeLxareq2226b95idO3fqq1/9qk4++eTVaqYk6eDBgzp48OBR94lGo3r3u9+t17zmNbJ45wkAQMfLJ8MwLRkNq7Zqfli5FT/6LBJrrlYPFwuo1MI/6/MsFuC5YWgWdcNQbL7FFTxnOjib/mKuMwAAOh8/rqG+vj59+9vf1sc+9jH9zd/8je64444F93vpS1+qN73pTUqlUivWng0bNujv/u7v9P3vf1833nij9u/ff8xjduzYoSuvvFJXXXWVNm/evGJtAwAA7ZWMhhVq1XpYpTZRkibKnRWmGSNV/engbLr6zA/m7hd1w8qzmfDMmWcI5kxl2kyA1surlwIAsF4RpkGSZNu2/vRP/1R/+qd/ql//+tf6+c9/rvvvv1++76u/v19/8Ad/oIc//OHyPG/Rz71z504Z0/pswvF4XK985Sv1yle+UlK4IMFtt92me++9VyMjI5qamlIkElE+n9fQ0JDOOeccAjQAANaxfFLaPx4O75wohZVpNX/tgqbAhIHZkcM2Z7+VsawwBIxN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eZxt2/rjP/7jpsfuuOOOox7z8Y9/vGl45+WXX64HPehBRz0mFovp6quvbnqsk96/E6ZhXdu9e7cOHDjQ2D7++ON10UUXtXTsi170oqbtL3/5y21sGdB+ndzfK5WK/uVf/qWxvXHjRr3kJS9p6zlmzvOtb32r6bEXvvCFLR07e79vfvObqlarbWsb2ov+jl7Syf19sYIg0Kc//emmx57//Ocf87i9e/c2zduTSqV02WWXtXTO2a/B7HmJ0Fno7+glndzfDx061LS9bdu2lo/dvn170/bY2NhR9//qV7/atD372hbyzGc+U8lksrF90003ad++fa01coURpmFd+/rXv960/bjHPa7lCZ0f97jHNW3/4Ac/0OTkZNvaBrRbJ/f3L33pS00/kC+//HI5jtO2558xu92nnHKKduzY0dKxO3fubJq8ulAoNC1MgM5Cf0cv6eT+vljf/e53tXfv3sa253l69rOffczjZr8G559/ftMHqKM5//zzm6opbrvtNt1+++0tthirjf6OXtLJ/X32ggaLWXxj9r4DAwML7nvbbbc1Va4lk0mdd955LZ1n9r7GmDmv6VohTMO69otf/KJpu9VvSknavHlz02pP1WpVt9xyS5taBrRfJ/f32T/UjlyRp52W8xpI4Qeuoz0fOgf9Hb2kk/v7Yn3qU59q2r744ouP+iFrxnJeA9d156zQzP29c9Hf0Us6ub+feeaZTds33XRTy8f+9Kc/bdqefQ8+0uzX4GEPe5hc1235XJ36/p0wDevarbfe2rR92mmnLer42fvPfr6VMD4+rl/96lf60Y9+pJ///Oe655575Pt+289jjNGePXv03//93/rxj3+sW2+9VaOjo20/D1ZPJ/f32T98zzjjDEnh3DXf/OY3dfnll+uUU05RMplULpfTSSedpMsuu0yf+MQnNDU11fJ5Ovk1QHt18v/1avX3hXB/7z6d3N8XY2JiQl/60peaHmt1yFu3vAY4tm75v15Of1+I7/u6/fbbtXv3bt1444363e9+p0KhsKznxNrq5P5+8cUXN1UA//jHP9aNN954zOPuuOMOfeELX2hsx2Kxo1ZkdvJrsBytx4FAhymVSrr33nubHlvMOO/59p89CWO7nXXWWfrVr37VNPmiFM4Lcv755+vSSy/Vc5/7XEWj0WWd51Of+pT+z//5P3PGwUvSqaeeqj/8wz/Uy172Mj34wQ9e1nmwejq5v4+Pj+t3v/tdY9txHO3YsUN79uzRc57znHl/KI+Pj+uOO+7Q5z73Ob31rW/Ve9/7Xl155ZXHPNfsNnfKa4D2or8vjPt79+nk/r5Y119/fVNgvGHDBj3pSU9q6Vju772B/r6wd7/73XrlK185JzyzbVsPechD9LjHPU6veMUrWp7eAmuv0/t7LpfTm9/8Zr3lLW9pPHbppZfqK1/5is4555x5j7n11lv11Kc+tWne4WuuuUZDQ0MLnqdb7+9UpmHdGhkZkTGmse153lG/ieezZcuWpu3h4eG2tG0hv/jFL+YEaZJULBb1rW99S3/2Z3+mnTt36nOf+9yyznP33XfP+0FLkn7729/q2muv1UMe8hA94xnPWHA/dJZO7u979uxpals6ndYtt9yiXbt2tfTbrX379um5z33unNV65jO7zVu3bl1UW1f7ex5LQ39fGPf37tPJ/X2xZg95u+KKK1oeynPkBN0S9/duRX9f2O233z5vFVoQBPrlL3+pD3zgAzrxxBN11VVXLWpuK6yd9dDfr7766qaqsvvvv1/nnnuunvrUp+of/uEf9LWvfU1f//rX9U//9E+6/PLLdcYZZzTNSXn11Vfrda973VHP0e7377N/XqwVKtOwbhWLxabtRCLR8mSOM2ZPbDv7OdfCAw88oMsuu0yvf/3r9f73v3/FzmOM0ec//3n99Kc/1Te/+c1Fl9tidXVyf5+9eo9lWbr44os1Pj4uKWzrs5/9bF144YXq7+/XwYMH9cMf/lDXXXdd05vB973vfdqyZYv+/M//fMFzzW5zq5NTL7R/J3zPYy76+/Jwf19fOrm/L8add96pG264oemxVoe8lUqlOVNecH/vTvT35anX6/rIRz6iH//4x/rWt76lTZs2rfg5sXTrob/btq3PfOYzOu+88/SOd7xDBw4ckO/7+upXvzpnBc4jnX/++XrHO96hxzzmMcc8R7vfv9dqNVUqlWWP5louKtOwbs3+pozFYot+jng8ftTnbIdYLKanPOUpuvbaa7V7924NDw+rWq2qUCjozjvv1Gc+8xk9+clPnnNj/cAHPqD3vve9izrXySefrNe+9rX6yle+ojvuuEMTExOq1WoaHh7WDTfcoLe97W3auHFj0zH33nuvnvSkJ2n//v3LvlasnE7u77PDhdHRUd11112SpLPPPlu33nqr/vmf/1lXXnmlnvSkJ+nKK6/URz/6Ud1yyy06/fTTm459wxve0DSEbrblvg6r8T2P5aO/z8X9vXt1cn9fjE9+8pNN27t27dJDHvKQlo6dr73c37sT/X2uM888U29961v1jW98Q3fffbeKxaKq1aoeeOABffvb39brX//6Oasu/vrXv9ZTnvKUNV3JFMe2Xvq7ZVl6+ctfrp///Oe6+OKLj7n/+eefr9e97nUtL8DU7vfv8z3nWiBMw7pVLpebtiORyKKfY3aa3e6S6de+9rXau3evvvrVr+qqq67Sueeeq8HBQXmep1QqpeOPP15XXHGFvva1r+lHP/rRnBLWN7/5zfrlL395zPPs3LlT3//+93Xbbbfpgx/8oC655BKdcMIJSqfTcl1Xg4ODOv/88/X2t79dd911l17ykpc0HX/PPffoZS97WVuvHe3Vyf19oR9mW7du1be//W1t37593n/fuXOnvvvd7zYFAJVKRR/4wAcWPNdyX4eV/p5He9Dfm4/j/t7dOrm/t8oYo09/+tNNjy2mSmf2ayBxf+9W9PfDdu3apZtvvln/8z//o3e+8536oz/6I+3YsUPJZFKe52nDhg167GMfq/e///2666679LSnPa3p+Jtvvll/9Vd/tYwrwUpbL/19cnJSr33ta3XyySfra1/72jH3//GPf6ynP/3pevCDH6z//u//Pub+7X7/LnXGPZ4wDevW7ET7yEkQW1WpVI76nMt1ySWXqL+/v6V9H/nIR+oHP/hB03Laxhi99a1vPeaxO3fu1EUXXdTSeWKxmD7ykY/o1a9+ddPjX/ziF/Wzn/2spefA6uvk/r7Q87z//e9XPp8/6rEDAwNzKjA//elPL/gDcrmvw0p/z6M96O+HcX/vfp3c31v1/e9/X/fcc09jOxKJHHVlt9nmay/39+5Efz/s9NNP165du1raN5/P6wtf+IKe/vSnNz1+7bXX6r777lv0ubE61kN/37dvnx760IfqQx/6UOP9yCmnnKJrr71Wv/3tb1UsFjU1NaU777xTn/zkJ3X22Wc3jv3tb3+rCy64QF/+8pePeo52v3+f7znXAmEa1q1UKtW0Pd9vNY9l9geY2c+52k488cQ586R94xvfWJFJpN///vfrxBNPbHrsM5/5TNvPg/bo5P4+3/P09fXp0ksvben4Zz7zmU3DF8rlsn7605+2dK7Fvg6d9j2P+dHfl4f7+/rSyf29VbMnYr/44otb/mWiNH97ub93J/r70tm2rY9+9KPK5XKNx8rl8rIXLsPK6fT+Xi6X9fjHP16//e1vG4+9+MUv1q9+9StdddVVOuWUU5RMJhWPx3X88cfrec97nm666aam1T/r9bqe9axn6dZbb13wPO1+/z7fc64FwjSsW7O/gaampppWS2nF7HkGOuGb8rnPfa4GBwcb20EQ6Dvf+U7bz+O6rl75ylc2Pfaf//mfbT8P2qOT+/t8z3PuuefK87yWjo/FYnrYwx7W9NhCVTSzz7XYuUI68Xsec9Hfl4f7+/rSyf29FcViUV/4wheaHlvskLd4PC7HcZoe4/7enejvy5PP5/XCF76w6THu752r0/v7+973Pv3mN79pbP/hH/6h/vEf//GowzAty9I111yjK6+8svFYuVw+6oqe7X7/7roulWnAcgwMDDRN2j8zEfNizC6LXuxSxSvBtu05Q3puu+22FTnX7NVXbr/99kXf4LE6Orm/b9iwYc5jJ5988qKe45RTTmnaXujaZrd57969izpPJ37PYy76+/Jxf18/Orm/t+Jzn/tc0wedDRs26I/+6I8W/TxH/iJR4v7erejvyzf7/r5SnxOwfJ3c333f14c//OGmx6655hrZdmsR0bve9a6mff/jP/5Dv//97+fdt93v32f/vFgrhGlYt+Lx+JyJnu+9995FPcfs/U899dRlt6sdtm3b1rR94MCBVTlPvV7X6OjoipwLy9PJ/f2EE06Y8xusTCazqOeYvf9C/XB2CNEprwHai/6+fNzf149O7u+tmD3k7YorrpDruot+Hu7vvYH+vnyr9TkBy9fJ/f1Xv/qVRkZGGtsDAwN6xCMe0fLx27Zt0xlnnNHYNsbohhtumHffbr2/E6ZhXZv9jXTLLbcs6vjZY7s75Rtz9nChWq22KudZyXNh+Tq1vzuOM6cyZ76JQo9m9twJiURi3v069TVA+3Xq//Vq9vfl4P6+vnRqfz+Wu+66Sz/60Y+aHnvBC16wpOdar68BFm+9/l+3s78vx2p9TkB7dGp/v+uuu5q2d+7c2VRF14rjjjuuaXuhxTA69TVYLsI0rGtnnnlm0/bu3btbPvb+++/X3Xff3dj2PE+nnXZam1q2PA888EDT9kqVss4+j2VZqzKBKpamk/v77NWo9u/fv6jjZ5e8L9QPl/MaSOFS3kd7PnQO+vvycH9fXzq5vx/Npz71qabhw2effbb+4A/+YEnPtZzXoF6vz1nIg/t756K/L89qfU5Ae3Rqf5/9i8ClVFjODnZ93593v9mvwU033aR6vd7yeTr1/TthGta1iy++uGn7O9/5TstzwsyerPPRj350x0xWO7tEdnY590qdZ9OmTateqo7WdXJ/v+SSS5q2b7755kUdP3v/2eXgMy666CIlk8nG9u9+97um5emP5u6779btt9/e2E6n03PmJ0TnoL8vD/f39aWT+/tCjDH6l3/5l6bHljMR+5Of/OSm7d27d7c8SfWPf/xjTU1NNbZPPvnkRc9liNVDf1+e1fqcgPbo1P4++xds+/btW/RztDqX2amnnqoTTjihsT05OdlyqDg5Oakbb7yxsW1Z1pzXdK0QpmFdO++88zQwMNDY3rNnj37wgx+0dOzHPvaxpu2nPvWp7Wzakv3whz/UnXfe2fTY7IlG22X2a7BS50F7dHJ/f+ITn9i0qs6vfvWrpuDqaH7zm9/MKd9eKOSKxWJ6/OMf3/TYxz/+8ZbOM3u/Jz7xiUddrQhri/6+PNzf15dO7u8L+dGPftQ0TCgSiejZz372kp9v27ZtOuussxrbxWJR119/fUvHdup7OsyP/r509Xp9zrxt3N87W6f29507dzZt33vvvXM+gx5NoVDQTTfd1PTYkYHZbLN/ETn72hby2c9+VsVisbH90Ic+VJs3b265nSvKAOvc61//eiOp8fWoRz3KBEFw1GO+853vNB2TTqfNgQMHVqnFCysWi+b0009vattDHvKQFTnXpz/96abzSDJf+MIXVuRcaJ9O7u8vfvGLm87z3Oc+t6XjLrvssjnXdDRf+9rXmvbv7+83w8PDRz1m//79pr+/v+m4//iP/2j10rBG6O9Lw/19ferk/j6fF7zgBU3nvvTSS5f9nB/+8IebnvPkk082pVLpqMfccsstJhKJNI6xbdv85je/WXZbsLLo70vzzne+c879/Wc/+9matAWt69T+vnXr1qZzvPSlL2352Le//e1NxyYSCVMulxfc/9e//rWxLKuxfyQSMbfccstRz1EqlcxJJ53UdJ6PfOQjLbdxpRGmYd07cOCASaVSTd9k73nPexbcf+/evWbnzp1N+7/1rW895nlm/+D6/ve/f9T9X/nKV5r77rtvUdfxh3/4h3PO88UvfvGox/3bv/2b+cIXvnDMG/KRrrvuOhONRpvOc+aZZy7qObA2OrW/G2PM73//exOLxZqO+9jHPnbUY/7hH/5hzrlaCbke8YhHNB3zlKc8xVSr1Xn3rVQq5uKLL27a/4ILLjjmObD2er2/c3/vLZ3c32ebnJw06XS66Xn+/d//fdHPM1ulUjHbt2+f8+Fuof47Pj5uHvrQhzbt/5znPGfZ7cDK6/X+fu2115rvfve7izrmgx/8YFMYIclccskly2oHVken9verr766aX/LssynPvWpY57nq1/9qnFdt+nYF77whcc87pnPfGbTMeecc44ZHx+fd98gCMxLXvKSpv2PP/74Bd/vrwXCNHSFd7/73XNuHldddVVTmOX7vvnSl740503a5s2bzejo6DHPsdibkyQTjUbN0572NPOZz3zG3HXXXfPud++995q/+Zu/MRs3bpxzjqc97WnHbNfb3vY2I8mceOKJ5s1vfrPZvXu3KRaLc/arVCrmu9/9rrnkkkvmnCcWi5kbb7zxmOdCZ+jE/j5jpj8e+UP55S9/ubn33nub9rvnnnvMS1/60jlvCp/1rGe1dJ7/+q//MrZtNx170UUXmZtvvrlpv5/97GfmUY96VNN+juPQ39eRXu7v3N97Tyf39yN96lOfanqOjRs3mlqttujnmc911103p41/8id/Yn73u9817ffd7353TjV/KpUye/bsaUs7sPJ6ub8/73nPM5LMGWecYd71rneZm2++ed6qnsnJSfPVr37VXHjhhXOupb+/39xxxx3LagdWTyf290OHDpm+vr45xz3/+c83//u//ztn/9tvv9284hWvmPMePJFImLvvvvuY7bv99ttNIpFoOvaMM86Y087bbrvNPP3pT5/Truuvv/6Y51hNhGnoCr7vz6k8mfnQfPzxx5uzzjrL5HK5Of8ej8fNDTfc0NI5Fntzmr2/JJPJZMwpp5xiHvawh5mzzjrLbN68ed79pLByZmpq6pjtmv1hTgqHOGzfvt2cfvrp5uEPf7g59dRT51RQzHx5nsfwn3WmE/v7jHq9Pm/bLMsyxx9/vDnnnHPM8ccfP29f3LVrlykUCi2/Du973/vmfZ7Nmzebs88+22zatGnef//gBz/Y8jmw9nq5v3N/7z2d3N+PNLuS/nWve92in+Norrrqqnm/r7Zv327OPvtsMzAwMO/3xuc+97m2tgMrq5f7+0yYduSX67rmuOOOM2eeeaZ52MMeZk466STjed689/d0Om1279697HZg9XRqf//hD384p6J95mtoaMjs2rXrqO+rbds2X/7yl1t+Hf7t3/5tzi8XJZnBwUFz9tlnm23bts3773/+53/e8jlWC2EaukapVDKXX375vN/k83319/cv6gfqYm9OrbZjvhvSG9/4xpZLWOf7sNXq18knn8w8C+tUp/X3I5XL5XnfJB7t65JLLllUkDbjAx/4gHEcp6VzOI5jPvShDy36HFh7vdrfub/3pk7u78aElZazP+j8+te/XtxFHoPv++Y1r3lNy69BIpEwn/3sZ9vaBqyOXu3vi/25ceTXwx/+cCrS1qlO7e//9V//ZXbs2LHovrhhwwbz9a9/fdGvw3XXXWfi8XjL53n961/fkdNVEKah63z+8583Z5555oLfjMlk0rzsZS8z+/fvX9TzLvbm9E//9E/m8ssvN9u2bWvpJrFx40bzqle9ytx+++2LatdvfvMb86Y3vcmce+65Ld2UXNc1F1xwgbnuuus6asw5lqZT+vt8vvnNb5rzzz9/wbZZlmUe/vCHL3vekf/5n/8xT37yk+eUnM982bZtLr74YvOLX/xiWefB2uu1/s79vbd1an+fPQH62WefvajjF+N73/ueueCCCxZ8DSKRiLniiisY2tkFeq2///d//7d59atfbXbt2rVg9dmRX7FYzDzxiU80//7v/96RoQIWpxP7+8TEhPnQhz5kTj311GP2x507d5prrrnGjIyMLPLKD7vzzjvNs5/97KP2/wsvvND84Ac/WPI5VppljDECutAdd9yhn/zkJ7rvvvtUrVaVy+X0oAc9SOeff75isdiqtuXgwYO69dZbdc899+jAgQOanJyU4zjK5/MaGBjQWWedpeOPP37Z5/F9X7fddpv27NmjvXv3amJiQtVqValUSvl8Xscdd5zOOeccxePxNlwVOkkn9ffZ7rvvPt1444265557VC6Xlc/ntWnTJp1//vkaGhpq23lGRkZ0ww03aM+ePZqcnFQymdQJJ5yg888/v2lJcqx/vdjfub/3rk7u76tl79692r17t+69916Vy2Wl02mddNJJeuQjH6lMJrPWzUMb9WJ/r1aruvXWW3XXXXdp3759KhQKqtVqymQyyufzOvnkk3XWWWcpEomsdVPRZp3a3x94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",
      "text/plain": [
       "<Figure size 1200x750 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "t_idx = 1\n",
    "\n",
    "for parameters_idx in range(0, 1, 5):\n",
    "    with torch.no_grad():\n",
    "        fig = plt.figure(figsize=(4, 2.5), dpi=300)\n",
    "\n",
    "        time_label = t[slice(*tpred)][t_idx].item()\n",
    "        param_val = x_train[parameters_idx, 0, 0, 0].item()\n",
    "        true_vals = y_train[parameters_idx, :, t_idx, 0]\n",
    "\n",
    "        # Plot true solution\n",
    "        plt.plot(grid, true_vals, color=\"black\", lw=2.5, label=\"True\", zorder=1)\n",
    "\n",
    "        # Unconstrained\n",
    "        plt.plot(grid, mu[parameters_idx, :, t_idx].cpu(), '-^', lw=2.5,\n",
    "                 color=\"#3a86ff\", label=r\"VarianceNO\", zorder=2)\n",
    "        plt.fill_between(grid,\n",
    "                         mu[parameters_idx, :, t_idx, 0].cpu() + 3 * std[parameters_idx, :, t_idx, 0].cpu(),\n",
    "                         mu[parameters_idx, :, t_idx, 0].cpu() - 3 * std[parameters_idx, :, t_idx, 0].cpu(),\n",
    "                         color=\"#3a86ff\", alpha=0.2, label=\"_nolegend_\", zorder=2)\n",
    "\n",
    "        \n",
    "        # ProbConserv\n",
    "        plt.plot(grid, new_mu[parameters_idx, :, t_idx], '-*', lw=1.5,\n",
    "                 color=\"#ef233c\", label=r\"ProbConserv\", zorder=3)\n",
    "        plt.fill_between(grid,\n",
    "                         new_mu[parameters_idx, :, t_idx] + 3 * new_std[parameters_idx, :, t_idx],\n",
    "                         new_mu[parameters_idx, :, t_idx] - 3 * new_std[parameters_idx, :, t_idx],\n",
    "                         color=\"#ef233c\", alpha=0.2, label=\"_nolegend_\", zorder=3)\n",
    "        \n",
    "\n",
    "        # TVD-Constrained\n",
    "        plt.plot(grid, sample_mu_r[parameters_idx, :, t_idx], '-o', lw=1.5,\n",
    "                 color=\"#BC7FF7\", label=r\"ProbHardE2E\", zorder=4)\n",
    "        plt.fill_between(grid,\n",
    "                         sample_mu_r[parameters_idx, :, t_idx] + 3 * sample_std_r[parameters_idx, :, t_idx],\n",
    "                         sample_mu_r[parameters_idx, :, t_idx] - 3 * sample_std_r[parameters_idx, :, t_idx],\n",
    "                         color=\"#BC7FF7\", alpha=0.3, label=\"_nolegend_\", zorder=4)\n",
    "\n",
    "\n",
    "\n",
    "        # Labels and title\n",
    "        plt.xlabel(\"x\", fontsize=10)\n",
    "        plt.ylabel(r\"$u(x, t={:.2f})$\".format(time_label), fontsize=10)\n",
    "        #plt.title(\"Learning {} for parameter = {:.2f}\".format(dataset, param_val), fontsize=9)\n",
    "\n",
    "        # Ticks and grid\n",
    "        plt.xticks(fontsize=10)\n",
    "        plt.yticks(fontsize=10)\n",
    "        plt.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "\n",
    "        # Legend\n",
    "        plt.legend(fontsize=9, loc=\"upper right\", frameon=False)\n",
    "        plt.xlim((0.55,0.8))\n",
    "\n",
    "        # Optimize for LaTeX\n",
    "        plt.tight_layout(pad=0.3)\n",
    "        plt.savefig(\"advection_tvd.pdf\")\n",
    "        \n",
    "        plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e5da2426-b031-4ab8-a09c-48e28bc7fbf8",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 't' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[2], line 9\u001b[0m\n\u001b[1;32m      5\u001b[0m parameters_idx \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n\u001b[1;32m      7\u001b[0m fig, ax \u001b[38;5;241m=\u001b[39m plt\u001b[38;5;241m.\u001b[39msubplots(figsize\u001b[38;5;241m=\u001b[39m(\u001b[38;5;241m4\u001b[39m,\u001b[38;5;241m2.5\u001b[39m), dpi\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m300\u001b[39m)\n\u001b[0;32m----> 9\u001b[0m time_label \u001b[38;5;241m=\u001b[39m \u001b[43mt\u001b[49m[\u001b[38;5;28mslice\u001b[39m(\u001b[38;5;241m*\u001b[39mtpred)][t_idx]\u001b[38;5;241m.\u001b[39mitem()\n\u001b[1;32m     12\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mno_grad():\n\u001b[1;32m     13\u001b[0m \n\u001b[1;32m     14\u001b[0m     \u001b[38;5;66;03m# 1) True\u001b[39;00m\n\u001b[1;32m     15\u001b[0m     l_true, \u001b[38;5;241m=\u001b[39m ax\u001b[38;5;241m.\u001b[39mplot(grid, \n\u001b[1;32m     16\u001b[0m                       y_train[parameters_idx, :, t_idx, \u001b[38;5;241m0\u001b[39m]\u001b[38;5;241m.\u001b[39mcpu(), \n\u001b[1;32m     17\u001b[0m                       color\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mblack\u001b[39m\u001b[38;5;124m\"\u001b[39m, lw\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m2.5\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 't' is not defined"
     ]
    },
    {
     "data": {
      "image/png": "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vu666+KVV17Z7PHTp0+P66+/PjE2adKkbeoXAAAAaJl2a+4GGnr99ddjzZo1G42/9957iXrt2rXx4osvbnKN8vLygl9ZcvTRR8fIkSPj+eefj4iI9evXx/e+97247rrr4l/+5V+iXbt2EfG3tx7deeedcemll8b69evz84855pg48sgjC9oTAAAAkG2ZC15+9KMfNep1zZ999lkcddRRm/zs1FNPjXvvvbfAnUXcd999ceihh8aCBQsi4m/hz3nnnReXXnpp9O3bN3K5XFRVVcXatWsT8/bZZ59U+gEAAACybZe81Whb7bXXXvHyyy/HgQcemBhfs2ZNzJkzJyorKzcKXYYMGRIvv/xy7LnnnjuyVQAAACADBC9N1KtXr5g1a1Zcf/31UV5evtnjysvLY/LkyTFz5szo0aPHDuwQAAAAyIrM3Wr00UcfpX6OXC63XfPbtGkTF110UfzHf/xHvP322/Hee+9FTU1NRER07do1hgwZEkOHDo1WreRaAAAAsCvLXPDSkrRq1SqGDRuWeNU0AAAAwFdckgEAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkJLdmruBxpg/f37MmjUrFi1aFHV1ddG5c+fo379/VFRURElJSbP1tXz58njzzTdjwYIFsXz58tiwYUN07NgxunfvHsOGDYu999672XoDAAAAml+mg5epU6fGL37xi3jnnXc2+Xn79u1j/PjxceWVV0ZZWdkO6+uxxx6LW265JaZNmxa5XG6zx33rW9+KM888M0477bTYbbdM/1EDAAAAKcjkrUbr1q2LcePGxejRozcbukRErFq1Km655ZYYOHBgvPLKK6n3tWzZsvjBD34QJ554Yrz88stbDF0iImbPnh0//elP45BDDol58+al3h8AAACQLZkLXjZs2BAnn3xy/OY3v0mMt27dOvr06RNDhgyJjh07Jj5bsmRJfP/734833ngjtb6+/PLLGDlyZDz77LMbfbbnnnvG0KFD46CDDtrk7UVvv/12jBgxIj766KPU+gMAAACyJ3PByw033BBPPPFEYuzMM8+MhQsXRlVVVcyePTs+//zzeOyxx6Jnz575Y1avXh1jxoyJFStWpNLXZZddttHVN8cdd1y88847UVNTE2+//Xa89dZb8emnn0ZlZWX86Ec/Shy7aNGi+Nd//ddUegMAAACyKVPBy7Jly+Kaa65JjF177bVx++23R3l5eX6sVatWMXr06JgxY0b07t07P75o0aK46aabCt5XTU1N/N//+38TY2eddVY88cQT8a1vfWuj4wcMGBAPPPBAXH311YnxF154IdWrcgAAAIBsyVTwMnny5Fi5cmW+Pvzww+Piiy/e7PHdunWLu+66KzE2ZcqUWLZsWUH7evrpp6O+vj5f77nnnnHjjTdudd5//ud/xoABAxJjTz31VEF7AwAAALIrM8HLhg0b4p577kmMXXXVVVFUVLTFeUceeWQcdthh+XrlypXx8MMPF7S3Dz/8MFF/73vfi3bt2m113ldX5nydh+wCAADAriMzwcuMGTNiyZIl+bpv375xxBFHNGru6aefnqinTp1awM4iPv/880Tdo0ePRs/9+nNoIiKWL19eiJYAAACAFiAzwcszzzyTqI866qitXu3y9WO/btq0aVFbW1uw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tr7+93//N958881YvHhxLF++PHK5XHTs2DH22muv+Pa3vx09e/Zstt42Z86cOXHAAQfk6w8++CAGDRrUjB0BAACwM9vVv4dm7hkvm9KvX7/o169fc7exkb333juOPfbY5m4DAAAAyKhM3moEAAAAsDMQvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAApEbwAAAAApETwAgAAAJASwQsAAABASgQvAAAAACkRvAAAAACkRPACAAAAkBLBCwAAAEBKBC8AAAAAKRG8AAAAAKRE8AIAAACQEsELAAAAQEoELwAAAAAp2a25G2iM+fPnx6xZs2LRokVRV1cXnTt3jv79+0dFRUWUlJQ0d3tRX18fb7/9dlRWVkZNTU2sX78+2rdvH927d48BAwZE//79o1UrGRcAAADsajIdvEydOjV+8YtfxDvvvLPJz9u3bx/jx4+PK6+8MsrKynZwdxELFiyIG264IR566KFYvnz5Zo/bY489YsSIEfGv//qvccwxx+y4BgEAAIBmlcnLMNatWxfjxo2L0aNHbzZ0iYhYtWpV3HLLLTFw4MB45ZVXdlh/GzZsiGuvvTYGDBgQt99++xZDl4iIL7/8Mp544om47777dkyDAAAAQCZk7oqXDRs2xMknnxxPPPFEYrx169bRs2fP6NixYyxYsCBWrFiR/2zJkiXx/e9/P1588cU49NBDU+1v/fr18aMf/SgeeeSRjT7r2LFjfPOb34w99tgjVq5cGR9//HGsXr061X4AAACA7MrcFS833HDDRqHLmWeeGQsXLoyqqqqYPXt2fP755/HYY49Fz54988esXr06xowZkwhk0nD66acnQpfddtstzj777Jg1a1Z88cUXMXfu3Jg5c2ZUVlbGypUrY+7cuXHzzTdHRUVFFBUVpdobAAAAkC1FuVwu19xNfGXZsmXRp0+fWLlyZX7s2muvjUsuuWSTx1dXV8ff/d3fxUcffZQf+/nPfx4TJ05Mpb8HHnggfvzjH+fr8vLyeO6552Lw4MGNmv/FF19E586dU+mtsebMmRMHHHBAvv7ggw9i0KBBzdgRAAAAO7Nd/Xtopq54mTx5ciJ0Ofzww+Piiy/e7PHdunWLu+66KzE2ZcqUWLZsWcF7W7p0aZx//vn5umPHjjF9+vRGhy4R0eyhCwAAALBjZSZ42bBhQ9xzzz2Jsauuumqrt+cceeSRcdhhh+XrlStXxsMPP1zw/q655ppYunRpvv7lL38Z/fr1K/h5AAAAgJ1HZoKXGTNmxJIlS/J1375944gjjmjU3NNPPz1RT506tYCd/e0tS19/I9Hee+8dP/3pTwt6DgAAAGDnk5ng5ZlnnknURx11VKMfRnvUUUcl6mnTpkVtbW3Benv88cfj888/z9djx46N1q1bF2x9AAAAYOeUmeDl3XffTdQVFRWNnlteXh69e/fO13V1dVFZWVmgzjYOhUaMGFGwtQEAAICdV2aCl7lz5ybqgQMHNml+w+Mbrrc93nzzzUR94IEHRkREfX19PPfcczF27NjYf//9o7S0NDp16hT77rtvjBkzJu65555YvXp1wfoAAAAAWpbdmruBiIg1a9bEwoULE2M9evRo0hoNj//www+3u6+IiBUrVsSf//znfN26devo1atXVFVVxbhx4+KNN97Y5Jx58+bFI488Epdffnlcd911iddQAwAAALuGTFzxsnTp0sjlcvm6uLg4unbt2qQ1unXrlqhramoK0ltVVVWitw4dOkRlZWUMHTp0k6FLQ4sXL45//ud/jksuuaQg/QAAAAAtRyaueFm1alWibteuXaMfrPuV0tLSLa65rZYvX56oi4qKYtSoUbFixYqI+Fuvp5xyShx++OHRpUuXWLZsWUyfPj0efPDBWLNmTX7e9ddfH926dYuf/exnBekr4m/h0tffBNUY8+bNK9j5AQAAgC3LZPBSUlLS5DXatm27xTW3VcPg5YsvvogvvvgiIiIOOuigeOyxx6Jnz56JY3784x/H5ZdfHscff3y8//77+fELL7wwvve978V+++1XkN5uu+22mDhxYkHWAgAAAAovE7carV27NlG3adOmyWvsvvvuifrrV5tsj80FON27d48XXnhho9DlK717946XXnop9t577/zYunXr4sYbbyxIXwAAAED2ZSJ4aXiFS11dXZPXWLdu3RbX3FabW+eGG26Izp07b3FuWVlZXHfddYmx+++/v2ChEAAAAJBtmbjVqH379om64RUwjdEwzGi45rba1Drf+MY34sQTT2zU/JNPPjnOPffc/DNh1q5dG7NmzYrvfve7293bhAkT4qSTTmrSnHnz5sUJJ5yw3ecGAAAAti6Twcvq1asjl8s16QG7tbW1W1yzUL1FRBx66KFRXFzcqPklJSVx8MEHxwsvvJAfe+uttwoSvHTt2rXJb38CAAAAdpxM3GpUVlaWCFnWr1/f5NdBV1dXJ+pCBRJ77bXXRmNNfTju/vvvn6gL9aprAAAAINsyEby0bdt2o4fULly4sElrNDy+f//+291XRMQ+++yz0cN+99hjjyat0fD4r96KBAAAAOzcMhG8RGwclFRWVjZp/ty5c7e43rZq3br1Rle4NHyQ79Y0fGZNu3bttrsvAAAAIPsyE7wMGTIkUc+YMaPRcz/99NP46KOP8nVxcXEMHDiwQJ1FDB06NFF/9tlnTZrf8NaiLl26bHdPAAAAQPZlJngZNWpUon7xxRcjl8s1au7zzz+fqEeMGFGwh+tGRBx33HGJ+u23327S/IbHN3zmCwAAALBzykzwUlFREWVlZfm6qqoqpk2b1qi5d999d6I+/vjjC9laHH300VFSUpKv33///fjLX/7SqLlz5szZ6DaoI444opDtAQAAABmVmeClVatWMX78+MTYxIkTt3rVy0svvRSvvvpqvu7QoUOMGTOmoL2VlpbGuHHjEmOTJk1q1Nyrr746UX/3u9/1CmgAAADYRWQmeImIuPjiixO3CE2fPj2uv/76zR5fXV0dZ5xxRmLs3HPPTVw5sylFRUWJn8ZcWXPllVcmrnq577774v/9v/+3xTm33XZbPPzww4mxSy+9dKvnAgAAAHYOmQpeysrK4rLLLkuMXXrppTFhwoRYvHhxfmzDhg0xderUqKioSDxUt7y8PC644IJUeuvevXtcfPHFibEzzjgjzjnnnPjkk08S4wsXLoyzzjorzjnnnMT4D3/4w/je976XSn8AAABA9hTlGvsE2x1kw4YNcfzxx8fTTz+dGG/dunX06tUrOnbsGAsWLIjly5cnPm/btm288MILMXz48K2eo6ioKFG//PLLjXruSn19fZxwwgkb9VZUVBR9+vSJLl26xLJly6KqqmqjuUOHDo3p06cX9KG/22LOnDlxwAEH5OsPPvggBg0a1IwdAQAAsDPb1b+HZuqKl4i/PevlkUceibFjxybG6+vro6qqKmbPnr1R6NKlS5d49tlnGxW6bI/WrVvHo48+GqeeempiPJfLRVVVVbz55pubDF2OO+64TIQuAAAAwI6VueAlIqKkpCQeeuihePTRR2PIkCGbPa60tDQmTJgQlZWVO+xNQbvvvnvce++98dxzz20x6CkqKorvfOc78dRTT8UTTzwhdAEAAIBd0G7N3cCWnHjiiXHiiSfGvHnzYubMmVFdXR11dXXRqVOnGDBgQAwfPjzxwNvGKsTdVUcffXQcffTRUV1dHW+88UZ8/PHHsXbt2ujcuXN885vfjOHDh3t7EQAAAOziMh28fKVfv37Rr1+/5m5jk7p16xb/9E//1NxtAAAAABmUyVuNAAAAAHYGghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJTs1twNNMb8+fNj1qxZsWjRoqirq4vOnTtH//79o6KiIkpKSpq7PQAAAIBNynTwMnXq1PjFL34R77zzziY/b9++fYwfPz6uvPLKKCsr28HdbWz16tUxePDgmD9/fmL81FNPjXvvvbd5mgIAAACaTSZvNVq3bl2MGzcuRo8evdnQJSJi1apVccstt8TAgQPjlVde2YEdbtrll1++UegCAAAA7LoyF7xs2LAhTj755PjNb36TGG/dunX06dMnhgwZEh07dkx8tmTJkvj+978fb7zxxo5sNWHWrFnx61//utnODwAAAGRP5oKXG264IZ544onE2JlnnhkLFy6MqqqqmD17dnz++efx2GOPRc+ePfPHrF69OsaMGRMrVqzY0S1HXV1dnH766bFhw4aIiCgtLd3hPQAAAADZk6ngZdmyZXHNNdckxq699tq4/fbbo7y8PD/WqlWrGD16dMyYMSN69+6dH1+0aFHcdNNNO6rdvF/+8pfxwQcfREREt27d4qc//ekO7wEAAADInkwFL5MnT46VK1fm68MPPzwuvvjizR7frVu3uOuuuxJjU6ZMiWXLlqXWY0Nz5syJa6+9Nl/fcsst0aFDhx12fgAAACC7MhO8bNiwIe65557E2FVXXRVFRUVbnHfkkUfGYYcdlq9XrlwZDz/8cCo9NrRhw4Y4/fTTo66uLiIiRo8eHSeccMIOOTcAAACQfZkJXmbMmBFLlizJ13379o0jjjiiUXNPP/30RD116tQCdrZ5N998c8ycOTMiIvbYY4+45ZZbdsh5AQAAgJYhM8HLM888k6iPOuqorV7t8vVjv27atGlRW1tbsN42paqqKq644op8fe211yaeQwMAAACQmeDl3XffTdQVFRWNnlteXp54yG5dXV1UVlYWqLNN+5d/+ZdYvXp1REQceuihcdZZZ6V6PgAAAKDlyUzwMnfu3EQ9cODAJs1veHzD9Qrprrvuij/84Q8REVFcXBx33nlno6/OAQAAAHYdmQhe1qxZEwsXLkyM9ejRo0lrNDz+ww8/3O6+NuXTTz+NCy+8MF9fdNFFMWjQoFTOBQAAALRsmQheli5dGrlcLl8XFxdH165dm7RGt27dEnVNTU1BemtowoQJsXz58oiI2HfffePyyy9P5TwAAABAy7dbczcQEbFq1apE3a5duybfulNaWrrFNQvh4YcfTrwx6Y477oiSkpKCn6exampqEm+Caox58+al1A0AAADQUCaDl20JM9q2bbvFNbfXsmXL4mc/+1m+/slPfhIjRowo6Dma6rbbbouJEyc2aw8AAADA5mXiVqO1a9cm6jZt2jR5jd133z1Rr1mzZrt6aui8887L377UtWvXuPHGGwu6PgAAALDzyUTw0vAKl7q6uiavsW7dui2uuT2ee+65eOCBB/L1lClT4hvf+EbB1gcAAAB2Tpm41ah9+/aJuuEVMI3R8AqXhmtuq5UrV8aZZ56Zr48++ug45ZRTCrL29powYUKcdNJJTZozb968OOGEE9JpCAAAAEjIZPCyevXqyOVyTXrAbm1t7RbX3FaXXHJJ/lXX7dq1i9tvv70g6xZC165dm/z2JwAAAGDHycStRmVlZYmQZf369U1+HXR1dXWiLkQgsWDBgkTQMnHixOjdu/d2rwsAAADsGjIRvLRt2zZ69uyZGPvqKpPGanh8//79t7uvFStWRC6Xy9cXXnhhFBUVbfWn4ZuG/vu//zvxeadOnba7NwAAACD7MhG8RGwclFRWVjZp/ty5c7e4HgAAAMCOlpngZciQIYl6xowZjZ776aefxkcffZSvi4uLY+DAgQXqDAAAAGDbZOLhuhERo0aNiuuvvz5fv/jii41+wO7zzz+fqEeMGFGQh+v269cvXnjhhSbPu+++++L+++/P1yNHjowLL7wwXxcXF293bwAAAED2ZSZ4qaioiLKysli6dGlERFRVVcW0adNixIgRW5179913J+rjjz++ID21b98+/uEf/qHJ81577bVE/c1vfnOb1gEAAABatszcatSqVasYP358YmzixImJh9tuyksvvRSvvvpqvu7QoUOMGTMmjRYBAAAAmiQzwUtExMUXX5y4RWj69OmJ248aqq6ujjPOOCMxdu6550ZZWdkWz9PwLUTTpk3brr4BAAAANiVTwUtZWVlcdtllibFLL700JkyYEIsXL86PbdiwIaZOnRoVFRWJh+qWl5fHBRdcsKPaBQAAANiiTAUvEX+76mXUqFGJsdtvvz169uwZ++yzTwwdOjS6dOkSo0ePjoULF+aPadu2bTz88MPRqVOnHdwxAAAAwKZlLnhp1apVPPLIIzF27NjEeH19fVRVVcXs2bNj+fLlic+6dOkSzz77bAwfPnwHdgoAAACwZZkLXiIiSkpK4qGHHopHH300hgwZstnjSktLY8KECVFZWRlHHHHEDusPAAAAoDGKclt7bVAGzJs3L2bOnBnV1dVRV1cXnTp1igEDBsTw4cOjpKSkudtrUebMmRMHHHBAvv7ggw9i0KBBzdgRAAAAO7Nd/Xvobs3dQGP069cv+vXr19xtAAAAADRJJm81AgAAANgZCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJYIXAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFKyW3M30Bjz58+PWbNmxaJFi6Kuri46d+4c/fv3j4qKiigpKdnh/axfvz4+/PDDmDNnTnz22WexcuXKaN++fXTp0iUGDx4cBxxwQLRqJdMCAACAXV2mg5epU6fGL37xi3jnnXc2+Xn79u1j/PjxceWVV0ZZWVmqvSxYsCAeffTReOGFF+K1116LNWvWbPbYjh07xrhx4+Lcc8+NfffdN9W+AAAAgOzK5GUZ69ati3HjxsXo0aM3G7pERKxatSpuueWWGDhwYLzyyiup9XLIIYdE375946KLLooXXnhhi6FLRMSKFSvi1ltvjQMOOCBuvPHGyOVyqfQGAAAAZFvmgpcNGzbEySefHL/5zW8S461bt44+ffrEkCFDomPHjonPlixZEt///vfjjTfeKHg/69evj5kzZ27ys5KSkujTp08MGzYsBg4cGG3atEl8XldXFxdeeGGcc845Be8LAAAAyL7MBS833HBDPPHEE4mxM888MxYuXBhVVVUxe/bs+Pzzz+Oxxx6Lnj175o9ZvXp1jBkzJlasWJFqf3369ImrrroqXn/99fjyyy+jqqoqZs2aFXPmzInly5fH/fffH7169UrMue222+KWW25JtS8AAAAgezIVvCxbtiyuueaaxNi1114bt99+e5SXl+fHWrVqFaNHj44ZM2ZE79698+OLFi2Km266KZXehg8fHr///e9j/vz5ceWVV0ZFRUUUFxcnjmnbtm2MGzcuZs+eHcOGDUt8dsUVV8Tnn3+eSm8AAABANmUqeJk8eXKsXLkyXx9++OFx8cUXb/b4bt26xV133ZUYmzJlSixbtqxgPbVp0yaefvrpeO2112LkyJFRVFS01TmdO3eOqVOnRmlpaX5s+fLl8dvf/rZgfQEAAADZl5ngZcOGDXHPPfckxq666qqtBh1HHnlkHHbYYfl65cqV8fDDDxesrzZt2sQPfvCDJs8rLy+PU089NTH2+9//vlBtAQAAAC1AZoKXGTNmxJIlS/J1375944gjjmjU3NNPPz1RT506tYCdbbuvB0IREQsXLmym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BC9DhgxJ1DNmzGj03E8//TQ++uijfF1cXFywB8YWFRXF4MGDt7m3119/PVEPHjy4Sc+uAQAAAFquzAQvo0aNStQvvvhi5HK5Rs19/vnnE/WIESMK9gDbTfX2wgsvNHpuw2OPPfbYgvQEAAAAZF9mgpeKioooKyvL11VVVTFt2rRGzb377rsT9fHHH1/I1uK4445L1I888kisWrVqq/NWrlwZjzzySKq9AQAAANmVmeClVatWMX78+MTYxIkTt3rVy0svvRSvvvpqvu7QoUPi/eCFMHjw4Bg2bFi+XrVqVUyePHmr8yZPnpx4lfQhhxxSsFugAAAAgOzLTPASEXHxxRcnbhGaPn16XH/99Zs9vrq6Os4444zE2Lnnnpu4cmZTioqKEj+NubLm6quvTtTXXXddvPLKK5s9flO9T5o0aavnAQAAAHYemQpeysrK4rLLLkuMXXrppTFhwoRYvHhxfmzDhg0xderUqKioSDxUt7y8PC644IJUejv66KNj5MiR+Xr9+vXxve99L379618n3lpUW1sbN998cxx99NGxfv36/PgxxxwTRx55ZCq9AQAAANmUqeAl4m9XvTR8mO3tt98ePXv2jH322SeGDh0aXbp0idGjR8fChQvzx7Rt2zYefvjh6NSpU2q93XfffdGnT598vXbt2jjvvPOirKwsDjjggBg0aFCUlZXF+eefH2vXrs0ft88++8S9996bWl8AAABANmUueGnVqlU88sgjMXbs2MR4fX19VFVVxezZs2P58uWJz7p06RLPPvtsDB8+PNXe9tprr3j55ZfjwAMPTIyvWbMm5syZE5WVlYnAJeJvr8l++eWXY88990y1NwAAACB7dmvuBjalpKQkHnroofinf/qnmDRpUrz77rubPK60tDROPfXUuPLKK6Nr1647pLdevXrFrFmz4uabb45f//rXiVugvq68vDzOO++8OPfcc6NNmzY7pLfG2HPPPePKK69M1LCzsc/ZFdjn7Arsc3YF9jm7gl19nxfltvbaoAyYN29ezJw5M6qrq6Ouri46deoUAwYMiOHDh0dJSUmz9bVhw4Z4++2347333ouampqIiOjatWsMGTIkhg4dGq1aZe6CIgAAAGAHahHBCwAAAEBL5JIMAAAAgJQIXgAAAABSIngBAAAASIngBQAAACAlghcAAACAlAheAAAAAFIieAEAAABIieAFAAAAICWCFwAAAICUCF4AAAAAUiJ4AQAAAEiJ4AUAAAAgJbs1dwNs3vz582PWrFmxaNGiqKuri86dO0f//v2joqIiSkpKmq2vXC4X77zzTrz77rtRU1MTERF77bVXHHjggTF06NAoKipqtt5oebK2z9evXx8ffvhhzJkzJz777LNYuXJltG/fPrp06RKDBw+OAw44IFq1klnTNFnb55CGrO/z+vr6ePvtt6OysjJqampi/fr10b59++jevXsMGDAg+vfv7+93tiqr+3z58uXx5ptvxoIFC2L58uWxYcOG6NixY3Tv3j2GDRsWe++9d7P1BoXSor+H5sicxx9/PDd06NBcRGzyp3379rlzzjknt2TJkh3aV11dXe6GG27IdevWbbO9de/ePXfjjTfm6urqdmhvtDxZ2udVVVW5yZMn54466qhc27ZtN9tTROQ6duyYO/vss3N//vOfU++Lli9L+7wxamtrc/vss89GfZ566qnN3RoZlvV9XlVVlTvrrLNynTp12uLf73vssUfu+OOPzz3zzDPN0ifZltV9/tvf/jY3YsSIXFFR0Rb397e+9a3cHXfckVu/fv0O7Y+WY9GiRbnHHnssd/HFF+dGjBiR69ChQ2IP9erVq9l62xm+hwpeMmTt2rW5H/3oR1v8S/PrP3vuuWdu+vTpO6S3hQsX5r71rW81ureDDjoot2jRoh3SGy1Llvb52rVrc9/5znca3cvXf9q0aZO74YYbchs2bEilN1q2LO3zpjj//PM32Z/ghU3J+j6vr6/P/fKXv8ztvvvuTfr7/eSTT95hPZJ9Wd3nS5cuzR1zzDFN/v3loIMOyv3lL39JvT9ahtdeey03evToXHl5+Vb3TnMFLzvL91DBS0bU19fnjj/++I02TuvWrXN9+vTJDRkyJNexY8eNPm/Xrl1uxowZqfb22WefbfJfQNu2bZsbNGhQbsCAAbmSkpKNPt93330z86+4ZEPW9vnKlSs3+5d2SUlJrk+fPrlhw4blBg4cmGvTps0mj5swYULB+6Jly9o+b6yZM2fmWrVqJXihUbK+z+vq6nInnXTSJvdzx44dc/37988dfPDBuQEDBuTatWsneGGTsrrPV6xYsdmrb/bcc8/c0KFDcwcddFBu77333uQx3bt3zy1YsCC1/mg5pkyZ0uhAozmCl53pe6jgJSOuu+66jTbMmWeemauurs4fU19fn3vsscdyPXv23Ogvz+XLl6fW2/e///2NvpDefPPNudra2vwxq1atyt10000bbfxjjz02tb5oebK2zxsGL3369MldddVVuddff32jyxRXr16du//++3O9evXa6H/D//k//6egfdGyZW2fN8a6detyBxxwQL6P0tJSwQtblPV9/uMf/zhxzt122y139tln52bNmrXRlYr19fW5uXPn5m6++eZcRUVFbuzYsan2RsuR1X1+9tlnb9TXcccdl3vnnXc2OraysnKTV+wcddRRqfRGy7Kl4KV9+/bNHrzsTN9DBS8ZsHTp0o3uobv22ms3e/yiRYtyvXv3Thz/85//PJXefv/73yfOU1xcvMXLJ6dNm5YrLi5OzPnDH/6QSm+0LFnc518FL8OHD8/9/ve/b9RtQ59//nlu2LBhib46deqUW7ZsWUF7o2XK4j5vjCuvvDJ//m7duuX+/d//XfDCZmV9n99///2Jc5WXl+fee++9Rs///PPPU+uNliOr+/yzzz7LtW7dOnGes846a6vzrr766o2+WDfnVZZkw1fBS4cOHXJHHHFE7sILL8w98sgjuY8++ij38ssvN2vwsrN9DxW8ZMBFF12U2CCHH374Vr8Avvjii4k5HTp0yC1durTgvR188MGJ81xxxRVbnXP55Zcn5lRUVBS8L1qeLO7zdevW5Z5++ukmz6uurt7oioD/+q//KlhftFxZ3Odb88EHHyRupXv88ccTQYzghYayvM+XLFmSKysry5+nY8eOnmfBNsnqPr/77rsT59hzzz0T//q/OfX19bkBAwYk5l566aUF7Y2WZ968ebk5c+bk6uvrN/qsuYOXne17qOClmdXX1+f23HPPbUrmDjvssMS82267raC9vf/++4n1S0tLc19++eVW53355ZcbfSmtrKwsaG+0LFne59tqwoQJib5OPPHE5m6JZtYS93l9fX3iAdOjR4/O5XI5wQublfV9ft555yXOceuttxb8HOz8srzPGwZC48aNa/Tcyy67LDH3pJNOKmhv7FyaM3jZGb+Htgqa1YwZM2LJkiX5um/fvnHEEUc0au7pp5+eqKdOnVrAziKeeOKJRD1mzJjo0KHDVud16NAhTjrppMRYoXujZcnyPt9Whx12WKJeuHBhM3VCVrTEfX7zzTfHzJkzIyJijz32iFtuuWWHnJeWK8v7fN26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GTlyZPzpT3/Kj51xxhnx/vvvx1lnnZV/ZXrbtm2jb9++ceqpp8abb74Z//mf/5k//q9//Wv88Ic/LOhrrqFQsv7f4LYSvDSjhhtg9erViaeoN0Ztbe0W19xWDddpeJ7GSKs3WpYs7/PGuPTSS+OOO+5IjP3qV7+Kn/zkJzusB7Ivy/v8kksuyb8atV27dnH77bcXZF12PVne55ta59BDD43i4uJGzS8pKYmDDz44MfbWW28VpDdalizv84i/PQB6zpw5+frv//7v44477tji7RhFRUUxadKk+PGPf5wfW7t2rTcbkUk76/dQwUszKisrSzwlff369U1+1VV1dXWiburr7jan4TqLFi1q8hpp9UbLkuV9vjXXXXfdRpef//znP4/zzz9/h5yfliOr+3zBggWJoGXixInRu3fv7V6XXVNW93lExF577bXR2H777dekNfbff/9EnYXXj7LjZXmf19fXxy233JIYmzRpUrRq1bivdNdcc03i2N/97neJZ9dBFuys30MFL82obdu2Gz3s7at/lWyshsf3799/u/uK2PiXj235S7nhnEL1RsuS5X2+JbfeemtceumlibFzzz03Jk6cmPq5aXmyus9XrFiR+JfaCy+8MIqKirb603Cf//d//3fi806dOm13b7Q8Wd3nERH77LPPRv/iv8ceezRpjYbHf/HFF9vdFy1Plvf5+++/H0uXLs3XZWVlccghhzR6fo8ePeLAAw/M17lcLl577bWC9AaFsrN+DxW8NLOGm6CysrJJ8xvem1moTdWrV6/Ea7hqa2vj448/bvT8jz/+OFavXp2vS0tLo0ePHgXpjZYnq/t8c+67777Ea3cjIk477bSYMmVKquelZWtp+xy2RVb3eevWrTe6wqXhwxW3puFzBNq1a7fdfdEyZXWff/WK9K/07t07cXVOY/Tp0ydRN7wyAJrbzvo9VPDSzIYMGZKov/7WlK359NNP46OPPsrXxcXFMXDgwIL0VVRUFIMHD97m3l5//fVEPXjw4Cb/HwM7j6zu80357W9/G6eddlriKoExY8bEnXfeaQ+zRS1pn8O2yvI+Hzp0aKL+7LPPmjS/4e0kXbp02e6eaJmyus8bhom77bZbk9do+Nyj+vr67eoJCm1n/R4qeGlmo0aNStQvvvhiox/g9fzzzyfqESNGFPTBQQ17e+GFFxo9t+Gx3v6ya8vy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",
      "text/plain": [
       "<Figure size 1200x750 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "t_idx = 1\n",
    "parameters_idx = 0\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4,2.5), dpi=300)\n",
    "\n",
    "time_label = t[slice(*tpred)][t_idx].item()\n",
    "\n",
    "\n",
    "with torch.no_grad():\n",
    "\n",
    "    # 1) True\n",
    "    l_true, = ax.plot(grid, \n",
    "                      y_train[parameters_idx, :, t_idx, 0].cpu(), \n",
    "                      color=\"black\", lw=2.5)\n",
    "    \n",
    "    # 2) VarianceNO\n",
    "    l_vno, = ax.plot(grid, \n",
    "                     mu[parameters_idx, :, t_idx].cpu(), \n",
    "                     '-^', lw=2.5, color=\"#3a86ff\")\n",
    "    s_vno = ax.fill_between(grid,\n",
    "                            mu[parameters_idx, :, t_idx, 0].cpu() + 3 * std[parameters_idx, :, t_idx, 0].cpu(),\n",
    "                            mu[parameters_idx, :, t_idx, 0].cpu() - 3 * std[parameters_idx, :, t_idx, 0].cpu(),\n",
    "                            color=\"#3a86ff\", alpha=0.2)\n",
    "    \n",
    "    # 3) ProbConserv\n",
    "    l_pc, = ax.plot(grid, \n",
    "                    new_mu[parameters_idx, :, t_idx].cpu(), \n",
    "                    '-*', lw=1.5, color=\"#ef233c\")\n",
    "    s_pc = ax.fill_between(grid,\n",
    "                           new_mu[parameters_idx, :, t_idx].cpu() + 3 * new_std[parameters_idx, :, t_idx].cpu(),\n",
    "                           new_mu[parameters_idx, :, t_idx].cpu() - 3 * new_std[parameters_idx, :, t_idx].cpu(),\n",
    "                           color=\"#ef233c\", alpha=0.2)\n",
    "    \n",
    "    # 4) ProbHardE2E\n",
    "    l_ph, = ax.plot(grid, \n",
    "                    sample_mu_r[parameters_idx, :, t_idx], \n",
    "                    '-o', lw=1.5, color=\"#BC7FF7\")\n",
    "    s_ph = ax.fill_between(grid,\n",
    "                           sample_mu_r[parameters_idx, :, t_idx].cpu() + 3 * sample_std_r[parameters_idx, :, t_idx].cpu(),\n",
    "                           sample_mu_r[parameters_idx, :, t_idx].cpu() - 3 * sample_std_r[parameters_idx, :, t_idx].cpu(),\n",
    "                           color=\"#BC7FF7\", alpha=0.3)\n",
    "    \n",
    "    # build legend handles: line alone for “True”, and tuples (shade, line) for the others\n",
    "    handles = [\n",
    "        l_true,\n",
    "        (s_vno, l_vno),\n",
    "        (s_pc,  l_pc),\n",
    "        (s_ph,  l_ph),\n",
    "    ]\n",
    "    labels = [\n",
    "        \"True\",\n",
    "        \"VarianceNO ±3σ\",\n",
    "        \"ProbConserv ±3σ\",\n",
    "        \"ProbHardE2E ±3σ\",\n",
    "    ]\n",
    "    \n",
    "    ax.legend(handles, labels, fontsize=8, loc=\"upper right\", frameon=False)\n",
    "    \n",
    "    ax.set_xlabel(\"x\", fontsize=10)\n",
    "    ax.set_ylabel(r\"$u(x, t={:.2f})$\".format(time_label), fontsize=10)\n",
    "    ax.set_xlim(0.55, 0.8)\n",
    "    ax.grid(True, linestyle=\"--\", alpha=0.4)\n",
    "    plt.tight_layout(pad=0.3)\n",
    "    plt.savefig(\"advection_tvd.pdf\")\n",
    "\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9a00416e-3046-483a-8163-ab85535c3e91",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
