{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6b3ccdb8-4fd8-4224-b23e-979fa8228059",
   "metadata": {},
   "outputs": [],
   "source": [
    "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": 6,
   "id": "5fdcc8cd-82d9-4cec-888d-806541259f2c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1d5eb530-ab43-4054-8953-9efdb86b3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "args = {'--batch_size': '20',\n",
    " '--dataset': 'HeatEquation_1D',\n",
    " '--dataset_params': '1,1,0,0',\n",
    " '--epochs': '200',\n",
    " '--fno_modes': '12',\n",
    " '--fno_width': '32',\n",
    " '--grid_len': '100',\n",
    " '--lr': '1e-3',\n",
    " '--m.drop_prob': '0.1',\n",
    " '--m.n_models': '10',\n",
    " '--m.n_regularize': '5',\n",
    " '--m.reg_strength': '1',\n",
    " '--m.reg_type': 'weights_l2',\n",
    " '--model': 'OutputVarFNO2d',\n",
    " '--n_samples': '200',\n",
    " '--no_train': False,\n",
    " '--ood_dataset_params': None,\n",
    " '--predict_time': '0,-1,5',\n",
    " '--seed': '0',\n",
    " '--time_len': '100',\n",
    " '--tplot': '0.5',\n",
    " '--train_ood_dataset_params': '1,1,0,0'}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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": 9,
   "id": "b02f6033-3977-4d51-8f39-024a376dbabf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Here 160\n",
      "torch.Size([160, 100, 1]) torch.Size([160, 100, 20, 1])\n",
      "torch.Size([160, 100, 20, 1]) torch.Size([160, 100, 20, 1])\n"
     ]
    }
   ],
   "source": [
    "if is_train:\n",
    "    # Train data\n",
    "    print(\"Here\", n_train)\n",
    "    a, u, p = dataset_class.generate_dataset(n_train, grid, t, tpred, *dataset_params)\n",
    "    print(a.shape, u.shape)\n",
    "    x_train, y_train = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Validation data\n",
    "    a, u, p = dataset_class.generate_dataset(n_valid, grid, t, tpred, *dataset_params)\n",
    "    x_valid, y_valid = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # In-distribution test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *dataset_params)\n",
    "    x_id_test, y_id_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Out-of-distribution inputs only\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *train_ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "\n",
    "    # Data loaders\n",
    "    train_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_train, y_train), \n",
    "                                            batch_size=batch_size, shuffle=True)\n",
    "    valid_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_valid, y_valid), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    id_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_id_test, y_id_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "else:\n",
    "    # OOD test data\n",
    "    a, u, p = dataset_class.generate_dataset(n_test, grid, t, tpred, *ood_dataset_params)\n",
    "    x_ood_test, y_ood_test = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "    ood_test_loader = torch.utils.data.DataLoader(torch.utils.data.TensorDataset(x_ood_test, y_ood_test), \n",
    "                                            batch_size=batch_size, shuffle=False)\n",
    "\n",
    "print(x_train.shape, y_train.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a7e5c61c-2b59-466f-9b4a-6157fa29ad4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "uq = False\n",
    "model_name = args[\"--model\"]\n",
    "n_models = 1\n",
    "fno_modes2 = min(fno_modes, 12)\n",
    "if args[\"--model\"].lower() == \"FNO2d\".lower():\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width, \"output_var\": True}\n",
    "    model = FNO2d(**FNO2d_params).to(device)\n",
    "elif args[\"--model\"].lower().startswith(\"EnsembleFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\"], mode=\"add\", new_config=save_args)\n",
    "    model = EnsembleNO(base_model_class=FNO2d, base_model_params=FNO2d_params, n_models=n_models)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"BayesianFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = BayesianNO(base_model_class=FNO2d, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"MCDropoutFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    dropout = float(args[\"--m.drop_prob\"])\n",
    "    n_dropouts = int(args[\"--m.n_models\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.drop_prob\"], mode=\"add\", new_config=save_args)\n",
    "    model = MCDropoutNO(base_model_class=FNO2d, base_model_params=FNO2d_params, dropout=dropout, n_dropouts=n_dropouts)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"OutputVarFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    model = OutputVarNO(base_model_class=FNO2d, probconserv=True, base_model_params=FNO2d_params)\n",
    "    uq = True\n",
    "elif args[\"--model\"].lower().startswith(\"DiverseFNO2d\".lower()):\n",
    "    FNO2d_params = {\"modes1\": fno_modes, \"modes2\": fno_modes2, \"width\": fno_width}\n",
    "    lam = float(args[\"--m.reg_strength\"])\n",
    "    reg_type = args[\"--m.reg_type\"]\n",
    "    n_models = int(args[\"--m.n_models\"])\n",
    "    n_regularize = int(args[\"--m.n_regularize\"])\n",
    "    utils.filter_config(args, [\"--m.n_models\", \"--m.reg_strength\", \"--m.reg_type\", \"--m.n_regularize\"], mode=\"add\", new_config=save_args)\n",
    "    model = DiverseFNO2d(reg_loss=reg_type, n_outputs=n_models, bias_last=False, lam=lam, n_regularize=n_regularize, **FNO2d_params).to(device)\n",
    "    uq = True\n",
    "else:\n",
    "    raise NotImplementedError"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "451bf5e4-8ec9-44d5-b739-75c4e4dc3bae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f8b67a37130>]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(y_train[1,:,0,0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "fb4da9f2-a677-4949-a760-e4035ef7c796",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0505, 0.1010, 0.1515, 0.2020, 0.2525, 0.3030, 0.3535, 0.4040,\n",
       "        0.4545, 0.5051, 0.5556, 0.6061, 0.6566, 0.7071, 0.7576, 0.8081, 0.8586,\n",
       "        0.9091, 0.9596])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t[slice(*tpred)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "252ea915-3038-415f-9ddb-79497851a42e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0.0000e+00,  6.3424e-02,  1.2659e-01,  1.8925e-01,  2.5115e-01,\n",
       "         3.1203e-01,  3.7166e-01,  4.2979e-01,  4.8619e-01,  5.4064e-01,\n",
       "         5.9291e-01,  6.4279e-01,  6.9008e-01,  7.3459e-01,  7.7614e-01,\n",
       "         8.1457e-01,  8.4972e-01,  8.8145e-01,  9.0963e-01,  9.3414e-01,\n",
       "         9.5490e-01,  9.7181e-01,  9.8481e-01,  9.9384e-01,  9.9886e-01,\n",
       "         9.9987e-01,  9.9685e-01,  9.8982e-01,  9.7880e-01,  9.6384e-01,\n",
       "         9.4500e-01,  9.2235e-01,  8.9599e-01,  8.6603e-01,  8.3257e-01,\n",
       "         7.9576e-01,  7.5575e-01,  7.1269e-01,  6.6677e-01,  6.1816e-01,\n",
       "         5.6706e-01,  5.1368e-01,  4.5823e-01,  4.0093e-01,  3.4202e-01,\n",
       "         2.8173e-01,  2.2031e-01,  1.5800e-01,  9.5056e-02,  3.1728e-02,\n",
       "        -3.1728e-02, -9.5056e-02, -1.5800e-01, -2.2031e-01, -2.8173e-01,\n",
       "        -3.4202e-01, -4.0093e-01, -4.5823e-01, -5.1368e-01, -5.6706e-01,\n",
       "        -6.1816e-01, -6.6677e-01, -7.1269e-01, -7.5575e-01, -7.9576e-01,\n",
       "        -8.3257e-01, -8.6603e-01, -8.9599e-01, -9.2235e-01, -9.4500e-01,\n",
       "        -9.6384e-01, -9.7880e-01, -9.8982e-01, -9.9685e-01, -9.9987e-01,\n",
       "        -9.9886e-01, -9.9384e-01, -9.8481e-01, -9.7181e-01, -9.5490e-01,\n",
       "        -9.3414e-01, -9.0963e-01, -8.8145e-01, -8.4972e-01, -8.1457e-01,\n",
       "        -7.7614e-01, -7.3459e-01, -6.9008e-01, -6.4279e-01, -5.9291e-01,\n",
       "        -5.4064e-01, -4.8619e-01, -4.2979e-01, -3.7166e-01, -3.1203e-01,\n",
       "        -2.5115e-01, -1.8925e-01, -1.2659e-01, -6.3424e-02, -2.2737e-16])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train[1,:,0,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "ae88be60-372c-44f7-8cb2-8c1dbd25e9f5",
   "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 = input_grid[:, :, :, 1]\n",
    "\n",
    "x_delta = probconserv._get_riemman_delta(x, riemann_type=\"simpson_1_3\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "2552301b-c87c-4d38-959e-423c07b99b5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = rearrange(x_delta, \"nf nt nx -> nf nt 1 nx\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "0de65e55-ea82-4ed1-b0da-a7744f5db58b",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_train_t = rearrange(y_train, \"nf nx nt 1 -> nf nt nx 1\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "953e1d46-91ac-48ba-b51e-209f93185abd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def trap_rule(p, dx):\n",
    "    return dx / 2 * np.sum((p[:-1]+p[1:]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2734cd49-8d68-4f14-addc-439ae12eca36",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simpson_rule(p, dx):\n",
    "    N = len(p)\n",
    "    return dx / 3 * (p[0] + 2*np.sum(p[2:N-1:2]) \\\n",
    "            + 4*np.sum(p[1:N-1:2]) + p[N-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "b79effdd-f631-4325-9da3-4b6262436126",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simpson_loop(p, dx):\n",
    "    N = len(p)\n",
    "    res = p[0] + p[N-1]\n",
    "    for i in range(1,N-1):\n",
    "        print(i)\n",
    "        if i%2 == 0:\n",
    "            res += 2* p[i]\n",
    "        else:\n",
    "            res += 4 * p[i]\n",
    "    return res/3 * dx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "2660cb9e-b53c-4255-aece-86648491d505",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0076)"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(grid[1] - grid[0])*(3/8)*(grid[0] + 3*grid[1] + grid[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1d70b032-3830-4cf6-ad86-b078c068c197",
   "metadata": {},
   "outputs": [],
   "source": [
    "h = grid[1] - grid[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "b691fdca-4f7a-4c0d-8a53-39e283819155",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0081)"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "(h/3)*(grid[0] + 4*grid[1] + grid[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "2d032649-8d35-4482-9dec-4d1511c9122f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.        ,  0.00296716,  0.00282779, ..., -0.00133034,\n",
       "       -0.00126486, -0.00120259])"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train[0,:,:,:].flatten().numpy().astype(np.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "741f42bc-e057-485f-a833-9500ded74453",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = y_train[0,:,-1,0].flatten()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "0c3babb9-0841-47be-be21-1111de4e9c42",
   "metadata": {},
   "outputs": [],
   "source": [
    "p = p.numpy().astype(np.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "7ca9d580-5c4e-4f25-8513-bf575bc16842",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.00120259,  0.02545432,  0.04960366,  0.07355379,  0.09720846,\n",
       "        0.1204726 ,  0.14325292,  0.16545784,  0.18699817,  0.20778747,\n",
       "        0.22774214,  0.24678211,  0.2648299 ,  0.28181386,  0.29766563,\n",
       "        0.31232166,  0.32572302,  0.33781588,  0.34855154,  0.35788691,\n",
       "        0.36578444,  0.37221235,  0.37714475,  0.38056046,  0.38244706,\n",
       "        0.38279691,  0.38160852,  0.3788867 ,  0.37464231,  0.36889234,\n",
       "        0.36165988,  0.35297391,  0.34286937,  0.33138674,  0.31857106,\n",
       "        0.30447495,  0.2891551 ,  0.2726731 ,  0.25509501,  0.23649156,\n",
       "        0.21693748,  0.19651136,  0.17529519,  0.15337436,  0.13083708,\n",
       "        0.10777322,  0.08427612,  0.06044041,  0.03636171,  0.01213686,\n",
       "       -0.01213678, -0.03636164, -0.06044042, -0.08427612, -0.10777308,\n",
       "       -0.13083687, -0.15337436, -0.17529526, -0.1965113 , -0.21693748,\n",
       "       -0.2364915 , -0.25509492, -0.27267304, -0.28915504, -0.30447495,\n",
       "       -0.31857109, -0.33138674, -0.34286943, -0.35297394, -0.36165985,\n",
       "       -0.36889234, -0.37464228, -0.3788867 , -0.38160855, -0.38279691,\n",
       "       -0.38244706, -0.38056046, -0.37714475, -0.37221229, -0.36578444,\n",
       "       -0.35788694, -0.34855154, -0.33781591, -0.32572302, -0.31232163,\n",
       "       -0.2976656 , -0.28181374, -0.26482993, -0.24678212, -0.22774211,\n",
       "       -0.20778745, -0.1869981 , -0.16545767, -0.14325282, -0.12047245,\n",
       "       -0.09720832, -0.07355388, -0.0496037 , -0.02545437, -0.00120259])"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "ea0cd95e-a52b-43b0-8092-9630790507f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "2\n",
      "3\n",
      "4\n",
      "5\n",
      "6\n",
      "7\n",
      "8\n",
      "9\n",
      "10\n",
      "11\n",
      "12\n",
      "13\n",
      "14\n",
      "15\n",
      "16\n",
      "17\n",
      "18\n",
      "19\n",
      "20\n",
      "21\n",
      "22\n",
      "23\n",
      "24\n",
      "25\n",
      "26\n",
      "27\n",
      "28\n",
      "29\n",
      "30\n",
      "31\n",
      "32\n",
      "33\n",
      "34\n",
      "35\n",
      "36\n",
      "37\n",
      "38\n",
      "39\n",
      "40\n",
      "41\n",
      "42\n",
      "43\n",
      "44\n",
      "45\n",
      "46\n",
      "47\n",
      "48\n",
      "49\n",
      "50\n",
      "51\n",
      "52\n",
      "53\n",
      "54\n",
      "55\n",
      "56\n",
      "57\n",
      "58\n",
      "59\n",
      "60\n",
      "61\n",
      "62\n",
      "63\n",
      "64\n",
      "65\n",
      "66\n",
      "67\n",
      "68\n",
      "69\n",
      "70\n",
      "71\n",
      "72\n",
      "73\n",
      "74\n",
      "75\n",
      "76\n",
      "77\n",
      "78\n",
      "79\n",
      "80\n",
      "81\n",
      "82\n",
      "83\n",
      "84\n",
      "85\n",
      "86\n",
      "87\n",
      "88\n",
      "89\n",
      "90\n",
      "91\n",
      "92\n",
      "93\n",
      "94\n",
      "95\n",
      "96\n",
      "97\n",
      "98\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(0.0003)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpson_loop(p, grid[1] - grid[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "87853599-71ac-4530-be73-fcf41b1a12f8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0002823446905355076"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "simpson_rule(p, (grid[1] - grid[0]).item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "ceb1aef6-1bb9-4f2f-8966-fe40fa025c03",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8.351932420658237e-08"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "trap_rule(p, (grid[1] - grid[0]).item())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "35ae5d57-4713-44e5-a1f6-4ff514d19792",
   "metadata": {},
   "outputs": [],
   "source": [
    "simp_arr = g[0,0,0,:].numpy().astype(np.float64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "5999ee54-a64b-4af9-ae2b-f3e5c1899675",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.00028225621198254766"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.dot(simp_arr, p)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "7963a47f-1abb-43ef-bc39-dd568cb04458",
   "metadata": {},
   "outputs": [],
   "source": [
    "from scipy import integrate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "7951fc44-ed3c-48cf-8f93-0148f125a8e3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-2.4768973119402e-07"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integrate.simpson(p, x=grid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "c3e09d98-62f2-45e3-8bf7-d9de80675a82",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 8.46452042e-04,  3.22882785e-03,  7.13857804e-03,  1.25589837e-02,\n",
       "        1.94692723e-02,  2.78407017e-02,  3.76406156e-02,  4.88287089e-02,\n",
       "        6.13609638e-02,  7.51861459e-02,  9.02495878e-02,  1.06489959e-01,\n",
       "        1.23842743e-01,  1.42237496e-01,  1.61601009e-01,  1.81854891e-01,\n",
       "        2.02918331e-01,  2.24706194e-01,  2.47131362e-01,  2.70103427e-01,\n",
       "        2.93530390e-01,  3.17317810e-01,  3.41370364e-01,  3.65591177e-01,\n",
       "        3.89883010e-01,  4.14148232e-01,  4.38289242e-01,  4.62209237e-01,\n",
       "        4.85811867e-01,  5.09002478e-01,  5.31687650e-01,  5.53776538e-01,\n",
       "        5.75179942e-01,  5.95812281e-01,  6.15590043e-01,  6.34434340e-01,\n",
       "        6.52268719e-01,  6.69022325e-01,  6.84627004e-01,  6.99020819e-01,\n",
       "        7.12145083e-01,  7.23947900e-01,  7.34380922e-01,  7.43403109e-01,\n",
       "        7.50977286e-01,  7.57073932e-01,  7.61667546e-01,  7.64740680e-01,\n",
       "        7.66279956e-01,  7.66280216e-01,  7.64740430e-01,  7.61667811e-01,\n",
       "        7.57073707e-01,  7.50977565e-01,  7.43402907e-01,  7.34381170e-01,\n",
       "        7.23947679e-01,  7.12145312e-01,  6.99020616e-01,  6.84627271e-01,\n",
       "        6.69022202e-01,  6.52268975e-01,  6.34434185e-01,  6.15590216e-01,\n",
       "        5.95812153e-01,  5.75180091e-01,  5.53776446e-01,  5.31687769e-01,\n",
       "        5.09002413e-01,  4.85811913e-01,  4.62209163e-01,  4.38289259e-01,\n",
       "        4.14148145e-01,  3.89882947e-01,  3.65591123e-01,  3.41370269e-01,\n",
       "        3.17317780e-01,  2.93530206e-01,  2.70103381e-01,  2.47131318e-01,\n",
       "        2.24706307e-01,  2.02918215e-01,  1.81855032e-01,  1.61600866e-01,\n",
       "        1.42237650e-01,  1.23842549e-01,  1.06490129e-01,  9.02493760e-02,\n",
       "        7.51863314e-02,  6.13607153e-02,  4.88289050e-02,  3.76403575e-02,\n",
       "        2.78409193e-02,  1.94690094e-02,  1.25592208e-02,  7.13835247e-03,\n",
       "        3.22910608e-03,  8.46214671e-04, -2.39852066e-07])"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integrate.cumulative_simpson(p, x=grid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "2620cc62-4709-4eb4-b2d8-cb066da693bd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([8.45910580e-04, 3.22774493e-03, 7.13593247e-03, 1.25547755e-02,\n",
       "       1.94625052e-02, 2.78313758e-02, 3.76277747e-02, 4.88123531e-02,\n",
       "       6.13401942e-02, 7.51609617e-02, 9.02191556e-02, 1.06454280e-01,\n",
       "       1.23801077e-01, 1.42189841e-01, 1.61546717e-01, 1.81793964e-01,\n",
       "       2.02850226e-01, 2.24630912e-01, 2.47048475e-01, 2.70012937e-01,\n",
       "       2.93431991e-01, 3.17211501e-01, 3.41255969e-01, 3.65468696e-01,\n",
       "       3.89752393e-01, 4.14009480e-01, 4.38142438e-01, 4.62054381e-01,\n",
       "       4.85649170e-01, 5.08831941e-01, 5.31509611e-01, 5.53590997e-01,\n",
       "       5.74987352e-01, 5.95612641e-01, 6.15383931e-01, 6.34221756e-01,\n",
       "       6.52050338e-01, 6.68798148e-01, 6.84397799e-01, 6.98786587e-01,\n",
       "       7.11906673e-01, 7.23705312e-01, 7.34135073e-01, 7.43153999e-01,\n",
       "       7.50725885e-01, 7.56820240e-01, 7.61412569e-01, 7.64484417e-01,\n",
       "       7.66023436e-01, 7.66023438e-01, 7.64484425e-01, 7.61412578e-01,\n",
       "       7.56820266e-01, 7.50725916e-01, 7.43154041e-01, 7.34135088e-01,\n",
       "       7.23705325e-01, 7.11906685e-01, 6.98786601e-01, 6.84397869e-01,\n",
       "       6.68798222e-01, 6.52050417e-01, 6.34221772e-01, 6.15383949e-01,\n",
       "       5.95612658e-01, 5.74987368e-01, 5.53591011e-01, 5.31509623e-01,\n",
       "       5.08831952e-01, 4.85649139e-01, 4.62054351e-01, 4.38142409e-01,\n",
       "       4.14009404e-01, 3.89752316e-01, 3.65468619e-01, 3.41255892e-01,\n",
       "       3.17211424e-01, 2.93431872e-01, 2.70012819e-01, 2.47048529e-01,\n",
       "       2.24630923e-01, 2.02850236e-01, 1.81793973e-01, 1.61546727e-01,\n",
       "       1.42189835e-01, 1.23801058e-01, 1.06454264e-01, 9.02191383e-02,\n",
       "       7.51609307e-02, 6.13401516e-02, 4.88123133e-02, 3.76277378e-02,\n",
       "       2.78313432e-02, 1.94624770e-02, 1.25547535e-02, 7.13595029e-03,\n",
       "       3.22775702e-03, 8.45918772e-04, 6.08045925e-09])"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "integrate.cumulative_trapezoid(p, x=grid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "d27eefb3-4fdb-4b93-bee8-ca87e546940d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([100])"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "grid.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "ee5260ae-3ca6-42e3-bf3a-949e5a67a65b",
   "metadata": {},
   "outputs": [],
   "source": [
    "k = x_train[1,0,0,0].item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "9c4b6104-3fc0-4d30-9162-4d94fb952f31",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0000, 0.0505, 0.1010, 0.1515, 0.2020, 0.2525, 0.3030, 0.3535, 0.4040,\n",
       "        0.4545, 0.5051, 0.5556, 0.6061, 0.6566, 0.7071, 0.7576, 0.8081, 0.8586,\n",
       "        0.9091, 0.9596])"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t[slice(*tpred)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "a762cf46-7097-413a-99d9-c5f6f3bee0a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Zs2aio6O1okTJ/K3R0RE6JFHHtFjjz2m6tWrq1u3bpd9HS6XS1OnTlVISIh8fHwUFhamVatW5W83DEOpqamaOnWqDMPQ5MmTr/DO/UdERIRGjx6tp556SlWrVlVwcHCBfS++T1FRUTIMo8D7lpSUpNtvv12+vr7605/+pClTpigvL69Aprlz5+ree++Vv7+/nn32WYWEhGju3LkFMnz99dey2Ww6cOCAJGnmzJlq2rSp/P39Vbt2bT388MM6e/Zsoa8hPT1dHTt2VEBAgAIDA9W8eXN9+eWXhY5fsmSJunTpIl9f3/x1F39O4uLiVK9ePVWuXFn33Xefzpw5U2DfHj16aMmSJYUeG4D7oxADqFDsdrteeOEFzZ49Wz///PM1HWvdunU6fPiwNm7cqJkzZ2rSpEm65557VKVKFW3dulUPPvig/v73v1/yPGPHjtUTTzyhr7/+Wm3btlWPHj108uRJSVJmZqY6deqkZs2a6csvv9SqVauUkZGh/v37FzjGggUL5O3trS1btuitt966bL7XX39dM2bM0CuvvKJvvvlG3bp107333qsffvhBknTkyBHdeuuteuKJJ3TkyBE9+eSTRX7tCxYskL+/v7Zu3aqXXnpJU6dO1Zo1ayRJ27dvlyTNnz9fR44cyV/etGmThg4dqjFjxui7777T22+/rdjYWD3//PMFjj158mRFRUVpx44duv/++zVw4EDFx8cXGLN48WK1a9dOdevWlSTZbDbNmjVLO3fu1IIFC7Ru3To99dRTheYfPHiwQkJCtH37dqWmpmrcuHHy8vIqdPymTZvUokWLS9bv3btXiYmJWrlypVauXKkNGzZc8pGcVq1aadu2bcrJySn0+ADcnAkAFcSwYcPMnj17mqZpmm3atDFHjhxpmqZpJiQkmP/9627SpElmaGhogX1fffVVs27dugWOVbduXdPpdOavu+WWW8zw8PD85by8PNPf39987733TNM0zX379pmSzGnTpuWPyc3NNUNCQszp06ebpmmazz77rNm1a9cCz33o0CFTkrlnzx7TNE3zzjvvNJs1a/aHr7dWrVrm888/X2Bdy5YtzYcffjh/OTQ01Jw0adIVj/Pf79vF52/fvv0lx3366afzlyWZCQkJBcZ07tzZfOGFFwqsi4uLM2+44YYC+z322GMFxnz99demYRjmgQMHTNM0TafTad54443m3LlzC828bNkys1q1avnL8+fPNytXrpy/HBAQYMbGxha6//+qXLmyuXDhwgLrJk2aZPr5+ZlZWVn568aOHWu2bt26wLj09HRTkrl///4iPx8A98IZYgAV0vTp07VgwQLt2rWr2Me49dZbZbP959dkzZo11bRp0/xlu92uatWq6dixYwX2a9u2bf6fHQ6HWrRokZ8jPT1d69evV6VKlfIff/7znyX9fjbyoubNm18xW1ZWlg4fPqx27doVWN+uXbtres0X3XbbbQWWb7jhhkte5/9KT0/X1KlTC7y2Bx54QEeOHNG5c+fyx/3vmdiwsDA1atQo/yzxhg0bdOzYMfXr1y9/zNq1a9W5c2fdeOONCggIUHR0tE6ePFnguP8tJiZG999/vyIjIzVt2rQC7+3l/PbbbwU+LnFRvXr1FBAQcMX34brrrpOkQrMAcH8UYgAVUocOHdStWzeNHz/+km02m02maRZYd7kvd/3vf7EbhnHZdS6Xq8i5zp49qx49eigtLa3A44cfflCHDh3yx/n7+xf5mKWhOK/z7NmzmjJlSoHXtWPHDv3www8FyublXtvgwYPzC3F8fLz+8pe/5H8JcP/+/brnnnt02223acWKFUpNTdWcOXMkFf6Fw8mTJ2vnzp26++67tW7dOjVu3FgJCQmFZq9evfplv4hZlPfh1KlTkqQaNWoUenwA7o1CDKDCmjZtmj766CN9/vnnBdbXqFFDR48eLVCKS/LawV988UX+n/Py8pSamqpGjRpJkm6//Xbt3LlT9erV080331zgcTUlODAwULVq1dKWLVsKrN+yZYsaN25cMi/kCry8vC65Xu/tt9+uPXv2XPK6br755gJn2i9n0KBB+vbbb5Wamqrly5dr8ODB+dtSU1Plcrk0Y8YMtWnTRg0bNtThw4f/MGPDhg31+OOPa/Xq1erdu/dlvwB5UbNmzfTdd9/94TEv59tvv1VISIiqV69erP0BWI9CDKDCatq0qQYPHqxZs2YVWB8REaHjx4/rpZde0t69ezVnzhx9+umnJfa8c+bMUUJCgnbv3q1Ro0bp119/1ciRIyVJo0aN0qlTpzRw4EBt375de/fu1WeffaYRI0Zc1Q0hpN+/vDd9+nQtXbpUe/bs0bhx45SWlqYxY8aU2GspTL169ZScnKyjR4/mn1mdOHGiFi5cqClTpmjnzp3atWuXlixZogkTJhTpeHfccYf++te/yul06t57783fdvPNNys3N1ezZ8/WTz/9pLi4uEK/aCj9/vGHRx55RCkpKTpw4IC2bNmi7du35/+j5HK6deumzZs3X8U78B+bNm1S165di7UvAPdAIQZQoU2dOvWS/+Ju1KiR3nzzTc2ZM0ehoaHatm3bVV2B4Y9MmzZN06ZNU2hoqDZv3qwPP/ww/+zhxbO6TqdTXbt2VdOmTfXYY48pKCjoD8+i/q/Ro0crJiZGTzzxhJo2bapVq1bpww8/VIMGDUrstRRmxowZWrNmjWrXrq1mzZpJ+r1Urly5UqtXr1bLli3Vpk0bvfrqq/lXivgjgwcPVnp6uqKiovI/lytJoaGhmjlzpqZPn64mTZpo8eLFV7ysnt1u18mTJzV06FA1bNhQ/fv3V/fu3TVlypQrPvfOnTu1Z8+eIr4Dvzt//rwSExP1wAMPXNV+ANyLYf7vB+kAAPBAY8eOVVZWlt5+++0i7zN37lwlJCRo9erVpZgMQGnjDDEAAJKeeeYZ1a1b96q+JOnl5aXZs2eXYioAZYEzxAAAAPBonCEGAACAR6MQAwAAwKNRiAEAAODRKMQAAADwaBRiAAAAeDQKMQAAADwahRgAAAAejUIMAAAAj0YhBgAAgEf7f6h4Ny/fxDfaAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Function to integrate\n",
    "def f(x):\n",
    "    return np.sin(x)\n",
    "    # return np.exp(-k*t[slice(*tpred)][-1].item())*np.sin(x)  # Example function, modify as needed\n",
    "\n",
    "# Exact integral of the function over [a, b]\n",
    "def exact_integral(a, b):\n",
    "    return 2\n",
    "    return -np.exp(-k*t[slice(*tpred)][-1].item())*np.cos(b) + np.exp(-k*t[slice(*tpred)][-1].item())*np.cos(a)\n",
    "\n",
    "# Simpson's rule integration\n",
    "def simpsons_rule(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = simpson_rule(fx, h)\n",
    "    return integral\n",
    "\n",
    "def trapezoidal_rule(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = trap_rule(fx, h)\n",
    "    return integral\n",
    "\n",
    "def scipy_simpson(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = integrate.simpson(fx, x=x)\n",
    "    return integral\n",
    "\n",
    "# Range of intervals to test\n",
    "n_values = np.array([2, 4, 8, 16, 32, 64, 128, 256, 512, 1024])\n",
    "\n",
    "# Parameters\n",
    "a = 0\n",
    "b = np.pi  # Example interval [0, pi]\n",
    "\n",
    "# Compute exact integral\n",
    "I_exact = exact_integral(a, b)\n",
    "\n",
    "# Initialize arrays to store errors\n",
    "errors_s = np.zeros_like(n_values, dtype=float)\n",
    "errors_t = np.zeros_like(n_values, dtype=float)\n",
    "errors_sci = np.zeros_like(n_values, dtype=float)\n",
    "\n",
    "# Compute errors for each n\n",
    "for i, n in enumerate(n_values):\n",
    "    I_approx_s = simpsons_rule(f, a, b, n)\n",
    "    I_approx_t = trapezoidal_rule(f, a, b, n) \n",
    "    I_approx_sci = scipy_simpson(f, a, b, n) \n",
    "    errors_s[i] = np.abs(I_approx_s - I_exact)\n",
    "    errors_t[i] = np.abs(I_approx_t - I_exact)\n",
    "    errors_sci[i] = np.abs(I_approx_sci - I_exact)\n",
    "\n",
    "# Plot convergence\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.loglog(n_values, errors_s, marker='o', linestyle='-', label=\"simpson\")\n",
    "plt.loglog(n_values, errors_t, marker='o', linestyle='-', label=\"trapezoid\")\n",
    "plt.loglog(n_values, errors_sci, marker='o', linestyle='-', label=\"scipy_simpson\")\n",
    "plt.xlabel('Number of Intervals (n)')\n",
    "plt.ylabel('Absolute Error')\n",
    "plt.legend()\n",
    "plt.title('Convergence of Simpson\\'s Rule')\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "05a90407-2523-4863-b929-ede36ceaf168",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Simpson's convergence rate:  4.031803283646012\n",
      "Scipy's Simpson's convergence rate:  4.0317304907970515\n",
      "Trapezoidal's convergence rate:  2.0041311505603736\n"
     ]
    }
   ],
   "source": [
    "coefficients = np.polyfit(np.log(n_values), np.log(errors_s), 1)\n",
    "slope = -coefficients[0]  # Slope of the line in log-log plot\n",
    "print(\"Simpson's convergence rate: \", slope)\n",
    "\n",
    "coefficients = np.polyfit(np.log(n_values), np.log(errors_sci), 1)\n",
    "slope = -coefficients[0]  # Slope of the line in log-log plot\n",
    "print(\"Scipy's Simpson's convergence rate: \", slope)\n",
    "\n",
    "coefficients = np.polyfit(np.log(n_values), np.log(errors_t), 1)\n",
    "slope = -coefficients[0]  # Slope of the line in log-log plot\n",
    "print(\"Trapezoidal's convergence rate: \", slope)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a6349c93-c446-45d1-9bc7-7b99f475196f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 410,
   "id": "3cb2c9d1-7acc-43cc-8f39-f43b76be9165",
   "metadata": {},
   "outputs": [],
   "source": [
    "t = torch.linspace(0, 1, n_t)\n",
    "grid = torch.linspace(0, 2 * np.pi, 1000)\n",
    "a, u, p = dataset_class.generate_dataset(n_train, grid, t, tpred, *dataset_params)\n",
    "x_train, y_train = get_xy_from_pu(p, u, is_markov=is_markov)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 411,
   "id": "12882252-ad82-4e67-b5fa-6d720acd18fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000])"
      ]
     },
     "execution_count": 411,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train[1,:,0,0].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 412,
   "id": "c9a18528-a93b-4116-87e1-d9ce1748dca8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<function datasets.HeatEquation_1D.get_mass_rhs_func.<locals>.mass_rhs_func(inputs)>"
      ]
     },
     "execution_count": 412,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_class.get_mass_rhs_func(x=x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 431,
   "id": "af099009-d522-4aec-9416-76326734fc9b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.5051)"
      ]
     },
     "execution_count": 431,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t_val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 451,
   "id": "061eda5d-8ef7-4567-a50b-042936718a7b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAsQAAAIoCAYAAABu0/16AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAADGb0lEQVR4nOzdd3xUZdbA8d/MpPfeICQhoYVeQgdRQUBEQRTsKLZVFBXXte1rWVcBXVkbi11RLIBYUBAVFelNikBogVACCWmk95n7/jGZQEgCKTO5d2bO9/NRJndu7j2TaWeeOc95dIqiKAghhBBCCOGk9GoHIIQQQgghhJokIRZCCCGEEE5NEmIhhBBCCOHUJCEWQgghhBBOTRJiIYQQQgjh1CQhFkIIIYQQTk0SYiGEEEII4dQkIRZCCCGEEE5NEmIhhBBCCOHUJCEWQji8lStX0qtXLzw8PNDpdOTl5dW738cff4xOp+Po0aOtGp8QjmT16tXodDpWr16tdihCNJokxMIpHT58mHvvvZf27dvj4eGBn58fQ4YM4fXXX6e0tFTt8IQV5eTkMHnyZDw9PZk3bx6ffvop3t7eVj9PcnIyzz33nN0k0yUlJTz33HNOm7Tcfvvt+Pj4NHi9TqfjgQcesGkM//vf//j444/rbLcklA399+WXX9o0rsZqKH6tOHDgAI888giDBw+u+TDc0PPz3L+vi4sLQUFB9O3bl4ceeojk5OTWDVyowkXtAIRobcuXL+f666/H3d2d2267jW7dulFRUcG6det47LHH2Lt3L++++67aYQor2bp1K4WFhbzwwguMHDnygvveeuut3HDDDbi7uzf5PMnJyTz//POMGDGC2NjYZkbbekpKSnj++ecBGDFihLrBOKn//e9/hISEcPvtt9d7/YwZM0hKSqqzfdCgQTaOrHEain/48OGUlpbi5uamTmDVNm7cyBtvvEFiYiJdunRh586dF9x/1KhR3HbbbSiKQn5+Prt27WLBggX873//Y86cOcycObN1AheqkIRYOJXU1FRuuOEGYmJi+O2334iMjKy5bvr06aSkpLB8+XIVI2y5srIy3Nzc0OvlCyCAzMxMAAICAi66r8FgwGAw2Dgi26iqqsJkMqmehBQXF9tkBN4ZDRs2jOuuu07tMJpMr9fj4eGhdhhcffXV5OXl4evry3/+85+LJsQdO3bklltuqbVt9uzZjB8/nkcffZTOnTtz5ZVX2jBioSZ5xxRO5eWXX6aoqIgPPvigVjJskZCQwEMPPVTzc1VVFS+88ALx8fG4u7sTGxvLU089RXl5ea3fi42N5aqrrmLdunX0798fDw8P2rdvzyeffFKzz7Zt29DpdCxYsKDOeX/66Sd0Oh0//PBDzbaTJ08ybdo0wsPDcXd3p2vXrnz44Ye1fs/y1eqXX37JP//5T9q0aYOXlxcFBQUALFmyhMTERDw8POjWrRvffPMNt99+e50RTJPJxGuvvUbXrl3x8PAgPDyce++9lzNnzjT5dlrk5eXxyCOPEBsbi7u7O23btuW2224jOzu7Zp/y8nKeffZZEhIScHd3Jzo6mn/84x91/r4NWbJkCX379sXT05OQkBBuueUWTp48WXP9iBEjmDp1KgBJSUnodLoGR+Og/hrixtzmjz/+mOuvvx6ASy+9tOar13PLEX788UeGDRuGt7c3vr6+jBs3jr1799Z7my52nx09ehSdTsd//vMfXnvttZrHZ3JyMhUVFTzzzDP07dsXf39/vL29GTZsGL///nut3w8NDQXg+eefr4n3ueeeq9nnt99+q4k3ICCAa665hn379tWK9bnnnkOn05GcnMxNN91EYGAgQ4cOBSAjI4M77riDtm3b4u7uTmRkJNdcc02jSkqacu6UlBRuv/12AgIC8Pf354477qCkpOSi52iOxj5eP/roIy677DLCwsJwd3cnMTGR+fPn19onNjaWvXv38scff9T8/ZszUl9eXs4jjzxCaGgovr6+XH311aSlpdW5P+t73sPZv6M142+ohvhiz1dLnD4+Ppw8eZIJEybg4+NDaGgof//73zEajU362wQFBeHr69uk3zlfcHAwX375JS4uLrz44ostOpbQNhkhFk7l+++/p3379gwePLhR+991110sWLCA6667jkcffZTNmzcza9Ys9u3bxzfffFNr35SUFK677jruvPNOpk6dyocffsjtt99O37596dq1K/369aN9+/YsXry4JkmzWLRoEYGBgYwePRqA06dPM3DgwJo6xtDQUH788UfuvPNOCgoKePjhh2v9/gsvvICbmxt///vfKS8vx83NjeXLlzNlyhS6d+/OrFmzOHPmDHfeeSdt2rSpczvvvfdePv74Y+644w5mzJhBamoqb731Fjt27GD9+vW4uro2+nYCFBUVMWzYMPbt28e0adPo06cP2dnZLFu2jLS0NEJCQjCZTFx99dWsW7eOe+65hy5durB7927++9//cvDgQb799tsL3jeWeJOSkpg1axanT5/m9ddfZ/369ezYsYOAgACefvppOnXqxLvvvsu//vUv4uLiiI+Pb9R935T7dvjw4cyYMYM33niDp556ii5dugDU/Pvpp58ydepURo8ezZw5cygpKWH+/PkMHTqUHTt21CQqTbnPwJy4lJWVcc899+Du7k5QUBAFBQW8//773Hjjjdx9990UFhbywQcfMHr0aLZs2UKvXr0IDQ1l/vz53HfffUycOJFrr70WgB49egCwatUqxo4dS/v27XnuuecoLS3lzTffZMiQIWzfvr1OYnX99dfToUMHXnrpJRRFAWDSpEns3buXBx98kNjYWDIzM/nll184fvz4BUtKmnruyZMnExcXx6xZs9i+fTvvv/8+YWFhzJkzp1H37bkf0C6kKY/X+fPn07VrV66++mpcXFz4/vvvuf/++zGZTEyfPh2A1157jQcffBAfHx+efvppAMLDw2uds7CwsN74goODa5LYu+66i4ULF3LTTTcxePBgfvvtN8aNG9eo29QQa8V/rsY8Xy2MRiOjR49mwIAB/Oc//2HVqlW8+uqrxMfHc99997XotjVHu3btuOSSS/j9998pKCjAz8+v1WMQrUARwknk5+crgHLNNdc0av+dO3cqgHLXXXfV2v73v/9dAZTffvutZltMTIwCKGvWrKnZlpmZqbi7uyuPPvpozbYnn3xScXV1VXJzc2u2lZeXKwEBAcq0adNqtt15551KZGSkkp2dXevcN9xwg+Lv76+UlJQoiqIov//+uwIo7du3r9lm0b17d6Vt27ZKYWFhzbbVq1crgBITE1Ozbe3atQqgfPbZZ7V+f+XKlXW2N/Z2PvPMMwqgfP3118r5TCaToiiK8umnnyp6vV5Zu3ZtrevffvttBVDWr19f53ctKioqlLCwMKVbt25KaWlpzfYffvhBAZRnnnmmZttHH32kAMrWrVsbPN75+6ampjb5Ni9ZskQBlN9//73WMQsLC5WAgADl7rvvrrU9IyND8ff3r7W9sfdZamqqAih+fn5KZmZmreNWVVUp5eXltbadOXNGCQ8Pr/UYy8rKUgDl2WefrfN36NWrlxIWFqbk5OTUbNu1a5ei1+uV2267rWbbs88+qwDKjTfeWOd8gPLKK6/UOfbFNPXc594mRVGUiRMnKsHBwRc9z9SpUxXggv9Nnz69Zv+mPF7Pfy4qiqKMHj1aad++fa1tXbt2VS655JI6+1qe1w39l56erijK2deo+++/v9bv33TTTXXu26lTp9Z6DFlY/o7nslb8ludCU56vlvvlX//6V61j9u7dW+nbt2+dczXWK6+8Uue5fa7z7+/zPfTQQwqg7Nq1q9kxCG2TkgnhNCxlBI39Cm3FihUAdSZSPProowB1ao0TExMZNmxYzc+hoaF06tSJI0eO1GybMmUKlZWVfP311zXbfv75Z/Ly8pgyZQoAiqKwdOlSxo8fj6IoZGdn1/w3evRo8vPz2b59e61zT506FU9Pz5qfT506xe7du7nttttqzaS/5JJL6N69e63fXbJkCf7+/owaNarWufr27YuPj0+tr9obezuXLl1Kz549mThxYp2/q2Vka8mSJXTp0oXOnTvXOu9ll10GUOe859q2bRuZmZncf//9tWoVx40bR+fOna1eB96Y29yQX375hby8PG688cZat9NgMDBgwICa29mU+8xi0qRJNaUPFgaDoaaO2GQykZubS1VVFf369avzuKlPeno6O3fu5PbbbycoKKhme48ePRg1alTN8+Jcf/vb32r97OnpiZubG6tXr65TdmPrcw8bNoycnJya5/uFeHh48Msvv9T73/ma8ng997mYn59PdnY2l1xyCUeOHCE/P//if4hqzzzzTL2xWf42lr/HjBkzav3e+d8gNZW14rdozvO1vvu1Mc83W7E8JwsLC1WLQdiWlEwIp2H5mquxL2jHjh1Dr9eTkJBQa3tERAQBAQEcO3as1vZ27drVOUZgYGCthKBnz5507tyZRYsWceeddwLmcomQkJCaN9asrCzy8vJ49913G+x2YZkoZhEXF1cndqBO7JZt5yZGhw4dIj8/n7CwsEadqzG38/Dhw0yaNKne45173n379tVJ6Bo677kst69Tp051ruvcuTPr1q274LmbqjG3uSGHDh0CqLl/z2d5XDblPrM4/363WLBgAa+++ir79++nsrLyovuf60J/2y5duvDTTz/VmTh3/nHd3d2ZM2cOjz76KOHh4QwcOJCrrrqK2267jYiICKue+/z7JjAwEIAzZ85c9Kttg8Fw0c4jFk15vK5fv55nn32WjRs31qlnzs/Px9/fv1Hn7N69+wXjs7xGnV8GVN/frymsFf+5cTYUV33PVw8Pjzp/58Y+32ylqKgIaPyAirA/khALp+Hn50dUVBR79uxp0u+dP+GkIQ11J1CqayotpkyZwosvvkh2dja+vr4sW7aMG2+8ERcX89PRZDIBcMstt9SpNbaw1HpanDui01Qmk4mwsDA+++yzeq+vbwSyPuffzsact3v37sydO7fe66Ojo5t0PFtqyW223J+ffvppvcmg5X5vjvru94ULF3L77bczYcIEHnvsMcLCwjAYDMyaNYvDhw83+1xNjePhhx9m/PjxfPvtt/z000/83//9H7NmzeK3336jd+/eVju3tR6PF9PYx+vhw4e5/PLL6dy5M3PnziU6Oho3NzdWrFjBf//735rHQ2tr6HXs/IlqWohfi51e9uzZg8FgaNSHSmGfJCEWTuWqq67i3XffZePGjRft5RkTE4PJZOLQoUM1k6PAPOEtLy+PmJiYZsUwZcoUnn/+eZYuXUp4eDgFBQXccMMNNddbZosbjcZGj17VFzuYJ4Od7/xt8fHxrFq1iiFDhrQosT7/mBf74BEfH8+uXbu4/PLLG/2hw8Jy+w4cOFBn5PXAgQPNvm9aoqHbYBm9CwsLu+D92ZT77EK++uor2rdvz9dff10rpmeffbZR8Z77tz3f/v37CQkJaXRbtfj4eB599FEeffRRDh06RK9evXj11VdZuHChzc9tbY19vH7//feUl5ezbNmyWqPX9ZUANfVxfz7La9Thw4drjb7W9/cLDAysd4XG87/pskX8Wny+NsXx48f5448/GDRokIwQOzCpIRZO5R//+Afe3t7cddddnD59us71hw8f5vXXXweo6Tf52muv1drHMkLU3JncXbp0oXv37ixatIhFixYRGRnJ8OHDa643GAxMmjSJpUuX1ptUZmVlXfQcUVFRdOvWjU8++aTmqz6AP/74g927d9fad/LkyRiNRl544YU6x6mqqmpwmeMLmTRpErt27arTiQPOjtxNnjyZkydP8t5779XZp7S0lOLi4gaP369fP8LCwnj77bdrtbz68ccf2bdvX4tn2TeHJVE7/+81evRo/Pz8eOmll2qVL1hY7s+m3GcXYhldO3eEdPPmzWzcuLHWfl5eXvXGGxkZSa9evViwYEGt6/bs2cPPP//cqD6sJSUllJWV1doWHx+Pr6/vBVvqWePcttLYx2t9f//8/Hw++uijOr/n7e3drOeXxdixYwF44403am0//zULzH///Px8/vrrr5pt6enpdZ6jtohfi8/XxsrNzeXGG2/EaDTWdNMQjklGiIVTiY+P5/PPP2fKlCl06dKl1kp1GzZsYMmSJTV9anv27MnUqVN59913ycvL45JLLmHLli0sWLCACRMmcOmllzY7jilTpvDMM8/g4eHBnXfeWWcRjdmzZ/P7778zYMAA7r77bhITE8nNzWX79u2sWrWK3Nzci57jpZde4pprrmHIkCHccccdnDlzhrfeeotu3brVSrguueQS7r33XmbNmsXOnTu54oorcHV15dChQyxZsoTXX3+9yYsDPPbYY3z11Vdcf/31TJs2jb59+5Kbm8uyZct4++236dmzJ7feeiuLFy/mb3/7G7///jtDhgzBaDSyf/9+Fi9ezE8//US/fv3qPb6rqytz5szhjjvu4JJLLuHGG2+saeMUGxvLI4880qR4raFXr14YDAbmzJlDfn4+7u7uNb1c58+fz6233kqfPn244YYbCA0N5fjx4yxfvpwhQ4bw1ltvAY2/zy7kqquu4uuvv2bixImMGzeO1NRU3n77bRITE2sdw9PTk8TERBYtWkTHjh0JCgqiW7dudOvWjVdeeYWxY8cyaNAg7rzzzprWZ/7+/rV62zbk4MGDXH755UyePJnExERcXFz45ptvOH36dK1vQ+rT0nPbSmMfr1dccQVubm6MHz+ee++9l6KiIt577z3CwsJIT0+vdcy+ffsyf/58/v3vf5OQkEBYWFitEdS1a9fW+WAB5pKpHj160KtXL2688Ub+97//kZ+fz+DBg/n111/r/Ubhhhtu4PHHH2fixInMmDGjpvVfx44da9WnWzN+C7Wer/n5+bz55puAuS4a4K233iIgIICAgIA6S3MfPHiQhQsXoigKBQUF7Nq1iyVLllBUVMTcuXMZM2aMTeIUGqFSdwshVHXw4EHl7rvvVmJjYxU3NzfF19dXGTJkiPLmm28qZWVlNftVVlYqzz//vBIXF6e4uroq0dHRypNPPllrH0Uxt+YaN25cnfNccskl9bYlOnToUE0LpXXr1tUb4+nTp5Xp06cr0dHRiqurqxIREaFcfvnlyrvvvluzj6W90ZIlS+o9xpdffql07txZcXd3V7p166YsW7ZMmTRpktK5c+c6+7777rtK3759FU9PT8XX11fp3r278o9//EM5depUs25nTk6O8sADDyht2rRR3NzclLZt2ypTp06t1UquoqJCmTNnjtK1a1fF3d1dCQwMVPr27as8//zzSn5+fr236VyLFi1Sevfurbi7uytBQUHKzTffrKSlpdXaxxpt1xp7m9977z2lffv2isFgqNOC7ffff1dGjx6t+Pv7Kx4eHkp8fLxy++23K9u2bat1jMbcZ5a2a/W1NTOZTMpLL72kxMTEKO7u7krv3r2VH374od62Wxs2bFD69u2ruLm51WnTtWrVKmXIkCGKp6en4ufnp4wfP15JTk6u9fuWll1ZWVm1tmdnZyvTp09XOnfurHh7eyv+/v7KgAEDlMWLF9eJtz4tOXd992F9pk6dqnh7ezd4PfW04Wrs43XZsmVKjx49FA8PDyU2NlaZM2eO8uGHH9aJKyMjQxk3bpzi6+urADWPp4u1XTv3fiotLVVmzJihBAcHK97e3sr48eOVEydO1NtS7+eff1a6deumuLm5KZ06dVIWLlxYb9s1a8V/fgvCxjxfG7pf6ovzYizPk/r+O/+5cO51er1eCQgIUHr37q089NBDyt69e5t0XmGfdIpi5ZkHQghNsyzMUF9rKaFNcp+JptLpdDz77LOqjqoLYU+khlgIB1VZWUlVVVWtbatXr2bXrl3NWiJW2J7cZ0IIoQ6pIRbCQZ08eZKRI0dyyy23EBUVxf79+3n77beJiIio0/ReaIPcZ0JcXG5uLhUVFQ1ebzAYGuwXLURDJCEWwkEFBgbSt29f3n//fbKysvD29mbcuHHMnj2b4OBgtcMT9ZD7TIiLu/baa/njjz8avD4mJoajR4+2XkDCIUgNsRBCCCHsxp9//nnBVes8PT0ZMmRIK0YkHIEkxEIIIYQQwqnJpDohhBBCCOHUpIa4mUwmE6dOncLX17fFy28KIYQQQgjrUxSFwsJCoqKi6iyCdS5JiJvp1KlTREdHqx2GEEIIIYS4iBMnTtC2bdsGr5eEuJl8fX0B8x/Yz89P5WiEuLjKykp+/vnnmqWZhRBNI88hIZpPredPQUEB0dHRNXlbQyQhbiZLmYSfn58kxMIuVFZW4uXlhZ+fn7yZC9EM8hwSovnUfv5crLxVJtUJIYQQQginJgmxEEIIIYRwapIQCyGEEEIIpyYJsRBCCCGEcGqSEAshhBBCCKcmCbEQQgghhHBqkhALIYQQQginJgmxEEIIIYRwapIQN9G8efNITEwkKSlJ7VCEEEIIIYQVSELcRNOnTyc5OZmtW7eqHYoQQgghhLACSYiFEEIIIYRTk4RYCCGEEEI4NUmIhRBCCCGEU3NROwAhRD1MRji2AYpOg084xAwGvUHtqIQQwjrkNc45KSZ0x9ZBaY7m7ndJiIXQmuRlsPJxKDh1dptfFIyZA4lXqxeXEEJYg7zGOSXd/h+4Yu9MXHbmnt2ooftdSiaE0JLkZbD4ttpvFAAF6ebtycvUiUsIIaxBXuOcU/IyDEvvwKMyt/Z2Dd3vkhALoRUmo3nUBKWeK6u3rXzCvJ8QQtgbeY1zTufc77o6V2rnfpeEWAitOLah7qhJLQoUnDTvJ4QQ9kZe45xT9f1eNxm20Mb9LgmxEFpRdNq6+wkhhJbIa5xzspP7XSbVCaEVPuHW3U/YHaPJyPbM7WSVZBHqFUqfsD4YNDIDW4gWk9c452Qn97skxEJoRe6Ri+ygM8/IjRncKuGI1rXq2Cpmb5nN6ZKzoyThXuE80f8JRsaMVDEyIawkZrD5NawgnfrriOU1ziFV3+9KQTo6Dd/vUjIhhNqqKuCHR+D7GedsbKDaasxszfRsFNaz6tgqZq6eWSsZBsgsyWTm6pmsOrZKpciEsCK9wdxiq17Vr3nyGud4zrnf66bD2rnfJSEWQk0F6bDgKtj2IaCDS5+G6z8Bv8ja+7n7wuRPNNGrUViX0WRk9pbZKPW8VVi2zdkyB6PMvBeOIPFqGPVC3e1+UfIa58gSr8Y46SMqDN61t2vofpeSCSHUcnyTuf9i0Wlw94dJ70PHK8zXdbnKPOP2r0Ww41MI766JFwxhfdszt9cZGT6XgkJGSQab0zczuI18lSwcQElW7Z973gTXvKX6CKGwLaXzVfzVdjNJx+ZDSCcY96qsVCeEU1MU2Po+rHwSTJUQlghTFkJw/Nl99AaIGwa+keaE+OQ2qCwFV0/14hY2kXV+ctCAe1fdi6+bL8EewQR7BhPsEUyIZ0jN5fO3uRncbBy5EM1gMsHupebLPhFQlAGBMZpJioSN6aoLE3zCzO9xGiIJsRCtqbIMlj8KOxeaf06cANfMA3ef+vcPjjcnxYXpcGILtL+k1UIVrSPUK7TR+xZWFFJYUcjRgqMX3dfX1Zdgz2CCPILqJM4hniFnk2jPYNwN7i24BS0n3TWcyIlNUJAG7n6QMPLsa6EQKpOEWIjWkp8Gi26BUzvMn5JHPgeDZ4Cu4Xbl6HQQOxR2L4Gj6yQhdkB9wvoQ7hVOZklmvXXEOnSEe4Wz6KpF5JXnkVOWQ05pTs2/2aXZtbZll2ZTZaqisLKQwsrGJc8+rj6EeIYQ5BHU8Ohz9WUPFw+r3n7pruFkdi8x/9tlPLha97EkREtIQixEa0hdC0tuh5Js8AyE6z6C+Esb97uxw6oT4rU2DVGow6A38ET/J5i5emad63TVM7Af7/84QZ5BBHkG0Z72FzyeoigUVBScTZLPSZ7rS6IrTZUUVRZRVFnU6OT5/DKNcxPmcxPpiyXPlu4a538QsHTXmDtiriTFjsRYCXu/NV/ufh3sX65qOEIN9bVd0wZJiIWwJUWBTf+Dn/8PFCNEdIcpn5lr5hordqj537RtUFECbl62iVWoZmTMSOaOmMv/rf8/iiqLaraHe4XzeP/Hm5QU6nQ6/N398Xf3p73/xZPnwspCc4J8buJcz+Xs0uxayfOxgmMXjcXb1btWkmwZgQ7xDCHQPZAXNr3QYHcNHTrmbJnDpdGXSvmEozj8O5TmgncoxA4/mxAr2k2ShPOQhLiJ5s2bx7x58zAapQWSuIiKEnNvYctXhD2mwFWvNT2hDWoPvlFQeApObG78yLKwKyNjRnIk/whv7niTfuH9uL/X/TavpdXpdPi5+eHn5tfo5NmSJGeXZddczi3LrTPyXGGqoLiymOLKYo4XHm9ybJbuGtszt5MUkdTcmyi0xPJa2PVaMEj6IbRFHpFNNH36dKZPn05BQQH+/v5qhyO06sxR+PIWOL0bdAYY/RIMuPfC9cIN0enMs3H/WmSuI5aE2GHpq2dgR/tGay4JPDd5jvOPu+C+iqJQVFlUZ+Q5uzS7Jnk+nH+YE4UnLnrexnbhEBpXUXJ2RLj79erGIkQ9JCEWwtpSfoWld0LpGfNXg9d/fLbsoblih55NiIXQOJ1Oh6+bL75uvg0mz1sztjLtp2kXPVZTunAIDTv4I1QWQ0AMtO2ndjRC1CEr1QlhLYoCa+fCZ9eZk+E2feGeP1qeDIN5Yh3AyT+horjlxxNCZZbuGroGlinXoSPCK4I+YX1aOTJhE7u/Mv/b/brmfVMmhI1JQiyENZQXwpKp8OvzoJigz21w+wrwb2Od4wfGgl9b80IeJzZb55hCqMjSXQOoNylWUHi8/+Myoc4RlOTCoV/Ml6VcQmiUJMRCtFTOYXh/JCR/B3pX88S5q9+0bo9NSx0xmFu4CeEALN01wrzC6lzn5eKluTpq0Uz7lpk/zId3g7AuakcjRL2khtgOVFRV8fmu1RwvyKCdXwQ39RyBm4vcdZpwYCV8fTeUF5iXIZ3yKUT3t825YofCri+kjlg4lJExI7k0+tKaleoCPQKZvXk2RwqO8NaOt3h64NNqhyha6txyiVqkdEJoh2RVGvfK2iV8eugNFENezba5uwK4tcMMHhsmXz2pxmSCNS/D6lnmn6MHwuQF4Bthu3Na6ohPbYfyooaXexZ2T+dkNZYGvaHWaPBTA5/irp/vYvHBxVzX8To6BXVSMTrRIgWnzn6I7zZJ3ViEuAApmdCwV9YuYcHhf2HS59XabtLnseDwv3hl7RJ1AnN2Zfnw5U1nk+Gku2Hq97ZNhsG8mId/OzBVwYlNtj2XECoaEDmAK2KuwKSYeGnzSyiycIP92vM1oJgHDQLaqR2NUJmWP+pLQqxRFVVVfHroDaDuhFzLz58efIOKqqpWjszJZe6H9y4ztxAyuMM1/4Nx/wEXt9Y5v9QRCyfx935/x9PFk+2Z21meKkv82i3LYhx1yiXOJR94nI4GvwWThFijPt+1GsWQ1+BjRqcDxSWPz3etbtW4nFryd/D+5ZCTYu74MG0l9L65dWOwtHCTOmLh4CJ9Irm7+90AvLrtVYoqii7yG0JzslMgfad5caKuE9WORogLkoRYo44XZFh1P9ECJiOseh4W3wYVReZa3nv/gDYq9Ee1JMSndphbvQnhwKZ2nUq0bzTZpdm889c7aocjmmpP9WS6+EvBO0TdWIS4CEmINaqdX+PqURu7n2imklz47HpYN9f886AH4NZv1XtxD2hnXulJMcJxqSMWjs3N4FbTq3hh8kKO5B9ROSLRaIpyTrmETAAX2icJsUbd1HMEOmMADc0lURTQVQVwU88RrRqXU8nYDe+OgMO/gosnTPoARr8IBpWbs1i6TaSuUTcOIVrB8LbDuaTtJVQpVczaPEsm2NmL9J3m8jIXD+g8Tu1ohLgoSYg1ys3FhVs7zACokxRbfr614wzpR2wru7+C90dB3jHziOxdv1xkUkgrskyskzpi4SQeT3ocV70rm9I38evxX9UORzSGpfdwp7Hg7qtuLEI0giTEGvbYsOuZGv8MelNAre16YwBT45+RPsS2YKyCn56GpXdCVSnEXw73rIaI7mpHdpaljjh9J5QVqBqKsC4Z/axftF80t3e9HYCXt75MaVWpugGJCzMZYc9S82UplxB2QhJijXts2PVsu+13FJP5rrox5im2Tf1dkmFbKM6GTyfAxrfMPw97FG5eAl5BqoZVh39bCIwDxQTHN6odjRCt4q7udxHhHUF6cTof7vlQ7XDEhRzbAIXp4OEPCSMb3k+DrbeE85KE2A6YyyLMd9WVnQZJmYQtnNwO71wCR9eCmw9M/hQufwb0BlXCMZqMbM3YyoojK9iasRWjyVh7h5r2a9KPWDgHL1cvHuv3GAAf7v6QE4UnVI5INMgyma7L1eDirm4sQjSSZFZC7PgMfngEjOUQnABTPoOwzqqFs+rYKmZvmc3pktM128K9wnmi/xOMjKkebYkbDjs+lQU6HJRO0+s5qWdUzCgGRA5gc/pmXt76Mm9e9qbaIYnzVVWYe7aDlEuIujRcFiYjxMJ5VVXA8kfhu/vNyXDHsXD3b6onwzNXz6yVDANklmQyc/VMVh1bZd5gGSHO+AtK81o3SCFUotPpeLL/k7joXFh9YjVr0+QDoeYc/hXK8sAn4uzr1MVoOEkStqK9D/2SENsZmXRjJYWnYcF42Po+oIMRT8ENn5tr3lRiNBmZvWU2Sj3LmFq2zdkyx1w+4RcFQfFSRyycTnxAPDd1uQmAOVvnUGGsUDkiUYulXKLbtaqVnAnRHJIQC+dzYgu8MxxObAJ3f7hpEYx4HPTqPh22Z26vMzJ8LgWFjJIMtmduN2+QZZyFk7qv530EewRzrOAYnyR/onY4wqK8CPavMF/WSptKIRpJEmLhPBQFtn0IH10JRRkQ2hnu+R06jlY7MgCySrKatl/ccPO/skCHcDI+bj482u9RAN79610yimUJe004sMLcrjKoPUSpsLS9EC0gCbFwDpVlsOxB8+Q5UyUkXgN3/QrB8WpHViPUK7Rp+9XUEe+G0jM2ikoIbbqq/VX0Cu1FaVUpc7fNVTscAWcX4+h+vbRUE3ZHEmLh+PLT4OMrzV0ZdHoY+TxcvwDcfdSOrJY+YX0I9wpvsMOADh0RXhH0CaseefGNgOAOgGLu+ymEE9HpdDw14Cl06Pjx6I9szdiqdkjOrTjHPKEOoJuUSwj7IwmxcGxH15n7C5/8EzwD4ZalMPRhTY5eGPQGnuj/BFC37Zbl58f7P47h3IkqUkfsUOqbUCka1iW4C5M7TQbgpc0vUWmqVDkiJ5b8LZiqIKIHhHZUOxohmkwSYuGYFAU2vQ0LroaSbAjvbl6COf4ytSO7oJExI5k7Yi5hXmG1tod7hTN3xNyzfYgt4oaZ/5V+xMJJPdj7QQLcA0jJS2HR/kVqh+O8zi2XaDTtDUwI5yUJsXA8FSXwzb2w8nFQjNB9Mtz5MwTGqh1Zo4yMGclPk36q+blLUBdWTlpZNxkGiKkeIT69B0pyWylCIbTD392fB3s/CMC8nfPILs1WOSInlHcCjm8AdNBtktrRCNEskhALx3LmGHx4Bfy1CHQGGDMbrn0X3LzUjqxJzi2L8Hf3r10mcS7fcAjpiNQRC2c2qcMkugR1oaiyiNe3v652OM5n79fmf2MGg38bdWMRGqfdsjBJiJto3rx5JCYmkpSUpHYo4nyHf4N3LzF3XfAKgdu+g4H3abJe2Kpiq8smjkrZhHBOBr2BpwY8BcC3Kd+yK2uXyhE5GctiHM3uPazdJEk4D0mIm2j69OkkJyezdas6M5pNikmV82qaosC612DhJHP7sag+cO8fZ+trHZ1MrBOCXmG9uCb+GsA8wc5oMqockZPI3G8ehNC7QOIEtaMR9kKDA1WSENsN7T14NKG8CL66A1Y9a17GuPctcMeP4N9W7chaxGg6O2KSX1pZ6+c6LCPEp/eYWx8J4aQe7vswPq4+JOck803KN2qH4xz2VE+mSxgJXkHqxiJEC0hCLOxXzmH4YBTs/Qb0rjBuLlz9Frh6qB1Zi6zck87QOb/V/Lw7LZ+hc35j5Z70+n/BJ9S86h7AsfWtEKEQ2hTiGcL9ve4H4PXtr5Nfnq9yRA5OUZrZXUII7ZGEWNingz/Bu5dCZjL4RMDtyyHpTk1+DdMUK/ekc9/C7aTnl9XanpFfxn0LtzecFEsdsRAA3ND5BhICEsgrz+PNHW+qHY5jO7kdzqSCqxd0Gqt2NEK0iCTEQttMRnOP3d1fmf+tqoQ/XobPp0B5PkQPMNcLtxugdqQtZjQpPP99cr3TSyzbnv8+uf7yCakjFgIAV70rT/Z/EoAlB5ewP3e/yhE5MMtkuk5Xgpu3urEI0UIuagcgRIOSl5l7CRecOrvNxQOqqkdPk+6C0bPAxU2d+KxsS2punZHhcylAen4ZW1JzGRQfXPtKS0KcmQzF2eAdYrtAhc0oisy2t4b+kf0ZHTuan47+xEubX2LBmAXo7PzbI80xGc+2W5NyCeEAZIRYaFPyMlh8W+1kGM5Jhu+Gca86TDIMkFnYcDJ80f28QyAs0XxZRomF4O/9/o6niyc7Mnfww5Ef1A7H8RxdC0WnwTOw+SuAyocUoSGSEAvtMRnNI8MX6k15YIV5PwcS5tu4yYAN7id1xELUiPCO4J4e9wAw98+5FFUUqRyRg7GUSyRe41ADE8J5SUIstOfYhrojw+crOOlwK7P1jwsi0t/jgg32vNwM9G4XUP+VUkfsMOTrfeu4LfE22vm2I7s0m3f+ekftcBxHZRkkf2++LOUSogm0/MomCbHQnqLT1t3PThj0Op4dby57aOhFo6TCyK0fbK6/bMKSEGfth6Is2wQphB1xM7jxeP/HAViYvJAjeUdUjshBpPxintTsGwXtBrf8eFI7LzRAEmI74xSTbnzCrbufHRnTLZL5t/Qhwr92WUSkvwf3XRKPr7sLW4+eYfyb69h+/EztX/YKgvBu5stSNiEEAMPbDmdE2xFUKVXM2jLLOV5Dba1mqeZJoJc0QjSH9saK5ZEstCdmMPhF0fATRgd+bcz7OaAx3SJZ9/jZSSptgzxZ9/hlPD62M989MISEMB9OF5Qz5Z2NfL75eO1flrIJIer4R9I/cNO7sSl9E6uOr1I7HPtWVmDuAw/Q7Tp1YxHCiiQhFtqjN8CYOQ1cWZ0kj5lt3s9BGfRnPwx4ubnU/Nw+1Idvpw9hTNcIKo0KT32zmye//ovyquoJhjKxTog6ov2iuaPbHQC8svUVSqtKVY7Iju1fbu72E9wBInuqHY0QViMJsdCmxKth8ifmlj7n8osyb0+8Wp24NMDH3YX5t/ThH2M6odPBF1tOMOWdTaTnl1aPmusg+yAUOlaNtRAtcWf3O4n0jiS9OJ0Pdn+gdjj2q6Zc4nppmyYciiTEQrsSr4axL5svh3aBqT/Aw7udOhm20Ol03D8igY/v6I+/pys7T+Qx/s11bM5QIELqiIU4n6eLJ48lPQbAR3s+4kTBCZUjskNFWXBktflydymXEI5FEmKhbbrqh6hPGMQNc+gyiea4pGMo3z8wlM4RvmQXVXDz+5vZ69bDfKXUEQtRy8h2IxkYOZAKUwUvb31Z7XDsT/K3oBghqjcEx6sdjRBWJQmxEHauXbAXX98/mKt7RlFlUvhvSgQAplQZIbY3yoUWoxEtptPpeLL/k7joXFidtpo1aWvUDsm+nFsuYRVSciG0QxJiIRyAl5sLr9/Qi3+O68KfdMak6NDnpnDyuPRdFdpnNClsPJzDdztPsvFwDkaT7T4YtA9oz81dbgZgzpY5VBgrbHYuh3LmKJzYDOig67VqRyOE1bmoHYAQwjp0Oh13DWtPYpQfBz6NowtHeOujj7jq5ocYkhCidnhC1GvlnnSe/z6Z9Pyzi81E+nvw7PhExnSLtMk5/9bzbyxPXc7xwuN8kvwJd3W/yybncSh7lpr/jRsGfra5X4Qz0O63YDJCLLRNmug32eD4ENr2GQVA98rd3PrBZt7547AsSGBHdE7yVfLKPenct3B7rWQYICO/jPsWbmflnnSbnNfHzYeZfWcC8O5f75JRnGGT8ziU3dUJsU2WapbXJqE+SYiFfZD2Pk3i28m8sMcor4OYFJj1434eXvwX5UaVAxOimtGk8Pz3yfWmQpZtz3+fbLPyiavaX0WfsD6UVpXy6rZXbXIOh3F6L2TuBb0rdBmvdjTCEWjwPV0SYjsjn6NFo8QMAp2e0IqTvDomBBe9jhV7TvPf3QaO5ZSoHZ0QbEnNrTMyfC4FSM8vY0tqrk3Or9PpeHLAk+h1elYeXcmW9C02OY9D2P2V+d8OV9TtDS+Eg5CE2G5o79OU0DAP/5pVpCYFHeOLewYS6uNGeqmOa9/exO8HMlUOUDir8iojGw/n8NH61Ebtn1nYcNLcUp2DOnN9R3MJwKwts6g0VdrsXHZLUWBPdUIsvYeFA5OEWAhHFTvU/G/qGpJig/jmvoHE+igUlFUx7eOtvPnrIUw2nM0vBIDJpLDnZD7v/HGYWz/YTM/nf+bG9zbxc3LjVlIM8/WwaXwP9n6QAPcAUvJSWLR/kU3PZZfStkLecXDzgY5j1I5GCJuRhFgIRxU7zPxv9QId4X4ePNjVyI1JbVEUePWXg/xt4Z8UlsmomLCu4zklfL75ONM/207ff//CVW+uY9aP+1l7KJuyShMhPu5c0zMSf0/XCx4n0t+D/nFBNo3V392fh/o8BMC8nfPILs226fnsjqX3cOdx4OalbixC2JC0XRPCUbUz1xFzJhXy08ArHBc9/OuqRHq1C+T/vt3Lz8mnmTBvPe/c2o+EMB+1IxZ2KqeonA2Hc1ifks26lGzSzpTWut7bzcDA9sEMSQhhSEIIHcN90Ol0NV0moP75Edf0isKgt3252MSEiSw5uITknGRe+/M1/j303zY/p10wVsGer82XbdJdQgjtkIRYCEfl4QeRveDUdvMoceKkmqumJLWjU4Qf9y38k8NZxUyYt55XJ/dkdNcI9eIVdrNSXUlFFVtSc6sT4Bz2pRfUut5Fr6NPu8DqBDiYntEBuBrqfiE5plsk82/pU6cPsZebgZIKIws2HGNc9yi6t/W36e0x6A08NeApbllxC98d/o7rOl5Hr7BeNj2nXUhdDSXZ4BUM7UdY//ga7DQgnJckxEI4srhh5oQ4dW2thBigV3QA3z84lOmfbWdzai73fvonD16WwMMjO7bKqJywH1VGE7vS8mtGgHccP0OlsXby3jnCl6HVI8D944Lwdm/c28uYbpGMSoxgS2oumYVlhPl60LtdAHd/so21h7K5c8FWvp0+hKgAT1vctBo9Q3syIWEC36Z8y6wts/j8ys8x6A02PafmWbpLdJ0IhguXtwhh7yQhFsKRxQ6D9a/D0bX1Xh3i487Cuwbw0op9fLT+KG/+lsLuk/m8PqU3/l7yBuisFEUhJbOIdSnZrE/JZtORXIrKq2rt0ybAk6EJIQxOCGZwfAihvu7NPp9Br2NQfHCtbfNu7sN18zdw8HQR0z7eylf3DcankUl2cz3U5yF+PfYryTnJfJ3ydU0HCqdUWQr7fjBf7ibdJYTjk4RYaJx9fIVsSy0aq203EHQGyDsG+Sfq3cXVoOfZ8V3p0dafJ5buZvWBLK6et453b+1HpwjflpxdNJMaK9Wl55eyPsVcB7w+JZvMwvJa1wd4uTI43pz8Dk0IISbYC50Nv/L283Dlg6lJTPzfevZnFPLA59t5/7Z+uNRTemEtIZ4h3N/rfuZsncPr219nVLtRBHgE2Ox8mnbwJ6goBP9oiB5g23PJKppCAyQhFnZCvsJvFndfiOoNJ7ehO7Ye8Gtw14m929IhzJe/LfyTYzklTJi3nleu78FVPaJaL17RavJLK9l05OxEuCNZxbWud3fR0z8uyFwHHB9CYpRfq5fSRAd58f7UJKa8s5HVB7L41w/JPH91V5sm4jd0voGlh5aSkpfCWzvf4p8D/2mzc2mapbtEt0mgl4ZUwvFJQmxnpG+saLK4YXByG/pj68Bw5QV37dbGn+8fGMqDX+xgXUo2D3y+g91p+Tw2upNNR+aE7ZVVGtl+/EzNRLjdaXmc+3Ki10H3tgEMTQhmSHwIfWIC8XBVv4a2V3QAr03pxX2fbeeTjceIDfZm2tA4m53PRe/CUwOeYtpP01hycAmTOkyiS3AXm51Pk0rz4NDP5svSXULYhPYGuSQhthvae/AIOxE7FNb91zxC3P7CCTFAoLcbC6b155WfDvD2H4d5Z80R9pzK580b+xDk7dYKAQtrMJkUktMLauqAtx7NpazSVGuf9qHe5jrg+BAGtQ/WbN342O6RPDG2M7N/3M8Ly5NpF+TFyMRwm50vKSKJsbFj+fHoj7y0+SU+GfuJTUelNWf/D2CsgNDOEN5V7WiEaBWSEAvh6KIHgt4FXf4JvMqzGvUrBr2OJ8Z2pnsbfx77ahfrU3IY/+Y63rm1L93a2LYFlmgeRVE4nltSkwBvPJzDmZLai66E+rpXJ8DmnsC27txgTfcOb8/R7GK+3HqCGV/uYPG9g2z6WJzZbyar01azM2snPxz5gfHx4212Ls2xlEt0v05aowmrspSLny4s58jhHPrHBWmmq5EkxEI4OncfiOoDaVsIKdrXpF8d1yOShDAf7v10G0dzSpg0fwOzru3OtX3a2ihY52Z5sziaU8zGRrxZZFsWxDiUzfrDdRfE8HF3YWD7IPNEuA4hdAjzsduRTp1OxwsTupF2ppR1KWfbsUX62yapj/CO4J4e9/D69teZ++dcLo2+FHdd8ztp2I3CDEhdY74s3SWEFf209zQbj+rop4f96QVMfW8Tkf4ePDs+kTHdItUOTxJiIZxC3DBI20JwExNigE4Rvnz3wFAe/nIHvx/IYubiXfyVls/T47rUu9iCaJ6Ve9L5YO0R8IN1Kdn8uq7um0VxeRVbjuZWJ8B1F8RwNejo3S6QIfEhDO0QTI+29S+IYa9cDfqadmyHMou48+NtLPnboEb3PG6q2xJv49uUbzlWcIy3d73NQ70essl5NGXvN6CYoG0SBNmuVls4l5V70nnwy11M0APnVN5l5Jdx38LtzL+lj+pJsSTEQjiD2KGw9lVCCvc1q8WRv6e5BdZrvx7ijV8P8fGGoySnFzDvpj4t6j8rzCxLGLuGVHHuXzMjv4y/LdzOVT0iySwsr3dBjC6RfgxNCGZwQgj9Yxu/IIa98vd05cPbk5gwbz3J6QXM+GIH797WzyZfu7oZ3Hii/xPct+o+Ptv3GePjnKBswrIYh0ymE1ZiNCk8/31ydRPV2s9TpXrL898nMyoxQtXyCccZOhBCNCx6AIreFa/KXHNP4mbQ63XMHNWR927rh4+7C1tScxn/5jp2HD9j5WCdS+03i9os2374K50tqblUGhXaBHhyQ1I0b9zYm23/HMmPDw3j6XGJXNopzOGTYYvoIC/em9oPdxc9v+7P5IUfkm12rqFthjIiegRVShUvb3sZxZF75uYegZPbQKc3r05nc/ZZviOaZktqbq2l2c+nAOn5ZWxJzW29oOohCbEQzsDNGyWqDwC6Y+tadKhRieF898AQ4kO9ySgoY8o7m/hyy3FrROmUftt3+oJvFhZ3Do3lj8dGsO7xS5k9qQdX94wixMd5R+f7tAtk7uReAHy84SgLNhy12bn+kfQP3PRubDm9heRK2yXfqtu91Pxv3CXgE6ZuLMJhZBaefX3TXWCxrXP3U4MkxELbHHk0ppUpMUMA0B9b3+JjxYf68O30IYzuGk6F0cQTX+/mya93U15lbPGxHV2l0cSW1Fz+89MBrnlrHXd/+mc9e9UdOevRNoCYYG+7nRRnC+N6RPLY6E4APP/9Xn7bf9om54n2jWZa92kArChdQWlV6UV+ww4pyjndJVq7XEJe5x1ZmK+HVfezFUmIhXASSsxQoHqE2AofNHw9XJl/c18eG90JnQ6+2HKcG97dREYjRjudzfGcEj7ddIy7P9lG73/9wuR3NvLW7ynsSstv9DHUfrPQqvtHxDO5X1tMCjzw+Q72nmr837QppnWbRqR3JPlKPh/t/cgm51DV6T2QfQAM7tDlKrWjEQ6kf1wQkf4eDRbI6IBIfw/6xwW1Zlh1SEJsZxRMF9/JEcmoWIspbfth0hnQFaabawWtQK/XMf3SBD66PQk/Dxd2HM/jqjfXsfWourVgaisqr+KX5NP837d7uOSV3xn+yu/837d7+CX5NEXlVQR5u3F1zyheua4HG564zC7eLLRKp9Px7wndGdQ+mJIKI3d+vM0mH8o8XTyZ2WcmAAv2LeBEwQmrn0NVltHhjleAh/QaF9Zj0Ot4dnxire8BlOpXPMvr3rPjE1XvRywJsRDOwtWLXK8E8+Wja6166BGdwvj+waF0jvAlu6icG9/dxCcbjzr2BKRzmEwKu9Pymfd7CpPf2Uiv53/m7k+28emmYxzLKcFFr6N/XBCPje7EsgeGsO3pkbxxY2+u7xdNVIAnz45PrPe4Wnqz0DI3Fz1v39K3pq79zgVbKS6vsvp5Lmt7GfEu8VSaKnl568tWP75qTKaz9cPSXULYwJhukTx8eXyd7RH+HppouQZOkhBPnDiRwMBArruubpPx1NRULr30UhITE+nevTvFxcUqRChE68jx7Wy+cLRlE+vqExPszdf3D2Z8zyiqTArPfLeXvy/5i7JKx6wrPl1Qxld/pjHjix30e3EV499axys/HWBLai5VJoWYYC9uHRjDe7f1Y8czo1h87yCmX5pAj7YB6M9Lbsd0i2T+LX3wPa9LhJbeLLTO38uVj27vT7C3G3tPFfDQlzswmqz7gUyn03GV51W46FxYnbaaNWlrrHp81ZzYBAVp4O4HHa5QOxrhoHw9zi4N3yXSly/uHsi6xy/TzOubU/Toeeihh5g2bRoLFiyoc93tt9/Ov//9b4YNG0Zubi7u7s47a1s4vmyfLnTiO0hda64jtnIpipebC2/c0Iuebf15acU+lm5P48DpAt6+pS9tA72seq7WVlZpZOvRXNYeymbNwSz2ZxTWut7H3YVB8cEM7xjK8A4hxAR7N+n4Y7pFcrgyjrf/gqEJIdw1fqCmljW1B+2CvXj3tn7c+N4mVu3L5MXl+3imgdH35go1hHJT55v4ZN8nzN4ymwGRA3A32Pn7hqVcost4cLWf5byFfTn3NTPcz4Pw+GAVo6nLKRLiESNGsHr16jrb9+7di6urK8OGDQMgKEhq9IRjy/VOQDG4oSvKgJzDEJJg9XPodDruGtaexEg/HvhiB3tOFnD1W+t568beDE4Isfr5bEVRFFIyi/jjYBZrD2WzOTWHssqzNfw6HXRv48/wDqEM7xhK73YtXxVOX/0BJS7Em0Eae7OwF31jAnn1+p48+MUOPlyfSlyIF7cOirXqOe7udjc/Hv2RE4Un+GTvJ9zd426rHr9VGSth77fmy90mqRqKcGz7MwrpoHYQF6B6ycSaNWsYP348UVFR6HQ6vv322zr7zJs3j9jYWDw8PBgwYABbtmyxyrkPHTqEj48P48ePp0+fPrz00ktWOa4QWmXSu6G06Wf+wcp1xOcbnBDCsgeG0L2NP7nFFdzywWbeW3NE03XFeSUV/PDXKf7x1S4Gz/6NUf9dw7+X7+OPg1mUVZoI93Pnur5teePG3vz5z1Ese2Aofx/dif5xQVZZIlmR9lNWMb5nFH+/oiMAzy7by+8HMq16fG9Xb2b2M0+we2/3e2QUZ1j1+K3q8O9Qmgveoeb+w0LYQJXRxMHTRWqHcUGqjxAXFxfTs2dPpk2bxrXXXlvn+kWLFjFz5kzefvttBgwYwGuvvcbo0aM5cOAAYWHmxuG9evWiqqruBIqff/6ZqKioBs9dVVXF2rVr2blzJ2FhYYwZM4akpCRGjRplvRsohMYoMUPg+AZzQtzvDpueq22gF0v+Noinv9nD0u1pvLhiH3+dzGfOpO54uan+8kOV0cTOE3msOZjFH4ey+Sstr1ZHOncXPf3jgmpGgTuG+0gfYDsx/dIEUrNLWLo9jQc+285X9w2mS6Sf1Y4/Lm4cSw4sYXvmdv6z7T/855L/WO3YrcpSLtH1WjC08nNSnktO42hOMeVVJlzUf9lvkOqhjR07lrFjxzZ4/dy5c7n77ru54w7zG/fbb7/N8uXL+fDDD3niiScA2LlzZ7PO3aZNG/r160d0dDQAV155JTt37qw3IS4vL6e8vLzm54KCAgAqKyuprKxs1vmbo9JobNXzqU1nrMIFMCkKRie63edSFMUq97nlGJVtBmIAlNS1VFVU2PxNyQDMmtCFblE+vLjiAN/vOsXBjALm3dSLmKDWrytOO1PK2pRs1h7KYeORXIrO60bQIcybYQkhDE0IJik2EA9XQ8119X3wtiaj0TwB0WQyOdXz3Fb+Nb4zaWeK2Zx6hmkfb+WrewcQ5tv8et+a51D1v//o+w9uWnkTPx39iYntJ9I/or9V4m41lSW47F+ODqhKnIjSyo85vcmIATCaTJjk8e7Qdp84A0CgmwImc2ee1npPb+xrqeoJ8YVUVFTw559/8uSTT9Zs0+v1jBw5ko0bN7b4+ElJSWRmZnLmzBn8/f1Zs2YN9957b737zpo1i+eff77O9p9//hkvr1Z4U68etdqyaRO5Xodsfz6NaJu7i75AdlYWG1esUDscVRQWFrLCirf9l31nuFLniqE4kzXffECRR8PfolhTEHB/F/jooIEDp4sY/8ZapnYw0SXQtmUC5UY4VKBjf575v6yy2h8AvFwUOvkrdA5Q6OyvEOCeD0o+hYcO81srP9UOlZpPeOzYMVZkOefj3dquCYbUdAPp+WXcMG81D3Y14m64+O9dyC+//FJzOck1ic0Vm3lm9TNM952OQdfCg7eiqDObSKosptgtlFU7T8Ou1n3MdU1LJQE4kpJCcqk83h3Z8mN6QE+AuwKlkJWVxaZWek8vKSlp1H6aToizs7MxGo2Eh4fX2h4eHs7+/fsbfZyRI0eya9cuiouLadu2LUuWLGHQoEG4uLjw0ksvMXz4cBRF4YorruCqq+pfoefJJ59k5syZNT8XFBQQHR3NFVdcgZ+f9b6Ga8jTC18AoP/AgQxsq+WydOvS7S6CYxASGsqVV16pdjit6p+f/xMAX19fq9z2yspKfvnlFy4fPQ5d3gA4to4RMQZMfVv373p9QRkPfrmLnSfyeeeAgUcuT+Bvw+OsVopgMinsyyhkXUoOa1Oy2X48j0rj2aTboNfRO9qfoQkhDEsIpmuUn2Y6ORz/6zi/7/mdmJgYrkxyrse7LfUfVsL172zmRHElvxRG8eYNPZt1n1ueQ6NGjcLV1dxCakj5ECb+MJHM8kwK4gu4ufPN1g7fZgyLPwfAo98tXHnpuFY/v37VRsiC9vHxxF4mj3dH9vUn24FsAt2AUghtxfd0yzf6F6PphNhaVq1a1eB1FyvZsHB3d6+3JZurq2vNC2NrMOj1rXo+1RnMoy16nR69M93uc+h0Oqve566urujjhsOxdRhObMAw8B6rHbsxooNdWXTvIJ7/PpnPNx9n7qoU9qYX8urkXvi4u2A0KWxJzSWzsIwwX49GtR7LLCxj7cFs1h7KYl1KNtlFFbXPGeRZUwc8KD4YPw9tPpYMlse7sz3PbSwh3J93b+vHze9t5pd9mby6KoWnxzW/Hdu5r/shriE83Odhntv4HO/sfoerEq4ixNMOuqmU5MLhXwEw9JqCQY3Hm978eDfo9eqcX7Sa/afNLdcC3cyDE3p9672nN/a1VNMJcUhICAaDgdOnT9fafvr0aSIiIlSKSh26Bhd2FaIZYoea/z26zib9iC/G3cXASxO706ONP898t5ef9p7m8Lz13DKwHe/8cYT0c5bejfT34NnxibWat5dXGdl29AxrDmax5lA2+9JrjwB4uxkYFB/C8I4hDO8QSkywl0yGc3JJsUG8cn0PHvpyJ++tTSU2xJubB8RY5dgTO0zkq4NfsSdnD//987+8OPRFqxzXpvYtA1MlhHeDsC5qRyMcWG5xBacLzHOwAjTcslvTCbGbmxt9+/bl119/ZcKECYB5ssmvv/7KAw88oG5wQtiztv3AxQOKsyDrAIR1ViWMG/q3o1OEL/ct3E5KZhHPLUuus09Gfhn3LdzOM+MTURRYeyiLTUdyKT1vBbzubfwZ1iGE4R1D6dMuEDcX1btKCo25plcbjmaX8N9VB3nmu720DfTiko6hLT6uXqfnyQFPcvOKm1l2eBnXd7yeXmG9Wh6wLe3+yvxv97oruAphTZYBi+hAT1w1/LKsekJcVFRESkpKzc+pqans3LmToKAg2rVrx8yZM5k6dSr9+vWjf//+vPbaaxQXF9d0nRBCNIOLO0T3h9Q15vZrKiXEAL3bBfLt9CEMf/k3Kox1J9hZtjz/fe1kOdTXvboMIoShCSEE+2h46EFoxozLEziWU8zXO04y/bPtLL1vMJ0ifFt83B6hPZiYMJFvUr7hpc0v8cW4LzDoNTrBruDU2eXbZTEOYWOWhLhzhC8YL7KzilRPiLdt28all15a87Nl4trUqVP5+OOPmTJlCllZWTzzzDNkZGTQq1cvVq5cWWeinRCiiWKHn02I+6u70lZqdnG9yfD5ukX5cXWvKIZ1CKVzhK+UQYgm0+l0zJrUnbS8Urak5jLt4618M30wYb4eLT72Q30eYtWxVezL3cfSQ0uZ3GmyFSK2gT1fAwpED4SAdmpHIxxccnVC3CXCF06qHMwFqD54PWLECBRFqfPfxx9/XLPPAw88wLFjxygvL2fz5s0MGDBAtXjnzZtHYmIiSUlJqsUghFWcX0esoszCsovvBNw9vD33DI+nS6SfQybDslJd63B3MfDOLX2JC/HmZF4pdy/YRmlFy4eugj2Dmd57OgBv7HiDvLK8Fh/TJiyLcUi5hGgF+9LNE+o6W+GbGFtSPSG2N9OnTyc5OZmtW7eqHYoQLdOmL7h4QkkOZO5TNZTGjs5ZYxRPCIBAbzc+vD2JAC9XdqXl88iinZhMLf9AMqXTFDoEdiC/PJ+3dr5lhUitLDsF0neCzgBdJ6odjXBwFVUmUjKrE+JIH5WjuTBJiIVwVi5u0K762xZLPaFK+scFEenv0WAvFR3mbhP944JaMyzh4OJCvHn31n64GfSs3JvBnJWN72/fEBe9C0/2Ny8mtfjAYpJz6k4UVdWe6sl08ZeCtx20hxN27XBWEZVGBV93F9oGeKodzgVJQiyEM4sdZv736FpVwzDodTw73twX9vyk2PLzs+MTNbOAhnAc/eOCmHNddwDeWXOEL7Ycb/ExkyKSGBs3FgWFlza/hEkxtfiYVqEo55RLXK9uLLVIqZCjqplQF6n9OR+SEAttU7m21eHVJMTrwKTum/aYbpHMv6UPEf61yyIi/D2Yf0ufWn2IHZ3T9R03GSF1rbkVWOpa88+taGLvtjx0uXkF0H9+u4e1h7JafMxH+z6Kp4snu7J28cORH1p8PKtI3wk5KeaWi51bf2U64XwsCXGXSNuv6NtSqneZEKJRNP7J0m616QOuXlCaC1n7ILyrquGM6RbJqMSIJq9UJ+xY8jJY+bi5FZiFXxSMmQOJV7daGA+P7MCxnGK+3XmK+xduZ+n9g+kY3vxJQOHe4dzb415e2/4ac7fN5bLoy/BxU7mG0tJ7uNNYcNf2BCfhGPZnmOuH6yTEGnxPlxFiOyOz0IVVGVyh3UDz5VR1yyYsDHodg+KDuaZXGwbFB0sy7MiSl8Hi22onwwAF6ebtyctaLRSdTsec63qQFBtIYXkVd3y0lazC8hYd89bEW4n1iyWnLIf5u+ZbKdJmMhlhz1Lz5W7SXUK0DnsaIZaE2F5IHixsRSN1xMLJmIzmkeF6X9yqt618olXLJ9xdDLxzaz9igr3M7dg+2UZZZfPP72Zw44n+TwDw2b7PSDmTcpHfsKFjG6AwHdz9ocMo9eIQTiOzsIzsogr0OujUgm9bWoskxEI4O0tCfGy96nXEwokc21B3ZLgWBQpOmvdrRUHebnx0exL+nq7sPJHHzMUta8c2pM0QLou+DKNiZPaW2ShqzYuwTKZLvNq8UqUQNmbpPxwb4o2nm0ZXbTyHJMRNJAtzCIcT1QtcvaH0DGTuVTsa4SyKTlt3PytqH+rDO7f2xdWgY8XuDF75+UCLjvdY0mO4G9zZnLGZX479YqUom6CqApK/M1/WVHcJ4cjsqVwCJCFuMlmYQzgcgyvEDDJf1kgdsbNSbfRQDT7h1t3Pyga2D2b2tT0AmL/6MIu3nmj2sdr6tmVat2kAvLLtFUoqS6wSY6Md/hXK8sAn4uwKlULYmCUhTpSEWAhhN85dxlmI1hAz2NxN4kIt5vzamPdTyaS+bZlxWQIAT32zmw2Hc5p9rGndptHGpw0ZxRm8v/t9a4XYOJZyiW7Xgl5DX11rsNOAsJ6zI8Tarx8GSYiFEACxw83/HlvX6j1ghZPSG8yt1YAGk+KIHqoncI+M6sjVPaOoMik88OUuMpo5uOvh4sFjSY8B8PHejzle0PIFQBqlvAj2rzBf7i7dJUTrKKs0cjirGKhdMqHTcIcASYiF0LhWGUOJ7AluvlCWD6f3tMYZhTBP8Jr8Cfidt+iKZ/US3Qd/hK2tPJp6Hp1Ox8vX9aBfTCCFZVW8s99ATlHz2rFdFn0Zg6MGU2mq5OWtL1s50gYcWAFVpRDUHqL6tM45m8qZSoWcREpmEUaTQoCXKxF+Hhf/BQ2QhFhonLxQtgqDi9QRa4jWlzi1qsSr4eE95vIIgNGz4bEUuOyf5p9XPAaHVJiIdg4PVwPv3NqX6EBPcst1/O3znc1qx6bT6Xii/xO46F34I+0P/jjxhw2iPY9lMY7u10uJgmg1yZZyiQg/u3k9k4RYCGEmdcRCLXqDecVEgMjqMolhf4deN4NigiW3Q8ZuVUMM9nHnvVv74GlQ2Hkin0eX7GpWO7Y4/zhuTbwVgDlb51BubNniHxdUnGOeUAeyGIdoVfbWYQIkIbY7LemHad/s4xOmXavpR7xB6oiF+nQ6uOo1iBsOFUXw2eSL9C22vfhQb+7sZMJFr2P5X+m8+kvz2rHd2+NewjzDOFF4go/3fMzWjK2sOLKCrRlbMVrzuZf8LZiqzLXYoR2td1whLsKSEHducEKd9t7TJSG2G9p78AgHE9ED3P2gPB8y/lI7GiHAxQ0mfwohnaDwFHw+GcoLVQ2pg7/Cv69JBGDe74dZvK3p7di8Xb2Z2W8mAG/tfItpP03j8bWPM+2naYxeOppVx1ZZJ9hzyyWEaCWKotQsymEvLddAEuImk4U5hMMyuJxtcSVlE0IrPAPg5iXgHWoum/hqGhirVA1pUp82TL80HoCnvt7NhsPZTT6Gm96t3u2ZJZnMXD2z5Ulxfhoc3wDooNuklh1LiCZIzy8jv7QSg15HQpiP2uE0miTETSQLcwiHZqkjlol1otVdoBwsMAZuXAQuHnDoZ1j5hOqdCR4d1YmrekRSZVL426d/kpJZ1OjfNZqMzNk6p97rlOq/w5wtc1pWPrFnqfnfmMHg36b5xxGiiSzlEvGh3ni4aqjv9UVIQiyEOMtSR3x8o+qjcM5Ika4qDWvbF659D9DB1vdg0/9UDUev1/Gf63vSu10ABWVVTPt4a6PbsW3P3M7pkoaXpFZQyCjJYHvm9uYHaFmMQ3oPi1ZmjxPqQBJiIcS5IrqDhz+UF0DGLrWjEaK2xKvhihfMl396Gvb9oGo4Hq4G3rutH9FBnhzPLeGeT/9sVDu2rJKsRh3/xU0v8t5f77Ene0/TRosz95vLS/QukDih8b/X6mRujCOy1A9LQiyEsF96A8QMMV+WOmKhhov1LB30APSbBiiw9C44+WerhNWQEB93Pro9CV8PF/48doZ/fPUXykXKOUK9Qht17MP5h3ljxxvcuPxGhi8azszVM1l8YDEnCk5c+Bx7qifTJYwEr6DG3hQhrOLCI8Ta/RZMEmIhtK61B1GkjlhomU4HY1+BhFHmFdg+vwHyWmkZ5AYkhPnyzi19cdHrWLbrFP/95eAF9+8T1odwr3B0DTy5degI8Qzhyf5Pcnm7y/F19aWgooBfjv3CC5te4MpvrmTs12N5bsNzrDy6kryyvLO/rChnu0vYTe9h7SZJomlKKqpIzbEs2dxQyzVtclE7ACEuSJb0bH2WhNhSR2yQlwmhMQYXuP4j+HCMeanxzybDnT+Zy31UMjghhJcmducfS//ijd9SiAn2ZlLftvXua9AbeKL/E8xcPRMdulq145Yk+ekBTzMyZiQ3dbmJKlMVyTnJbDy1kY3pG9mVtYuTRSdZemgpSw8tRYeOzkGdGRQ1iIGuwfTJS8Xd1Qs6jW2V2y6ExYGMQhQFQnzcCPO1jyWbLeSdTghRW3h38AiAsjxI3wlt+6kckPNpaORQnMPdF25aDO9fDln7YPFtcPNXYHBVLaTJSdGk5hQzf/Vhnvj6L9oEejKwfXC9+46MGcncEXOZvWV2rQl24V7hPN7/cUbGjKzZ5qJ3oUdoD3qE9uDenvdSUlnCttPb2JS+iY2nNpKSl8K+3H3sy93Hh4B7u7b0dglg0KHFDIwcSOegzuh18oWwsD17rR8GSYjtjtPOQreTtdAdgl5vriM+sByOrpWEWGiXfxu4aRF8OBaOrIYfHoGr31T19eKxKzpxPKeE5bvTuffTP/n6/sHEh9bfi3VkzEgujb6U7ZnbySrJItQrlD5hfTDoL9yqysvVi+FthzO87XAAskuz2XhqI5tObWTToWVkGvRsMhWw6c//AhDoHsiAyAEMjBzIoKhBRPlEWfdGC1Ftf0YjO0xo8D1dEmIhRF1xw6oT4nUw9BG1oxGiYZE9zeUTX9wAOz6FoDgY9qhq4ej1Ol6d3JOTeaXsPJHHtI+38s39Qwjyrn8hDoPeQFJEyxZ6CvEMYXz8eMbrfFF+nUeqTzAbxzzLptPb2JKxhTPlZ1h5dCUrj64EoJ1vO3N5ReRA+kf2x8/N/kbzhDadnVBnX/XDIAmxEKI+ljriYxvBWKnq19BCXFTH0TD2ZVjxd/j1XxAYq+rqbJZ2bBP/t55jOSXc++k2Ft41AHcXGy9SsHsJOqB9p/G07zaVm7tNpdJUyZ7sPeb641Mb2Z29m+OFxzl+4DiLDixCr9PTNbhrzehxz9CeuBnqT96FuBBFUdgvJRPOY968ecybNw+jsQUrCAmhdWFdwTMQSs/AqZ0QLUuVCxtr6QTa/ndDbipsmgff3Ad+baDdQOvE1gyhvuZ2bNf+bwNbj5rbsb02pRc6W31VXFkGyd+bL3e/vmazq96V3mG96R3Wm/t73U9RRRFbM7aa64/TN5Kan8ru7N3szt7Ne7vfw9PFkz7hfRgUOYhBUYPoENDBdjELh5J2ppTC8ircDPoGy4S0TBLiJpo+fTrTp0+noKAAf3/1ZjQLYVOWOuL9P8DRNZIQt5KL9a8VF3HFC3DmqLnc54sb4a5VEByvWjgdwn353y19uP2jrXy38xSxwd48MqqjbU6W8guU54NvFLQb3OBuPm4+XNruUi5tdykAGcUZbErfZP7v1CZyynJYf3I960+uByDYI5iBUQMZGGn+L8I7wjbxC7uXXF0ukRDmg6vB/iZxSkIshKhf3PDqhHidqjWZQjSa3gCT3oOPx8GpHfDZ9eakWMXFKYZ1COXfE7rx5Ne7ef3XQ8SGeDGxd/3t2FrE0nu4+yTzB9pGivCOYELCBCYkTEBRFA7lHTJP0EvfxJ+n/ySnLIflR5az/MhyAOL84xgUaa4/TopIwsetBSOBMvLsUOx1yWYLSYiFEPWr6Ue8CaoqwEXqCkVraGGS5OYNNy4yt2PLPQxf3gy3fQsu7laJrjlu7N+OoznFvPPHER7/ajdtArzoH2fFJL2sAA6aJ8y1ZDEOnU5Hx8COdAzsyNSuU6kwVrAra1dNgrw3Zy+p+amk5qfy+f7PMegMdA/pXjNBr3tod1z1Mt/AWdnzhDqQhFgI0ZDQLuAVDCU55tG2dgPUjkiIxvENh5uXwAdXwPEN8N0DcO27qo5IPj66M8dzSvhxTwb3fLqNb+4fQlyIt3UOvn85VJVBcAdz1w0rcTO4kRSRRFJEEjOYQX55/tn641MbOV54nJ1ZO9mZtZP5u+bj5eJFUkQSg6IGMShyEHH+cQ3WHxtNRraXZ5Hl7UVoWRZ9TMaLtpsT2mbpQZwoI8RCCIdiqSPet8xcRywJsbAnYV1g8ifw2XWwe7G5HdulT6kWjl6vY+7kXpzK38Su6nZsX983mMAG2rE1ye4l5n+7X2/TpN/f3Z+RMSNrFg05WXSSTac21dQg55Xn8UfaH/yR9gcAYV5hNbXHg6IGEeIZAsCqY6vOLkgSFgJnNhC+dDRP9H+i1oIkwn4UllVyPLcEkJIJIWxEJhmpKm54dUK8DoY/pnY0TkNm9VtJ/KVw1X9h2YPwxxxzO7ZeN6kWjqebgfdu68vEeRtIzS7m3oV/8vEdSew6kU9mYRlhvh70jwvCoG/C/V+UZV6UBKB788slmqONTxsmdZzEpI6TMCkmDuQeYGP6Rjad2sT2zO1klmSy7PAylh1eBkBCQAJtfNrUJMznyizJZObqmcwdMVeSYjt0IMM8Ohzh52GdD3kqkITYzpicdha6JAiqqKkj3gxV5arWYQrRLH1uM7djWzcXls0A/7bmD3oqCfP14MPbk7hu/ga2pObS94VfKK001Vwf6e/Bs+MTGdMtsnEHTP4WFCNE9Va1o4Zep6dLcBe6BHdhWrdplFWVsSNzR015xf7c/aTkpZCSl1Lv7yso6NAxZ8scLo2+VMon7EzT64e1955uf30xnJb2HjzCCYR2Bq8QqCqFk9vVjkaI5rns/6DrtWCqhEW3QNYBVcPpFOHL7UNiAWolwwAZ+WXct3A7K/ekN+5g55ZLaIiHiweDogbxSN9HWDx+MX9M+YO/9fzbBX9HQSGjJIPtmfJaY2+Sq+uHO9tpuQRIQiyEuBCd7uwo8dG16sYiRHPp9TBhPkQPgLJ8czu2oizVwjGaFL76M63e6yzfAT7/fTJG00W+ETxzFE5sBnTmhF/DAj0CifOLa9S+WSXq3Teieey95RpIQiyEuBhJiEWrsHE5mKsH3PA5BMZB3jH44gaoLLXtORuwJTWX9PyyBq9XgPT8Mrak5l74QHuWmv+NGwZ+jSyxUFGoV6hV9xPaYDQpNTXEiXbacg0kIRZCXIyl3vLEFnMdsRD2yjvE3I7NIwBOboOv7wGT6aK/Zm2ZhQ0nw03ab3d1QtyC3sOtqU9YH8K9wtE1UAKoQ0eEVwR9wvq0cmSiJY7lFFNaacTdRU9ssJVaCapAEmIhxIWFdATvMHOf07RtakcjRMuEdDCPFOtdzR1Ufn2u1UMI8/Vo1H6hPheYxHp6L2TuNd+OxKutFJltGfQGnuj/BECdpNjy8+P9H5cJdXbG0n+4U4QvLna4ZLOF/UYuhGgdteqI16kbixDWEDsErplnvrz+ddj2Uauevn9cEJH+HhedKv3W74fIaKi0wrJUc4crwDPQqvHZ0siYkcwdMZcwr7Ba28O9wqXlmp2qqR+OaET9sIY7ZUlC3ETz5s0jMTGRpKQktUMRovVIHbFoLa3Vg7nnFBhRvVDH8kfh0KrWOS9g0Ot4dnwiULd/kOVnN4OeDYdzGfP6Glbuyai9k6LAnuqEuJV7D1vDyJiR/DTpJy51jwDgGo9oVk5aKcmwnbL3JZstJCFuounTp5OcnMzWrVvVDkWI1nNuHXFl4+ofhdC8S/4BPW809/Fdcjtk7Gm1U4/pFsn8W/oQ4V+7fCLC34O3b+nDjw8Po3sbf/JKKvnbwj958uu/KKmoMu+UthXyjoObD3Qc02oxW5NBbyDM4AlAGxcvKZOwY47QYQJkYQ6hdRr+esWpBCeATzgUnTa/GccNUzsih9bQpCNhZTodjH8D8tPM3358Phnu+rXVOjaM6RbJqMQItqTm1rtS3dL7BjP3l4O8s+YwX2w5weYjubx2Qy96WHoPdx4Hbl6tEqsQ9ckrqeBUdVmPPfcgBhkhFvZClrJVl04HsdVJsNQRC0fi4gZTPoXgDlBw0pwUlxe12ukNeh2D4oO5plcbBsUH11q22c1FzxNjO/PZXQOI8PPgSHYx1/9vLaU7tLkYh3A++6vbrbUJ8MTf07Xxv6jB93RJiO2MYutenUI0ROqIhaPyDDS3Y/MKgYy/YOldYDKqHVWNwfEhrHx4GFd2j2AAu/GsPEOB3p9TQQPUDs0qFPkm0G45SrkESEIshGgsSx1x2lbVFjQQwmaC4uDGL8HFAw7+CCufVDuiWgK83Jh3Ux+eb78fgG8r+jP2rU2s2N3IJZ6FsAFLQmzPC3JYSEIshGicoPbgGwnGCvPkOiGsSQujhNFJMPFt8+Ut78Cmt9WN5zy6qjLiMn8DIDl4FPmlldz/2XYeW7KL4vIqlaNrDu19bS6axtKDWEaIhRDOQ/oR25yURGlA14kw8nnz5ZVPwP4V6sZzroM/QUUh+EfzwoN38sClCeh0sOTPNMa9sZadJ/LUjlA4kSqjiQOnJSEWQjijmol1UkcsHNiQh6Dv7YACS++EUzvUjsjM0l2i2yRcXVz4++hOfHn3QKL8PTiaU8Kk+Rt467dDGE128sFKBojtWmp2MRVVJrzdDLQLsv9uJ5IQCyEazzJCnLYNKkrUjUUIW9Hp4Mr/QPxlUFkCn0+BvBPqxlSaB4d+MV8+p7vEgPbB/PjQcK7qEYnRpPCfnw9y47ubOJkndf7CtpKr64c7Rfii1zfu041Ow9+CSUIshMZpahAlqD34tQFTJaRJHbGwBY084g2ucP0CCOtq7r/9+WQoK1Avnv0/gLEcQjtDeNdaV/l7ufLmjb159fqeeLsZ2HI0lzGvreH7XadUClY4A0eqHwZJiIUQTXFuHXGqlE0IB+fhBzctMi9Kk5mM4etp6BSVJq9ZyiW6X1dvD1edTsekvm1Z8dAwercLoLCsige/2MHMxTspLKts5WCFM3CklmsgCbHQPO1+veK0ZIEO4UwCos1JsasX+tTV9DjxSet3xCjMgNQ15svdrrvgrjHB3iy+dxAzLu+AXgdfbz/JuDfW8eexM60QqHAmkhALIZybZYT45J9QUaxuLEK0hqjecN2HKOiIzVmNftObrXv+vd+AYoK2SeZ+yRfhatAzc1RHFt87iDYBnhzPLWHyOxt5fdUhqoymVghYOLqconIyC8vR6aBzhP33IAZJiO2O867oo5G6QgGBseAfba4jPrFZ7WiEaB2dxmK64kUADL/9y5yktpbdX5n/vcjo8Pn6xQbx48PDuKZXFEaTwn9XHeSGdzdxIldbE2Kd9V3Nnlnqh2OCvPB2d2nGEbT3ni4Jsd3Q3oNHOCmpIxZOypR0D4dDrzD/8PW9rbNATe4ROLkNdHpzj+Qm8vNw5fUbevPalF74uruw7dgZrnx9Ld/uOGmDYIWzsJRLdI5wjHIJkIS4yebNm0diYiJJSUlqhyKEeqSOWFidfYwT7mlzE6YOo80dH764AXJTbXvC3UvN/8ZdAr7hzT7MhN5tWPHQMPrGBFJYXsXDi3by0Jc7KFBxwp0M89gvR6sfBkmIm2z69OkkJyezdetWtUMRQj2WEeJT26G8SN1YhGhNOj3GCe9AZE8oyYHProeSXNucS1HO6S5x/YX3bYToIC8W3TOQR0Z2xKDX8d3OU4x9bS3bjtoofuGwkmsSYseoHwZJiIUQzREYAwHtwFQFJzapHY3DcN45AnbGzQduXAR+bSHnECy6FaoqrH+e03sg+wAY3KHLVVY5pItBz0MjO7D43kFEB3lyMq+Uye9sZO4vB1WYcCdjxPaoosrE4SzzQIiMEAshhKVsQuqIhTPyi4SbF4ObLxxbB8setH47NsvocMcrwMPfqofuGxPIihnDuLZPG0wKvPHrIa5/ZyPHcqRzjLiwlMwiKo0Kvh4utA30VDscq5GEWAjRPFJHLGyhnkUnNCu8K0z+GHQG+OtL+GOO9Y5tMp2tH7ZCuUR9fD1cmTu5F2/c2BtfDxd2HM/jytfXsvTPtFb+tkK+GbEnNfXDEX7o7On5ehGSEAshmid2iPnfUzugvFDdWIRQS8JIGPeq+fLqWbBrkXWOe2ITFKSBux90uMI6x2zA1T2j+PGhYfSPDaK4wsijS3bx4Bc7yC+RFe5EXfscsH4YmpgQV1ZW4uLiwp49e2wVjxDCXgS0g4AYUIxwXOqIhRPrdwcMech8+bvp1vnWxNJ7uMt4cLX919JtA7344p6B/P0K84S7H/5KZ+zra9h8JMfm5xb2ZV+G43WYgCYmxK6urrRr1w6j0WireISoTSYZaVucpWxC6oityZG+hnQalz8HideYF6z58mbIPtT8Yxkrzy780W2SVcJrDINexwOXdWDpfYOJCfbiVH4ZN7y3iVd+2k+lrHAnME/8tSzK4dQJMcDTTz/NU089RW6utGlRg8lZE0RJELRJJtYJYabXw8R3zMsrl+XBZ9dBcXbzjnX4dyjNBe9Qc//hVtYrOoDlM4Zxfd+2KArM+/0w183fQGq2bSbcOem7ml3KKiwnt7gCvQ46tWTJZg2+pzc5IX7rrbdYs2YNUVFRdOrUiT59+tT6T9iK9h48QtT0I07fCWUFqoYihOpcPeGGL8ylRGeOwhc3QmVp049j6S7R9VowNGdZ3JbzcXfhlet7Mu+mPvh5uLArLZ9xb6xl8dYT0h7QiVn6D8eFeOPhalA5Gutq8jNtwoQJNghDCGGX/NtCYBycSYXjG6HjaLUjEvbKUZIsn1C4eQl8MArStsC398GkD80jyI1RUQL7l5sv26i7RFOM6xFJ73YBzFy8k01HcvnH0r9YfTCTlyZ2J8DLrUXHlmEe++Oo5RLQjIT42WeftUUcQgh7FTfMnBAfXSsJsRAAoZ1gymfw6URzLXBgLIx8rnG/e/BHqCw2jzK37WfLKBstKsCTz+4ayDtrDjP354Os2J3BjuN5vDq5J4PjQ9QOT7QiR1yy2aLZbdf+/PNPFi5cyMKFC9mxY4c1YxJC2BOpI7YaRaopHUfcMLj6TfPldf+FPxc07vcs3SW6X6epOkuDXsf9IxL4+v7BxIV4k55fxs3vb2b2j/upqJIJd87CkhAnSkIMmZmZXHbZZSQlJTFjxgxmzJhB3759ufzyy8nKyrJFjEIILbPUEWf8BaV5qoYihKb0uhEuedx8+YdH4PBvF96/JBcO/WK+rIFyifr0aBvA8hlDuSEpGkWBt/84zKT5G2qW8m0a7ST84uLKKo0cqZ5Y2fwRYu1+6G9yQvzggw9SWFjI3r17yc3NJTc3lz179lBQUMCMGTNsEaMQQsv8oiAoHhSTuY5YiBZxsCRpxJPQY4q5X/fiqXA6ueF99y0zt20L7wZhXVovxibycnNh9qQevH1LHwK8XNl9Mp+r3ljHF1uON2/CnaPUjzu4Q6eLMJoUAr1cCfdzVzscq2tyQrxy5Ur+97//0aXL2SdrYmIi8+bN48cff7RqcEIIsIsEIU6WcRaiXjqduXQiZgiUF8Dnk6Ewo/59LeUSrdh7uCXGdItk5UPDGZIQTGmlkSe/3s3fFv7JmeIKtUMTNnBu/bAj9kpvckJsMplwdXWts93V1RWTSeqIhHBKNXXEa9SNQwgtcnGHKQshOAHyT8DnU6DivJ6+BafOfqC0k4QYIMLfg0+nDeCpKzvjatDx097TjHl9DesONbMHs9CsZAeeUAfNSIgvu+wyHnroIU6dOlWz7eTJkzzyyCNcfvnlVg1OCC3XG4lz1NQR74bSM+rG4gB09vCtgGgaryC4aTF4BZv7di+9G0znrPq652tAgeiBEBijVpTNotfruGd4PN/cP4T2od6cLijnlg8289KKfZRXycq2jsKRO0xAMxfmKCgoIDY2lvj4eOLj44mLi6OgoIA333zTFjGKczhvQ3RJEDTNNwKCOwAKHJM6YiHqFRxvXrjD4A4HlsPP/zQnxalrYcu75n26XatujC3QrY0/yx8cxs0D2gHw7pojTJy3gZTMwgv+nrO+q9kT85LNloS4BSvUaViT+xBHR0ezfft2Vq1axf79+wHo0qULI0eOtHpwQgg7EjsUcg6Z+xF3vlLtaITQpnYDYOJ8+GoabPof7PwMyvLPXr92LvhGQuLV6sXYAp5uBl6c2J1LOoby+NK/SE4v4Ko31/HPcYncPKCdQ9aeOoNT+WUUlFXhoteREOajdjg20aQR4srKSlxcXNi7dy+jRo3iwQcf5MEHH3SqZHjevHkkJiaSlJSkdihCaEvNxDrpRyzEBXWbdLat2rnJMEDRaVh8GyQva/24rOiKrhH89PBwhnUIoazSxD+/3cPdn2wjp6gcAKNJoai8CoCi8iqMJhkn1rJ9p8yjwwlhPri7ONaSzRZNSohdXV1p164dRqPz1gRNnz6d5ORktm7dqnYoQmhLjKWOeI+5n6oQTeJECZHJCMfWN3Bl9d9h5RO1a4ztUJifBwvu6M8/x3XBzaBn1b5Mxry+lld/PsDQOb+RWt3T9nBmEUPn/MbKPekqRywaYimX6BzhmOUS0Iwa4qeffpqnnnqK3Fx5wxNCnMM3HEI6Ya4j3qB2NHZJVqpzEsc2mLtKNEiBgpMO8TzS63XcNaw9304fQocwH7IKy3nztxTS88tq7ZeRX8Z9C7dLUqxR+zIce0IdNHNS3Zo1a4iKiqJTp0706dOn1n9CCCdm6TYhZRNCNKzotHX3swOJUX58O30IXm5nv24/9+Of5fLz3ydL+YQG7Us3T4xsaUKs5QryJk+qmzBhgg3CEEI4hLhhsO0DWaBDNJ8zTLryCbfufnbir7R8SirqKwNRav6fnl/GltRcBsUHt2psomElFVUczWnpks3a16SEuKqqCp1Ox7Rp02jbtq2tYhJC2CtLHfHpPVCcA97ypiZEHTGDzUueF6RTf+20znx9zODWjsymMgvLLr5TE/YTrWN/RiGKAiE+7oT6Ot6SzRZNKplwcXHhlVdeoaqqylbxCCHsmU8ohFYv697gpCEhnJzeAGPmVP9w/oh49c9jZpv3cyBhvh5W3U+0DkfvP2zRrJXq/vjjD1vEIkRdTrsQiR2TOmIhLi7xapj8CfhF1t7uF2Xebqd9iC+kf1wQkf4eDdaR6oBIfw/6xwW1ZljiIvZX1w8nOnC5BDSjhnjs2LE88cQT7N69m759++Lt7V3r+quvdrwnsZaYZBa60Lq4YbD1PakjbgFZutlJJF4NnceZu0kUnTbXDMcMdriRYQuDXsez4xO5b+H22o/wc354dnwiBr08/rXE0ZdstmhyQnz//fcDMHfu3DrX6XQ6p+5RbFtO/gLhDBNtHIWljjgzGYqzwTtE3XiE0DK94eyiNk5gTLdI5t/Sh+e/T6613d1Fz+s39GJMt8gGflOowWRS2J9hnQ4TtWjwPb3JJRMmk6nB/yQZFkLgHQxhXc2XZZRYCHGeMd0iWff4ZcSHnF0C2M2gY1RihIpRifqknSmlqLwKN4Oe9qHeF/8FO9bkhFgIIS6qpo5YEmLRSFIN5lQMeh2+HuYvqfU6HYXlRvaczL/Ib4nWllxdLtEh3AdXg2OnjI2+dVdeeSX5+WcfrLNnzyYvL6/m55ycHBITE60anBDCTsnEuuaRpFA4IR93c2K8/nC2ypGI8zlL/TA0ISH+6aefKC8vr/n5pZdeqrV8c1VVFQcOHLBudEII+2RJiLP2Q1GWurEIITTNp3qkeENKjsqRiPNZPSHWcOeoRifEynk34vyfhRCihlcQhHczX5ZRYtEk2ptsI2zLMkK89WguZZUyF0lL9mU4Rw9ikBpiIYStxFbPnJc6YiHEBXi46gn1dae8ysT242fUDkdUKyyr5ERuKeD4PYihCQmxTqdDd16bjPN/FkKIGlJHLIRoFB2D483LvEvZhHZY2q1F+nsQ4OWmcjS21+g+xIqicPvtt+Publ7HuqysjL/97W81C3OcW18shPVIaY7dihkM6CD7IBSeBt9wtSMSQmjUkPgQvtt5ivWHs/k7ndQOR+BcE+qgCQnx1KlTa/18yy231Nnntttua3lEQgjH4BUEEd0gY7d5lLj7dWpHZDfk2zfhbIZ0MC/g81daPoVllfh6uKockTibEDt+/TA0ISH+6KOPbBmHaCSZzCjsSuzw6oR4nSTEQogGtQnwJDbYi6M5JWw+ksvIRPlGSW3J6TZYoa6G9j70y6Q6IYTtSB2xEKKRBieYR4mlH7H6jCaFAxnOVTIhCbEQwnYsdcQ5KVCQrnY0QtPk2y9nc/4Y4ZB4c0IsE+vUdzSnmLJKEx6uemKDHXvJZgtJiIUQtuMZAJE9zJePrVc1FHugSFIonNig6k4TB04XkllYpnI0zs1SP9wp3BeDXnvlDbYgCbEQwrYs/YhT16gbhxBCY2onWkHebjX9bjcellFiNdmuw4R2P/RLQiyEsC1ZoEM0hXMMRolaziZJQxLMo8TrU6SOWE37bDqhTpualRB/+umnDBkyhKioKI4dOwbAa6+9xnfffWfV4IQQYPcduGIGgU4PuYeh4JTa0QghNKxmYl1KjnRVUpGz9SCGZiTE8+fPZ+bMmVx55ZXk5eVhNJrXHQ8ICOC1116zdnxCCHvn4Q+RPc2XZZRYCHEB/WODcNHrOJlXyvHcErXDcUp5JRWk55truDs7SQ9iaEZC/Oabb/Lee+/x9NNPYzAYarb369eP3bt3WzU4IYSDsLRfkzpiIcR5zh0I9nZ3oXe7AMA8SixaX3L16HDbQE/8nGiBlCYnxKmpqfTu3bvOdnd3d4qLi60SlBA15CszxxA73PyvjBA3ik4KaYUTGxwv/YjVtN8J64ehGQlxXFwcO3furLN95cqVdOnSxRoxadq8efNITEwkKSlJlfObnDVBtPtCWifXbiDoDHAmFfLT1I5GCKFhQ6rriDcezsFkctL3PBW1Sv2wBt/Tm5wQz5w5k+nTp7No0SIURWHLli28+OKLPPnkk/zjH/+wRYyaMn36dJKTk9m6dWsrn1l7Dx4hGs3DD6J6mS/LKLEQ4gJ6RQfg5WYgt7iC/RmFaofjdPZVr1CX6ET1wwAuTf2Fu+66C09PT/75z39SUlLCTTfdRFRUFK+//jo33HCDLWIUQjiC2KFw8k9IXQs95bVCnMdZv/0Sdbi56OkfF8TqA1lsOJxNYpRzfXWvpiqjiYOniwApmWiUm2++mUOHDlFUVERGRgZpaWnceeed1o5NCOFIauqI16obh4ZJmykhzCzLOEs/4tZ1JLuYiioT3m4GogO91A6nVTU5Ib7sssvIy8sDwMvLi7CwMAAKCgq47LLLrBqcEMKBtBtgriPOOwZ5x9WORgihtgvUkQ6uXqBjS2oulUZTa0Xk9Cz1w50j/dDbYMlmLRd/NjkhXr16NRUVFXW2l5WVsXatjPwIIRrg7gtt+pgvSx2xaJCW3zKFbdT9ZqRLhB9B3m4UVxjZdSKv9UNyUsk1E+qcq34YmlBD/Ndff9VcTk5OJiMjo+Zno9HIypUradOmjXWjE0I4ltihkLbVnBD3ukntaIQQGqXX6xjUPpjlu9NZl5JNv9ggtUNyCs64ZLNFoxPiXr16odPp0Ol09ZZGeHp68uabb1o1OCGEg4kdBuv+a55YJ4QQFzA4wZwQb0jJ4eGRakfjHJxxyWaLRifEqampKIpC+/bt2bJlC6GhoTXXubm5ERYWVmvlOiGEqCN6AOhdIP84nDkGgTFqRySEUFlDU0ktE+t2nDhDSUUVXm5NbowlmiC7qJyswnJ0OugcISUTDYqJMb9xmUxS3C5ak8y6dyjuPtCmL5zYbO42IQlx/aSMVghigr1oE+DJybxStqTmMqJTmNohOTTL6HBssLdTfvho8i3+5JNPLnj9bbfd1uxgxMUpTpsgSobgMGKHVifE66D3LWpHI4TQKJ1Ox+D4YJb8mcaGwzmSENvYvladUKe99/QmJ8QPPfRQrZ8rKyspKSnBzc0NLy8vSYhtRIfOaVNh4WBih8LaV811xIqiySU8hRDaMCQhhCV/pkk/4lZQM6Euwvnqh6EZbdfOnDlT67+ioiIOHDjA0KFD+eKLL2wRoxDCkUQPAL0rFKTBmaNqRyM0Qz7yO5vGfBQeHG/uR5ycXsCZ4rotX4X1OPOEOmjmSnXn69ChA7Nnz64zeiyEEHW4eZvriEFWrTuP85ZECVG/MD8POoT5oCiw8UiO2uE4rPIqIymZ1Us2O+lS2VZJiAFcXFw4deqUtQ4nhHBkccPM/8oCHUKIixiSIMs421pKZhFVJgU/Dxei/D3UDkcVTa4hXrZsWa2fFUUhPT2dt956iyFDhlgtMCGEA4sdCmtekTpiUZc8FsR5hiSE8PGGo2w4LCPEtmKpH+4c6YfOps9B7X4L1uSEeMKECbV+1ul0hIaGctlll/Hqq69aKy4hhCNr2x8MblB4CnKPQHC82hEJITRqQPsg9DpIzS7mVF4pUQGeaofkcCz1w4lOWj8MzUiIpQ+xEKLF3LygTT84vsFcNiEJsRCiAX4ervRoG8DOE3msT8nm+n7RaofkcFq35Zo2Wa2GWAghmqSmjlgm1gnhzBozmXRIgrnbhJRNWJ+iKE7fYQIaOUI8c+bMRh9w7ty5zQ5GiDoU7dYbiRaKHQp/zDGPEEsdsRDiAobEhzDv98OsS8lGURQb17k6l8zCcs6UVKLXQcdw5x0hblRCvGPHjkYdTB6gtmcySYIoHETb/mBwh8J0yDkMIQlqR6QZOg2u4iSEmvrEBOLuoiersJyUzCI6OHHiZm3J1aPD7UN98HA1qByNehqVEP/++++2jkOIC5MPW47H1QPaJsGxdeayCUmIhRAN8HA10C82kPUpOaxPyZaE2IpUKZfQ4Ht6i2qI09LSSEtLs1YsQghnI3XEwkLKo8RFDI6v7kcsdcRWVbNksxNPqINmJMQmk4l//etf+Pv7ExMTQ0xMDAEBAbzwwgvSgUII0TSxQ83/WuqInZysVCecSVNLgywLdGw6kkOVUfINa5EJdWZNbrv29NNP88EHHzB79uyahTjWrVvHc889R1lZGS+++KLVgxRCOKg2/cx1xEWnIfsQhHZUOyIhhEZ1b+OPr4cLhWVV7DlVQK/oALVDsntllUaOZJmXbHbmHsTQjBHiBQsW8P7773PffffRo0cPevTowf333897773Hxx9/bIMQhRAOy9UDovubL0vZhACQCYXOp5FfjBj0Oga2N7dfk2WcrePg6UJMCgR5uxHm694KZ9Tut2BNTohzc3Pp3Llzne2dO3cmNzfXKkEJIZxIrNQRCyEaZ2h12cSGw5IQW8O5C3I4e6ewJifEPXv25K233qqz/a233qJnz55WCUoI4URqJtZJHbEQ4sIsC3RsO3qGskqjytHYv5oJdRHOXS4Bzaghfvnllxk3bhyrVq1i0KBBAGzcuJETJ06wYsUKqwcohHBwbfqCiwcUZ0HWAQir+w2UEMJxNeVjcHyoD2G+7mQWlrP92BkGV48Yi+ZJlgl1NZo8QnzJJZdw8OBBJk6cSF5eHnl5eVx77bUcOHCAYcOG2SJGIYQjc3GH6AHmy1I2IYS4AJ1OV9NtYr2UTbSILNlcW5NHiAGioqKkm4QQwnpih0HqH+ayif53qx2N6mSlOiEaNjg+mG92nGR9Sg6PjVY7Gvt1Mq+UwrIqXA06EsJ81A5HdU0eIV65ciXr1q2r+XnevHn06tWLm266iTNnzlg1OFEfZ62xlATBoUkdsRCikSwjxH+l5VFQVqlyNPbLUj8cH+qDm0uL1mlrBu29pzf5L/DYY49RUGAeYt+9ezczZ87kyiuvJDU1lZkzZ1o9QGGhvQePEFYT1QdcvaAkG7L2qx2NEELDogI8iQvxxqTAJlm1rtks5RLO3n/YoskJcWpqKomJiQAsXbqU8ePH89JLLzFv3jx+/PFHqwcohHACLm5n64hTnbeOWHHq0XFnvu3OqSVtvgbHm7tNbJCEuNmkfri2JifEbm5ulJSUALBq1SquuOIKAIKCgmpGjoUQoslqlnF23oRYCNE4NRPrZIGOZpOEuLYmT6obOnQoM2fOZMiQIWzZsoVFixYBcPDgQdq2bWv1AIUQTiJuuPnfo+vAZAJ9a9e0CU1w8sUBnFPTvx0Y1D4YnQ4OZRaRWVBGmJ+HDeJyXMXlVRzLNQ9udo70bbXz6jT8RVCT33HeeustXFxc+Oqrr5g/fz5t2rQB4Mcff2TMmDFWD1AIZ+c06UFUb3D1htJcyNqndjRCCA0L9HarqX2Vsomm259RiKJAqK87IT6tsWSz9jV5hLhdu3b88MMPdbb/97//tUpAQggnZXCFdgPh8K/mOuLwrmpHJITQsCEJIew9VcD6lGwm9G6jdjh2Rcol6mpWH2Kj0cg333zDvn3mUZwuXbowYcIEXFyadTghhDCLHWpOiI+uhYF/UzsaIYSGDY4P5t01R9hwOAdFUVo0Sc/ZnE2IW69cQuuanMHu3buX8ePHc/r0aTp16gTAnDlzCA0N5fvvv6dbt25WD1II4SRiq/sRH1kNfy0G30iIGQx6g6phCSG0p39cEK4GHSfzSjmWU0JsiLfaIdmN/RnmHsTScu2sJtcQ33XXXXTr1o20tDS2b9/O9u3bOXHiBD169OCee+6xRYzCmTl1GyonlJ8G6KCiCL6+GxZcBa91g+RlakfWqmSkS4iL83JzoXe7QECWcW4Kk0lhv5RM1NHkhHjnzp3MmjWLwMDAmm2BgYG8+OKL7Nixw6rBibpMzpogSoLg+JKXwVd3UGfGeUE6LL7N6ZJiIcTFDYk3t1/bkCIT6xrrxJkSiiuMuLnoaa/WqLoG39ObnBB37NiR06dP19memZlJQkKCVYIS9XDSPFg4CZMRVj5O/Q/06m0rnzDvJ4QQ1YYkWBboyMZkkjfKxrDUD3cM98HFIO0tLRr1lygoKKj5b9asWcyYMYOvvvqKtLQ00tLS+Oqrr3j44YeZM2eOreMVQjiiYxug4NQFdlCg4KR5P+GYnPXbLydmjTHCntEBeLsZOFNSyb4MWRysMZLTzfXDXSKkXOJcjZpUFxAQUKumTVEUJk+eXLPNstzo+PHjMRq1N4IzceJEVq9ezeWXX85XX31Vs/3AgQNMmTKl1s9ffPEFEyZMUCFKIZxYUd1vnVq0nxDCDrQ8JXY16OkfF8TvB7JYn5JN1yh/K8Tl2KTlWv0alRD//vvvto7Dph566CGmTZvGggULam3v1KkTO3fuBKCoqIjY2FhGjRqlQoRCODmfcOvuJ+yY9moLha217NuBIQkh1QlxDvcMj7dSTI5L3YRYu98ENSohvuSSSxp1sD179rQoGFsZMWIEq1evvuA+y5Yt4/LLL8fbW9q2CI1xhvwgZjD4RZkn0NX7gqkzXx8zuLUjE0Jo3ODqiXVbUnOpqDLh5iJ1sQ0pKKsk7UwpIC3XztfiR01hYSHvvvsu/fv3p2fPnk3+/TVr1jB+/HiioqLQ6XR8++23dfaZN28esbGxeHh4MGDAALZs2dLSsOtYvHhxrfIJIUQr0htgjGUOwvmfAKp/HjNb+hELIeroHOFLkLcbpZVGdp7IUzscTdtfXT8c5e+Bv5erytFoS7MT4jVr1jB16lQiIyP5z3/+w2WXXcamTZuafJzi4mJ69uzJvHnz6r1+0aJFzJw5k2effZbt27fTs2dPRo8eTWZmZs0+vXr1olu3bnX+O3XqQpN0ziooKGDDhg1ceeWVTY5fCGEliVfD5E/qlkX4RZm3J16tTlxCCJtq6Zfoer2OQfHmbhPrU6Qf8YVI/XDDmrRSXUZGBh9//DEffPABBQUFTJ48mfLycr799lsSExObFcDYsWMZO3Zsg9fPnTuXu+++mzvuuAOAt99+m+XLl/Phhx/yxBNPANTUATfXd999xxVXXIGHh0eD+5SXl1NeXl7zc0GB+UFVWVlJZWVli87fFEajsVXPpza90YgBMJlMGJ3odp9LMSlWuc8tx9D046fDWLijF65vdkcBjLd8ixI9yDwyrOW4rcRY3VbO2Z7nAC4o6IDKqirN3td28RyyI5a++ial5a9xA2MDWf5XOutTsnhgRJw1wnNIe0/mAdAx3LvVH8fnnq8139MbezsbnRCPHz+eNWvWMG7cOF577TXGjBmDwWDg7bffbnaQF1NRUcGff/7Jk08+WbNNr9czcuRINm7caLXzLF68+KKr7M2aNYvnn3++zvaff/4ZLy8vq8XSEEsnj127dmI4kmXz82lFXNYeegDp6elsW7FC7XBUUVBQwAor3vZffvnFaseyBffKfMYAoGP53gLY+5PKEbWeoyVHATh8+DArTjnX4310WTkewLp16yjwOqF2OBek9eeQvThzJhdcoNAKr3EVZQAubD9+hm++X4G7VFfVa9N+A6CjND2FFSsOtfr521f/e+pUOn+20nt6SUlJo/ZrdEL8448/MmPGDO677z46dOjQ7MCaIjs7G6PRSHh47a9Qw8PD2b9/f6OPM3LkSHbt2kVxcTFt27ZlyZIlDBo0CID8/Hy2bNnC0qVLL3iMJ598kpkzZ9b8XFBQQHR0NFdccQV+frb/6uH/PvkPCtCjZ0+u7Nzf5ufTCv3Wk5AGkVFRTlfS8s/P/wmAn5+fVW57ZWUlv/zyC6NGjcLVVcO1Y0WZUD0/19nu871/7mXjgY0kJCRwZU/nuu0uhx6DIhg6dChEdFc7nHrZzXPIThz8/jMoPI2vFV7jFEXho9S1pOWVEdQpiUs6hlopSsdhNCk8vu1XwMRNY4cT18qr1FVWVnL4M/MAR1RUJOGt9Ppu+Ub/YhqdEK9bt44PPviAvn370qVLF2699VZuuOGGZgfYmlatWtXgdf7+/vWuvHc+d3d33N3d62x3dXVtpRdG88Qig8HgXC/EBvPHfL1Oj96Zbvc5dHqdVe/z1nvMNlN1bDrQdpw2YKieNGjQO9nzHLC8xrm6uNQ8BrRK888hO6GvXstAr7POa9yQhFAWbTvB5qN5jOwa1eLjOZpjmUWUVZrwdDUQH+6PQa9eCyO93tBq7+mNfWw1elLdwIEDee+990hPT+fee+/lyy+/JCoqCpPJxC+//EJhYWGzg21ISEgIBoOhTsJ6+vRpIiIirH4+IYSWaLdfpbAFub+djbXTscEJlol1OVY+smOwTKjrFOGrajKsVU3uMuHt7c20adNYt24du3fv5tFHH2X27NmEhYVx9dXWnQXu5uZG3759+fXXX2u2mUwmfv3115qSByGEcBSKJIVCNJulH3FyegG5xRUqR6M90mHiwlrUh7hTp068/PLLpKWl8cUXXzTrGEVFRezcubOmU0Rqaio7d+7k+PHjAMycOZP33nuPBQsWsG/fPu677z6Ki4truk4IIRyNjFw4NZ3c/87Duvd1qK87ncJ9Adh4WEaJz2dJiBMjfVWMQrsf+pvUdq0hBoOBCRMmMGHChCb/7rZt27j00ktrfrZMXJs6dSoff/wxU6ZMISsri2eeeYaMjAx69erFypUr60y0E0IIIYRzG5wQzIHThaw/nM24HpFqh6Mp+6oX5ZAR4vpZJSFuiREjRtS0FGvIAw88wAMPPNBKEQkhhBDCHg2JD+Gj9UdlgY7znCmuIKOgDDDXEIu6ZMHvJpo3bx6JiYkkJSWpHYoQQghh96xZOz+gfRAGvY5jOSWknWlc/1lnYCmXiA7yxNdDOqTURxLiJpo+fTrJycls3bpV7VCEEEIIcQ5fD1d6tPUHYIN0m6ixL6O6XCJCyiUaIgmxEEIIIRzGkOpuE+sPS9mEhXSYuDhJiO2M6SL11g7H2W6vEEKIFrH0I95wOOeic5SchSTEFycJsd1w8lZE0opJCCFEI/RpF4i7i56swnIOZRapHY7qKo0mDp02/x0StZIQa/A9XRJiIYQQ6pORPGElHq4GkmKDAKTbBHAkq5gKowkfdxfaBnqqHY5mSUIshBAaIV/vCmEdQxKq64hlYl1NuUTnCF/0smRzgyQhFkJoiwa/ShOtSe5/p2G5q23wOXBIdR3x5iM5VBlN1j+BHZH64caRhLiJpA+xaH2SIAghRFN0jfLHz8OFwvIqdp/MVzscVSVLQtwokhA3kfQhFkIIIazHFoVCBr2OQfFnu004s7NLNssKdRciCbEQQgghHM7ZOmLnnViXVVhOdlE5Op0s2XwxkhALIYQQwuEMrl6gY9uxM5RVGlWORh2W+uG4YG+83FxUjkbbJCEWQgghhMOJD/Um3M+diioT246eUTscVciEusaThFhonLShEs5HJ502hGgxnU7n9Ms4n02IpVziYiQhtjOK0yaIkiAIIYRomsHVdcQbnLSO+OyEOq2NEGvvPV0SYiGEEBrgrB/2hS1Z+hHvPplPfmmlytG0rvIqI4ezzEs2ay8h1h5JiIUQ2uVkK7c57zdAwhm1xhhhpL8n7UO8MSmw6YhztV87dLqIKpOCv6crkf4eaoejeZIQCyE0RntfpYlWJPXTTsSGS9WdY3D1KLGzlU2cWz+slXkJOg1/6JeEuIlkpTrR2rTxMiaEEPZpqKUfsZMt0KHd+mFtkoS4iWSlOiGEEMJ6bD1mOLB9MDodpGQWcbqgzMZn0w5pudY0khALIYQQwmEFeLnRLcofgA1O0n5NURT2ZVQnxBGSEDeGJMRCCCGEcGiWOuL1Kc5RNpFRUEZeSSUGvY4O4T5qh2MXJCEWQgghhEOzLNCxISUbxQm61+yvrh9uH+KNh6tB5WjsgyTEQtuc4IVLCCGEbSXFBuFm0HMqv4yjOSVqh2NzyVI/3GSSENsZxeSkCaJGWsYI0Rp00ltECKvydDPQu10AAOudoP2a5ifUafA9XRJiOyFvkEIIhybfBgkbG2Jpv+ZUCbGvypHYD0mIhRDa5WRJkjPUNgph0drDPJZlnDceycHkwN+2llUaSc0uBiBRqyPEGiQJsRBCWzT4VZoQwgZ0rbNSnUWPtgF4uxnIK6msqbF1RAcyCjEpEOztRqivu9rh1KbhzyGSEAshhNAQ+UAkbMPVoGdAe0v7Ncctmzi3flgrSzbbA0mIm0iWbhZCCCGspzUHDQfHVyfEDryMs9QPN48kxE0kSzcLIYQQ9skysW5rai4VVSaVo7GNfdU9iDXbYUKjJCEWQgghhFPoFO5LiI8bpZVGdhw/o3Y4VldryWZJiJtEEmIhhBBCOAW9Xseg6lXrHLFsIu1MKYVlVbgadMSHypLNTSEJsdA4DU9JFUIIYXeGVNcRb3DAiXWW+uGEMF/cXCTFawr5a9kZkySIQjg8mRkuhO1Y6oh3nsijuLxK5Wis62z9sEyoaypJiIWdkARBCMcmH/ZF64gO8iI6yJMqk8KW1Fy1w7Eqywix9hfk0N57uiTEQggNc64kSXGy2yucm5op0ZB4x1zGWSbUNZ8kxEIIIYRQgXop8eAEx5tYV1RexbGcEkDLCbF2P/RLQiyEEEI7pH5atALLAh370gvILipXORrrOFA9Ohzu506Qt5vK0dgfSYiFEEIIoR4VBg1DfNzpHGGeeLbRQUaJk2VBjhaRhFgIIYQQTmdwdR3xhsOOUUd8dslmSYibQxJiIYQQQjidIQnmson1KY4xQmxJiC0j36JpJCFuonnz5pGYmEhSUpLaoQghhBCimfrHBWHQ6zieW8KJ3BK1w2kRk0nhQIa5ZEL7Lde0SRLiJpo+fTrJycls3bpV7VCEEEII0Uy+Hq70ig4A7L9s4nhuCSUVRtxc9MSFeKsdjl2ShNjOKIp2W5bYhLPdXiEAnQab1gvhiCzLONt72YSlXKJTuC8uBkntmkP+anbDyd8gpRWTEEIIK7P0I95wOMeuB5zOTqizk/phDb6nS0IshNAuO36DEk0k97XT0UJK1LtdAB6uerKLyjl4ukjtcJpNWq61nCTEQght0eDIgRDCMbm7GEiKDQLsexlne2m5ppOV6oQQQojGkA9EonUNSbDvfsT5pZWczCsFoEuEthNiLZOEWAghhBCqUVQeNRxSvUDHpiO5VBlNqsbSHPurR4fbBHji7+WqcjT2SxJiIYQQQjitxCg//D1dKSqvYldavtrhNJndTajTKEmIhRBCCOG0DHodg9qb269tsMM64n0yoc4qJCEWQgghhFOrWcbZDuuI92XYx4Q6rZOEWAghhBBOzdKPePuxPEorjCpH03hVRlPNks2SELeMJMRC47TbokUIIYRjaB/iTYSfBxVGE9uO5aodTqMdzSmmvMqEl5uBmCAvtcOxa5IQ2xm1Z+OqR1oxCechSzcL0bp0Oh2DE+xvGWfLghydInzR6+3pdUN7sUpCbDe09+ARwvac6wOgPS8d23LOfNudlbbe14baYT9ie1mQwx5IQiyE0BhtvUkKIZyDZYGO3SfzyS+pVDmaxpGE2HokIW6iefPmkZiYSFJSktqhCCch6aFwKrJ0t1BJuJ8H8aHeKApsPGIfZROWhDhRehC3mCTETTR9+nSSk5PZunWr2qEIIYQQdk9LxTL2tIxzbnEFpwvKAegkSza3mCTEQgghhBDA4OplnNfbwQIdltHhmGAvfNxdVI7G/klCLIQQQggBDGofjF4Hh7OKycgvUzucC6qpH5bRYauQhFgIIYQQAvD3cqVbG39A+2UTliWbO0v9sFVIQiyEEEIIUc1SNrFO42UT0mHCuiQhFtrm1H1ZhRBCtLYh1Qt0bEjJ0Wxv8EqjiZTMIgASJSG2CkmI7YxWn5w2J62YhDORh7sQqukXE4SbQU9GQRlHsovVDqdeh7OKqDCa8HV3oW2gp9rhNJ0G39MlIRZCaJeTfQB03qXZcbr7WpiXS9YiTzcDfWICANig0bIJS7lE50hfzf4d7Y0kxEIIbZEXdyGcjPY+DA2pab+mzQU6LBPq7K9+WHv3tYUkxEJoneSHwqnIA16ob0gHc0K88UgORpP2kjiZUGd9khALIYQQQjVarJbp0cYfX3cX8ksrST5VoHY4dUhCbH2SEAshhBBCnMPFoGdA+yAA1musH3FmYRnZRRXoddApXHoQW4skxEIIIYQQ59HqMs6W+uHYEG883QwqR+M4JCEWQgghhDjPkARzQrz1aC7lVUaVozlLyiVsQxJiIYQQQojzdAz3IcTHnbJKEzuO56kdTg1LQiwLcliXJMRCCCGEEOfR6f6/vTuPj+nc/wD+mZksk32XRSIpsSREYklIgqYVgjYuilZdREtbje2ntPzqNkFVuLYi3La/tpZWF24pXVSkQgVJBKkllDS2SgQh+zpzfn/ETI3szJbM5/16zYs585znfM+ZOWe+8+Q5zyNCSAfFrHX6023i7xZi9h9WJybELYxcj8fw0wxD218iQMShx4j0gmIa5+Qs/RiPuLxKhqzbNbPnscuEejEhbiH4BWno+2+oDOsHkUHPVGfQ+076SnFj3enr91FUXqXjaIDLecWQyQXYmhvDxVqq63CegP59pzMhJiI9o38XSiJSv5bQ0ONhb4529uaQyQWkZufrOhycV3SXcLFukVM2i/Rx0OkHmBA3U3x8PHx9fREYGKjrUIiIWp8W+CVPrZuy24QeTOPMESY0hwlxM0VHR+P8+fNIS0vTdShEREQtnr53FVJ0mziqBxN08IY6zWFCTERERFQPxUgTF3KLcKe4QmdxCIKgnJSDLcTqx4SYiIiIqB4OlqbKBPSoDkebyCkoR0FZFYzEInR0ttRZHK0VE2IiIiKiBoTqwXjEF3Jrukt0cLKEqRGnbFY3JsREREREDVBM45ysw37Eiu4SXdh/WCOYEBMRERE1IOgpexiJRbieX4br+aU6ieE8R5jQKCbELYygx2P4aYSh7S8REekdC1MjBHjYAgCSddRtgkOuaRYTYmoZODapYTLQH0QtYcICtTPMt5pakBBltwnt31hXVinDlTuKKZtbQZcJPbzEMSEmItITBvcXIDJoLe2Hn+LGumNZd7R+rl68VQS5ADhamqCNVUuesll/MSEmIv3CvwYYOL7/BqOFvdU92tnBzFiCO8WVuHirSKvbZncJzWNCTERERDrTUv4uYmIkRuBT9gCAI5e024+YCbHmMSEmIiIiagLleMRa7kfMKZs1jwkxERERURMoxiNO+fMuqmRyrWxTEARc4JTNGseEmIiIiKgJfF2tYWtujJJKGX6/cV8r27xxrwxFFdUwkYjRwYlTNmsKE2IiIiKiJhCLRQh50G0i+bJ2uk0oJuTwbmMJYwnTNk3hkSUiIiJqopAOD8Yj1tIEHbyhTjuYEJOeayn3HxMRkSFQ9CM+de0+yiplGt8eb6jTDibELYzhDtzfwgasJHoCIoMci9lQr23U0ng5mMPNRopKmRxpV/I1vr3MBzfU+baqFmL9u8YxIW4x9O/DQ6R5TJKIWqu/v9Va1nkuEokemsZZs90misqrcC2/FEBr6TKhv+81E2Ii0jP88WfQDLJ13FC13Pc61PvBeMQavrHuYm5N67CLtRR2FiYa3ZahY0JMRERE1AyKG+vO3izA/dJKjW2H/Ye1hwkxERERUTM4W0vh3cYSggAc/1NzrcTnOSGH1jAhJiIiImomxTTORzQ4/BqHXNMeJsREREREzaS4sU5T/YhlckHZh5gJseYZ6ToAIiJtkMvlqKzUXF8/dbAUWcLVxBWmginKy8t1HY52mbcFjG2AShmgp/teVVUFIyMjyGQyGBsb6zoc0rG+7R0gFgF/3ilBTkEZXG3M1Fr/tfxSlFXJIDUW4ylHC7XWTbUxISaiVq+yshLZ2dmQy+W6DqVBoWah6OHdA1awQnZ2tq7D0a4+SwBBDtwtB+7r574LggAXFxf8+eefsLOzg4uLi4GOGU0AYGNmDL+2Nsi4UYDky3cxupe7WutXdJfo7GwFiZifM01jQkz6zWAnIiF1EQQBOTk5kEgk8PDwgFisvz3F8kryUFBZAAepA+zN7HUdjnblVQKQAfaegJGprqOpk1wuR1FREcRiMe7cqek36urqquOoSJdCvB2RcaMARy/f0VhC3MWF3SW0gQlxCyNngkjULNXV1SgtLYWbmxvMzc11HU6DjKqNIBbEMDY1hlQq1XU42mUMQBABUlPASD/3XdHtxtraGmKxGHl5eWjTpg0kEomuQyMd6eftiE1JWUjOugNBENT6FwMOuaZd+ttUQo8w8D+XGPjuGyw1/ACUyWQAABMT/R/UXtDjWZxIleLHVVVVlY4jabmUl/UW/LHv5WkHEyMxbhVWIOt2iVrrzmyFQ64p33M97GrEhLiZ4uPj4evri8DAQF2HQgZC/y4bGqahCyX7epI68fOkBg+OYUv+ISg1lqC3px0A4Kgap3EuKK3CX/fLAABdWlFCrM+YEDdTdHQ0zp8/j7S0NF2HQkRERDoW+mD4tWQ1jkecmVvTXaKtrRlszDiiiTYwISYiamGioqIwYsQIXYdBRABCHkzQcSzrLmRy9bR2c0IO7eNNdURETSCTC0jNzkdeUTnaWEkR9JS9zoZC+vDDDyHwBlsiveDX1gZWpkYoLK/GuZsF6O5u+8R1KhJiX95QpzVMiImIGrHvbA4W7T2PnIK/J4xwtZEiJtIXQ7ppf9gtGxsbrW+TiOpmJBGjT3sHHMi8heTLd9WUELe+G+r0HbtMEBE1YN/ZHEz74qRKMgwAuQXlmPbFSew7m6Oxbe/cuRN+fn4wMzODg4MDwsPDUVJSUqvLRFhYGGbMmIHZs2fDzs4Ozs7O+OSTT1BSUoLJkyfDysoK3t7e+Pnnn5XrJCUlQSQS4ccff0T37t0hlUrRt29fnD17Vlnm6tWriIyMhJ2dHSwsLNC1a1f89NNPytcPHTqEoKAgmJqawtXVFfPnz0d1dbVKXDNnzsTbb78Ne3t7uLi4IDY2VmPHi0hXQr1ruk2o48a6apkcF28xIdY2JsREZFAEQUBpZXWTHkXlVYjZc67Oe+AVy2L3nEdReVWT6mtON4ecnByMGzcOr7zyCjIzM5GUlIRRo0bVW8eWLVvg6OiI1NRUzJgxA9OmTcOYMWMQEhKCkydPYvDgwZgwYQJKS0tV1ps3bx5WrVqFtLQ0ODk5ITIyUjmUWHR0NCoqKnD48GGcOXMGy5cvh6WlJQDgr7/+wrBhwxAYGIiMjAxs2rQJn376Kd5///1acVlYWCAlJQUrVqzA4sWLkZCQ0OTjQNQSKG6sS83OR3mV7Inqyr5TgspqOSxMJGhnr99jp7cm7DJBRAalrEoG3/d+UUtdAoDcwnL4xe5vUvnziyNgbtK0y25OTg6qq6sxatQoeHp6AgD8/PzqLe/v74+FCxcCABYsWIC4uDg4Ojpi6tSpAID33nsPmzZtwu+//46+ffsq14uJicGgQYMA1CSv7u7u2LVrF8aOHYtr167hhRdeUG63ffv2yvU2btwIDw8PbNiwASKRCF26dMHNmzfxzjvv4L333lPOCNi9e3fExMQAADp27IgNGzYgMTFRuU2i1qBjG0s4WZnidlEFTl67h5AOjo9d13nFlM0uVhBzymatYQtxC2N4N9IY2v4S1fD398fAgQPh5+eHMWPG4JNPPsG9e/fqLd+9e3fl/yUSCRwcHFQSaGdnZwBAXl6eynrBwcHK/9vb26Nz587IzMwEAMycORPvv/8+QkNDERMTg99//11ZNjMzE8HBwSrj8YaGhqK4uBg3btyoMy6gZqrjR2MgaulEIpFytImjl+8+UV3sP6wbbCFuIfgbkUfAMKn/B5GZsQTnF0c0qWxqdj6iPm98zPHNkwMR9JR9k7bdVBKJBAkJCTh69Cj279+P9evX491330VKSkqd5Y2NVccqFYlEKssUiatcLm9yDFOmTEFERAR+/PFH7N+/H8uWLcOqVaswY8aMJtdRV1zNiYGopQjt4IjvT99EctYdzEXnx66ndQ+5prim6993OluIiUjPaPZCKRKJYG5i1KRH/45OcLWR1huRCDWjTfTv6NSk+po7u5lIJEJoaCgWLVqEU6dOwcTEBLt27XriY/Cw48ePK/9/7949/PHHH/Dx8VEu8/DwwBtvvIHvvvsOb731Fj755BMAgI+PD44dO6byV6vk5GRYWVnB3d39CSLSvy9K0hTFTHWtQ2jHmm4Sv98oQFH540/p3boTYv3FhJiIqB4SsQgxkb4Aaqdpiucxkb4aGY84JSUFH3zwAU6cOIFr167hu+++w+3bt1WSVXVYvHgxEhMTcfbsWURFRcHR0VE5gsXs2bPxyy+/IDs7GydPnsTBgweV23/zzTdx/fp1zJgxAxcuXMD333+PmJgYzJkzR9l/mMiQtLU1g5eDOWRyASl/5j9WHXeLK5BXVAGRCOjiwjGItYlXLSKiBgzp5opN/+wJFxupynIXGyk2/bOnxsYhtra2xuHDhzFs2DB06tQJCxcuxKpVqzB06FC1bicuLg6zZs1Cr169kJubi71798LExAQAIJPJEB0dDR8fHwwZMgSdOnXCxo0bAQBt27bFTz/9hNTUVPj7++ONN97Aq6++qryxj8gQhSimcX7M4dcU/Yc97c1hYcperdrEo01E1Igh3VwxyNdFqzPV+fj4YN++fXW+tnnzZpXnSUlJtcpcuXKl1rK6bsrt16+fytjDD1u/fn2DMT799NNITU2t9/W64tq9e3eDdRK1ZKEdHLE95dpj31jH7hK6w4SYiKgJJGIRgh/cRU5EVBfFNeLirSLcLqqAk5Vps9ZnQqw77DJBREREpAb2FibwfZDMPs6sdZm5HHJNV5gQExEZoLCwMAiCAFtbW12HQtSqKKdxbma3icpqOS7nKRJi3lCnbUyIiYiIiNTkcW+sy7pdjCqZACupEdrammkiNGoAE+IWRmg1IzY2kcHNzEdERC1ZkJc9jMQi3LhXhmt3S5u8nrL/sIt1s8cspyfHhLjFMPCTgxcHw8QfREQGoHWd5xamRujRzhYAcORy01uJ/76hrjV3l3jwXuvhdzoTYiLSL3p4oSQi9RO1spnqHhbSofndJhRjEPOGOt1gQkxERESkRqEP+hEfy7oLubzxlF8QBA65pmNMiImIiIjUKMDDFmbGEuSXVOLCg6HUGnK7qAJ3SyohFgGdOWWzTjAhJiIijYuKisKIESMaLBM2eipmz5mrnYCINMjESIw+7e0BNG084vMPWoefcrSA1Fii0diobkyIiYiaQi4Dsn8Dzuys+Vcu0+jmwsLCMHv2bI1uQ5s+/PDDWlNOE7VmoYp+xE24sY79h3WPUzcTETXm/B5g3ztA4c2/l1m7AUOWA77DdRKSIAiQyWQwMmoZl3EbGxtdh0CkVSEPJuhIzc5HlUwOY0n9bZDsP6x7bCEmImrI+T3AtxNVk2EAKMypWX5+j9o3OeO1GTh06BA+/PBDiEQiiEQibN68GSKRCD///DN69eoFU1NTHDlyBFlZWfjHP/4BZ2dnWFpaIjAwEAcOHFCpz8vLC0uWLMG4ceNgYWGBtm3bIj4+XqXM/fv3MWXKFDg5OcHa2hrPPvssMjIyVOpQxPLwQ+HMmTN49tlnYWZmBgcHB7z22msoLi5Wvv5ol4mSkhJMnDgRlpaWcHV1xar/bFXzUSTSLR8Xa9hbmKCkUoaM6/cbLKtIiH2ZEOsME2IiMiyCAFSWNO1RXgj8/DbqHhjqwbJ979SUa0p9TRxXeem/lyI4OBhTp05FTk4OcnJy4OHhAQCYP38+4uLikJmZie7du6O4uBjDhg1DYmIiTp06hSFDhiAyMhLXrl1TqfPf//43/P39cerUKcyfPx+zZs1CQkKC8vUxY8YgLy8PP//8M9LT09GzZ08MHDgQ+fn5AIC0tDRlLDdu3EDfvn3Rv39/ADXJbUREBOzs7JCWloYdO3bgwIEDmD59er37OG/ePBw6dAjff/899u/fj6SjJ3DyzIUmHR+ilkAsFiG4fU0rcXID0ziXV8nw550SAGwh1qWW8bc2MmCtcYRK0qmqUuADNzVVJtS0HMd5NK34/94ETCwaLWZtYw0TExOYm5vDxcUFAHDhQk2yuHjxYgwaNEhZ1t7eHv7+/srnS5Yswa5du7Bnzx6VhDQ0NBTz588HAHTq1AnJyclYs2YNBg0ahCNHjiA1NRV5eXkwNTUFAKxcuRK7d+/Gzp078dprr8HJyUlZ16xZs5CTk4O0tDQAwPbt21FeXo6tW7fCwqJm/zZs2IDIyEgsX74czs7OKvtXXFyMTz/9FF988QUGDhwIANjy4RK494po2nEkaiFCvB3w45kcJGfdwazwjnWWuXSrGDK5ADtzYzhbm2o5QlJgC3ELIxjszF2crMEwGdjnvQm727t3b5XnxcXFmDt3Lnx8fGBrawtLS0tkZmbWaiEODg6u9TwzMxMAkJGRgeLiYjg4OMDS0lL5yM7ORlZWlsp6H3/8MT799FPs2bNHmSRnZmbC399fmQwDNQm4XC7HxYsXa+1DVlYWKisr0adPH+UyezsbdO7g2fgBIGpBFDfWnbp2D6WV1XWWebj/cKufsll5jdO//WQLcYuhfx8e0o7Wfn2sTcM7bGxe01LbFFePAl+Obrzc+J2AZ0jTtv2EHk46AWDu3LlISEjAypUr4e3tDTMzM4wePRqVlZVNrrO4uBiurq5ISkqq9Zqtra3y/wcPHsSMGTPw1VdfoXv37o+7C0QAoEz+WvPPXk8Hc7S1NcNf98uQduUenu7kVKvMed5QpxeYEBORYRGJmtRtAQDQ4dma0SQKc1D317ao5vUOzwJi9Y4damJiApms8aHdkpOTERUVhZEjRwKoSW6vXLlSq9zx48drPffx8QEA9OzZE7m5uTAyMoKXl1ed27l8+TJGjx6N//3f/8WoUaNUXvPx8cHmzZtRUlKiTNiTk5MhFovRuXPnWnV16NABxsbGSElJQbt27QAA9+4X4o8/r+LpZxvdZaIWQyQSIaSDA3ak38DRy3fqTIg5woR+YJcJIqL6iCU1Q6sBqN1y/eD5kDi1J8NAzagOKSkpuHLlCu7cuQO5XF5nuY4dO+K7777D6dOnkZGRgZdffrnOssnJyVixYgX++OMPxMfHY8eOHZg1axYAIDw8HMHBwRgxYgT279+PK1eu4OjRo3j33Xdx4sQJlJWVITIyEj169MBrr72G3Nxc5QMAxo8fD6lUikmTJuHs2bPKluQJEybU6j8MAJaWlnj11Vcxb948/Prrrzh79iyiZr8HsZhfSdT6KKZxPlLHeMSqUzZzhjpd4tWHiKghvsOBsVsBa1fV5dZuNcs1NA7x3LlzIZFI4OvrCycnp1p9ghVWr14NOzs7hISEIDIyEhEREejZs2etcm+99RZOnDiBHj164P3338fq1asREVFzE5tIJMJPP/2EAQMGYPLkyejUqRNeeuklXL16Fc7Ozrh16xYuXLiAxMREuLm5wdXVVfkAAHNzc/zyyy/Iz89HYGAgRo8ejYEDB2LDhg317t+///1v9O/fH5GRkQgPD0e/oAD06u6jhiNHpF9COtSMNHE+pxD3SlS7Mt0sKEdheTWMxCJ4t7HURXj0ALtMEBE1xnc40OW5mj7FxbcAS+eaPsMaaBlW6NSpE44dO6ayLCoqqlY5Ly8v/PrrryrLoqOja5WztrbGt99+W+/2rKyssG7dOqxbt67O1xu7odfPz69WHA97dJY6S0tLbNu2Ddu2batZkJOBedMmAm18G9wOUUvTxlqKjm0scSmvGMf+vIthfn//uM68WdM67N3GEqZGnLJZl5gQExE1hVgCPNVf11EQUQsU6u2IS3nFSL58RyUhvpDL/sP6gl0miIiIiDRI0Y/4aJbqBB2ZOUUA2H9YH7CFmIiolatr1Aki0p4+7e0hFgHZd0pw834Z3GzNAHCECX3CFmIiIiIiDbKWGqO7uy0AIPnBaBOlldXIvsspm/UFE+IWRmjVQ5jXwcB2lx5hsDMzGiC+1YbLQM7zUO+a0SYU3SYu5hZBEABHS1M4WhrGlM0iPT7RmRBTy2B407U9xMD23aDf6xqtfvpWIgAiA7u2KaZxTr5858H4wwbcf1gPr3FMiImIiIg0rKenHUyNxMgrqkDW7WJl/2FfdpfQC0yIiYiIiDRMaixBby87AEDy5bu8oU7PGERCPHLkSNjZ2WH06NG1XluzZg26du0KX19fzJw5s9HB54mIiIgeR0iHv6dxvpCr6DLBhFgfGERCPGvWLGzdurXW8tu3b2PDhg1IT0/HmTNnkJ6ejuPHj+sgQiIi9RGJRNi9e7euwwBQM5Pe2rVrdR0GkV5QjEf864VbKK6ombLZ08Fcx1ERYCDjEIeFhSEpKanO16qrq1FeXg4AqKqqQps2bbQYGRG1FDK5DCfzTuJ26W04mTuhZ5uekGhw6uYnkZOTAzs7O12HAQBIS0uDhYWFrsMg0gs375VBBEAmr3leLRfwzMokxET6Ykg31wbXJc3SeQvx4cOHERkZCTc3t3pbNeLj4+Hl5QWpVIo+ffogNTVVLdt2cnLC3Llz0a5dO7i5uSE8PBwdOnRQS91E1HocuHoAEf+NwCu/vIJ3fnsHr/zyCiL+G4EDVw/oOrQ6ubi4wNRUP4ZxcnJygrk5W8CI9p3NQfT2k7UGHsstKMe0L05i39kcncRFNXSeEJeUlMDf3x/x8fF1vv7NN99gzpw5iImJwcmTJ+Hv74+IiAjk5eUpywQEBKBbt261Hjdv3mxw2/fu3cMPP/yAK1eu4K+//sLRo0dx+PBhte4fEbVsB64ewJykObhVektleV5pHuYkzdFoUrxz5074+fnBzMwMDg4OCA8PR0lJzUD+n332Gbp27QpTU1O4urpi+vTpyvUebly4cuUKRCIRvv76a4SEhEAqlaJbt244dOgQAEAQBHh7e2PlypUq2z59+jREIhEuX77cYIyCICA2Nhbt2rWDqakp3NzcMHPmTOXrj3aZEIlE+Oijj/D888/D3NwcPj4+OHbsGC5nX0PY6KmwsLFHSEgIsrKylOvExsYiICAAH330ETw8PGBubo6xY8eioKBAWSYpKQlBQUGwsLCAra0tQkNDcfXqVeXrmzZtQocOHWBiYoLOnTtj27ZtKvshEonwf//3fxg5ciTMzc3RsWNH7Nmzp8F9J2oqmVzAor3n6xyFV7Fs0d7zkMl5H5Ou6LzLxNChQzF06NB6X1+9ejWmTp2KyZMnAwD+85//4Mcff8Rnn32G+fPnA6i5cD+OAwcOwNvbG/b29gCA5557DsePH8eAAQNqla2oqEBFRYXyeWFhzd2hVVVVqKqqeqztPw6ZTKbV7emaWC6DBIBMLofcgPb7YYIgqOU9V9Sh95+f6ioYP/hvVXU18ITxVlVVQRAEyOVyyOVyCIKAsuqyJq0rk8uwLGVZnRPiKJYtS12GwDaBTeo+YWZk1uAYw4o6BUHAX3/9hXHjxmH58uUYMWIEioqKcOTIEchkMsTHx2Pu3LlYtmwZhgwZgoKCAhw9ehRyuVxZl2J/FcvmzZuH1atXw9fXF2vWrEFkZCSysrLg4OCAyZMn4/PPP8ecOXOU63/22WcYMGAA2rdvr1Lvo3bu3Ik1a9Zg+/bt6Nq1K3Jzc5GRkaGyjuL4KyxZsgQrV67EypUrMX/+fLz88sto37YNFkyfDPduoZjy+jRER0fjp59+Uq5/+fJlfPvtt/j+++9RWFiIqVOnYtq0afjiiy9QXV2NESNGYMqUKfjyyy9RWVmJ1NRU5XZ37dqFWbNmYc2aNRg4cCB+/PFHTJ48GW5ubnjmmWeUcS1atAhxcXFYvnw5NmzYgPHjxyM7O1v5HaG46VpRr+LclEj0s+uMvpMLNZ8JAeq5xumzlOx85BSU1/u6ACCnoBzHLuehz1P22gtMix5+j7X5nd7Uz5bOE+KGVFZWIj09HQsWLFAuE4vFCA8Px7Fjx564fg8PDxw9ehTl5eUwNjZGUlISXnvttTrLLlu2DIsWLaq1fP/+/Vr5c6DiyyTzwgX8lNu6LxwP65R7ET4Arl+7jowHX46G5v79+8rEQB0SEhLUVpcmiOVViHzw//37f0G15MnOLyMjI7i4uKC4uBiVlZUoqy7D4B8HP3mgD+SV5qHft/2aVHb/c/thZmRW7+uVskoAQHl5Of68/Ceqq6sRHh4Oe3t72Nvbw9PTE3K5HEuXLkV0dDSioqIA1HSR6Ny5s/KHOgCUlZWhsLAQxcXFAIBXX30VgwYNAgDExcXh559/xsaNGzFr1iyMGjUKMTExOHjwIHr16oWqqips374dS5YsUamzLpcuXUKbNm0QFBQEY2Nj2NraokuXLsr15HI5ysvLVeoZN24chgwZAgCIjo7G4MGDsXDGJESEhaBA2hZTpkzB9OnTletUVFSgvLwc69evh5ubG4Caa/KLL76ImJgYmJiYoKCgAM888wycnJwA1IwuBNQ0XqxYsQIvv/wyxo8frzwWR44cwfLly9GrVy9lXC+99BKee+45AMA777yD9evXIykpCeHh4Sr7XFRUVPNZKivD4cOHUV1d3eAxorrl3c0DJEBpaalar3H6KP2OCEDjP5z2/5aCu5mtt5W484Mf/deuXcPvWnrPS0tLm1ROrxPiO3fuQCaTwdnZWWW5s7MzLly40OR6wsPDkZGRgZKSEri7u2PHjh0IDg5G3759MWzYMPTo0QNisRgDBw7E8OHD66xjwYIFKq0nhYWF8PDwwODBg2FtrfkhU2K3boIcQOcuXTCs5yCNb09fiH87D+QAHu3aoe2wYboOR6sWbl8IALC1tcUwNex7VVUVEhISMGjQIBgbGze+gq7IKoGMmv8OHjQYkD7Z+VVeXo7r16/D0tISUqkURlW6u+xZWVnB3Lj+BL+4pBhlFWWQSqUICQnBwIED0a9fPwwePBiDBg3C6NGjUVVVhZycHAwdOrTBa4+ZmRmsra1haWkJoObm4ofLBwYGIjs7G9bW1rC2tsawYcPw7bff4plnnsF3332HyspKTJgwodEf/P/85z/x0UcfoWfPnoiIiMDQoUMRGRkJI6Oa4ywWiyGVSlW23bt3b+Xz9u3bAwD8unR8cIys4eXlpbzZ2draGqampmjXrh26dOmirGPgwIGQy+W4efMmnn76aUyaNAkvvPACwsPDER4ejjFjxsDVteYmpUuXLuGNN95QieHpp5/GunXr6o1LcVyKi4uVywRBQFFREaysrFBRUQEzMzMMGDAAUqm0wWNEdcv9ZS9w9wrMzM3Vco3TZw7Z+dh66USj5Qb379OqW4ivbf0OANCunSfch2rnPW/sR72CXifE6nLgQP19/JYuXYqlS5c2WoepqWmdN6kYGxtrNbmQiCX6ncyo24M/RUrEYkgMab8fIhKJ1Pqea/sz22yiv1tHjI2NgCeMVSaTQSQSQSwWQywWw8LEAikvpzRp3fRb6Xgz8c1Gy20cuBG9nHs1Wq6xLhOKqWwV73lCQgKOHj2K/fv3Iz4+Hv/617+QmJgIAMr9qY/idUWZR8uLRCLlcQGAqVOnYsKECVi7di22bNmCF198UZlMN8TT0xMXL17EgQMHkJCQgOnTp2PVqlU4dOiQ8nP28HaAmuup4rmiu4GJIoEWQaULglgsVh6zh+t4dL82b96MWbNmYd++ffj222/xr3/9CwkJCejbt2+9+/9onQ/HVVcZxV/qFPujeJ/0+nzSY+IHx1cEtPpjGOzdBq42UuQWlNfZj1gEwMVGimDvNpCI9W9aY3XT5nd6Uz9bOr+priGOjo6QSCS4dUv1ZpZbt27BxcVFR1ERUUsmEolgbmzepEeIWwiczZ2ViWqtuiCCi7kLQtxCmlRfQ8lwfbGGhoZi0aJFOHXqFExMTJCQkAAvLy9lYtxUD4+xXl1djfT0dPj4+CiXDRs2DBYWFti0aRP27duHV155pcl1m5mZITIyEuvWrUNSUhKOHTuGM2fONCu+xly7dk3lRunjx49DLBajc+fOymU9evTAggULcPToUXTr1g3bt28HAPj4+CA5OVmlvuTkZPj6+qo1RqL6SMQixETWfN4evQoonsdE+hpEMqyv9LqF2MTEBL169UJiYiJGjBgBoOYXemJiosod1UREmiARSzA/aD7mJM2BCCKVm+sUSfI7Qe9oZDzilJQUJCYmYvDgwWjTpg1SUlJw+/Zt+Pj4IDY2Fm+88QbatGmDoUOHoqioCMnJyZgxY0a99cXHx6Njx47w8fHBmjVrcO/ePZWkVyKRICoqCgsWLEDHjh0RHBzcpDg3b94MmUyGPn36wNzcHF988QXMzMzg6en5xMfgYVKpFJMmTcLKlStRWFiImTNnYuzYsXBxcUF2djY+/vhjDB8+HG5ubrh48SIuXbqEiRMnAqi5oXDs2LHo0aMHwsPDsXfvXnz33XcN/vWQSN2GdHPFpn/2xKK951VusHOxkXIcYj2g84S4uLhYZVif7OxsnD59Gvb29mjXrh3mzJmDSZMmoXfv3ggKCsLatWtRUlKiHHWCiEiTwj3DsTpsNeJS41SGXnM2d8Y7Qe8g3DO8gbUfn7W1NQ4fPoy1a9eisLAQnp6eWLVqlXJUnvLycqxZswZz586Fo6NjnVPTPywuLg5xcXE4ffo0vL29sWfPHjg6OqqUefXVV/HBBx806/pqa2uLuLg4zJkzBzKZDH5+fti7dy8cHByav9MN8Pb2xqhRozBs2DDk5+fj+eefx8aNGwEA5ubmuHDhArZs2YK7d+/C1dUV0dHReP311wEAI0aMwIcffoiVK1di1qxZeOqpp/D5558jLCxMrTESNWZIN1cM8nVBanY+8orK0cZKiqCn7NkyrAd0nhCfOHFCZdgbxY1rkyZNwubNm/Hiiy/i9u3beO+995Cbm4uAgADs27ev1o12RESaEu4Zjmc8ntHqTHU+Pj7Yt29fva+//vrryoTvUYrhwR6tLyWl4b7Tf/31F4yNjZUtq00xYsQI5V/w6nLlypUGY/Py8qpZdvM0FCOyhoWF1bkP06ZNw7Rp02otd3Z2xq5duxqMs75164sLqBnhhUjdJGIRgjuo9wcjPTmdJ8T1XfgeNn36dHaRICKdkoglCHQJ1HUYGlFRUYHbt28jNjYWY8aMYYMDERkcvb6pTh/Fx8fD19cXgYGt84uRiAzPV199BU9PT9y/fx8rVqxQee3LL7+EpaVlnY+uXbvqKGIiIvXSeQtxSxMdHY3o6GgUFhbCxsZG1+EQETVI2SWhAVFRUcpJPh41fPhw9OnTp87XtDVUVmxsLGJjY7WyLSIyTEyIWxgB9U+h2io18kVOrZyBvf91TRGta1ZWVrCystJ1GEREGsUuEy1Ec8cvbXUMff8NiYbe68ZaSUlftIxznZ+nJ6f4XuORNEB6+J3OhJiIWjXFrGeVlZU6joRak9LSUgCtf4Y1IkPBLhNE1KoZGRnB3Nwct2/fhrGxcYPTHetadWU15FVyVFVUoVxU3vgKrUm1AEAAyssBI/3sGiaXy1FRUYG7d+/izp07sLW1VZlmmohaLibERNSqiUQiuLq6Ijs7G1evXtV1OA26V34PZdVlKDcpx32T+7oOR7vu3wYgAEXGgFg/v5oEQUBZWRnMzMxgZ2cHFxcXXYdERGqin1cdIiI1MjExQceOHfW+28TuE7tx8PpBTO46GSOfGqnrcLRr43hAXglM3AtY6+cUtlVVVTh8+DAGDhwIqVSq63CISI2YEDdTfHw84uPjIZPJdB0KETWDWCzW+ySmSChCTmUOKsQVeh+r2pXcAGQVgIkRoKf7LpFIUF1dzW4SRK2Q/nam01PR0dE4f/480tLSdB0KEREREakBE2IiIiIiMmhMiImIiIjIoLEP8WNSDMpeWFiole3Jyqohk8hQWlSitW3qhZJyoEIASisAQ9pvALKymn7qlaYVannPq6qqUFpaisLCQv0eO1VWVfOeA0BhAVBlOL/bK0oqICuToay4zLDOcwAolwNyASgsAsT6ue8t5hxqIcpKKyErk6FcUmV4n3cDVFVVheKyShRq+Ttd8dlqbDIdkcDpdh7LjRs34OHhoeswiIiIiKgR169fh7u7e72vMyF+THK5HDdv3oSVlZXWplUODAzUu5v5tBWTurfzpPU97vrNXa855RsrW1hYCA8PD1y/fh3W1tZNjqG14PnD8+dJyxryOcTzh+fPk5bV1fkjCAKKiorg5ubW4MRM7DLxmMRicYO/NDRBIpHo3UVYWzGpeztPWt/jrt/c9ZpTvqllra2t9e5zpA08f3j+qKusIZ5DPH94/qirrC7OHxsbm0bLGE7nvFYgOjpa1yHUoq2Y1L2dJ63vcddv7nrNKa+Pnw99oo/Hh+ePZtfj+aM++nh8eP5odj1DO3/YZYLIQBQWFsLGxgYFBQV619JD1BLwHCJ6fPp+/rCFmMhAmJqaIiYmBqamproOhahF4jlE9Pj0/fxhCzERERERGTS2EBMRERGRQWNCTEREREQGjQkxERERERk0JsREREREZNCYEBMRERGRQWNCTEQAgJEjR8LOzg6jR4/WdShELcr169cRFhYGX19fdO/eHTt27NB1SEQtxv3799G7d28EBASgW7du+OSTT3QSB4ddIyIAQFJSEoqKirBlyxbs3LlT1+EQtRg5OTm4desWAgICkJubi169euGPP/6AhYWFrkMj0nsymQwVFRUwNzdHSUkJunXrhhMnTsDBwUGrcbCFmIgAAGFhYbCystJ1GEQtjqurKwICAgAALi4ucHR0RH5+vm6DImohJBIJzM3NAQAVFRUQBAG6aKtlQkzUChw+fBiRkZFwc3ODSCTC7t27a5WJj4+Hl5cXpFIp+vTpg9TUVO0HSqSH1Hn+pKenQyaTwcPDQ8NRE+kHdZw/9+/fh7+/P9zd3TFv3jw4OjpqKfq/MSEmagVKSkrg7++P+Pj4Ol//5ptvMGfOHMTExODkyZPw9/dHREQE8vLytBwpkf5R1/mTn5+PiRMn4uOPP9ZG2ER6QR3nj62tLTIyMpCdnY3t27fj1q1b2gr/bwIRtSoAhF27dqksCwoKEqKjo5XPZTKZ4ObmJixbtkyl3MGDB4UXXnhBG2ES6aXHPX/Ky8uF/v37C1u3btVWqER650m+fxSmTZsm7NixQ5Nh1oktxEStXGVlJdLT0xEeHq5cJhaLER4ejmPHjukwMiL915TzRxAEREVF4dlnn8WECRN0FSqR3mnK+XPr1i0UFRUBAAoKCnD48GF07txZ67EyISZq5e7cuQOZTAZnZ2eV5c7OzsjNzVU+Dw8Px5gxY/DTTz/B3d2dyTIRmnb+JCcn45tvvsHu3bsREBCAgIAAnDlzRhfhEumVppw/V69eRf/+/eHv74/+/ftjxowZ8PPz03qsRlrfIhHppQMHDug6BKIWqV+/fpDL5boOg6hFCgoKwunTp3UdBluIiVo7R0dHSCSSWjcp3Lp1Cy4uLjqKiqhl4PlD9Pha0vnDhJiolTMxMUGvXr2QmJioXCaXy5GYmIjg4GAdRkak/3j+ED2+lnT+sMsEUStQXFyMy5cvK59nZ2fj9OnTsLe3R7t27TBnzhxMmjQJvXv3RlBQENauXYuSkhJMnjxZh1ET6QeeP0SPr9WcP1of14KI1O7gwYMCgFqPSZMmKcusX79eaNeunWBiYiIEBQUJx48f113ARHqE5w/R42st549IEHQwPx4RERERkZ5gH2IiIiIiMmhMiImIiIjIoDEhJiIiIiKDxoSYiIiIiAwaE2IiIiIiMmhMiImIiIjIoDEhJiIiIiKDxoSYiIiIiAwaE2IiIiIiMmhMiImI1OjKlSsQiUQ4ffq0rkNRunDhAvr27QupVIqAgABdh6Mxmzdvhq2t7RPVkZiYCB8fH8hksiav89JLL2HVqlVPtF0i0i0mxETUqkRFRUEkEiEuLk5l+e7duyESiXQUlW7FxMTAwsICFy9eRGJiYp1loqKiMGLEiGbVKxKJsHv37icPUI+8/fbbWLhwISQSSZPXWbhwIZYuXYqCggINRkZEmsSEmIhaHalUiuXLl+PevXu6DkVtKisrH3vdrKws9OvXD56ennBwcFBjVOpRVVWl6xAAAEeOHEFWVhZeeOGFZq3XrVs3dOjQAV988YWGIiMiTWNCTEStTnh4OFxcXLBs2bJ6y8TGxtbqPrB27Vp4eXkpnytaTT/44AM4OzvD1tYWixcvRnV1NebNmwd7e3u4u7vj888/r1X/hQsXEBISAqlUim7duuHQoUMqr589exZDhw6FpaUlnJ2dMWHCBNy5c0f5elhYGKZPn47Zs2fD0dERERERde6HXC7H4sWL4e7uDlNTUwQEBGDfvn3K10UiEdLT07F48WKIRCLExsY2cOT+FhYWhpkzZ+Ltt9+Gvb09XFxcVNZVHKeRI0dCJBKpHLfvv/8ePXv2hFQqRfv27bFo0SJUV1erxLRp0yYMHz4cFhYWWLJkCdzd3bFp0yaVGE6dOgWxWIyrV68CAFavXg0/Pz9YWFjAw8MDb775JoqLi+vdh4yMDDzzzDOwsrKCtbU1evXqhRMnTtRb/uuvv8agQYMglUqVyxSfk23btsHLyws2NjZ46aWXUFRUpLJuZGQkvv7663rrJiL9xoSYiFodiUSCDz74AOvXr8eNGzeeqK5ff/0VN2/exOHDh7F69WrExMTg+eefh52dHVJSUvDGG2/g9ddfr7WdefPm4a233sKpU6cQHByMyMhI3L17FwBw//59PPvss+jRowdOnDiBffv24datWxg7dqxKHVu2bIGJiQmSk5Pxn//8p874PvzwQ6xatQorV67E77//joiICAwfPhyXLl0CAOTk5KBr16546623kJOTg7lz5zZ537ds2QILCwukpKRgxYoVWLx4MRISEgAAaWlpAIDPP/8cOTk5yue//fYbJk6ciFmzZuH8+fP46KOPsHnzZixdulSl7tjYWIwcORJnzpzBlClTMG7cOGzfvl2lzJdffonQ0FB4enoCAMRiMdatW4dz585hy5Yt+PXXX/H222/XG//48ePh7u6OtLQ0pKenY/78+TA2Nq63/G+//YbevXvXWp6VlYXdu3fjhx9+wA8//IBDhw7V6pITFBSE1NRUVFRU1Fs/EekxgYioFZk0aZLwj3/8QxAEQejbt6/wyiuvCIIgCLt27RIevuTFxMQI/v7+KuuuWbNG8PT0VKnL09NTkMlkymWdO3cW+vfvr3xeXV0tWFhYCF999ZUgCIKQnZ0tABDi4uKUZaqqqgR3d3dh+fLlgiAIwpIlS4TBgwerbPv69esCAOHixYuCIAjC008/LfTo0aPR/XVzcxOWLl2qsiwwMFB48803lc/9/f2FmJiYBut5+Lgptt+vX79a9b7zzjvK5wCEXbt2qZQZOHCg8MEHH6gs27Ztm+Dq6qqy3uzZs1XKnDp1ShCJRMLVq1cFQRAEmUwmtG3bVti0aVO9Me/YsUNwcHBQPv/8888FGxsb5XMrKyth8+bN9a7/KBsbG2Hr1q0qy2JiYgRzc3OhsLBQuWzevHlCnz59VMplZGQIAIQrV640eXtEpD/YQkxErdby5cuxZcsWZGZmPnYdXbt2hVj896XS2dkZfn5+yucSiQQODg7Iy8tTWS84OFj5fyMjI/Tu3VsZR0ZGBg4ePAhLS0vlo0uXLgBqWiMVevXq1WBshYWFuHnzJkJDQ1WWh4aGPtE+K3Tv3l3luaura639fFRGRgYWL16ssm9Tp05FTk4OSktLleUebYkNCAiAj4+PspX40KFDyMvLw5gxY5RlDhw4gIEDB6Jt27awsrLChAkTcPfuXZV6HzZnzhxMmTIF4eHhiIuLUzm2dSkrK1PpLqHg5eUFKyurBo+DmZkZANQbCxHpNybERNRqDRgwABEREViwYEGt18RiMQRBUFlW181dj/6JXSQS1blMLpc3Oa7i4mJERkbi9OnTKo9Lly5hwIABynIWFhZNrlMTHmc/i4uLsWjRIpX9OnPmDC5duqSSbNa1b+PHj1cmxNu3b8eQIUOUNwFeuXIFzz//PLp3747//ve/SE9PR3x8PID6bziMjY3FuXPn8Nxzz+HXX3+Fr68vdu3aVW/sjo6Odd6I2ZTjkJ+fDwBwcnKqt34i0l9MiImoVYuLi8PevXtx7NgxleVOTk7Izc1VSYrVOXbw8ePHlf+vrq5Geno6fHx8AAA9e/bEuXPn4OXlBW9vb5VHc5Jga2truLm5ITk5WWV5cnIyfH191bMjDTA2Nq41Xm/Pnj1x8eLFWvvl7e2t0tJel5dffhlnz55Feno6du7cifHjxytfS09Ph1wux6pVq9C3b1906tQJN2/ebDTGTp064X/+53+wf/9+jBo1qs4bIBV69OiB8+fPN1pnXc6ePQt3d3c4Ojo+1vpEpFtMiImoVfPz88P48eOxbt06leVhYWG4ffs2VqxYgaysLMTHx+Pnn39W23bj4+Oxa9cuXLhwAdHR0bh37x5eeeUVAEB0dDTy8/Mxbtw4pKWlISsrC7/88gsmT57crAkhgJqb95YvX45vvvkGFy9exPz583H69GnMmjVLbftSHy8vLyQmJiI3N1fZsvree+9h69atWLRoEc6dO4fMzEx8/fXXWLhwYZPqCwkJwauvvgqZTIbhw4crX/P29kZVVRXWr1+PP//8E9u2bav3RkOgpvvD9OnTkZSUhKtXryI5ORlpaWnKHyV1iYiIwJEjR5pxBP7222+/YfDgwY+1LhHpHhNiImr1Fi9eXOtP3D4+Pti4cSPi4+Ph7++P1NTUZo3A0Ji4uDjExcXB398fR44cwZ49e5Sth4pWXZlMhsGDB8PPzw+zZ8+Gra1to62oj5o5cybmzJmDt956C35+fti3bx/27NmDjh07qm1f6rNq1SokJCTAw8MDPXr0AFCTVP7www/Yv38/AgMD0bdvX6xZs0Y5UkRjxo8fj4yMDIwcOVLZLxcA/P39sXr1aixfvhzdunXDl19+2eCwehKJBHfv3sXEiRPRqVMnjB07FkOHDsWiRYsa3Pa5c+dw8eLFJh6BGuXl5di9ezemTp3arPWISH+IhEc70RERERmoefPmobCwEB999FGT19m0aRN27dqF/fv3azAyItIkthATERE98O6778LT07NZN0kaGxtj/fr1GoyKiDSNLcREREREZNDYQkxEREREBo0JMREREREZNCbERERERGTQmBATERERkUFjQkxEREREBo0JMREREREZNCbERERERGTQmBATERERkUFjQkxEREREBu3/AU9VFOWR68DaAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Function to integrate\n",
    "def f(x):\n",
    "    return np.sin(x)  # Example function, modify as needed\n",
    "\n",
    "# Exact integral of the function over [a, b]\n",
    "def exact_integral(a, b):\n",
    "    m = 2\n",
    "    p = 1 + 1/m\n",
    "    return ((m**p)/(m+1))*(b**p) - ((m**p)/(m+1))*(a**p)\n",
    "\n",
    "# Simpson's rule integration\n",
    "def simpsons_rule(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = simpson_rule(fx, h)\n",
    "    return integral\n",
    "\n",
    "def trapezoidal_rule(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = trap_rule(fx, h)\n",
    "    return integral\n",
    "\n",
    "def scipy_simpson(f, a, b, n):\n",
    "    h = (b - a) / n\n",
    "    x = np.linspace(a, b, n+1)\n",
    "    fx = f(x)\n",
    "    integral = integrate.simpson(fx, x=x)\n",
    "    return integral\n",
    "\n",
    "# Range of intervals to test\n",
    "n_values = np.array([2, 4, 8, 16, 32, 64, 128, 256, 512, 1024])\n",
    "\n",
    "# Parameters\n",
    "a = 0\n",
    "b = 2*np.pi  # Example interval [0, pi]\n",
    "\n",
    "# Compute exact integral\n",
    "t_idx = 0\n",
    "# t_calc = t[slice(*tpred)][t_idx].item()\n",
    "# m = 2\n",
    "# p = 1 + 1/m\n",
    "# I_exact = ((m**p)/(m+1))*(t_calc**p)\n",
    "I_exact = 0.0\n",
    "# I_exact = exact_integral(a, b)\n",
    "\n",
    "# Initialize arrays to store errors\n",
    "errors_s = np.zeros_like(n_values, dtype=float)\n",
    "errors_t = np.zeros_like(n_values, dtype=float)\n",
    "errors_sci = np.zeros_like(n_values, dtype=float)\n",
    "\n",
    "# Compute errors for each n\n",
    "for i, n in enumerate(n_values):\n",
    "    grid = np.linspace(0, 2 * np.pi, n+1)\n",
    "    # a, u, p = dataset_class.generate_dataset(n_train, grid, t, tpred, *dataset_params)\n",
    "    # x_train, y_train = get_xy_from_pu(p, u, is_markov=is_markov)\n",
    "    # p = y_train[0,:,t_idx,0].flatten().numpy().astype(np.float64)\n",
    "    p = np.sin(grid)\n",
    "    # p = p.numpy()\n",
    "    h = grid[1] - grid[0]\n",
    "    I_approx_s = simpson_rule(p, h)\n",
    "    I_approx_t = trap_rule(p, h) \n",
    "    I_approx_sci = integrate.simpson(p, x = grid) \n",
    "    errors_s[i] = np.abs(I_approx_s - I_exact)\n",
    "    errors_t[i] = np.abs(I_approx_t - I_exact)\n",
    "    errors_sci[i] = np.abs(I_approx_sci - I_exact)\n",
    "\n",
    "# Plot convergence\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.loglog(n_values, errors_s, marker='o', linestyle='-', label=\"simpson\")\n",
    "plt.loglog(n_values, errors_t, marker='o', linestyle='-', label=\"trapezoid\")\n",
    "plt.loglog(n_values, errors_sci, marker='o', linestyle='-', label=\"scipy_simpson\")\n",
    "plt.xlabel('Number of Intervals (n)')\n",
    "plt.ylabel('Absolute Error')\n",
    "plt.legend()\n",
    "plt.title('Convergence of integrators on {s}'.format(s=dataset))\n",
    "plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 414,
   "id": "726f840d-a90a-4738-b72a-43fec4b86e15",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0.0000e+00,  6.1419e-03,  1.2284e-02,  ..., -1.2283e-02,\n",
       "        -6.1419e-03,  1.7485e-07])"
      ]
     },
     "execution_count": 414,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sin(grid)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 417,
   "id": "fb33159a-707d-4e9c-947e-103a08e9189f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(0.0230)"
      ]
     },
     "execution_count": 417,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "t_idx = 10\n",
    "t_val = t[slice(*tpred)][t_idx]\n",
    "exact = np.exp(-1*t_val)*np.sin(grid)\n",
    "torch.norm(y_train[0,:,t_idx,0] - exact)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 422,
   "id": "04bf0e4a-5e0e-475e-a87b-2025fe9fb595",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7fdaf4c266d0>]"
      ]
     },
     "execution_count": 422,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(grid, y_train[0,:,t_idx,0])\n",
    "plt.plot(grid, exact, '--')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 368,
   "id": "42381d1c-0c94-4fee-99c8-81b72a250add",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([ 0.0000e+00,  6.1419e-03,  1.2284e-02,  ..., -1.2283e-02,\n",
       "        -6.1424e-03, -2.2737e-16])"
      ]
     },
     "execution_count": 368,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "y_train[0,:,0,0] - "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 365,
   "id": "601380e5-5f70-4194-9e22-0ba21d640db9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([4.76210340e-16, 1.20919967e+00, 1.44087166e-01, 2.96794325e-02,\n",
       "       6.87068515e-03, 1.65930914e-03, 4.07942396e-04, 1.01246093e-04,\n",
       "       2.51387428e-05, 6.34689013e-06])"
      ]
     },
     "execution_count": 365,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 366,
   "id": "f05cebe7-6706-43e1-a0cb-af3e38d9003c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([7.14315522e-16, 4.53449846e-01, 1.69113430e-02, 1.17086297e-03,\n",
       "       6.86687897e-05, 4.01508527e-06, 2.58276886e-07, 1.88796989e-08,\n",
       "       4.85151777e-09, 2.08233123e-08])"
      ]
     },
     "execution_count": 366,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors_sci"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 367,
   "id": "fee2ef27-02c1-4709-974e-bab6c9e97040",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([7.14315537e-16, 2.32524573e-16, 1.07002009e-07, 2.30946000e-07,\n",
       "       1.38930034e-07, 1.56044592e-07, 4.98544068e-08, 1.95055758e-08,\n",
       "       2.16431726e-08, 2.18808509e-08])"
      ]
     },
     "execution_count": 367,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "errors_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 236,
   "id": "46a6c07c-b5b8-48ea-bbbf-81cdb1c87cc3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0"
      ]
     },
     "execution_count": 236,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "I_exact"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3217c39a-ea1c-456e-8f07-073fc19134dc",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 237,
   "id": "b8535622-ac47-47ba-86bc-58027b747a8b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "-5.996345266779171e-09"
      ]
     },
     "execution_count": 237,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "I_approx_sci"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 238,
   "id": "2f318fc7-1cfa-42eb-bf69-724c95a2b0b5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(4.8911e-06)"
      ]
     },
     "execution_count": 238,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "I_approx_s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 239,
   "id": "7c41b37c-bcbf-422b-98a4-1f0050f21dae",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.2207e-08)"
      ]
     },
     "execution_count": 239,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "I_approx_t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a6277e4-9315-4d97-8646-8b8dc74c16b1",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "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
}
