{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:12.048498900Z",
     "start_time": "2026-01-22T07:35:11.100861200Z"
    }
   },
   "source": [
    "import sys\n",
    "import os\n",
    "sys.path.insert(0, os.path.abspath(os.path.join(os.getcwd(), '..')))\n",
    "import random\n",
    "from sched import scheduler\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import gpytorch\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "id": "507a2b4e9f7cb8b9",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:13.179576500Z",
     "start_time": "2026-01-22T07:35:12.995713900Z"
    }
   },
   "source": [
    "# Base GP model\n",
    "class GP(gpytorch.models.ExactGP):\n",
    "    def __init__(self, x_train, y_train):\n",
    "        super().__init__(x_train, y_train, gpytorch.likelihoods.GaussianLikelihood())\n",
    "        self.mean_module = gpytorch.means.ZeroMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(\n",
    "            gpytorch.kernels.RBFKernel()\n",
    "        )\n",
    "\n",
    "    def forward(self, x):\n",
    "        function_mean = self.mean_module(x)\n",
    "        function_covar = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(function_mean, function_covar)\n",
    "\n",
    "# Sampling function\n",
    "def f(x):\n",
    "    gp = GP(x, torch.randn(len(x)))\n",
    "    gp.covar_module.outputscale = 1.0\n",
    "    gp.covar_module.base_kernel.lengthscale = 0.5\n",
    "    gp.likelihood.noise = 0.2\n",
    "    with torch.no_grad():\n",
    "        targets_dist = gp.likelihood(gp(x))\n",
    "    return targets_dist.rsample(), gp\n",
    "\n",
    "# sin function\n",
    "def h(x, scale=3.0):\n",
    "    return torch.sin(x/scale) + 2.0\n",
    "\n",
    "# Build input data, initialize the GP, and sample from it\n",
    "random.seed(63)\n",
    "np.random.seed(63)\n",
    "torch.manual_seed(63)\n",
    "\n",
    "x = torch.linspace(-5, 5, 500)\n",
    "y, gp = f(x)\n",
    "y_shift = y + h(x, scale=3.0)\n",
    "\n",
    "train_mask = (x > -3) & (x < 3)\n",
    "to_false = torch.randperm(len(x))[:(train_mask.sum() * 0.5).int()]\n",
    "train_mask[to_false] = False\n",
    "\n",
    "x_train = x[train_mask].reshape(-1, 1)\n",
    "y_train = y[train_mask]\n",
    "x_test = x[~train_mask].reshape(-1, 1)\n",
    "y_test = y[~train_mask]\n",
    "\n",
    "print(f'x_train.shape = {x_train.shape}, y_train.shape = {y_train.shape}, x_test.shape = {x_test.shape}, y_test.shape = {y_test.shape}')"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "x_train.shape = torch.Size([213, 1]), y_train.shape = torch.Size([213]), x_test.shape = torch.Size([287, 1]), y_test.shape = torch.Size([287])\n"
     ]
    }
   ],
   "execution_count": 2
  },
  {
   "cell_type": "code",
   "id": "de745749ece59498",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:15.014742300Z",
     "start_time": "2026-01-22T07:35:14.810482500Z"
    }
   },
   "source": [
    "fig, ax = plt.subplots(figsize=[4, 3])\n",
    "ax.plot(x_test, y_test, 'x', color='r', label='test points')\n",
    "ax.plot(x_train, y_train, '.', color='k', label='train points')\n",
    "ax.set_xlabel('inputs')\n",
    "ax.set_ylabel('targets')\n",
    "ax.set_xticks([-3, 0, 3])\n",
    "ax.set_yticks([-2, 0, 2])\n",
    "ax.legend(fontsize=8)\n",
    "fig.tight_layout()\n",
    "plt.show()\n",
    "# fig.savefig('./logs/1D_data_pretrain.pdf', dpi=300, bbox_inches='tight')  # save fig"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "id": "a93a38f94148d0bd",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:16.917215100Z",
     "start_time": "2026-01-22T07:35:16.901229900Z"
    }
   },
   "source": [
    "def plot_confidence_region(y_data, y_mean, y_lower, y_upper, fig_path=None):\n",
    "    fig, ax = plt.subplots(figsize=[4, 3])\n",
    "    ax.plot(x_train, y_data, '.', color='k', label='training points')\n",
    "    ax.plot(x_test, y_mean, color='r', linewidth=1, label='posterior mean')\n",
    "    ax.fill_between(x_test.squeeze(), y_lower, y_upper, color='r', alpha=0.12)\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([-2.5, 0, 2.5])\n",
    "    ax.set_xlabel('$x$')\n",
    "    # ax.set_ylabel('$y$')\n",
    "    ax.set_title('Mean posterior with 95% confidence', size=10, style='italic')\n",
    "    ax.legend(fontsize=8)\n",
    "    fig.tight_layout()\n",
    "    # save figure as pdf\n",
    "    if fig_path is not None:\n",
    "        fig.savefig(fig_path, dpi=300, bbox_inches='tight')\n",
    "    plt.show()"
   ],
   "outputs": [],
   "execution_count": 4
  },
  {
   "cell_type": "code",
   "id": "138d4d9e344a5b57",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:18.363387900Z",
     "start_time": "2026-01-22T07:35:18.052527900Z"
    }
   },
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "print(f\"Using device: {device}\")"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Using device: cuda\n"
     ]
    }
   ],
   "execution_count": 5
  },
  {
   "cell_type": "code",
   "id": "fa8f194fa705e11e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:16:24.012815200Z",
     "start_time": "2026-01-22T07:16:23.957364400Z"
    }
   },
   "source": [
    "class ExactGPModel(gpytorch.models.ExactGP):\n",
    "    def __init__(self, train_x, train_y, likelihood):\n",
    "        super(ExactGPModel, self).__init__(train_x, train_y, likelihood)\n",
    "        self.mean_module = gpytorch.means.ZeroMean()\n",
    "        self.covar_module = gpytorch.kernels.ScaleKernel(gpytorch.kernels.RBFKernel())\n",
    "\n",
    "    def forward(self, x):\n",
    "        mean_x = self.mean_module(x)\n",
    "        covar_x = self.covar_module(x)\n",
    "        return gpytorch.distributions.MultivariateNormal(mean_x, covar_x)"
   ],
   "outputs": [],
   "execution_count": 6
  },
  {
   "cell_type": "code",
   "id": "c773ed875ec99d0",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:16:24.062414700Z",
     "start_time": "2026-01-22T07:16:24.012815200Z"
    }
   },
   "source": [
    "def train_gpr(model, criterion, optimizer, epochs=200, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_train_ = x_train.to(device)\n",
    "    y_train_ = y_train.to(device)\n",
    "    losses = []\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        # Zero backprop gradients\n",
    "        optimizer.zero_grad()\n",
    "        # Get output from model\n",
    "        output = model(x_train_)\n",
    "        # Calc loss and backprop derivatives\n",
    "        loss = - criterion(output, y_train_)\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "\n",
    "        losses.append(loss.item())\n",
    "        if epoch % 100 == 0:\n",
    "            print(f'Epoch [{epoch}/{epochs}], Loss: {loss.item()}')\n",
    "\n",
    "    return losses\n",
    "\n",
    "def evaluate_gpr(model, x, likelihood, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_ = x.to(device)\n",
    "\n",
    "    model.eval()\n",
    "    likelihood.eval()\n",
    "\n",
    "    with torch.no_grad(), gpytorch.settings.fast_pred_var():\n",
    "        observed_pred = likelihood(model(x_))\n",
    "\n",
    "    mean = observed_pred.mean.cpu().numpy()\n",
    "    lower, upper = observed_pred.confidence_region()\n",
    "\n",
    "    return mean, lower.cpu().numpy(), upper.cpu().numpy()"
   ],
   "outputs": [],
   "execution_count": 7
  },
  {
   "cell_type": "code",
   "id": "fd3d5e82cb89c8cc",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:16:26.681878600Z",
     "start_time": "2026-01-22T07:16:24.063413500Z"
    }
   },
   "source": [
    "# initialize likelihood and model\n",
    "gp_likelihood = gpytorch.likelihoods.GaussianLikelihood()\n",
    "gp_model = ExactGPModel(x_train, y_train, gp_likelihood)\n",
    "\n",
    "gp_optimizer = torch.optim.Adam(gp_model.parameters(), lr=0.001)\n",
    "gp_criterion = gpytorch.mlls.ExactMarginalLogLikelihood(gp_likelihood, gp_model)\n",
    "\n",
    "gp_losses = train_gpr(gp_model, gp_criterion, gp_optimizer, epochs=500, device=device)\n",
    "gp_mean, gp_lower, gp_upper = evaluate_gpr(gp_model, x_test, gp_likelihood, device=device)\n",
    "plot_confidence_region(y_train, gp_mean, gp_lower, gp_upper)"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [0/500], Loss: 0.9529625177383423\n",
      "Epoch [100/500], Loss: 0.9278796911239624\n",
      "Epoch [200/500], Loss: 0.9036049246788025\n",
      "Epoch [300/500], Loss: 0.880197286605835\n",
      "Epoch [400/500], Loss: 0.8577349185943604\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ],
      "image/png": "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795NJ0+e1P4eugwePJhmzZpFRCykQ0NDKTg4mNLT04mI6M0336TBgwdrjw8PD6eNGzcSEVF2djY1a9aMlixZQiqViq5evUpERJMmTaLg4GB69NFH6fDhw3TgwAFq1qyZ3sKoi0ajIaVSSV988YXe8wMGDKD4+Hjt319++SUpFApq0aIFNWnShO699146c+aM9vWioiJSKBR07tw5ys7OpoSEBFq+fDlduXKFOnfuTMePHzd7TehSXl5Ot912G8XHx9Mvv/xC58+fp59++om+/fZbIiLasmULBQQE0IIFC+jChQv0448/UmBgIK1atUr7fUJCQrRzk5KSQh9//LHeon/t2jW67bbbaOLEiaRSqSg3N5c2btxIYWFh2nHs2LGDfH19ad68eXThwgVavnw5RUZGGl3/UVFRtHLlSjp//jz98ssvFBkZSatXr9Z+DgBq27YtrVmzhs6fP09Tp04lX19f7SYnLS2NmjRpQg899BDt27ePzp49S8uXL6d//vmHiIg++OADatGiBa1fv54uXLhA33zzDfn5+dGuXbtsmk9PRAgGFzJ58mTq2bOn9sY4fPgwnT17lgIDA+nUqVM0ZswYvUXm9ttvpzfeeEPvHOvXr6dWrVqZ/QxZK5G1ihkzZlBYWJjeTnDRokV08803mz3HN998QwBo9+7d2ufkG0i+2BMSEujZZ5/Ve98bb7xBPXv2JCKiP/74g7y9vSkvL8/kZ7zwwgv04IMP6j339ttv02233aYVArqfe/HiRSIiSkpKovj4eO0CT8SCwMfHh7Zv305ERAsXLqQmTZpQfn6+9pgLFy4QAO3OftSoUdS0aVOz45N59NFH6ZVXXiEioilTptCzzz5LrVu3pqNHj1JFRQXFxMTQli1biIgXEACUmppKRCwcAehpPES8G+7fvz+p1Wrtcw899BA999xzZsfRvHlzGjJkCBUUFFBhYSG9+eabBIDuvPNO7TGbN2+m77//no4ePUpbtmyhDh060E033UQVFRXaYyZPnkySJJGXlxeNGzeOiouLqX///vTFF1/Qww8/TE2bNqVHH33UpJCUmTt3LkVFRZnULsrLyykmJobmzZun9/zIkSPpkUceISKi8+fPEwC9XXlRUREBoAMHDmifa9y4Ma1du1b798yZM+m2224jIqKqqipq164dvf7663qf07t3bxo0aBAREeXn51Nk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+mmKiYnR+ilWrVpFzZo1s+l3W7ZsGQUFBVGnTp20z40YMYICAwNp0qRJese2bt2aVqxYof37ySefpH79+tHFixe19nhT3+GLL76gFi1amB3D33//Td9++y2dO3eOdu7cSXfffTe1bNlSL/po9uzZtGXLFjp//jzt37+fxo0bR35+flq/iy4HDx6kLl26UE5ODhGxuSQgIID27dtH33//PUVERGgd5aa49dZbqXv37rRv3z46d+4cff/997R582Yi4t9edginpqbSpk2bqFmzZvTaa69p39+qVSsjc2BSUpJetNDw4cO15h4iol27dpGXl5fW93Hw4EECQG+//TZduHCBvvzySwoJCSE/Pz+qqqoiompz08yZM+ns2bN0/PhxWrt2Lb3//vtERFRZWUk+Pj60detWvbG0bNmSVq5cSURsEg0PD6eRI0fSyZMn6cSJE/TJJ59ozahffPEFeXl50eLFi+n8+fN05MgR+uyzz+jzzz83O391ASEYXMS0adOoW7duZl8fP368XughES8ISUlJFBISQsHBwXTLLbfo2Xb37t1L//rXv8jPz4969+5NP//8s54D7+OPPzZyMhtGdhiydetWCg4Opq1bt9JNN91Evr6+NGjQIDp//rzecXv27KHu3buTv7+/dtGXb8gTJ07QnXfeSZGRkeTr60vt27en+fPn6znvXnzxRQoNDSUA9OOPPxIRUWZmJo0YMUIbetumTRt65plntNEhDz74oEkHbWRkJK1fv177d25uLj3xxBMUHh5OYWFh9Mgjj2iFAhHRyy+/TEOHDjU7B7p89913Ro7S8ePHk0Kh0AosIg45liSJDh48qH3u8OHD1KlTJ1Iqldrf3tR3eOGFFyz6fH744QdtWGjz5s3pxRdf1AtZJmLnbrNmzbTHDB8+3MjpTcS+lo4dOxo5S2fOnEmhoaF0880307Zt2yzOyaVLl+jf//43RUREUGBgIPXo0UMv/PmHH36gjh07kp+fH3Xs2JGWLVtmNE+6TmYiorCwMG00FxFR+/btadGiRdq/Fy5cqCecidgJ3qhRI4qOjqZ7772X/u///o+6d++ud8zq1aupU6dO5O/vT5GRkTRgwAD65ZdfiKjar6EbJiwHDMi+KCKi3bt3U58+fSgwMJDCw8Np8ODBevM/f/58atu2Lfn6+lKjRo3o7rvvpr///tviHHo6EpFO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"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 8
  },
  {
   "cell_type": "code",
   "id": "21501f1f1d3bd759",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:16:26.918456300Z",
     "start_time": "2026-01-22T07:16:26.860349200Z"
    }
   },
   "source": [
    "# Train BNN\n",
    "def train_bnn(model, criterion, optimizer, num_mc=1, epochs=2000, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_train_ = x_train.to(device)\n",
    "    y_train_ = y_train.to(device)\n",
    "\n",
    "    losses = []\n",
    "    # bnn_scheduler = torch.optim.lr_scheduler.CosineAnnealingLR(optimizer, T_max=epochs)\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        output_ = []\n",
    "        kl_ = []\n",
    "        for mc_run in range(num_mc):\n",
    "            output, kl = model(x_train_, return_kl=True)\n",
    "            output_.append(output)\n",
    "            kl_.append(kl)\n",
    "        output = torch.mean(torch.stack(output_), dim=0)\n",
    "        kl = torch.mean(torch.stack(kl_), dim=0)\n",
    "        loss = criterion(output, y_train_.view(-1,1)) + kl / len(x_train)\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        # bnn_scheduler.step()\n",
    "\n",
    "        losses.append(loss.item())\n",
    "        if epoch % 200 == 0:\n",
    "            print(f'Epoch [{epoch}/{epochs}], Loss: {loss.item()}')\n",
    "\n",
    "    return losses\n",
    "\n",
    "def evaluate_bnn(model, num_mc=1000, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_test_ = x_test.to(device)\n",
    "\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        predicts = []\n",
    "        for mc_run in range(num_mc):\n",
    "            output = model(x_test_, return_kl=False)\n",
    "            predicts.append(output.cpu().data.numpy())\n",
    "\n",
    "        pred_mean = np.mean(predicts, axis=0)\n",
    "        pred_std = np.std(predicts, axis=0)\n",
    "        lower = pred_mean - 2 * pred_std\n",
    "        upper = pred_mean + 2 * pred_std\n",
    "\n",
    "    return pred_mean, lower.squeeze(), upper.squeeze()"
   ],
   "outputs": [],
   "execution_count": 9
  },
  {
   "cell_type": "code",
   "id": "c02a0952",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:24:42.215254800Z",
     "start_time": "2026-01-22T07:21:55.623245Z"
    }
   },
   "source": [
    "from csgp.models.dgp import DeepCSGP, DeepCompactGP\n",
    "csgp_model = DeepCSGP(\n",
    "    in_features=1,\n",
    "    out_features=1,\n",
    "    hidden_features=[10, 10],\n",
    "    dyadic_levels=[6, 6, 6],\n",
    "    anchor=False,\n",
    ")\n",
    "\n",
    "csgp_losses = train_bnn(\n",
    "    model=csgp_model,\n",
    "    criterion=nn.MSELoss(),\n",
    "    optimizer=torch.optim.Adam(csgp_model.parameters(), lr=0.001, weight_decay=0.0001),\n",
    "    num_mc=10,\n",
    "    epochs=2000,\n",
    "    device=device,\n",
    ")"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [0/2000], Loss: 1.246172547340393\n",
      "Epoch [200/2000], Loss: 0.26723992824554443\n",
      "Epoch [400/2000], Loss: 0.2377486675977707\n",
      "Epoch [600/2000], Loss: 0.23116476833820343\n",
      "Epoch [800/2000], Loss: 0.2234756350517273\n",
      "Epoch [1000/2000], Loss: 0.21930819749832153\n",
      "Epoch [1200/2000], Loss: 0.21819747984409332\n",
      "Epoch [1400/2000], Loss: 0.2075214833021164\n",
      "Epoch [1600/2000], Loss: 0.2087438553571701\n",
      "Epoch [1800/2000], Loss: 0.19684016704559326\n"
     ]
    }
   ],
   "execution_count": 18
  },
  {
   "cell_type": "code",
   "id": "0743d25e",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:24:51.393625400Z",
     "start_time": "2026-01-22T07:24:49.818438Z"
    }
   },
   "source": [
    "csgp_mean, csgp_lower, csgp_upper = evaluate_bnn(csgp_model, num_mc=1000)\n",
    "plot_confidence_region(y_train, csgp_mean, csgp_lower, csgp_upper)"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEiCAYAAAD9DXUdAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAiN9JREFUeJztnXd4FFUXh3+zJb0XIGRJAiaASA+gFENAJWDFTxTEhoZmbyhFpYgasKAiogRiAVFREBVFsAWQYgHpzQQSyEIgoaT33fP9cffO7OzOpkASAtz3efZJdnZm9s7s7jn3nioREUEgEAgEAhu6Cz0AgUAgEDQthGIQCAQCgQqhGAQCgUCgQigGgUAgEKgQikEgEAgEKoRiEAgEAoEKoRgEAoFAoEIoBoFAIBCoEIpBIBAIBCqEYhBcEmRnZ0OSJPz3338XdBxbtmyBm5sbCgsLq90vNjYWb731ViON6uJl+fLlaNeuHYxGI+68806MGzcOI0eOrPaY8ePH4+67726kEV6aCMXQyMTFxUGSJMycOVO1nYhw9dVXQ5IkTJ069QKNrnHp2rUr3nnnnXo5V3BwME6cOIG2bdvWy/nOla5du+L48ePw9fUFAHz77bcIDAyEfeWZqqoq7N27F126dKnTuTdt2oTrr78eAQEBiIiIwLRp02CxWFT7XH/99ZAkSfVISEiQXz9x4gSGDh0Kf39/dOvWDYcOHVId/+abb2LUqFF1vOqG4fTp07jvvvvw3HPP4ciRI/joo4+QlJSEhQsXVnvczp0763xvBWqEYmhEiAg7duxAZGQkdu/erXrt008/xfHjxwEA3bt3vxDDa1RKS0uxd+9e9OrV67zOY7VaYbVa4ebmhubNm5/zeYgIVVVV5zUWAPD09ERISIj8/J9//kHPnj0hSZK8bf/+/SgvL6+T8Pr9999x3XXXIT4+Hn/99Rc+/vhjzJ8/Hx988IHqGrZu3YqPPvoI2dnZ8uPrr7+W93nwwQfRsmVLbNu2DV26dMGsWbPk13744QesWrUKycnJ53r59cratWsREBCA0aNHo2XLlvD19UVQUBC8vb1dHkNE2L17N7p27dp4A70UIUGjcfDgQQJA06ZNo/bt28vbCwoKqEWLFvTiiy8SADp69Kj82tGjR2nkyJEUEBBAAQEBdPfdd9OZM2fk13fu3Em33HILNW/enDw8PKhbt260bt06+fW0tDQCQD/88AMNHDiQPD09qW3btvTnn3+6HKfFYiEvLy+aOXMm9evXjzw8PCgqKoq++eYb1X67d++mIUOGkK+vLzVv3pyeeeYZKi8vl1/fsWMHDRkyhIKDg8nLy4s6depEqamplJqaSgBUj+eff56IiIqLi2nKlCkUHh5OXl5edO2119Lu3bvlc3788ccUERFBS5cupfbt25NOp6OcnBx64IEHaNSoUfJ+JSUl9Pzzz5PJZCJvb28aOHAg7d+/X349NTWVDAYD/fDDD9S9e3cyGAz0999/O92Lq6++mubMmSM/v+uuuwgAFRUVERHRsWPHyGg00r59+4iIqH///jR9+nT5f/trlCSJioqKaPHixdSyZUtavnw5de7cmTw9PSk+Pp5yc3NdfiY9e/akhx9+WLVt3LhxNHDgQPn5/v37CQAdO3ZM8xylpaWk1+upsLCQiIjmz59PI0aMICKiXbt2UefOnSknJ8flGOwpLy+npKQkatOmDbm5uVFkZCS999578uvr16+nuLg48vLyolatWtFrr72mOr5v3740efJkeuqppyg0NJQCAgLk+0ZENHDgQNW969evH2VkZBAAyszMlPfbvHkzde/endzd3SkuLo5+//13AkDHjx9X7RMXF0ceHh7UsmVLmjZtmmos4eHh9Pbbb9MDDzxAAQEBFBoaSgsXLlTtk5OTQ2PGjKFmzZqRh4cHde7cmdavXy+/vmrVKoqNjSV3d3eKioqiDz74oFb3sakiFEMj8vnnn5OHhwcdOHCA9Ho9lZWVERHRc889R4MHD6b333+fQkJC5P3T0tIoNDSUXnrpJdq/fz9t3bqVevXqRYmJifI+P/zwAy1dupT27dtHBw4coMTERGrWrJn8+vLly0mSJBowYAD9/vvv9N9//9H1119P8fHxLsfJBUyLFi3ou+++o7S0NHrooYfIx8eHzp49S0RE//77L/n6+tILL7xAaWlptG7dOgoLC6OXX36ZiIjOnj1LISEhNH36dDp48CAdOHCAFi9eTPv376fS0lJ6++23qU2bNpSdnU3Z2dlUXFxMpaWldPXVV9Mdd9xBf//9N/3333/00EMPUXR0NFmtViIievLJJ8nb25tuvfVW2rZtm6w0unTpQm+//TYREVVUVFB8fDz17duXNm/eTAcPHqQ777yT2rVrR5WVlURE9Pbbb8vCZOPGjbRv3z7587AnISGBZsyYQURMSfv7+5Ovry9lZWUREdG0adMoISFB3j8wMJBWrlxJRES5ubkUHh5O8+fPp+zsbDp58iQRET3zzDPk6+tLI0aMoO3bt9M///xD4eHhKsFoj9VqJb1eT5988olq+4ABA6hLly7y808//ZR0Oh1FRkZSixYt6JZbbqGDBw/KrxcVFZFOp6P09HTKzc2l2NhYWrhwIZ04cYI6depEe/bscfmdsKe8vJz69+9PXbp0oZ9++okOHTpEq1atoq+++oqIiFavXk1eXl709ttv0+HDh+n7778nb29vWrx4sXw9fn5+8r1JS0ujuXPnqoT+qVOnqH///vTEE09QdnY2nT17llauXEkBAQHyONatW0fu7u70+uuv0+HDh2nhwoUUHBzs9P0PCQmhjz/+mA4dOkQ//fQTBQcH05IlS+T3AUAxMTG0dOlSOnToEE2cOJHc3d3lSU5mZia1aNGChg0bRlu2bKH//vuPFi5cSP/++y8REc2ZM4ciIyNp+fLldPjwYfryyy/Jw8ODNmzYUKv72RQRiqERmTBhAvXq1Uv+YWzfvp3+++8/8vb2pv3791NiYqJKyFx33XU0depU1TmWL19OrVu3dvkefFXCVxUvvfQSBQQEqGaC8+bNo6uuusrlOb788ksCQBs3bpS38R8Q/7LHxsbSI488ojpu6tSp1KtXLyIi+u2338hoNFJeXp7mezz55JN0xx13qLbNnDmT+vfvLysB+/c9cuQIERHFx8dTly5dZAFPxBSBm5sbpaamEhHRe++9Ry1atKD8/Hx5n8OHDxMAeWY/atQoatmypcvxcUaMGEHPPfccERE9//zz9Mgjj1CbNm1o165dVFFRQWFhYbR69WoiYgIEAGVkZBARU44AVCseIjYb7tevH1ksFnnbsGHD6NFHH3U5joiICBoyZAgVFBRQYWEhTZs2jQDQDTfcIO/zww8/0IoVK2jXrl20evVqat++PV1xxRVUUVEh7zNhwgSSJIkMBgONGTOGiouLqV+/fvTJJ5/QnXfeSS1btqQRI0ZoKknO7NmzKSQkRHN1UV5eTmFhYfT666+rtt9///101113ERHRoUOHCIBqVl5UVEQA6J9//pG3NW/enL744gv5+fTp06l///5ERFRVVUVt27alF198UfU+11xzDQ0aNIiIiPLz8yk4OJh+++031T6P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eK0+t+TkZPLx8aGOHTvK20aOHEne3t70zDPPqPZt06YNpaSkyM8feOAB6tu3Lx05ckS2x2tdwyeffEKRkZEux/DXX3/RV199Renp6bR+/Xq68cYbKSoqShV9lJSURKtXr6ZDhw7R33//TWPGjCEPDw/Z72LP1q1bqXPnznT69GkiYuYSLy8v2rJlC61YsYKCgoJkR7kW1157LfXo0YO2bNlC6enptGLFCvrhhx+IiH323CGckZFB3377LYWHh9MLL7wgH9+6dWsnc2B8fLwqWmj48OGyuYeIaMOGDWQwGGTfx9atWwkAzZw5kw4fPkyffvop+fn5kYeHB1VVVRGRYm6aPn06/ffff7Rnzx764osv6M033yQiosrKSnJzc6O1a9eqxhIVFUUff/wxETGTaGBgIN1///20b98+2rt3L33wwQeyGfWTTz4hg8FA77//Ph06dIh27NhBixYtoo8++sjl/bsYEIqhkZg0aRJ1797d5evjx49XhR4SMYEQHx9Pfn5+5OvrS926dVPZdjdv3kxXXnkleXh40DXXXEM//vijyoE3d+5cJyezY2SHI2vXriVfX19au3YtXXHFFeTu7k6DBg2iQ4cOqfbbtGkT9ejRgzw9PWWhz3+Qe/fupRtuuIGCg4PJ3d2d2rVrR2+99ZbKeffUU0+Rv78/AaDvv/+eiIiOHz9OI0eOlENvo6Ojady4cXJ0yB133KHpoA0ODqbly5fLz8+ePUv33XcfBQYGUkBAAN11112yUiAievbZZ+mmm25yeQ/s+frrr50cpePHjyedTicrLCIWcixJEm3dulXetn37durYsSPp9Xr5s9e6hieffLJan893330nh4VGRETQU089pQpZJmLO3fDwcHmf4cOHOzm9iZivpUOHDk7O0unTp5O/vz9dddVV9Pvvv1d7T44ePUr/+9//KCgoiLy9valnz56q8OfvvvuOOnToQB4eHtShQwdKTk52uk/2TmYiooCAADmai4ioXbt2NG/ePPn5e++9p1LORMwJ3qxZMwoNDaVbbrmFHn74YerRo4dqnyVLllDHjh3J09OTgoODacCAAfTTTz8RkeLXsA8T5gED3BdFRLRx40bq3bs3eXt7U2BgICUkJKju/1tvvUUxMTHk7u5OzZo1oxtvvJH++uuvau9hU0ciskvJFFz2vPHGG1i5ciU2b958oYciEAguECLzWaBix44dTnZxgUBweSEUg0AFjxgRCASXL8KUJBAIBAIVDbpiSEpKQs+ePeHr64tmzZph6NChOHjwYLXHrFu3zqk6pCRJOHDgQEMOVSAQCAQ2GlQxrF+/Ho8++ij+/PNP/PLLL6iqqsKgQYNQXFxc47EHDx5UVYiMiYlpyKEKBAKBwEajmpJyc3PRrFkzrF+/3mXm7bp16zBgwACcPXsWAQEBjTU0gUAgENho1Mxnni3J09Gro1u3bigrK0OHDh3w4osvYsCAAZr7lZeXo7y8XH5utVpx5swZBAcHq2rgCwQCweUMEaGwsBAtW7aETleDsaixEiasVivdcsst1K9fv2r3O3DgACUnJ9O2bdto8+bN9PDDD5MkSara5/bwKpPiIR7iIR7iUfODl4yvjkYzJT366KP48ccfsXHjRqc6PDVxyy23QJIkfP/9906vOa4Y8vPzERERgaysLKdCXgKBQHC5UlBQgFatWiEvLw/+/v7V7tsopqTHH38c33//PTZs2FBnpQAA11xzDT777DPN19zd3eXiX/b4+fkJxSAQCAQO1MbE3qCKgYjw+OOPY+XKlVi3bh1at259TufZvn07wsLC6nl0AoFAINCiQRXDo48+is8//xzfffcdfH19ceLECQCAv7+/3FNg8uTJOHbsGBYvXgwAeOeddxAVFYWrrroKFRUV+Oyzz7BixQqsWLGiIYcqEAgEAhsNqhg++OADAHBqrPLxxx9j1KhRAIDs7GwcPXpUfq2iogITJkzAsWPH4Onpiauuugo//vgjbrzxxoYcqkBwycN7aAgubYxGo1NzprpyyZXEKCgogL+/P/Lz84WPQSCwUVRUBLPZjEvs5y7QQJIkmEwm+Pj4qLbXRTaKDm4CwSWOxWKB2WyGl5cXQkNDRX7PJQwRITc3F2azGTExMee8chCKQSC4xKmsrAQRITQ0VPbtCS5dQkNDkZmZicrKynNWDKLstkBwmSBWCpcH9fE5C8UgEAganenTp6OiouKcjt26dSvuueeeWu3btWtXlJaWntP71Ccffvgh3n777Rr3y8zMRHJyciOMqHqE81kguMQpKytDRkYGWrduDQ8PjzodazabkZaWhpiYmHNKTnWFJEkoLCx0cpACQFVVFQyGy9PKvW7dOkyYMAFbt24953O4+rzrIhvFikEgEGiSkpKCyMhIDBw4EJGRkUhJSamX844fPx4A0KdPH3Tt2hU5OTkYNWoUnnjiCQwePBhdunQBANx7773o0aMHOnfujJtvvhk5OTkAmPDs0aMHADbDDgkJwdSpUxEbG4vo6GisXr1afi9JklBUVAQAiIqKwowZM9CnTx+0bt0ar7zyirzfvn37cPXVV6Njx44YOXIkrrnmGvzwww9OY1+3bh26dOmCBx98ELGxsejRowd27twpv/7666/jqquuQqdOnXDPPffIhUOnT5+OCRMmAAA++eQTJCQk4O6770anTp3Qo0cPHD58WL43+/btQ9euXXHrrbfCarXiscceQ/v27dGlSxfExsairKysXj6HaqlDHbyLgvz8fAJA+fn5F3ooAkGToLS0lPbt20elpaW1PiYrK4t0Op2q+Jper69VAbbaAIAKCwvl5w888AB169ZNtS03N1f+PykpiR599FEiIkpNTaXY2FgiIsrIyCAA9O233xIR0U8//URt27bVfJ/IyEh66qmniIgoJyeH/Pz8yGw2ExFR9+7dacmSJUREtHXrVtLpdLRq1SqncaemphIASk1NJSKiZcuWUYcOHYiIaPXq1dS+fXs6e/YsERGNGTOGHnnkESJixT6fffZZIiL6+OOPyd/fnzIzM4mIaOLEiTR27FinayMi+vfff6l9+/ZksViIiCgvL0/+3xWuPu+6yEaxYhAIBE6kpaXBarWqtlksFqSnpzfYe951110q09LSpUvRo0cPdOrUCYsWLcKOHTs0j/P29sZtt90GAOjduzcOHTrk8j24byI0NBRt2rRBRkYGCgoKsGfPHowcORIAEBsbW23f8+joaDlp96677sKxY8dw/Phx/Prrr7jnnnvkPjIPP/wwfv31V81z9OvXD5GRkTWOuU2bNqisrMRDDz2ETz/9FJWVlTWXzK4HhGIQCAROxMTEOAkgvV6P6OjoBntPe6WwceNGzJs3Dz/99BN2796NOXPmuDSh2NvR9Xo9LBaLy/dw3LeqqgpEJLcQPlckSZLP47i9tuPQwt/fH3v37sXIkSNx4MABdO7cuUGVM0coBoFA4ITJZEJycrIcB6/X67FgwYJ6c0D7+vrK9nctzp49Cz8/PwQFBaGiogILFiyol/fVwt/fHx06dMAXX3wBgBXt3L17t8v909PTsWHDBgDA8uXLER4ejrCwMNxwww348ssvUVhYCABITk7G9ddfX6ex+Pn5qe5Lbm4uiouLMWjQILz22muIiorCvn376nqJdebydP0LBIIaSUxMREJCAtLT0xEdHV2vUUnPPvssBg4cCE9PT/z8889Orw8ZMgSfffYZ2rdvD5PJhD59+mDt2rX19v6OLF68GA8++CDeeustdOvWDV26dHHZs6Br16748ssv8cwzz4CI8Pnnn8tj3r17N3r37g1JktC5c2fMnz+/TuPo3Lkz2rVrh44dO6JNmzaYPn06xowZg8rKSlitVvTp0wdDhgw57+utCRGuKhBc4pxPuOrlQnFxMby8vCBJEvbt24f4+HgcPHgQgYGBqv3qI5y0oamPcFWxYhAIBJc9mzZtwnPPPScXGVy4cKGTUricEIpBIBBc9gwaNAiDBg2qcb/4+PgmvVqoL4TzWSAQCAQqhGIQCAQCgQqhGAQCgUCgQigGgUAgEKgQikEgEAgEKoRiEAgEFzXr1q3TTJKrLVOnTsWyZcvqcUQXPyJcVSAQXNSsW7cORUVFtQo3daSqqgovv/zyOR13KfeMECsGgUDQ6EiShOnTp6Nv375o27atXKcIANasWYPu3bujc+fO6N+/v1wbKC0tDX379kWXLl3QqVMnvPjii9ixYwc+/PBDLF68GF27dpWF/Nq1a9GvXz/Exsbi6quvlmsbrVu3Dl27dsUTTzyB3r17Y+XKlRg1ahTmzZsHACgqKsJDDz2Ejh07omPHjpgxY4Y8rvj4eLzwwgu47rrrkJCQ4HRNo0aNwvjx43HdddchMjISTz75JFJTUxEXF4eoqCjMmTNH3jctLQ033XQTevbsiS5duqhKZ1TXh6Jr16545JFH0KVLF1x11VUNllNx6ao8gUCgTUkJcOBAw52/fXvAy6vG3SRJwqZNm3D48GH06tUL/fr1g7u7O+69916kpqaiU6dOWLp0Ke666y7s2bMH8+bNw0033YQpU6YAAM6cOYOgoCCMHz8eRUVFePPNNwEAhw8fxowZM7BmzRr4+fkhPT0d/fv3R2ZmJgBg165dmDdvHubOnQsA+PHHH+UxzZw5ExUVFdi1axdKS0vRr18/dOjQAXfeeScAYMeOHVizZg2MRqPmNe3Zswe//fYbLBYLoqKiUFhYiHXr1iE7Oxvt2rXD2LFj4enpiZEjR2LJkiVo3749SkpKcM011+Caa65B9+7d8c477yAkJAQAMGvWLLz88suy4tq7dy8WLVqE+fPn48MPP8QLL7zQIDWkhGIQCC43DhwAYmMb7vzbtgHdu9e42+jRowGwngP9+vXDH3/8AV9fX3Tt2hWdOnUCwPonPProo8jOzkZcXByee+45FBcXo3///i4rl65Zswbp6emIi4tTbc/KygIAtG3bFv369dM89tdff8W7774LnU4Hb29v3H///fj1119lxXDfffe5VAoAMHToULi7uwMA2rVrhxtvvBE6nQ7h4eEIDAyE2WyG1WrF3r17MWLECPm4wsJC7Nu3D927d8fSpUuxZMkSlJeXo7S0FC1atJD3a9eundy9rnfv3rIyrG+EYhAILjfat2fCuyHPfw646mnAX7vjjjvQp08f/PLLL5g3bx7eeecdVRtPDhFh8ODBWLx4sdNrR48e1ewzbX9sdT0VqjsWcO6zoNV3QZIkhISEaDYe4n0oNm/ejNDQUHz//fcqH0ht+zicL0IxCASXG15etZrRNzQfffQRXnrpJWRmZmLjxo1477334OHhgcTEROzfvx9XXnklvvzyS5hMJrRo0QJpaWlo06YN7r//fvTq1Qt9+vQBwHoYHDt2TD7voEGDMGPGDOzZswcdO3YEAPz999/o1atXjWO64YYbsHDhQvTp0wclJSX47LPPMHny5Hq97nbt2sHLywuLFy/G/fffD4D1eAgKCmrUPhTVIRSDQCC4ILi7u6Nv377Izc3Fe++9h1atWgEAlixZgnvuuQcWiwUBAQH46quvAABff/01li5dCjc3NxARPvzwQwDA7bffjiVLlqBr16743//+h6lTp+Kzzz7D6NGjUVpaioqKCtlEUxMvvfQSHn/8cdmUdeedd2LYsGH1et0GgwGrVq3C008/jTfffBMWiwWhoaFYunRpo/ehcIXoxyAQXOI0xX4MkiShsLCwRtOMoO7URz8GEa4qEAgEAhXClCQQCBqdS8xQcckhVgwCgUAgUCEUg0BwmSBm6ZcH9fE5C1OSQHCJYzQaIUkScnNzERoaqpknILg0ICLk5uZCkqRqE/FqQigGgeASR6/Xw2QywWw2y2UhBJcukiTBZDJBr9ef8zmEYhAILgN8fHwQExODysrKCz2U8+bEiRM4cuQIIiMjVeUiBAyj0XheSgEQikEguGzQ6/XnLTAuNCkpKRg7diysVit0Oh2Sk5ORmJh4oYd1ySES3AQCwUWB2WxGZGQkrFarvE2v1yMzMxMmk+kCjuziQCS4CQSCJoXZbEZqairMZvM5nyMtLU2lFADAYrEgPT39fIcncEAoBoFAUO/YK4KUlBRERkZi4MCBiIyMREpKyjmdMyYmBjqdWmTp9XpER0fXx5AFdgjFIBAI6hV7RRAREYExY8bIM32r1Ypx48ad08rBZDIhOTlZ9pPo9XosWLBAmJEaAOFjEAgE9YaWH0CL1NRUxMfHn/N7pKenIzo6WiiFOlAX2SiikgQCQb2h5Qdw5HzNPyaTSSiEBkaYkgQCQb2h5QeQJEmYfy4yhGIQCAT1hpYfYOHChcjMzERqaioyMzNF3sFFgDAlCQSCeiUhIQGff/45JElC79695dWBWCVcPIgVg0AgqDd4RNLw4cMxYsSIC9KWUnD+iKgkgUBQL4jM5KaNyHwWCASNjshMvnQQikEgEJw3ZrMZubm5IjP5EkE4nwUCwXlhX/FUkiTodDpYrVYRmnoRIxSDQCA4Z8xms6wUANZBTJIkfPXVV6qIJMHFhTAlCQSCc0bLr2C1WhEaGiqUwkWMUAwCgeCcERVPL02EYhAIBOdMdRVP69KDoT76NQjqD6EYBALBOcGFeUJCArZs2YI5c+Zgy5YtSExMrFMPhvrq1yCoP0SCm0AgqDOOkUgAczzrdDrMmjULkyZNqlWim0iKazxEgptAIGgwtCKR+PzSarU6KQXAlui2ezdQUgKUlgK219MOHhRJcU0QEa4qEAjqRE09F6xWK3SSBKudMUKv0yEaAA4eBHQ6IDAQMBgQo9fLeQ/yvsJ5fcERKwaBQFAntCKR7NHr9Zg9aZLaIZ2UBNOVV8JcWorUnTth3rULOHECpmbNkPzqq9DbzqfX6bDg/fdrZ0YqL5dXHoL6RfgYBAJBnUlJScG4ceNgsVggSRIkAFYipgReew2Jw4fDnJ2N9MxMREdFwRQWhpRlyzB28mS2otDpkJyUhMThwwGA7Xv4MKKDg2GKiwM8PasfABGQkcFWHoGBDX/BlwB1kY1CMQgEgnPCnJaG9A0bEN22LWA0qpSA077Z2Yjs21dlMtLpdPhi7lz0iY1Vjjl1CmjXDvDxqf7Ny8qA//4DmjUDWrSoz8u6ZBE9nwUCQYNjCg6GqUsXIDSUPddQCJy0jAzNDOnhjz3mtHqAxVLzm5eVMVNSQYFQDA2A8DEIBIJzIz8fMBprtevW3btdvma1WjFuyhSYs7PZBjvF4DLxraSE7VdRAVRW1nnoguoRikEgENSdigqguBjw8KhxV3N2NibNnl3tPhaLBemZmfwJgGoS34iAoiLA25uNo7z8fK5EoIFQDAKBoO6UljKB7O5e465aZiRH9Ho9oqOiWChrZaVTroTVasW4cePYyqGsjD08PVlUklAM9Y5QDAKBoO4UFQGSxB41ENO6tVN4qyRJSoiqLZLJFBYG6PVARUX13eDKypj5yGgEDAampAT1ilAMAoGgblgszOnrIqTUnJ2N1M2bZZ+BKSwMyUlJqryGhbNmIXPTJqR+8QUyN25UHM86HVBRUX3VVnufgtHIlNSlFVx5wRFRSQKBoG6UlrKHRv6Aq1yFxOHDkRAX5xTS6hTJpNcDFgtM4eFITk6WcyVU3eBOnGAKBADc3NhYKipqZdZywmJh7ylQIfIYBAJB3Th5EjCbgZAQ1WatXAW9Xo/MjRurDWVVwc1E7dsDBgPMZjPS09MRHR2tZEObzSzfITCQrRROnwauuII5wonYX0cT19mzQGEhYDIpSqWsDMjOBsLCauVEl7Fa2fv7+WkfR1SziS0/nx3LlZnVqoyrgRB5DAKBoGEgYkJNY3au5WTm0Uaukt7SMjIQ07q18rpez5zJFgtgMMBkMjmXx7AXopLExnTmDFs16PXs4eXFFExQEPs/N5cphoAAJpArK5liyM9nrxuN7ByVlUBwsBIO6+nJop+4w9tgAHJy2P8VFUDLlsCRI2wsPj5s3+xs9j6SpITzuruzcVZUsG3Hj7Nx+PqycxUVseM9PAB/f6b8eH5GURFTQqWlTAl6eDBl1oCKRCgGgUBQe8rKmIDy9nZ6iTuZnQriRUU57euyPIbNlFRtkptjhJPBwGbw3PhhNDIfSHk5G6uHB/trsTDBWlXFQm29vNj1nDnDXj91iu1TXs6EMTcxhYQwpVJYyM7FfRpGI1uJnDnD/i8uZseXlrL3KC9nysGm5EDEHm5u7BwFBYpS8PAAsrKYcsjLYwqrooI9SktZEmFFBTvGYGCKR+MzqC+E81kgENSekhIm9DQS27SczHK0kR3m7GxZKQAOCW46HRP81SmGqiq1qSYggM3yQ0LYDNxoZDN9f38mrM+cYeO2F+SenkzIWq3stRMn2Kw+MJDtU1ys+FKOHmXb3N3Zc4OBCfK8PLZ6sFqZ0CZiyqZ5c/YaX2F4erL3dneXnesICGDCvqSE/e/nx1Yf3ExFxFYvbm5MWRQXszE0kj9ErBgEAkHtIGLCqZpsZ1dOZntqZXKqLu/B0R4vSUwAA8pfTkUF+xsUxF4rKWFKBGCC19fX2U9AxJSK47kAJvjt/y8sZOdzFNjNmrHzOG53NME5+GkQEMDe217xWa1McXl7s/Hm5TmPq54RikEgENSOkhLFFl4NprCwap3NtTI5VbdisDl3NX0Ujvj7q5/bO119fbWPqa0j2mBwXdn1fOz/jo5rnY6tQvT6RgvLFaYkgUBQO/LzmcB2WDFk//svDs6cidOffw788w8rh11Y6FKI1WhykiTXKwarFbBakfLNN4js2xcDR45EZN++SFm2rN4us0nSyCG1YsUgEAhqpqqKmTDsTSkAvli4EP1efRXttI5xd2emkpAQZk/n/4eFITEqCre/+CLyDh5Es6oq+BQUqI91tWIgYj6KadOcfBQJcXG1D4sVVItQDAJBbSgrY7NgW4npy47KSmavtzPFmLOz4fHqq5AAhAMoA9BSp8Pvc+cilDtR7R/79rG/OTlAVRWCAAT5+zPb+TffAHfdxUw/tnpJmhAh7ciROoXFCuqOUAwCQW04c0ZxNDZwIlKTpKqKmXHsTBppGRnoBeBjAMdt285YrdgbHIz43r1dnys/n93PFi1YxM7x40CfPsDGjcBNN7H7W1XFHo4OYKsVMSZTrcNiBefGZfgNFwjqSGUli8apqGDC6nKkqsrJZ9A2NBThAPbbbauVgPb3B1q3VmottWwJtG0LrF/Pnut0LAfAbHZeORDB1Lw5kl95pcawWMG5I1YMAkFNFBay+HW9nglIN7cLPaLGxzF3AEB4UREA4D9b7oGWgK5V5BCAwthYuK1Zg9zjx2EKCGBKiOcR2Du7bUliiXfeiYRrr0W62ewyLFZw7gjFIBBUBy+34ObGZq+XWbcws9mMtLQ0xPj4wOSYv5CeDgD49tdfkXbypJOAdpndDLXCWLthA5Z9+SV+JsJNffviiZkzkTh0qJL1ax9iarWyz2TNGphefhmmv/66PE17DYxQDAJBdRQXs9h9nlh0GZmSUlJS5GY5Op0OyVOnInHUKGWH9HQgPBzhbdogvE0b1bGuspsT4uKwdsMG+TXJtgpxI0IxgEFEGDd1KhJ69WIrh8JCFsPP4WUldu5k9Y9yckTP5wZAqFqBoDp42QSDQbF9XwZodlB7+WWlLzMAHDoEREdrHu8qu3nLtm0qhUFEICKUA9gMoDcAi9WK9CNHFHMSz15mB7DPg7cBdewFLagXhGIQCFxRUcGczjx2X69nYauXAZod1KxWpS8zwFYMLhSDVtc2vV4PAly2+cwBEAhAp9PB292d5TJUVKjvOT82I4P9FYqhQRCKQSBwRVERm7Hy6Bmjka0YauhffCmg2UFNp1MijsrKWHE5F4qBZzfzc0iShKTnn0ef2FjNNp86nQ4FAPzAFMc1o0bhjc8+Q+rWrTAfOqTsTMQUxtGj7LlQDA2CUAwCgRa2BC3z2bNKm0oelXQZ+BlMJhOSk5OVkFCdDguSkhTncmYmu0cuFAOH9wEjIkycNQtrN2xQlcPgr1mtVhQA4JWNrFYrnp8/HwPHj0dkjx5IWbSI78z6HVRWsigpoRgaBKEYBAKA+RKKi5XnJSVIWboUkYMHK/V4vvnmslEMAJCYmIjMzEykfvcdMletUvoyA3JEkivFYM7OxphJk2DfIJKIMG7yZCTExWHLN99A5xD+mg+2YnDEarVi3PjxMJvNTBllZbEXOnUSiqGBEIpBICBiZY2zs2UzkXn/fox95RW18/XFF9nK4TIKWTWZTIjv3Rsmx8if9HSWBe6iumhaRga0ugZzP0VRcTGsDq/nQ1kxOB1nsSA9PZ19VkeOsPDhnj0VJSGoV0S4qkDAE6mqqtjKwcsLabt3a9fjycqC6TJZMciUlTlX90xPZ32WXRDTujUkSXJSDvZ+CseyFgUA3G0Px9gvvV6P6OhophiysoDISPY4fpz5HBq5+uiljlgxCATFxUpXspwcID8fMc2ba0bVREdGXjYhqzLl5dqKoRr/giksDAtnzZLzFABAJ0myn0Kr9Pb9DzwAAPjtww/xxuTJav/GjBkwhYezFd3Ro0BUFGAysdVbTk79Xq9ArBgElzm8KxlvoXjmDKvHExGB5KQkjJsyBRaLRSn30LLlZROyCoAJ4spKdTE7iwU4fJhVQ7XDsfwF7+a2Zds2QJLQu3t3VWa0U7e3I0eATz9F33bt0HfwYIy49Vb2Wng4TP7+SkTY0aPAzTczxQAwP4MoiVGvCMUguLzhZiQfH5bAZjSy6p8hIdptKktKmICydRG75OHOdg8PWfC3NxoRVlGhWjG4Kn9hCgvDnTff7PL0qm5vp0+zv4WFzq+dOsXue1kZ8wXxFQPAFEPPnvV95Zc1QjEILm+4GYnPiHl/AJsZw6lNpV7PBBRv1H6pU1UFWCxIWbECY194AVarFbdIEr4HkO3nhwObN8PH29up/MVYW/RRnYrb8ZpItuJ8KiSJKfCMDLZqiIpiiYfBwSIyqQEQikFw+WJvRrJHqwk8x2hkq4bLpcpqVRXMx4/LSgEA2hGhEED40KEgQNPJbLVa8e7HH+ONKVNq/168l7RjNzeAdYMrKGD1qgAlGspkEpFJDYBwPgsuX0pLYc7IQOrOnTBnZ8Ocna0ks7lCp2M2dhchq2azGampqSzm/lKgqgppWVmq6KErARwAwFWBVlgqALy9aBHMhw+zshY1ZYuXlbGVGiCbklS4u7N9+GrCw4P9NZnEiqEBECsGwWVLSnIyxj77rKrKJxE5lYjWRCNk1akaaXIyEhMTG2r4jUNVFWJatVKFll4JYF8tDrVYrdiyYwfuDAlROsABzCxkr0z0eqZoPTzYw86UJDu0o6Jg4soBYIoCYIph9+7zv06BCrFiEFyWmLOyZKUAKFU+AaVEtMuVg06nrvgJF9VIx427+FcOZWUwhYerQks7QN21DVDqHTkyYsIEpGzeDLRrx5zVUVEsgigqinVxa9UKCApipiGrlZmTbCuGlGXLENm3L8s879cPKStXMj8DoF4x8FwGQb0hFIPgsiRtzx6XVT4Bpbk8AGcTk16vCCh+Pq1qpDxb92LGltyWOHw4MjduxPevvAJ/OCuG15OSkJyc7KQcrFYrxj36KMxnzjDHfnAwUwzBwUwhNGsGRESw16qqmAO6qEi7n8Nrr+H0yZPsxPaKoaoKmD0b2LKFfS7z5wP//KMMgojlXWRlAS+8oJgBy8qAn35irxUXK6sRImDPHqdWpi7vz8mTSjlwLRzPQwTs26dtMgPY+BxzZaxW9l6ujqlnhClJcFnio9dDJ0lOZRk4vHexfRimJEl4dswYPDliBExubqqQVV6N1KlBfQ1F5po0VqsqYssUFgZT69YAlHaeOknCrAkTMGHiRACAr68vhjuY4OwVZFpaGmJiYlT/m0wmxeFvWzFo9nOwWpF7/DiCAcWU1KoV+5uczB49eypK4b77gMmTgQkTgNWrlRNt3Qr07g38+y+wa5ey3c0NGDoU6NABmD4dGD6cKa2uXYHvvmP3w92dfeZhYSyX47ffmEO8eXOmpAYOZNV4jx4F1q1TMrX1euDee9nrS5cCa9YAbdoA99zD/rdYmILx9WXhuH5+wLBh7D06dgQ++ohtB4A77wQWLqz751kX6BIjPz+fAFB+fv6FHsolQVZWFv3++++UlZV1oYdSbyxauJB0Oh2B+U8JAEmSRDpJIgCk1+tp0ezZlLVli9N+AEin09Gi6dOJysvZCS0Worw8WpSURHrb/nqdjhbNn39hL/R8KS8n2rWL6OBBosxM9pgxg8jNjbL++INSv/iCsn7+mejQIfmQrKwsp3um1+vpjTfekLdLkkSS7V7rdDpatGgRUWEh0bZtRH37Et10k+a91+t0dObRR4mMRmU8+/fznm5EPj5Ebm5E779P9PjjynajkejKK5Xn9o/rr1f+HzFC/ZqPD5Gvr/MxERHK/126KP/r9eyvwUDk7090221EAwYQ/e9/6uP1eqJRo5TnISHKMXy8AJFOpz7u1lvZ+w0Zwu5XHamLbJSIarNeungoKCiAv78/8vPz4WffK7YulJayj4I3aCksZLOA8nIWOVFVxezMWr1mjx9ns4qgIKXMAqB8vNnZbFZkMChRGPw9eeNzX1/n8/KPKS+PjcXDQx1/XxNFRWzWwnsL1CJB66J0phYXswS1li01XzabzYiMjFTNRnU6Hf5cuRJhzZqpktlSN2/GwJEjNc+j1+mQuWcPTM2bs+SroiJAp4O5sJA1qA8MhOnaa9Wf8cVGeTlw8CD7HfDv8UsvAX/9Bfz8M3t+9iwQGgqEh8uHpaSkYNy4cXLGeFJSEiZNmuTSdKfX65F54ABMJSXAc8+x9/30U6QsW6bOPH/+eSSWl7PZsr3D+fhx5fdWWamEsm7bxrrMde/O/Bt797JVgacnu64rrmC+jmPHgG+/BR55BNixg32e117LfmNWK1ttGI3ANdewY93c2EqhbVu2Ytm1i12/jw97fx52a09+PvDjjyyCavRoNt7Ro4H9+4GNG9nYi4uB//4DevVix/DS4keOsOO7d1d6kLdrV+fvVl1ko1AMjlitzOZYVcV+EDx+2t2d/fhDQ5VYajc3ICCAfRErKtgHlpPDPsyQEPZhcqdaSQn7wpw8yV43GJgCcHNj58zMZDZEnY4tS41Gdk43N/Y3J4dtO3uWnadFC3auwEB2Pj8/9gPx82Pnzc1l/1ssbBwlJewaQkPZ2HNy2PsYDCzj1MeHHSdJQGUlzJmZiGzf3sk0kpmZyZb+TZUTJ9j1tm2rqfhSU1MxcOBA5+1ffIH43r1V28zZ2Yjs29elQEv9+GPEd+rEPiO7pDgA7J62bastJC4WSkuZoPL1ZddGxEwt4eHMjg+w62zVSvle2TCbzUhPT0d0dDTS0tI077k9qb/+iviwMODFF5kg/OYbdp7sbEVZW63MDPP112ofwsWKLXlQNovVBp5707ZtgyoG4WNwJC+PrRAqKtiD18/x9FRqwROxD7OkhCmNggJ2TFkZm2VUVLBtp0+zWYBez7aVlrLZkI8PE162WSZKS9l+hYVMUHNBVFjIPnw3NzYGNzf2Iy0oYOc8fZqNpaSEKbH8fHb+kyfZWPgqpLiYnTMoiP3Q3d3ZuUtL2fvx8wUGMmWSm4u0v/5y6UxtsorBamWfn9XKHhoVN2Oio518ATr7zmR28EJv9k5Qjl6nQ3REBHOiulp51XXOZbVqr0IvFPw+8utbsADYuRMZ0dEwZmezrGYizftsMplU3xPHe26PXq9HdLt27Hvs7a1ysKoyz48dQ8GpUzACOJ2dDRQUIC07GzHt2tUtw7qpYDDUfsXfyDT4t3D+/Plo3bo1PDw8EBsbiz/++KPa/devX4/Y2Fh4eHigTZs2+PDDDxt6iGoKCtjMPDiYLeVOnWIRE3xbaCiLpPD3Z4K2spIJYauVrRJ8fdkqoqiI7efuzn7soaHsiy9JTIiHhDBBbDSy97BamUPLy4spgYICdkxVFRN2Hh7sGHd39h6nTrH3P3uWzTqqqtiYCgrYmPR69hrAVhdBQYoC0OvZuSSJKZLQUHZsfj4rOVBRgZhmzbSrizZlZ2pZGXtYLC4jRExBQUh+8UVV1U8iwtoNGzT3Txw+HEc2bcL4kSPl+6HX61mV0CuuqF4p1EUx8HaV9s2CLjQ80sZ23Wc++QQ7AHResYI1Llq2jO1Xg3Bz7AZnH9qq1+uxYMECpkS8vNhDK/MZQMqqVfjoq6+QkZuLiD59EDF4MAaOGqUei6BeaFB1tWzZMjz11FOYP38++vbtiwULFmDIkCHYt28fIiIinPbPyMjAjTfeiDFjxuCzzz7Dpk2b8MgjjyA0NBR33HFHQw5Vgf+Y3d2ZYK/JFi9J7IscFKTsxwUvoC6b0KyZ8j+32fr5sdUEX076+LAfB/9BBgQoZiCOhwcT9pLEzEGSpLw3D+NzxN2dvcaLxdmPAWA/brumK6bKSiS/+SbGPfecYuPlP+CmSkkJu5ceHkzQ2l+f3T4JvXqpyjgQEcZNmeKyts/aDRuQ/OWXcmRS0vPPq5LfeBKWj7c3Mo4eBSQJfVq3ZoqjLmMvLnbZ+OaCYLdaOPHXX2hx4gQeAlBke23clClI+OEHmNq3r/FUiYmJSEhIkM1LAOT/5e+Uhwf7PXBTrR3m7GyMff11zANQCnW2Nc87qXNtJoFLGlQxzJkzB4mJiRg9ejQA4J133sHatWvxwQcfICkpyWn/Dz/8EBEREXjnnXcAAFdeeSW2bt2KN998s/EUgyM1VdAMCFBMMudyLklytjE6Ora5E1zrXLU1PXA/RG1xd0fiTTchYdgwpB86pP4BN1Xy89m9dLVisNln006e1DaTZWY6CRYeT8/PR0SY/PrruPvWW2EKC1OFs9ojSRIWvvMOEp94onZjLylxyo244Fit8kSp+JtvUARgrd3LFosF6ceOwVRLc4ijecnp+2QwsO9oeTm7FzxQApDDVz0BaBU9d/X5Cc6NBjMlVVRUYNu2bRg0aJBq+6BBg7B582bNY7Zs2eK0f0JCArZu3YrKptpOkTuRLzVs5QdMoaGIj49v+kqhvJzNuD09mTDTyoQtKQFKShDTtq22mUzDz5CWkQEPqxUZAB6wbeNCyDEJyx4iwrinn6595nNhoWLTbyrYlII5OxveO3diHdRCWe7GVl/d04xGNtECVKsGc3Y2ck+fhk6ngyfYisERV5+f4NxoMMVw6tQpWCwWNG/eXLW9efPmOHHihOYxJ06c0Ny/qqoKp06d0jymvLwcBQUFqoegHnBzY76KpjaLdUVpqWKSq04xWCwwtWrl1D1swWuvac42Y1q3xsOShAgAfWzbuBDSSsKyx2K11i7zmWe6NjXFYLUi5bvvENm3LwoOHMB/YF3YANs9mz6ddVWrL8VgMDCTLACcPQtzdjaee/VVRPbti+GPPw4igheYYpAkST0WF5+f4NxocJe45GA+ISKnbTXtr7Wdk5SUhBkzZpznKAWa6HRNz+7tCh79xdESsPn5ss9HswmPBqbAQLzs7Q0UFeFKOAuhaqNtdLraOet5BJx9RFoTwGw2Y+yrr4KsVkQCOAwAkoSv5s1j3di8vdksv74aFul08ndt9cqVuHnRIpUvgYjgAaB9t244Ons24O6OLZs3g3x90Sc2tn7GIADQgCuGkJAQ6PV6p9VBTk6O06qA06JFC839DQYDgoODNY+ZPHky8vPz5UeWqM1ef3h4MBNHUy9QZrGwAADueJck5zFXVbFZuV0wgCksDPG9e1c/0/zyS3iVlqL4xhtxjY8PMv/4Q3Y8O/YttkeSJCx4883ameB4WWq9vknd67T0dFitVoQBcAeQCeboDQ0KYvesrjH4NSFJsinpEwelwPEAYPTxAYjw7uLFGDFlCoY/9piITKpnGkwxuLm5ITY2Fr/88otq+y+//II+ffpoHtO7d2+n/X/++Wf06NEDRq0IEwDu7u7w8/NTPQT1hLu70k6xKcPDVLmQsiXpqaisrHWmOC+at3XrVpTNnYviG26A9803w1hUxGok2ZE4fDi2fPONbNbgSAAS4uJqN/7SUiXgoAn50mIiI6HT6RBle54JB1t+QygGPz+QJCHQRaivJ4CThYWIGDwYb6akyLWuaqyIK6gTDZrH8Mwzz2DRokX46KOPsH//fjz99NM4evQoxo8fD4DN9u+//355//Hjx+PIkSN45plnsH//fnz00UdISUnBhAkTGnKYAjhXEDVnZyP1r79gPnas6SsGHoXEZ+68vr89tVQM9qWeFw4bBrczZ9BjzRqssPkKcv76y6mZT1FxsVMxPisR0g8frt34i4oUk4xGn4cLhalZMyS/9BLa2JSeWadT2/Ilqf78CwBTjHo9rH5+6AAgyOFlvU6HqJAQrNuxQ3M1YV8RV3B+NKiPYfjw4Th9+jRefvllZGdno2PHjli9ejUiIyMBANnZ2Th69Ki8f+vWrbF69Wo8/fTTeP/999GyZUvMnTv3woWqXiY4NnK/7/bbsWTlSqVG0quvInHSpAs9TNc42uW1Zt61mInbRxkZAEwC8DVYt7KRc+agVJIw/bHH8IFDM5+Y1q2dK6vyzOiaqKxkpiSjkf3fhFYMsFiQ+L//YdiJE6hcuhR7fvlFVgrm7Gyk7dyJGA8PmIIcRbgas9msrqTqCls+jj4wEE/m5yMKwFAwP84zo0fjyQcfhPdtt2lGJQEiMqk+afDM50ceeQSZmZkoLy/Htm3bEGe3vP7kk0+wbt061f79+/fHv//+i/LycmRkZMirC0HDoFX3/tMVK9R18F94AeaMjAs5zOqxL9sAMMVQVaXOPC4vdz27zcoCHnoIGbt3y9d9D4DWAF6x7VIB4D8itNMwXTj6GvR6PRa89BJM9gmNrigvV2pi2UpZ17mURkNhsQA6Hfzz8mBs00ZWCvKqavx4RHbqhJSUFPkQx9amKSkpiIyMxMCBAxEZGanaVxOdjmXhA7jF0xPrlizBkU2b8MaUKTCFhcHNakWZhrNb77iaEZwXTagwi+BCUFPIJWALu9xXm2aOFwhHYcqduPbXVVzs2oy0ciXw++/o/Pff0Ol00AGYAmAlgD12u+0H617GsTdd8EY2qV98gcyNG5F4xx21cyRXVLCxcx/DhQpZ1TIXWixM4ZrNrNcAtCcSvFOdoxJ444036t7VTqdDqS2IQFdaiv7u7iphr6+owI0JCdDb8lB0Oh0mPPAAMjdtqr4Vq6BONM0KToJGQ8sM4ohep0N0bWa/Fwq7RKy0jAzEmEww+fszwabXs9UDN9do8dtvgF4P/6+/xsfTp+PnadPQlgh32+0igSmG++22OZouVAXfiopqJ+B5RV2ACeFqCgA2GFVVrBx88+ZKlr19nSSzGbjqKgDaEwmLxYItW7Y4KQGtUts1FWJMWb4c7n/9hXttz7cvWIBuvAw1AJSXo1ePHsh85hmkA6y8uUM5F8H5I1YMlzlaZpAH7rhDbRaZMQMmL6+mZf+2x2JByvffK/2B4+OR8s03yoy9OsdzTg6wcyfwzDOg4mJ0/ecfzA0Jwc7mzbGDJ1DpdFg4ezb6DB8OEwBf1CKpyrHhvRZETIHwSCe9/sKsGKqqlMq/HL4KI2Ll3G2CfKt9HwQber0eROSkBLiPynFfV7kdZrMZY194AXydVQig7LffFEc/kRxybAoPR/zAgTBFRDSpEN9LBbFiEGgme70yYYLyvEULpRlNE5yZmbOyMPaVV9Qmi5kzkXD33TC1a1e9YkhNBXQ6fObpidKqKjywahXcANwEwAqWj5A0cSIzU3ToACxbhtSZM9H8+uurt2fz2X91RRh5xjMP+dTpqu8d3FBYLEp9Iv75cgV1+jQbp8kEc3Y2Js2e7XT4rFmz0KdPH83WprNmzcKkSZNqVYiR983ma6VvwHw9W/btY/eaKy6jUakS3Jgrq8sIsWIQAHBO9lI9lyT2Y9SoetkU4IlY9qjKUVS30vn1V5R37Ij7Z85EEtgP4lcAf9pe5kXzzNnZrOMXgFibDdwxbFUFXzFUJ+TtHc/AhfMx8LLtRUXKKoeP/dgxAMBfp05h87ZtmibHHj16OJXW5kpgwoQJyMzMRGpqKjIzM6vtAMj7ZnNR/wXYzPXK3FyYs7PxBy+N7uammAWFYmgQhGIQ1A4vL6W5TxMjplUrZ5OFTodoW1g0Kiq0q9CWlQEbN8LcoQOICBkAbgXwkMNuspPZywsID8euH35QzFa2jFvHPBBZMRCxe1ZWxhSUvXmpokLZl/+9UIqBiI2Rj8k2hvXffgsAGPj88xjx+ONOpWnsTUOJiYmaSsBkMtWqEKPJZELym29im+09tut0KAgORo6tXtPwsWMBAD//84/a/FZfJTkEMsKUJKgV5tOnkbZzJ3xOnECR0VhzTHojYmrWDMnTpmHcyy8rJovJk5kJDJBDVWXndOvWbCW0ZQtQWgrvW2+FtGwZiAg/aZzf3smc17w5jqxfDy66rVYrxkyaBEmSlLyPpCQkDh3KhGtZGQuHrahgQszDg/UZNhhcR0o1hGKwWJhZKCTEWUlWVSlJgdy0ZbXCnJ2N35Yvx5UASgDAVudMr9PBYrVqmoYcS2vXlcR774W5bVv8eegQtvXqBd3rr0O/ciWsYFnPAPDGsmXoMHEiex+uGJpa97uLHKEYBDWi1XNAp9MhOTm5WtNAo2AzeSQOG4aEQYMUv4ibm5JFXFGBlG+/xdgZM9TCe9cuICICLXr3xsJZszBm0iSnjFq9Xo+k559HWkYGvvz+e+j//Rc3Ow2B5OPkpjG9e7PIKFupbwQEKOaaykomxEpKtCOlGkIxlJUpLWody8Tz8Vitih2fCGmZmYgkQqbDtX7x3nsINRgQfe21MHXogHpFkmBq0QKmjh0BAHsiI9ERQCsoiqGIiPVe6NpVzpbmOReC+kEoBkG1uOo5wGPSExISLuzKwWplQsFgUIeL5uUxgWexsGgXm1KQxz55Mh4ICYHhppsASZId8Fu2bQMkCVEmE4pLSrB11y5MnD1bPnY0gCfAisqVa40HNtPT0aMwdeokt3M15+ay1Yq/v9IStKLCuQkTn/3WN1wpFRY6KwbbasZ86hTS/vsPMddeC5O/P2IiImAFVIpBr9ezyqru7kBtMrvrioNwDxwyBJZ33sENAHbZtlVKEqLbtOEDYse46tgnOCeEYhBUS3UJcDXFpNcKnljlqiVpTfBENkc7My+LUVWFtMOHna6ho9UKQ04Ocrt2xZ7Nm2Xz0p03K+sBc3Y2rrvnHtWx+wDoAbQFwAM37duEAnamJ1t45Zuff46Jc+bAyktpvPMOEh94gI2vsVYMVVXs/c6eZT2+7d9Xa0X1zjtI7NMHfkFBWHD2LECkhOg2a8aUTEM0snf4HMPbtUNOq1a4wWzGf7Z7PGn8eNYHAlAik5pKtvglglh7CaqFJ8BpUV1Meq0pKGAmjnOFh4Q6RqdwxWCxaDqnb5UklLm5odVTT6mcyPZoKcX9tr9XQmkW46gUFrz2GkwtWwJWK95YsADPvfWWugro00+zEiOunKYNEZfPfQdlZcy3Yfdemiuqp5+G+fhx+BUUYPSECUpG9/DhSuJgQ0QE2fcvt9Hs1ltxp78/5tnqdQ278UZ1a9smVq78UkAoBkG1uOo5UFNMeq3hWcnnCjclOSovLiwqKmAKCXG6hpuJ8H1FBcqrKduspRTPAjgJpTSGfVVVnU6HLd98w4SnJMF84gQm2vqX22OxWJC+f7/2jJubReqbsjL2fgYDWzUog3GZzZy1dy9QVYXADh3UfSsaWjE4zv779YM+Lw9d+OrS3V2tPAyG2t+z8vImVcG2qSIUQ2NSWcmW4PVBcTErY9AI2NcB+vu775C6aBEy169H4kOOgZ3nwPkqBm5KclQM3JlqOzfvmyBJEloA6AVgldOp1GWbtbLCX588Ge5XXomHunVTrRSCAQyzWmF65x2gb19g8mSkZWZqlofW8RIjbm7OYa68AGB9wjOGjUbmfC4sVEx4LlZUer0eV/BtrVqpz2fz6TSIs1frnN27s3H/9ht77uamVgxubmrzW2UlW4VqmeTOngVyc9XbystZd7+6whtE8c+4rt/jcldeKhecPl1/8qMGhI/BkbVr2RfKaAQyM4GjR9kP6b77gDVrgL//Bg4cYHba114Drr0WOHwY2L6dZdHm5bEvyy23sBmVlxc7R0gIsHo1kJYGJCcrguvMGeCrrwAfH+CPP4CYGKBHD6B/fzaeNm2ARx8FgoPZa5WVTPBMmcKOHTGC7V9WBvz+OzBnDnDkCPDDD0BiIjB3Loujv+EG9gNLSwPWr2fXdO+9QKtW+OfAAfzx99+4tlcv9OzSRfO2qBy7lZVMMZWWOjtP64rF4lq41wbHH//Bg0yQcWFh9+PbumsXiAg3AbAAWO1wKh1vbm+HZgvQo0dRtWYN4gEMAnADgO5gs6zKzEz23dm/HzEPPKBZh2r2s8/CFByMlJUrMfbFF9WRUkOG1P+KgWd+u7uzR0EBEzAeHkBlJUzBwUhOSsK4KVNYuK9OhwVvvIFmvH86t+dz6rtBjz1a5jV3d6BXL/a9BZz9UW5uSkmP4GAm/H19mbD38WEBAPw4T0+2r8XC9uO5JW5u7Lfr4cH+t/UHh5cX+x7ZXy//zvKugadPs/0KClj0mX3nQ36uykq2j61yLAoK2PbgYLW/x2plr+n17Br4d+fUKXauwsJz98fVAYm0pjQXMQUFBfD390d+fn7du7l98QUwcuS5v7nBwL7YXboAW7c6vx4ayr4M9jbe2hAWxr5QBw6oz1VZ6ZyNHBCg3qa1NHdzYw/b7MMMYKPt0eraazFx4kSgffvqnYu5uSwq5XyL66WnM6XWrt25RZWcOQNkZDDFW1YGdO0KTJoE3H8/uw/+/kBBAVJ+/hmjJ04EAHwL1gTGsb+aJElYOGtWjVU6z86di8A5cwAws9KvAH6x/Z0xezYS9+9nORJr1yJl2TJZ4Op0Osx69lk8N2oUzBkZiLz1VqcSEplr18LUqhXQtm3d74UrSkqA//4D/PyYwCkoYIIuOpoJx8xMICQE5uxspKelIbpFC1ZK5LXXgBUrnL/Lp08zZeGiRe95UVzMxhoYqFYSSUnAggXse7t5Mxs7F7KnT7NjgoKYAA0OZr+D48eVUihcIQYHs+89N4dZrey9ysuVHuf8GE9Pdu/4b8VoZPvwhEk3N/bbzM9n7xsSwv43GNi5uTzg71NWxs7JOw4GBLC//PWKCjauwEA2hpIStr2qio3bw4N9393dWS6Mt3edbm1dZKNYMdgTFwc8+yyriRMSwr5o//7LlrCdOgEPPQT8+CP7v2VL4M8/gRdfZB9Sbi4waxab4fv5sS/ql1+ylUNoKPtgPT3ZfikpbPbv789KDtx6K/tCpqUBEyawR1gYUwTHjwPjxrH3y81l505PZ0K5pAT46SegWzc2G1myhP1IVq9mgtHfHxg8mH2B161jX8KOHYEOHbD4p5/w1fTpCAJwFYBrAcwB4PbHH8AffyB/3Dj4T57s+l55erIvaXDw+dma+WrhXMMN7SOSdu8GyspQkJGBbX/+yUJDfXxgzs3FWNu1eAC4HsAMjVMREctBiIurtg7SnvbtsRSsbMYuAPZqd9yUKbhz5Ej42TLEnVYcwcFAaSnSzGbtyqNZWSziproaS3WlqkoRhIAyuy0pYbNn23ZTWBhLCjxzRqm46rha4DRERBLABC4P2bX/Xvn4qP86+hi8vZUVQWgo++0WFbHrMBrZ76asTNnPamXXbjCw39rJk+y1wED2W+Sr/eJitu3ECXYeXgGAK4zQUHZuSVJm8uXlbJzNmyt9NsrKWJXa0lI2xubNmSLIz2cKwmJh2w0GJnuMRvY+xcXs0awZOycR++vpiYZEKAZ7wsOZ2aawUJmNtGoF3Habss+ttyr/9+/PlrdaJpC2bYGpU523h4ayGa0jgYGsguW2bcq2+Hj1Pnx2bkv+gZ8f8OCDyuszZ7K/ZWXOy82YGPlfc3Y2Hnz5ZajFEhOaYQCSAPRYsADLW7dG4ogRzmMF2A8kL4/9QBzj4msLL//Al+bngv1x//wDAPj800/x8KefMvPMjBloYzLJQngAAG84+xeU0zE/Q3WKoXWnTljoolS5xWLB6bIyWTEADmY4m0CKadNGs+hcdFRUzcX36opjrSiDgb1HURH7/OyFvH2NJx7a6ohWFFh9waOSHFe5fHaspRj8/IDWrZVe39wH0bIle+7jw56XlTGFwWfthYXse+zlxSZ3Wvc7JEQR+tycFBzMzLU+PooCiYlRxp2fz/a1F97e3ky+VFay7R4eTElUVDAlwfMxPDyUcXh6ss8hL48pD53O9TjrGeF8Pl+aYrZlDTZIV7kJZQAyAKQAuALAu9U1V+c+kvOxh9eHYuBZuwBKN24EAPD6r1arFeOmTYOPr6/sXL0FwCEA/0kSVqWkaIbibt21y9kpbIcpLAz33X675nD0ej0CW7Rw3Sdbp4O5sBBpJ09i9sSJimNbp8OCV19lCqS+6yVVVjoLEy8vtjLQyqUwGtmst7jYWelzgd1QKwZXioErBE9P55BWSWLj9PFhs3++L7fpc6HbqpUirD08mNLjCseVsOXb7X0MRiNbsdub0uzrXQUEaM/ofXzYBJD/Pj092Zj8/Ng4+LXZo9MxZWbfs6MRaIJSTdDQVJebAAB/gCmJAVZr9c3VJen8FAOfmZ6PgqmqkpWUYccOAOom8harFcUVFSy6SKfDzQB+kCQkz5qFm6+7DrNsfgd7np81y6lInj3m7GwsWbnS6TjeXjKgWTNQSYmmYklZtgyRCQkYeN99mDh7NpKefx6pX3yB/EGDkPjaaw1TepuHqtrDnbBa5ch9fBQzBheynIoKxYbeEHCh73j9jgrKlYD09m4c4ekYGXWuNIIj+VwQiuEyxDEMU5Ik3HzdddDZvuhlADaD2eKrba5+vgLMvhnMuSoG7gj87z8YS0pwAGrFoNfpEN26NRKHD8exjz5CKwAj331XdjD36NTJ6ZT2TWe08htcrbi+mDsXicOHY/3u3ZAsFgxyUCxabTEnv/46oqOi4L1mDbP710IxOPZVrnY7r5rqKPwlSXGkOr6m1zOzZUmJWjHwKDqdruF9DK5WDNzEJiqqNihCMVym2OcmHN28GatSUpA8a5asLH6XJCS4u8MUEuL6JDy7+FzhisFF7L4rASjDBahez/wLBgOq+vaVFYNjl7XmO3cCvr4IHTxYPkVNqyfAOb9B6xi9Xo/esbEwZ2dj/tdfAwC8oFYsrhLJDttHm9VQejslOVnVVzklJYVtd+i3zLfLqzGtGb6/v+JLc0SvBwoLkQ+7vhPcqerm1vArBkfsFZRQDA2OUAyXMY7NeeyVxeMLF8KtvBzYtcv1CXg/5XOFC0Cj0Sk5yEnQLVqkfTzPet66FejYER3790ekt7dSwsHeef7bbyzyjNfyh/PqSafTafcccOjt7Jj4xhVQWkYGimyzXZ7hwRWLK4XS3v7aeZSWRhS52WzG2IcfVq9mxo3DP//8gzFjxqi2jx07linU6nJE9HrX+QhEsBYUYMqHHyomtS+/VKqzNpRvja9kHK/f3pQklEKDIxSDwAkiQmX79uzHaHPoasIrhJ4rXDHo9arzmM1mp8by48aPd1452BfQ27OH5Y8EBEBXXIz4Hj3UkUU5OUzJXX89ew8757K9QjyyaRMW2q2cZKHfooVqdWR/jFxDCGw1UWYTXFwxcMXiSqE0s8vE/SM1FeYTJzRXDLz1pfoWWPDDqlVOGdZWqxVbtmxxqRiqc64DgDkzEzqrFfn2JUNmzoS5pIRF+zQU9uGq9ghTUqMiFINAJmXZMsXpGheHzIgIYNMm1wecb/Ey+wiXqir5uSsBKLfqVDbKReCsGRk4Gxam9Cy2rwcEABs2MGESH6++TpsPwH71pCn08/Kciv05rrj4ticfeQQAUwyO5izNcx88KB8/atw4RN5yC1I++cTpdsVccYVmp7oWrsxBgFr52tC6fkcybeatArttFqsV6bZWnw0Kj3izx9EJLhRDgyIUgwAA8M/OnRg7aZJqlj5n3z7Qv/+6ztTmBd/O1QHNj+PnsSkZ3vvXHr1Op9Tg51RVIWXFCtx2/fXQWa24afZsrPr3X/aaTYjzmXHBzp1AeDj+OXrU6TodncuAg9AvK1Ni2WvhU7n1llsAAJ/MnKlaTWieG0D59u3gXgZ/Pqann3ZaIZm8vZE8ZQr0tnuj1+ux4KWXcEuvXk7mL0mS0Lt3b6ey5FoOcK3rjw4OBgDYVxDS63SIbt++xus/b4xG5+8UL73Ck8mEYmhQhGIQIGXZMlw9dKiqUigA/EwEqaqK1YdywJydjdS//4b5+PFzXzVYrTCfPInUf/5RncfUogWSp01TBKBOhwUvvAATXw3wMWRmYuxrr+Eq27h3E+G5BQvYi2fOqGbGPy9Zgr3l5ZrX6ehcVkHEQjd5NmptnO22EMTYK66oNlEOAFBWBuOBA3JLUT73d1ohlZUBJ04gccQIZG7apKw4HngAJi8vLHznHVmZ6nQ6LFy4kFW+dRCwrhzgjtffwnYNxfafwcsvw1RdlFp9YTA4+xh0OuDNN4G33xaKoREQmc+XOXwGqVUyK12nQ1VwMAybNwMDBsjb7Vt9SpKE2a++iueqK5/hgpTFizH22WeVInLz5iHx4YeB8nIk3nILEq67DulZWUqrTofuY9zk1BnAYQBFAE7YhN7pQ4cwdto0WQheAWBjbi6cr9LZuayisJDFxvPaVAUF2vvZw5ObXCW52bN7N3RVVfhJkvA0EQLsx8R7XRCxkg1lZUBICEw+PmqF4+6OxEGDkHDoECu9ER2tlEN3UNrcAa6ZcW2PrY7WqmXLcLCqCtHBwTDZZc83KForBgAYNozdg6oqoRgaGLFiuMxxFZOv0+mwICkJhmuvVTmgHU0RRITnp0zBm2++Waf3NZvNslIAbCaNxx9n5pPycsBigclkUkwuXl5KNUwbMeHh0Ol06ASlm1o+gAoAG9asUV3XFWAZz5rX+dprMPEaOPbwkuAtWrBIJi+v2kVh8aQlu7IYLvnnH8DHByNt5Uz8YZudv/46TCYTC9ldtQrmfftch5b6+ABFRTB5eSE+Pl7dI8NBMVQXUaXCdi/C2rRhn0FISOMlY9WmI5tQDA2KUAyXOVohlDqdDn+uXMls4/37A/v3A1lZAFwrkokTJ7rON9CgWgdzSQnMp06po2Z4bRm7evSmwEAkT5uGqwDssTvPKQC7Nm2SrysEgB8AB9e1cp133cUUTnm5eqaan69U6gSYcnAQWJrRPXzFUI1i4MeVbtwIdOuGUffeC6uHB1687z5krlmDxP/9TwnZve02RN58M1K++Ub7ZJLEVjW5uc41/quqnHIOXEVU2XPG9lma+f3mYcWNgVa4KkdEJTUKQjFc5mjNIJOTkpS+DDfcwISOTSjFtG7t5OgE2IzfKWqoGjQdzHo9oq+4AimffILIm25SR81IEhNMvKS4xQJUVSHxzjvRUqeDvUrKBVMGz4weDZ1Ohyts2+1XDHpb/4OeXbowYermxq6TO9p55c1mzRQhxBO7bLNwl9E9RiPbz4Vi4MddN3IkSjdvxjbbTFzn58dMNuHhzH/iGLJbXe0qLy/2fqdPq7dXVMCcm+ukvLQiquzHN/2VV1AGIHLAAOW6Girb2ZHqciSEYmgUhGIQVD+D9PICbrwRWL4csFphCgvDbI3qsHXt/2wymZD86qtqB/MbbwDl5SrfgEogcnMPr/FTVQWUlUFntSLPTlDkAmgmSXjywQfxxdy54KM6bPf+vHwFAKYYvL2Vng688mjz5upGRG5usgO62ugeSVIqeDpgf9yVYOU7Jv/2GzvOz09u0pJ2+HCtnMQqfH1ZXwDemAZAyuefI3Lw4GpDU7FyJfJffRWpmzez6LTJk+FLhAL768rJabhsZ0eqe5/6rDorcIlQDAIA1c8gMWwYMyXZylo/N24c3pg8WZ7xn2v/58Rhw5C5di1TSD/9hMRhw5C2f79rgejmxmz+vJlKVZU8w7//oYfkVc8pSULf1q1hCgtDn9hYREsSToI5p/l4e8fGKm9QWcmEsr8/E+inTrHntpBNGYOBjaGysuboHm76csD+uL4AqgBs5sUKfX2Z4jMaZf+JPdU6yfl7VlWxVQMRzFlZGPvSS9WuOszZ2djzzjuwLlyI60aORK/bboPVaoUflBwGi8WC9OPHxYrhMkIoBoFLZPt5q1aszPDy5fJrE8aNw5FNm5D64YfI3LoViYmJdX8DiwWmli1V+QIx/v7VC0TexaqiggkJm2lpyO23y6uem4YNQ0ubEDOFheGebt1kM5KTs5WX1PD0ZKuBkBAm/Js31xaE3t5AZaXL8hbyOHn1Uod76ePtLR/XC8xpXsaP8/NjikGvhykoCMkzZqhzFrScxI74+sq9gdMOHtRUXlu2bUPq5s14c8ECRPTpg7IjRxAI4Eq7/fyg5DDoecvTxlQMvLmNFkIpNDgiXFWgiX1Iqk6nw9/XXYfYH38Epk+Xa9ibwsJg4nXta8KxLAPPyOU/cr2e9R/28kLyq69i3Isvsv7DNoEIsGJuMRERLIKIO3i5z8HfX2mI8/ffrP+2jRgALQcPRuoDDyh9mznl5axeEI+4CQxkAtBV60Nb9y/um5H7JDsKbjvF4Hgv77v9dnz27bfoarFgB4Ck559nx/n6KtnVFgsSb7sNCf37I/3YMXh7eaGouBjm7OzqlQNvQ3nqFHxcRBGNePxxVS4H79HWF8A+2/98xaDX67Fg6lS2GmxsxcA7BNrXc+JFFwUNirjDAie07Od3/vab0krUntpUWK2sBI4eVYd6csXAf+QGg9w5L/Huu1U+DwCqUh0pK1cq5ba5YuCRQwBrbHL2rBJhdPQovNu31zaVlZczgczt2m5uTBi5mpW6ucGck4PUzZuREBfn2jdj8zFo3cvPvv0WU8aNQ0cA2wFMmj2b2f65KQlgK5mKCphMJhw6ehTX3H579X4Ce/z8gLNnUXTypObL9krBAIC3m+lnt48/gIi2bdl1DR3qutheQ8AVg5eX86pBKIZGQdxhgRNa9vMMqxVnr7pKZU4CUHvFUF6u/pHzktn2HbJ4vgAUnwcAZyfvq6/CfOgQE+Z5eUyp2NfSCQ5mgrWgQJ49IzJSe2xVVc51eKohZelSRN58syyk127YoK1wbD4GV76IlfPnwwPADii2/0K9Xkmg8/YGysthPnmyViUsVGGzBgNgMCAmNLTGkuJhYELgINiKgeMPoEWbNuy6LJbGbSjDFYNWCRLhfG4UhGIQOOHKfk533AH8+aec0wBAqXNUXUKSxcKUgn0lVvteDNWgKVitVqQfPsyUCe+Hay8sgmwdGU6fZisVgPlIHOFtLWsp9MxmM8Y+8kjtQkhtpqTYNWuQDuATAIkAQsHyJzrbdtvJr8liQW5lpbJiCAgAbGW8a4pO0gybdXODKSQEyVOmQKfTYRSAoRrXxMMFloElATYHIAFo16wZvHmP8cbMYQAUxcBbcjqWXBGKocERikHghKvs2KARI9jsesUKZWce119dIT2bWUS1YqilYnDp5O3alQn0vDznjGAeTXTmDMCT7lq1cj55ebnSmL0WuEzK0wohtSkGvzVr4Bcejo4AFgBYBGDWxInoBhY+yyN/9Ho9Alu1YoqBz4p1uhqd3C7DZnNymJ/illvwxdy5eA7AGw5D1Ol0mDh0KADgf3PnAmDmJAJQlJODHfYTgMbyL7CBKYrB3V2dtCdMSY2CuMMCTTRzG7y8gJtuYoqBC8gaOo4BUCqn2mUt2/sYqusNUGMJh7NnlVLbHPsVg9nMhIuWg7y8XKnWWQtcJuVphZB6erIeETk5CJ09G823bMGJQYMwpE0bPDduHO6OjsYuu3MseO01BJpMbBVjU6C869vsiRNdXr/LFYXZLN/jPl274goA0WCRUICS9X1bx46AhwcCevRAJoA+ttf9AXy1bh0rbihJjasY2ADZw8/P2QQpFEODI6KSGgpuprCnuJh9se1t2pWVbNbr7a1OprLn7Fn2ul3nMVitzD5uNDbY0lqO8rFn2DBg2TLgr7+A3r3ZrM5+LFpwU1NFhXJfbEIr5auvVBE7yUlJTiUaEocPR0JcHCsQ5xhVlJ+vdjwDimmJrxjCw53vEe817eqea90PkwnJyckYN26cdiSSPR4e7HPz8AB69GDRW926AVu2AEQIP3MGPqNHI/W665Rr+v13dmxhIVK+/151X2ZNnIienTs7Xb/Lonht2rDPxGKByc7Mdy+AbbZx9+zSBfjhB2ayyszEMSh+Bj8AeURIP3wYpk6dGi+5jWM0MgXg48MKCHKEYmgUhGJwpKqKzWzd3dmM02BgQtnbW0ke8vJiX1D+5S0sZF/g0lImvMvK2HajkR2j07HtxcVKXX++PK6qYqaQggL2nmVlbD+9ngk4/oM/fZqZSHiSV34++z8/n81Oed9k+//Ly9lYz5xhfysr2XWUlCiC3M1NCf2sDT16MEfu8uVMMRgMcnkKl1RUKI7Eigr2vkQwnziBFZMmyVEy3AySEBfnJGw1lRTAlKrjjF2vZ6sIrhi0Eu94GYw6OlUTExOZklq/HtHt28OkZaIClHt6zTXKe7Rsyb4rhw4BZ87Av1cv2cEOQK4ce+LQISfz0OTXX0fmxo2a98Vl2OyJE2ynjAwAQEl8PMZt24bbV69Wxp2dDTRvjpjWrbFckjCcCEEAjACKJAnRJhO7n429YmjZUmkdy1u/8omRUAwNjrjDjnh4MCF/5gxLdgoIYF/OvDzF0VlZqThU8/OZ6aKsTKmP4+3NthUWsi8zN6Xw5utnzyqlHUpKlNXCqVPsPH5+bNupU+zh4cESroqK2Ozp7FkWwdOuHfvLi44ZDMox+fnseV6eMhadjm3X69l7uLuzH1xBgSK0XUQYyeaeEyfYquGnn5S6QkTVRyaVlbGxWK2KA9pqxfG//sJqItl8AdSi7IMjeXnOpiSAXTM3JblSDI6rsFpiatMG8X36sP4Q5eVKcb/8fDaeU6cUZ3xcnHIgF+p8ZdChg/rENsVw7L//6lQOw9HslxAXxz4rbmbLzAQMBng9+yzcCgthsq9pdfIkYFO61z35JIwArrO9dO/997OqqrYop0aF16XiVW25OUmsGBoFsWJwpFUrJau2eXP2xSwoYD92b28mUPmX1ZaUhWbN2I/PYmGzG3d3tq2ggM0cQ0OZsnFzY8Lx0CEmTIKClJWBjw9TEiUl7Bh/f/YefLYdHs76FhcUKIrCaGRCj9vrKyvZPtzZGxGhzLiqqpRELm9vJoSImDAzm5X6OtzEEhAA84kTSMvIwLbduzFx9mzZrLH0+ecxorQUWL0auPPO6ns/83EZDErYqm17a9tMOgrAZtvuNZZ9cIQraw5/j6AgptyPHQNuvtn5uIoK10lsNaHXs8+ooEBpm2kwsG28nhI3F2ophl9/Ze8dHq4+r208Eb6+teuZYAdfUTkm0yUnJSExI4N9Fzp2BNq2BVauVPprZGUBV18NAPjf44/DunAh5sbGAhs2YNCQIey7ZEtovCBIEvst5NvysEW4aqMgFIMWzZszsw2PdvH0ZDMvvd61rbVFC6V+v4cHOyYsTFmBcPR6du68PCYY7Gdifn7qdpfcZMVnn82asYcj3FFnMDAzD88ZsLeft2mjRHpwJIkJVU9PZSZWUQEcP46UlBSMfe01p5mr1WrFvW+8gaE9esDj66+ZYjAYVIXbVPCaRh4eTGDalXEOtc38IiQJIKp92QcOL4lhH5VUUqIo3SNHmEBxXDFwYX4+sfnh4ewz598J+/tqsQBdurDKtFdcoWxv3pzd823bgJ49nQWcbcUQajRWn1XtAlcRSiOvvhqeUVHs/YYOBebOZZ+DXs/MTVzh6PXQxcaixT5b/rOPj/LZXUg8PZUgB0AohkZAKAYttBKeajI5aM2qQkK09w0JYUJAa3nuuEw+l4Jh7u7OmarVxaHb7+vmBrNOp6kUOBaLBVlXXYWYJUuUGHfey8Bh/OYjR5D255+IueoqZnqpqlKS22yzwBf+9z8kDBvm7FiuiaIiJoTtTUncuR0UBPz8M9vmqBjKytg118W34kh13wedjvlfevdWf3Zubuyzz811NiMBgLc3SKfDwR07kDB6NDI3btR2uLvAVYQSHT7MKuQCwG23Aa+/zu4NH0Pr1soBPXoAGzaw/3m3vMbMYdCChxTz1aZQDA2OMNZdCLgDuomSlpXlUikAzKwR1LYtE8qFhYqZyMEBnZKSgsj27TFw7FhEXnstazTD/S1VVcg/fpydLyfHdWXX6tAqhwEwwRwYqMwwHRWDYxmM+oYrc62kv5Yt2V8NxZDy9dfIs1rxUUpK9VnVLtDKeXDT6eCZm6sI//BwoFcvZk7iPgv7rPAePZT/ubmxsf0Ljuj1bCy1aZUqqBeEYhA4oRWvz+FmjeA2bdiGM2cUH4adA9psNjs3mpk6lcXFWyxIWboUKYsXAwD2//FHzfV/tHBUDFVVTIhxxQAARiPMlZXqPAmLpU5lMM4JV13IuJB3UAzcDJQPlkNQY2MeDbRyPpY8+ywki0UduXX77cCmTayMuq+vurx4167K/15eFyaHQQsfHyUDWqwYGhyhGAROmEwmJM+bpyr5/Prkyfhq3jx8/u67SIiLU5LIzpxRZsd2ikEzS9hqRfqRIzAfPYqxkyaBG4BMQK2EoFMinKNi4GYkSZIVQ5nRiMhrr1XKRXz+ORN0Db1iq04xGI2AQ1MjbgbKAxBg21bnCC04RyjdpWUuuvFGwGCAdelSFISEsEgzjr1fijvVGzuHQQteFt1iEYqhERCKQaBJ4rhxyPztN6R+/DEyN25EUEAARjzxBIY/9hgi+/bFUm6H5mWiAZVicJklHB4uKw0+T20GwFCDEExZtgwRffpg4MiRiOjTh60wzp5lL3LFwHMk7FYMeSUl6lXLiy/CnJ9/4RTDrbcCzzzj5KOIiYqCTqeTVwzAOURo2VA1XeINjrgJCwD8/ZEZEwNdWRlWZ2Q4V2z9/nvg0UeVIodNQTHwaC/RpKdREIpBoI1OB1Pbtoi39X52jHZJtPVIkIWzwaBqTMOzhJ0azTRrJgvBIAC8Gk8kbwajgTk7G2MmTQLZBC0RYcykSTh79KiSgAgolVLtFINjEK3FakX6qVMNL1zsFINqpdOtG/Dww6prS928GaisRLKdKanOEVquyMpiPhY7JW3OzsYEW+RRGjTMVp07A889p0SqNQVBzCPv+P+CBkXcYYFrvLwAq1Uz2qXcakWlt7eyYjAYYM7MRGpqKsy2wnWJo0Yh8+efkfrpp6p+BabmzZE8YwaCALle0FM8asaR9HT8/ccfslLgEBGOHTigrqxKpGR+21YRjml3ep0O0VdeiQbHphg0K5/aUL02YABgMOC666/Hte3aOfd3sOFoTquuzhQAOYHNnrSMDPxAhF0A/rBt0zRb8SizpiKIbYUFm4SiusRpIp+4oEliyz2IMZk0zUJyQxwAKd9+i8gBAzBw4EBERkYiJSUFqKqCKTSUZQnbC6fKSiTefjvaBQbCw+bs3PzDD2rBWVkJbN0KXH89+s+frzk8t+JixYxksSiZsnq9nNsQEBamOGN1OtaNzD63oKHQ6/HP7t0YO2mSZpluzZyDmTNh9fZGgCSp7hcX/m8uWIDWdua0wfff71LpyOTkOOW+xLRujUqdDl0A/CIPV8NsxVcMTUUx8DLcTWU8lzDiDgtcY8uUNgUFaVY4NYaGAmfOMCE3dapayI0bB3NmphIpxOFJdFVV0BUU4JudO3EaQCsogjN761aWADZsGAAgODMTDgGnkMAUQzl3lvLsaqNRcZg+/TSCP/tMccauWYPE++47pzIYdSXlyy9x9f33q7qlAcrM3FWfidO8wRA/j51vZUZSEk4QIR3APCK4bdgAqqk3xMmTToqhxoq1sCmjP/9k5bubCny1IBRDg9ME4tAETRZJYuGM2dnaFU5/+QU4c8Z16ee0NLafJMklpGOCg2Hy8wOKiyFZLDgF5mcw2R1X/N13LIN5xQoWTRMXh+979ULPdetgsVoh2UwJ+/7+GzsBbHztNTw5fDhMLVsqdX2IgCefBGznNoWFscSycy2DUQfMZjPGPv+8k/kLUM/Mncpe6HQIaNFCbtbj6FsZACAYwPcAbgDwCIDXAUy0Hc+VjizgiZhiaN4cjlRXsdaprEZyMhITE8/rntQLwpTUaAjVK6geXpYDDtEugFzB1GUzGVvXNJUtfcgQpHz5pWyCypMkmMFWDPy48IwMIDaWPYKCgDvuQLddu5CZmooPZs4EwHwM7QD8B+DN5GRE3nADUr79Vom7d+z6BbDXGqF3sVaoLsAUAZ+ZO83aba/JisFiweatW1XK5QEAhwA8BKAtgAkAngcw2Pa6kzmooIAl82koBkDj84SLshrjxsl+owuKWDE0GuIOC6qH1zjSKpJn8zHIQs4+AmnBAphCQmDOzXUWNFOn4uShQwCAhx97DGZJQivbccmvvALPnTtZOQnOffcBp04hff58PDJ1KogI3mCtKPfYdpFDUc1mZkZynK1zH0QjhF5qheryxjj2DmU552DJEmbmuvdeJfGuqEg1M54I4A4AL9qdcw6AHwEsBhAuSc5RTDYz0L85ObVOlHO5+rOvyHqh4EpBKIYGR9xhQfXwngXl5c4RMLznAWxCbs0apH72GTIzM5npoawMaWazpi39hE0xDL3rLtw9diyu8vFB5saNeKhjRzZjtlcM0dEo69kTHsuWyTNonje8x/68XIDp9TCfPOmc7dxIfQVMJhOS58xRKcrkpCTWGMdx37AwxHfrBlNkJFvN8PpEhYXoExsLSZIwFMAsAC+D9WYef8890Ot0ILBVRAWAJUSQHO7zTzZn9LAZM1w7px1wufpzSMi7IBApDmhBgyLusKB6bFnEmmGXQUFKLwcAplatmJALC5M7tsW0aeMsaHQ6+NhWIMfKy+Hfrh2MRUUwBQQgb+1aWNzcYHYwf6Rdey2uAcAr+XQEYAWw3/68NgGWsnQpIm+5RT3WRlQMAJB4333IXLVK3RrVFbzFqF6v5GQUFMAUFoZvHn8cnwH4CsBMScLC2bPxwauvYsvKldBJEk4DGAkgDkCWnfPZnJ2NZSkpAIBs1L7EhqZjesECmLR6WlwIhI+hURCKQVAj5rw8VbVVLmRO8R14aQqDQSmzbSuqZwoPdxI09yYkYM6CBagEEHHDDVh94AAA4OuUFGyeNw+/V1QgMj5eNcMt69cPmQAetT3vCGZv5yl1ep0OC959FwAw9qmnnENEzWaljlJjoNPB1Lx5zUXweFl1nn/RogXbfuQIcPIkhn71FYxXXokWn3yCjM2bZQVTVFwsRzxtADADwItEOLV6NQBmEmpBhDMAeOk5i8WCLdu2VZ/3ADsT14cfInP79qbheOYYDEIxNAJCMQhqRNMcZLHgKM90tktykzvB8W507u6q+j1bvvkGS9auRYBNaFmJ8PSiRQCAlLfeQj8AqVDPcFOWLcM1w4ZhPoARAELAFMMeMNv9hNGjmY0+MVG7RpPFgvQjRxq3om1thRdvMcp7DoSEsPIVW7YAY8YAANw++QRx8fGavZ45r4IpiE4ffIDj+/Yh9/RptARwXDUkCSOeeKL6vAcbprAwxPfo0XRWCgC7R02hPMdlgFAMghpxVfeoJc8g5oqBC8P8fOb49POTt/EImKLiYrlOEq+ydMQmyIcSwQ/Ab7btFosFP/z6q5wklgKAAIyRJMT5+6Pb7bfjyKZNeGPCBDlU1WWNppYtGyUiSUaSnP0cWvC+3G5uipmkWzdg8WJg3z5g0SLNqCJHk4+k1yP7hRdQUVqKXTfeiBGPP44wALw8Hr8nWsl2ALR7dje1CKCQEO02rYJ6pwl96oKmislkQvIHHzjVPWrRrh3bgddL4vD+0naCmDuufby95TpJXDFU6fWo9PPD3QDOAthq2y5JEh6ZOlU2mZwB8AWAJ4ngkZ+PqIED2SyaJ9EZDGys77+vWaOpMctHpyxZ4uzn0KKyUulAxyNuunVjz1u3Zu04XZAQF4fP33kHX73/PjI3bkTczTfjfyUlGAzgWUBeMXz1/vv4Yu5cp7wKuQyGxcIUuVa/g6akGJpKQb/LAJHgJqgViWPHIqFbN6Rv347ozp2ZQOYtMu0rrHp4KK01bTgmTN13++0IXrECp2GXRb18Obx27sRzlZWwEkGn04GInITZPLA4fgAAV0y8ixwfa2IiEqKjkZ6djeiYGDbWU6caTTGYzWaMfeIJp9l5Qlyc2t/A+xdzExdfMfCeCC6EoDk7G+9+9BHmpKTAakv4e3bMGPTs3BlriDALwGsAjGDmpd5BQYi2FS7U7CPN23eWlytj4fe9KSkGQaMhFIOg1pjat4dJr1fqE/EqpvYrBh8fVRMcc3Y2SidOxOtgCVlWqxWfffst3mvfHsXNmiFz9mwmLAcPhlGSMKG4GEMzM5Fz+jSGP/aY0xh26nQ4aTKheXa20nzGanUqu2Fq2ZLZx3k/60acbbr0c9hnJQNK/wheooMrhvbt2fOEBKdzpyxbpsqGBliy35vJyZAkCZIk4SUi3AuW8Z0tSfD28pJNT5p9pEtKmEIoLlbeiBfQE47eyxKhGAS1x9ubCf2SEiXe3i6XQYu0jAz0B3MYT7Bts1gs0BUUoEXfvkrlT5s5xeTnB1NYGMzZ2U4zXJ4k1ryigjlnuUB1WDHIse78WItFKZXRCHA/h+bs3B6uGPjYuU3fYAB27HAq38GzkrVKbQBMQUiSBNLpcMxqhQnAMSJcc/vtSE5Kkk1Pkk6H3t27K0rKYlH6WHCF0NQK6AkaFfGpC2oPXyHwpuxAjYohJioKUQDCAPBi13q9Hh6lpUr7TQ204unlJLGePYEnnlB2dlwxsAMUxVBV1ag5DC79HI5hq9yEw2fl9oI4IMBJKGtlJTtCRJg3YwaKbM95DsOYSZMQ2bcvhj/+OEY8/jjW8kZLgKIY3NyUDHfepEcohssSsWIQ1A0fH5jPnEHavn2IiYmBKSgIOH3a5e4mu1aR1wH4T6/Hgldfhe6FF3Dw9Gl4Z2e7jPOvrtCbE45mIqNRaRzUiOUwOIkPPoiEK65Aek4Ooq+4QnvsVVXqVprcdONC+PMQ1eqUg16vR1BgIAptz0/a/tr7a5x8HhaLklhXVMSUlVAMlzXiUxfUiZTPP0fk4MEYaOsF8G9lJbB3r0thBlvxNauvL6b26IHMjRthLC+HZLFg6scf1y6evqYkMS0BZjCoVwxubo1rL5ckluDWsydM3t7aET9E6hLg3A/i4l46rqJ0Oh0S4uKcViZ9YmPxjCRhEYAjLobn1JjHYGDmQd6eVZiSLmvEikFQa8xmM8aOHauKtpmcmoq1Vitw6BAQE+N8kE346O64A6HffAOzxYLp06fjfgCnUU3ETl3gQsweo1ERsFZr4+YwAIqy4gqhooKF8bq7M98Bt+Xb+0YAtW9EA61VlDk722lV9cKsWbKjWSvCS+Xz4DWIuPIkEs7nyxwxHRDUmnfffdfJjLHRaoVVrwf++kv7oJ07gfBw4KabgIICnEhNRaBdXgLgoq1kbXEVcWRfYdViaZTmPCp40/rSUuZYb9uWRVERMR+NfWMhewwGmE+ccEqMsy9g6LiK0lpV2WebH9m0CQunTdP2efB7ZDAwpWU0svE1pX7PgkZHrBgEtcJsNuOtt95y2l6u06GyfXu4//03cO+9zgf++y9L2OrSBfDwQHRODkJss1KuGDQjdmoLz6VwXDE4CjVHAdzQcMUgSWyFwIVubi4bM4+kchhXyvLlGDtxotIkJykJANSNc5KSqi/KZ4P3fQCAxFtvRcINNyB9926Wh9KyJduJR2zxFYOnp+KbacSEQEHTQnzyglqRlpamGSb5dGIi3HU64LvvlNk7p6IC2L2brRbc3IArrkDAqVOYePfdwOefqxLcztmMZLFo+xh4yCUfU2MLOa4UPDyYsOVj0uvZasFiYSsJu/tlNptlpQAwM9vYyZPl//nfczK9Wa0wXXEFTAEB6o564eEwBQYq98fXl5U0MRpFlvFljDAlCWqFZvMZScKTw4cDvXoBJ04AWVnqg/btY8qBl3iIigIOH8bAK68E6fVY9fnnyPzjDyTeeWe17+3UB8IebgvXMiUBqnIZjQpfsXh4qP0bbm4wHz+O1C1bYOZVaW1oJcZZrVaXyXJ1xsMDCAhAyhdfKCXUBwxAynffKfeLKzG+EhNclgjFIKgVJpMJycnJTnkFptBQoEcPJgT//huAIsjz1q9nK4WrrmInadOGOaPz8iAFBiK+Tx+YPDyUst0aaPaBsMdV8xYumBs5h0GFXs9yNexWBSkrVrCorvHjEdm9O1JsPRMA153fNIsCujC9aSpRHq5rNMJcUICxr76qXoFMmwbzcVsdVns/gzAlXbYIxSCoEbPZjNTUVCQkJCAzMxOpqamsS9t997GZpb8/q1v0998qQb7m7bdxskULxfEbFcWa0x87ppTVsNnbtQSaZv9hx2YzFot2WCVfRVRUMEF3IYRcQIC6PIjZjLHPP++yn7LJZELy2287dX5zapzjwvTmUoly5Wg0uuyoJ7fu5B37uDIRXJaIKYGgWlJSUuQQVZ1Oh+TkZKVxS04OEyAAcPXVqPztN4xdvlwWPFcDWHr0KK7duZNlLLduzfbdtEn5H0DKd9/Js1h756rL/sP2NYdcmTz4iqGiQqle2tiEhqqeuqyhlJ4u9z1IvP9+VgCwoEAVflpTop8rJZoQFweTn5+sHGPat9cu18Fbd3Jn+ZkzIofhMkZ88gKXaOUt2M9wodcrZpJevWA0m9HMtm9zAK0BbAFwzdChbPbKlUFWFgthBWA+edLZtGFbFbjsP2xvRnFMElN2ZIKtsrJxG/RUg8teEfb9lHU6mFq0cAo/rSnRrzolal96w2QyIXnuXGVVotNhwZw56oY8np7MpCRCVS9bhGIQuKS6GS4Ada5Az54AgP42YXKNbf8tYF3axk2ZAnNZmWJCMpkAIpfd4fiqoEYzCg+3dISbl7SSyC4QJpMJyfPmqfMJHPsp82iqOlKtEq2qUpzKABIffhiZqalI/egjZK5ahcRRo9Qn45FUWs17BJcFwpQkcInLKqF8hmsTRDz0sV+rVphqMuHrv/5Cb6sVZgDHbMfJwr55c+ZsDg8HLBbN+j/2q4Ia6yVpFdDjY+OrhiZkK09MTERCTAzSi4oQrdU6kyszHm1VS6otq33qlFo56nQwtWsHk6entv+F+xmaiEIVND5ixSBwiVYkkmqGq9cj5bvvZIfn4qwstMjIwM45czAOwC9255KF/bPPsg0dOgAWCxNoM2dWW4m0xnpJrgR/E1QMMBhgiopCfHy8dj9lnpNhU5TVhuo6YJ/tnLlxo5IEJ0nOQt7HR8lVcFQMkgS0aqWs7gSXHRK5Ku5+kVJQUAB/f3/k5+fDz6GeveDcMJvNSE9PR3R0tEqYmdPSENm+vTzbvw/AYgBlPj7I8/HBlTk5yLNaZWGfEBfHkqoiIth5SkuZAPTzg3nPHqTn5dVcRdWRU6dYGKxWCe/Dh4GCAlaOwr6K6YXm9GmWSKblGykvBw4eBDw9kbJy5TllPKuoqmIVU9u2BTw9YTabkZaWhpjoaJhKS5kprl074Wi+DKiLbBTfBkGNmEwmzRmuo8NzPQArgG1FReh88iSmTJwoz14BKKGUcXHMGc39Ax4eMIWGyqsCeZZ8/DgrQpeTU21hOZdCrSmuGAAgONh17SabKalWobq1wS6PIyUlBZGRkRg4cCAio6KQsno1czILpSBwQHwjBOdMTNu2kOwiV44C6AbWdyGXCJNff132FWgKuePHnbKSVbH4/fohZfFiNrsuKoJLXAl+ewf0xYJtvNVGGdUFm/I1nzjhHGE2YQLMPNxYILDjIvrFCJoapogIPOsQ0bILAO/vxgWZSyF35AibORsMrH7P8ePOCmT2bJhLSpiJxXHV4KqAHodIKRB3sWBTDDEREXXKeHaJrRdFWnq69mdw7JiLAwWXM0IxCM4dnQ7NQkJcvswFmctQyvBwRTEYDEg7dEhbeJ09y5KuHFcNrrKe7TEYLq4Vg835bGrWTDtUNyiIRXUVFLDe27yxjissFsDDo3Y5FAKBjYvoFyNoapjNZkzSKMUNqKOLXOYjNGumRMXo9Yhp1UpbeLVrB4SEKH0COFwxuFoReHpenPV+bFFJmlFGhYXMtObpyZRIQYFSJlsLqxVwc6s5wkwgsOMi/NUImgpaCXAA8PZLL2HYjTc6NY5xykc4dUpRDEYjTCEhLBZ/8mRYeDQTF15VVSzEsqiICUaAlbvgsfhahIRoRys1dQwGWQHa91RAQQG71hYtWJQVEYtwMpvZ/eH3xR67kuOJiYlISEjQjDATCOwRikFwzrhKgHNUChyVkFMOYH/d3ICyMiT+739I6NoV6USIvuoqRXgZDKz2UEYGUxC8DlKzZq4HeCH6MNQHdooBAPv/7Fl2j8LDldBbSWLKz2BgZUby8tS5B/bd2WyYTCahEAQ1IkxJgnPGZDIh+a23qk1OcwnP7OWmI16CobycJYANGuQswPz9AW9voLhYEXp2pR4uGQwGxdFusbCVlbc3qzWllXQWEACz0YjU7dth3r9f3dL0QpUcF1zUiG+M4LxIvP9+JLRt61QNtEa40OIrBqORCbSKCqceBjJ81ZCZyf7npRsuNfR6dn8qKlg3teBgtlJwkfvgVAF3yhQkPvjghWtSJLjoESsGwfnhohpojTh2XuPCy2pVdzxzxN8f5oICpP72G+uA5ipR7GLGy4vdj7w8ICwMiIhweZ2aFXCTktjKgTfbuZjCdQVNAqEYBOfHOVYDlXMQ7BUDdyJXI+xTFi9G5A03YOCjjyIyPl7VAe2SwcuLOZLd3ZkPoRrB7rICbnExi1YyGkX5bEGdEYpBcH7wngx1VQ7clMR9DF5eQGQki7hxYR6qsT/EpYIkMfNRQED1qydU0+MhNpb5Xy6mHA5Bk0F8awTnh80cZDabXVcBtViA3Fyl2xvf5hhm6u/PbOkuwk9r7A9xKREQwHpW1IDL/IQ2bZiyFasFwTkgvFKC80OvZ1VAZ850XQW0vJytDoqLWQYzwExJdaz3X2N/iEuNWs72XeYntGgheioIzgmxYhCcF+bsbFkpAC6qgFZWstyD8nJlm8VSZ8exyN51jWYFXB+fGk1RAoEWYsUgOC/SDh+utgpoWkYGYgICYLrqKjmJTfYhnEO0jMjeFQgaHqEYBOeFK/PO1l27cN099yjmpbffRuJttwFnzsiN6c81jFJk7woEDYswJQnOCyfzjk6HpOefx8TZs9XmpWeegZlnLFut7K+IrxcImiRixSA4bxITE5Fwww1I/+MPRIeGIu30aW3zUnY2m+kXFKhzGAQCQZNCKAZBvWCKiIDp5ptZn2UvL+3ooXbtmBnp0CFW9uJSLGchEFwCCFOSoP7w8wMCAmByc0PytGna0UN+fqwiavPmIvlKIGiiSETnUs+g6VJQUAB/f3/k5+fDj8fMCxqPkhJWisHbG+ZTp0T0kEDQRKiLbGywKVtmZiYSExPRunVreHp64oorrsC0adNQUVFR7XGjRo2CJEmqxzXXXNNQwxTUN15erJyDh4d2bL1AIGjyNJiP4cCBA7BarViwYAGio6OxZ88ejBkzBsXFxXjzzTerPXbw4MH4+OOP5edul2IFTYFAIGiiNJhiGDx4MAYPHiw/b9OmDQ4ePIgPPvigRsXg7u6OFi1aNNTQBAKBQFANjer9y8/PR1BQUI37rVu3Ds2aNUPbtm0xZswY5OTkNMLoBAKBQAA0YrjqoUOH8N577+Gtt96qdr8hQ4bgzjvvRGRkJDIyMvDSSy9h4MCB2LZtG9w16r6Ul5ej3K4GT0FBQb2PXSAQCC4rqI5MmzaNAFT7+Oeff1THHDt2jKKjoykxMbGub0fHjx8no9FIK1asqNN48vPz6/xeAoFAcKmSn59fa9lY53DVU6dO4dSpU9XuExUVBQ9b8tLx48cxYMAAXH311fjkk0+cmorUhpiYGIwePRoTJ050es1xxZCfn4+IiAhkZWWJcFWBQCCwUVBQgFatWiEvLw/+/v7V7ltnU1JISAhCQkJqte+xY8cwYMAAxMbG4uOPPz4npXD69GlkZWUhzEU/YXd3d5WJiZuSWrVqVef3EggEgkudwsLCGhVDgyW4HT9+HP3790dERAQWL14sZ8ECUEUctW/fHklJSbj99ttRVFSE6dOn44477kBYWBgyMzMxZcoUHD16FPv374evr2+N72u1WnH8+HH4+vpCEt2rBAKBAABARCgsLETLli1rnKQ3mPP5559/Rnp6OtLT050SnOx10cGDB5Gfnw+AlU7YvXs3Fi9ejLy8PISFhWHAgAFYtmxZrZQCAOh0OpFQJRAIBBrUtFLgXHIlMQQCgUBwfogqZgKBQCBQIRSDQCAQCFQIxSAQCAQCFUIxCAQCgUCFUAwCgUAgUCEUg0BQz3zxxRfw8PDAsWPH5G2jR49G586d5dBsgaApI8JVBYJ6hojQtWtXXHvttZg3bx5mzJiBRYsW4c8//0R4ePiFHp5AUCONVl1VILhckCQJr776KoYNG4aWLVvi3XffxR9//CGUguCiQawYBIIGonv37ti7dy9+/vln9O/f/0IPRyCoNcLHIBA0AGvXrsWBAwdgsVjQvHnzCz0cgaBOiBWDQFDP/Pvvv4iPj8f777+PL7/8El5eXvj6668v9LAEglojfAwCQT2SmZmJm266CZMmTcJ9992HDh06oGfPnti2bRtiY2Mv9PAEglohVgwCQT1x5swZ9O3bF3FxcViwYIG8/bbbbkN5eTnWrFlzAUcnENQeoRgEAoFAoEI4nwUCgUCgQigGgUAgEKgQikEgEAgEKoRiEAgEAoEKoRgEAoFAoEIoBoFAIBCoEIpBIBAIBCqEYhAIBAKBCqEYBAKBQKBCKAaBQCAQqBCKQSAQCAQqhGIQCAQCgYr/A3822x7pu9bdAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 19
  },
  {
   "cell_type": "code",
   "id": "a1c98743",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:35:47.413314700Z",
     "start_time": "2026-01-22T07:35:47.398787100Z"
    }
   },
   "source": [
    "# Train DKL\n",
    "def train_dkl(model, criterion, optimizer, num_mc=1, epochs=2000, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_train_ = x_train.to(device)\n",
    "    y_train_ = y_train.to(device)\n",
    "\n",
    "    losses = []\n",
    "    bnn_scheduler = torch.optim.lr_scheduler.CosineAnnealingLR(optimizer, T_max=epochs)\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        optimizer.zero_grad()\n",
    "        output_, kl = model.mc_forward(x_train_, num_mc=num_mc, return_kl=True)\n",
    "        output = torch.mean(output_, dim=0)\n",
    "        loss = criterion(output, y_train_.view(-1,1)) + kl / len(x_train)\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        bnn_scheduler.step()\n",
    "\n",
    "        losses.append(loss.item())\n",
    "        if epoch % 200 == 0:\n",
    "            print(f'Epoch [{epoch}/{epochs}], Loss: {loss.item()}')\n",
    "\n",
    "    return losses\n",
    "\n",
    "def evaluate_dkl(model, num_mc=1000, device=\"cpu\"):\n",
    "    model = model.to(device)\n",
    "    x_test_ = x_test.to(device)\n",
    "\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        \n",
    "        predicts = model.mc_forward(x_test_, num_mc=num_mc, return_kl=False)\n",
    "        predicts = predicts.cpu().data.numpy()\n",
    "\n",
    "        pred_mean = np.mean(predicts, axis=0)\n",
    "        pred_std = np.std(predicts, axis=0)\n",
    "        lower = pred_mean - 2 * pred_std\n",
    "        upper = pred_mean + 2 * pred_std\n",
    "\n",
    "    return pred_mean, lower.squeeze(), upper.squeeze()"
   ],
   "outputs": [],
   "execution_count": 9
  },
  {
   "cell_type": "code",
   "id": "70c0689024ce1b09",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:36:26.714608700Z",
     "start_time": "2026-01-22T07:36:26.690709600Z"
    }
   },
   "source": [
    "from csgp.layers.gps import CSGP, CholesGP, CompactGP\n",
    "\n",
    "class FeatureExtractor(nn.Module):\n",
    "    def __init__(self, in_features, num_features):\n",
    "        super().__init__()\n",
    "        self.fc1 = nn.Linear(in_features, 100)\n",
    "        self.fc2 = nn.Linear(100, 50)\n",
    "        self.fc3 = nn.Linear(50, num_features)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.fc1(x))\n",
    "        x = F.relu(self.fc2(x))\n",
    "        return self.fc3(x)\n",
    "\n",
    "class DKL(nn.Module):\n",
    "    def __init__(self, input_dim, output_dim, dyadic_level=3):\n",
    "        super(DKL, self).__init__()\n",
    "\n",
    "        self.feature_extractor = FeatureExtractor(input_dim, 10)\n",
    "        self.gp = CSGP(\n",
    "            in_features=10,\n",
    "            out_features=output_dim,\n",
    "            dyadic_level=dyadic_level,\n",
    "            anchor=False,\n",
    "        )\n",
    "\n",
    "    def forward(self, x, return_kl=True):\n",
    "        x = self.feature_extractor(x)\n",
    "        res, kl = self.gp(x, return_kl=True)\n",
    "        if return_kl:\n",
    "            return res, kl\n",
    "        else:\n",
    "            return res\n",
    "\n",
    "    def mc_forward(self, x, num_mc=1, return_kl=True):\n",
    "        x = self.feature_extractor(x)\n",
    "        res, kl = self.gp.mc_forward(x, num_mc=num_mc, return_kl=True)\n",
    "        if return_kl:\n",
    "            return res, kl\n",
    "        else:\n",
    "            return res"
   ],
   "outputs": [],
   "execution_count": 13
  },
  {
   "cell_type": "code",
   "id": "bb556e747352993f",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:36:50.439374200Z",
     "start_time": "2026-01-22T07:36:29.571107Z"
    }
   },
   "source": [
    "dkl_model = DKL(input_dim=1,\n",
    "                output_dim=1,\n",
    "                dyadic_level=10,\n",
    "                )\n",
    "\n",
    "dkl_losses = train_dkl(\n",
    "    model=dkl_model,\n",
    "    criterion=nn.MSELoss(),\n",
    "    optimizer=torch.optim.Adam(dkl_model.parameters(), lr=0.01, weight_decay=0.0001),\n",
    "    num_mc=10,\n",
    "    epochs=2000\n",
    ")\n",
    "\n",
    "## Sparse epoch time (DKL): 7.6 ms\n",
    "## Dense epoch time (DKL): 73.6 ms"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [0/2000], Loss: 1.834435224533081\n",
      "Epoch [200/2000], Loss: 0.1869925856590271\n",
      "Epoch [400/2000], Loss: 0.172000452876091\n",
      "Epoch [600/2000], Loss: 0.17246367037296295\n",
      "Epoch [800/2000], Loss: 0.148853600025177\n",
      "Epoch [1000/2000], Loss: 0.15404564142227173\n",
      "Epoch [1200/2000], Loss: 0.13025885820388794\n",
      "Epoch [1400/2000], Loss: 0.1244754046201706\n",
      "Epoch [1600/2000], Loss: 0.10831364244222641\n",
      "Epoch [1800/2000], Loss: 0.10629488527774811\n"
     ]
    }
   ],
   "execution_count": 14
  },
  {
   "cell_type": "code",
   "id": "462951d708a97810",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:36:52.505545900Z",
     "start_time": "2026-01-22T07:36:51.688634100Z"
    }
   },
   "source": [
    "dkl_mean, dkl_lower, dkl_upper = evaluate_dkl(dkl_model, num_mc=5000)\n",
    "plot_confidence_region(y_train, dkl_mean, dkl_lower, dkl_upper)"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ],
      "image/png": "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1WqsWLGi1hzQnp6ekv1diZycHHh5ecHPzw/l5eVYsWJFrbyvEt7e3mjfvj3WrVsHgIp2Hj9+3OH2SUlJ2LNnDwBgw4YNCA0NRXBwMO666y588803KCgoAADEx8djyJAhNToWLy8v2XW5evUqioqKcPfdd2PBggUIDw/HqVOnanqKNaZpuv45HE6VxMXFITY2FklJSYiMjKzVqKSXXnoJgwcPhqurK3755Re754cNG4Yvv/wS7dq1g06nQ9++fbFjx45ae39b1q5di6eeegrvvvsuunTpgujoaIc9Czp37oxvvvkGL774Ihhj+Prrr6VjPn78OPr06QNBENCpUyd8/PHHNTqOTp06oW3btujYsSNatWqFOXPmYPz48TAYDDCZTOjbty+GDRt2w+dbFTxclcNp5NxIuGpToaioCG5ubhAEAadOnUJMTAzOnj0LX19f2Xa1EU5a19RGuCpfMXA4nCbPvn378PLLL0tFBleuXGknCk0JLgwcDqfJc/fdd+Puu++ucruYmJgGvVqoLbjzmcPhcDgyuDBwOBwORwYXBg6Hw+HI4MLA4XA4HBlcGDgcDocjgwsDh8O5pdm1a5diklx1mT17NtavX1+LR3Trw8NVORzOLc2uXbtQWFhYrXBTWyoqKjBv3rzrel1j7hnBVwwcDqfeEQQBc+bMQb9+/dCmTRupThEAbN++HV27dkWnTp0wcOBAqTZQYmIi+vXrh+joaNx+++147bXXcOTIEXz66adYu3YtOnfuLA3yO3bsQP/+/dGtWzf06tVLqm20a9cudO7cGc899xz69OmDTZs2YezYsVi+fDkAoLCwEE8//TQ6duyIjh07Yu7cudJxxcTE4NVXX8Wdd96J2NhYu3MaO3YsJk2ahDvvvBNhYWF4/vnnsXPnTgwYMADh4eF47733pG0TExNx7733okePHoiOjpaVzqisD0Xnzp0xefJkREdHo0OHDnWWU9F4JY/D4ShTXAycOVN3+2/XDnBzq3IzQRCwb98+JCcno2fPnujfvz9cXFzw3//+Fzt37sTtt9+Or776Co8++ihOnDiB5cuX495778WsWbMAANnZ2fDz88OkSZNQWFiIJUuWAACSk5Mxd+5cbN++HV5eXkhKSsLAgQORmpoKADh27BiWL1+ODz74AADw008/Scc0f/58lJeX49ixYygpKUH//v3Rvn17PPLIIwCAI0eOYPv27XByclI8pxMnTuB///sfjEYjwsPDUVBQgF27diEjIwNt27bFhAkT4OrqijFjxuCLL75Au3btUFxcjN69e6N3797o2rUrli1bhoCAAADAokWLMG/ePEm4Tp48ic8++wwff/wxPv30U7z66qt1UkOKCwOH09Q4cwbo1q3u9n/oENC1a5WbjRs3DgD1HOjfvz/++OMPeHp6onPnzrj99tsBUP+EKVOmICMjAwMGDMDLL7+MoqIiDBw40GHl0u3btyMpKQkDBgyQPX7p0iUAQJs2bdC/f3/F1/722294//33oVKp4O7ujieeeAK//fabJAyPP/64Q1EAgBEjRsDFxQUA0LZtW9xzzz1QqVQIDQ2Fr68v9Ho9TCYTTp48idGjR0uvKygowKlTp9C1a1d89dVX+OKLL1BWVoaSkhI0b95c2q5t27ZS97o+ffpIYljbcGHgcJoa7drR4F2X+78OHPU0EJ8bOXIk+vbti19//RXLly/HsmXLZG08RRhjGDp0KNauXWv33MWLFxX7TFu/trKeCpW9FrDvs6DUd0EQBAQEBCg2HhL7UOzfvx+BgYH48ccfZT6Q6vZxuFG4MHA4TQ03t2rN6OuaVatW4fXXX0dqair27t2LDz/8EFqtFnFxcTh9+jRuu+02fPPNN9DpdGjevDkSExPRqlUrPPHEE+jZsyf69u0LgHoYpKWlSfu9++67MXfuXJw4cQIdO3YEAPz999/o2bNnlcd01113YeXKlejbty+Ki4vx5ZdfYubMmbV63m3btoWbmxvWrl2LJ554AgD1ePDz86vXPhSVwYWBw+HcFFxcXNCvXz9cvXoVH374IVq0aAEA+OKLL/DYY4/BaDTCx8cH3377LQDgu+++w1dffQVnZ2cwxvDpp58CAB588EF88cUX6Ny5Mx566CHMnj0bX375JcaNG4eSkhKUl5dLJpqqeP311zF16lTJlPXII4/g4YcfrtXz1mg02LJlC/7v//4PS5YsgdFoRGBgIL766qt670PhCN6PgcNp5DTEfgyCIKCgoKBK0wyn5tRGPwYersrhcDgcGdyUxOFw6p1GZqhodPAVA4fD4XBkcGHgcJoIjWWWXl5ejvz8fJSXl9/sQ2mQ1MbnzE1JHE4jx8nJCYIg4OrVqwgMDFTME7hVyM7ORnp6unQ/JCQEfn5+N/GIGhaMMVy9ehWCIFSaiFcVXBg4nEaOWq2GTqeDXq+XykLUNxUVFVLhuestPldRUSHLVwCArKwshIaGNuqCdjVFEATodDqo1err3ge/mhxOE8DDwwNRUVEwGAx18wZ5eYCTk2KNpA0bNmD27NkwmUxQqVSYN2/edeUG/PXXX5g0aZLd42vXrq1W8lpTwcnJ6YZEAeB5DBwO50apqADOnQMMBsDPD/D3hz47G4mJifDw8EDv3r1hMpmkzdVqNVJTU6HT6Wr0Nnq9HmFhYbWyr6YIz2PgcDj1h8FAN2dnIDMTCW+/jbCwMAwePBi9evWSDeQAYDQakZSUVOO30el0iI+Pl2bDarUaK1as4KJQB/AVA4fDuTEKCoDERFopZGQgrF8/OzGw5kZn+Xq9HklJSYiMjOSiUANqMjZyHwOHw7kxDAbAPL9MTElRFAWVSgWTyVQrs3ydTscFoY7hwsDhcG4Mq9LPURERkgiIqFUqHFi1CkVGIyI7d4auQwf7fVy+DHh7A66u9XHEnCrgPgYOh3NjlJZSRBIAXXAw4hculPsBFi5Ej5gYxPTrBx1jZHbKz7e8vqICyM4GcnJuxtFzFOArBg6Hc2OUlgJW4ZGxAwbg62XLIKhU6NO1K3TBwfSEVku3rCxqLyrauQ0GoLycxMHfHzB3QOPcPPiKgcPhXD8VFTSwmxPMEtavR1i/fhg1dSpGT52KHXv22L/GyQkoKbHcLysDjEYSmIKCqt/TZKIbp87gwsDhcK4fg4HEQaOBPiMDE2bOlPwLJpMJE2fNgj4jQ/4ajYbEoKwMuHIF0OtpxeHqSqsJo7Hy97x2Dbh6tY5OiANwYeBwODdCRQVQUQH91av4dutW5ZwF2zIcajUJSlIScOkSCYWvL5mQystlzmxFDAagqKh2z4Mjg/sYOBzO9WMwIGHzZkxYsEAxTFWtViMyPFz+oIsLDeyurkBgoPXGZCKqasVQXk5mJ6NR5tvg1B5cGDgcznWjT02tVBRWLFhgcT6LCAI5mW1RqWiwr0oYRL9GeTkPb60juDBwOJzrJvH0aUVRWPr663j4nnvsRaE6VOVYNhotZTi4MNQJ3MfA4XCuD5MJUSEhUKnkw4harb5+URCEylcMoqlJXDHUNkajPGLKaJSyupsSXBg4HM51oU9JQeL581g8bZo8oc1sPtJnZGDn/v32UUlK+xK3vXy5cmEwGkkc1GrKhahtMjOBixfJXJWfT8l4ubm1/z4NHG5K4nA4NSYhIQETJkyQeizMeOYZBPj6on+PHugRHY2E9eul0FWVSoX4hQsRN2qU8r5st337bcS99JLyG4s5DC4uJAyM0SqjNjCZSAzy84G0NNp/djb5Pjw8pOzupgCvrsrhcGqEUl8EEZVKhUXTp2PG4sX2fRP27rUzLylVY620+mpJCXD2LGVQGwxA27ZU7rs2KC2lvhJlZdRwqKwM8PGhvInwcHkE1S0I78fA4XDqjMTERIdltU0mk50oAA7yGaBcjbXSfg2iKcnFpfb9DGVltE8fH1ot+PqSyUoMr21CcGHgcDg1Iioqys7hbI3JZILKxrwj5jPY+h3EaqyybVUqREZGOto5mY9UKvq/rOzGTsYaUWScnYFmzeg9AEsJjyZUhoMLA4fDqRFSJzUH4qBWq7F4xgw7h/SOPXsQ1q8fBo8Zg7B+/ZCwfr19NVaVCivmzHEc0WQ9ODs5Va+2ku3rr12TV3cVKSmRaj7JcHKquyioBgp3PnM4nBoT9+STiA0LQ1J6Og6eOYMZb78No9EoiUDcqFEYff/9SEpNlTKfrX0JJpMJE2bOhKe7O2IHDEDq3r20bUgIdL6+NAjn5ZFd3zq72VoYtFoy8ZhrNVWLvDwgJYV6P9ja2UtLqxYGrbYGV+nWhQsDh8OpOQYDdIGB0LVqhZiBA2UiIM72dcHB0v879++38yWYTCaMevZZedRSRQVQWEiz97w8igby8LC8yDqU1dmZhKGkBPD0rPqYS0qAjAwyEZWUkBCIA71NlVhFmtCKgZuSOBxOzRGrqppn87rgYMT06ePQBHTw+HGHu5JVYVWrLSW4CwuhT0zEzp07odfraWOj0WL7V6nI31BaWvXxVlRQFdeyMirHYW0aKikh01JZmeOQVI2G8hmys5UT3rKzKQeiqnIe10NFRe36UqoBFwYOh1NzDIZqb6rPyMCMxYsr3UaKWhIEGnjLypCwcSPCunfH4MGDERYWhoSEBBrMrX0bTk7K/gKR8nIyP2Vk0ArEx4ceFwQabPPygPPnqcqrk5Pjonzu7iQMFy+SCFhTUkJ5D6mp9s/VBuK+a3DNbxQuDBwOp+aUlckH6EpQCkm1RVaF1cMD+qQkTLAKezWZTJg4cSL0ly7JE9pcXGhgtjXzFBfTYJ+SQn+zskgUxGPWaEgUMjJoRu7qau9zsMbJifwSGg0N1Nbhq1eu0KAt+jxulLw8anMqmtXy8kj86jFklgsDh8OpOcXF1Xb4KoWkCoIgRTXZVWHVapF4/rxyfsP58/L3dXEhkbI2J4lmo/R0ikC6do3ExNpMJGZO5+eTYFSnnaizM/kyjEYyG4nhsvn55AfRaOg4biRnuKQEuHyZBC0piUTIZKJ9FxbWW90m7nzmcDg1w2SiGboDe7w+IwOJKSmIioiQHNDxCxdi4qxZssil2AED7BzWIlGdO0OlUtllREeGhsrNPeLqIT+fBm1BoBDW/HwgKIjum0z2qxutloTBw6PmJTW8vWlG7+tL9w0GegywNBq6nvIZeXlkqioro9VLaSnt28+PHsvKsuRY1DFcGDgcTs0QHc9ubnZPOaqRFDdqlKIQOHJWS2IycyaMJhOJyfLl0NmGrwJk/8/MpOPx8yNfgJOTZcB3ZPLy87u+81eraZ95eZaCfgDN6ouL6fpcjzAUFlpEwcVFvopxdaX3Sk+nVUNQ0PUdezXhtZI4HE7NKCykmkJ+fjT4JiQAq1YhZ/RohLz3HkqthhRHNZIA+5WFEvr0dCQdO4bI/v2hi4igOknWvgKRvDyLMOj1NJDWVg0lJcrKyOxjNNJALgpBVhYQHAyEhNRsfyYTXVOTiYTOEcXFJMpRUTXOqeC1kjgcTt1hMMirmh44ABQUwOe993CWMYyHxRThqEZSwvr1dlnQSuhCQhDTsyd0Pj40ICqZhQAyCeXmkqO5oqJuRQGg2bxGQ2JkvTpwc6PjqGnYalkZ3ao6bldXOr+6CIu1ggsDh8OpGQaD3C6fnAw89BCufP01DgD4FMBZAE8CcFap7Ho+6zMyJHMTYJPHoIRWa8kzcIRaDQQEkJ9BqW1oXeDhYd9BTskZDtBMPz3dcWSR6E9oIKW9uTBwOJyaYR2RZDCQw7R1azTv0weFixejq0qFwwDWAMj084Pur79kM1yHFVUVVhYASBhKSuh9K3MUC4LjPIT6Qq2mVU1hoeWxggKKMkpPp9BWMSnP+hqUlNz8Y7eCCwOHw6k+5uQzSRhE003r1gCAuFGjsHXfPvivW4cra9bAOzoaeOEFYOhQ4KefqB2oUkVV6zwGW8RtrTKtAdSoQ1y94upKvgbREZ2RQdFKYpJcaiqFolon5pWWcmHgcDi3KLY1hZKTAQD7srOlAVosjxEUE0OO6U2byCE7ZQpwzz3QnTolr6hqm8eghFgXySwS1fVR3BTc3UkILl6kaKmCAgptdXOj57KyyFkurioYo+2rWwiwHuBRSRwOp3owRiaR/HyKxFGr8dfkyWi/bRu8gCpbeOKff4B33qG/e/ZAr9EgKTUVbby8EFJYCPTq5fi9DQYpe1mfm6vc9c1B9NNN49o1y2Av5jmIiG1J27Sh+2fOkH+hqkgjxiiHok2byqOXFOBRSRwOp/YRM4WNRkCthj4jA8e3bcM589NVOpF79ADefVcSGHFlEbJ5M/D44zS7doSTE826tdqa+yhuFr6+5Iy2FQXAkmB34QKtHIzGBrVi4MJgS0kJ2QGrU7GRw2lKiANYQAAAciK3AUUgiVQ5QAcHky390iXLY0ePkinliy8qf3+tFhCEmvsobhYqleMVgEpFonH1KhXeMxi4j6FBk5lJiSapqSQS167R0s2avDxL2Fl1LHGM2W9XXl6v1RI5nBvCZKLvvdVAFxURgbaQC0OVA7RGQ+Kg19Nv4tw54NQpCjP98kv6zVWBXde36vgoGiJeXpSsl5tLf2tamqMOaThrl4aCyWRZ5l26ZKkimZtLj2s0JB6CQM4kQQCaN7dEa4gNxRmjbT09qSiW0Ujbe3rS0lKsEtmq1c0+Yw6nasRMX6umOTpzSYxEc6lspQFaMbtZpwM2bAC+/ZYmXs7OuPb66/CbPRu5q1bBd8qUKg/HUYmNWw5XV/tciAYAFwZH+PrSDEmtptl9cTEN7k5OlmbkRUX0f2Gh5b51IxHGSAiKiymqorCQHGi+vpYVR3IyCY6bG/3oCgroPVxdLcvLBpL0wml66PV6JCYmIiooCDrbFprnzwMAlq5ejQkuLnYDtKO6SRg2DGWbNiEjPBzugwZhW34+nn7jDfzMGAzvvIPLAQGOHdhWWHeI49QuPCrJlpQUGpxtHUbWMdSiMIj/l5ZaVgRiVymAHisutlR9BGhbMZnFZKL7YmKOmxuJh6+vpeSAdUYn5+bAGK0Yy8vrvHhZQyIhIQETJkywDOyzZiFu3DjLBhs2ANOmkSnIpqCePiPDYeTQjj17JMEQzL8LxhjiAUQD6FtZhJHRCHz/PfDggw3KWVtv8KikBoZGQwO1IMhrtQgCze49PCyPi9tpNGRHtLYdarU08Iv2xaAguoklfN3d6YMXY52zssjsJPo1CgrqrSY7ByQGej2t7K5dq/MaNQ0FvV4viQJgjjhasEAecZScTMXiFKqsOoocOnDokKwcBmMM4tw0E0Azq+0UOX4cePllYP/+Gz5HjmOaoOQ2METREFcM4v9OTpaa9/n59CPUaGjl0rw51YNxcmpwYW6NBsYsHb6KimjFVlpKn0kDtAnXNomJifYDu8mEpNRUy0w+Odmhj0yMHLLeh0qlAgMcdnMThQEARj/3HFLT0tD99tvl/gmxdebx48CAAdd5dpyq4CuGhohWS+Lg6kqDvp8fmbZE34NeT/bdixcpDppHN9Uu4iohJYWEOCCAPpOb0JT9ZhEVFWUfEmpbEK8SYdAFB+PxBx+UPcZMJlxIS7Pbr0gmADcAHiDxeGXhQvvMZlEYTpyo+Ulxqg0XhlsFUShcXYHAQBq8cnPJvJGcLC/axbl+SkpIEDIzqfdwURF2HjhAJhSxgXxVVFRQwbSKiro/3jpCp9MhPj7eEhKqUmHFwoWWmbvRSCHdDoRBn5GBtd9/L3uMAZi5eDEWT5+uKA5iepttfzJZ4lxuLj14/Ph1nRenenBhuBURBEvcs48PObiTk2kw46uHGyMri0TW3x8JmzbJ6/H8+GP1GrLn5pKf6Bb/LOLi4pCamoqd33+P1C1b5JFCaWk0OXEgDIkpKVCKazGaTOjeqRPWffCB3XOOhAGwSpwTVwx6vX1+EafW4MJwK+PtTdmTfn60orhwgX4wubnykr6c6lFYSCswLy/oL1+27xkwfz70qamVO6DLyqi0spjLcouj0+kQEx0NnU4nf8IcqlqZj0FQSNgSzVF9u3WzWzVcNf9VEgYpcS4nhwI3AG5OqkO4MDQWPDzIIZ2VReJw+fItP2OtVxij8gSMAc7OylE1JhOSkpNppuyIa9fIHKWU7X4rYjSS0922s9j58+R3cdDCUhccjJWLFsnEQSUIkjlKKXt5wYIFYIKAt8eNwzszZypnNufmAp060fedm5PqDB7O0phQq2k2lZtLolBQAISF1bg3LAASGFfXGsdK37Lk59Ns1Jy/ohRVo1arERkcTKsCpcik4mK6bp6etPpoDMIglm6xyngGQKbL8HBZ6LZtlrOYnXzg0CFAENCna1dZboJi9vKSJWjr44O2Eydi9P3322c2Z2dTVF779nzFUIdwYWhsaLWUF2E0WnrgenvTYFXdMEuTiWa+Wm3TEAaTiVYLarUU+ivOaCfOmgWj0SiftSo5oBkjUaiooOvdmITBnPEsG/iTk6XmPIDjLGddcDAeue8+h7u3y14OCKDrqPQcQN/p226j7X75pTbPlGMFF4bGiJhc5+dHM+HcXFpJaDSWEFi1mpLqDAaahQUEWEpvlJTQra4bqjcU8vLoJiYZmlGc0VoXULTGyj8h0ViEAfYDf767O4wPP4xD+/fDw93dzh8zYeZMxA4YUPOSFf7+dB3T0uj72MzG45CdTZ9Tq1bUBOjKlSaVjV5fcGFozKhUFLVkbT8XS3GoVJbyHNnZlmKAAA18JSWKGa2NDf2FC0jcvRtRwcHQmctJW2M3a3V2tpRAEUukmEyWworWda0aQwBAYSH02dmygd/dZIJ7QQH+u3o1vlq9GoIg2EUgmUwmvL96Nd6ZNatm7ycKw7RptGJdvdrynFiaxNcX6NOHHtu/n8pjcGoV7nxuCgiCpaprQADlQXh4kIO6sJCey8y0FArMzqYB0GC4pWPxqyIhIQFhrVph8JNPImzoULyzYkXVPYSdnOi6WDug8/KkVZnUh1hs+n4rYzQCJSVITE+X+VrMPcdwxvzXUbm1pZ99VvN+zAEBNIk5dw44cAD61FTLZ1JYSNfe15e2a9cO2Lev5ufliJwc4LPPKm8Y1ETgwtBUcHW1OKEFgf4PCLD0oq2ooB9EYSEJhJeXpb9vI0SpFpBipq0tYlkSURgqKmggc3JCwoYNlryH4cORUFXjmYaO0QhUVCCqVStZaGlb899zyq+yvNxkclzzyBHR0UBiIq0aSksxdtAg6TNZ/+WXtI1o8uvbl1YMtSXAb70FvPkmsHAhfe+PHAE2b66dfd9icGHgEN7etFK4do3uOzs3amFQqgUkUmWLSusM6NxcID8f+qIi+7yHF1+EXq+vg6OvJ0wmgDHoQkJkoaVtAaQDKLDaVBAEqBTyFkY/95xjkVVi+HDJqW0EMMQ86JtMJix95x3aRhSGfv0ow7wmLT1TU0kAxAxqa8zRU9i0CYiKAkaMAF54Adi7t/r7byRwYeAQGg2ZSbKz5ZFIjVQYosLCHNbsAeQtKiXzkCgUGg2trMrLaZXl5obE1FTlPsRJSXV1CnWPyST5o+JGjULq3r34dvlytIO8axsAvD1jBuIXLbK7ptYia3cdldBogFmzUOrnhx8B3GX1lI94fUVh6NmT/DzVNSclJdFgv3IlsHWr/LmcHCqFsmgR+d/c3YHly0mkEhKqt/9GBBcGjgVPT7qJJie1GvrkZOzcufPWnvkqkZeHF8eMgdqBOIiZtgnr10vmoZZ9++LlBQugz84mB3RWFpnd3N0d9yGOjKyPs6kbjEZLoAIghZ7eGRyMc+bVgUqlwtszZ2LaxImIGzVKsdSF0WjE+6tXy8qLVOrPufNOZP30E34UBHQDIIYENBNXJKIweHoCnTtXrwR3Zibw6KPkX4uIsH/NkSP0t1cveu7PP4H77gOeeAL44w/lFUYjhgsDx4LoezCT8OOPCOvdG4MHD0ZYWBgSGsnMKeHTTxHWvTuWfPklTIxh2oQJipm2AOx6ByyJj0fYnXci4dtvLclsUOhDrFJhxdtv25eSuJVQMrWZTPDPycGoqVOxc906XNi3Dy9PnEimNZNJsdSFSqXCe599ViN/ji44GHebI5ruBH0mU2NjyfdlnY/Trx9w4ID8WAsLqX+06N/IzwdefJEE7ptvyFz1559y38SRIyQ4YWEUnSc2xho0iEyqhw/X9Ord0vAObrY46uDWxHDYgSs19ZYe7PR6PcLCwhQ7iwGQ5Szs3L8fg8eMUdyPWqVC6pYt0HXoIN9/Rgbtw8cHuk6dHJaMuCXIyaEMZ+swXr0e6N+fwkgHDaLHjEbyTalUgLMzEn76CRNfe01KDPy/uDgsiY93+DbqSjq2GQYPRlaLFjAuWgTdRx8BBw8C27dbNvjzT2D0aDINdexIj02eDGzbRv+/+SawcSNw7BhFHA0aBOzcCTz1FLBuHTBzJtCiBXD2LNChgzw8FiDxiI4Gxo8Hpk69nqtYu9RTBzeex8BRxFEHrqSkpIYpDIxR/oVt6QYbEk+cUD6v1FTE9OkjG5yUymJIrzGZkJSbC9srIeU9NIZChgrHf/XgQQQCyPD0hHSlDAaaxTdvDmRnI27IEMR264aka9ek/g3WKwZbxOuvJAxOgwYheNs22ndaGkoCAvDn/v2IiogAACSVleEOb2+ov/gCWLyYQoe3bwfmzQNOnwZee4129OWXJGgA0LUr/Z082dItsbAQeP11+4MTBBKcJlZ+o85NSR9//DEiIiKg1WrRrVs3/PHHH5Vuv3v3bnTr1g1arRatWrXCp59+WteHyFHglrOZi1VNS0oq3SzKz0/R6Xzw2DG7x0TzkNL2arUakQ4qiwKgAaWRCUPC+vWY/3//h1IALR95xGICMhopcMHfn5y1rVpBFxaGmMhI6Dw8oGveXGZms0WqnKpE//7URe/8eeScOoWEvXslf0/Lvn0x6Mkn8UJ+Pti339LgvXcvHfedd9Jq4e23aRUgigJA1oCoKBKFKVOAX38FFiwgn4ISXBhql/Xr1+OFF17Aq6++isOHD+OOO+7AsGHDcPHiRcXtU1JScM899+COO+7A4cOHMWvWLDz33HPYuHFjXR4mRwHJZm4eFNVqNVasWNEwVwsADU5FReQMdkRREXQuLlj00kt2T814+21FR2jcqFFYPH06rAMxVYJgqZsES9TSP0eP4tstW/Dt1q2U4HarC4PRKLWe1WdkYMLMmWjDGJIAVDBmCemtqKDy74JAUUJ+flSyIiKCooyyshB3771I/eMP7Fy3znHlVCV69QKcnZG7dSs0V64g1fywda/oTxnDacZQ9tprwPffUy2l0FA6lkcftZi8rJk8mf4++SQQHAyMGSPvzW5Nx45UoqMJ9X+oU1PSe++9h7i4OIwbNw4AsGzZMuzYsQOffPIJFi5caLf9p59+ipYtW2LZsmUAgNtuuw0HDx7EkiVLMHLkyLo8VI4CcaNGIbZTJyQVFSGyV6+GKwoADWLl5fTj9fNT/pFnZwMmE7p36aLwcmVzhj4jA9MXL4bMEScIiDX3G7auISTfRMDKt95C3MyZN3pmN4+KCikiKTElBa1MJjwLQJymSdcsKsq+QKNGQysIb28y72RmQufkBN3ttyOmd2/lyqlKuLkB3btD2LYNngAuKB0mgOcB/HLsGImxaD6qjAcfBO65hwStKkTfxdGjQExM1ds3AupsxVBeXo5Dhw7h7rvvlj1+9913Y7+D8LIDBw7YbR8bG4uDBw/C0Ejj6Rs6utBQxHTu3LBFAZCSsVBcTKGkSs8XFgJarWMzmYI5Q8nXYjKZkJSaKs2ilWznjDFMfO21WzvM1ywM+owMXL12De+ZHxbPSHbNHBVcFAUiKorKdAsCkJUFna+vnU/HEXnR0fA+R3nWyrYGYKdajYxNm8jB/Pjj1Tu/6ogCQMfdqhUQF0dmpyZAnQlDVlYWjEYjgmwqHwYFBeHy5cuKr7l8+bLi9hUVFcgyl+K1paysDPn5+bIbpxZxcpJCERs0RiPNbsvLlc1JBgPdNBrFJjGOzBmViYiSaMgOyWS6tRPcKiqk9qajp05FLwB7AcyB1TUTCy9aFw9UQqOh6KaoKDLdVKNFqj4jAy+/9RbutPIzXjL/tc60Fo8lJDoaGDKk+gN+dVGpyDHt4wNMmgT89Zf8+cxM4NVXgR9/rN33vYnUeVSSbXs/xphiy7/Ktld6XGThwoWYO3fuDR4lxyEaDQ20BkPt/+BqE7HdprMzRQT5+8ufFwsCmgcwxZLaClTalwFwGLUEmNtYWvUsuNXQp6Vhwrx5MJlM6AJquTlaEBC/fLml6Y7BQNdUU82hxMmJcmWqiJJPWL8e42fMoPEC1PbTE0CmIODb5csRrtMh5eJFZOflwc/HB327dbuxk62KQYNIEB57jFYO69dTeKvRCLzyCrBrF9VV6t+fTJm3OHW2YggICIBarbZbHWRmZtqtCkSaN2+uuL1Go4G/7Q/dzMyZM5GXlyfdLl26pLgd5zrRaOyriTZEDAZyNrq4UGSS7fGKPZitJhi64OBqmTPEchA7161D6t69iBs1Snq9o2gbQRCwYu5c6EJDb/zcbgYmk2xFNBRUG2kvYwj087NcM3MTnypXDNYoiUhmpmQCFE104qSQAfgNQCoAI2P4++hR9H7wQYyaOhXPvPYaRj37bOWFD2sLjYbKYwQGAmKGd0ICsGcPsGQJrYKqiLqsMVevAhMm1HtUVJ0Jg7OzM7p164ZfbWxyv/76K/r27av4mj59+tht/8svv6B79+5wcvDFc3FxgZeXl+zGqTkO69iIA2lWVsMWB4OBlvwuLnSctn6GGhy7eC22/u9/eG/lSvxz5Ah0R48ipm1bOxGJGzUKB77/3q6AnAAgtm/fW7f0tsmEqBYtJDPaIAC7AJhsfTEGA63SHISiKqLR0PdKvDbl5bSPAirLp2SiexnAGNhnUVsOt4rCh7WFhwfw9NPAb79RUt/69cD99wMPP0y5FomJN7b/4mLg66+pLEd5OfD889Sp7rnn6vW7VKfhqi+++CI+++wzrFq1CqdPn8b//d//4eLFi5g0aRIAmu0/8cQT0vaTJk3ChQsX8OKLL+L06dNYtWoVEhISMG3atLo8zCaPdT0gceYlEwo/P4rouXBB2bHbECgvJ2EQBxzbYIXi4mrNaq2vxfC4OEx76y3sHzGCbMurVikKaGFREUy2jWoYQ9KFC9X/MTc00TWZoGvWDPHz50OtUqEbgINWYbrSdUhPr3lDJ7GFan4+BQQUFZF5ydwEScmvkwbgmEqFF8eNqzJRrs4ZNow+1/nzgfPnLY2C2rQBzpyp/LVV8fHHwKxZFD7brRtldo8fTxno58/f+LFXkzoVhlGjRmHZsmWYN28eOnfujD179mDbtm0ICwsDAGRkZMhyGiIiIrBt2zbs2rULnTt3xvz58/HBBx/wUNU6xDayxmQyYfyMGXKh+O47stkXFJA4VMNxWK8wRs5xcdaqUsn7MptMJGhVCIPttVADWAVgKqjM9NktW+wEFHDgoFapEKnTVU8YiouBixcb1nU1R3nFjRqFS999Bz8AU5csQdyoUfKJxD33UN2oStDr9fJCjM7OVPNIq7W0m/XxoQlIUZGdiU6lUmHahAlI3bcPzz/1lMOquJUmytUmAQHA4MHkU2jXDjCHLqNdO+Dkyeub2RsM5L9Yvhx46CFg+nTg9tuBjz4CXnqJxHfhQhLSeoDXSrKlidVKqqwekIhUy6Z5c8oTcHGh+jLu7jSYiQXHbhYVFVTrRqOhwSY/nwabyEhyDhoM1BHM1bXSPtbW18IZwDcA7gPwBIAOAOIAWFc+sq7xk7B+vdxBPW8e4u67jwaLqnpnZ2bSjDA4GGjZ0nGiVX1SXEzXzNubSkxMngz88w/0FRWV1tDS6/VITExEVFQUdDodEhISpIZIKpUK8fHxiIuLU37PoiIgMRH6wkIkXroED3d3FBUX2wUHWF9r62NYsWCB5P+pcxITacXw+usUaQUAu3dTwtz27fS514S//gJGjaJM7YcflvJHJH77jXpDdO8OvPcer5XEqVsqqwckIkv+8vOjhKXUVJr1GQz0Ba2kt0GdYzIBRiP02dlI1Oupf3OzZvR4WhoNtFYRSY4Qr4WryYRNAPoDeBDATwAeAhAMIAjAFfP21tfFLsopIIAG16rCfE0miqJydSXRDQio8Q++TrDqxYDjx4GgICAwEIn79zusobVjxw6ZCCxatAgzZsyQNy+aOBGxsbHKeTEuLkj48UdMmDvXIiQLFyJG7O9sxvpau7u5KYpHnRMVBaxdK3+sd2/67H77rebCsHcvVXcdOVL5tzRkCDm4J00i/0ObNvbb1CK87HYTR2nZbhsabLdE9/amwdbcfvGm5zgYjUj4/nuExcSQeUMsi11WRrPQvDy7iCRHPP/gg/gVQC9QJM5P5sebDxwIALDOmba9LrIoJ5WK3rOqBXlRkaXvtsnUcHpsW3+mJ06QWQPAwePH7TZVq9Vwd3e3a5VqLQoilTUv0qenS6Ig7sORQ1m81j2io6udKFfnuLgAAweSMFhjMJD4V2Yq3LOHWpVW5sSPjQV69ACWLbOEZ9cRXBg4snDMC/v2YeWiRVUnf4kNfcSZ5U1Ef/EiJsyfLx9Q5s+HPimJfpQlJVWuaBLWr0fLPn3w6MaNiAIwGMAe83OzpkzBR2vWoEyrRTebpCrFAenaNSr8Vh1hMEfiQK2mbW+GMIilnK0HG/EzZYxWDB07Qp+RgRmLF9u9fNHChSgsLFSMFKpJIcbE8+cdVr69ZRgyhHo7WIfNT59ODYV696ZWpHq93AeWl0fXWPRVOEIQgDfeoFVDHa/QuTBwAMhnu47i9u0QE95usjAo9W82mkxIOn2ahCEwsNKkI31GBsbPmIEhAHoDGAXAuoX94k8/hf7yZbhER2NWTAx2rluHA99/j1YtWtjPZisqgP/+lwYDsUyHI4xGixkJsGRu1zcGA1WmtS4SJ17PtDQgNxfHNBrsP3RI0eTYvUcPREVFKYrA4sWL5ZOMSgoxOtpHZHi4PBqsuLjyYok3k6FDadK0YgXdP32aCvv160diMGECJcENHWqZBPz7L13v3r2r3n+HDuT4rmM/FBcGjiLVSv5SqRrEiiEqPFw5KqhlS7pTxY8oMSUFjDH8H4DDAH63eV6atXboALfkZJy/eBG9H3xQMbw39/33aTDIz1deMVivCEpKyBRn1Uq1qrLhdYLBQAPtlSuWmaxZ1H4zD3CxS5Zg9NSpymbGyEjodDrEx8fbicC0adOQmpqKnTt3IjU11bHjGaB9LF4sr+i7YAF27Nkjjwb7+uuGKwxubuQk/vJL4LvvgE8/pUqva9ZQaW8xUS0lhRoGif87O1NARwOBO5851UKfkYHElBR4uLujsKgIURERFKVU18JQUUEDZiWDuy44GPGzZmHiwoWWqKDXXoMuMFDWq1c8h6iICLuGPLcBGAaKQLJF8iV06ACsWoVp06dDPGMxvFcQBISaTDgNoEKjgUbM9xDNM4xRLkh2NrWPdHYmEWDMYhbQaGjFUE1/SK1hMNBnWFJCiYyhoYDJBH1mJv7+4gu0B3DZfA6CIECtUsFoMlH70vfek1YAcXFxiI2NRVJSkiQWAA341S3CGPfEE4ht3x5J+fmS/8Y6CspkMmHiggWI7dsXOj+/mxv04Ii4OJocvPwy3Z8zhwIfRo6kyDMfH+oc9/XXwF13kTBERDSoc+HCYA1jFE+ekUFRB/7+tJRu6JVF6xil0tJixEjcnXfWrTCkp1O0RmUhsUYj4kaMQOy991qigjw9afZrnsFan4N07FalLb7v2RMZf/+Nb2x2rVarsfCVV5CYkoLfTp3CWAC3A7AufCD2BvgQQC6AzUYjJhYWQqNW0yzc2ZnsyKLfobycBoqcHHkoq1ptV9OpXhCzxj08SBi8vYGKCiTq9egKuVmNMYZ1H36IQH9/RHp5QXfHHbJd1UQEFFGroQsKklqm7lSKgjKZkHT5MnStWsl6lDco5swhXwJjFIYKkNj360f/jxlD4nD2rEUYGhBcGKxZsQJ45hnl5wYMoFu/fjSzat2aBp7AwIYRd15HOCotLUaMxP74I3R11dXNaKRrXFUERnk5DSgBAZaVQGkpmRsEQTGJb+KsWVJPhdSjR9HvyBHkT5iArzp1AgQB4TodioqLcfDYMUxfvBgmkwlqkP+hC+TCAAAPmG8jAdzGGEzFxTQzvHYNuHgR+vPnkXj1KqICA6GLiKDzKi2V9zHQaOix+haGkhJAo6Fw36NHEVVUBF1ICKLCwuAC4GOrTdVqNfp062YJx63t47SZNSuFU0vFCcvLG64weHgA39hOM6wYMYLqLE2dSpOf8ePr7dCqAxcGax5/nOx+np70o965k6ILOnSg1PQ9e+xfExpKkQgdOlAMelgY/fX0bFBLw+ulstLSRqMRSZcuQVdXK4aKCouZo6rtbK+1OMi6uzvsX/3+6tV477PP8JbJhM4AtgYF4TGr9o76jAzc+dhj0muNAI5DHrIKUNXPDwFsBfA9gGmCAI3BQBMGX18s+fBDTH//fZgYo9XKkiWIGzuWBjbrREqNhs6lPiOTGANKSpDwww+YMGeOZUU1bx7ievQAABw2+5JkkVilpTUvnlcdbMI1FavbvvoqdC1bkujeqmi1lBwnlgR6+OGbezw28MxnWxxlPl+6RINPfDy1G7x2jX7ABw9S3LJ1+JlIz55khiotBV58kfYbHX1LCYY+I8Mu01VErVYjdcsW6Hr2tC9zXV1yc2lw8vW1f66oCEhKIvENCHC8j3PnaJC1NTeVlABaLfSXL9udgyAIEAA0YwznAbwHYI5VJjOgnBX+KShyqbPVPt5hDJMAtAegV6uxe/hw9Nu6FUhKwjsrVuAVm26FarUaqfv2QefiYn/eWVnUFEbpetQFBgP0u3cjLDbWblZ+ee5cBLz+OtJ/+AHnbJPICgrIDFbbiVZFRfR5+vrKVuL6jAwyE+p0ZCZs1oxm2pV9Lxo6jJGTulUri4mpOq/JyeGZzw0GMWLAtvfDU0/RjzkvjwaitDS6XblCEQhnz9L/Q4bQ9iNGAHfcQV/qtm0pvtnf3zJTqm/HYxXYzthEpNljUNCN+RiKi0lglQbCigoa8Cvbv22dJGvMZhqlc2CMgQF4FUAZgCWwb++pZMY4DOBpAFpBQBmATozheQAzAVxSqfDn99+jx7lzwObN0F+6hOmLFtkdltFoRNKpU9D16aPsEK/j5CUZBoPyispkQuG//yIgIAAhnTohxPY7WVFBq+raRq2miZPRKCvPrQsOpusjVs51c7OssKrbC6KhIQjV7zZXz9yiV7SBERBgmbmI/WGtSUoC3n+fauJs3kw3a9zcyNbo4kKFsrRaioVPSQHGjqVsx8JC4MABcmA+/DDtw9ubZtOdOt3Qkv6fo0fxx99/446ePdEjOpoGWr2e6vagihIE167d2EBWXk6rLSVBNBrpVplpRTS9VFGPKG7UKAQFBGC4VbhkOIAJAGYDyAM51G0zmW3NGP0fewxOa9fi9dhYvL59O1YAOAlgKch3UVRcLAlS8tmzUFqQq1QqRDZvjoTNmzHh1VflDvG77qrfXIaKCkSFhtrb8dVqNMvJodIOShMVo7Fu7PsqFd0qKijk18dHvsIWy3S4utJ33tyVj1O78CtaH0RGAh9+SP8fOECOazc3WlmcOEFOKuuMUoMB+OQT+n/7djJHZWdbYreVOtZ5eVFkg7Mz1YW/5x4qY1BFhMjYl17C5xs3SvefHDkSa1q2BJYupebnZpOaNGOzRfwRXy/l5Y4jcQyG6gmDzexSiYT16zFu+nTZY3MAXAP5BwBaRezYs0eW0GdXA8nHB+zLL5GyfTsmAegJoC+oIb1KEEhYzKUPIps3V6xDtfj55wHGJFEArBziXbpAV19mJACoqIAuKEixS53b5s0UXOGIunCQq9V0E1eSZWVyB70oDE5OZEqxThDk1BpcGOob64JgbdvSbeRI4PJlEgqVigYWlYpmSydPAseOkU110CD6Yfz8M+1HtDH+/DO9NjMT+OcfemzLFhKJzp1JIF58ETh8mAbi5s2B0FBs/ecftNi4Ec8CWG4+pM83bsQ7wcEIBMgM1rNn5edzI8JgLn4nOZltBxox2auyFYkoDFamJFvzjBiVZE17AI+DSmqLqVKMMSlayVoEbUWxODgYw9LScCeAFQAOiK8HSFjMYhzi7S0bcFUqFRZNn45p99+PnadPK5d/0OuhM5elrxfMn51iq9PPP6dJjC3i4FwXM3WxC19uLpkXlYTByYlWMWJ4LafW4cLQUGjenG62tG8PPPKI/LFOneT3rfvdiuUCSkqAn34i5/iXX1JonBVlWi1UpaWYD6AcFFGTan6u3FzmYf/XX6NvVcIgCNdvShJNRQaDfWMdgERMtCM7oqJCll2slK/QqkULu0F4HoALAFbaHZLcz6BIx454KC0NVwDMsHpYFJbhn3yCZgBQUqI84BoMiLrtNkXzTWREhKLY1RlidBEUVoV5ecrl50XzTV2F1DZrRs5tV1f7DGej0dIYSKula1Rf16oJceuEx3Cqh5sb+TtatKBiW599BvzwAzUBWbUK+P13XHvrLXxdWoquIOdrFoA3zS/vB0DsUnz8hx+qbpUoOgqvB6PRUk/IVhhEwXByqnrFYLaBO8pX8HB3l5XM6A7KN5gLoELBfn7w2DHHrU4BuHfvDgB4EZTQJj9sIy6KYZTm7Gfb8iL6rCwkpqRg8fTp9sUKQ0MtglkfWCUB2pGfTyZKW0SzX10Jg6cnlfl2caHP1lrUGbO8r1ZL2yhFBHJuCL5iaAq0awe89ZZ099jly3ja6ulM0Mz5XQDjASQB+AdAR8aqnj2L9ZKuJ5pKHACdnOxbhoqzZhcXEgixL7AtVgObo3yFouJimUlnAYArPj54c+tWdPjpJ7tw0lcWLZKS2myzpAEgvW9fzBcEfK3gWFar1ZSRC+Dff/5Bs8BAuyYz1iuaRdOno0enTpbVhHhNaksYiorIxCgINGnw8bFcR7HMt5JJyGh03LCqooIG77qMngsOpvfJzpabk6z9SWo1HUdWVs3bi3Iqha8YmiC2rShXAzgN4AMAjwL4DMAxAB0BRFZl7xZndNcTsiquGJyc7E0GojC4udHA4Ki4XEkJDRCHD6O9weCwOqdYMfbwa6/hLgBBixZBp9Ohu7nPgDWMsUp7ApzNy8OnDqKNVixYgF1HjgAAZs2fL2sBqrSimfn22/L8ANE0Uon5zK5VptLjBQXkdzp/nuz1+flU7kW8L5b4VkoOBCwtJB2tGOrD4avRkB/NOkqLMbmQubs3nB4WjQguDE0Q2+Y8UKuR9sQT6A9aQq4BcEqlgjdQdVbzjQoDYAk7tP6BV1RAf/kydv75J/RXryo3OTGZLPbuhQsRtHSp7LxseybomjdH523byEcTGwtAuV+z/WHKewIovUalUuHPTZsQO2AApppzF1whFxZHKxrFfgNKK4bSUiS88w7CwsIwePBghIWFIcHsO0pISJA//u67FNDg7Ewlx729ycRYUUFtRMUe044iuvLyAABXKyrsTWqMVd2utLbw8LA3M1pfe63W8v3h1BpcGJootj0XhsydC/Tpg/LYWHyzbh0+FUNYz56tfEfWpqSaYjSSsIgOZqsfd8KaNQi77z4qtXzffUhYtcpefKydtFlZwJEjiIuJcdxL4vffqfb9yy9LZpDr6WBn+xq1Wo34hQvRIzoaiSkpKDJfC9G4IQ7+SoJivW/Jr3Hliv0suLAQ+j//xASFVpn//PMPxo8fL3t8wrx50BsM8pm9INAKwMuLrld6umPHbX4+AOCe55+XlReX9lNftZy0Wns/g/XxurjQNjXxM4h1qjgO4cLQhJE5RQUB+OIL5Lz+OhhjMAYFkf32zJnKd6JWX39LStFxbCMMer0eE158UT4AvvEGdWSzfb044xUdvr/+qtxLwmQC3nmHmqH07y9zLl9PBztHzYyiIiJQbhYWcUgWB38lQRH3nbB+vaXnwPDhSFizxvJmOTlASgoSk5IUVxxbN2+2S6QzMYYD//6rfN2dnKA3GLDz77+hz85W3ORqcjIA4Jp5v9LK59Il+szrUxhcXCwZ8LZhsioVfU9thaGsTDmgISeHVkpW5dglGKPHuWmKO585FhI2bpQ5RtNatkTzqlYMajX9kMQyBUoUFtIP1c9P7rA0V0WVMP8gK+vIprOuzWMWBn1aGnR5eWCCAOGXXyhr3JZffyWR27gRCd9+q1iCWxz8FUNMFVBK+tMFB2PFokUomT4dbrAXFqV9K0ZTTZ+O2AcfpLpA6emARoOojh0VQ1ybO4oqcrCKq6wEuciV5GQEQh51ZTQakXT0KHQxMfWXbazR0PeqoIBEQK22f293d0tTJEGwVNY1mUhYPDxou7w8+t/Dg8rU2DrexQz87GwKmW3C8BUDBwCVxbA1U2y+cAEGseNUZWg0lXfUEpP3bEs9lJVZ7MUqlTTri4qMVO7IZluor6ICCZs3o5e5fPavjMG4b59kBgEs5pmCP/4AQkPxj0Zjb45RaDhfrQ52DogbNQrOXl54/j//UWyNartvR7WKkv7+m4o3uroCnp72Kw6VCitmzcLwO+6wM38JgoA+1vktVtdDKaTX9vxDzCaoPKvH1CoVItu0sdQpqi88Pem7I64Obd/b1ZV8HuKqoayMfCotWljKmGdmkqgEB1tCYZW+j+7utK/S0pvTZrWBwIWBg4T169FrxAiYbGaYxxiD+sIFxR+IPiMD327Zgm+3biVzRGGhYwe0GGVjvUQ3R8Xor14lk05WlhR5pAsKQvzs2fIWj/PmQeftLTMZ6C9dwoQFC+BvPu54AGqjEec//1w6L9E8s+fLL3HUaFQ8z7poOK92d0drm1BVRyj6HlQqRHp60qBoVZPIzoQ1dix0bdpg5aJF0j5UKhVWLlqk+N7VdYD7CQLKtFoI1mavN96grGwrf0u9oNXSxEEMNLBdITk7k9+koMCSEyP6UpycSBR8fak8jIeHpSlRWRmZljIzLYEMvr5UBiQvjyYYev3Nabd6k+GmpCaOOINUKvZ2UqWCymikEMfbbpMeT1i/HuNnzJBeIwgCVs6ejbjp0+3DGMWIJdsQTKMRCd99hwlz51pMGnPnIm7WLMBgQNz99yP2rruQdPGixZwjioeLCwAg8exZmEwmiIv+fwEcBJD87rv43tkZM8y5CABwG4CNly9Dybhi61yuFWrgEFXsOfDWW9C1ayclw1lXX1UyYVXX/KXY+Ebp/PPy4OLvj9QNGyz7FAfg+q7+K/oZCguV8yoAqhpQWEg3QaDtXVxIANzcqCCkdSSVuzutZFUq2ufVqyQirq6U6yG+X1kZiYToBG8i8BVDE8dRIx6VSoVxs2fTHSs/gz4jQyYKgLkUxPz50JsdljKsK6RaOQP1Fy5IogBYOZhTUmhbkwm60FC5OUelssTXA4gKDoZKpYJY5u0qgM2g3s2vLVok7dsNQCtQFVSl81RyLtuRl0czSxscZkhrtTWaadqtBEaPRsL331sc0tZRQQ6ojvmrMge4NYUZGSgwm2ykfTJ2cwrWaTT0vhUV0qTADhcXmukbDCQEbm40kIeHU70n2/BaV1d6jZsbEBJC993c6K9GQ6XwW7Ykc5Sra5PLrubC0MSpLCb/8bFj6UdjFZmUmJKiuLowmkxIUnJUi0lsYqN7cT/nzinb1c+do+YxV67YD7haLZkLjEaAMegCAxE/dy6aCQJKABSCCtp5AmjJGFTmGZ641rEVBvE8bX0Adog5FM7OslWPLJLIduDWaisNiZQJyv79wD//yAb26voCqoOteDmKqLI+ry3ff4+DFy5YzkssT+JoYK5rRLNQZb6NwEASgZAQi7lJpVKe6bu60qrB25tWFe7uZEay/i0IAm2n1TY5fwMXhiZOZTH5AKj6q9WAHxURYefoBMw28YAA+0gYccUgOvSs9qNoVw8LoxyG4cPtB1wXF9pHSYnks4h75BFMf/hhXDXvI9H8t51KhcUzZkClUqG9+bHTVu8lRuNI5+mIsjK6BQfTwGQWhioHbldXhysGa0GJ6NuXGsM/8gj13xDPoybJcJXgSLwcrS7E8/IBkAObMFUnp/pLbLNFnN1XJgzWeRrVISzMUrgyPNxxiXGlJLtGDhcGTuUzyLZtacVgHvB1wcFYuWiRTBxUgkDOYR8f+5mVddmL8nLLfoKCED9rltykMWsWUFGBCdOnKw+4Ys6EKAzmKJUQjQZuoaFQq9XQAygB8Oo992DaxIn4c+NGdARVjhVzp6u9UhCbxQQHU9aws7N0flUO3A5WDLaCcoe1kFqtOKpKhqsONVl1/HP0KGa/+y6WxMfDZDLBB5ZQVaPRiKTz52lgvlltabXa2o+G0mjkUXGOfAguLteXwHkLw53PHADKDk19RgaueXsjOiMDmDePmperVJKj88ChQ4AgoE/XrtA1b05JZmVlcnODWNpBrZY35DEaETdiBGLvvdfi3NRqHfcpEIv5OTtbnIEVFbTfa9cQEBkpOUrVr72G3j4+wG+/oceMGWgRHo7D5gFbtKlXuVIwmShiJTCQYtrF+v/mUNgqnbiurnZhs4kpKbianS17zRgAyQC0gwYh5NdfgRkzpM9DqXlOTcJnHYnXgUOHEODnh6iICADAuFdewY4//pBt5wtaMUjnFRJS4x7DtYqTE83ub4aPw9nZkuF/C/VrvxG4MHAUsU6CmiwIWL5mDYTcXODttwEnJ+iCg/HIfffZv9DWSScKg0ZjiSkXTTKCIBek/HzJoWw74Lq7uWHn/v2I0umgY8xi9xcESkhq2dKyr6goIDUV+OsvICsLzbOy0H/MGOwcPrzSiB0ZOTkUnRISYhkMrGaOVQ7cWi0lUdlcS0EQIAgCGGNwBvAwgI8ATO7WDfjjD1nSlW1L1cKiIugzMqotDh4OBvLRU6fCxJh0HEr4gFYMst7eN8uMJHKzKqiKvo3y8rppZ9oAaRryx6kRtiaIjxnDfwCwLVuACRMcR9s4OZFz2Brbshei89Y26xkANBpyKNuYmP47YgR6P/gg2cljYpDw3XdyAcrOpqxqkYgIstdbOc09u3SpfsJaXh7NTEND5aUfzJ3D9Glp2Ll/P2IHDHBsgjObkmyvpXWI71DQALwOwJ85OXRt0tJkh6ILDsb5ixct5+8gOkkpOqpQqfAgIOVxiMfSA8Bwm218AQweOpTO66GHbq5/4Wbj7Gwp/95E4MLAsUPJBLGeMRx7+WWahf/3v8q1ZlxcKAPa+gfkoOwFysvtl+XmWVncvfdKA+6B77/HF5s2ye3kCxZAf/Gi5fXXrtkLQ1oacOQI0LcvCZNCeW1FRL+ATmdvtnB2RsKWLQi74w5pkN6xZ4+y4Jidz0rXUhyQHwJwAhQt9ezq1fSkjXO5On4CRw7m6lSOBYCZANYDCDHf1wJwARDdq5fUca5JCwNADu0mFJnEhYFjhyPHp//99wNff01lmx99lP63iqSRnLPWs3klYRB7AdiuGEQTk7+/FDVTWFTkOKxVrNOUl2cvDACtXkaNIjFr1656J19URI5mT0+7p/RXrmDCvHlVO3NNJqlmj/W11JlvKpUKYAxDAfxkfkmqyQSTRmMnDFU5uSsTDtHcVZU43AYq+DfXfN/X/PfghQv0j1iltYnY1xXRaul7ez3l5W9BmvAnzXFEpUlQnTsD331HNvhZs4BlyywvNA94kjDYCoBaTc+Vl9PNtkKnIFiif8w4jM4JDKQVhrlvAHx8LBuIwgCQOai6BdHEMuAOwh0dVTe1CyHNy6NzKCmRrmWYSoW/QWU7Fk2fjm6CgCAA28VTV6thDA2VCy2qjk6qSjjiRo3Cug8+UDwfQRDgAiASwBEAT4FEwsf8/Jtr15LoVVTcXMdzQ0AsT3LtWpOovsqFgaNIpSGskZHA1q3KL9RoLNnJYg6DOLCp1WSqKS2lWahZABxmDxuN0Lm6KotUhw7kjMwxx874+lpeZ11sLyQE1aa4mAZAB07OqKioqkNIS0rofMPDyfexfz/i7rsP51q3RjCAu0JC8PLEifjk7rtRAGCf1Tk5iU5zM2Ikk2JvaLPpqjphrX27dVNMYvxr82akrlsHDYC8KVNwAcBCWFYMWSYTCUx9NuZpqKjVlAkdGEjlMxp5PwcuDByHVFpiISgIGDLE3tns4mLpDCbexBWDiwsNnAUFUsx4pdnD69cDQ4cqi5RGQ/sQfR3WwmAdj16T8smlpWSScmAy0el0iH//fXlxP+tIJKORRDEoCBg2DOjRA3jlFeD55+Gcng6MHQvN5ctAeTm6X7sGzYAB+MX6nMLCALP5xvq6TF+8GAtfeUVRpKtT4qKyJMbm5hVX1D33YLYg4AEAYqxZgUqFSNEBf7MynhsSWi2FzPr5USiydUSXWFOpkeQ78HBVzvXj5UUtIq0R8wxKSy2dt6yFIT+fntNoHNrHYwcMoIHtzBkqdGY0KuZZALCsGKxNSdZUNyGqvJyOvQqTSdy4cYht2xZJmZmIbN1afkw5ObRaCQig/+fPBx56CPjf/4CVK2nfa9YAJ04A//4L1/nzEdOnj+X14eHApUtUNVahN3Tq3r2K18C2gB4ACu21KrznsMheUhLg7Y2Q9u0xaMEC/DtzJmaa9zt/3jzoAgLoTlNfMYi4uJCAJyaSGIjlMvLzyQ9TVGTp/3ALw4WB4xDRlCEmQtlW+YSXlyyJC4ClmX1pKQ0mtklBYj6DkxMSz5/HOJMJqwCIVltZMpsoOpVV1XQkDJs22YtWZRQX0/lUlUDl7AxdaCh0YnE1kYICuh8cTNdApaLIpo8/pn0PGQKIprIvv6TrEhMj37dOB1RU4OKRI5Un+SkgCmdlTXgUxTUpiUyDgoC4//wHV93cgOefBwCMfewx+ny9vJq249kWFxe6JtnZtJrKy6NVorMzlenmwsBprNgmZQEUZikbbJSEAaAfiziY2y6tXV1pMA8IQPuyMqwAkALgV/PTMvv4pUv0Nz/fsTDk5tIP0XZG26UL3aqDWP3V2hzlCJWKZomFhRZhKC8nn0l4uCUBSnTEWw/+QUH0/NatlIQXGirfd1AQACDS1bV6pbFtqHIFpkRysixiK/CBB8jcl5NDKz6DgTuelfD0pGq7BQU0KQkNtSRdip3kagvxN1SPZb/5NIBjh1JSlhh7LwvRdCQMzs40Sy4vt6+SqtWSucXJCUHmrOj25i+8zD5uMsmFwRHXrlVvQK+MggISnuoWX3N3t0SmMEYzxmbN5KsWURisEZ3S5eX2qwVAEoYrJ05U6nB2xHUV3tPryalqzejRwDPPWO5zM5I9Hh6WUuABAfTZurjI6mldN2IPdXHCcvUq9SKpx1BZvmLg2OGoR4OIZNbw8rIktNlmCBcXI2HNGmWzhnmgyUlKgi+AWUOHYsQTT8ht35mZlh9YZcKQnl6zyCNbxB9gYGD1zSXWRdXy8khQxHpKIkrCAJB9+swZYOBAu6cSfv0V/wUQv2wZPlapsGj6dPTo1KnaZTyq3YRHpLiYzCGOrp9YnoMLgz1OTvSdYcwyoRAzpMvLr99ZX1FBn4lGQ78rMYS7vJxWqQr5NXUBXzFw7KgqY1YabMQfhG1kkpMT9Hp9pRm7CevX4/133gEAnPj5Z5y/eFE++ImrBaX9W5Oebm+SscFhOKy4bx+f6q8WABoUVCpLn2uxJLc1joShdWsKh+3Rw+4YJ8yahXQAobA4nKtd2wnVb8IjkZ5Ofx1dPzHUuD77O99KNGtGqzzr34q7+/WXzjAYSBQCAykXp1kzoFUrahYUEEDO7nqKeuLCwLHDdoARBEFqeqNSqbDwlVdosBEHU4UZfeKlSw7NGqKpKsj8JW8L2GcQWzuOzftXHODT0ioVhkrDYcUs7ICAmtlvnZ0tfpTmzZVncWq18o84Lo4yxm1mlOIqLQ2W0hTX03+hqiY81lw9dgwAkGEraiKM0aDHHc/VR6u1FI6sKfn5JAohITRZCQ8ns6tGQ781T08yK9UD/BPnKGI9wFzcv5+a3ggCTCYTZixeTANsJcJQWeKVOAiK89hQAG62g+ClS/QjcXEBCgqQsH49Wvbti8FjxqBl3770/uXlVMHUgTBUWWcoP59+gDVdnotx/X5+JCpKOBIGf3/KHrdBvF5poOtBu7i+XtSy/JPSUuDcObvPKGH9esx+6SVUAAgbOVK5bagYUcaFofq4uFhKtdQEUUz8/ZVNd05OZIZ0FIRRy/BPnOMQcYABgOmLF0tVOcUBNkMsfaEgDDqdjqqkKiSDiYNgcwBHzdu3V6nkg+DFi7SE9vJCXlqarM80YwzjZ8xAxvHjNPg6EIZKnbHW9tvrifYICqL3ta33JGJlSqrMlCU+BwDxCxciQxAQiuo7nCslIwMYMQK4+26gUyfgiSeA7GxJMFswhjQABsYc13yqrIENxx53d5owWVe2NZnIeXztGv0vloqxRsyJqKy0uFZLgRaOvnO1CBcGTpU4GmDPZ2fTHSVTj7Mz4u65B6m7d9uZNURTVXMAu8z7e37AAPmbitEyAQHIPnHCrm8AYwxnd++mOw6cp5WWiygooB/Z9cace3lVXptfEKC/cgUvv/WWQ1OWrZkLAMY++ywitVplM9Avv6B82DAc/egjaRBXFJ3MTGDxYmD4cDrPVauoj8bJk8Dw4cj4/XeYTCaEATCXyVM2W1knJ3KqhyDQ98qqW6FUasXLi8QhO5tutlWIPTyqvt5ij+o6jlDiwlAZZWWWD8D6g24KFBVJUUGOBtjw226jO/n59rb8778HgoOha9FCsaxG3KOPIszJCWF9++ISgORdu+QDp7hi6NMHQVZ9FazJPm3u4iyuGERnsBmHzlix7MX1rhaqQcJXX6HlvfdiycqViqYsR2YuY2AgNKWl0FkJ1j9Hj+LXyZNhmjABzqdPI+yddxDTpw+GPvGE7Jp//dln1Gnvjjsoia5XL0r0GzyYquFu2QL4+6P73Ll4UhAQBkD05NiarfQZGdj511/Q15NNu1Hh4UHmSbFcS0kJmYhatqQVgdFI93NzLWNKdQsVurjQ972Ok+i4MDgiP59u6enk8CkqapzFs4xGCrm0nYEUFtLME5UMsDod4OmJXEcRSJcvS7uzm9nm50MwGLDuwAGcAdDO+nWpqeQ7aNECiImBW24uOioc+uFff8UVAAk//ECfi1iKwwpFZ2xBAfkH6ihxS6/XY8JLLyl2RxNn5o5WYRdFW7O5+9vYl17Cdw88gLu2bcPHoAJ3VwFsALB7zx6YTCY0A/COyYQH33wTpm+/BSZPBvbtAz76SF4rKiQE+PZbCA88gDWMoTdoxWBrtpJEfvx4hPXvj4SEhFq+Qo0cZ2cavAWBvmvOzpYkTH9/+u4FB5NIlJRYEuKqGxbs4lLn5j0eh6ZEYaHFzFBWZslwFXsai4XhxDhvUe0bii3WYKBjLCmhYxMdiKJ9E6BjFQR63s3NkuQlvl6sP2/GYa0dLy/k6vWVlnBQLNPQrRsAII0xnAEw2Op1aYcOUfvOFi0oe1mrRcLgwei7fTuMVu8jzngnzJyJTuHh6NGuncVWa4WsFIS5HIesAmstk5iY6DAPxHpmrpRzENSrF323DhzAP4WFaLtxI2YCmA9gtnm7kQD+BLASwGUAkwEYACwGMGTZMvQfMsTxwWm1ZFbq1AnqOXMwYsoUPPmf/0jXR3ElM3EiYmNjaSLAqR4eHhQ8kZYm71XdrJkl58XPjyaeGk2DyxfhKwZbXF3pQ9XpKJa4VSuKBggKssQtl5SQmUWjsZgvRJvh9Yaq1QYGAy1PCwvpfw8PmpkEBtKA4OJC59W6NZ2Tjw+ZU5o1o+3FQaqszBKSaSUOitVWPT0RoFY7tOU7MplcNZuBMgUBZ0E9AdTm17UWd9KyJR13nz7omZuL1H37MPu556T3EG3kJpMJvUePRsKWLVXHkBcWkijUYf9gpfLcAKBWqaSZuaNVWEj79pQVvWEDnOfNw0wAL8IiCgBwHMAkAP8FMB7AOwDCAbypViO8Q4eqD1AQgMcfh3DkCDr83//JPk+HDvukpBpcAQ4AGisiI+WrNnFCBtB3kDFLAUdHYcM3AS4Mtvj7k8KLZgZRxbVaGlSbNaOBNTISaNOG/rZsSTbFwkISiJwcmoGXljruj3yjMEb7FzumZWWR6cvNjcSsbVs6ztBQmnlHRlqSZnx86DwjIujm52c5foCO2c2NvqhW6f2Kjk4vL3gYjQ4TqxwNNFfPngUAvDp3LhJVKrgAaG0eOAPy8+m6iwPWwIHAP//g919/xTyrpjMtYXGemhjDxNmzoa+skYpY2M+621sdoNPpEL9smRSRpVKpMG3CBKTu2ydzKDvMORg5Ejh6FNH//ounASxVeI8vAMQAiAAwB0AugP+OGGHny6k0uc/T026V69BhHxlZ7fPnmFGryfLgKAtanKzl5ja4QoUN50gaCk5ONHg6+pAEgQZWV1f6X+zsJIpFaCg9r9VaupVlZ9d+16fsbEsN+JISek/xGLy8pMb1EhoNDfZK5i612pJZKQ6eAQGyBugOE8XM9ZIcDXJtgoLwrCDAT/Z2aoSoVIC7O5584gms2bQJALBv8WLEDhgA/Z9/whAaavkMYmIAgwHfv/GG7LCthQEwt/y8cgUoLVUeEMXVQlUVVGuBuCefROqWLdi5bh0u7NuHd2bNUgw9VVyF3Xkn0KEDMGcOTCNHyrZ/eNgwTJswASpBwG4AOVbPfbl5c7V6QVeG4kpmxQpuRqoLnJ0tE7UGVqhQYEoesluY/Px8eHt7Iy8vD141KXNQF5SV0aB97RqtIsTVx/UmqZSUWPwGzs60shFrtYiJNdeL0UglmMXaOWFhFDKalQV9aSnC+vWzs4en7t0L3UcfAQcOUM8BJX74AXj+eWwE8DAsq4lHjx6F+n//Q/bmzdA1bw506IC/YmLQd/t2bDGZUAHg6uLFksAUdO+OL7OyMNm822YArgAYAeAH62P6+2/s2LwZE956S+7TePRROrc2beqnLHJBASWWOUqAqwH/HD2KfQcPol/37ugRHQ0A+HbrVox69lm7bXeuW4eYPn2gz8hQ/MwOfP89CouK5OXTFdBnZCDp6FFE3nEHdO3b3/A5cBxgbUqqYx9lTcZG7nyuS1xc6ObuTjPxsjKayWdkWJxNoq/Cw4Oeq6iwFHZzdrbUqRG7Q4m2cXd3qRpnraBWky+irMxSrdTVFTAaK00U0/XoQaGRWVnKg6A5sml469bY+eabiAwPx449e/DD118jDEBMv36IX7gQj7dogePbtsEEIAo02M8wl4zesWcPSrKycK/VbsV6oOKKQa1SYcWSJYCrqyQKgFXp6T59oPP2rj87rpgYVgslmHtER0uCICK261QqmKfPyMC3W7cqfma9R4yAybZ8ugK64GDonJzIDMmpOwShQXbH46ak+sDJiezloaE0mAcEkPlJo6H/nZxoVZGbS3+LisiEU1xM97OyaNvmzWkmHxFhsb/XJt7etF9xRm2exUSFhztOFBOLwR08qLxPszA4Z2QgpndvABRFFAQgA5aB+4qbGyJAM5VwAEmggWzrb79hwowZ+BlkT29r3m2E+W/Cl1+S+WrLFsQ98QQS09OVRSw5ma5zfQmDIECfmenYvn+DOHJe79izB2H9+uGlt95SfJ1t9rrDY+N1kpo0fMVQX1g7PAMCLE5pNzdLzkB5Od339rasKMQQU9EZXJeIqwYR84pF5+mJ+IULKQHLaLQv19CiBfDnn8DQofb7FBOkioux7+efkWYywWQyoTkAc3oajEYjCgMC0Bq0EnACCYMgCJg8ezYYY9gJoBTAUABnAbz64IPAjh3o2q8fzbquXQPUakS1bas8kw4JoZlZPQ10CZ9/jgnPPqvYSc2OigqaFHh61mj2GDtgAL5etgyCSoU+XbsCgJ35SMT2mgBVdIXjdZKaNFwYbgZmx6uE6MC2zjloCDg7081gcJzHAFCG7d9/K+8jMxM5zZrBNzMTr0yejAOCAEEQEMwYxPQ3tVqN5t26wfu333C7uU90slXXOAAoAbAbwDAAy9VqtHJysiQR0YaASkURQe+9h4kvvgijyWQRMX//enPw6fV6SRSAanRSKy6mVZpYXbOq/Wdk4P1Vq/BeQoLUYe+l8ePRo1MnRVFY+vrr6Ne9O3o/+GD1ezWYTHRtG8p3kVOv8E+9IaHRNKwfoiDQSsUcmaQYQQMAPXsCp0+TH8QGQ3o6NpjNSa1BA70TYwgAJWeJA7dvp05QMYYvHn4YJo0Gi99/3y5zeDuAgQA+mzMHnjk5llIYYk0fs1kl7qmnpIggKUKKsXpLIFJKcKu0hLaYlCf2y64EscqsdakNxhiWxMdj9NSpUhtWEZVKJTmta9Srga8YmjR8xcCpHDe3qmvA9+5NA+/BgxRqaU1mJpJA/gQxcU2cE78wfTrmibH35sY8nocOAWFh6NOjh535Y4cgYCljGKvTUUapWL5abCgjDmIaDXQhIdC1a0diVVREIldP/gUxwa1as3Ox+52/v6U+lYNwWjFZ0FEgIWMMgiBArVJJGeImkwm9H3wQ8QsX2pmeKq3cyn0MTRr+qXMqpzqz7BYtyDFua04qLYVTcTGuCALOwyIMOvNg0+mOOyyDU0gIrZjOnwfMpirbGe5LCxfSKmH3bnnnNnF2K4brOjlZWiOaTOTD0WjqTRh0Oh3iP/lEseS4HWLlTXd3Wd6IElW1XAVIHJbPnSs1VgJIHMbPmIGwfv0waupUjJ46FTv27Kn8JPiKoUnDVwycyhFT9a36OuszMpCYkmKJhRcEMif99Zf8teaVxqinn0byqlWIYgxqtRrz/vtf4PPPse/CBYT5+9M+1GrKLE9NpcgrOKjPdPw4sH07OWvFpCtbYRBrz5SU0PFXVNRvRBKAuLg4xLZujaS0NES2aeN4dm4wUHiwaLarpL+1Uk9nW9RqNfx8faXoIxHGmLTSUPR5lJSQOUsUFJPJPkmS02Tg0wFO5VgLA4AlK1YgzNxJTZZN26sXDdrWDUrMvoVhjzyCB+Li0M3LC6l798KtoABGAAOmTJHvQyx+FxEh7cLOrzFwICBWbRX7MIhFDcXZrRgbLgqDWHqgPme/gkDH3rNn5aIgZqQDlig0B9iuolQqFWIHDLBbmYg5DpUh83kYDJSQZ91b22TivZ6bMFwYOJWjUlHEVFER3vnkE7y8cKFyLHyvXjRA//uv5bVmYUCzZvDu2BHO+fkQiorw66ZNuArAZLuPhx4C2renBjOO6NvXMvO3dT5b4+pKj7u43JySA2JEj60/wLosuFi5VxTEaqxorEuPXNi3D9vXrkXqvn0yR7uSgNg6pWU+D7E6cHm5RZgY48LQhOHCwKma4GDoTSZMf/ttu6ekmWfr1uRAtfYzZGbSYOfrS4UGAaT//TfaMIZUpX1MmABs20YDuSM8PIDu3UkIxMxvpUHMyYm20WqpHk0tlKaoEWIVTWthKCggU5HYErWsjMqZiIO22Teiv3TJLjHOuvaT7SpKKVrMVkBWLlrkOCJJNBN6elpWDXzF0KThnzynatRqJBYUKEbDqMRezUp+hsxMissXBMlv0ApAEIDvZLuvYdP7hx8ms4u4ShDt4dY4OVnMYDerPaVabREBg8HSvtFoJMGwLnFiPuaEH37AhLlzZYlxAOz7WThKlrPCug+Frb8GAHbu309+IrFsi6srkJxM15MLQ5OGrxg41ULMKLZl8fTplplnz57AkSMWc4koDABlfnt5wf/YMbQEsK86ETtm7CqljhwJfP65ZQOlQUyjufk1aPz8LD068vJoReXkBL1ej527d0OfkyNrKqS/fFkSBYDMbBNmzlTujncdZTbElYVYNkPWhtXFhTLuxVWDGK7KaZLwT55TLXQ6HeLj4y12a0HA29OmYdrEiZaNevYEysuR+fvv2Ll/P0r0ekuTEkEA+vcHNm4EAHy0YYN9HwIFEuLjqy4dzZj9qkAUhptZPNjHhwbbq1dJAIKCkLB5M8KGDsXgsWMRFhuLhC++kDZXSowzmUuIWFNZslyl/RfgoEPbggXQZ2aSEFg3beLC0GThZbc5VaLX65GYmIioqCgAQFJSEiL9/aETnb6enrSh0Yiyjh3xVmkp5jOGfwFoe/fGbd98Q89v3gy88AKZT06ckA08diGwAPRpaQi74w7lct/WK4xr14DwcHk9KsbocR+fm2sSyc+n5L3gYOiLixEWFmZ/Pqmp0Ol00Ov1ds+Lq7QqrwGg3ELVRnR37t+PwWPG2B3mzu3bERMbS4KQnGwpUV6Zv4dzS1GTsZFPCTiVkpCQgLCwMAwePBhhYWHYsWMHYmJioLv9dsojsIpk0Wdm4teSEtxhnmsEA/jmr7/wz9GjtLNBg0hIWre2iEJuLhJWrVJcFSSeP1+92bKS2UMQyOF8s+3knp7kX/H1dVwqw9w2U6zzZB1+Gr9wYbVKWThqoWq7clDs0KZSIbKtuW6tuGqwdopzmhzcu8RxiF6vx4QJExw3hnd3p4HXbHZITEnBblCrSS2omU46Y+g9YgTiFy2i2eudd1rCTEGrgglvvqlYcC5Kp6t+aYmGavYQBKmMucNSGVZtM+OefBKxUVFIys+XFSt0WMDQTKU9M6y2F0NZpUq5KhVWzJ0LnTk4AACJghjRxWmSNNBfE6chUNUMV2pGY94mKiICfwgC3EHlsVWgQnkmxiyz1xUrAKsWnYmXLjke0AICED9vXuWlJcRGODcr8qgG6HQ6xH/0kfx8bNtmqtXQNW9uF37qsIChGYe9mhVEVNaGdft2xI0ZY786cHe/Ja4pp27gKwaOQ6qc4Zpr6ejT05GYno6oiAhMeOstFM6ahdHm7UVDhqPa/1EtWzpeFRiNiPvPfxDbpYvdDFrCaKRVyy0yiMVNmIDYjh2RlJuLyM6d7XspixncNXT+2q0Eqoj2kkJZbSKjOByArxg4lWAbiWQ3w1WpkLBpE8IGD5b8A9cKCpDTujXuM+9DFAbF2Stj0AUFIX7OHOVVgbnUhS4oyPFsWexhcYsIA1Qq6Lp0QcywYfaiAFiEwVx+u6ooI2tkK4Eqor0kxBayHI4VPCqJUyV6vZ4ikSIjZYOZUhQNAMwC8Bao5IUzAJgH+9gBA+SRRxUVVPnU1RX6CxeQdO2aJB6JKSmI8vGhRvSO+kkDVJ1UEIC2bRuHs7SiAjh7FtBoKNntOhLb7CgpkUJ69dnZ8s8gKwto1crS55vTaOFRSZxaRafTUSSSzQxXyQcBAGJB56sA1n30EVL37gUA+8gjsY+CkxN0gYH2yVf33YeE776z27+MigoyJTUGUQCkhkP6tDTlKKNz52gwr+58Li+PIscAJHz9tf1nIAg3P3KL0+DgwsC5bqKiouyKswHAP6D+zBkAAs25BYqDXHo6DYTu7oDRqBxyOWMGJV85wmRqXDZyc0Mhh1FGly5RlFNubuX7KSsj/4EgAOHh0Ht4YML8+fJrO3Mm9FevcmHg2MGFgXPd6HQ63DVggN3jZQD2AbgEIDI83PEgl5JCwmAuXeFwO73ecTnqiorGZyN3dkZUixbK+Qa9e1O4r0pFJiJrDAZaIVy9SmVJxBwKLy8kJiXZX1uTCUlpabeOf4ZTb3Bh4Fw3er0evzroBBYnCCiaORO64GDHoZQ6naWBjlqNqLAw5e1atZLMIYo0thmviwt0/v7yxDaVCiuWLSOfi4cHEBxsaQVaWEhiUFREWeUREZS13Lo15STAEmFmjVqlQmREROO7fpwbhgsD57pJTExUrLj66H33Ye/+/RhtrqOk1KZzxYIF0DVrZmnDqVZT3oLtditWQBcZKe9jYEtjm/GaV1BxjzyC1B07sPOzz5B67Bjipk61bOPvTw55sW1py5ZAVJSl/LmNeU0xwmzePPIbNdTkQM5Ng0clca4bR7V9Luzbpxhaqs/IkGfvXrtGZpFmzSgSx2QC3N1pu6NHEdmzJ3RdulDdnuRkS6VWEcboubZt678RT11iNALnztGg7+xMg75S1JDBQL4EN7dqD+6yCLPAQNqHOTOb07ipydjI15Cc60an0yF+2TJMfOEFGE2m6idViYhVUQWBZrjmfse64GDonJykHg7QamllIUYgiYj3G9uKQa2m4nUGA9CiheNQUqs+1taFDhXzI8zodDr58ze7NDmnQcKFgXNDxD35JDW9d5SZXBXioO7qSrN/a0QREHs2l5bKZ7dir+fGaCMPCKBVUDVWvQkJCVJNK5VKhfj4eMTFxdXDQXIaK9y4yLkxVKrKM5OrQhQGJydLbL444Itd2VQqGiDN3dCkbGAxoqaxrRgAOvdqiIKjQod6vb6uj5DTiOHCwLkxxHIUjsJJARrQKyrkj4mlsq2FQeyRXFFhvxJwdwcYQ8I331iStO66CwmbNzee5LbroMpChxzOdcCFgXNjiIX00tIc1/TJziZHs/UAJmY9WwuDWk2PG42WaCURV1fos7MxYdYs+ez4tdea9OxYMQzVppQ3h1NTuDBwbgyxkN7AgY7bb6rVFDljnYtgKwwaDd0qKixJa9YrAWdnJF65wmfHNlRZ6JDDuQ54uCrnhtBfuICwVq0ct54UQ0rd3WnAF53HJSW0gmjXjgSCMQrRNBrJ9BQUBISEyN/r2DGEdenisDVmU8ZRoUMOR4QX0ePUG4nJyZW33xQdyaKZyLKRpcQ0QKsDFxcSD5NJscyFrlUrxL/2mqVEt0qFFe+/zwdCOC50yOFcD40wzo9Tnzhs5hMeDn1GBhLPnUNUcDB0t91GdXxEjEYKUbXGxcUiHkohqK6uiBs1CrExMUjKyECkvz90CrWaOBzOjcFXDJwbQqfTIf7DD+0a7Ujls598EmFDhyJhwwb5CxmzXxU4O5MwOCoFrVYDXl7Q+foipnt36EJCGmcOA4dzk+G/Ks4NEzdxImJvuw1JFy8ism1bANR7QRY9NG0aYrdsgU5suKPUOUyjIcHQaCw5DLa4uwNXrtxyLT05nFsJvmLg3DhqNXStWyMmOhq64GDH5bPT0iz5DGI5DGvEgb6ybGZXVxKN0lL6ywvAcTi1Dv9VcWoHDw9p0HdYZjsiQp7oZjuoiyGrla0EXFyoREZJCa/zw+HUEVwYOLWDVivlISiW2RZj662FQWnF4OZGBeQcIQiAt7clionD4dQ6dSYMqampiIuLQ0REBFxdXdG6dWu88cYbKK+s4QqAsWPHQhAE2a137951dZic2kIsdGf+fONGjULq3r3Y+emnSD18mIq6ubqSb8Bkkie3iajV1Jg+KKjy93Jzoxt3PHM4dUKd/bLOnDkDk8mEFStWIDIyEidOnMD48eNRVFSEJUuWVPraoUOHYvXq1dJ958bWurExolKROenaNRq0YVU+u2VL2karpVLS5eXkeFaa8VfHZ6DVcmHgcOqQOvtlDR06FEOHDpXut2rVCmfPnsUnn3xSpTC4uLigefPmdXVonLrC3R3IzLR/3LoeEkCZzR4e1z+wOzlRcx+zAHE4nNqlXn0MeXl58PPzq3K7Xbt2oVmzZmjTpg3Gjx+PTKXBhtPwsPIzAJBnPQOWCqrl5TfeNczbm68YOJw6ot5+WefPn8eHH36Id999t9Lthg0bhkceeQRhYWFISUnB66+/jsGDB+PQoUNwUTA9lJWVocxcpx+geiCcm4RWSyaisjIatG0L5bm60q2gwHGeAofDuenUeMUwZ84cO+ew7e3gwYOy16Snp2Po0KF45JFHMG7cuEr3P2rUKNx7773o2LEjhg8fjp9//hnnzp3DTz/9pLj9woUL4e3tLd1atGhR01Pi1BYqFeDpKTXUgckkXzGo1ZaZPhcGDqfBUuPqqllZWcjKyqp0m/DwcGi1WgAkCoMGDUKvXr2wZs0au/j26hAVFYVx48Zh+vTpds8prRhatGjBq6veLHJygPPngcBAoKiIxKJtW0sJ7bw84PJl6uds/o5wOJy6pybVVWtsSgoICECAWNagCtLS0jBo0CB069YNq1evvi5RuHbtGi5duoRgB20jXVxcFE1MnJuEaE4yGMiU5OIi76vg7k7N7XmkGYfTYKkz53N6ejpiYmLQokULLFmyBFevXsXly5dx+fJl2Xbt2rXDpk2bAACFhYWYNm0aDhw4gNTUVOzatQvDhw9HQEAAHnzwwbo6VE5totXSrbRUuXy2RkMRRbyUBYfTYKkz5/Mvv/yCpKQkJCUl2dWIt7ZenT17FnnmcsxqtRrHjx/H2rVrkZubi+DgYAwaNAjr16+Hp6dnXR0qpzYRBGpin55O9/nKgMO55eAd3Di1T34+kJhIhfIiIgB//5t9RBxOk4d3cOPcXFxdybcgRiVxOJxbCi4MnNrHyYmczEr1kDgcToOHCwOnbvDyIv8CFwYO55aDCwOnbnB1pVUDFwYO55aDCwOnbnB1pSQ3HpXE4dxy8CpknLpBDFvlcDi3HHzFwOFwOBwZXBg4HA6HI4MLA4fD4XBkcGHgcDgcjgwuDBwOh8OR0eiiksTST7yTG4fD4VgQx8TqlMdrdMJQUFAAALyTG4fD4ShQUFAAb2/vSrdpdNVVTSYT0tPT4enpCcG6QQyHw+E0YRhjKCgoQEhISJVN0xqdMHA4HA7nxuDOZw6Hw+HI4MLA4XA4HBlcGDgcDocjgwsDh8PhcGRwYeBwOByODC4MHA6Hw5HBhYHDqWXWrVsHrVaLtLQ06bFx48ahU6dOyMvLu4lHxuFUD57HwOHUMowxdO7cGXfccQeWL1+OuXPn4rPPPsOff/6J0NDQm314HE6VNLqSGBzOzUYQBLz11lt4+OGHERISgvfffx9//PEHFwXOLQNfMXA4dUTXrl1x8uRJ/PLLLxg4cODNPhwOp9pwHwOHUwfs2LEDZ86cgdFoRFBQ0M0+HA6nRvAVA4dTy/z777+IiYnBRx99hG+++QZubm747rvvbvZhcTjVhvsYOJxaJDU1Fffeey9mzJiBxx9/HO3bt0ePHj1w6NAhdOvW7WYfHodTLfiKgcOpJbKzs9GvXz8MGDAAK1askB5/4IEHUFZWhu3bt9/Eo+Nwqg8XBg6Hw+HI4M5nDofD4cjgwsDhcDgcGVwYOBwOhyODCwOHw+FwZHBh4HA4HI4MLgwcDofDkcGFgcPhcDgyuDBwOBwORwYXBg6Hw+HI4MLA4XA4HBlcGDgcDocjgwsDh8PhcGT8P9photQoZ134AAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data",
     "jetTransient": {
      "display_id": null
     }
    }
   ],
   "execution_count": 15
  },
  {
   "cell_type": "code",
   "id": "20573489",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2026-01-22T07:19:01.257159600Z",
     "start_time": "2026-01-22T07:19:01.193068500Z"
    }
   },
   "source": [
    "x = torch.ones(2, 1, 3)\n",
    "x = x.unsqueeze(-3).expand(*x.shape[:-2], 10, -1, -1)\n",
    "print(x.shape)"
   ],
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([2, 10, 1, 3])\n"
     ]
    }
   ],
   "execution_count": 16
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dgp",
   "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.13.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
