{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f5b14808",
   "metadata": {},
   "source": [
    "# DFN"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2efb5921",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce8269a4",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "from __future__ import annotations\n",
    "\n",
    "import cppimport\n",
    "\n",
    "import sys, time, math, io, contextlib\n",
    "from pathlib import Path\n",
    "from typing import Optional, List, Tuple, Dict, Any\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from IPython.display import display\n",
    "\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "_TOL = 1e-9"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "417583e0",
   "metadata": {},
   "source": [
    "## LEMON"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "62767112",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "repo = Path().resolve().parent\n",
    "if str(repo) not in sys.path:\n",
    "    sys.path.insert(0, str(repo))\n",
    "\n",
    "lemon_mcf = cppimport.imp(\"lemon_mcf\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15e6bd1b",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "88381d28",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'status': 1, 'flow': array([1., 2., 0.]), 'potential': array([-2.,  0., -1.]), 'reduced_cost': array([0., 0., 4.]), 'at_capacity': array([False,  True, False]), 'total_cost': 4.0}\n",
      "{'value': 4.0, 'flow': array([2., 2., 2., 2.])}\n"
     ]
    }
   ],
   "source": [
    "n = 3\n",
    "src    = np.array([0, 0, 1], dtype=np.int64)\n",
    "dst    = np.array([1, 2, 2], dtype=np.int64)\n",
    "cost   = np.array([2.0, 1.0, 3.0], dtype=np.float64)\n",
    "cap    = np.array([5.0, 2.0, 4.0], dtype=np.float64)\n",
    "supply = np.array([3.0, -1.0, -2.0], dtype=np.float64)\n",
    "\n",
    "out_min_cost_flow = lemon_mcf.solve_mcf(n, src, dst, cost, cap, supply)\n",
    "print(out_min_cost_flow)\n",
    "\n",
    "n = 4\n",
    "src = np.array([0,0,1,2], dtype=np.int64)\n",
    "dst = np.array([1,2,3,3], dtype=np.int64)\n",
    "cap = np.array([3.0,2.0,2.0,4.0], dtype=np.float64)\n",
    "out_max_flow = lemon_mcf.max_flow(n, src, dst, cap, 0, 3)\n",
    "print(out_max_flow)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75235271",
   "metadata": {},
   "source": [
    "## Dataset generators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67763cc2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def make_mdvsp_dataset(\n",
    "    K: int,\n",
    "    filename: str,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    max_trips=None,\n",
    "    max_succ=None,\n",
    "):\n",
    "    \"\"\"Multiple-Depot Vehicle Scheduling (MDVSP) dataset.\n",
    "\n",
    "    Returns:\n",
    "      X: (K, m) integer-ish capacities (float32)\n",
    "      y: (K,) min-cost-flow objective values (float32)\n",
    "      gt: dict containing the fixed network pieces (for later evaluation)\n",
    "    \"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "\n",
    "    with open(filename) as f:\n",
    "        m, n, l = map(int, f.readline().split())\n",
    "        f.readline()  # blank line\n",
    "        trips = np.loadtxt(f, max_rows=n, dtype=np.int64)[:max_trips]\n",
    "        D = np.loadtxt(f, max_rows=l, dtype=np.int64)\n",
    "\n",
    "    p, s, q, e = trips.T\n",
    "    ntr = len(trips)\n",
    "\n",
    "    # node ids\n",
    "    SS = 0\n",
    "    depS = 1 + np.arange(m)\n",
    "    depT = 1 + m + np.arange(m)\n",
    "    trS  = 1 + 2*m + np.arange(ntr)\n",
    "    trT  = 1 + 2*m + ntr + np.arange(ntr)\n",
    "    TT = 1 + 2*m + 2*ntr\n",
    "    N = TT + 1\n",
    "\n",
    "    src, dst, cost, cap = [], [], [], []\n",
    "\n",
    "    # depot boundary arcs (capacity is what we learn/provide per sample)\n",
    "    for d in range(m):\n",
    "        src += [SS, int(depT[d])]\n",
    "        dst += [int(depS[d]), TT]\n",
    "        cost += [0.0, 0.0]\n",
    "        cap  += [0.0, 0.0]\n",
    "    idxSS = np.arange(0, 2*m, 2)  # arcs SS->depS\n",
    "    idxTT = np.arange(1, 2*m, 2)  # arcs depT->TT\n",
    "\n",
    "    # trip arcs (always cap=1)\n",
    "    src += trS.tolist()\n",
    "    dst += trT.tolist()\n",
    "    cost += [0.0] * ntr\n",
    "    cap  += [1.0] * ntr\n",
    "\n",
    "    # depot-to-trip and trip-to-depot arcs\n",
    "    for d in range(m):\n",
    "        # depS -> trS\n",
    "        src += [int(depS[d])] * ntr\n",
    "        dst += trS.tolist()\n",
    "        cost += (5000 + 10 * D[d, p]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "        # trT -> depT\n",
    "        src += trT.tolist()\n",
    "        dst += [int(depT[d])] * ntr\n",
    "        cost += (5000 + 10 * D[q, d]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "    # feasible trip successor arcs (trT -> next trS)\n",
    "    order = np.argsort(s)\n",
    "    p2, s2 = p[order], s[order]\n",
    "    max_succ_eff = ntr if max_succ is None else int(max_succ)\n",
    "\n",
    "    for i in range(ntr):\n",
    "        travel = D[q[i], p2]                          # time from trip i end depot -> next trip start depot\n",
    "        feas = np.flatnonzero(s2 >= e[i] + travel)[:max_succ_eff]\n",
    "        j = order[feas]\n",
    "        if j.size:\n",
    "            src += [int(trT[i])] * j.size\n",
    "            dst += trS[j].tolist()\n",
    "            cost += (8 * travel[feas] + 2 * (s[j] - e[i])).astype(float).tolist()\n",
    "            cap  += [1.0] * j.size\n",
    "\n",
    "    src = np.asarray(src, dtype=np.int64)\n",
    "    dst = np.asarray(dst, dtype=np.int64)\n",
    "    cost = np.asarray(cost, dtype=np.float64)\n",
    "    cap0 = np.asarray(cap, dtype=np.float64)\n",
    "\n",
    "    # sample capacities X and compute y via max-flow + min-cost-flow\n",
    "    X = rng.integers(x_min, np.asarray(x_max) + 1, size=(K, m)).astype(np.float64)\n",
    "    y = np.empty(K, dtype=np.float64)\n",
    "\n",
    "    for k in range(K):\n",
    "        cap_k = cap0.copy()\n",
    "        cap_k[idxSS] = X[k]\n",
    "        cap_k[idxTT] = X[k]\n",
    "\n",
    "        Fmax = lemon_mcf.max_flow(N, src, dst, cap_k, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, dtype=np.float64)\n",
    "        supply[SS] = Fmax\n",
    "        supply[TT] = -Fmax\n",
    "\n",
    "        y[k] = lemon_mcf.solve_mcf(N, src, dst, cost, cap_k, supply)[\"total_cost\"]\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = dict(\n",
    "        type=\"mdvsp\", N=int(N), SS=int(SS), TT=int(TT),\n",
    "        src=src, dst=dst, cost=cost, cap0=cap0, idxSS=idxSS, idxTT=idxTT\n",
    "    )\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n",
    "\n",
    "\n",
    "def generate_bipartite_subset_matching_dataset(\n",
    "    K: int, num_nodes: int, c_min: int, c_max: int, noise_std: float = 0.0, seed: int = 0\n",
    "):\n",
    "    \"\"\"Assignment-style dataset: choose a subset of left nodes, match to right nodes with min cost.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    C = rng.integers(c_min, c_max + 1, size=(num_nodes, num_nodes)).astype(np.float32)\n",
    "\n",
    "    X = np.zeros((K, num_nodes), dtype=np.float32)\n",
    "    y = np.zeros((K,), dtype=np.float32)\n",
    "\n",
    "    for k in range(K):\n",
    "        mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        while not mask.any():\n",
    "            mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        idx = np.flatnonzero(mask)\n",
    "        X[k, idx] = 1.0\n",
    "\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        y[k] = C[idx, :][r, c].sum()\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = {\"type\": \"assignment\", \"C\": C.astype(np.float32)}\n",
    "    return X, y, gt\n",
    "\n",
    "\n",
    "def generate_convex_quadratic_dataset(\n",
    "    K: int,\n",
    "    dim: int,\n",
    "    eigen_min: float,\n",
    "    eigen_max: float,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    x_star_zero: bool = False,\n",
    "):\n",
    "    \"\"\"y = (x - x*)^T Q (x - x*) + noise, with Q symmetric PSD.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    U, R = np.linalg.qr(rng.standard_normal((dim, dim)))\n",
    "    U *= np.sign(np.diag(R) + 1e-12)\n",
    "    Q = U @ np.diag(rng.uniform(eigen_min, eigen_max, dim)) @ U.T\n",
    "\n",
    "    x_star = np.zeros(dim, dtype=np.int64) if x_star_zero else rng.integers(x_min, x_max + 1, size=dim)\n",
    "\n",
    "    X = rng.integers(x_min, x_max + 1, size=(K, dim)).astype(np.float32)\n",
    "    d = X - x_star\n",
    "    y = np.einsum(\"bi,ij,bj->b\", d, Q, d) + noise_std * rng.normal(size=K)\n",
    "\n",
    "    gt = {\"type\": \"quadratic\", \"Q\": Q.astype(np.float32), \"x_star\": x_star.astype(np.int64)}\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1dfc62e4",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "89201b4a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 8) (50,) \n",
      " [[ 5.  5.  8. 10.  0.  1.  9. 10.]\n",
      " [ 2.  3.  9.  4.  3.  9.  2.  4.]\n",
      " [ 7.  6.  0.  0.  9.  8.  9.  5.]\n",
      " [ 8.  3.  4.  8.  1.  3.  1.  4.]\n",
      " [10.  1.  4.  4.  9.  2.  5.  2.]] \n",
      " [490251.12 366100.16 447590.56 326038.94 376371.84] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[0. 1. 1. 0. 0. 0. 0. 1. 0. 1.]\n",
      " [1. 0. 0. 0. 0. 0. 1. 1. 0. 0.]\n",
      " [0. 1. 0. 0. 1. 0. 1. 0. 1. 1.]\n",
      " [1. 1. 0. 0. 1. 1. 1. 1. 0. 1.]\n",
      " [0. 1. 0. 1. 1. 0. 0. 0. 1. 0.]] \n",
      " [ 9.  4. 13. 17. 11.] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[-47. -87.  -1.  69.  25. -87.  30. -31. -55. -14.]\n",
      " [ 75.  94. -72.  13.  53. -48. -46. -52. -58.  78.]\n",
      " [-57. -55. -75. -75.  56. -43.  61.  17.  72.  11.]\n",
      " [ 53.  62. -88.  12.  -9. -43. -10. -18.  -2.  64.]\n",
      " [ 65.  25.  42.  92.  28. -26. -84.  11. -54.  19.]] \n",
      " [1.5913905e+06 9.7035825e+05 7.8526031e+05 5.9535256e+05 1.0773938e+06] \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# NOTE: MDVSP requires that `filename` exists on disk.\n",
    "X, y, _ = make_mdvsp_dataset(\n",
    "    K=50, filename=\"RN-8-3000-03.dat\", x_min=0, x_max=10, noise_std=1.0, seed=1, max_trips=200, max_succ=5\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_bipartite_subset_matching_dataset(\n",
    "    K=50, num_nodes=10, c_min=1, c_max=10, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_convex_quadratic_dataset(\n",
    "    K=50, dim=10, eigen_min=1.0, eigen_max=20.0, x_min=-100, x_max=100, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70071f5f",
   "metadata": {},
   "source": [
    "## Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "07278db8",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _ste_round(x: torch.Tensor) -> torch.Tensor:\n",
    "    return x + (torch.round(x) - x).detach()\n",
    "\n",
    "class _MCFValue(torch.autograd.Function):\n",
    "    \n",
    "    @staticmethod\n",
    "    def forward(ctx, n_nodes, src, dst, cost, cap, supply):\n",
    "        n = int(n_nodes)\n",
    "\n",
    "        src = src.to(dtype=torch.int64).contiguous()\n",
    "        dst = dst.to(dtype=torch.int64).contiguous()\n",
    "\n",
    "        m = int(src.numel())\n",
    "        if (dst.numel() != m) or (cost.numel() != m) or (cap.numel() != m) or (supply.numel() != n):\n",
    "            raise ValueError(\"Bad shapes for MCF inputs.\")\n",
    "        if torch.abs(supply.double().sum()) > _TOL:\n",
    "            raise ValueError(\"Require sum(supply)=0\")\n",
    "\n",
    "        def as_np(t: torch.Tensor, dtype):\n",
    "            return t.detach().cpu().contiguous().view(-1).numpy().astype(dtype, copy=False)\n",
    "\n",
    "        out = lemon_mcf.solve_mcf(\n",
    "            n,\n",
    "            as_np(src, np.int64),\n",
    "            as_np(dst, np.int64),\n",
    "            as_np(cost, np.float64),\n",
    "            as_np(cap, np.float64),\n",
    "            as_np(supply, np.float64),\n",
    "            tol=_TOL,\n",
    "        )\n",
    "        if out[\"status\"] != 1:\n",
    "            raise RuntimeError(f\"LEMON failed (status={out['status']})\")\n",
    "\n",
    "        flow = out[\"flow\"]\n",
    "        pot = out[\"potential\"]\n",
    "        red = out[\"reduced_cost\"]\n",
    "        at = out.get(\"at_cap\", out.get(\"at_capacity\", None))\n",
    "        if at is None:\n",
    "            at = np.abs(flow - as_np(cap, np.float64)) <= _TOL\n",
    "\n",
    "        ctx.flow, ctx.pot, ctx.red, ctx.at = flow, pot, red, at\n",
    "        return cost.new_tensor(float(out[\"total_cost\"]))\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, g):\n",
    "        dev, dt = g.device, g.dtype\n",
    "        flow = torch.as_tensor(ctx.flow, device=dev, dtype=dt)\n",
    "        pot  = torch.as_tensor(ctx.pot,  device=dev, dtype=dt)\n",
    "        red  = torch.as_tensor(ctx.red,  device=dev, dtype=dt)\n",
    "        at   = torch.as_tensor(ctx.at,   device=dev, dtype=torch.bool)\n",
    "\n",
    "        grad_cost = flow\n",
    "        grad_cap  = torch.where(at, red, torch.zeros_like(red))\n",
    "        grad_sup  = pot.mean() - pot\n",
    "\n",
    "        return None, None, None, grad_cost * g, grad_cap * g, grad_sup * g\n",
    "\n",
    "\n",
    "class DFN(nn.Module):\n",
    "    def __init__(\n",
    "        self,\n",
    "        input_dim: int,\n",
    "        layer_sizes,\n",
    "        p_list,\n",
    "        big_cost: float = 1e6,\n",
    "        big_cap: float = 1e6,\n",
    "        seed: int = 0,\n",
    "        A_fixed=None,\n",
    "        alpha: float = 1e-6,\n",
    "        beta: float = -0.0,\n",
    "    ):\n",
    "        super().__init__()\n",
    "        self.alpha = float(alpha)\n",
    "        self.beta  = float(beta)\n",
    "\n",
    "        layer_sizes = list(map(int, layer_sizes))\n",
    "        if len(layer_sizes) < 2 or len(p_list) != len(layer_sizes) - 1:\n",
    "            raise ValueError(\"Need len(layer_sizes)>=2 and len(p_list)=len(layer_sizes)-1\")\n",
    "\n",
    "        self.n = int(sum(layer_sizes))\n",
    "        if self.n <= 0:\n",
    "            raise ValueError(\"sum(layer_sizes) must be > 0\")\n",
    "\n",
    "        # node indices per layer\n",
    "        layers, off = [], 0\n",
    "        for s in layer_sizes:\n",
    "            layers.append(torch.arange(off, off + s, dtype=torch.long))\n",
    "            off += s\n",
    "\n",
    "        L1, LK = layers[0], layers[-1]\n",
    "        if L1.numel() == 0 or LK.numel() == 0:\n",
    "            raise ValueError(\"First/last layer must be non-empty.\")\n",
    "\n",
    "        self.fix_node = int(LK[-1].item())\n",
    "        boundary = torch.cat([L1, LK[:-1]], 0)\n",
    "        self.register_buffer(\"boundary\", boundary)\n",
    "\n",
    "        gen = torch.Generator().manual_seed(int(seed))\n",
    "\n",
    "        def bipartite(U: torch.Tensor, V: torch.Tensor):\n",
    "            su, sv = int(U.numel()), int(V.numel())\n",
    "            return U.repeat_interleave(sv), V.repeat(su)\n",
    "\n",
    "        def sample_edges(U, V, p: float):\n",
    "            s, t = bipartite(U, V)\n",
    "            if p < 1.0:\n",
    "                keep = torch.rand(s.numel(), generator=gen) < float(p)\n",
    "                s, t = s[keep], t[keep]\n",
    "            return s, t\n",
    "\n",
    "        # learnable arcs between consecutive layers (both directions)\n",
    "        sf, tf, sb, tb = [], [], [], []\n",
    "        for i, p in enumerate(map(float, p_list)):\n",
    "            if not (0.0 <= p <= 1.0):\n",
    "                raise ValueError(\"p_list entries must be in [0,1]\")\n",
    "\n",
    "            s, t = sample_edges(layers[i], layers[i + 1], p)  # forward\n",
    "            sf.append(s); tf.append(t)\n",
    "\n",
    "            s, t = sample_edges(layers[i + 1], layers[i], p)  # backward\n",
    "            sb.append(s); tb.append(t)\n",
    "\n",
    "        src_param = torch.cat([torch.cat(sf, 0), torch.cat(sb, 0)], 0)\n",
    "        dst_param = torch.cat([torch.cat(tf, 0), torch.cat(tb, 0)], 0)\n",
    "        if src_param.numel() == 0:\n",
    "            raise ValueError(\"No learnable arcs (increase p_list / layer sizes).\")\n",
    "\n",
    "        s1, t1 = bipartite(L1, LK)\n",
    "        s2, t2 = bipartite(LK, L1)\n",
    "        src_fixed = torch.cat([s1, s2], 0)\n",
    "        dst_fixed = torch.cat([t1, t2], 0)\n",
    "        m_fixed = int(src_fixed.numel())\n",
    "\n",
    "        self.register_buffer(\"src\", torch.cat([src_param, src_fixed], 0))\n",
    "        self.register_buffer(\"dst\", torch.cat([dst_param, dst_fixed], 0))\n",
    "        self.register_buffer(\"cap_fixed\",  torch.full((m_fixed,), float(big_cap),  dtype=torch.float32))\n",
    "        self.register_buffer(\"cost_fixed\", torch.full((m_fixed,), float(big_cost), dtype=torch.float32))\n",
    "\n",
    "        nb = int(boundary.numel())\n",
    "        input_dim = int(input_dim)\n",
    "\n",
    "        m_param = int(src_param.numel())\n",
    "        self.cap_raw  = nn.Parameter(torch.zeros(m_param) + 0.542)\n",
    "        self.cost_raw = nn.Parameter(torch.randn(m_param) + 1.0)\n",
    "        self.b_raw    = nn.Parameter(torch.zeros(nb))\n",
    "\n",
    "        if A_fixed is None:\n",
    "            A = torch.zeros(nb, input_dim)\n",
    "            rows = torch.arange(nb)\n",
    "            A[rows, rows % input_dim] = 1.0\n",
    "            self.A = nn.Parameter(A)\n",
    "        else:\n",
    "            A_fixed = torch.as_tensor(A_fixed, dtype=torch.float32)\n",
    "            if A_fixed.shape != (nb, input_dim):\n",
    "                raise ValueError(f\"A_fixed must have shape {(nb, input_dim)}, got {tuple(A_fixed.shape)}\")\n",
    "            self.register_buffer(\"A\", A_fixed)\n",
    "\n",
    "    def forward(self, w: torch.Tensor) -> torch.Tensor:\n",
    "        capP  = _ste_round(F.softplus(self.cap_raw))\n",
    "        costP = self.cost_raw\n",
    "        b     = _ste_round(self.b_raw)\n",
    "        A     = _ste_round(self.A) if isinstance(self.A, nn.Parameter) else self.A\n",
    "\n",
    "        cap  = torch.cat([capP,  self.cap_fixed.to(w.device, w.dtype)], 0)\n",
    "        cost = torch.cat([costP, self.cost_fixed.to(w.device, w.dtype)], 0)\n",
    "\n",
    "        def one(w1: torch.Tensor) -> torch.Tensor:\n",
    "            supply = torch.zeros(self.n, device=w1.device, dtype=torch.float64)\n",
    "            supply[self.boundary] = (A.double() @ w1.double()) + b.double()\n",
    "            supply[self.fix_node] = -supply.sum()\n",
    "            return _MCFValue.apply(self.n, self.src, self.dst, cost, cap, supply)\n",
    "\n",
    "        out = one(w) if w.dim() == 1 else torch.stack([one(wi) for wi in w], 0)\n",
    "        return self.alpha * out + self.beta\n",
    "\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dims, out_dim):\n",
    "        super().__init__()\n",
    "        dims = [in_dim] + list(hidden_dims) + [out_dim]\n",
    "        layers = []\n",
    "        for a, b in zip(dims[:-2], dims[1:-1]):\n",
    "            layers += [nn.Linear(a, b), nn.ReLU()]\n",
    "        layers += [nn.Linear(dims[-2], dims[-1])]\n",
    "        self.net = nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.net(x)\n",
    "\n",
    "\n",
    "class MaxAffine(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int):\n",
    "        super().__init__()\n",
    "        self.W = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        return (x @ self.W.T + self.b).max(dim=1).values\n",
    "\n",
    "\n",
    "class LSET(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int, T: float = 0.01):\n",
    "        super().__init__()\n",
    "        self.T = float(T)\n",
    "        if self.T == 0.0:\n",
    "            raise ValueError(\"T must be nonzero\")\n",
    "        self.A = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        z = (x @ self.A.t() + self.b) / self.T\n",
    "        return self.T * torch.logsumexp(z, dim=-1)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7cca0120",
   "metadata": {},
   "source": [
    "## Training Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0a7db872",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _split_train_val_test(X: torch.Tensor, y: torch.Tensor, *, val_frac: float, test_frac: float, seed: int):\n",
    "    N = int(X.shape[0])\n",
    "    n_test = int(round(test_frac * N))\n",
    "    n_val  = int(round(val_frac  * N))\n",
    "    n_train = N - n_val - n_test\n",
    "    if n_train <= 0:\n",
    "        raise ValueError(\"splits too large; train set would be empty\")\n",
    "\n",
    "    g = torch.Generator().manual_seed(int(seed))\n",
    "    perm = torch.randperm(N, generator=g)\n",
    "    i_tr = perm[:n_train]\n",
    "    i_va = perm[n_train:n_train + n_val]\n",
    "    i_te = perm[n_train + n_val:]\n",
    "\n",
    "    return (X[i_tr], y[i_tr]), (X[i_va], y[i_va]), (X[i_te], y[i_te])\n",
    "\n",
    "\n",
    "def _fit_standardizer(Xtr: torch.Tensor, ytr: torch.Tensor, *, eps: float):\n",
    "    x_mean = Xtr.mean(0, keepdim=True)\n",
    "    x_std  = Xtr.std(0, unbiased=False, keepdim=True)\n",
    "    x_std  = torch.where(x_std < eps, torch.ones_like(x_std), x_std)\n",
    "\n",
    "    y_mean = ytr.mean()\n",
    "    y_std  = ytr.std(unbiased=False).clamp_min(eps)\n",
    "\n",
    "    return {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std}\n",
    "\n",
    "\n",
    "def _apply_standardizer(X: torch.Tensor, y: torch.Tensor, scaler):\n",
    "    Xn = (X - scaler[\"x_mean\"]) / scaler[\"x_std\"]\n",
    "    yn = (y - scaler[\"y_mean\"]) / scaler[\"y_std\"]\n",
    "    return Xn, yn\n",
    "\n",
    "@torch.no_grad()\n",
    "def _mse_norm(model: nn.Module, loader: DataLoader, device: str):\n",
    "    model.eval()\n",
    "    tot, n = 0.0, 0\n",
    "    for xb, yb in loader:\n",
    "        xb, yb = xb.to(device), yb.to(device)\n",
    "        pred = model(xb).squeeze(-1)\n",
    "        tot += F.mse_loss(pred, yb, reduction=\"sum\").item()\n",
    "        n += yb.numel()\n",
    "    return tot / max(n, 1)\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def _predict_in_chunks(model: nn.Module, X: torch.Tensor, *, chunk: int):\n",
    "    out = []\n",
    "    for i in range(0, int(X.shape[0]), int(chunk)):\n",
    "        out.append(model(X[i:i + chunk]).squeeze(-1))\n",
    "    return torch.cat(out, 0)\n",
    "\n",
    "\n",
    "import json, hashlib\n",
    "\n",
    "# ---- Caching / persistence helpers ----\n",
    "_CACHE_ROOT_DEFAULT = Path(\"saved_runs\")\n",
    "\n",
    "def _to_hashable(x):\n",
    "    \"\"\"Convert nested objects to a deterministic, hashable (and mostly JSON-friendly) form.\"\"\"\n",
    "    import numpy as _np\n",
    "    import torch as _torch\n",
    "    from pathlib import Path as _Path\n",
    "\n",
    "    if x is None or isinstance(x, (bool, int, str)):\n",
    "        return x\n",
    "    if isinstance(x, float):\n",
    "        return float(x)\n",
    "    if isinstance(x, _Path):\n",
    "        return str(x)\n",
    "    if isinstance(x, (list, tuple)):\n",
    "        return [_to_hashable(v) for v in x]\n",
    "    if isinstance(x, dict):\n",
    "        return {str(k): _to_hashable(x[k]) for k in sorted(x.keys(), key=lambda z: str(z))}\n",
    "    if isinstance(x, _np.ndarray):\n",
    "        h = hashlib.sha256(x.tobytes(order=\"C\")).hexdigest()\n",
    "        return {\"__ndarray__\": True, \"dtype\": str(x.dtype), \"shape\": list(x.shape), \"sha256\": h}\n",
    "    if isinstance(x, _torch.Tensor):\n",
    "        t = x.detach().cpu()\n",
    "        h = hashlib.sha256(t.numpy().tobytes(order=\"C\")).hexdigest()\n",
    "        return {\"__tensor__\": True, \"dtype\": str(t.dtype), \"shape\": list(t.shape), \"sha256\": h}\n",
    "    return {\"__repr__\": repr(x)}\n",
    "\n",
    "def _run_signature(dataset_type, dataset_params, model_type, model_params, train_sig):\n",
    "    return {\n",
    "        \"dataset_type\": str(dataset_type).lower(),\n",
    "        \"dataset_params\": _to_hashable(dict(dataset_params)),\n",
    "        \"model_type\": str(model_type),\n",
    "        \"model_params\": _to_hashable(dict(model_params)),\n",
    "        \"train_params\": _to_hashable(dict(train_sig)),\n",
    "    }\n",
    "\n",
    "def _run_id_from_signature(sig) -> str:\n",
    "    blob = json.dumps(sig, sort_keys=True, separators=(\",\", \":\"), ensure_ascii=True).encode(\"utf-8\")\n",
    "    return hashlib.sha256(blob).hexdigest()[:16]\n",
    "\n",
    "def _get_run_dir(cache_root: Path, dataset_type, model_type, run_id: str) -> Path:\n",
    "    return Path(cache_root) / str(dataset_type).lower() / str(model_type) / run_id\n",
    "\n",
    "def _cpuify(obj):\n",
    "    import torch as _torch\n",
    "    if isinstance(obj, _torch.Tensor):\n",
    "        return obj.detach().cpu()\n",
    "    if isinstance(obj, dict):\n",
    "        return {k: _cpuify(v) for k, v in obj.items()}\n",
    "    if isinstance(obj, (list, tuple)):\n",
    "        return [_cpuify(v) for v in obj]\n",
    "    return obj\n",
    "\n",
    "def _set_full_determinism(seed: int):\n",
    "    import os, random\n",
    "    import numpy as np\n",
    "    import torch\n",
    "    seed = int(seed)\n",
    "\n",
    "    # NOTE: For strict CUDA determinism, this env var should be set before any CUDA work.\n",
    "    os.environ.setdefault(\"CUBLAS_WORKSPACE_CONFIG\", \":4096:8\")\n",
    "    os.environ[\"PYTHONHASHSEED\"] = str(seed)\n",
    "\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed(seed)\n",
    "        torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "    # Determinism flags (will error if a non-deterministic op is used)\n",
    "    try:\n",
    "        torch.use_deterministic_algorithms(True)\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "    try:\n",
    "        torch.backends.cudnn.deterministic = True\n",
    "        torch.backends.cudnn.benchmark = False\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "    # Avoid TF32 variance on Ampere+ GPUs\n",
    "    try:\n",
    "        torch.backends.cuda.matmul.allow_tf32 = False\n",
    "        torch.backends.cudnn.allow_tf32 = False\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "def _seed_worker(worker_id: int):\n",
    "    import random\n",
    "    import numpy as np\n",
    "    import torch\n",
    "    worker_seed = torch.initial_seed() % 2**32\n",
    "    np.random.seed(worker_seed)\n",
    "    random.seed(worker_seed)\n",
    "\n",
    "def _try_load_cached_run(run_dir: Path):\n",
    "    artifact_path = Path(run_dir) / \"artifact.pt\"\n",
    "    if not artifact_path.exists():\n",
    "        return None\n",
    "    try:\n",
    "        return torch.load(str(artifact_path), map_location=\"cpu\")\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "def _build_model_from_params(model_type, model_params):\n",
    "    mt = str(model_type)\n",
    "    mp = dict(model_params)\n",
    "    if mt == \"DFN\":\n",
    "        model = DFN(**mp)\n",
    "    else:\n",
    "        mp.pop(\"alpha\", None)\n",
    "        mp.pop(\"beta\", None)\n",
    "        if mt == \"MLP\":\n",
    "            model = MLP(**mp)\n",
    "        elif mt == \"MaxAffine\":\n",
    "            model = MaxAffine(**mp)\n",
    "        elif mt == \"LSET\":\n",
    "            model = LSET(**mp)\n",
    "        else:\n",
    "            raise ValueError(\"model_type must be: DFN | MLP | MaxAffine | LSET\")\n",
    "    return model\n",
    "\n",
    "def _save_run(run_dir: Path, signature: dict, model: nn.Module, data: dict, history: dict, spec: dict):\n",
    "    run_dir = Path(run_dir)\n",
    "    run_dir.mkdir(parents=True, exist_ok=True)\n",
    "    artifact_path = run_dir / \"artifact.pt\"\n",
    "    if artifact_path.exists():\n",
    "        return\n",
    "    state_dict = {k: v.detach().cpu() for k, v in model.state_dict().items()}\n",
    "    artifact = {\n",
    "        \"signature\": signature,\n",
    "        \"state_dict\": state_dict,\n",
    "        \"data\": _cpuify(data),\n",
    "        \"history\": history,\n",
    "        \"spec\": spec,\n",
    "    }\n",
    "    torch.save(artifact, str(artifact_path))\n",
    "    try:\n",
    "        with open(run_dir / \"signature.json\", \"w\", encoding=\"utf-8\") as f:\n",
    "            json.dump(signature, f, indent=2, sort_keys=True)\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "def generate_and_train_simple(dataset_type, dataset_params, model_type, model_params, train_params=None):\n",
    "    \n",
    "    tp = train_params or {}\n",
    "\n",
    "    epochs     = int(tp.get(\"epochs\", 200))\n",
    "    batch_sz   = int(tp.get(\"batch_size\", 32))\n",
    "    lr         = float(tp.get(\"lr\", 1e-3))\n",
    "    wd         = float(tp.get(\"weight_decay\", 0.0))\n",
    "    val_frac   = float(tp.get(\"val_frac\", 0.15))\n",
    "    test_frac  = float(tp.get(\"test_frac\", 0.15))\n",
    "    eps        = float(tp.get(\"eps\", 1e-8))\n",
    "    seed       = int(tp.get(\"seed\", 0))\n",
    "    device     = tp.get(\"device\", \"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "    plot_every = int(tp.get(\"plot_every\", 0) or 0)\n",
    "    plot_points= int(tp.get(\"plot_points\", 2048))\n",
    "    plot_chunk = int(tp.get(\"plot_chunk\", 4096))\n",
    "    print_stats= bool(tp.get(\"print_stats\", True))\n",
    "\n",
    "\n",
    "    # ---- determinism (seed controls data, model init, dataloader order, etc.) ----\n",
    "    _set_full_determinism(seed)\n",
    "    # force dataset generation to use the same seed as training\n",
    "    dataset_params = dict(dataset_params)\n",
    "    dataset_params[\"seed\"] = int(seed)\n",
    "\n",
    "\n",
    "    # ---- cache check (skip training if identical run already saved) ----\n",
    "    train_sig = {\n",
    "        \"epochs\": int(epochs),\n",
    "        \"batch_size\": int(batch_sz),\n",
    "        \"lr\": float(lr),\n",
    "        \"weight_decay\": float(wd),\n",
    "        \"val_frac\": float(val_frac),\n",
    "        \"test_frac\": float(test_frac),\n",
    "        \"eps\": float(eps),\n",
    "        \"seed\": int(seed),\n",
    "        \"deterministic\": True,\n",
    "    }\n",
    "    cache_root = Path(tp.get(\"cache_root\", _CACHE_ROOT_DEFAULT))\n",
    "    signature = _run_signature(dataset_type, dataset_params, model_type, model_params, train_sig)\n",
    "    run_id = _run_id_from_signature(signature)\n",
    "    run_dir = _get_run_dir(cache_root, dataset_type, model_type, run_id)\n",
    "\n",
    "    cached = _try_load_cached_run(run_dir)\n",
    "    if cached is not None and isinstance(cached, dict) and \"state_dict\" in cached and \"data\" in cached and \"history\" in cached and \"spec\" in cached:\n",
    "        model = _build_model_from_params(model_type, model_params)\n",
    "        model.load_state_dict(cached[\"state_dict\"])\n",
    "        model = model.to(device)\n",
    "        return model, cached[\"data\"], cached[\"history\"], cached[\"spec\"]\n",
    "\n",
    "    # ---- data ----\n",
    "    dt = str(dataset_type).lower()\n",
    "    if dt == \"mdvsp\":\n",
    "        X, y, gt = make_mdvsp_dataset(**dataset_params)\n",
    "    elif dt == \"assignment\":\n",
    "        X, y, gt = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "    elif dt == \"quadratic\":\n",
    "        X, y, gt = generate_convex_quadratic_dataset(**dataset_params)\n",
    "    else:\n",
    "        raise ValueError(\"dataset_type must be: mdvsp | assignment | quadratic\")\n",
    "\n",
    "    X = torch.as_tensor(X, dtype=torch.float32)\n",
    "    y = torch.as_tensor(y, dtype=torch.float32).view(-1)\n",
    "\n",
    "    # ---- print a quick dataset stats ----\n",
    "    if print_stats:\n",
    "        with torch.no_grad():\n",
    "            xmn = X.mean(0)\n",
    "            xsd = X.std(0, unbiased=False)\n",
    "            print(\n",
    "                f\"\\n--- Dataset stats ({dataset_type}) ---\\n\"\n",
    "                f\"  X: shape={tuple(X.shape)}  mean(mean)={xmn.mean():.3g}  std(mean)={xsd.mean():.3g}  \"\n",
    "                f\"min={float(X.min()):.3g}  max={float(X.max()):.3g}\\n\"\n",
    "                f\"  y: shape={tuple(y.shape)}  mean={float(y.mean()):.3g}  std={float(y.std(unbiased=False)):.3g}  \"\n",
    "                f\"min={float(y.min()):.3g}  max={float(y.max()):.3g}\\n\"\n",
    "            )\n",
    "\n",
    "    (Xtr, ytr), (Xva, yva), (Xte, yte) = _split_train_val_test(X, y, val_frac=val_frac, test_frac=test_frac, seed=seed)\n",
    "\n",
    "    scaler = _fit_standardizer(Xtr, ytr, eps=eps)\n",
    "    XtrN, ytrN = _apply_standardizer(Xtr, ytr, scaler)\n",
    "    XvaN, yvaN = _apply_standardizer(Xva, yva, scaler)\n",
    "    XteN, yteN = _apply_standardizer(Xte, yte, scaler)\n",
    "\n",
    "    g_dl = torch.Generator()\n",
    "    g_dl.manual_seed(seed)\n",
    "    train_loader = DataLoader(\n",
    "        TensorDataset(XtrN, ytrN),\n",
    "        batch_size=batch_sz,\n",
    "        shuffle=True,\n",
    "        generator=g_dl,\n",
    "        worker_init_fn=_seed_worker,\n",
    "    )\n",
    "    val_loader   = DataLoader(TensorDataset(XvaN, yvaN), batch_size=batch_sz, shuffle=False)\n",
    "\n",
    "    # subset for plotting\n",
    "    Nv = int(XvaN.shape[0])\n",
    "    if plot_points <= 0 or plot_points >= Nv:\n",
    "        plot_idx = torch.arange(Nv)\n",
    "    else:\n",
    "        g_plot = torch.Generator().manual_seed(seed + 12345)\n",
    "        plot_idx = torch.randperm(Nv, generator=g_plot)[:plot_points]\n",
    "\n",
    "    # ---- model ----\n",
    "    mt = str(model_type)\n",
    "    mp = dict(model_params)\n",
    "\n",
    "    if mt == \"DFN\":\n",
    "        model = DFN(**mp)\n",
    "        extra = f\"layers={mp.get('layer_sizes')} p_list={mp.get('p_list')} alpha={getattr(model,'alpha',None)} beta={getattr(model,'beta',None)}\"\n",
    "    else:\n",
    "        mp.pop(\"alpha\", None)\n",
    "        mp.pop(\"beta\", None)\n",
    "        if mt == \"MLP\":\n",
    "            model = MLP(**mp)\n",
    "            extra = f\"hidden={mp.get('hidden_dims')}\"\n",
    "        elif mt == \"MaxAffine\":\n",
    "            model = MaxAffine(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')}\"\n",
    "        elif mt == \"LSET\":\n",
    "            model = LSET(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')} T={mp.get('T')}\"\n",
    "        else:\n",
    "            raise ValueError(\"model_type must be: DFN | MLP | MaxAffine | LSET\")\n",
    "\n",
    "    model = model.to(device)\n",
    "    opt = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=wd)\n",
    "\n",
    "    n_params = sum(p.numel() for p in model.parameters())\n",
    "    n_trainable = sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "    print(\n",
    "        f\"\\n=== Run: {dataset_type} | {model_type} ===\\n\"\n",
    "        f\"  data: N={len(X)}  train/val/test={len(Xtr)}/{len(Xva)}/{len(Xte)}  dim={X.shape[1]}\\n\"\n",
    "        f\"  model: params={n_params:,} {extra}\\n\"\n",
    "        f\"  train: device={device}  epochs={epochs}  batch={batch_sz}  lr={lr:g}  wd={wd:g}  seed={seed}\\n\"\n",
    "    )\n",
    "\n",
    "    history = {\"train_mse_norm\": [], \"val_mse_norm\": []}\n",
    "    best_val, best_ep, best_state = float(\"inf\"), 0, None\n",
    "\n",
    "    live = display(None, display_id=True) if plot_every > 0 else None\n",
    "\n",
    "    for ep in range(1, epochs + 1):\n",
    "        model.train()\n",
    "        for xb, yb in train_loader:\n",
    "            xb, yb = xb.to(device), yb.to(device)\n",
    "            loss = F.mse_loss(model(xb).squeeze(-1), yb)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "        tr_mse = _mse_norm(model, train_loader, device)\n",
    "        va_mse = _mse_norm(model, val_loader, device)\n",
    "        history[\"train_mse_norm\"].append(tr_mse)\n",
    "        history[\"val_mse_norm\"].append(va_mse)\n",
    "\n",
    "        if va_mse < best_val:\n",
    "            best_val, best_ep = va_mse, ep\n",
    "            best_state = {k: v.detach().cpu().clone() for k, v in model.state_dict().items()}\n",
    "\n",
    "        if plot_every > 0 and (ep == 1 or ep % plot_every == 0 or ep == epochs):\n",
    "            model.eval()\n",
    "            x_plot = XvaN[plot_idx].to(device)\n",
    "            y_true = yvaN[plot_idx].to(device)\n",
    "            y_pred = _predict_in_chunks(model, x_plot, chunk=plot_chunk)\n",
    "\n",
    "            fig, ax = plt.subplots(1, 2, figsize=(10, 4))\n",
    "            ax[0].plot(history[\"train_mse_norm\"], label=\"train\")\n",
    "            ax[0].plot(history[\"val_mse_norm\"], label=\"val\")\n",
    "            ax[0].set_yscale(\"log\")\n",
    "            ax[0].set_title(f\"Epoch {ep}/{epochs} | val MSE={va_mse:.3e} (norm)\")\n",
    "            ax[0].legend()\n",
    "\n",
    "            yt = y_true.detach().cpu().numpy()\n",
    "            yp = y_pred.detach().cpu().numpy()\n",
    "            ax[1].scatter(yt, yp, s=10)\n",
    "            lo = float(min(yt.min(), yp.min()))\n",
    "            hi = float(max(yt.max(), yp.max()))\n",
    "            ax[1].plot([lo, hi], [lo, hi])\n",
    "            ax[1].set_xlabel(\"y_true (norm)\")\n",
    "            ax[1].set_ylabel(\"y_pred (norm)\")\n",
    "            ax[1].set_title(f\"Val scatter (n={len(yt)})\")\n",
    "\n",
    "            plt.tight_layout()\n",
    "            live.update(fig)\n",
    "            plt.close(fig)\n",
    "\n",
    "    if best_state is not None:\n",
    "        model.load_state_dict(best_state)\n",
    "\n",
    "    if print_stats:\n",
    "        print(f\"[DONE] best val MSE (norm) = {best_val:.3e} @ epoch {best_ep}\\n\")\n",
    "\n",
    "    data = {\n",
    "        \"raw\":  {\"Xtr\": Xtr,  \"ytr\": ytr,  \"Xva\": Xva,  \"yva\": yva,  \"Xte\": Xte,  \"yte\": yte},\n",
    "        \"norm\": {\"Xtr\": XtrN, \"ytr\": ytrN, \"Xva\": XvaN, \"yva\": yvaN, \"Xte\": XteN, \"yte\": yteN},\n",
    "        \"scaler\": scaler,\n",
    "        \"best_val_mse_norm\": float(best_val),\n",
    "        \"best_epoch\": int(best_ep),\n",
    "        \"stats\": {\"n_params\": int(n_params), \"n_trainable\": int(n_trainable)},\n",
    "        \"true\": gt,\n",
    "        \"device\": device,\n",
    "    }\n",
    "\n",
    "    spec = {\n",
    "        \"model\": model_type,\n",
    "        \"extra\": extra,\n",
    "        \"n_params\": int(n_params),\n",
    "        \"n_trainable\": int(n_trainable),\n",
    "        \"model_params\": dict(model_params),\n",
    "        \"train_params\": {\n",
    "            \"epochs\": int(epochs),\n",
    "            \"batch_size\": int(batch_sz),\n",
    "            \"lr\": float(lr),\n",
    "            \"weight_decay\": float(wd),\n",
    "            \"seed\": int(seed),\n",
    "            \"device\": str(device),\n",
    "            \"val_frac\": float(val_frac),\n",
    "            \"test_frac\": float(test_frac),\n",
    "        },\n",
    "    }\n",
    "\n",
    "\n",
    "    # ---- save artifacts for this run ----\n",
    "\n",
    "    _save_run(run_dir, signature, model, data, history, spec)\n",
    "\n",
    "\n",
    "    return model, data, history, spec\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ace7f63f",
   "metadata": {},
   "source": [
    "## Optimization Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "38416530",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def eval_true_obj(gt, x):\n",
    "    if not isinstance(gt, dict):\n",
    "        return np.nan\n",
    "\n",
    "    x = np.asarray(x).reshape(-1)\n",
    "    t = gt.get(\"type\", None)\n",
    "\n",
    "    if t == \"quadratic\":\n",
    "        Q = np.asarray(gt[\"Q\"], float)\n",
    "        xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "        d = x.astype(float) - xs\n",
    "        return float(d @ Q @ d)\n",
    "\n",
    "    if t == \"assignment\":\n",
    "        C = np.asarray(gt[\"C\"], float)\n",
    "        idx = np.flatnonzero(x > 0.5)\n",
    "        if idx.size == 0:\n",
    "            return 0.0\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        return float(C[idx, :][r, c].sum())\n",
    "\n",
    "    if t == \"mdvsp\":\n",
    "        N, SS, TT = int(gt[\"N\"]), int(gt[\"SS\"]), int(gt[\"TT\"])\n",
    "        src = np.asarray(gt[\"src\"], np.int64)\n",
    "        dst = np.asarray(gt[\"dst\"], np.int64)\n",
    "        cost = np.asarray(gt[\"cost\"], float)\n",
    "        cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "        idxSS = np.asarray(gt[\"idxSS\"], np.int64)\n",
    "        idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "        cap = cap0.copy()\n",
    "        cap[idxSS] = x.astype(float)\n",
    "        cap[idxTT] = x.astype(float)\n",
    "\n",
    "        Fmax = lemon_mcf.max_flow(N, src, dst, cap, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, float)\n",
    "        supply[SS] = Fmax\n",
    "        supply[TT] = -Fmax\n",
    "        return float(lemon_mcf.solve_mcf(N, src, dst, cost, cap, supply)[\"total_cost\"])\n",
    "\n",
    "    return np.nan\n",
    "\n",
    "\n",
    "def local_search_l1_int(\n",
    "    f,\n",
    "    x0,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    delta: int,\n",
    "    sum_eq=None,\n",
    "    max_iters: int = 10_000,\n",
    "    print_every: int = 1,\n",
    "):\n",
    "    x  = np.asarray(x0,    int).ravel()\n",
    "    lo = np.asarray(x_min, int).ravel()\n",
    "    hi = np.asarray(x_max, int).ravel()\n",
    "    n = int(x.size)\n",
    "    delta = int(delta)\n",
    "\n",
    "    assert lo.size == n and hi.size == n\n",
    "    assert np.all(x >= lo) and np.all(x <= hi)\n",
    "    if sum_eq is not None:\n",
    "        sum_eq = int(sum_eq)\n",
    "        assert int(x.sum()) == sum_eq\n",
    "\n",
    "    def eval_batch(X):\n",
    "        y = np.asarray(f(X), float).reshape(-1)\n",
    "        return y\n",
    "\n",
    "    def ok(z):\n",
    "        if np.any(z < lo) or np.any(z > hi):\n",
    "            return False\n",
    "        if sum_eq is not None and int(z.sum()) != sum_eq:\n",
    "            return False\n",
    "        return True\n",
    "\n",
    "    # integer deltas with exact L1 = k\n",
    "    def deltas_exact(k):\n",
    "        d = np.zeros(n, int)\n",
    "\n",
    "        def rec(i, rem):\n",
    "            if i == n:\n",
    "                if rem == 0:\n",
    "                    yield d.copy()\n",
    "                return\n",
    "            for t in range(rem + 1):\n",
    "                if t == 0:\n",
    "                    d[i] = 0\n",
    "                    yield from rec(i + 1, rem)\n",
    "                else:\n",
    "                    d[i] = +t\n",
    "                    yield from rec(i + 1, rem - t)\n",
    "                    d[i] = -t\n",
    "                    yield from rec(i + 1, rem - t)\n",
    "            d[i] = 0\n",
    "\n",
    "        yield from rec(0, k)\n",
    "\n",
    "    t0 = time.perf_counter()\n",
    "    y = float(eval_batch(x[None, :])[0])\n",
    "    hist = [{\"iter\": 0, \"t\": 0.0, \"best_y\": y, \"x\": x.copy()}]\n",
    "    print(f\"iter=0  t=0.00s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    for it in range(1, int(max_iters) + 1):\n",
    "        cand = []\n",
    "        for k in range(1, delta + 1):\n",
    "            for dlt in deltas_exact(k):\n",
    "                z = x + dlt\n",
    "                if ok(z):\n",
    "                    cand.append(z)\n",
    "\n",
    "        if not cand:\n",
    "            print(f\"STOP: no feasible neighbors. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        Y = eval_batch(np.stack(cand, 0))\n",
    "        j = int(np.argmin(Y))\n",
    "        if float(Y[j]) >= y:\n",
    "            print(f\"STOP: local minimum. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        x, y = cand[j], float(Y[j])\n",
    "        hist.append({\"iter\": it, \"t\": time.perf_counter() - t0, \"best_y\": y, \"x\": x.copy()})\n",
    "        if it % max(1, int(print_every)) == 0:\n",
    "            print(f\"iter={it}  t={hist[-1]['t']:.2f}s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    return x, y, hist\n",
    "\n",
    "\n",
    "def _scaler_np(scaler):\n",
    "    xm = scaler[\"x_mean\"].detach().cpu().numpy().reshape(-1)\n",
    "    xs = scaler[\"x_std\"].detach().cpu().numpy().reshape(-1)\n",
    "    ym = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    ys = float(scaler[\"y_std\"].detach().cpu())\n",
    "    return xm, xs, ym, ys\n",
    "\n",
    "\n",
    "def solve_dfn_ip_gurobi(dfn, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    x_mean, x_std, y_mean, y_std = _scaler_np(scaler)\n",
    "\n",
    "    cost = np.r_[dfn.cost_raw.detach().cpu().numpy(), dfn.cost_fixed.detach().cpu().numpy()]\n",
    "    cap  = np.r_[torch.round(F.softplus(dfn.cap_raw.detach())).cpu().numpy(), dfn.cap_fixed.detach().cpu().numpy()]\n",
    "\n",
    "    A = dfn.A.detach().cpu().numpy()\n",
    "    if isinstance(dfn.A, torch.nn.Parameter):\n",
    "        A = np.round(A)\n",
    "    b = np.round(dfn.b_raw.detach().cpu().numpy())\n",
    "\n",
    "    src = dfn.src.detach().cpu().numpy().astype(int)\n",
    "    dst = dfn.dst.detach().cpu().numpy().astype(int)\n",
    "    boundary = dfn.boundary.detach().cpu().numpy().astype(int)\n",
    "    fix = int(dfn.fix_node)\n",
    "    n = int(dfn.n)\n",
    "    m = int(src.size)\n",
    "    alpha = float(dfn.alpha)\n",
    "    beta  = float(dfn.beta)\n",
    "\n",
    "    out = [[] for _ in range(n)]\n",
    "    inn = [[] for _ in range(n)]\n",
    "    for e in range(m):\n",
    "        out[src[e]].append(e)\n",
    "        inn[dst[e]].append(e)\n",
    "\n",
    "    M = gp.Model(\"DFN_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    f = M.addVars(m, lb=0.0, ub=cap.tolist(), vtype=GRB.CONTINUOUS, name=\"f\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq)\n",
    "\n",
    "    xm_over_xs = x_mean / x_std\n",
    "    s = [0] * n\n",
    "    s_boundary = []\n",
    "    for r, v in enumerate(boundary):\n",
    "        const = float(b[r] - (A[r] * xm_over_xs).sum())\n",
    "        expr = const + gp.quicksum((A[r, j] / x_std[j]) * x[j] for j in range(d) if A[r, j] != 0)\n",
    "        s[v] = expr\n",
    "        s_boundary.append(expr)\n",
    "    s[fix] = -gp.quicksum(s_boundary)\n",
    "\n",
    "    for v in range(n):\n",
    "        M.addConstr(gp.quicksum(f[e] for e in out[v]) - gp.quicksum(f[e] for e in inn[v]) == s[v])\n",
    "\n",
    "    flow_cost = gp.quicksum(cost[e] * f[e] for e in range(m))\n",
    "    M.setObjective((alpha * flow_cost + beta) * y_std + y_mean, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No solution (Gurobi status {M.Status})\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None)}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_mlp_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    base, a_out, b_out = model, 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base, a_out, b_out = model.base, float(model.a), float(model.b)\n",
    "\n",
    "    if not hasattr(base, \"net\"):\n",
    "        raise ValueError(\"Expected an MLP with attribute .net (nn.Sequential).\")\n",
    "    linears = [L for L in base.net if isinstance(L, torch.nn.Linear)]\n",
    "    if not linears:\n",
    "        raise ValueError(\"No Linear layers found in base.net\")\n",
    "\n",
    "    W = [L.weight.detach().cpu().numpy().astype(float) for L in linears]\n",
    "    b = [L.bias.detach().cpu().numpy().astype(float) for L in linears]\n",
    "\n",
    "    W[0] = W[0] / xs[None, :]\n",
    "    b[0] = b[0] - W[0] @ xm\n",
    "\n",
    "    W[-1] *= a_out\n",
    "    b[-1] = a_out * b[-1] + b_out\n",
    "\n",
    "    u = np.maximum(np.abs(x_min), np.abs(x_max))\n",
    "    preLU = []\n",
    "    for k in range(len(W) - 1):\n",
    "        U = np.abs(W[k]) @ u + np.abs(b[k])\n",
    "        preLU.append((-U, U))\n",
    "        u = np.maximum(0.0, U)\n",
    "\n",
    "    M = gp.Model(\"MLP_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    prev = [x[i] for i in range(d)]\n",
    "\n",
    "    for k in range(len(W) - 1):\n",
    "        Lk, Uk = preLU[k]\n",
    "        h = W[k].shape[0]\n",
    "\n",
    "        a = [M.addVar(lb=float(Lk[j]), ub=float(Uk[j]), name=f\"a{k}_{j}\") for j in range(h)]\n",
    "        z = [M.addVar(lb=0.0, ub=float(max(0.0, Uk[j])), name=f\"z{k}_{j}\") for j in range(h)]\n",
    "\n",
    "        for j in range(h):\n",
    "            M.addConstr(a[j] == b[k][j] + gp.quicksum(W[k][j, i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "            Lj, Uj = float(Lk[j]), float(Uk[j])\n",
    "            if Uj <= 0.0:\n",
    "                M.addConstr(z[j] == 0.0)\n",
    "            elif Lj >= 0.0:\n",
    "                M.addConstr(z[j] == a[j])\n",
    "            else:\n",
    "                s = M.addVar(vtype=GRB.BINARY, name=f\"s{k}_{j}\")\n",
    "                M.addConstr(z[j] >= a[j])\n",
    "                M.addConstr(z[j] >= 0.0)\n",
    "                M.addConstr(z[j] <= Uj * s)\n",
    "                M.addConstr(z[j] <= a[j] - Lj * (1 - s))\n",
    "\n",
    "        prev = z\n",
    "\n",
    "    if W[-1].shape[0] != 1:\n",
    "        raise ValueError(f\"Expected scalar output, got out_dim={W[-1].shape[0]}\")\n",
    "\n",
    "    y_norm = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == b[-1][0] + gp.quicksum(W[-1][0, i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "    M.setObjective(ys * y_norm + ym, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_maxaffine_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    base, a_out, b_out = model, 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base, a_out, b_out = model.base, float(model.a), float(model.b)\n",
    "\n",
    "    W = base.W.detach().cpu().numpy().astype(float)\n",
    "    b = base.b.detach().cpu().numpy().astype(float)\n",
    "\n",
    "    Weff = W / xs[None, :]\n",
    "    beff = b - (Weff @ xm)\n",
    "\n",
    "    Weff *= a_out\n",
    "    beff  = a_out * beff + b_out\n",
    "\n",
    "    K = int(Weff.shape[0])\n",
    "\n",
    "    M = gp.Model(\"MaxAffine_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    t = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"t_norm\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(t >= beff[k] + gp.quicksum(Weff[k, j] * x[j] for j in range(d) if Weff[k, j] != 0.0))\n",
    "\n",
    "    M.setObjective(ys * t + ym, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_lset_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    A = model.A.detach().cpu().numpy().astype(float)\n",
    "    b = model.b.detach().cpu().numpy().astype(float)\n",
    "    T = float(model.T)\n",
    "    if T == 0.0:\n",
    "        raise ValueError(\"T must be nonzero\")\n",
    "\n",
    "    Aeff = A / xs[None, :]\n",
    "    beff = b - (Aeff @ xm)\n",
    "    K = int(Aeff.shape[0])\n",
    "\n",
    "    lin_lo = np.empty(K, dtype=float)\n",
    "    lin_hi = np.empty(K, dtype=float)\n",
    "    for k in range(K):\n",
    "        a = Aeff[k]\n",
    "        lo = beff[k]\n",
    "        hi = beff[k]\n",
    "        pos = a >= 0\n",
    "        lo += (a[pos] * x_min[pos]).sum() + (a[~pos] * x_max[~pos]).sum()\n",
    "        hi += (a[pos] * x_max[pos]).sum() + (a[~pos] * x_min[~pos]).sum()\n",
    "        lin_lo[k], lin_hi[k] = lo, hi\n",
    "\n",
    "    z_lo = lin_lo / T\n",
    "    z_hi = lin_hi / T\n",
    "    m_lo = float(np.max(z_lo))\n",
    "    m_hi = float(np.max(z_hi))\n",
    "\n",
    "    w_lo = float(np.min(z_lo - m_hi))  # <= 0\n",
    "    u_lo = float(np.exp(max(-700.0, w_lo)))\n",
    "    s_lo = max(1e-12, K * u_lo)\n",
    "    s_hi = float(K * 1.0)\n",
    "    v_lo = float(np.log(s_lo))\n",
    "    v_hi = float(np.log(s_hi))\n",
    "\n",
    "    yN_lo = float(T * (m_lo + v_lo))\n",
    "    yN_hi = float(T * (m_hi + v_hi))\n",
    "    y_lo  = float(ys * yN_lo + ym)\n",
    "    y_hi  = float(ys * yN_hi + ym)\n",
    "\n",
    "    M = gp.Model(\"lset_ip_stable_bounded\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    M.Params.FuncNonlinear = 1\n",
    "    M.Params.FeasibilityTol = 1e-9\n",
    "    M.Params.OptimalityTol  = 1e-9\n",
    "    M.Params.IntFeasTol     = 1e-9\n",
    "    M.Params.NumericFocus   = 3\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    z = M.addVars(K, lb=z_lo.tolist(), ub=z_hi.tolist(), vtype=GRB.CONTINUOUS, name=\"z\")\n",
    "    for k in range(K):\n",
    "        lin = beff[k] + gp.quicksum(Aeff[k, j] * x[j] for j in range(d) if Aeff[k, j] != 0.0)\n",
    "        M.addConstr(z[k] == lin / T, name=f\"zdef_{k}\")\n",
    "\n",
    "    m = M.addVar(lb=m_lo, ub=m_hi, vtype=GRB.CONTINUOUS, name=\"m\")\n",
    "    w = M.addVars(K, lb=w_lo, ub=0.0, vtype=GRB.CONTINUOUS, name=\"w\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(m >= z[k], name=f\"m_ge_z_{k}\")\n",
    "        M.addConstr(w[k] == z[k] - m, name=f\"wdef_{k}\")\n",
    "\n",
    "    u = M.addVars(K, lb=0.0, ub=1.0, vtype=GRB.CONTINUOUS, name=\"u\")\n",
    "    for k in range(K):\n",
    "        M.addGenConstrExp(w[k], u[k], name=f\"exp_{k}\")\n",
    "\n",
    "    s = M.addVar(lb=s_lo, ub=s_hi, vtype=GRB.CONTINUOUS, name=\"s\")\n",
    "    M.addConstr(s == gp.quicksum(u[k] for k in range(K)), name=\"sumexp_shifted\")\n",
    "\n",
    "    v = M.addVar(lb=v_lo, ub=v_hi, vtype=GRB.CONTINUOUS, name=\"v\")\n",
    "    M.addGenConstrLog(s, v, name=\"log_shifted\")\n",
    "\n",
    "    y_norm = M.addVar(lb=yN_lo, ub=yN_hi, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == T * (m + v), name=\"y_norm_def\")\n",
    "\n",
    "    y_raw = M.addVar(lb=y_lo, ub=y_hi, vtype=GRB.CONTINUOUS, name=\"y_raw\")\n",
    "    M.addConstr(y_raw == ys * y_norm + ym, name=\"y_raw_def\")\n",
    "\n",
    "    M.setObjective(y_raw, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution found. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], dtype=float)\n",
    "    y_star = float(y_raw.X)\n",
    "\n",
    "    info = {\n",
    "        \"status\": M.Status,\n",
    "        \"runtime\": M.Runtime,\n",
    "        \"gap\": getattr(M, \"MIPGap\", None),\n",
    "        \"sol_count\": M.SolCount,\n",
    "        \"obj_gurobi\": float(M.ObjVal),\n",
    "        \"obj_bound\": float(getattr(M, \"ObjBound\", float(\"nan\"))),\n",
    "    }\n",
    "    return x_star, y_star, info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4858979",
   "metadata": {},
   "source": [
    "## Test Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "569f2165",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_ip(model_type, model, scaler, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    if model_type == \"DFN\":\n",
    "        return solve_dfn_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MLP\":\n",
    "        return solve_mlp_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MaxAffine\":\n",
    "        return solve_maxaffine_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"LSET\":\n",
    "        return solve_lset_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise ValueError(model_type)\n",
    "\n",
    "\n",
    "def suppress_stdout(fn, *args, silence: bool = False, **kwargs):\n",
    "    if not silence:\n",
    "        return fn(*args, **kwargs), \"\"\n",
    "    buf = io.StringIO()\n",
    "    with contextlib.redirect_stdout(buf):\n",
    "        out = fn(*args, **kwargs)\n",
    "    return out, buf.getvalue()\n",
    "\n",
    "\n",
    "def make_obj(model, scaler, device, chunk: int = 4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def obj(Xraw):\n",
    "        Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "        if Xraw.dim() == 1:\n",
    "            Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "        outs = []\n",
    "        B = int(Xraw.shape[0])\n",
    "        for i in range(0, B, int(chunk)):\n",
    "            Xb = Xraw[i:i+chunk]\n",
    "            try:\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)  \n",
    "                y  = (yn * ys + ym).reshape(-1).detach().cpu() \n",
    "                if y.numel() != Xb.shape[0]:\n",
    "                    y = y.expand(Xb.shape[0]).contiguous()\n",
    "                outs.append(y)\n",
    "            except Exception as e:\n",
    "                obj._err_count += int(Xb.shape[0])\n",
    "                if obj._err_first is None:\n",
    "                    obj._err_first = repr(e)\n",
    "                outs.append(torch.full((int(Xb.shape[0]),), float(\"inf\"), device=\"cpu\"))\n",
    "\n",
    "        return torch.cat(outs, 0).numpy()\n",
    "\n",
    "    obj._err_count = 0\n",
    "    obj._err_first = None\n",
    "    return obj\n",
    "\n",
    "\n",
    "def safe_raw_mse(obj, Xraw, yraw):\n",
    "    yp = np.asarray(obj(Xraw), dtype=float).reshape(-1)\n",
    "    yt = yraw.detach().cpu().numpy().reshape(-1) if torch.is_tensor(yraw) else np.asarray(yraw, float).reshape(-1)\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "    mask = np.isfinite(yp)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions were non-finite (inf/nan)\"\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def safe_norm_mse(model, scaler, device, Xraw, yraw, *, chunk=4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "    if Xraw.dim() == 1:\n",
    "        Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "    yraw_t = yraw\n",
    "    if torch.is_tensor(yraw_t):\n",
    "        yraw_t = yraw_t.to(device=device, dtype=torch.float32)\n",
    "    else:\n",
    "        yraw_t = torch.as_tensor(yraw_t, dtype=torch.float32, device=device)\n",
    "    yraw_t = yraw_t.reshape(-1)\n",
    "\n",
    "    preds = []\n",
    "    B = int(Xraw.shape[0])\n",
    "    try:\n",
    "        with torch.no_grad():\n",
    "            for i in range(0, B, int(chunk)):\n",
    "                Xb = Xraw[i:i+chunk]\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)\n",
    "                if yn.numel() != Xb.shape[0]:\n",
    "                    yn = yn.expand(Xb.shape[0]).contiguous()\n",
    "                preds.append(yn.detach().cpu())\n",
    "    except Exception as e:\n",
    "        return np.nan, f\"model forward failed in safe_norm_mse: {repr(e)}\"\n",
    "\n",
    "    yp = torch.cat(preds, 0).numpy().reshape(-1)\n",
    "    yt = ((yraw_t - ym) / ys).detach().cpu().numpy().reshape(-1)\n",
    "\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "\n",
    "    mask = np.isfinite(yp) & np.isfinite(yt)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions or targets were non-finite (inf/nan)\"\n",
    "\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def t_to_best(hist, y_best):\n",
    "    for r in hist:\n",
    "        if abs(float(r.get(\"best_y\", np.inf)) - float(y_best)) < 1e-12:\n",
    "            return float(r.get(\"t\", float(\"nan\")))\n",
    "    return float(\"nan\")\n",
    "\n",
    "\n",
    "def check_ip_matches_obj(name, obj, x_ip, y_ip, *, strict: bool, tol: float):\n",
    "    y_obj = float(np.asarray(obj(np.asarray(x_ip)), dtype=float).reshape(-1)[0])\n",
    "    y_ip  = float(y_ip)\n",
    "    rel = abs(y_obj - y_ip) / (abs(y_obj) + 1e-12)\n",
    "    print(f\"[CHECK {name}] obj(x_ip)={y_obj:.6g}  ip_y={y_ip:.6g}  rel_err={rel:.3e}\")\n",
    "    if strict and rel > tol:\n",
    "        raise RuntimeError(f\"{name}: IP objective != obj() (rel_err={rel:.3e})\")\n",
    "    return rel\n",
    "\n",
    "\n",
    "def mean_se(x):\n",
    "    x = pd.to_numeric(pd.Series(x), errors=\"coerce\").to_numpy()\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = int(x.shape[0])\n",
    "    if n == 0:\n",
    "        return np.nan, np.nan\n",
    "    m = float(x.mean())\n",
    "    se = float(x.std(ddof=1) / np.sqrt(n)) if n > 1 else 0.0\n",
    "    return m, se\n",
    "\n",
    "\n",
    "def fmt_mean_se(m, se):\n",
    "    if not np.isfinite(m):\n",
    "        return \"nan\"\n",
    "    if not np.isfinite(se):\n",
    "        return f\"{m:.6g}\"\n",
    "    return f\"{m:.6g} ± {se:.3g}\"\n",
    "\n",
    "\n",
    "def repr_solution(xs: pd.Series, seeds=None):\n",
    "    xs = xs.dropna().astype(str)\n",
    "    xs = xs[xs != \"None\"]\n",
    "    if xs.empty:\n",
    "        return None\n",
    "\n",
    "    # With seed information: show per-seed if solutions differ\n",
    "    if seeds is not None:\n",
    "        df = pd.DataFrame({\"seed\": pd.Series(seeds), \"x\": xs})\n",
    "        df = df.dropna()\n",
    "        df[\"x\"] = df[\"x\"].astype(str)\n",
    "        if df.empty:\n",
    "            return None\n",
    "        if df[\"x\"].nunique() == 1:\n",
    "            return df[\"x\"].iloc[0]\n",
    "        df = df.sort_values(\"seed\")\n",
    "        return \"\\n\".join([f\"seed={int(r.seed)}: {r.x}\" for r in df.itertuples(index=False)])\n",
    "\n",
    "    # No seed info: keep compact\n",
    "    if xs.nunique() == 1:\n",
    "        return xs.iloc[0]\n",
    "    vc = xs.value_counts()\n",
    "    top = vc.index[0]\n",
    "    n_unique = int(vc.shape[0])\n",
    "    return f\"{top} (+{n_unique-1} other)\"\n",
    "    \n",
    "\n",
    "# -----------------------------\n",
    "# Ground-truth optimum solvers\n",
    "# -----------------------------\n",
    "\n",
    "def solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    Q  = np.asarray(gt[\"Q\"], float)\n",
    "    xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "    n  = int(xs.shape[0])\n",
    "    assert Q.shape == (n, n)\n",
    "\n",
    "    m = gp.Model(\"gt_quadratic\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    x = m.addVars(n, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(n):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(n)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    expr = gp.quicksum(float(Q[i, j]) * (x[i] - float(xs[i])) * (x[j] - float(xs[j])) for i in range(n) for j in range(n))\n",
    "    m.setObjective(expr, GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT quadratic solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(n)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_assignment(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    C = np.asarray(gt[\"C\"], float)\n",
    "    n_rows, n_cols = C.shape\n",
    "    k = int(sum_eq)\n",
    "    if k > n_cols:\n",
    "        raise RuntimeError(f\"sum_eq={k} exceeds number of columns={n_cols} (infeasible)\")\n",
    "\n",
    "    m = gp.Model(\"gt_assignment\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    z = m.addVars(n_rows, vtype=GRB.BINARY, name=\"z\")  # select row i\n",
    "    y = m.addVars(n_rows, n_cols, vtype=GRB.BINARY, name=\"y\")  # assign row i to col j\n",
    "\n",
    "    m.addConstr(gp.quicksum(z[i] for i in range(n_rows)) == k, name=\"k_rows\")\n",
    "    for i in range(n_rows):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for j in range(n_cols)) == z[i], name=f\"assign_row_{i}\")\n",
    "    for j in range(n_cols):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for i in range(n_rows)) <= 1, name=f\"assign_col_{j}\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(C[i, j]) * y[i, j] for i in range(n_rows) for j in range(n_cols)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT assignment solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(z[i].X)) for i in range(n_rows)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    N  = int(gt[\"N\"])\n",
    "    SS = int(gt[\"SS\"])\n",
    "    TT = int(gt[\"TT\"])\n",
    "    src  = np.asarray(gt[\"src\"], np.int64)\n",
    "    dst  = np.asarray(gt[\"dst\"], np.int64)\n",
    "    cost = np.asarray(gt[\"cost\"], float)\n",
    "    cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "    idxSS = np.asarray(gt[\"idxSS\"], np.int64)\n",
    "    idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "    E = int(src.shape[0])\n",
    "    k = int(idxSS.shape[0])\n",
    "    assert idxTT.shape[0] == k, \"Expect idxSS and idxTT to be same length\"\n",
    "\n",
    "    out_edges = [[] for _ in range(N)]\n",
    "    in_edges  = [[] for _ in range(N)]\n",
    "    for e in range(E):\n",
    "        out_edges[int(src[e])].append(e)\n",
    "        in_edges[int(dst[e])].append(e)\n",
    "\n",
    "    idxSS = idxSS.astype(int)\n",
    "    idxTT = idxTT.astype(int)\n",
    "    var_arc_to_i = {int(idxSS[i]): i for i in range(k)}\n",
    "    var_arc_to_i.update({int(idxTT[i]): i for i in range(k)})\n",
    "    var_arcs = sorted(var_arc_to_i.keys())\n",
    "\n",
    "    m = gp.Model(\"gt_mdvsp_true_opt\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    m.Params.NonConvex = 2\n",
    "\n",
    "    x = m.addVars(k, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(k):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(k)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    f = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, name=\"f\")\n",
    "\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            m.addConstr(f[e] <= x[i], name=f\"cap_var_{e}\")\n",
    "        else:\n",
    "            m.addConstr(f[e] <= float(cap0[e]), name=f\"cap_fix_{e}\")\n",
    "\n",
    "    F = m.addVar(vtype=GRB.CONTINUOUS, lb=0.0, name=\"F\")\n",
    "\n",
    "    # flow conservation: out - in = F at SS, = -F at TT, else 0\n",
    "    for v in range(N):\n",
    "        out_sum = gp.quicksum(f[e] for e in out_edges[v])\n",
    "        in_sum  = gp.quicksum(f[e] for e in in_edges[v])\n",
    "        rhs = F if v == SS else (-F if v == TT else 0.0)\n",
    "        m.addConstr(out_sum - in_sum == rhs, name=f\"flow_{v}\")\n",
    "\n",
    "    y = m.addVars(N, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"y\")\n",
    "    m.addConstr(y[SS] == 1.0, name=\"ySS\")\n",
    "    m.addConstr(y[TT] == 0.0, name=\"yTT\")\n",
    "\n",
    "    z = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"z\")\n",
    "    for e in range(E):\n",
    "        m.addConstr(z[e] >= y[int(src[e])] - y[int(dst[e])], name=f\"dual_{e}\")\n",
    "\n",
    "    dual_obj = gp.QuadExpr()\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            # bilinear term: x_i * z_e\n",
    "            dual_obj += x[i] * z[e]\n",
    "        else:\n",
    "            dual_obj += float(cap0[e]) * z[e]\n",
    "    m.addConstr(F == dual_obj, name=\"strong_duality\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(cost[e]) * f[e] for e in range(E)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT mdvsp true-opt failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(k)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status), \"F\": float(F.X)}\n",
    "    \n",
    "\n",
    "\n",
    "def solve_true_opt(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    \"\"\"Top-level dispatcher for ground-truth optimum.\"\"\"\n",
    "    if not isinstance(gt, dict):\n",
    "        raise RuntimeError(\"No ground-truth structure found (gt must be a dict).\")\n",
    "    t = gt.get(\"type\", None)\n",
    "    if t == \"quadratic\":\n",
    "        return solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"assignment\":\n",
    "        return solve_true_opt_assignment(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"mdvsp\":\n",
    "        return solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise RuntimeError(f\"Unknown gt type: {t}\")\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# Benchmark runner\n",
    "# -----------------------------\n",
    "def run_benchmark(\n",
    "    *,\n",
    "    dataset_type: str,\n",
    "    dataset_params: dict,\n",
    "    runs: list[tuple[str, str, dict]],\n",
    "    train_base: dict,\n",
    "    lr_map: dict,\n",
    "    x0: np.ndarray,\n",
    "    xmin: np.ndarray,\n",
    "    xmax: np.ndarray,\n",
    "    delta: int,\n",
    "    sum_eq: int,\n",
    "    n_seeds: int = 1,\n",
    "    vary_dataset_seed: bool = False,\n",
    "    vary_model_init_seed: bool = True,\n",
    "    strict_ip_check: bool = False,\n",
    "    ip_check_tol: float = 1e-4,\n",
    "    silence_local_search: bool = False,\n",
    "    allow_plots_multi_seed: bool = True,\n",
    "    time_limit=None,\n",
    "):\n",
    "    seeds = list(range(int(n_seeds)))\n",
    "\n",
    "    learn_rows, opt_rows, spec_rows, fail_rows = [], [], [], []\n",
    "    gt_rows = []\n",
    "\n",
    "    gt_cache_by_seed = {}\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"\\n\\n===================== SEED {seed} =====================\")\n",
    "\n",
    "        for name, model_type, model_params_base in runs:\n",
    "            # ---- per-run params ----\n",
    "            dp = dict(dataset_params)\n",
    "            if vary_dataset_seed and \"seed\" in dp:\n",
    "                dp[\"seed\"] = int(seed)\n",
    "\n",
    "            mp = dict(model_params_base)\n",
    "            if vary_model_init_seed and \"seed\" in mp:\n",
    "                mp[\"seed\"] = int(seed)\n",
    "\n",
    "            tp = dict(train_base)\n",
    "            tp[\"seed\"] = int(seed)\n",
    "            tp[\"lr\"] = float(lr_map[model_type])\n",
    "\n",
    "            # avoid plot spam unless explicitly allowed\n",
    "            if (n_seeds > 1) and (tp.get(\"plot_every\", 0) not in (0, None)) and (not allow_plots_multi_seed):\n",
    "                tp[\"plot_every\"] = 0\n",
    "\n",
    "            # ---- TRAIN ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                out = generate_and_train_simple(dataset_type, dp, model_type, mp, tp)\n",
    "            except Exception as e:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=repr(e)))\n",
    "                learn_rows.append(dict(seed=seed, model=name, train_time=np.nan, best_epoch=np.nan,\n",
    "                                       best_val=np.nan, test=np.nan, train_err=repr(e)))\n",
    "                continue\n",
    "            train_time = time.perf_counter() - t0\n",
    "\n",
    "            if isinstance(out, tuple) and len(out) == 4:\n",
    "                model, data, hist, spec = out\n",
    "            elif isinstance(out, tuple) and len(out) == 3:\n",
    "                model, data, hist = out\n",
    "                n_params = sum(p.numel() for p in model.parameters())\n",
    "                spec = dict(n_params=int(n_params), extra=\"\", train_params=tp)\n",
    "            else:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=f\"Unexpected return: {type(out)}\"))\n",
    "                continue\n",
    "\n",
    "            # ---- model spec (seed 0 only) ----\n",
    "            if seed == seeds[0]:\n",
    "                spec_rows.append(dict(\n",
    "                    model=name,\n",
    "                    n_params=int(spec.get(\"n_params\", np.nan)),\n",
    "                    details=str(spec.get(\"extra\", \"\")),\n",
    "                    lr=float(spec.get(\"train_params\", {}).get(\"lr\", tp[\"lr\"])),\n",
    "                    batch_size=int(spec.get(\"train_params\", {}).get(\"batch_size\", tp[\"batch_size\"])),\n",
    "                    epochs=int(spec.get(\"train_params\", {}).get(\"epochs\", tp[\"epochs\"])),\n",
    "                ))\n",
    "\n",
    "            device = data[\"device\"]\n",
    "            scaler = data[\"scaler\"]\n",
    "            obj = make_obj(model, scaler, device, chunk=int(tp.get(\"plot_chunk\", 4096)))\n",
    "            gt = data.get(\"true\", None)\n",
    "\n",
    "            # ---- compute GT optimum (once per seed) ----\n",
    "            if seed not in gt_cache_by_seed:\n",
    "                t_gt0 = time.perf_counter()\n",
    "                try:\n",
    "                    x_gt, y_gt, gt_info = solve_true_opt(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=False)\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    # evaluate with the existing helper to be extra sure\n",
    "                    y_gt_check = float(eval_true_obj(gt, x_gt))\n",
    "                    if np.isfinite(y_gt_check) and abs(y_gt_check - float(y_gt)) / (abs(float(y_gt_check)) + 1e-12) > 1e-6:\n",
    "                        fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT_CHECK\",\n",
    "                                              error=f\"gt solver mismatch: solver={y_gt:.6g} eval_true_obj={y_gt_check:.6g}\"))\n",
    "                    gt_cache_by_seed[seed] = dict(x=str(np.asarray(x_gt, int).tolist()),\n",
    "                                                  true_y=float(y_gt_check if np.isfinite(y_gt_check) else y_gt),\n",
    "                                                  runtime=float(gt_time),\n",
    "                                                  err=None)\n",
    "                except Exception as e:\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    gt_cache_by_seed[seed] = dict(x=None, true_y=np.nan, runtime=float(gt_time), err=repr(e))\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT\", error=repr(e)))\n",
    "\n",
    "            # ---- learning metrics: best val (normalized) + test loss (normalized) ----\n",
    "            test_norm, err_te = safe_norm_mse(model, scaler, device, data['raw']['Xte'], data['raw']['yte'], chunk=int(tp.get('plot_chunk', 4096)))\n",
    "            if err_te:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"EVAL_TEST\", error=err_te))\n",
    "\n",
    "            if obj._err_count > 0:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"OBJ\",\n",
    "                                      error=f\"obj() had {obj._err_count} forward failures; first={obj._err_first}\"))\n",
    "\n",
    "            val_curve = np.asarray(hist.get(\"val_mse_norm\", []), dtype=float)\n",
    "            best_ep = int(np.argmin(val_curve) + 1) if val_curve.size else np.nan\n",
    "            best_val = float(np.min(val_curve)) if val_curve.size else np.nan\n",
    "\n",
    "            learn_rows.append(dict(\n",
    "                seed=seed, model=name,\n",
    "                train_time=float(train_time),\n",
    "                best_epoch=best_ep,\n",
    "                best_val=float(best_val),\n",
    "                test=float(test_norm) if np.isfinite(test_norm) else np.nan,\n",
    "                train_err=(err_te),\n",
    "            ))\n",
    "\n",
    "            # ---- LOCAL SEARCH ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                obj_ls = obj\n",
    "                (ls_out, _ls_log) = suppress_stdout(\n",
    "                    local_search_l1_int, obj_ls, x0, xmin, xmax,\n",
    "                    delta=delta, sum_eq=sum_eq, print_every=0,\n",
    "                    silence=silence_local_search\n",
    "                )\n",
    "                x_best, y_best, ls_hist = ls_out\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=str(np.asarray(x_best, int).tolist()),\n",
    "                    y=float(y_best),\n",
    "                    true_y=float(eval_true_obj(gt, x_best)),\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=float(t_to_best(ls_hist, y_best)),\n",
    "                    iters=int(len(ls_hist) - 1),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=np.nan, iters=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"LS\", error=repr(e)))\n",
    "\n",
    "            # ---- IP SOLVE (learned objective) ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                x_ip, y_ip, info = solve_ip(\n",
    "                    model_type, model, scaler, xmin, xmax, sum_eq,\n",
    "                    time_limit=time_limit, verbose=True\n",
    "                )\n",
    "                ip_time = time.perf_counter() - t0\n",
    "\n",
    "                rel_err = check_ip_matches_obj(name, obj, x_ip, y_ip, strict=strict_ip_check, tol=ip_check_tol)\n",
    "                if rel_err > ip_check_tol:\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"IP_CHECK\",\n",
    "                                          error=f\"rel_err={rel_err:.3e} (tol={ip_check_tol})\"))\n",
    "\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=str(np.asarray(x_ip, int).tolist()),\n",
    "                    y=float(y_ip),\n",
    "                    true_y=float(eval_true_obj(gt, x_ip)),\n",
    "                    runtime=float(ip_time),\n",
    "                    status=(info.get(\"status\") if isinstance(info, dict) else None),\n",
    "                    gap=(info.get(\"gap\") if isinstance(info, dict) else None),\n",
    "                    ip_rel_err=float(rel_err),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ip_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ip_time),\n",
    "                    status=None, gap=None, ip_rel_err=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"IP\", error=repr(e)))\n",
    "\n",
    "    # ---- build DFs ----\n",
    "    spec_df  = pd.DataFrame(spec_rows).drop_duplicates(\"model\").sort_values(\"model\").reset_index(drop=True)\n",
    "    learn_df = pd.DataFrame(learn_rows).sort_values([\"model\", \"seed\"]).reset_index(drop=True)\n",
    "    opt_df   = pd.DataFrame(opt_rows).sort_values([\"model\", \"seed\", \"method\"]).reset_index(drop=True)\n",
    "\n",
    "    fail_df = pd.DataFrame(fail_rows)\n",
    "    if fail_df.empty:\n",
    "        fail_df = pd.DataFrame(columns=[\"seed\", \"model\", \"stage\", \"error\"])\n",
    "    else:\n",
    "        for c in [\"stage\", \"model\", \"seed\"]:\n",
    "            if c not in fail_df.columns:\n",
    "                fail_df[c] = np.nan\n",
    "        fail_df = fail_df.sort_values([\"stage\", \"model\", \"seed\"]).reset_index(drop=True)\n",
    "\n",
    "    gt_df = pd.DataFrame([dict(seed=s, **d) for s, d in sorted(gt_cache_by_seed.items())]).sort_values(\"seed\")\n",
    "\n",
    "    # ---- per-seed gaps ----\n",
    "    gap_seed_df = pd.DataFrame(columns=[\"seed\", \"model\", \"ls_vs_ip_pct\", \"ip_true_vs_gt_pct\"])\n",
    "    if not opt_df.empty:\n",
    "        pivot_y = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"y\", aggfunc=\"first\")\n",
    "        pivot_true = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"true_y\", aggfunc=\"first\")\n",
    "\n",
    "        if (\"LS\" in pivot_y.columns) and (\"IP\" in pivot_y.columns):\n",
    "            ls_vs_ip = 100.0 * (pivot_y[\"LS\"] - pivot_y[\"IP\"]) / (np.abs(pivot_y[\"IP\"]) + 1e-12)\n",
    "        else:\n",
    "            ls_vs_ip = pd.Series(index=pivot_y.index, dtype=float)\n",
    "\n",
    "        # IP true vs GT optimum true\n",
    "        gt_true = gt_df.set_index(\"seed\")[\"true_y\"] if not gt_df.empty else pd.Series(dtype=float)\n",
    "        ip_true_vs_gt = []\n",
    "        for (seed, model), row in pivot_true.iterrows():\n",
    "            ipt = float(row.get(\"IP\", np.nan))\n",
    "            gtt = float(gt_true.get(seed, np.nan))\n",
    "            if np.isfinite(ipt) and np.isfinite(gtt):\n",
    "                ip_true_vs_gt.append(((seed, model), 100.0 * (ipt - gtt) / (abs(gtt) + 1e-12)))\n",
    "            else:\n",
    "                ip_true_vs_gt.append(((seed, model), np.nan))\n",
    "        ip_true_vs_gt = pd.Series({k: v for k, v in ip_true_vs_gt})\n",
    "\n",
    "        gap_seed_df = pd.DataFrame({\n",
    "            \"seed\": [k[0] for k in ip_true_vs_gt.index],\n",
    "            \"model\": [k[1] for k in ip_true_vs_gt.index],\n",
    "            \"ls_vs_ip_pct\": [float(ls_vs_ip.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "            \"ip_true_vs_gt_pct\": [float(ip_true_vs_gt.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "        })\n",
    "\n",
    "    # ---- LEARNING SUMMARY (mean ± SE over seeds) ----\n",
    "    learn_sum_rows = []\n",
    "    for model in sorted(learn_df[\"model\"].unique()):\n",
    "        sub = learn_df[learn_df[\"model\"] == model]\n",
    "        m, se = mean_se(sub[\"train_time\"]); train_time_s = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"best_val\"]);   best_val_s   = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"test\"]);       test_s       = fmt_mean_se(m, se)\n",
    "        learn_sum_rows.append(dict(model=model, train_time=train_time_s, best_val=best_val_s, test=test_s))\n",
    "    learn_summary_df = pd.DataFrame(learn_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- OPTIMIZATION SUMMARY ----\n",
    "    opt_sum_rows = []\n",
    "    gt_x_repr = (repr_solution(gt_df.get(\"x\", pd.Series(dtype=str)), gt_df.get(\"seed\", None))\n",
    "                if not gt_df.empty else None)\n",
    "    m, se = mean_se(gt_df.get(\"true_y\", pd.Series(dtype=float))); gt_true_s = fmt_mean_se(m, se)\n",
    "    m, se = mean_se(gt_df.get(\"runtime\", pd.Series(dtype=float))); gt_time_s = fmt_mean_se(m, se)\n",
    "\n",
    "    for model in sorted(opt_df[\"model\"].unique()):\n",
    "        sub = opt_df[opt_df[\"model\"] == model]\n",
    "        row = {\"model\": model}\n",
    "\n",
    "        ls = sub[sub[\"method\"] == \"LS\"]\n",
    "        ip = sub[sub[\"method\"] == \"IP\"]\n",
    "\n",
    "        row[\"LS_x\"] = repr_solution(ls[\"x\"], ls.get(\"seed\", None))\n",
    "        m, se = mean_se(ls[\"y\"]);       row[\"LS_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"true_y\"]);  row[\"LS_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"runtime\"]); row[\"LS_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"IP_x\"] = repr_solution(ip[\"x\"], ip.get(\"seed\", None))\n",
    "        m, se = mean_se(ip[\"y\"]);       row[\"IP_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"true_y\"]);  row[\"IP_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"runtime\"]); row[\"IP_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"GT_x\"] = gt_x_repr\n",
    "        row[\"GT_true_y\"] = gt_true_s\n",
    "        row[\"GT_time\"] = gt_time_s\n",
    "\n",
    "        gsub = gap_seed_df[gap_seed_df[\"model\"] == model] if not gap_seed_df.empty else pd.DataFrame()\n",
    "        m, se = mean_se(gsub.get(\"ls_vs_ip_pct\", pd.Series(dtype=float))); row[\"LS_vs_IP_%\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(gsub.get(\"ip_true_vs_gt_pct\", pd.Series(dtype=float))); row[\"IP_true_vs_GT_%\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        opt_sum_rows.append(row)\n",
    "\n",
    "    opt_summary_df = pd.DataFrame(opt_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- Print tables ----\n",
    "    print(\"\\n=== MODEL SPECS (from seed 0 run) ===\")\n",
    "    if not spec_df.empty:\n",
    "        print(spec_df[[\"model\", \"n_params\", \"details\", \"lr\", \"batch_size\", \"epochs\"]].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== LEARNING SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not learn_summary_df.empty:\n",
    "        print(learn_summary_df.to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not opt_summary_df.empty:\n",
    "        cols = [\n",
    "            \"model\",\n",
    "            \"LS_x\", \"LS_y\", \"LS_true_y\", \"LS_time\",\n",
    "            \"IP_x\", \"IP_y\", \"IP_true_y\", \"IP_time\",\n",
    "            \"GT_x\", \"GT_true_y\", \"GT_time\",\n",
    "            \"LS_vs_IP_%\", \"IP_true_vs_GT_%\",\n",
    "        ]\n",
    "        print(opt_summary_df[cols].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== FAILURES / WARNINGS (if any) ===\")\n",
    "    if fail_df.shape[0] == 0:\n",
    "        print(\"None\")\n",
    "    else:\n",
    "        print(fail_df.to_string(index=False))\n",
    "\n",
    "    return spec_df, learn_df, opt_df, fail_df, learn_summary_df, opt_summary_df, gt_df\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e88e7a1f",
   "metadata": {},
   "source": [
    "## Tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "813038a0-30b4-4138-b56a-397a9bc381a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[MDVSP] inferred in_dim=8 from Xtmp shape=(2000, 8)\n",
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2000, 8)  mean(mean)=25  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(2000,)  mean=2.02e+06  std=4.17e+05  min=6.96e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MLP ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=8\n",
      "  model: params=17,793 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA5mVJREFUeJzsnQWYVGXbx/8zs0Uv3Z0iqYRgobwGKCqgoh8WtmJ3vOprYmJiB7YY2AEqAhYKCNLd3bvswu7U+a77zM7uc86cnDnT9++6Znfm5HNizjz/5y6XJEkSGIZhGIZhGIZhGIZxHLfzm2QYhmEYhmEYhmEYhkU3wzAMwzAMwzAMw8QRtnQzDMMwDMMwDMMwTJxg0c0wDMMwDMMwDMMwcYJFN8MwDMMwDMMwDMPECRbdDMMwDMMwDMMwDBMnWHQzDMMwDMMwDMMwTJxg0c0wDMMwDMMwDMMwcYJFN8MwDMMwDMMwDMPECRbdNpg4cSJcLpfua/r06Ugm69atk9vx5JNPRr2N//73vzj11FPRvHlzeVsXXXSR7rJr1qzBiBEjUFhYiJo1a+KEE07AP//8o7nsRx99hF69eqGgoADNmjXDDTfcgJKSkojlaBrNo2VoWVqH1tXjq6++Qk5ODnbu3Cl/fuaZZ+Q2tW3bVm7/oEGDdNfdsWOHfHwNGjRA9erVMWDAAPz888+ay/7000/yfFqOlqf1aH01Pp8P999/P9q0aYP8/Hx06dIFzz//PKxC6/3vf/9Dsu5tuoesLKd3v0uShA4dOmie+927d+POO+9E165dUaNGDdSpU0c+P+effz4WLFiQ0O8ZnWetbV955ZWW1rd6n9F9Q98Lup/pfmjUqBGOP/54fPfdd5rfXb3XySefHPMxR3NPG7XL6Hup5oEHHpCvezAYRDpyzz334LDDDkvb9jNMujN8+HBUq1YN+/bt011m9OjRyM3Nxfbt2y1vl55lyfjNNeORRx7BF198ETF9yZIlcnvNfqvjwTvvvIOGDRti//79Cdvnpk2b5D7hscceK/c16XpRH0FNcXExHn74Yfm3uEmTJnKftHv37njsscdQVlYWsfyqVavkvkerVq3k+6p9+/a46aab5H6KCC1zxhlnxPUYmewhJ9kNSEfeeustWSyooU5luvP000+jR48eOO200/Dmm2/qLkci9+ijj0bdunXl5Uggjxs3Tn7gzZ49G507d65c9v3338d5552HSy+9VN7+ihUrcPvtt8s/HlOnTlVsl4QMrf/oo4+iU6dO+OCDD3DuuefKnd3/+7//i2jHZ599hmOOOUb+ISBefvllWdCRsPn66691219eXo7BgwfLP+DPPvusLIYmTJggixsSI/SADzNjxgwMGTIEp5xyCr788ktZmFD7af05c+bIYirM1VdfjXfffRcPPvgg+vbtiylTpuD666+Xf6TuuusuZAq1atXCG2+8ESE26VytXr1anq8eTDniiCPk/7feeit69uyJgwcPyvfC5MmTMX/+fPm+S+T37Mgjj4wYoGrcuLGlda3eZ/QDfuihh8r3PnUE9uzZI69L9xLdJ/S9IJo2bYo///wzYn3qdFGngTqcTmLnniauvfbaiO9fx44dLe1ry5YtePzxx+WOktudnuO8t9xyC1544QW8/fbbGDNmTLKbwzBZxyWXXCI/D6lPQL+zaoqKivD555/LRgOrz/FUhkT3mWeeGSH4qN9EA/v020uDx4niwIEDch+GfifUv+/xhMQx9SHJADN06FB8+OGHmstt2LBBHgwnkUzimUT3r7/+Kg9Q/Pjjj/KLBHu4/0r9kdq1a8t9NRLe8+bNw3333YdffvkFc+fOrfytovWpHzJt2jT5955hYkJiLPPWW29JdMpmz56dkmdt7dq1cvueeOKJqLcRCAQq39eoUUO68MILNZe79dZbpdzcXGndunWV04qKiqQGDRpIZ599duU0v98vNW3aVDrxxBMV67///vtyW7/77rvKad9++6087YMPPlAse8IJJ0jNmjWTtyXi9XqlwsJC6YUXXtBs/6GHHiode+yxmu2fMGGCvK8//vijcprP55O6du0q9evXT7Fs37595ek0P8zvv/8ur//iiy9WTlu0aJHkcrmkRx55RLH+ZZddJlWrVk3avXu3ZEbr1q2l++67T0rWvU33kJXlLr30UvmY6JqLnHfeedKAAQMizv2bb74przdt2jTN7YrXLRHfMzrPp5xyStTrW73PtKD7tnnz5tLRRx9tuuygQYOk6tWrR5znWLF6TzvxTLntttvk4xXPWaIoLS11bFvXXHON1KlTJykYDDq2TYZhrEG//9QPOPzwwzXnv/TSS/Kz6uuvv7Z1SmmdZPzmmqHX//rkk0/kNv/yyy8JfVbS70JBQYG0d+9eKZGIvxvUJ6Bj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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 3.558e-06 @ epoch 974\n",
      "\n",
      "Set parameter Username\n",
      "Set parameter LicenseID to value 2685751\n",
      "Academic license - for non-commercial use only - expires 2026-07-09\n",
      "iter=0  t=0.00s  best_y=1.35788e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "STOP: local minimum. best_y=1.35788e+06 x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 1282 rows, 777 columns and 19849 nonzeros\n",
      "Model fingerprint: 0xfac6829d\n",
      "Variable types: 513 continuous, 264 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-06, 1e+02]\n",
      "  Objective range  [4e+05, 4e+05]\n",
      "  Bounds range     [4e-01, 1e+02]\n",
      "  RHS range        [3e-04, 1e+02]\n",
      "Presolve removed 387 rows and 99 columns\n",
      "Presolve time: 0.08s\n",
      "Presolved: 895 rows, 678 columns, 16438 nonzeros\n",
      "Variable types: 451 continuous, 227 integer (219 binary)\n",
      "\n",
      "Root relaxation: objective 1.056091e+06, 256 iterations, 0.00 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 1056091.20    0   87          - 1056091.20      -     -    0s\n",
      "H    0     0                    1357332.2716 1057483.14  22.1%     -    0s\n",
      "     0     0 1174048.45    0  133 1357332.27 1174048.45  13.5%     -    0s\n",
      "     0     0 1193131.45    0  122 1357332.27 1193131.45  12.1%     -    0s\n",
      "     0     0 1193140.21    0  122 1357332.27 1193140.21  12.1%     -    0s\n",
      "H    0     0                    1351519.5277 1193140.21  11.7%     -    0s\n",
      "     0     0 1289635.53    0  105 1351519.53 1289635.53  4.58%     -    0s\n",
      "     0     0 1291947.94    0   95 1351519.53 1291947.94  4.41%     -    0s\n",
      "     0     0 1291947.94    0   97 1351519.53 1291947.94  4.41%     -    0s\n",
      "     0     0 1318364.50    0   89 1351519.53 1318364.50  2.45%     -    0s\n",
      "     0     0 1320180.05    0   88 1351519.53 1320180.05  2.32%     -    0s\n",
      "     0     0 1320249.12    0   89 1351519.53 1320249.12  2.31%     -    0s\n",
      "     0     0 1333000.69    0   67 1351519.53 1333000.69  1.37%     -    0s\n",
      "     0     0 1333389.56    0   88 1351519.53 1333389.56  1.34%     -    0s\n",
      "     0     0 1333483.10    0   89 1351519.53 1333483.10  1.33%     -    0s\n",
      "     0     0 1333494.25    0   87 1351519.53 1333494.25  1.33%     -    0s\n",
      "     0     0 1336000.68    0   81 1351519.53 1336000.68  1.15%     -    0s\n",
      "     0     0 1336131.33    0   81 1351519.53 1336131.33  1.14%     -    0s\n",
      "     0     0 1336163.27    0   82 1351519.53 1336163.27  1.14%     -    0s\n",
      "     0     0 1336985.89    0   88 1351519.53 1336985.89  1.08%     -    0s\n",
      "     0     0 1337043.64    0   86 1351519.53 1337043.64  1.07%     -    0s\n",
      "     0     0 1338890.31    0   82 1351519.53 1338890.31  0.93%     -    0s\n",
      "     0     0 1338971.15    0   93 1351519.53 1338971.15  0.93%     -    0s\n",
      "     0     0 1339139.88    0   86 1351519.53 1339139.88  0.92%     -    0s\n",
      "     0     0 1339144.13    0   86 1351519.53 1339144.13  0.92%     -    0s\n",
      "     0     0 1339163.26    0   85 1351519.53 1339163.26  0.91%     -    0s\n",
      "     0     0 1339171.17    0   85 1351519.53 1339171.17  0.91%     -    1s\n",
      "     0     0 1339177.38    0   45 1351519.53 1339177.38  0.91%     -    1s\n",
      "     0     0 1342521.02    0   78 1351519.53 1342521.02  0.67%     -    1s\n",
      "     0     0 1343999.10    0   78 1351519.53 1343999.10  0.56%     -    1s\n",
      "     0     0 1344043.38    0   73 1351519.53 1344043.38  0.55%     -    1s\n",
      "     0     0 1344047.72    0   74 1351519.53 1344047.72  0.55%     -    1s\n",
      "     0     0 1344050.71    0   75 1351519.53 1344050.71  0.55%     -    1s\n",
      "     0     0 1344054.10    0   75 1351519.53 1344054.10  0.55%     -    1s\n",
      "     0     0 1345846.99    0   59 1351519.53 1345846.99  0.42%     -    1s\n",
      "     0     0 1346142.33    0   69 1351519.53 1346142.33  0.40%     -    1s\n",
      "     0     0 1346204.17    0   59 1351519.53 1346204.17  0.39%     -    1s\n",
      "     0     0 1346218.55    0   53 1351519.53 1346218.55  0.39%     -    1s\n",
      "     0     0 1346238.42    0   57 1351519.53 1346238.42  0.39%     -    1s\n",
      "     0     0 1346241.85    0   61 1351519.53 1346241.85  0.39%     -    1s\n",
      "     0     0 1346627.26    0   55 1351519.53 1346627.26  0.36%     -    1s\n",
      "     0     0 1346876.47    0   62 1351519.53 1346876.47  0.34%     -    1s\n",
      "     0     0 1346901.17    0   61 1351519.53 1346901.17  0.34%     -    1s\n",
      "     0     0 1346905.05    0   61 1351519.53 1346905.05  0.34%     -    1s\n",
      "     0     0 1347091.39    0   71 1351519.53 1347091.39  0.33%     -    1s\n",
      "     0     0 1347112.67    0   62 1351519.53 1347112.67  0.33%     -    1s\n",
      "     0     0 1347116.34    0   63 1351519.53 1347116.34  0.33%     -    1s\n",
      "     0     0 1347137.76    0   69 1351519.53 1347137.76  0.32%     -    1s\n",
      "     0     0 1347162.07    0   66 1351519.53 1347162.07  0.32%     -    1s\n",
      "     0     0 1347162.07    0   66 1351519.53 1347162.07  0.32%     -    1s\n",
      "     0     0 1347396.71    0   61 1351519.53 1347396.71  0.31%     -    1s\n",
      "     0     0 1347421.74    0   70 1351519.53 1347421.74  0.30%     -    1s\n",
      "     0     0 1347421.74    0   70 1351519.53 1347421.74  0.30%     -    1s\n",
      "     0     0 1347450.17    0   66 1351519.53 1347450.17  0.30%     -    1s\n",
      "     0     0 1347480.45    0   68 1351519.53 1347480.45  0.30%     -    1s\n",
      "     0     0 1347480.45    0   58 1351519.53 1347480.45  0.30%     -    1s\n",
      "     0     0 1347608.08    0   56 1351519.53 1347608.08  0.29%     -    2s\n",
      "     0     2 1347608.28    0   56 1351519.53 1347608.28  0.29%     -    2s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 2\n",
      "  Gomory: 6\n",
      "  Cover: 29\n",
      "  Implied bound: 36\n",
      "  Clique: 3\n",
      "  MIR: 124\n",
      "  Flow cover: 8\n",
      "  RLT: 14\n",
      "  Relax-and-lift: 28\n",
      "  BQP: 1\n",
      "  PSD: 1\n",
      "\n",
      "Explored 1812 nodes (15603 simplex iterations) in 2.52 seconds (3.63 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.35152e+06 1.35733e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.351519527656e+06, best bound 1.351519527656e+06, gap 0.0000%\n",
      "[CHECK MLP] obj(x_ip)=1.35152e+06  ip_y=1.35152e+06  rel_err=2.046e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2000, 8)  mean(mean)=25  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(2000,)  mean=2.02e+06  std=4.17e+05  min=6.96e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=8\n",
      "  model: params=16,663 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA1XpJREFUeJzsnQd8E+Ubx39JugeFskfZe29kKaCyFBEUcYMbQQVxb+Wv4hYHIA7ELU7c4gYU2XsP2buMlra0Wff/PG96yeVySS5p0ow+38/n2tzI3Xsjd/d7n2WQJEkCwzAMwzAMwzAMwzAhxxj6VTIMwzAMwzAMwzAMw6KbYRiGYRiGYRiGYcIIW7oZhmEYhmEYhmEYJkyw6GYYhmEYhmEYhmGYMMGim2EYhmEYhmEYhmHCBItuhmEYhmEYhmEYhgkTLLoZhmEYhmEYhmEYJkyw6GYYhmEYhmEYhmGYMMGim2EYhmEYhmEYhmHCBIvuAJgzZw4MBoPX4a+//kIk2b17t2jHCy+8EPQ6Hn74YVx44YWoW7euWNfYsWO9Lvvff/9h5MiRqFy5MjIyMnD++edj1apVmst++umn6NixI1JSUlCnTh1MmjQJBQUFHsvRNJpHy9Cy9B36rje+/fZbJCQk4NixY2J82rRpok2NGjUS7e/Xr5/X7x49elTsX7Vq1ZCWloaePXvi999/11z2t99+E/NpOVqevkffV2OxWPDEE0+gYcOGSE5ORsuWLfHaa69BL/S9xx9/HJG6tuka0rOct+tdkiQ0bdpU89gfP34cDzzwAFq3bo309HRkZWWJ43PNNddg3bp15f47y83NxcSJE53nqmbNmhgyZAhOnDjh97ve2vbMM8+4Lbd//35xPZ9zzjnid0LL0P55++16GwYPHoxQo/eaVn9HbhMdP71MmTJFnHe73Y5Y5JFHHkHnzp1jtv0ME+uMGDECqampOHXqlNdlrrrqKiQmJuLIkSO610v3skg8c/3x9NNPY968eR7TN23aJNrr71kdDt5//31Ur14dp0+fLrdt6n2G5ufn46mnnhLvHbVq1RLvpO3atcOzzz6L4uJij+V37Ngh3j3q168vrqsmTZpg8uTJ4j1FCS1z8cUXh3UfmYoDi+4gePfdd/Hvv/96DPRSFuu8/PLL4qZz0UUXISkpyetyJHL79u2Lbdu2Yfbs2fjss8/EjY1ueFu3bnVb9qOPPsIVV1yBbt264aeffsJjjz0mbpokjtXQtPfee08sQ8vSd+i7H3/8sWY7vvzyS5x99tniQUC88cYb2LNnDwYMGOCcpkVJSQnOPfdcIbJfeeUVfPPNN0J0kbhZsGCB27I0TmKM5tNytDyJD/o+rUfJ+PHjMXXqVEyYMAHz588XLwok7OgBGk9kZmbinXfe8ZhOx2rnzp1ivroz5ayzzhLn/cYbbxSdJXRd3Hzzzdi1axfWrFlTrr+zgwcPokePHvj555+FoPr1118xc+ZM0WFgNpt1rePSSy/1aNu1117r8WCn/aTf0tChQ72uq3bt2pr7et9994n5dB2FkkCuaeU5vOmmm0SHWKDH+rnnnhPC22iMzUfO3XffLa5TujcxDFP+3HDDDeIdw9u7QF5eHr7++mthNKD7WqzjS3RTx355i+6ioiI8+OCD4pmkfr6HE73P0L179wqjC70fvPnmm+Idg57R1EFB1wQZBJTvr/Q+8s8//+B///sffvzxR/HO9tZbb+G8885z61yl7//www/4448/wr6vTAVAYnTz7rvv0q9WWr58eVQetV27don2Pf/880Gvw2azOT+np6dLY8aM0VzunnvukRITE6Xdu3c7p+Xl5UnVqlWTLrvsMuc0q9Uq1a5dWxo4cKDb9z/66CPR1h9//NE57YcffhDTPv74Y7dlzz//fKlOnTpiXUrMZrNUuXJl6fXXX9dsf5s2baRzzjlHs/3Tp08X21q8eLFzmsVikVq3bi11797dbdlu3bqJ6TRf5p9//hHfnzFjhnPahg0bJIPBID399NNu37/pppuk1NRU6fjx45I/GjRoID322GNSpK5tuob0LHfjjTeKfaJzruTqq6+Wevbs6XHsZ8+eLb73xx9/aK5Xed7K43c2fPhwqW7dutKJEyeC+j61b8KECX6XU+4X7Q99j/ZPL/369ZPS0tI8jnNZ0XtNK6H97dSpk/Twww+L5Y4dO6ZrW/fee6841spjUV4UFhaGbF233Xab1Lx5c8lut4dsnQzD6IOe//Qe0KVLF835M2fOFPel7777LqBDSt+JxDPXH97evz7//HPR5j///LNc75X0XEhJSZFOnjwplSd6n6EFBQViUEPvw/SdRYsWOae99dZbYtpvv/3mtiy9u9H0VatWuU2/8MILxXsow5SV2DQ7xADkAnPbbbdh1qxZaN68uXBfJfdKLVfpDRs2YPjw4ahSpYrTpVrLokJuVXfddRcaN24s1lejRg3R87dlyxaPZV966SXhYk0uNuRCumTJEl3t1muJoh5lsiY3aNDAOa1SpUrCUv3dd9/BarWKabTdQ4cO4brrrnP7/qhRo0TbaD3KddI0mqeEvkvWsqVLl7pNJys19W4rrYCBtL9Fixbi2MiQm/rVV1+NZcuW4cCBA2Ia/V++fLlwMaL5Mr169RLnVdl+6pWmZ7h6X2n8zJkzwqoaCqg3l64v6gFWQ73Q1CMsu/6SBZeurXr16olriyy5t9xyS0CuwVqQ9wHxySefOKfRuSDPg+uvv95jedlliyy6WpSnBZQsBNQLTlZb+s2Fk7LsF3kMkEX6sssuE78tJYcPHxbnkc4rnW/6rZP1Q/7d+SKQa1pm0aJFwnrw9ttvw2Qy6d4H8hogj4grr7zS7VgoQ2H03KvofMmu8GRloVAW8gRQQhYJWieFuJCFg84tuQwSFEJA1o7vv/8enTp1Eu6ErVq1EuMEeWDQOIU9dO/eHStWrPBoAx0v8uz5888/de8/wzChge47Y8aMwcqVK7F+/XpNzyh6vpAHD1kyyeuM3rnovkLvSvS+QvexYCFPqA4dOoj10T2IQqPI8qu+t5L3Vk5Ojrgvk1cQ3Ytkd3ey1NM7HL3jUXhVdna2uK+Rt5ESuo8VFhaK90A5nIe8COk+Jb8f9e/f3zlP6W4teyzRM4Pul7179/YIm/N1r/S1/8OGDRMu3lrvuh988IG4h9I26TjJ99byeobSvZsGNXQ/J/bt2+ecRiEIBJ0DJfK+0buS+t5Px5WeyQxTFlh0B4HNZhMvt8qBpmm9KL766qvCrfKLL74QApXECn2WIVdsetnduHGjWParr74SDwqKrySXTBmKoenTp48Q8STiSNiSKzW9JJOoVTJ9+nQhtkickVsO3bxJnJMoCgUkIOnm0759e495NI3mU7y33KEgT1dCNz16aMnz5WXppq0UAsrvKpclSODRAytQd1d5Xd7aT9D58NV+eZq6/eTSTvFEetofLNQxQA90dVwTXYMffviheDBSjC5B54mOET0wf/nlFzz66KOi84KuJYo/DxZ6oNPDmkILZEiA0wNy9OjRHsvLnRvkfk2dE+q4qWB/Z1rLaA1KdzF68aLOEbpu6PdIL1H0kKWXGrWQ8wW5OZJ4ow6wLl26iJe+UELHltpJ7vhqwU0vEhS+QOeTwjDI9ZLCGqgjwR+BXNME/Z5p/RRXF6hrP11rdK7pBVELPfcqOs7UcUTXHF1jJOJPnjwpztfff//tsU7q+KPOpc8//1zcI2XWrl0rcgpQxxTdZ+mFi5alUBbqTCB3TmoDbZsEOu23EjrHdK2QqyHDMOUPdeiSyFM+d2SXa+osJ1FO4lzOy0G/bfq90r2ZjBV0zwgmJwgZS0jEU1wxdUrSM+zOO+8U9yul4KZwOJpPscF0X6b7Gt1n6H5FUOgOtY3CVWgddD+jZzHdhyheWoaeQ/RsoXuhHGo0Y8YMXHDBBc5QNbp3yvNoOkHP/4EDB4p7JQl2CvsjYT9o0CDNfDXe7pVacdXU0eHtPk7H+PXXXxfvuvReRtskY4j8HkjQs0zPs1pPx3EgyG7hbdq0cU6jGG2K5aYOEHrXo9CphQsXipws9P5E76FK6Lqh9pMbOsOUiTLbyisQstur1mAymdyWpWnkfnv48GE396iWLVtKTZs2dU67/PLLpeTkZGnv3r1u3x8yZIhwKz116pQYnzJliljnr7/+6te9vF27dm6u2MuWLRPTP/nkk5C4Nx04cECsb+rUqR7zyDVc6bb91FNPifFDhw55LEsu5+SuKdOsWTNp0KBBHssdPHhQrEPptk37R67sL774otf2+3IvJ9f4W265xWM6tVvp4i67wf/7778ey958881SUlKSc5zcj1q0aKG5PVqOlg+Ve/nIkSOlevXqublekau+L/c6cosld+I9e/aI5b755pug3cvJzYvc2+gzudXLLstjx471euzpGqbjIP9mGjVqJI0bN05au3Zt0L8z2oa3ZZWD8jqm65amVapUSbiZ//zzz9KXX34ptW/fXrjPqdujxZVXXimujYULF0pffPGF+L3SOsn12huBuJfT9U0u2XS/UEPXbUZGhjiPSl544QWx/o0bN/pcdyDXNHHXXXdJjRs3loqKisQ4XZ963cufffZZsazyPhjIvYqub3IppeWU1/rp06elGjVqSL169XJOk9v16KOPav6u6H68f/9+57Q1a9aI5Sn8RelaOW/ePDH922+/9VhP7969pR49evjdb4ZhwgPd8+nZT+FlynsU/Wa3bdum+R26x9Cz79xzz5VGjBgRsHs5hZZQKJsvrr/+evFesWnTJt37IrfrhhtuEKE7ZXEvp3tYdna2NGzYMLfpdN/s0KGDW9icr3ulFnPnzhXLL1myxGMeTa9Zs6aUn5/vnEb3e6PR6PaOKL8v6Bm8vYcEGqJFz3K676vPufxeSaFwyu2OGjVKKi4u1lwXPY9Hjx6ta7sM4w13kyKjC+qRVPeEUe+rGnLxUSb0oB5YsgKSGyj1HJJrKPXC0XLkjqSELN3UU0q9mJTciz6TVZuSPPiDej2VLqCyRYsSjIUSrX32Ns/bsnqXU88jt1tykdZKxhYL7S8r5O1A1jpyeaKebYJ688nKTu51MpSNmqyh1BNNLvpKi+/mzZtFwrxgoV5/ckkjqwNdr+Sy/OKLL3pdnhKWkesd9RaTBXTx4sWid52sjPSbkl3WA/mdkeeHnkyqsuWfkI8B/f6oV17+rZA1nnr9ycOELAa+IIuokksuuUT0kFNP+R133OEziZ8eKBSBLCfPP/+8xzxy2yOLA1nqlVYBOu9kQaHfBnnLkBeAMnkMeSEoXfX0XNNkPSJrDbWHLC+BQtccrU95/AO5V5EnEK2DrOzKtpPFmY45nX9K8EMujTI0XQty6aSqDDLytUVWDOX35ela90tyU6XrnGGYyEBeN+QxRZ6E9FuneyDdrymxa7NmzZzL0bOFQmLICq5MDkkedoFCnkVkyaVn1OWXXy5cttX3NHpHo/uy+pmlhqzKdE8lzxulpVzt0hwo9DwlKzpZ+9XWYnqHpOcabU/pgu3tXqmG7sHy/U8L2m9lcjV676VllfdQ8hTSe+8MxntRDYUwkccSvVvTO4YS8jwg7yl6dtCznJYhDy9KqkbvRPS+pPa4pP2Rww4ZJlhYdAcB3VS7du3qdzm1m7FyGrlc0ks//deKc5VvOrIbLsUokTuMHqpWreo2Tu6vhNpdMlgo/odepLVchGW3LnIvUraFllVnFKVl5eXkZfWskyAXfbqJU6xmMOjdlrL9Wsuq26+VhZsedBTbqly2rJDAouuGhDaJbnqI0EsIZUqXRQyJS5pHD0wSvFQ+gx64NJ0yd5b1eqBrgMQ/hUVQrBp1CtGLjy/oGqDvyHHv5NJF+0LtVotuPb8zEslKYekNpWCTzyl1YCkFHx1PikXzVvZOj9s/CWKKB1Z2fAQDuVBTCIY6GzpB8YEUXiLHpamR4/WpM0+ZiZ9exigkIZBrmtw5qWOLzoNcqkcuv0IlWuje4iuTLV1j1E5vceD+7lW+cgHQPZKuZbr2laLZW94A9e9Prs7gbbpWmRl6MQ7VfZRhmMChsKbbb79dPPtINFInLt0TqTSUDOWJINfhcePGCSFFApnuQfQcpM7mQKGYXhKylN2atkn3HXIlf/LJJ0V+Cfkdjd7pfEEd5ZSjg+Ky77nnHvE+SOKOwr/ULvOBIseN0/HxBt3flaLb271SjXzP89YxoL6Py/dy5b2SOkqp41MPasEbKCT2qSOA1kNu9ep7PF0r9K5Gy8nHgN5dqEOGYv9JiNPzUgnf+5lQwKI7jFDspbdp8k2K/qtjspU9i3JvKlnOyDoeDZDFi8SOVjITmkbzKX6KIKEnTyfrmww9wCgBnFJo0bIU40TzlDddeTtt27YV/+mBR3FTZFEMFtqWt/YrtyX/p+nqchU0TZ4vr5Niv+gcKztc1OsMBfQCQS8CJHhJDFHcK/XmK5O4Uc8t9aaT0FI+QLQSsAULWbjJkk5WBaqRGShU7o06Bii+jazy3nrSvaEWlt6QBae3WGYZEvDBJj+TxX9Zk8LRcSDxTj3uWseD7gm0D96Ot9xhp/YCkO8lgVzTFO9GA1ln1JCXA3VSaHU0KbdJHU5qC4te5Pukt3skHWt1MrxQepRovbR6s9ozDBN+6P2C3htIANN9gcQqdfwpE7CS5Zs8WEjMKilLfWm5s5juZdRZTPHiZEml5IqUr0fPOxq1i5JGzp071+0+5a1MYyDI96XXXntNdKproTZ86L1Xyuum+59eoa6GntPeYsLVUHnGYA0qJKTlGGyK39fqCKFnFnk9qfeFOlK85d+hfQ+2TQwjw6I7jFAPG/U+yjc6cvekmy29rMo3AhINJCDpBVLpUkOutWS9kW+eZDkjcUPu6NQTF2koSQa5SFFGSNk1nh5o1JNLYkEWzVQLmW5sJHiUCbbIUk3JK5Tu4bROepCSy69yWUoIQseG1iW7UZGw1esa5a39lBiF3Jzl9cpuajQunwu6MZNrGU0n113ZYkcZlsn1ldxeZchd6eGHHxbtlesrE7Tv9KJALl6hhF4AyGWMOipoG+QerXSdkx+osvVQhsRYqKDjQz321IGi7hlWQr8DeilRC1L6TWzfvl1c6+qsqHoIxr2czi/9/iixHG1fPqf0G6ROCsq0HQyUvZWsuuSBURbot09J7siNUgt60SPrDt1HfGVfp+z8WgRyTWtl6qZrja5x6ihRumtrIV+P3hIv+oP2gbZBnUrUVvmaphdfOZGi0sodbigxUCg7zxiGCRy6N1JHL4Xf0L2QOn+V9wG6T6ife+vWrRPheupQvkChzkN6H6PORErIRZ2SJLppGj0D6B7q7d5L7SJPGqXYpXcZdfZyLUuxcjqhnkcu7/QMJXd6yiYeSpT3cWVCskAoD/dyqtVNgpue6yS4ldV11Oun93NyF1c+w+REqmqhTu+G9K7rq044w+iBRXcQUC+YVoZFeglWxnLSiz4JZHJpohs1ZZ8kcaIsG0a9pXKMJolqcoMh1xaKKSFBJZc0oBdhEuwk7O6//37x0kw3Xeo9pJdwvT2I/qD1kZsUQTcu6jWUs61TDK+8f/QCTA8YismkjJX0IKB4VnLJpHIUMvRCT/tBVlkqcUQ91CSy7r33XuGWpRSi9NCiabfeeqtwXSVrOglKiiclgSCLA2oPvfiSO7Macu2lWB6C1kG9nXL7qRdTvgmT2yxl/6TecWo3WRTp/NADk+Kk1a5I1C5aloQ6WSLpHFAblJZlehjRywCdU2orbY+EHcWVkRtaKN3L5QchiQ7KWk0PBNqOej5dk9RWOg60fXJLpmzRoYSOnz/oWiGBTIKWjgtd12QVoFgremmha1926w3kd+bt5cYXJPxffvll4eZHvye63kjEkRsitYEyXCt/D9QxRu2jgaAXPXqxoen0cKbrgdzB6VzTta+2hMrXn5zJla5RcrXz5gpI66IXQ8o4qwX93ugcUtUD8vagY0C/O7ru6QWUXkb9uTnqvabpBUaNnP1XK65Rjfx9EvTBiG46V3T/uOqqq8R9ju4hZBWic0AeHnquvVBBru507yLXVoZhIgeFu9D9hDr+6dmm7qCkewXdz+lZTO8t9Fyn+yZZmYPJjk1VIajjnO55ZEQgoUzPXXqOydZRWj/FdZP3FpUSI883ukfR+wtlM6fnMbWLDBN0z6V7Pz23qZ20Trq3KKHv072Wntk0n6z5dK+XO/3oeU/TyO2Z9ou8gsjKTZ3fZJWl9dN7Db3PUWcy/Vdb/vVCHdW0/3QfDzYPDLVVT1imFnqeofQMo/dg8n6gZyiN0yBDz0T5uThhwgTxnk3PQHruyTHd9J5GRjJ63qg7bCj+O1Tv2UwFxmuKNcYDX1mVaXjrrbecy9L4hAkTpBkzZkhNmjQRWS0pEzFlDlazfv16kXEyKytLZA6mTJNa2RlPnjwpTZw4Uapfv75YH2XvveCCC6QtW7a4ZQR+/vnnPb6rJ0Onv2zQ6myZO3bskC6++GKRBZoyrVNm0JUrV2qul7KBU3Zo2r9atWpJd9xxh8hArIam0Txahpal76izrufk5HjdF8r26a396mNKGTavvfZakfGTslafddZZXrPD//LLL2I+LUfL0/eOHDnisRxlVKW20Tmi9lN29ldffVXSi97s5TJvvvmmM1N+Xl6ex3zKpEpZ1TMzM6UqVaqI7JyUKV99PQSTvdwX6uzl1A7KMNu1a1epevXqUkJCgmgPLfPBBx8E/TsrC5SlmjKu0zml395FF13kkflbzriqPFaU1bpPnz7O/aBj27dvX6/VAXzti5p//vlHV1ZZyhxOvxPKAE/3Aromu3TpIj300ENSQUGBrv3Xe02rCSR7OUHHZujQoW7TAr1X0bmirOHUVsrqS/caOlZ620W/K7pXam2L7tN62vbOO++IY63OxM4wTPnzyiuviN9p69atPeaVlJRId999t8g4TfeMzp07i3sIvR/QvSDQd6P33ntP6t+/v8jSTc91qqhw2WWXSevWrXNbbt++fSKLOb2/0L1CXk55X33mmWekhg0biqo1rVq1Es8z+d6lhKorULUEereiecrn6bRp08S9n6p5qN9tFixYIO51dE+nNtAxoHHKeh7sPZy45pprNI+11j2UoOOslX09GPQ8Q/1lR1ef41WrVoms5lQFhs4FVei48cYbPSoJEY888ojImO8tsznD6MVAfyIt/OMRch+i3jTKeMmEDsqmTL2u1PMox4vHExQzRK5ySm8Bholl5HAR8prx544ezVCiHUpmqc5czzAME++QdZms+mTtlkPyKgLk8Ulel+SlF0zeGoZRUraMPwxTzpBbPfUTxaPgZph4hPI20MsauWPGKpQ4ieIRyRWUYRimokGu4RSSVdHugRTaSPmHKHcNw5QVFt0MwzBMWL1+KEGiXOIrFqF4bkpwJ1dlYBiGqWi8+OKLogO1LFngYw16ZpF3UzCJXhlGDbuXM0wUwe7lDMMwDMMwDBNfsOhmGIZhGIZhGIZhmDDB7uUMwzAMwzAMwzAMEyZYdDMMwzAMwzAMwzBMmEhAHCY9OHjwIDIzM0UCH4ZhGIaJZqgiAyUnomRzRmPF7gvnZzjDMAwTj8/wuBPdJLhzcnIi3QyGYRiGCYh9+/ahXr16Ffqo8TOcYRiGicdneNyJbrJwyzteqVKlSDeHYRiGYXySn58vOovl51dFhp/hDMMwTDw+w+NGdE+fPl0MNptNjJPgZtHNMAzDxAocEuU6BvwMZxiGYeLpGR43wWMTJkzApk2bsHz58kg3hWEYhmEYhmEYhmHiS3QzDMMwDMMwDMMwTLQRN6KbXMtbt26Nbt26RbopDMMwDMMwDMMwDCMwSJTnPM6C2bOyspCXl8cx3QzDMCEs5WQ2m/l4BkFiYiJMJpPX+fzc4mPBMAzDxCZ6n+Fxk0iNYRiGCQ8ktnft2iWENxMclStXRq1atThZGsMwDMNUQOI2eznDMAxTdsgZ6tChQ8JSSyUxjMa4iUoqt+NXVFSEo0ePivHatWtHukkMwzAMw5QzCfGUvZwG2cTPMAzDlB2r1SpEY506dZCWlsaHNAhSU1PFfxLeNWrU8OlqzjAMwzBM/MEmC4ZhGMYrsvdQUlISH6UyIHdYWCwWPo4MwzAMU8GIG0s3wzAMEz4MBgMfXj5+DMMwDBOzrN57ErtyC9GoWjo61a9SrtuOG9EdrphuisczW8xITkoO6XoZhmEYhmEYhmGY8PPMT5vxxoL/nOPjzmmM+4e0QnkRN+7lFM+9adMmLF++PGTr3LJqATY8fTZWvX17yNbJMAzDxB4NGzbEtGnTIt0MhmEYhmGCsHArBTdB4zS9vIgb0R0ObAUn0M6yDp2OfIU9W1dHujkMwzBMAPTr1w+TJk0KyTGjDt2bb76Zjz/DMAzDxBi7cgsDmh4OWHT7oHWf4diS3BYpBgsSPx0Nc3FRuZ0YhmEYJrxQ+BBlZ9dD9erVOXs7wzAMw8QgJRbt8GOK7S4v4kZ0Uzx369at0a1bt5Ct02A0osYNn+EoslFHOoJ1P88O2boZhmGY8DF27FgsWLAAr7zyikgCR8OcOXPE//nz56Nr165ITk7GokWLsHPnTgwfPhw1a9ZERkaGeI789ttvPt3LaT1vv/02RowYIcR4s2bN8O233/IpZRiGYZgowWqzY9pv2/DwNxs95t16TuNyTaYWN4nUwlWnO7tGXfxTfxRq7J2FxG3fA7gtZOtmGIaJRevwGS89xuEmNdGkO4s6ie1t27ahbdu2mDJlipi2caPjoXvvvffihRdeQOPGjVG5cmXs378fQ4cOxZNPPomUlBS89957GDZsGLZu3Yr69et73cYTTzyB5557Ds8//zxee+01XHXVVdizZw+ys7NDtMcMwzAMwwTDvhNFmDR3DVbuccRtj+hUF5d0roujp0s4e3m0kt1+CLB3FuoXbYRktwsLOMMwTEWEBHfrR+dHZNubpgxCWpK+vmLqfKXa4mSFrlWrlpi2ZcsW8Z9E+Pnnn+9ctmrVqujQoYNznMT3119/LSzXt912m09r+hVXXCE+P/3000J4L1u2DIMHDw56HxmGYRiGKRtfr96PR+ZtREGJFZnJCXhyRFsM71gXkYTVow4atu4Oi2RCFeTj6L7t4T8rDMMwTNgg13IlhYWFwvpNIUpk+SYXcxLoe/fu9bme9u3bOz+np6cjMzMTR48eDVu7GYZhGIbxTt4ZCyZ+uhp3zl0rBHfXBlXw48S+ERfcceVeHk5S09KxNbEpWli3Ysfy+ajZoEWkm8QwDBMxF2+yOEdq26GABLKSe+65R8R5k8t506ZNkZqaiksvvRRms9nnehITE93GyfXdbreHpI0MwzAMw+hn+e4TmPTpGhw4dQYmowETz22G8f2aIMEUHTZmFt06ya/TB9i7FYm7/wJwR3jPCsMwTJRCwlKvi3ekIfdym81//DklUyNXcUqKRhQUFGD37t3l0EKGYRiGYcqCxWbHq79vx/Q/d8AuAfWz0zDt8o7oXI5J0vQQHdI/SrOXK8lsfZ7436RghYjrZhiGYaIbyji+dOlSIaBzc3O9WqHJuv3VV19hzZo1WLt2La688kq2WDMMwzBMlLPneCFGvfEvXvvDIbgv6VwPP9zRJ+oEd1yJbspcvmnTJixfvjws62/UsR9KpERURR7271wflm0wDMMwoePuu++GyWQSHbJUZ9tbjPbLL7+MKlWqoFevXiJr+aBBg9C5c2c+FQzDMAwTpZVUPl+xD0NfWYQ1+04hMyUBr13RCS9e1gGZKe6hX9FCbPgIRgHJKWnYnNQcrSwbsW/Zd8hp5sp0yzAMw0QfzZs3x7///us2jdzItSzif/zxh0dHrhK1uzk98NWcOnWqjC1mGIZhGMYXeUUWPDhvPX5Yd0iMd2+UjZdHd0TdyqmIZuLG0l0eFDa9UPyvvOuHSDeFYRiGYRiGYRimwrDkv+MY8spCIbgTjAbcM6gFPrnprKgX3ARbugOgQa9Lgc3PorllC/JOnkBWlezwnRmGYRiGYRiGYZgKjsVmx8u/bsPMBTtBjmYNq1KytE7omFMZsQKL7gContMcx5CN6oYT2LdtNbJ6nBu+M8MwDMMwDMMwDFOB2ZVbKGpvr9ufJ8Yv61oPjw1rg/Tk2JKxsdXaKOBYSn1ULz6B/P0bARbdDMMwDMMwDMMwIUWSJHy2Yh+e+G4Tisw2ZKUmYurIdhjarnZMHmkW3QFyplIToHgNLAc3hOeMMAzDMAzDMAzDVFBOFZnxwFfr8dOGw2K8Z+OqeGl0B9TOiv7Y7bgX3VSnmwabzRbW7aQ16QUc/RI1TqwQPTAGgyGs22MYhmEYhmEYhqkILN6Ri8mfrcXh/GKRLO3uQS1wU9/GMBljW3PFTfbycNfplmnUbbD438L+H3bu2x/WbTEMwzAMwzAMw8Q7ZqsdU3/ajKveWSoEd+Nq6fh6fG+MO6dJzAvuuBLd5UVKdj0cTMiB0SBh14pfIt0chmEYhmEYhmGYmGXH0QKMnPkPZi34T2Qnv6J7fXx/Rx+0q5eFeCFu3MvLk1M1e6LOgX2Q/lsA4IZIN4dhGIZhGIZhGCamkCQJnyzbhynfb0SxxY7KaYl4ZmR7DG5bC/EGW7qDoEobR6mwhqdX4ow5vDHkDMMwTGRo2LAhpk2bxoc/AGbOnIn27dujUqVKYujZsyd++uknPoYMwzCMGycKzbjlg5V48Ov1QnD3aVoN8yedHZeCm2DRHQS1OpwPOwxobtiPFes4iznDMAzDEPXq1cMzzzyDFStWiGHAgAEYPnw4Nm7cyAeIYRiGESzafgyDpy3EL5uOINFkwENDW+H967ujZqUUxCvsXh4EhvSqOJDWGvWKNmL3oo/Qt2uH0J8ZhmEYhokxhg0b5jb+1FNPCev3kiVL0KZNm4i1i2EYhok8JVYbnv95K97+e5cYb1I9Ha9e0Qlt6sRP7LY32NIdJOndrxb/+5/6Esv+yw3lOWEYhmHKyKxZs1C3bl3Y7Xa36RdddBHGjBmDnTt3CgtszZo1kZGRgW7duuG3337j4x5CqITnp59+isLCQuFmzjAMw1Rcth85jYunL3YK7qvPqo/vb+9bIQR31Iru77//Hi1atECzZs3w9ttvIxqp0vs6nDGkoZ4hFwvfuR8Xv74IdrsU6WYxDMOEF0orai6MzEDb1smoUaOQm5uLP//80znt5MmTmD9/Pq666ioUFBRg6NChQmivXr0agwYNElbavXv3hunAVRzWr18vOjKSk5Mxbtw4fP3112jdurXmsiUlJcjPz3cbGIZhmPhKlvbBv7tx4Wt/Y/OhfGSnJ+Hta7viyYvbITXJhIpC1LmXW61WTJ48WbwoURKWzp07Y+TIkcjOzkZUkZgKW8/bgcXP4u7Ez3HTsR/w97bVOLtlfAb/MwzDCCxFwNN1InMwHjwIJKXrWpSeGYMHD8bHH3+Mc891JL/8/PPPxXQaN5lM6NDBFRr05JNPCnH47bff4rbbbgvbLlQEqNN8zZo1OHXqFL788kvhWbBgwQJN4T116lQ88cQTEWknwzAME15yC0pw3xfr8PuWo2K8b7NqeHFUB9SI49jtmLF0L1u2TMR9kVtgZmamsESQZSIayTjvfpgbDhCfswxFeO/9N/H2IqovxxZvhmGYSEMWbRJ9ZE0lPvroI1x++eVCcJPL87333iuEYOXKlYVldsuWLWzpDgFJSUlo2rQpunbtKkQ1dW688sormss+8MADyMvLcw779u0LRRMYhmGYCPPX1qMYPG2RENxJJiMevbA13ruue4UU3GGxdC9cuBDPP/88Vq5ciUOHDgnLwcUXX+y2zIwZM8QyNJ8ENpVk6du3r5h38OBBIbiVmVAPHDiAqMRoRNIVHwBTHe19J+lFvDN/Ez40/g/X9G4W6dYxDMOEnsQ0h8U5UtsOAHIXp5juH374QcRsL1q0CC+99JKYd88994gO3RdeeEEIxNTUVFx66aUwm81hanzFhTqi5Y4PNeSCTgPDMAwTHxRbbHj25y1495/dYrx5zQy8cnkntKpdCRWZkItush5Qr/Z1112HSy65xGP+3LlzMWnSJCG8e/fuLZLdDBkyBJs2bUL9+vU1rcQGgwFRS3IGcPsqWN4ZgsSiI7gh4Sd8PN+CLY1no2XtipEYgGGYCgTdj3W6eEcaEtIUnkQW7h07dqB58+bo0qWLmEcCfOzYsRgxYoQYpxjv3bsdLwhM8Dz44IPimZ6Tk4PTp0+LRGp//fUXfv75Zz6sDMMwcc7Ww6cx8dPV2HL4tBgf26sh7h/SEimJFSd2u9xENz1safAGWRluuOEG3HjjjWKcrNxkbaCSIuSGRlZupWV7//796NGjh9f1Ue+5sgc9IklYqjZB4q2LIH04AoYjG3Gl8Te8NnMyjl/9NHo3r1n+7WEYhmGcLuZk8aY60Vdf7ag6QZB1+6uvvhLzqGP3kUce8ch0zgTOkSNHcM011whPtqysLLRv314I7vPPP58PJ8MwTJxCRtP3Fu/G0z9tgdlqR7WMJDx/aQf0b1kj0k2rmDHd5LZHbucDBw50m07jixcvFp+7d++ODRs2COFNveQ//vijyCrrDRLq9GCXB+pdjwiZNWG4dTEKz35UjN5u/ALHP74Rf2w+HJn2MAzDMBgwYIBInrZ161ZceeWVziPy8ssvo0qVKujVq5cQ3vScocSdTNl45513hMcAdYYfPXpUZIdnwc0wDBO/HDtdguvmLMfj320Sgrt/i+r4aeLZLLgjmb2cyrdQ3U6qi6qExg8fdojThIQEvPjii+jfv7+wOlCim6pVq3pdJyVhoWznSkt3xIQ31e/uPxklyWlI+PVBXISFWPzxCLx81uu4rn87VE5Lili7GIZhKiKUNI1yhahp2LAh/vjjD7dpEyZMcBtnd3OGYRiG8c4fW47gns/X4XihGUkJRjw0tBWu7dkgukODK1LJMPWJIJcE5bSLLrpIDHqQk7BMnz5dDCTqI4rBgOTet6LIlIK0nyehl2kTGiwbhRe3TsbjkybAZIz/i/DPRYtQs3Y9tG7aKNJNYRiGYRiGYRgmxMnSnv5xM97/d48Yb1krE69e0QnNa2bycY4G9/Jq1aoJq4Ns1ZYhFzS19TtQyEJBydiWL1+OaCDtrOsgjf0BJQkZqGs4jrvznsLopz/AvhNFiGc2rl+F/r9fiNYfdox0UxiGYRiGYRiGCSGbD+Vj2Gt/OwX39b0bYd6E3iy4o0l0U+1Oyhz766+/uk2ncYqrKwtk5aZ6q1QWJlowNOyD5NuXwmpMcdTxttyNZ6e9KDL7xStFO/+JdBMYhmEYhmEYhgkhdruEd/7eheGv/4PtRwtQPTMZ713fHY8Oa83ZySMhuqnsypo1a8RA7Nq1S3zeu3evGKf467fffhuzZ8/G5s2bceedd4p548aNiytLt5Oseki4dRHOZNRHuqEE0wwv4cvX78UPaxy9Q/GGwRiRiAWGYRiGYRiGYcLA0fxijHl3Gf73/SaYbXac16oGfp7YF+c0r87HWychV0grVqwQSdBk5CRnY8aMwZw5czB69GgcP34cU6ZMESVF2rZtKzKUN2jQAHFL9eZIvf1fmL+6FUlbv8WDCR/ji68PYVON99G6TnwVijeYWHQzDMMwDMMwTDzw66YjuO/LdThRaEZyghEPX9gaV/eoz8nSAiTkCqlfv34iMZovxo8fL4ZQEjWJ1LyRnIGk0XNg/+c1GH9/DJca/sTbs25D0diX0bWR9+zssYbRlBjpJjAMEwb83dcZ33ANcIZhGCaWOGO24ckfNuGjpQ5v5da1K+HVKzqiaQ1OlhYMcWOWJPdyGqhkGNXrjkqMJhj7TkJxcRFS/nkWNxq+wZz3bMCYV+NGeBtMrrJo1AFCifMYholdEhMTRW/2sWPHUL16de7ZDqKzwmw2i+NnNBpFbhOGYRiGiWY2HMjDxE9XY+exQjF+U99GuHtQCyQn8Hs9KrrojiVSzn8QJRnVkTz/bozF9/jh3RPYMf5TNK0VpZ0FQbqXW8wlMKWmRbQ9DMOUDeo4q1evHvbv3891q8tAWloa6tevL4Q3wzAMw0RrsrS3//4Pz8/fCotNQo3MZLx0WUf0aVYt0k2LeeJGdEe9e7mK5J434QyA1Pl34wLjYrwy4x4MuPl5tKsX28LbmOC6pMzmYqSw6GaYmCcjIwPNmjWDxWKJdFNituMiISGBvQQYhmGYqOVwXjHu+nwN/tlxXIwPbF0Tz1zSHtnp7KEVCuJGdMeEe7mK1J43Ib/wFCr9/SQmGudixmwTcu5+BZXTkuIie7m1pDiibWEYJrTCkcNFGIZhGCb++HnDYdz/1TqcKrIgNdEkyoBd3i2HO4tDCPu5RZhK596Noo7Xi8832z7FWx9/GuMJiwzOT1aLOaItYRiGYRiGYRhGmyKzFQ98tQ7jPlwpBHe7uln4/o4+uKI7ZycPNSy6I43BgLSLX8bJxhchwWDHVfsew4+rdiBWkSS787PVUhLRtjAMwzAMwzAM48m6/adw4at/45Nl+0iOYNw5TfDlrb3QpHoGH64wEDeim+K5W7dujW7duiEWqTJ6JvKS66KO4QTyfpyC/OLYjJ2U7ErRze7lDMMwDMMwDBMt2OwSZv61EyNnLMZ/uYWoVSkFH93YA/cPaYmkhLiRhlFH3BxZiufetGkTli9fjpgkOQOpF78kPl5m/R4zZ78Tk27mSku34cgmmhDR9jAMwzAMwzAMAxw8dQZXvb0Ez/68BVa7hCFta+HnSX3RqwlnJw83cSO644GkVoNxvNEw4WZ+9ZHnMGfRNsQcCpGd89s47Pnp5Yg2h2EYhmEYhmEqOj+uP4QhryzCkv9OIC3JhOcubY8ZV3WO6QTOsQSL7iij6uVvoCAxG3UNx9H4t5uw+1gBYgrJvWRb5WUvRKwpDMMwDMMwDFORKSyx4p7P12L8R6uQd8aCDvWy8MMdfXFZV85OXp7EjeiO9ZhuJ8kZSBv1lvh4jnEt/pn3BmIJye7uTp6FQuD7yexmzjAMwzAMwzDlyJp9p3DBq4vw+cr9IlnahP5N8MWtvdCoWjqfh3ImbkR3zMd0KzA2Pw+HO9wuPvfa/xb25MaOtVtSWboFK95B4e7YPy8MwzAMwzAMEwvJ0l7/YzsumbkYu48XoU5WCj696SzcM6glEk1xI/9iCj7qUUqtofejxJCCRobDWPz1DMSqpVtm8/I/y70tDMMwDMMwDFOROHDqDK54cwle+GWbEN8XtK+NnyaejR6Nq0a6aRUaFt3RSnIGjne6TXzssX829uSeRixwNP+M5vRf1u7C9+sOlnt7GIZhGIZhGKYi8N3agxg8bSGW7T6B9CQTXhzVAa9f0QlZaYmRblqFh0V3FFNn0CQUGjLQ2HAIf389C7HAvNX7Nac/mPgJ5n36drm3h2EYhmEYhmHimdPFFkz+bA1u/2Q1Thdb0al+Zfw4sS8u6VIPBgrmZiIOi+5oJjkTeZ1uER+7k7X7WB6inRcTZ3qd93bSi+XaFoZhGIZhGIaJZ1btPYkLXv0bX606AKMBuGNAU3x2S080qMrJ0qKJuBHdcZO9XEWdgRNRZEhDM8MBbP3+VUQ76YaSSDeBYRiGYRiGYeIaq82OV37bjlFv/Iu9J4pQt3Iq5t7SE5MHtuBkaVFI3IjueMpe7kZKFna2uUN8rL/va5EQIVqRpOhtG8MwDMMwDMPEA/tOFOHyN5fg5d8cydKGd6yDnyb1RbeG2ZFuGhPvojueaXzu9bDAhJb2nfjmmy8QrdijuEOAYRiGYRiGYWKdeasPYOgri7Biz0lkJCdg2uiOeOXyTqiUwsnSohkW3TFAepWa2FtniPhce/30qLUo2+x2j2kFhoyItIVhGIZhGIZh4oX8Ygsmfroak+auwekSK7o0qIKfJvbFxZ3qRrppjA5YdMcI9YY9JP53tq3HfwcOIxqx26we07antItIWxiGYRiGYRgmHlix+wSGTFuEb9YchMlowJ3nNcfcm89CTnZapJvG6IRFd4yQXKsVDptqI9lgxY5/vkY0YrfbPKZZEzhzIsMwDMMwDMMEkyztpV+34bJZ/+LAqTPIyU4VmcknntcMCSaWcbEEn61YwWDAiUbDxMfaW+ZEpYu5lui2JbLoZhiGYRiGYZhA2HO8EKNm/YtXf98OSps0snNd/HhHX+FWzsQeLLpjiMZDJ8EuGdBe2opNmzci2rDZPEW3nUU3wzAMwzAMw+iCDGtfrtwvkqWt3nsKmSkJePWKTnjpso7I5GRpMUvciO54rdOtJCW7LnamOWKkD//7KaINScPSjSS2dDMMwzAMwzCMP/KKLLj9k9W46/O1KDTb0L1htkiWdlGHOnzwYpy4Ed1xW6dbhbnFcPG/1v75UedibtewdCOJs5czDMNUFKZOnSo6vzMzM1GjRg1cfPHF2Lp1a6SbxTAME/Us/e84hryyEN+vOySSpd0zqAU+ufks1KvCydLigbgR3RWFxmdfCZtkQBtpG9at/AfRLrqNKZlu47t37yzHFjEMwzDlyYIFC0Qn+JIlS/Drr7/CarVi4MCBKCws5BPBMAyjwfJdx3Hje8tx+ZtLcDCvGA2qpuHLW3thQv+mQnwz8UFCpBvABEZqdh2sq9wP7fP+RPGi14CufaLmEEqShuhWuZdnv9sbeCI6S54xDMMwZePnn392G3/33XeFxXvlypU4++yz+fAyDMMouP/Ldfh0+T7neMtamfji1l7ISGaJFm+wpTsGSTv7NvG/7ak/cSrvFKLZ0m1Kdbd0VzKcKccWMQzDMJEkLy9P/M/OztacX1JSgvz8fLeBYRgm3lm154SwbisFN7Hl8GlsP3I6Yu1iwgeL7hikSacBOGSsiXRDCdb8PhfRgl2ye0xLVIluouD3FwGruZxaxTAMw0QCyjsyefJk9OnTB23btvUaA56VleUccnJyyr2dDMMw5cnj327AyJn/4rfNRzXn78rlcJx4hEV3DGIwGnGoziDxOWn3X4gWJJtVl+jOWDQF+355pZxaxTAMw0SC2267DevWrcMnn3zidZkHHnhAWMPlYd8+d6sPwzBMPPH+v7sxZ/Een8s0qsaVf+IRFt0xSnKDruJ/dsE2RAt2u6elOznNU3QTh7fGd5Z5hmGYisztt9+Ob7/9Fn/++Sfq1avndbnk5GRUqlTJbWAYhok3zFY7nvlpCx77ZqPP5W49pzE61a9Sbu1iKrjoHjFiBKpUqYJLL7000k2JWmq36iH+N7btwoED0WEZeHv+Co9pCYnJmstKBlM5tIhhGIYpb5dysnB/9dVX+OOPP9CoUSM+AQzDVGh2HivAJTMX440FO+Gt2O/Ec5vi6/G9cN+QVuXcOqZCi+477rgD77//fqSbEdVk12uJ/xKbIclgw67f30Y08PjhCR7TTCbt7IuSMbEcWsQwDMOUJ1Qu7MMPP8THH38sanUfPnxYDGfOcBJNhmEqBqv3nsRXq/aLZGmfLNuLC1/9G+sP5KFyWiLeuLozxp3T2MO6fef5LdjCHedEZT76/v3746+/oidWOVo52fJyYP3/kL37J0jS4zAYoq+Wn9GkbdGWjFF56TEMwzBlYObMmeJ/v379PEqHjR07lo8twzBxzTM/bcYbC/7zmN67aVW8OKojamWlYHDb2hjUppZImEbx2+xOXjEI2NK9cOFCDBs2DHXq1BEib968eR7LzJgxQ7iUpaSkoEuXLli0aFGo2ssoaNH7YvG/mW0HNu0+FLVJ3z6XzvWcwaKbYRgmLt3LtQYW3AzDxDNzl+/Fze8v1xTcY3s1wAfX9xCCW4aE9sjO9VhwVyACFt2FhYXo0KEDXn/9dc35c+fOxaRJk/DQQw9h9erV6Nu3L4YMGYK9e/c6lyEhTuVD1MPBgwfLtjcVjIyaTXAksR4SDTbsX/QeohJJwqDbNa4VFt0MwzAMwzBMjHPx9L9x35fr8csm7RJg7etVhtEYfd6oTPkSsI8vCWgavPHSSy/hhhtuwI033ijGp02bhvnz5wuXM6rHSaxcuRKhoqSkRAwy+fn5qDAYDDjS6GLU3PY6Mg8tQTQiSXZkVqnuOcNLrDfDMAzDMAzDxIqFe82+PJ/LcAkwJuSJ1MxmsxDUAwcOdJtO44sXLw7LESchn5WV5RxycnJQkchq2kv8r1u4SZQjiDaM6dVgMHkmTbNIUZnDj2EYhmEYhmF0sWbvSZ/zuQQYIxNS5ZObmwubzYaaNWu6Tadxyl6ql0GDBmHUqFH48ccfRX3P5cu913R+4IEHkJeX5xz27YuO8lnlRd02DtHdwHgUM2e9imji9bafoWa1qprzGu7/HjfOXoxjJ333DjIMwzAMwzBMtGUof3/xbvz73wnN+aO71uMSYIwbYfHxVWfRpiQqgWTWJnd0vSQnJ4th+vTpYiDRX5FISK/i/Hx+7gcAJiEaKJSScdulg7zOzzEew9t7h2DfK7WARzayuznDMAzDMAwTsxnKZTrlZOHZSzuUa5uYCmbprlatGkwmk4dV++jRox7W73DUBt20aZNPq3i8cqDNLeJ/Vcm3i0t5ou5imWdzWOTV5OAwzAXavYQMwzAMwzAMEy0s/e+4puCe0L8Jruyeg2cvaYevJ/SJSNuYCiS6k5KSRGbyX3/91W06jffqpS26QgVZuVu3bo1u3bqhopFy1g3if2UpH2aLNdLNERgguY3faRnvddnTBQXl0CKGYRiGYRiGCY5tR05jwserNOclGA14emR7jO5Wnw8vExrRXVBQgDVr1oiB2LVrl/gslwSbPHky3n77bcyePRubN2/GnXfeKeaNGzcO4aQiW7qzazeCGQlINliwbfNqRKPofuva7l6XNZcUlUOLGIZhGIZhGCYwKEz2vcW7Mey1v5FbYObDx5RPTPeKFSvQv39/5ziJbGLMmDGYM2cORo8ejePHj2PKlCk4dOiQqL9NCdEaNGgQXAsZvxgSkrArtR1anFmNo2t/Adp3izr38vNaew8vKD7DopthGIZhGIaJLo6dLsG4D1Zg5d5TYrxz/cpYVfpZSb8WNSLQOiauRXe/fv1Ej48vxo8fL4bypKImUpMpqdMD2LkaiYdCVwM9lJZuX5hLzoS1LQzDMAzDMAwTCG8v+g/P/rwFFpvrnbZbwyro3ijbLa6by4IxEcteHgnIvZyG/Px8Ua+7opHdohew8w00KlwHi9WGxARThFukX3TP/mUlnu18TlhbwzAMwzAMwzD+SoH9tukwPluxH8c0XMlnLdwlSoENalMLu3IL0ahaOjrVd1USYpi4F90VnTrtB+DMj0moZziGVSv/RucekRWx+gvEAc8WP0GBCmFsDcMwDMMwDMMEXwpMhsT2yM71WGwzkcteHkkqcvZywpiSiR2pjpqAX3/7FSw2e9S5l3/R5vWItIVhGIZhGIZhvFm3X/pliy7BTZB1m2EqrOiuyNnLZRLqOzocOhp3Ys/xwoi2xahh6h55ydVYmtA1Es1hGIZhGIZhGDfunLsaI2Ysxqt/7NR1ZDh+m0FFF90M0LJ9D3EYLjEtwtaDx6PO0m00GpCeGIjjOcMwDMMwDMOER3B/vfqgrmUHtKwuYrnvG9KKTwUTFBzTHUcYqjVzfk7ZMg/oOClybcmsrTm90JhR7m1hGIYJGeYiICmNDyjDMEwMs2Rnri7BTWL79gHNOH6bKTNxI7oreskwQdWmzo+ZuWsj2hRc9bnm5E+ybkaPwj/LvTkMwzBlpXDrH0j/ZARyO01AteFP8wFlGIaJQTYezMPEuWu8zu/esAp6Nqkqam9zZnImVMSNeznHdFMXSjI254wWx8NsLonsCanVVnPycVNVNCz+CK9YR7hN91f7nWEYJtLkfX23+F9t9fRIN4VhGIYJELtdErW3R0xfjCP53t+THxjaCnee34IFNxNS4kZ0Mw6s1RyxJknFkY3p9sYjF7ZGpZREzE68Ej8PXuicbq3IHgoMw8QEJebYuU/t27cPixYtwvz587Fq1SqUlES4I5ZhGCaC/L75CAa/shBP/rAZZpsd57euiTG9Gngsx4nSmHARN+7ljINKVeuK/2nm3Kg8JM1rZmLNowNFUrWi/BPAz47pS7+egT6j7oh08xiGYXwQ3R45e/bswRtvvIFPPvlEiG6lB1FSUhL69u2Lm2++GZdccgmMRu5zZximYnDLByswf+MR5/jZzarhzWu6wGAw4OKOdfHX1qNiOruTM+Ekbp66Fb1Ot0zNhi3F//rSQeSeLkY0QoKbSExKdk7rs/GRCLaIYRgmtpk4cSLatWuH7du3Y8qUKdi4cSPy8vJgNptx+PBh/Pjjj+jTpw8eeeQRtG/fvkKX12QYpmJQZLbi5vfdBTexcHsu1uw7JT5TzDa5krM7ORNuEuIpppuG/Px8ZGVloaKSUqslLEhAJUMRVu7cgmodO5bbtvcZ6iBHOoit589BCx3LJyS6RLdMQbEFy1cuQ/cu3ZGekhiWdjIMw4SqFGK0QJbsnTt3onr16h7zatSogQEDBojhscceEwKcrOIVvZOaYZj4ZPXek1i0/RjmLt+PA6fOaC6zK7eQY7aZciVuRDdTSkISDic1QI55J07tWgWUo+iWX0ilBH3ldAwmz8tv4Ru3Y+ipT/DTiqswZOKMkLeRYRgmHnn++ed1Lzt06NCwtoVhGCZSTP1xE2Yt3OUcT0k0othi91iuUbX0cm4ZU9GJG/dyxkV+lsPObNnvvRxCeCi1Ahkc7uPBQIKbGHLyo1A1imEYJkREr6WbYRimovPrpsNugpsgwT2iUx23aZwsjYkEbOmOQzKa9QaO/Yj2uT+gxPISkhMTytn1Msi+nA1fhrI5DMMwISX47sTy5fjx43j00Ufx559/4ujRo7Db3a08J06ciFjbGIZhwsFP6w9h8udrNef1bVYd1/ZsKFzKycLNtbeZSMCiOw7JOed6FC9+AnUMuViyZiXO6tajXF9IDcH6T3xxfQhbwzAMUzG5+uqrRXz3DTfcgJo1a4oMvQzDMPFIYYkVU77bhLkr9nldRhbaLLaZSJIQT9nLabBxvWcYk9NwILU5mpzZgDO7lwPlJLpdrpf8gscwTPwRzYnUlPz9999i6NChQ6SbwjAMEzY+W74Xz83fitwCs4hsvPWcJrDY7HhrkcvFnF3JmWghbkQ3Zy93pyC9AXBmA3Bqb7mdA0NpTVhD0KZuhmGYaCY2RHfLli1x5ox2xl6GYZhYx2aXcMVb/2LZrpPOacPa18a9gx1lc4e2q82u5EzUETeim3HHnlEbyAVMBYfL3wrErowMwzARY8aMGbj//vtFXHfbtm2RmOhefrFSpUoRaxvDMEywZcAoJjsjOQHTft+OTQfz3eZ/u/YQrut90ulGzq7kTLTBojtOMVWuJ/6nFh8p920HEj+4pdcLaLn47rC2h2EYpiJRuXJl5OXlibrcSiRJEvdnDsNiGCaWxParv2/Hn1uP+V2Wa28z0QyL7jglpapDdFcyHy13S7chgJhue2r1MLaIYRgmdMRKtoqrrroKSUlJ+PjjjzmRGsMwMcszP23GGwv+0708195mohkW3XFKpRoNxP9s+3GndSMa3ctNCe5uj2XCcgb4/k6g5QVAq2GhWy/DMEwMsWHDBqxevRotWrSIdFMYhmGC4vn5WwIS3JwwjYl2OONVnFKllkN0Vzfk4eTpwvLdeACi25iQ5H3mG32BA6v0b3fpG8DaT4C5V+v/DsMwTJxlL+/atSv27fNePiecLFy4EMOGDUOdOnVEZ++8efMi0g6GYWKXi6f/jel/7vS73MRzm+Klyzrg6/G9cN+QVuXSNoYJFhbdcUpypRowlzoyHDmgv6cwJO7lgYhukw9ni8PrIL07VH8DTpdz/Dpla//qFuDPp8t3uxWdAysdNd1PRUZUMBWY0goN0c7tt9+OiRMnYs6cOVi5ciXWrVvnNoSTwsJCUars9ddfD+t2GIaJT+Yu34s1+/J0LduvRQ2M7FyPk6YxMUHcuJdznW4VBgOOmWqjrm0fju/ZDLRqX45WIP19OabEJN/rtAZQ9sZoQrmLv3WfOj73f9A5ed+Sr2FY+DzSR7+JKg3alm+bKgJvOZJDFR3bjbRb/4h0axgm6hg9erT4f/311zunUWdoeSRSGzJkiBgYhmECFdu/bz6CNftO6Vqe3cmZWCNuRDfX6fYkL6MR6ubtQ/GhzeV6LgzGQGK6Q3gJBlsfvDgfsFmA9KoBfa2w8DTSNabn/DxW/N/70RhUeXBlcG1i/FJyZDvS+Dgx5UisuJfv2rULsUJJSYkYZPLz3csAMQxTMdzJ9Vq3M1NMeP/6HmzdZmKOuBHdjCfWqi2AvIVIOL4tat3LTb5iun3xzyvAineBsT8AWXXLZul+Jsfx/4H9QHKm7q/tzi1EGx/zk8z6emuZ4IgN+cPEE7GQvdxisaB///74/vvv0bp1a0Q7U6dOxRNPPBHpZjAME8GEaf4Ed83MJDSunoHODargnkEty61tDBNKOKY7jkmt7UgqkZq/EycLzZ4L2KwhjVF0WYFClEhNzbGtwMejHW7dvz4KnNwFLHxeuTLX52D267j/pB1KJJZ9DMNEGYmJicJyXB4VK0LBAw88IGqKy0OkEsAxDFP+PP3jJp8J03o2zsazl7TD0ofOxyc392TBzcQ0LLrjmHrNO4n/bQy78c9G92Rq38yeCvyvKvJnnhdRS3dA1umPRgHbfnbG9Ho2QLEua7G+ddrtrs+S4rMe/Aj7WHFFLVfIjT9GklHFDXYbH/OQETuJ1J599llYrVZEO8nJyahUqZLbwDBM/LJ670l8tWo/Zvy5A28u9B0Kc+/glhjdrX65tY1hwgm7l8cxqTkdkJtQG9Wsh5C69y+gu8slZ/jeZ8T/SkdXQLIUw5CYErLtBiK6JaVQ9sepPZ7TElO1BTzV7FbO89oARUKhQMWgcnn6HCOWpYhRmAtMawe0GAJcOrvMq5NiwtnXD9YSYM3HQJP+QJWGYVi/GZjeHajaBLj6S5Q7/LuICEuXLsXvv/+OX375Be3atUN6unv2ia+++ioyDWMYpkLzzE+bddfe5kRpTLzBojueMZpwKLMNqp08BCn/oNfFivJzkV61Xui2G4D4rFWpbGK/BIlIVlr0lKJbD8rvBGjFctPoZCUPpAOhAmJb9QFMliJgw5chEd1Klu8+gUN5xbioQx3EEvm/PY9KS56H3ZAI42O5ZVsZhYvMGwc06AV0Lc1avW+pIwyDhvKGEhTO6gs0GwQMfa78t1+BqVy5Mi655JKIbLugoAA7duxwS+q2Zs0aZGdno359tlgxTEW1bn+6bC/mrtjvd9nzWlbHhAHNOFEaE3dEneimeK5rrrkGR48eRUJCAh555BGMGjUq0s2KWWxpNYGTgKnwqNdl9r9+IRo/tAKJZcwkHkxMt0GHS7dc5kaLpfuKcLY8YisJXHS7WboDdC+H0jU9NtxOBaf2Ah9eAvQYB3S7odw2u/FAHsJVuG7UG/+K/81qZKBV7dhxTz205hdQa42Spewr2/gVsP5zxyCL7gi6Q0trPobh5G5g2ay4Ed2xEjLy7rvvRmzbK1asEIncZCZPniz+jxkzRtQNZximYhGodfu+IY58RAwTb0Sd6CahPW3aNHTs2FEI786dO2Po0KEe7nGMPgyZNcX/5GLvoruFtAurFn6DzgMuKf+Y7qwcoGY74Mh6r4vYju9Cwh+Pa847aTa5xwvLmAuAz64FarYFzrlXn6U7QOHs7l1ugyH6fk7a/PIIkLsN+GFyuYruopLwxZf+L2E22hh348Dxb2JKdFuVOQXKSGFermcJuwh2Bu08ehpNI7Z1hjh27Bi2bt0q7snNmzdH9erVw35g+vXrJzpKGYap2JB1+6+tR/0KbkqUlmgyolG1dLZuM3FN1KmE2rVri4GoUaOGcEk7ceIEi+4gScyqJf6nmV2uq3ab3SODnsFaFOwmXOug9yxDoInUjMAtC2F5ohoSDTbtRT4fAxxZpznPBpfotpqLXRf0m+c4/m/6xrfoLpOl2/ViabfbFS2JcquY3iRzISd0AlPNNQm/if+rD/8NtL0cFZENB/LQA9FDbkFJ3InuWMkiUFhYKJKpvf/+++LeRJhMJlx77bV47bXXkJbGFe4Zhgkfd85dja9Xew9rlBnQsjonSmMqDAFnL1+4cCGGDRuGOnXqCHE1b948j2VmzJiBRo0aISUlBV26dMGiRYuCdlOjF4acnNI6ykzApGQ5LBup1nznNLPVEqakVEFYugmjERaDj/6fY5u9fxUu0bz1QBAxsWXIXq605khuseGMlwMW4gNjCCpcoSKJOLOtDIkCGQ1i4xiSS/eCBQvw3Xff4dSpU2L45ptvxLS77ror0s1jGCaO0Su4idsHNAt7exgmZkU39aB36NABr7/+uub8uXPnYtKkSXjooYewevVq9O3bF0OGDMHevXudy5AQb9u2rcdw8KDrR3r8+HHRK//mm28Gu28MgIwqDvfyDPtpp0gsKfaMdzYayl49LpiYbhmrD6cLo917vKtJcrksl5QEYcFVijSl1TtAZGtSTBCs+KL43MWvAyUFwW44yO/FM6GU3Z7Hd8eR04rZ5Xz8OZt/xPjyyy/xzjvviGevXIaLwrTeeustfPHFF5FrGMMwcc3z87foFtycnZypaATsXk4PcRq88dJLL+GGG27AjTfeKMYpPnv+/PmYOXMmpk6dKqatXLnS5zZKSkowYsQIPPDAA+jVq1egTWQUZGXXEP8r4zTyz1iRlZYISzDiNAD5YDAGLiSUbuKBYFSIbpPdHPgKlELbHmDMsdLSXQbBHjO8cTZQkgec2Alc+HLg3w+x6GMJ7//wuk0S12jZO9cqMlEbMqKiqKgINWs6OlyVUMgWzWMYhgl1/PbET1dj7wn/SWxrZSZh5jVdOX6bqXCENKbbbDYLQX3//fe7TR84cCAWL16sax1kjR07diwGDBggspj7gwQ6DTL5+S43agZIrlRNHIZ0Qwl25OUjK60qLBZFlu8QWqWcidSCebGnGtv2MojuwuPokPdH4CtQuoVTyaUAkBQv4JI9Nl7GHQTZVhLc9EK/9U+kXRjMZsvhGFVg66qmIHTL9hdD3hhRSqyI7p49e+Kxxx4TMd0U5kWcOXMGTzzxhJjHMAwTKrH95A+bsHLPKZ/LdapfGa1qZaJDTmWO4WYqLCEV3bm5ubDZbB497DR++PBhXev4559/hIt6+/btnfHiH3zwAdq1a6e5PFnP6UWC8UJyFmwwwgQ78o8fBmpXhVXL0h0SsSIFva7ipGyg+GTA39tzNA95ZyzI+n6S94XI9ZsSthH/LQCWvwUMfQHIrBU6S7eGe3msvKAHSm6BGcFV243P4xE9sOhmHLzyyisYPHgw6tWrJ8LBKM8G1comAU6eZwzDMOUVuz2yUx28NLoTH3CmwhOW7OXqRFq+6iyr6dOnT0DxseSCLtcBlS3dnHhNgdGIk8aqqGY/hjPH9gBoA7O5OCya21CGlRVkNAKKdwb8vQuMS/DwZ8vx2rFl3hdSutW+f5HjP11jV3zsbulWx46fPgx8PNpR87jLGM/VKjSOPYYSqZVY7UguywqCvFZCLbnl5H/i/lI6reLaubWRImrpjv6zYbXZcfmbS9C8ViaeHqHdsRuLUI6U7du348MPP8SWLVvEdXD55ZfjqquuQmpqaqSbxzBMBRHcE/o3wT2DWpZLmximQonuatWqibIkaqs21dvWii8LBcnJyWKYPn26GMjSzrhzIqk2qhUfw7F92wAMFaW1PAldIrWAs5eT62NmQyCI5OM5xmPoueN5oKoPGfnhSGDUe0BatntSMLUQUVu6f3scOLQG+O4OTdHtJiOl2LF07zhagDahWBEJOnMhkJyhf/kwQK79ZenwiSQhba3G8XUT3THUMVRe/LMjF+cdmIHd+2sCI170u3y0/qa1IHF90003RboZDMPEoUu5HsHdKSeLBTfDhEt0JyUliczkv/76q0iEJkPjw4cPRziZMGGCGMjSnZWVFdZtxRoFafWA4nW4YOcUbDlwDeyaojuEMd1BCB9bZt2gtzva+CeQ0Nz7ArsWAv++Dpz7qHOSJNkde+wjpvt0/klk+tqw4rt2vVZEawlwaB1Qt7Mjjj0C2Mqcab30/H57G7D6Q+Dmv4A6nSImuunYx2p6MCnMnQTKvAPlbemOhf6PtCOrMC7hu9Ix/6I7lti2bRv++usv0emt9h579FHXvZBhGCYQ5m/0Hy7KFm6GCYHoLigowI4dO5zju3btErFi2dnZqF+/vnD1pgRoXbt2FQlbqOQXlQsbN24cwglbur0jVW4AnAASDTbs+es91G7cNkyJ1BAR0W0ySLAaE31fzJu+dRPdeYXFqEwffMR0k0XYl5Qk4e78bNMpaL6+Bdj4NdD/IeCcexGLOO3KJLjp3C16CabRH+j6puujVOZrTm6Hnb1bXMfU4yDZPTuayo3oV92mksDzSMQCVBrs1ltvFd5ntWrVcrsn02cW3QzDBIrZaseLv2zFmwv/81sKjF3KGSYEonvFihXo37+/c1yOpx4zZgzmzJmD0aNHixrbU6ZMwaFDh0Rs2Y8//ogGDRognLCl2zuGSi5BW9OYp10yLITZy4OK6a7TC9vtdVHfcBTJBu91ub2RcHSD7wWOb4fl3zeRWDpaWFwqun3FdPtxJTWoBI3HfK0vkeAmqN51xER3aMXQrmOFaKpnQbWrsykhJHvhFk8fTp2XuwPI3w807odoRPJzzKlzIjK+FdGL1u82HnjyySfx1FNP4b777ot0UxiGiQN38iX/HcfnK/bjv9xCMa117UxsOnTauUzLWhkY1KYW+rWowaXAGMYLAb/19uvXzz1OUIPx48eLgYkOWjZpAKxxfD6TUAlSseOmqSQY67Qnsnt54M6+icmpGGh+Ft0MW/FZ8v8QDgp+nYoqpZ+Ncn0ypaXb5i66Df7coRXf1cpe7pOE0hj0wuPAvqVAs4FlFqGRIr9YbyeJpDp2odlf5bE3hFN1v95F/LPcuBCJ9TogJlCISuqcYNGtIsA4d7/3hCjh5MmTGDVqVKSbwTBMjDP1x02YtXCXczwlwYhXr+iEgW1qCTG+K7cQjaqls9BmGB3Eaiikpnt569at0a1bt0g3JepIaz3E+VkyF8FaeEJjqci6l2elJkKCEdYwygKrwg3ZKIsRN0u3+wu42+u1pRj4YASw8HnF8gpLt+bLu+RfdL9zHvDpFcCS6Sgvyp4MSlWdQO+1E6akXvZAS72VkfUrF4VsXbqOXHE+8MvDwMHVfhaUQtsxVAGI12NCgvuXX36JdDMYholhFmw96ia4iWKrHdUzHe8vnepXwcjO9VhwM4xOYtO0pgG7l/vAlIgV2Rei64nvYS8pcjPuhhJnIrUgBHybOpUwtldDJB8+DvhPihkUSnHosnQrs5erLN3KkZ1/uIaDa4Dmg90EjZxITVm+yiey6D5RGhv166NA74koF8rYvyIFuUL3pF6hFN2Kzo9yyN5lC6GxU9fV8vsTwPK3gcWvAY/nBbYBxbEp786JWMikJoXrZhhhmjZtikceeQRLlixBu3btkJgoB9Y4uOOOOyLWNoZhop93/96FZ+dv0ZxH1m0S3AzDVFDRzfjGnpgm/hsshTBQBu0wuJc7LajGwNdF23/8ojbYuvJY2ES3XUt0u1m63UWJm7Yia7TMlu/FIHV5VrGwY31z/9mEy/U0JiHFc9qRTUDN1gg3hkAEG4kSU2JoRHuILd2uRGpxXn/6yMbgv6sUlTHiGl2uBGjpjpWSYZTANCMjAwsWLBCD+l7LopthGDXkLv7b5iMidvvoac/3RBlyJ2cYpgKLbs5e7ht7oqOWstFSSGbZsJwDp3t5GaIWjKayuZfbJIPIZq5bdLvFdFsDe8HWcN1N/1NnKR7Z0q3kyAa/ots6/xFIx3ci8fIPAaOX47zoJeDUHuDCaWWzNr47xGGJn7QeSEwps3u52/EMYQIrSdFZEvKYbknCtl/fQlajLqjp3EjothHK1rrFG8vZ4RWdG+oQCPPp49g3/1XU7HMtMmo1QVgJQbb6cKAdFhL7opuqijAMw+jlmZ82440FvrOSy5nJ2crNMBVcdLN7uW8MSWlO0Z1gN4c8iy+5VRtlsVuGTAGGMtauNiMRqfDcP6IqXJk2TbJg9mHp9qu53WK6HZ8729fraucpi9GRPd1thf5f6BP+fVX8L/pvMdKa9nHNoIRslIgtJcvhjiwacy1Q15H8Kyj2LXH8P7gKaNALZUWZgJHETlklmKSVvTzEbF30BVosvgdYHOqkg/LKvEw/tRc4fRjI6R7ceun3bDD5jOneOfsGtDr5J05s+gB41P/LVsRFN13juxcBLYYCCUkhalZ8xnQzDMPotW7/ueWIX8F9ZfccjOqaw4KbYcpA3CRSY3xjSHZYug3mAphs5pAnFFLqxbJYGw0kFMqACd4FmLIUmZ6Ybn+qW2klk2NDjQqR47SKrf8C+O8vt+9uPKLVMaDfivbfEUV9YXMh8Hxj4Jn6bidCouRvISE0ItOgjIEPhVA2aMR0h9gSeeK/Vd43HE6mtQPeOR84uiW47TkTBXqP6a57Yqn4n20/XsbG6mpQ2VdBnhefjwEWPle29RTmOkr3Wc0Be1xEs6X7mWeeQVFRka5lly5dih9++CHsbWIYJrqt2yNmLMarf+z0uywLboYpO3Ejujl7uW9qN2wp/lcr2gnJQ1yGxtItE0zJMOd3TWW7JJMM+sScScO9vPCM9xgm/+WY7O7rlTm+E/jyBuD94W5WdatRw1IXbMwtWUVlLGecH7cedX1WoqtTRCnePSyUavdyfSg7JGzWECb1cvNWKAfLpTeLbclpRwdIYCvzPfvwOt1rkjSuTWVHh1pglkfSOW/bDorcreKffUNprfsyifexQry73fdiPOZ906ZNqF+/Pm699Vb89NNPOHbsmHOe1WrFunXrMGPGDPTq1QuXX345KlWqFNH2MgwTOeYu36vLnZxgl3KGCQ3GeHIvp5eO5cuXR7opUUm9tmeL/40NB5FkcblZOymz6FbUSi7Dy7yxjO7lurfjTKTmavfi7YdUS0n6xV7pC7uH6FYKYoUgsxlVycl0bc+17qzD/wJbfnSMKDs5zAXOjxa7t/OgQ1wozufOY76FpF7PhpBbuuVEakqhXQ7uwprXNyUnnFoPmJoTWuEf5O/B6YXh5l7uft7tvm7/ZAXOV/8eNMg/6Bj0ticEnCzSDh/RTe42x/+N89y9VcIYplAevP/++/jjjz/E7+Gqq65CrVq1kJSUhMzMTCQnJ6NTp06YPXs2xo4diy1btqBv376RbjLDMBHgyR824r4v/YfCDWhZHV+P74X7hrQql3YxTLwTNzHdjG8M6VVhRgKSYEWGPd+npbrslu4yuJerM2UHwEEpG6vtTXGBaZnfZbUSqeUXngnIlVRZbkh2z3euV5aEyhd5pRXUoPHT83cOFNvLWT8doOGubY7YXXmR4nynBJa8JVrTg6LdZlWNLLWFVO3STcdizfNDYU6pjh4TP9C0dLsdl1UfACvnAFd8AmTUcEyj0mz/Tnckg6ucE4Cbf3nE6Gpc3/kHShtgAyh8w6iRnT4IjhVaUV1vq9xi5kvTBrrlHVBn5/fxO32zH3B0I3Drv96T+5Ewf6n0ZezhY55x1orrhISgfJXmF1vw4rfLMahzM/RqqnfvXBSW2FAVoUBSHR+78qcUc+7lRPv27TFr1iy88cYbwrK9e/dunDlzBtWqVUPHjh3Ff4ZhKi7zVu/H24t2e50/ums91MpKQb8WNTh+m2FCDIvuCsQZpCAJBUizFwjdYJcMzuRn0eJenpgUnFh51zoIT1ivxdSEtwOL/VYItswklZj0936tfGGXY7rVMeVKoaMQ3YlGjZX7OQeSzeIpkwqPwmJKhdxVYSvOd/6o3URuoChj0/24l6vHd21ZgU5n/qULzi2BlrI9dmWm+G9vc/z/fQow/HXH5w9GOP5/dwdwjW93YptGQrvQ4SlM/XYqlVX4Ky68HbnFqK67E0sZ7mBz2LElq9dj49PSTYKb2DTPu+guPuXuYZGQ7b1ldptTdH/21Zd4Ytst+GzdOcCT3yJiSJLbfU9PPoBoF93Ka7RDhw5iYBimYkPJ0v47VoBNh05jzuLdPt3I2arNMOGDRXcFotiQgiypAJlwJNuxwogkp/gMnXt5WbIUJyZplNLSQYmQnfq3a5RfnhVCMD1BKnPJMHdLN1nSFOKyJM/5MdGgdbz9WNZtVo89PHiiAMVGOxqXjlvPuES3QZ2NXZ6u4zDZrRaXJNPbiULZtk/udg+xttlgTHC0yChZvCb1EpR4emD4cnF2Wmrd3PxD7CKscay0RbdimpfjrjubtyLRYSDZ/N0qhsnXkuLY2FXHxqfoLiXfaoTXyF8/7tjKvVOGE3Td+474f1mCe/3o8sZK7vZx5F7OMAyj5s65q/H1av8hQGThZsHNMOElbmK6OZGaf0qMqeJ/msGRMMxlewpFTLfijd8YvOhOSna0MVDIdV6vkFCifNFO8JH5XPu7Sku3XaieTGHedWGzKpLWFfsR3TaLI6vy/pWa27Op6ogTJRYzTHBNtxS5hKtbEi1v9ZzVHFgJ/HQ/bEUnXMv7U+ny/BdbALMHIf3oakWbXQJSaenWtEhrtEvl2a6JW3x4eRgi/XVC+BPddB7f6At8epW28Kb48FIkgxGF5sCTzslx7m7XgCqmW0999dUHCoHc7cDfLwNmVWZstyRt/jL9KzxhQt0xEiTHC0pUyRBjw4rNMAwTSsFNXN69Ph9UhgkzcSO6OZGaf8ylolvGqhDdZY6FVbqXl6GkUmJycJZus+RwsF5mbxHQ95Ruzs7a3U4CtHTL9bEV/Hf0lFu8tU/RvX+FI6vy2wMcyam+uAHYuxSg0l/f3wls+9mzCcKN2LUuS5FL2BsVrsVu+Do9bw0Als6E8Y8prsX1WLqXvOH8mH7YUYqKsFlcotukyJrvjC9WHBOtjp8jp71nlJciFdOtefwU14o/i+mBFcCR9cCW77XnU+eLvFaDCXtyA82I7urUcE8U5n49lEZ9u7Lsk6eCCkNCMvB6N+C3x4E/nnSbV1ziOrfFZo0yhIr1KztZokV0W2x2d/dyf+2K8ezmDMNUHJb8l+tVcLes6SghK8PZyRmmfGD38gqERSW6bcoEXCFNpBZ8X05SUmoZ3MuB7+y90Mm6A2MTftH1PWWsKcVj7z1ehCd/2IRbzmni/8ehdmsma6AbEuyK0liWwlNI8iW6SYjJfHs7sOM3YMMXQL8HgBWzkYjZmm1QZky3nlGK7uDFjeHYFtdn1Ty1hbTJmfXAz7+75puSNTs1lJ0Akq20bV+Pc62IROhXtwDDpjknnbH4F9H2co7p1uqrPFFQDDmi2WI1O2PsNfEnym2ujgaHIVxvJ5Z7IjV/HRKScj9e6+z4/3ieW6iJwZTkWu/uRW7fLzxDWSIclJjNzs/+vBHKlGtAp4VeD47wDz/eFzKLXgKWzkIWXNUBGIZhopFNB/Mx8dM1XufXr5qGqZe0x67cQjSqls4J0ximnIgbSzfjH2tCmtu40r28rGLFvWRY8OtJSEz0mpmceN06XHO+1ZDodC9/3DpG9/bUovDRj35Hn23P4IE35qI0x5x33KxkXhZWWHdtB1Y5P7cqWu4ZR394vWdZIxJxB72X9qj/yw1I3b/Ytbkzp90Sr2mh5/RIipJmzvh35fcVbc+2HnX/LllH5fZQhmt5PW4x3aViZ+sP7hte9ynwVC1drXXOCWdMt9Z2NS7wMwqrr/GbW4Gjm4HvJwPL3tJYg58LS+FeLgSqzt+TMgeBfHwNPkSl1zrd1mLXOhMUUlp1PUmKc2tQl8pTnTmlFdlQLhnm9SCpvCt8nBfyYinw9ARgGIaJhkRpX63aj5V7TuDtRf/h4un/4Ei+dy+xc1vVFEJ7ZOd6LLgZphxhS3cFwuZDdGu9NEeiZJg39mV1xT2Zk/HPzhO4LeEbj/kJlPXcqZ/dt7/C3hxdjS4Rq4QSfcmYJCtuOvE8eiesxSjTAmxHe59t8lfjl1ohKWKaU9e+577A+s99rNz1cd+hw85EaWoSSvJQ5e/HXV9TJCNzyxAeIErR7XFtGPzELSs8KJSWfqPiO5QUTlc79CyjFE4h8Niw2SUkmLz3R2pe3sowhV0LgBlnueZ1v8lt0YOnilBHXpfGHtI1I2/CKNk9lziyEfjmNqD/Q0Cz8xRftHtcj24u06pr1Gv+A4XoNiYqyoAprmUxqugcgOJ3pGiQa1sKwe817EEvIbq9iNW4xXRHS2dAcIwcOVL3sl999VVY28IwTPnwzE+b8caC/zymn9eqJupWTsF7/+5xm94pJwuju3H8NsNEArZ0VyCMKVlu467KudFTMszr+hMz8NAFbbzONyZqO7cusrXFYxbvlm9lnCtZFdvDIc5TDWa/JYSUFjttTwHJUcvYG0p3cq3vlmKy6HdptZcU+LV060FSZM1Wx+AK915fotvo6suzK9rg5l6uM1O0Hldiewgt3dfOXoaez/yBM+ZS0apVMkzje4HEKecVKS3EnteY3aKwdGsl9/vyRuDgKuCjS1RtUCX285O9XPPI2u2wFruuoQRlUkSF14bYhiJJoDpe3LF+pbt7EJZuyxlgZm/gh7sQHlQlw2JcdGdlZTmHSpUq4ffff8eKFSuc81euXCmm0XyGYWKfucv3agrucec0xlvXdsETw9vi6/G9RGbyga1r4NlL2uHrCX0i0laGYeLI0k3Zy2mwaVpcGMJYqRZwxHUsbCSO5cpZZczc6+5eHnpLtz0xHVYfL8VK0V23cipQaqyba+uPfVINnYnU3IVDhxLtLOIy7kmYtI+fQWE11Ni4z3XLRzHFFkAcafFpr+7AgWBFgisuWbKLzM5GN/dyqy7BblO6l7slUtP7O/V+LcmCWOmtoHkdH1wDVK4PpHmvIy2zaPsxESO/5L/j6N/Sy3WjFo25O1D536l+1+38uuL7WvHNZEF25hlQXAdOlMnnjm6G5b+FSOx6naoTyPnDdi0rTyMLdeEx7ZJ4diusuxc7Hwxu9eRV15NdYenW8qrQbI+3jgQtNn0LHNngGC54Ud931KXYKEHcrLOBGq2Ba+cBSemK9rm7l5c1r0Wkeffdd52f77vvPlx22WV44403YDI5riZ6No4fP14IcoZh4jczefOamc73MHIjp4FhmMgTN5Zuzl7un+Rs2anV09JdVguh2+tqOER3UgYqpXhPT5WoiAV/97puzs/FohK5l8vcZnFzcw40q7JbHWwN6x0dBYMiKZYHPoTrmWKXWE+x689ebbAU+q6FrZP/TpjdRKJNIUhI7PpyXTcoxJm3RGqp6z8Afv+f33Z4jTt2W0h59dlF0jnMudBRom3vEuDNc4Dp3V2LzL0aeOtcTS+EOYnP4e/kiUi0+zhv6nM9qy/S9v6ps33u49Uth3xaug0aAtWeqEg2OOMsJP58Lw7Pf8FtWaf1Xyum+81+wMttUFfSiFG2lSDl21ucownKxAbUgaRouzJeX3SiLHzBUQZN3qaGu7vckaALq3v5Pb9Q9v/nGgOrPnBN+2EyYC4A9i8DfrzXbfHaOIY+e2a42hglWdVDwezZs3H33Xc7BTdBnydPnizmMQwTv6XAKDkawzDRR9yIbsY/GdXquY3bDC5Hh7Iaedzq8IZec6MoszEaVkvHlOHaLuYpia6Xy5QEE7639cAOex0ssrdDIVJgkzQaZSlSZVX2LVJ/sHXHp9Z+jhGDyU2ke3NNNfoSDlt/8jrLanYJrxS7qj6yDwyWIr9x015Pj0Is55W4Z8K22ex+a4a7Zpo13ctNikRq6Vu+ABa9gFDg5tpM54HKq1Gm7b+nATv/cEwvPFa6sARs/s5RtmunK+O6Y5aEfqa1qG04gezcpV6PlkcohuKYa6K06i+dhRrbPnWOVrblKlfsKbrFttzbcKTIs01HNvzpXn9dbqPiGjUWHXNkiz+6yXtbqVSdAreOqDMnHaJa4xoV5+CP/zky0G+b77Fau9ITRq+l24unhtdbFe3bmRPAt7e5puUdcH1e86HPzZXV2yeasFqt2Lx5s8d0mlYeseszZsxAo0aNkJKSgi5dumDRIvfM9wzDBAclS/MluAe0rM6WbYaJUuLGvZzxT5XaTb2WDCtz7VzF+6ohDH05praOrOXX9mwIqN7pN9tzUNhwIAaknUF6cgJSk0y4zTKxtFEOgXKBeSp+Tr7f/YvL3oJkM7q7+rq+4sHr1hE4JlXG5Ql/CTFjUMa4erHe+YzHztvndVaCKysckiUfVlcVRqUADDSRmrnQSzk5Et3K68MAm9XitSyWQeF2rMxwrUykphdfMd3yPLcOD+V1XHgUqKVIhkfLKToEju1cjeothjjHRQI1ua2mRGDLj8gu2qmx4QBFC10npgSHoP3pXlTz4xqtdNvWsgofPmNEbY+vGlRJwTwt3VX+fgwg4e2LU3tVbVdtX5FtXtmh4ub58OkVjtJjZbV0qxK3+UUR1uBE7mzRQ4zHdCu57rrrcP3112PHjh046yxHUr8lS5bgmWeeEfPCydy5czFp0iQhvHv37o1Zs2ZhyJAh2LRpE+rX5wRODBNMdnIq71UpJQHP/rzV57K3D2jGB5hhohQW3RWIlNotRT3rZFg0EqmVMaZbkeHaoEy+FCLa1fOe/Odhy/Xom5SE2WPbivFTzkRVrnZYlK70Mn/8D1Kvh5yjTcxbvAruLfYcbJYaIBv5mu7lWonoKGY2kCRoStLkoPQAMVoVlu5ARa5S7CncFWg9Sld1cvn2mRld4VLvFjOv18IZaCI1b3G5tD+p2e6WWsV+Ld/8H4YOdc22WG3OG2LGiQ3Ar8+hZSjEGYlHcgkvOuF7ObEfRpWl2+ph2TUbkj3MvXSctDwvlNMS/Alu4pR7plvNsBM6jonpbp0Dmtn7vWSVN+qslFBScgau4nM6ULrdE9Sm4lOuUYPJZ3dgWZNJRhMvvPACatWqhZdffhmHDjlCGGrXro17770Xd90VrsR0Dl566SXccMMNuPHGG8X4tGnTMH/+fMycORNTp+rPfcAwjH9XciW3ntOYrdwME8Wwe3lFwpSIPYlN3F5CQ+ZfrnQvD1VNHwU1MrWzk8uCI1FR4kmr3JNmXHdimu7SVSelTPFfmdbKJCkscRqig0SmSRFjTZglDfEfQqoXbFG0yVudbm81xV3HIlFhaSe3W2Wyskbm7UhY+Iw+0a3IcG3y0p6yim632HilcKLs18pYh/z9jmmlJJZ2PsmYza6ODung2tCJM/kaU5bY0lyxY72Scjm7zT1cQ5LQQ/Jsm6TucJDXFWBbpdOKTIul2/fg2YbA611htyhiujUSWCrbowzjMOn0qtl50E8nhZrENJ+eJBa772vJHuOJ1JQYjUYhsA8cOIBTp06JgT7TNGWcd6gxm80iS/rAgQPdptP44sWLw7ZdhqnognviuU1x35BWYW8TwzDBw6K7gpFX21Uuwu4W013GkmEKIWcwlvGy6ns3kJKFp6s8ISzMd5gVMZoakKBONBm0yxz5qkncYqhua7BNCHuqWK1wR1eIyNSjqz2+k4YSpBS7J6saYH4J5YX3kmEGHaJbWYbL7l5aDXYkrf/Y63YNCrdgZ53yY1tRxX4coUV2L9eIZZYTfynP775lsJldngDpKm8Cm0J0nyrwkbwuGPdyuT2+oPUeXO0eV62K6T695mvtrxoMMCjLg8mW7gC9HSRFybnSNWkveGoPmix9WNFMlZD+/X/oun2aYr49YEu3ssa9LhLcO+ZOFZwJrANHd0b92Inr/u233/DJJ584MxkfPHgQBQXBed/oITc3V4Si1KxZ0206jR8+fNiLR0MJ8vPz3QaGqeiQS7lewU30a+G9SgvDMNEBi+6KRmVXMjVJWU+7rNnLFS/VZbZ0n/sIcO8unD30agw2P4v0rqP9im6l7tItuu0W3aI7NTlJWNuVlu5WJ1wZq+usfVXze1XzXZbnAikF+6XquMk8GeWBU4SpxYTKcur6bNO0AlNW50BqGCtFt3Avp7JN07uLUlzhsHQrs0532KxIzmYpdk/GReW1il1iOsnuLsqsCtGt3AfPDQbhXq6KmddcLdXefrMfshY94ZxW6cQ6tC5xWbY3rPpH+7siUaBGDHWArvCGjV+6T7Db8J+9luayJl+hDKokeW6Wbt2J1HTmMqBreNdCHFeK7P8WwLJ7iXsblPe7OHcv37NnD9q1a4fhw4eLyh7HjjlCC5577jmR1TzcqMtGkteDt1KS5HKurDGek5MT9vYxTDSzYvcJPP7tRq/zu9Sv7DbObuUMExvETUw31+nWR0JaFU1Lt5tqLbOlOwTu5UYT+jSrhmUPnYvqGb4jO6mCNCXBkjFpbN8mabxw2yxubtM+MRiRlEA2Otd6EgNIcEaYS39uAUaqls3STZm8N84Dxv8LZGqIJxIaFGZwYBXwy8Oa7uXZu3+EvVVf3dtVJlKrtvIV4Ielwe+Dz0Rqpf8V5zBJ0W5Rcsots7kFVi3RTdbvpDQ30Z1g85F1PlCXbZvFsRfm076X27PEY2/r7/lKNcXg/TgpY9tLj07AZfAKPN3LvYYjKLfvp/NK6Wqu19Ltvc686hj8+7q4dqsqp71/EaqrvmX0sx+xXqdbycSJE9G1a1esXbsWVau6jsyIESOcsdbhoFq1asJ9XW3VPnr0qIf1W+aBBx4QpcxkyNLNwpupiInSqNTXlyv348OlqoSWKh6+sLX4L3+H63AzTGwQN6KbevNpoAc29ZYz2iSluY7N7hY3oO062XXbHsKSYcZyieWWIeuz1abcvobo1rJ0kwVSp6WbrGRJJpILwXcomEvzfZ+RklAetN41B7CVWiOpdvE594iPbnsghJoJeKu/23eVorvGf1+jYH073dtV1iZPPxy84C5dm98l0k5ol8CylRTB5Ca6bbCWFLmL7j+eAhY+Bwx8Etbq/Vz77090FxwDMtSyThuLuQTijHu4brtjz6gZtOsRGbqVicskucRbmasSULpFHfcGjZrn6vUEaun2WeNeiaKzyBcpMAN/ec9F4OEiT5ncafmeExBr/P333/jnn3+QlOR+r2nQoIGI7Q4XtD0qEfbrr78KgS9D42R11yI5OVkMDFMRxfZrf2zHH1v0V1lQlgRjsc0wsQW7l1cwEtIcCcGIvv0GY6GtXUhq1Cqzl+sRSqHG5sdKpWkxtZboTqQmUeZjo3tMd6CYpQR0yKmM4nKydCfKgtuXddbLdHWSsYyFU/xuL09yJLJKz/WehCxQ2tg2ASW+LcSN1jynOb0g/6TK0m11i+luWbLeIbiJXx5Gys6fnfMS7N4FX9Pts4EXmgL/Tte1D7bShGOFp12ZtL1dY/7R/m1Vsx5Bq9yffWYvD4YGe76EyeBfdEt+BLKzNrQkIUV1bVFbNz1zDjY9089N+Bq8WrrLwF8BZM+eezWw5iNg1jmINeh4u5f5c7B//35kZrqeAeGArNZvv/02Zs+eLeqC33nnndi7dy/GjRsX1u0yTCzxzE+bMWLG4oAEN8ElwRgmdmHRXcFISnW9cCUkJiKjcmnV4LLGMypFr5fYvXBB7q82P7GrmpbuQ2tRc+PbOrdiBHmtl8XSbUECbuvfFGccds/ypcSVnMgkKTOTa4uyBMUyejklZSAszBvv+hyAC3CW+TCw5x930V3iPa66xpInnZ+NPvY/o6g0K/b8B3W1w1paAqyw0E8CqzKIzMaWHUixufZNkq3JZfxdZxbuRjVFmTyv+MnMLl9n0oeXIM3gvuzJ40fRungNWhevxqn9W/XF1YcBj7wFh9Y5/geRdT/SnH/++aJUl9L7hxKoPfbYYxiqrJMXBkaPHi22PWXKFHTs2BELFy7Ejz/+KKzsDMM4LNxvLPgv4EPBsdsME9vEjXs5o4+UTFfdYqMxQZFMTYpZ0U1Y/VjqNUW3Qoj6g44T1a4uk6XbkIj0JBOKy8m93I3TpTGWm79D48LVbkJD62zVtu7XtdpiKREpBocoyUM6wsLmb12fA4273fyd67PNIlzO9ZAjOWobhwJLqaXb5scF265HZOr8acmeK2W1dBPJpefXJ4rScF4a5GjPzt/dp9spM74i2/3JXUB9R7yiQTHdgwMrgZ/uF2EBoUKZkK90CmIVqpU9YMAAtG7dGsXFxbjyyiuxfft2EXNN2czDzfjx48XAMIyn4H7wq/W6D8vITnXQp1l1jt1mmDiARXcFo1ZOU/yTdSEkYyL6pJNlslRElrVkWATfT0mHdKjnns1TTVnEsuz6ayijpdtmSBRJ3iJi6ZbrU382xm2yXSrbkTksZaOhwZF8a7m9JdobdyEsvDPIIbDqdnZNC/RU2G2wK9zLy4uUtXOAf55E5VPaJZOc+KvjLUS0znJbpZZlvcuXGT3u5Vo3CckGm1lR1/246/oxKC3M6u++N9yRmG62ez3oshBPidTq1q2LNWvW4NNPPxV1s+n433DDDbjqqquQmpoa6eYxTIV1Kddr4aa621QGjOO2GSZ+YNFdwSA3w953fuRW3zc0otvxfbtkKPeYBUosMqStdlkjmbKIZdnS7UjQFvx6rIZEsY4i+E8OZ5WMSNARS6t/46WiOzEVMBf4F0M6WS81wgeW87FLqoUmBv01RQNm3xKHwHrosFvWesJmSoHJ5qcGNmG3wpSvz4IfStI2fyH++5M6e4+dQjM/y+jJJO5W/ioElm5d2/PXYUDXmZYl306i23XuLApPBKPS0q24RkV+Bj+Z4IPBW6hFrGGxWNCiRQt8//33uO6668TAMEzsuJSTdfvO81uEvU0Mw1TwmO7Tp0+jW7duIhaM6oy+9dZbkW5SnGMIiZVH/n4kbEXntqzhtQasT/fyADidUEXEdJcFKxJROS0RlMv6FvMkvGi5FKvtTXGP5WaPZY+jkuY6Pra6ZxkPyNJ94j83we0U3UoX7AAhV/l3bEPxh72zrs6EMkFCUhH3bKOs65QwrVJTfV8vOIpaG2YhWjl07ITfZXRbruVEavboEN2m0/u065TbrbCaXZnilWXbTG4iPfg7i7c64x7EiaU7MTERJSUlfu+JDMOUHy//6spX4Yt+zavhpdGdwt4ehmHKn6gT3WlpaViwYIFwjVu6dCmmTp2K48ePR7pZcYszpruslu7Sl2JfdZXDhcHg/2W5rO7lhxMblHnPCowZaF4zEzUykzHf3h2v2UZihHkKPrf1w0zrMLdll9u1e7nXSU3wmMXdRVyLE+qkZpYi4LtJ2smjFmhn/9ZDscJVPk8qe0z37Wa5hJ0XFC7H8jnVm4HecMgVyx6NJEs6Yrp1u5eXiu4gSwGSx0pA0PXlg3q/jYektQy5l1uKPZLOeSSzK8P9ia6T6813+12urBUcoonbb78dzz77LKzWwBMiMgwTWj5ZthcLtx/XJbjnXN+DDz/DxClRJ7pNJpMQ3gQlgKGyJ/EUaxdtyNaQMsd+lr7kR0J0W1NreEzLTk8KqaV7fUYfkUgtWLbYczAz+Qbxedw5TTzmP2cd7Tb+hBdhTfvxge18XG1+QLcYJkqKi4BdCzyWs5MlNMPz+OnFanSVPzuFsmcv95eMTSmw5WutqERnPWcFhVL01QVOkvTEdOuzXMvZy4OxdL9hHYZ/7Y5kZnrJWfOy/4Xev9iLe7lrv5WfjW4x3WUR3QbhifG97awAE6nFLtRh/dVXX6F+/foYNGgQRo4c6TYwDBN+rDY7pv22DQ99vV6XSzkLboaJbwJWIlT+Y9iwYahTp44QbPPmzfNYZsaMGWjUqBFSUlLQpUsXLFq0KKBtnDp1Ch06dEC9evVw7733ioyrTHiQ42KdMaAx5l5+g/kuWNM93Uc/H9czZDHdV5gfQu26OWUS3YPNz+JEgkPcJiYYvZ4HYqz5HhyDdmI4u2QUlru/7Y766t4okRLdxpNPbvcaxyqd3I1gOROEpXuieTx222s6xw9IVV3r8yOG7VpltYIotfWZrR+ijWT4F93dDn6oa12SLXhL9xJ7S121uQPFcHy7tuhWWLeVn01uMd1ls3QThZKf8IdAO3f3LkG0UrlyZVxyySVCcNOzOisry21gGCa87DtRhNFvLsG037bDmxPNs5e0w0uXdcDX43uxSznDVAACTqRWWFgoBDElZ6GHupq5c+di0qRJQnj37t0bs2bNwpAhQ7Bp0ybR606QEKeYMzW//PKLeEGgF4a1a9fiyJEjolf+0ksvRc2arpd0JoQ4E6mVVS7L3y9fS/fv9i64RUMMN6megf9d3BaPzNtQ2rrgLd19O7bBTec2w5JdS8vU1gSTow0JfoLDfbnCKy32y+3N0c24TXM5ihvXQ+pnl8FwYieCpXqVLOAIULNSMtJN1UiF++Ubex98Y+6D3SlXivEiEkOlh8RaGqftDbvV7FxCPorGICyUiQiR220IvXCS7DqSwelE7kTzZ+leam+JHsYtqqmUDLF8sp5TJ4pdzqwvogcUMd2SJbSi20/OgYA7HmcPAh7PQzTy7rvvRroJDFPhEqXtyi0Upb3+2noMbyzYiRKrHZnJCXhyRFtsPpTvlkiNam6P7uZ4J2YYpmIQsOgmAU2Dr/qgVJrkxhtvFOPTpk3D/PnzMXPmTBGfTVAJEz2Q0G7fvr2wro8aNUpzGRLvSgGfn6+/9jKjP6b7SH4x1u47hfNa1YRRQzTK8ZDl4V5OluDnE2fhbsutYtybhq2ZGRoX4iEd6iHRRHW6y7YeWWz7E91HpSpIS9IWnxbFT3a0+VHcavoW9yR+5rFcMdwt3d4wHdFfL1SLtLR0LH3wXGQkJ+CDP9cCARj/frN1wnmm1ZhhvQgvJ83U9R27oh60sOLm7UeyFLhYTSh1vy4zIUxUlqjDvVzJNOtI9DJuRHejZ4KeREpctvtvGHzs5y3mO3GV6TeP6eQVErLj4webzQq7wrptUHgtJHjJXt7IvjegbcheLlqi+4hUGTUNp0o3YQcOrXNkWa/XFfHA0aNHsXXrVuGV1rx5c9SoEXwoCcMwgZcCG9axNoZ3rCuGQW1qOYU5lwJjmIpHSGO6zWazENQDB7rXTqXxxYsX61oHWbdl4Uz/SXBT+RNvkJBXus3l5OSUcS8qGDpjus9+7k/c/MFKfLlqv59EauHnL3sndCuZiQX2DmLcm9c31cQOBaYEh3j35l5ukXxbZ9XtSTAZvIqgRy1jsEWqj2Y13OOj86Q0rLM3wq/2Lm4WPGUM9CmFe/d3Nnf3eiUFCdkIFVJCKmpWSkF6cgKSUxy5GPQyznInzil5Cd/Ye+suiWVcOsP5uSGJr5fboIr9ZMDtTjSEyNL92bWhWY/I1h1Y58FxqRL+s9fWnFdv4T3AnAvQpGid5vxd9pqYb++GM/DsmKKOM1M5WbqNf7/olvm85aGvgc+vA45tRVXb0ZDEW/tyL3/VOhL7pdLwJbKyz+oLvH0uUOKe5T/WoGfnNddcI+p1n3POOTj77LPF56uvvhp5edFpnWeYWGTu8r0+S4F9vHSfsIITJLRHdq7HgpthKighFd25ubki8ZnaFZzGDx921df1xf79+8ULArmw9+nTB7fddpuwdnvjgQceEC8R8rBv374y70fFojSm289S5CZFLNyeq72AM6a7vNzLXdvxVhpHyyIfDKaEJJ/iPtFg06yz7bFcqdg2GbV/diSC3rcNEp+rZriLoU4lb+Ii81MwqyzYSjfpLiVvoHPxG7jWfB8+sp3ndX96W2Z4xHwHTaJLyKSna4vuVXbtkl5WJGCPVMvNnf4kMn1vbtVshIJl9lYhWQ+2/hA20b3DXsfn8tRB8bpNIzmZDuTwA2VMvnOelFhuotu0ag5q7fjUfeLGr4DvJmpmYw8Kg2/3cqk0U3vy8U2uicUO63esQp5mlEyNanVTjhR6NtLnFStW4Kabbop08xgmbizc933p31uMrNsMwzABu5frQS2CKMmW3pqhFO9N5cL0kpycLAYmSJzu5b4tSRkoQmPDIRik2n4SqUWgZJiX6d4s0zvttdHEeEj3+o2JiV7Xd1DKhkVKQAOjyypHlCARCarEWAmlYtufeznxwJCWwEyXVdJbnLfSDZjqVp9AJSwUHgCubpSfbd0w2LTcOZ5XYoc9OUTnKSHV+bFymvbvcL9UHRn2M2huPOB1NePNd6C6IQ+7vFxfoeZz2zl4NvEtRBNq0U3HoikOel2ezuB+qQbuME/Aq0nTA9pWEhxu3JvsDXCxyeGFNMt6gfiNL5dalJt7OVH12DLPiXv/dRstUwULg+9EarL7eVKuQnSb3cubLbO30HTjj1Z++OEHEdZFHdcylFTtrbfewuDBgyPaNoaJB8h67cvCrYTcyRmGYUJq6aYs41TyS23VpriycCdCmz59Olq3bo1u3bqFdTvxhlMk+3mp/S7pIXyb/AjaF/6tvZ6ylhwrA97EtUkxfXAbV4bzj20DAlp/QqJDTKo7jn63dULvkleRYzjm8Z0bLZ51gWW3cn9u70+NaIvG1V3u5b6WTvQqjgxoX/yWsHyTG7cafwnL9GI0utZTOU07eZuecm0/2s/Ce6VW/lDwsOU6HJMqac5bmnEe5o7rLTLfR6vo/sx6jt/yaS5X/MA7UNIMjg6hd21DREz9ZSWPYKr1KtxkuVskHfQnun+yle991l4Gd2/Jj6VbPo6JpxQv0Gb37a2zN8aDFkfJv1igatWqmlnKaVqVKlUi0iaGiRex/eXKfZjx1w5dy1PCNI7fZhgm5KI7KSlJWKp//fVXt+k03qtXr7Ae8QkTJogM6cuXuyx6jA6cQtK36G5kPCL+d8r/07eluwxltfRyXe+GbuPeNqnUtv1aVA96e8YEh6VbvRl6iSeB8ppthBj/2DoA/9pa4wXLKPxrbyMShRGLbY6ax5VSEt3czL2RZDK6CfN9kve2+xJH+UgXlm8tylq3XJ2Rnaicpu2yTu7Kej0gejZ2lQ8Llnetg/Ch7Xyv822mZHRrmC0y3w8vmYJIs8/uOL9Vi/5zZhR/wHqjW4y+L7EYjA04rdQLgxLzPWe9HMskd3d7f9nLtTqawknCO+cG/V1DqYdJIVxeGTJb7fVQ3+jYl7RDriyA1hJ3d1AK63DGfscADz/8MCZPnoxDh1wePdQZfs899+CRRx6JaNsYJpbdyUfMWIy7Pl+HXze5e7cpy4CJEmClpcDuGxKiUCaGYSqee3lBQQF27HD18O3atUu4g2dnZ4uSYPSgpwQuXbt2Rc+ePfHmm29i7969GDduHMJt6aaBYsqZANCZvdy1vBfxVPr98nAvf/iC1ujXogbGzF7m09KtjOkuS3y3bOlWr6JAcrzEv2a9GAtt7bBWaiLilGUmWSZgoG0FltpboVXtSnjoglY+Y7plKFM6MarkUVyf8BOmWLwn60oIMiGYJUSWbqWrfOVUbdGdC/11ga/t2QDmL0xIKo2TH1zyDO6tuw4Dcj/2+11KQtfDuBkvWR2VDt63DsRdiV+4ZagmJFNyyC3+xBkpCakGRcZtnWySGiAHLhG7T6ohQgX81T3XuqJnWwfj+oSf/W7zTesFPuf/bO+O8cZvvc6vZziGFfbm6OqlZF2oMRRqv+DqQTI4zvExyf06vM18O1ZILTW/k/D+hW7jZiRgob095lgHYmzCL4qVS97viRGEqoXQc7pBgwbOUp30HKZQrGPHjolSnjKrVq2KYEsZJjas239tPerXnVxZBoyt2wzDlFl0UyKW/v37O8dJZBNjxozBnDlzMHr0aBw/fhxTpkwRvext27bFjz/+KB7+4bZ000BZW7Xc6hhtDLLo1pmoyJuotpV+vTxEN1mB29RxWXD1ZC9XupprLW6WEpDkRcAmlFq61eL+dKnljIT2Sskzw34B0vCV/Wzx+Z+JfV3r89MBIHcQLJdaYrlFWxTI/GA7C3ckzMN2e10EgrJzgDBLLqEbCCaF1T4jRft2kqsSO/4s52RVTCq14FMm9++r99Qlun+ydXcmoiNm2IaLY0ixvN8lP+ycbk1wiVkSt6GiZ8lrWJNyS8DfI0GnpBIcVla97uXK35y/WtTE5eaHsdzuvSIEMc16CTbb62OJvTXeT5qKVkb3BJV/29thomUCOhm244vkyHsLyOy1V3dartUx21sl98oW39u9Z/jXuj/QEacOHTfRbbcCphAlJQwhF18cXII9hmH0lwMjJp7bFA2qpnMZMIZhQi+6+/Xr5zepzfjx48XARD8Ug09YdWcHdr3gH80vxl/bjmFEp7rlHtPtzbrtvoy2ANcqS/UTemI4FmmuJyHB0TGh3mRhqaU7UPzFdKtn03a9/eS2SvXRs/g1nPCT9ZuEh1Gx31Yqc6bYDrkZy0I3EM5kNnJzi9eiRuP2MO37S9f6qENCWYtctJVqwF/wEvCDo4PPG2oBTeMkGhsZ3JPmnUprEHKLf65UCaf8nAO9olvGn6W7cfU04LC76PaWcE8JHRP/bUrEd3ZHSNBQ81Sxjd0pVznnP2IZK47vEQQWH/yU5Uo8lPixCAG4LmE+Qs0qqRnqK7wGHMjHJPgOQblqgEenItUVj0LR/dhjj+la7pNPPkFhYSHS0znRE8MEY90mrzu2ajMMU+4x3ZGEE6kFh9HkeOE3KGrlyhRbbDh62j2jsjJm+67P1+LeL9bhf99vgr3UrV/PS38o0OMtrhTm/jT6M8abcFpDRFN8rZx1nLSfkgV276XsfOHX0q1qbMecyj6XP4SqzhJQ3lCfF7XYTC9NrBUIN5kn40x2S834bplXrRdjf5UeMHkR5FodEtsld6u9jXocut0APO67vrDVy7WnjF+nbPP7aw8OeWx7Wa57yn6vFafvz9J9MMnR4bFecnV87LaHPmEl5S1QClbKW3CyNFeAuu3+eMt2gegkerE0BECLE5J7jXo9UCfAhSVP4rDkWYPeLnvzlAG5Y0S2mjv5fAximVtuuQVHjjjydTAM4xDb1727TMRuv/K772RpnCSNYZgKKbo5kVpwSMmOF1y7uRDHTrsLr37P/4XuT/2Og6fOKKa6XjoXbc9FJorwwb+7YC+1dJeX6DbosFopxasv6zLF/JLL8dvWoW7T86Q0jDY/4vyuvdTc3L14OkaUPIG1knb9aX9oiVP3druP29VqPwiOGKr7tAoflXwLezXf2nriV3tXZ/y5N16yXoa0pISAOiTuNI/Hj7buGFnyuJj215ajHtemFjef01xkqX9mZDu36amK0m39S15CekZGWGK6fZHvwytCneBLLueV50N8brPXxdY0RwbxvVJNDC15GmcVv4Yf7Gch3Cgt8+owBSVUqo4s287vkXcFDKKTSO3NoExStk3lBq6HrfYcbJAaa1qzHZ0GDuylNbkDRW6vh6XbGJaqm+VGmUqxMUyccefc1UJs/7nVd6LIga1rcJI0hmEqruhmgiTJ8WJfkH8S3Z76DXlnHC/8xOF8h5V78c7jzmnKl872iQewPuVGvJA4C3abtVzrdOsxXnmL6W5f1xVjvNHeAGeXTNN0jXa4lCpcd0vfT4+iClZLzYJuuz9Lt7o0mbD0lpGHku/D3rQ2uNL8oKbYnGfrrXtdJIbvtozzOK7eSE3SL2zpnB1AdYy3TMIqqbmYVmi2YdC0hX6/O7BdXbxxTRf0auKeZXqnVEeIVEp2Rx4BytJmdik0t0B/Z+gve0ev806qxLWcW8CXpfszWz+0rO3Ka7BJaojDqCqu2YtLpuBwg2GYU8txrn2Rk52KC9vXxpMXt/W77Bo7iVrgU5srp4dZdR0dUliaqVTdn4r9Vgp0tYeB0pWeYsn90a14uu4zoewIDPaXdKr0HKm/L5l8e5gwDBMbjJm9FF+vPqhr2Vv7NWWXcoZhKq7oZvfy4DAkO+JQM+AQ2DuOuurTjjX9jNcTX0F6gqSpdm83fib+X2JaBMluC5krpx6UVmxvmlSpByk5mfwy/191V53uE1KmEGLJpXHbSkgY1KyU7NcqpKU7L+1Sz2vb1Vb3QW1q+nQvt9qkgEufqYX9VqkB3m31Fhbb22q6l/uKbf7CdjZsCguhvV53Z4yrHrzFemu220s5tROF/rOCG0tja9XrILE3yPwsrrXcL8azSrOsd2lQJUhhRzHxgV3nVDbNGydVseBJsPqN6S5CiijR9vd9/UVddyVrpKZY2/0FUY9cz7l5/crOGNahjtt05XUvc7n5EVxQ8jR+snd3TlNbrIsk9+8pO3eU15i604d+a/dbbsSXtj6YbXO5/3vjWACx5HKd7rJ44lDiOK1ORckYffHcDMPocyP/atV+8Z8s3Au25eo6bOxSzjAMKrroZvfy4DClOF740w0O0S1rNavNjscT38eFpqWod9SVBEspO5tiv2t6aSK2aIrpVopbErLDzE+iY/EsWLNcibTkl2gt93Pal0X3ugS6NxI1SoA9f2l7XYL4zWu6YPL57pmk1U2xKdzLh7St5bc9msLTLrltV+1evsneEE9brtBc18OW69xE0me36M/6TCQlKFO4BZ8g7+F561Gc6N0NXs4yr+VJoIxLzizNsv7udd1wRTfvnSNadZ3/tHXAHebbcE7Jy26xx/48PEp8dFJQx4+W6D6T4D0x2/HS79SrkoYG2Z7i3Gy1i3NOHSbKOG+LcPF2IV9aytrx57WqgbZ1PDPOFyMZG6WGbt4fatGtzi3gLrqVyxo8fmuf2gbgLst4HJUCS86mRCtJonuiucA8cVbZm+Kikv/hNNI81iXWpyg/xzBMbNXbnvzZWvFfr4WbanBz3W2GYVDRRTdTRtGNM26uzUUWVybrZLf3dNdLZxWcdn62l1q6lfGTkc5ernR9JmNrhwbVRYbpy7p6xoxKXur7kmB0jkv6rbNKF3G1CFQK/GqZyR6CX71vStFN89op3OP1dgTQOrzFRf9h64if7d3wpu1CkRxNyXxbVyG2lCJdKdD04Ij71vcdtWu9kg+X7MXOEu/7Lidr85cdvlqGQyhVSklEn9Yu0b3S7h4yoJVkrZKhCN/aewkX+L4lr0AvanGqTEomCzp1THfdbJf7uJqTCqHeu2lVDO/obqk+XWzFr5uOiDCAfuaXcFnJI9hgbyhyFGhdW8pjNqZXQ2f+An+oLdbFqs4FkSXfy7LuuLbnLymgzNklL3tM22hv6LlmgxFfjOuJSqKzxfe1QYkTlXxn64l1UhOvy9vZvZxhYgqybPvLSO6vBjfDMEyFFt3sXh4cplTHy3szwwE0Nex3vpIWFhU5lzGkKGNODZofJapXW46W7kAFHIlVstCuf3wgcrLTsNNeW0wnASWTrxI/euPTqyhihLVQ169WJh8j916tEmFK2ipENu2Hjv4GTDzPXUBSrP68Na7efANcJd5utUwqFdUGD9EiHwNlZnBfwliLRA3XfV/40sxUG5pqMav5xtbLKRx9Jaqb0L8JGlZzWYbtaTWEhf8xyxhcYn5CJP/yJbpnWS/UtITTcaLtdy2e6RbXrJyvZkjJVFxnuQfrSmOl1aK7aY0MXG1+APdYbvb47vHS7OHy+XhmpLtnxYNfr1eMGbBMaoULzU874+RlejWpqtlJoz/22X2/iiW1pVuZdM2EB4c6RO3tA9yTECYorke9UAI51+ca4v939p541DIGbymSIhphR9eG2bh/SCuf+0VWbfJiUHIG7pZsD0u3Ibbdyxs0aIDExNjeB4YJhCd/2KR72a4NKos63F+P78UWboZhykz0KKQywu7lwZGQ6nh5TzDY8VvyvUgodiRNO3P6lHMZq0nhvmrQdtWUbPaIxXTrSqRmdIiizBTHC+YIyxRcbn4YX9r6Cpdtitf+2HYufrV1dn7HZnC3zEleXtnJ0igztldDvHK5e9KsdFX2bmW7yJLuzdL9y51n45ZzGuOJi9q45hl9i965N5+FTVMGeSR5UVrLxXoU+6K0wharrIxL7K0C6kxRixYiOYCYbjoPKYneLaI7pHo42+xuYf7Iei4mWm5zehT4SlQ3qou7lwMd+zdtw/CebZCHe7KW6P7F3k273WQlffBc5CILo8yPucXAq9crs1lqILwI8pHu5vb9tb0vruvdUFxLFEv8ua2f18ReMkqPjEB46IJWzpwHrrYaPMrj6eUw3DscrKrM4Zd2ycGGJwaJfdMqk6aMuVejVQ7t/JLncGnJoyKJnOxp875tEPYoBHl96x7xn/I2+OpIK5GoUr37tae2zseKe/nYsWOxcKH/5IMbNmxATk7g2eIZJhah2O2Ve1zvNr7ENgntL27tjTvPb8FJ0xiGCQlxI7qZ4EgqFd0yKQX7xH9zwQnnNKXLuA0GLNh2DIUlZNlWJjMrb/fywJZRZ9k2J2Riib21aO+MqzoLSURurTdZ7nYuoxaa3jxuB7etJcTxc5e2x+MXtcHwju51puUYYhmlKCRLd4Oq6bh/SEuP+c1rZuKBIa1QJT3JTZA/emFrzXYseeBc9GhcVZTo8ucCrhTdtJ/y4VGL7g9s5/t0DW5U3T2emDwHZlqHic8/2BwJtxITDG7H8uzm3pPBUau0ktr5ItngsAzLnRe+3MvVgl59XSjFsSGADiQ6Z7Lb+n6pOpqUfIS2xW875yeWxmkTt5onok/JNK9luP6tex0eG9bG49jKzLX2E5Zu5fVI+9xakc1cDz0bV3V2QoWqlNRUy5XCRXuiebzmdUPHOyM5wbOjSWHprlM5VbjDz7EOdFvmiEbytO1SPayQ3F3CidMaJdqSE2kr3q8NSvSmTihoVtUhVx8VW5QmUjt9+jQGDhyIZs2a4emnn8aBAwci3SSGibhbuZ7YbYrbJrGt7rhmGIYpKyy6KziZWaoHS6nQMBe6eoPtpYKaOHDyDMbMXoZznv/LzeoTyezlepZRW4eV4kvM09AYekU3GflJHKtjxR++oBUykxPwwqgObtOVgkN2vR53ThOM7pojMmp3b+TpnqwU6bTM1icHe6y3eqbL6pagkdzNl+W1U05lj4Rf39nOclr+1Fbf727rI5LAtazlKfResF6GUSWPYrLFIbySTCZMS58oEo89YhkrOjk+urGHZrvoGE8tdZVuW1efiEwtzbwvH1df2dJTEt3nqQ+T8ipZdJ//JHra33SgzPCeqLDk/mTvgf2l7tBay9oMDqFXNV3binqf9WbN7X1/ex+c18rTGuyNd8Z21ZxOVnO9Md1qjqEyRpsfxTf2Pvj4ph4iy7qM0SA5ix+oRbdyrG7lVOEO/7h1rNsy1JmhFzrGMgmlHR5kvfdl6aZrXN1JoI7FV/8OCpqNQDTy5ZdfCqF922234fPPP0fDhg0xZMgQfPHFF7BYXGUhGaaiCO63F/mP4+a4bYZhwgmL7gpOJZXoll+17WfyFRNdL+DFVsfn3IISNxdUp+gup0tKqaG96QO1e7mSlAT3l+ubz3aPqxXrVXUgeHMvV7tuy9zYtzHWPDbQLSbbo12KHXn20vb48tZemjHJ1L5uDavg3FJRlZxgEmXJlBZy5Xq9ld6SUecTl620SvdapcvvdOtw8f9721nif7t6WRjYRjuTOq1judRSeA7Uq5KKAS1rYFdCY3QumYUPbAOFpbN3U/da2jKpiSbhObDu8YG48zz3+GNvpMLstv/kKk3f1+qXUVu6PTsnXMclJcGIv2zuHRte0diY0nqdVGqN94ZyWXLvlvfniu710dVLaTP1Jmm/9Yrl7g2zhUeEOt59aLtaYnshKA0v6qW/PdZVXkx5vat/j8rLla4ZLR63jBG1wp+yXOl3224dHpLj2BeVWD0s3cprjAS21a97uRH9Sl7E4JJn0Ln4DRRned43ooWqVati4sSJWL16NZYtW4amTZvimmuuQZ06dXDnnXdi+/btkW4iw4RdbF/37lKRofyH9Yc1l+nXvBpeuqwDx20zDBN2tFPqxmgiNRpsNpdQYPxjSnR3J3a6h9sUma5Ly4E55nuL6Zbdy31lKA4dhgAt3Wodq7Z4ju6WI+oej/twlYgdbWg8gr8S+kCZ7smbELEqjo8af5m09bjJEw8OdcTeqvEmsnzFNYt2KQS1N5GuTCL1vm2gcMffKdWBK5WYJ09e3BYPz9vgHF9wT3/FMdBuU6valTCiUx0cPFWMVrUznZnFlXHGvkgzlHgIaPp+5dREnCxyF7tq13X1daHsjKD1jbNMwiuYjkGmFcLy7w1tC6oBa+2NUd1wCjvtdeigB5zdfOpIR31oPO6Ki5bJVoQdKEuF6UKjufcMcnXgBGvp9tiM4jcoSY68ClqeKmQFl2mi4VZPLuuU5f1i85MBt8FUKrqLRUUGg9dYeCrdpj4PWudlt+RIwkgUmV1hA9HKoUOH8Msvv4jBZDJh6NCh2LhxI1q3bo3nnntOCHCGiSeh/dfWo5i3+gD2nHBUZfHGyE518NLoTuXWNoZhKjZxY+nmRGrBo0ziJAtpue62+gXcTWhruJdLAWa2DidKI6b6JV9t8SRxMLhtbSx76FyMND+BW8x34vPkkbq2I1sm9UKWXpnKfjKf+8PuxcquzJCuRWVDodu4SXGwVtibu1m3HRiwTcrxSDSl5uqzGqjWq6dzhCz5TUQ8vK9SayM7u8fKy6SiRNtlWbGuGpnJwl1d3Vmjvi6qGE67dURQojMS3sNKnnS6y2thNrjcqJVcbJ6Cs0umacYSb54y2KNUFSVg0xK8+0pdq/+2t3VOu6iDe5kwosSqr9PR32kJkeYWx/dFy6Xi84PWG5zH25elO13x+5CxSfoeVVq3H5PdIbop14L6PFAzJpvHYZm9BZ63jvbw1JE9EMhbQ4ub31+JaIRcyMnF/MILLxQZysnFnMQ1CfD33ntPCPAPPvgAU6ZMiXRTGSakidLIqv3K7zt8Cu4ru+cIyzYLboZhypO4sXQzwVNiSEJiaZ1up+iWFBYzRUy3V0t36fKRKBnWsJp7qS89Md3JXjJk18hMwQlUwnx7N7RQJUnypkPOa639Qu4Nch9f+9jAMmWdlvGWZdqfe3k2FOEDpQKXXLvPWGwYY74PaSjGMY3EVeUZn69Ocla91AVezc+lCdt8Wff/vm+A5ny1+CNR29m4A6ekdKSUziPvj/WSbzfi0ybt+uH0Xcrg/Y8Qy5+hRJGYKzXJdQ0+YRmDI1I2vrb1QaaG4r3C/DBGmRbgvdLkYncPbK4ZhqDX0u0vJ4Ie0T24TS38vFHbZVN5Dl+zjRCeEnnIcIp9kw9LN52Tewe3wPuL95Dq9ZpJ3tv2rKrGJ5euhBISnvQQ3QZ8ZT8bX5nP1lyfXGec8ij0bVYNT3znXm6oTmXtzpZIU7t2bdjtdlxxxRXCtbxjR/eKCsSgQYNQubIjlwPDxLJle1duIT74dzdW78vT9Z1RXXM4URrDMOUOi24GFhH/WCq6S0t/ye7i4rPiHba6IQ+vJL6OT2wDvFi6y8e9nKC4XRIZ3jIwK1/s1RKD4nX94aFLNIRI4+rpIr46ULyVRQoUPfHsWlCJOLdxowEf3tgDl8xcLOpPK2tQhxtv+k/tXi7Hnat5yzZUc/mHhrbCXZ+vFeWpvHVuqMXnHOtg5Evp+MJ2NlYnGNGvRXX8tfWY330oMDnEy8c39sCVby/1mL9WaooLS57EAUk7lp3Khj1nvVx81nJ2pCRiL1sdFmNf4RUlOkW3P4cUf+7ldP2+cU0X7DxWAEz3vpzjlBiE4FbH3SsxKUQ35UgY368pbj2nCfCEtvs+eS1sOODecSR7eFhL70Va61avx99xkN3Lqd3pqhh4olZW+f1OAuHll1/GqFGjkJLivVOgSpUq2LVrV7m2i2FCyTM/bcYbC/wnSFMnS+PM5AzDRIK4cS9ngsdsSPIo/QUvlu4LTUsw3LQYnyapYisj4F5OcbvehJinpRu6LN1K6men+U2kFmlnem/iKNFP9nK5/vbftjZOyzhZ8yjjtDLW+n/D2zit8mXBl4bzJiDVHQc9m7jqoSuxeuk7vKRLPVFG7bFh2iXWtMQfeTm8bbsAp5Ap2jXnuu5eS5gN7+hy7841ObwdejWthmY1XDW0yYVx25NDxHHcIDXGSfjPyB5sjWyiks7OHKvN90b8NSHvTGmZNoPBLTzF17mlj97OtVEjMaFyWbuqM+/ta7XrpVNZMF94im7fv2DZvVx04GksSpnWoxFKmOZLcDNMPFi4AxHcLWtlcLI0hmEiStyIbkqiRolhunXTfhljvKOM05Ut3MoyYcr4biV1Dcc16nSXn6XbH0rdqRZ9tSt5fyElayVlcX5yhCt+VmsdYhsRjmH3mkjNj3v57ebbRRbo2yx3uAlcZTKyahlJuKZnw5BZ5b3hraVK0U21UxtV065bTXXQp1/ZWXNerawUXUn3fOHNbf2Zke3xP8vVIqP215Wu0BR+ZFEhK7ueTp5AfLtX7z3lpU3t0KG0/JsvLKUeLcFauu8Y0NR5jp4ttdB/aD3XM6O6wftvZVJpLW8Hku9tqyoJUNJDLfzVeFeLbmX7yHr+z/0DNC3d1DnToZ7ncb1Fo+pBReapp55Cr169kJaWxq7rTFgF9+cr9ulePqdKCn6edA5buBmGiSgJ8ZRIjYb8/HxkZWnHVzLaKOOwJbvVM2O5PE3EOBo9XJMdy9jLtU63Hny5WFPM6J4Thbi8W32PeWStpEGNlgyJdN44raRTehKpUT3lt2yuPOSy2FaK9WDFqih7rjpYvlblbZ4yPIDKrnk7n9f2bIAL2rsySociEZ0SEs2FZpvm9HdsQ8XQy+DIuq5Vjk6g2Axl5762Z8MyWbov7aKdVK5x9Qx8M6E3Vu45iQkfrcLhfEcNczVmv6Lbc9onN52FJf8dF7HNnetXcYrRt21DscjeDjukuuL6sSis6EpPAnUc9zx7H0zDjNIxpXu557bVYSveOkJuObsJpv+5A8cLS4PB1evRiOl2ts9oRLoizl5ZMox+Fi1qZeL967vj2tnLxLQ513UTceKMC7PZLNzae/bsiXfeeYcPDRNxl3IqCTbnepcHF8MwTKSIHoXERAylUJbFs1Jo7ziibVVTIsd0R9Ml5cu9vGpGMj69uScu7qQtXrSQNCxwkbZ0k+AkEfS/i92t8kqBOr5fE7/rcVm6DQGXM1NjCFUiNUUDyIKpHFe6NKvFXKiZdU1XZCYn4LlL2+Ps5tU126fs5NBycVZab7+9rQ/G9GroLLHma1lvUKZ9X1CowJIHzxXXxeiuOR7zLVY/7uUabSBL8J3nN0fXhtlOMS3HbG+V6guPGXXdczdLt49bg0GxPZvGtg2qL3vrgKlbJRXLHzoPN/RphGcsDgv8K5LjP7HS4AirKJIcYSnK1ZCwVq/X6V5eOr2zoma6v46tisgTTzwhsqS3a1da6o5hQmjdfvnXrboEt7L2NgtuhmGihbixdDOhsXTbS8W20qX89w0HMSrJs46xdkx39LyIhloQh6iKUkhJS0rABzd49uIrxfOt/Zpgxl87fa5HXl4pOtSdFnrLSNH31MLR13e9iXu1qFWK61NIR/XSDOzKcmeBQu7nZLH2lfW7e6NsEddOQvOHdYc0l1EmatNKrKcUkkpvAiqxtnTXCXy39mBIYrrVXFNawm2uyhXTn6VbbyiFusND7JvFiyXZx+/RoPh1dSm1orvNV1m6vXlhUOcMnSc6n+/YLhLZ4AuSqmFi6fz/4SZstdbCPFsfj/XQ9aYW3ZbSbPNyJ4MhijrcGKaiEIh1m0KRRmt4sDEMw0Sa6FFITMSwK+OwZbGtiOlOgE2ztI8SOaZbnfAokijfnwOtpa2FZqhplL54U7soidjCe/p7ze6uRBaCSuuduxVQ/36S5Z2oV0Vfkilv50YpgEjUKl2VbzFPRp6UhnssN6MsBkfa33WPDcTFHev4bK9TdHk5DErRrbUepZBWJ7lTh99rWZlDjb/SYlrWdi2Rqb7+1W7fyu8Y/YjupQ+ei3kTeqN1Hc9kcwmJ+vIKyOdBrld+BNmwS67tnkYGXraOwi6ptnAlv1ARlkDtU4tu2b28oNjRGancBT016Bn/lJSUiLAw5cAwwSRMo8zkLLgZholWWHQzbkJZ0rB0K0W3V2T38igSocqXYq3M46EgevZW24pbv6ojA7s/fSBbi5XHTCmo1Fm+ffHiZR1x1/nNMfeWnmUrGaaYnqRS1quk5uhQ8hY+t/ULqG1apCSaMO3yTlh0b3//bfUyPVnRvrvOb4HzW9fEG1d31owdV7dXLUa1NPd71ztqkRNUT72sBGPp1jpPauGprh3uJrqNvkV3zUop6OglCZzBaMLIzv5DQeREaue1qqnZgaC8plc/OhCV05Lc9oXc4+803+qcZikV3XJWeGUHUUXxLn/88cfFcfM1rFixIuj1T506VeRhkYecHM9wCKbiQjW4fTGyUx2nK/l9QxzhIwzDMNEIu5czkNwSqZW6iStKhlU3+I/ptsux4FFk6Q61FVpLtpfBs7n8j4UPC6psoVRaKpVHLxBLd3Z6Em4/t5nf5UZ0qouvVx/AbaWZsH1ahzWzUpe6xIfoPNMxalOnEjYezEdTRdkv9TJaKD0EstIS8da1XXXHaavFqNay5zSvjo1PDMJHS/dgcJvgksaFw9KtPvaJqn3RbRn2Y92nsJVaPioOyCSZHPcf6vTQWrWyPera7dQ+auK/dleJuZpZ6bixe3On4Hffnxj58ZeR2267DZdf7oqL16JhQ++JAf3xwAMPYPLkyc5xsnSz8GZkjp0u0TwYE89tin4tanBGcoZhYgYW3YxmIjWn5RrAQ4kf+z1Kdps16mK6iUopCcgvtqJZDVd26aDRSvAU1bZuFyQmbHoSqbm5l7vHu5YFLa1K1omHLmjltda6XK9Zy9KtJJRuvm9e2xXvLd7tTHSmxtuW1AJOja84bbVw9SbQKVP9zWf7T4qnhypeSm75jun2nKb+uT8wtBXu+nwtbu7bOGD3cp/tgVFXDLV8HtxqfOt016f10/cos3++lCas3BOHdsSFHeppLh/uBH7RQrVq1cQQLpKTk8XAMLI7+V9bj4qyhjuPFWL+xiOabuR3nt+CDxjDMDEFi27GvcyXXG/bS21ub0iy6I6iOt3E8ofPg9UmIVVVCigYlK/uvZpUxeKdx3H1WbGRsMXROeBdfMguy27ZyxWXRVl1rbd4eG+CO1Kiu27lVDw41LuLojed1bNJ1aBLk5lUQd3hDukmF+6nR/jOLq0VjqHH0t2qdqawyMuW/1BdQ9SZd32fRvhm7QFc3NG7m3mD0nAKt+8qPvtqgnwdURb2biUzRILJ10ot587v68zGXlHZu3cvTpw4If7bbDasWbNGTG/atCkyMrS9RxjGX8K0m/o2Et4r+0+eQaNq6WzdZhgmJokb0T19+nQx0IOeCQylULbLx0+RSE0XNkfKYinKrD+USdpLKeuAUYqh2WO7YcfRAuGOHAtc1q0ePlyyFz0aZYts2WrkTgm3mG63+FVDRGLS9cQDl2fb1O7lf93dDxsO5mFI21o+v+fL2irHIcuEO40aJSvzh1YfgdZPWy3E6fgoXe2VotzXeTLAj7u7wSTCFhbdO0Bz/kc39kC7elkiPt/juwFYumVKkKS9fxH+TUQ7jz76KN577z3neKdOncT/P//8E/369Ytgy5hYTpg2tF1tIbS7Nyr3ZjEMw4SMuBHdEyZMEAPFg1EyFqZslm5nFvOARXd0WbpDidL6Ry/3bevGznX28AWt0atJNfRuWg0dnvjFY35KaW1pZWZt5f5GQmCQFfyr8b2QnuT7NuXLCh5q1EehYbV0MfjDl3u5usSYXpEYTpQZ1Ced10xkwNeKZ1dbe9WWb0OI3Mv3JPt2JaXfYyUvWfrdY7p9dd5oTfMeo67O1M4Ac+bMEQPDBCK2KVnau//s8roMzSfRzTAME8vEjehmyoJWIrUALd12s+N/lMV0My5RQtYCfwmolK7Oyn6XSNUk7qzjRUvLuhkugj0MvoS0Oh48OkS36/Ok85p7XU59XahFqlGnO7Y30T2o5Bl0M25FbqXBuNZ3i1FWtDqW1B4WyuNSURKpMUy4hPai7cfw9eqDfpcnl3KGYZhYh98aGPySOdx5FJyx3Irs5boojemOZ9EdBVoobMguzkrrnU2xw3I28uEd6yDaKFfRHWTiPF8x3R7u5VFwnekV/p6Wbe+ifN+JM17XY/Cyva1SfXxoOx8wJATtSeC2HY1pd5zbDBnJCbh7YAv/2dlNBtTITBY1vin+n2GYwOO2R8xYjMmfrdUluClpGlu5GYaJB9jSzaCk6RAczH0NdQwnFO7lgVm6DfYK4F4eBWIoXCRpiG6lULy6R32RPK5h1eizOMiu8dFs6T63VU28+Os2zcRx0Si6q2YkY/fxIr/LqS3BnpZufQfMn3u5P6OynnJiYjsazZl8fnNMPLeZpqVb7UJO7un/3D9AdEr4y1jPMIz+uG0tnr2kHUZ3i41kpQzDMP7gtwZGvHDusJdmBNao062HTQdOxL/oRnygleFZFhBK4aG0dpLYaFI9IyqTR8WCe3nrOpVE0rUF93gmk0pWtZ8ShkWaF0d1QPdG2Xj3um5+l3VzIfdj+VbzsOU68f+J5HuC9jColpGEnGzPazoQvF3XWgn8KFGcOg6fYRj/gnvmXzt0HyaycLPgZhgmnmBLN4O0pARUyUgFzrhiugNNpJYoV4GOsuzl4UouFct8d3sftH/8Fx31jRETyOXOyoOy1GX3lnAtWZXBa9rlHRFpqK2f3dJT17IktOUOGn8x3krIPfvDU+fjU1t/1E33XQVA67by3CXt8dGyvXjrmi662lm6pgCW5QzlDBPOUmBqRnaqgz7NqnNZMIZh4pKoFd1FRUVo1aoVRo0ahRdeeCHSzYl7qA6u40NwJcNSUSL+5xaWxnYzUQtleSYtpBTVahfnaEnoFW2W7skDm+O3zUdwXe/Q1a5JVrjHUwk68iiIJZSC2Jd7+f1DWrrN+3lSX7R7/BdYkeD3WtPKOn5ZtxwxhJNIJRBkmIrkUj7x3Kbo16IGx24zDBPXRK3ofuqpp9CjR49IN6PC4HQLly3dAbqXX5nwh/h/pCB+RXeMaFBdqK3YWkmhYkd0l1+UDAnijU8MQkIIy5QpOzxiUeQ5rP+ypdt9nnJcXdOeypDJ+HOsCVVUQ6CHNxrDKRgmlthyKN+vG/md5/suCcgwDBMPRKXo3r59O7Zs2YJhw4Zhw4YNkW5OhbJ0B529vJQuDbMRryjrVscT393WB5XTPOOIbSH0L6esz/Fg6SZCKbgJZXxwLGo85e9CHQOttFCXJQwgVIdFz3oosdpLv24Tn7kWN8MEztzle7F23ymRn+LLVQc0l2HrNsMwFY2A3x4XLlwoxHCdOnXEC9W8efM8lpkxYwYaNWqElJQUdOnSBYsWLQpoG3fffTemTp0aaNOYMiCVXgrOmO4gRXfD6r5jM5noo129LM3pZmtw14AWz13aQWSYnjqyXZnW89SItujRKDuiojvUKLNgayXuiiXUlnrl7vhKPuavgydUHgD1qvgv8zWkba2Qb5dhKgoXT/8b9325Hh8v24fX/9yJQ3nFyEg2aVq3uRQYwzAViYAt3YWFhejQoQOuu+46XHLJJR7z586di0mTJgnh3bt3b8yaNQtDhgzBpk2bUL++o/QDCfGSEkcMsJJffvkFy5cvR/PmzcWwePHiYPeLCRDJ6HgoGoIsGSZjKF1PPBIj3tYh49QZRxm4UNCiViaWPHhumddzVY8GYmh4/w8RSaQWDmLdvdxXXWule7Yydj3gUIYQHZZXLu+Ex7/diJvObux9U4p9YPdyhgnMwr1mX57H9LsGtkDHnMrYlVvISdIYhqmwBCy6SUDT4I2XXnoJN9xwA2688UYxPm3aNMyfPx8zZ850Wq9Xrlzp9ftLlizBp59+is8//xwFBQWwWCyoVKkSHn30Uc3lSbwrBXx+vu/4IcYb6kRqvq2cechAFgo8Z6RXi9tDXME0N04WmhELxHq95IwU1204XIZuKquVW2DWLBcXStT1tJUCNsmHW76/31aoOiOotNg7Y32XQVMK7RBHEjBMXPPtmoOa07cfOS2ST7Jlm2GYikxIXynMZrMQ1AMHDnSbTuN6rdYkzPft24fdu3eLrOU33XSTV8EtL5+VleUccnLCm822oiRSc1q8vS3vxfRkb3o+4pV4KRmml5NFobN0h4vzWtVErFNfUWM6/0x4EhF+enNPjOpSD+9d1x3hxJc49mXp9vfbKk/7v6+64wzDeHK62ILJn63BPzuPax6eDjmV+bAxDFPhCanozs3Nhc1mQ82a7i/CNH748OGwHOwHHngAeXl5zoEEOxM4UqmJSiq1cMv/vS7v5TU4IbVK3B7+iiW5Y4NwJmgrL9KSXJbuPScKw7KNpjUy8PyoDl5rhYfLvVwpYJX7qcZfzr7yFL/KbSWoTfcMw7ixau9JXPDq3/hq1QHxe69ZKdltfqecLIzu5ggtZBiGqciEJXu5uqYqWTG06qz6Y+zYsX6XSU5OFsP06dPFQKKfCT6RmqFUbMv/A8WY4CoDFHdUENX98U09cN+X6/DkxWVLehaLmcQjTbEldMnrIoH6Nk9lwR4c2lKUFctKTQze0l2OfSvKbbHmZhhtrDY7pv+5E6/+sV0kQqSyk69c3hFdG2Y7s5eThZsFN8MwTBhEd7Vq1WAymTys2kePHvWwfoeaCRMmiIFiusnNnAkQY2DZy729Iickepaeiheu690Qj3yzEf1aVEc806tJNSy6dwBigcQYz/YdDygzj2t1rt58dpOA1hEq0f3e9d0xee4aPHdp+6At3ZxIjWE82XeiCHfOXYMVe06K8eEd6+B/F7dFpRRHxxoJbRbbDMMwYRTdSUlJIjP5r7/+ihEjRjin0/jw4cNDuSkmTDHdzlhuv5ZuQ4WzdF99VgORCKZZzYxIN4UpJSEO3MtjnVCUc/dXKi0YT6lzmlfHiofPC/i7bqKbY7qZCs7qvSfdso7PW30Aj8zbgNMlVmQmJwixfXGnupFuJsMwTPyJbsoovmPHDuf4rl27sGbNGmRnZ4uSYJMnT8Y111yDrl27omfPnnjzzTexd+9ejBs3DuGE3cvLiCqRmjOLeYAx3TDGr+iml/e2ddmLIpqIN/fyisarV3TCE99uxKxrumjOH9+vCT5dvg+39W8a1PqDEetuidTYk4KpwDzz02a8seA/53izGhnYftRRtaRLgyqYNrqjqAjAMAzDhEF0r1ixAv3793eOk8gmxowZgzlz5mD06NE4fvw4pkyZgkOHDqFt27b48ccf0aBBA4QTdi8PTUy3HFtp8BNj6XWuKX5FNxN9xIt7Oe1GKCzGkYB0bbCJ/S/qUAfD2tf2Ko7vHdwSdw9sETHxy5ZupiJbuJWCmyDBTT/Fiec2x4T+TbjTk2EYJpyiu1+/fn6T3owfP14M5QlbusuGofSl1pVILciEdMaw5OZjmLi2dFNm74KS8JQLi3b8WaPLW3ArOz/Y0s1UVMH9+QrtSjDkdTLxvGbl3iaGYZhYJ24UElu6y4jBvWSY/0RqXl6EOQYyJqiTlYKDecVoU6cSYpl4ielOSTSioAQxCZ2BGDXSayIp9oZvZ0xFY8zspViwLdfr/P4ta5RrexiGYeKFuBHdTKgSqektGRYfYqei8snNZ+G9xXtwY99GiGUS46SmU0piaU4FJuIoHbn4LsdUJM5/6S9sP1rodf6t5zQWydQYhmGYwGHRzQgMpZZup4Xbn+gWgZx88GKVBlXT8eiw1oh14sXSffPZjfHoNxsxIAatSIayBHVHIdUzk8XtjTp0yO2fYSqCO/mny/Z6FdxXds/BqK45LLgZhmHKQNy8UXBMdxlRiW5/lu705ASguKwbZZjgqFUpBYfzizGwda24OIRX92iAjjmV0bxmJmKN+Oj2cJFoMmLTE4OF8OY63UxFy1CuBQtuhmGYshM3optjukMb0+1PdCtr2TJMefP7Xefg2OkSNKyWHhcHnxJ2ta9XGbFIPN4KUpPY3Z+Jf+v2X1uP+hXc/ZpXYws3wzBMCIgb0c2ERnTLWcsNsFW8N20mZiBPC+FtwUQcQ9ylUmOY+EaPdZtoXiMdc67vUS5tYhiGiXfi5q2V3cvLhkFOSCXHZvqN0WTRzTAMwzCxXn9bzcDWNXBuq5oY3a1+ubWLYRgm3okb0c3u5WVDCjCmmy3dDMM47gV8HBgmFsT2rtxCbD2c73M5ylB+35BW5dYuhmGYikLciG6mjHDJMIZhgrl18FFjmJh3J594blP0a1GD47cZhmHCBItuRrtkGNjSzTCMfzi9A8NEL3OX7/UruMm6fef5LcqtTQzDMBURFt2MAzmmuzQhktGPe/nR5leg/qrn+OgxTAUnOy0JB/O4fiDDxJKFmyzbDaqmo1G1dLZuMwzDlANxI7o5kVrZMJSaq+Ts5b4s3XsHvI4zhrQybpFhmHjgzWu74t4v1uHewWwpY5hoYdWeEz4t3OxKzjAMU77EjejmRGqhjen2Zem2p1aFoaTEY/qhTneidlnbwTBMTNG2bhZ+nNg30s1gmAqNnCiNLNcNq6bjsW83+XQn71S/Srm2j2EYpqITN6KbCW1Mt8GHpdtuMMFgkt3RXRQ2GMCngWEYpgKye/du/O9//8Mff/yBw4cPo06dOrj66qvx0EMPISkpKdLNq1Bu5GlJJhSZZa81d569pB2XAmMYhokALLoZB07RLfktGWaHEYZSy7gSo9FzGsMwDBP/bNmyBXa7HbNmzULTpk2xYcMG3HTTTSgsLMQLL7wQ6eZVqLrbJLjrVk5Fz8bZ+GLVATcLN9feZhiGiQwsuhmBoTSRmiy2fYpugwkmo2ehIIPGNIZhGCb+GTx4sBhkGjdujK1bt2LmzJksusMIuZRrcfuApri8e31cdVYDp9s5u5QzDMNEjrgR3ZxIrYw4rdSlMd1+3MsTNSzdBrClm2EYhnGQl5eH7Oxsn4ejpKREDDL5+fl8+HQiSRK2Hj6tOa9FrUzxn4Q2i22GYZjI4xmYG8OJ1DZt2oTly5dHuikxHdPttHT7EN052RmKEmOKdbClm2EYhgGwc+dOvPbaaxg3bpzP4zF16lRkZWU5h5ycHD5+OjheUIKb3l+BWQs9M5RzojSGYZjoI24s3UwZ8XAvd8R2a5GekgSjluiW48IZhmGYuODxxx/H/9u7E/AoqnTh42/2QAhhCXtCWAUh7KCyOBBQREHhCggoiyJecUDhMoMsOrIog4Mj6qBsOh/qgAJ3WOUqhBFlGVCGJeyCIBA2RQTCaiBJfc97oGM66XQS0k2S6v/veYp0VVc31aerq+qtc857JkyY4HYdvdndvHnz9PmTJ0+apuY9e/aUQYMGuX3tmDFjZMSIEU413QTe7jOUJ125LtPXHpKfLyZLcIC/jHqwrjSOjpCjv1yhGTkAFFIE3cgUMDtqul1nPjUsS/xcJU1zEYgDAIquoUOHSu/evd2uU61aNaeAOy4uTlq2bCmzZ8/O8f1DQkLMhLxlKFe1y5eQv/VpIndWKmnmm8W4b8oPACg4BN24Ib15uZVjTbdYqeInWZOmuar9BgAUXZGRkWbKjRMnTpiAu1mzZjJnzhzOCV7MUK5e7VY/PeAGABRuBN1wCpj9cpFIzYzl7TLAJns5APgireFu166dVK1a1WQr//nnn9Ofq1ixYoFuW1EOtn/4+ZJ8tuOky+dPnv/1tm8TAODWEHTjBv+bu4Kjpttd0J2WJsI43QCAm+Lj4+XgwYNmioqKypJlG/lvTp6ZDgMGACgaaA8Mw8/vRi21v3WjL7e/m3G6pXSM65puEqkBgE968sknTXDtaoJnmpNnRIZyAChabFPTzTjd+eNIjPZb8/JsLpQGbxApUV78JOsFAUOGAQCQ94zkWmut42n/ej1V3ow/4HLdYR1qSUzZMDKUA0ARFGincbp10uFGdKxP3GL28vTm5TdqvBOCmkjj69tvruQvUrHBb48z8aemGwCAW2pC3rNZlOw8niT7f7rocv12dcqbwBwAUPTQvByGX5ZEao7gO0ONd8Ym5y6GDHM5jBgAAMixCfn/bj1uAu7IEiHyUAPn5HM0JweAos02Nd3wUNCdccgwP5GyxQNEkiRXw4PRvBwAgJxpk3JX6lUqKR8/fZcJvDM3PQcAFF0E3TD8bmYjzzxkWGRYkMug29XwYOlN1AEAQJ4zj7/Wrb4JuJUG2gTbAGAPREm4uScEOGUtdwTdfjezmRtBYTkE3TQvBwDAnavXUmXxthNZlmsT8qYxZSg8ALAharrh1Fw8c023U5/uJ1e4bUpO83IAALK352SSDJufIAdPXzLzXRtVlta1ykrtCuHUagOAjRF0w6lpuAbZl5JTfgu2MyZPq9I0y7jeGZG9HACArNLSLPl//z4sU1bul2upaVI+PETefKyR3Fu7HMUFAD6gUAbdgYGBEhsbax43b95cPvjgg4LeJJ9JpJaSmiotXvuXbPR3NC/PEHRnUKFkaLbvAQAAbvjpwq/yh4U7ZMPBM2b+/noV5C/dG0qZsGCKCAB8RKEMukuVKiUJCQkFvRk+xf9mn24Nsq9eTxX/kBvB9tWW/yNBSweINH86x6RpDBkGAMBvVu35UUYv2innrlyX0CB/eaVLfelzV7TL1mIAAPsqlEE3bj9HEO0Yn9vxV8rVFXn5tEhgSM7v4aKfNwAAvubKtRR5dcU++XRzopmPrVJS3u7VRGqVL1HQmwYAKAB5bg+8bt06efjhh6Vy5crmTu3SpUuzrDN9+nSpXr26hIaGSrNmzWT9+vV5+j8uXLhgXtemTRtZu3ZtXjcRt8A/wDFkmCWt/XdJuN/VG/O63FXA7eIuPdnLAQC+bveJJOkybYMJuPVU+WzbGrL4udYE3ADgw/Jc03358mVp1KiRPPXUU9K9e/cszy9YsECGDx9uAu/WrVvLrFmz5MEHH5S9e/dK1apVzToaUCcnJ2d5bXx8vAnmjxw5Yv7u3r1bOnfuLLt27ZKSJUve6mdELvvRq/J+52Re8OT05f7+ud9F/KnpBgD4cLK02et/kDfj98v1VEsqlgyVqY81kla1Igt60wAARS3o1gBap+xMnTpVnn76aRk0aJCZf/vtt2XVqlUyY8YMmTz5RjC3detWt/+HBtxKk6nVq1dPDhw4YBKquaLBe8YAXmvJkXdBgTdqusv43RjGxCEg2+Rormq6SaQGAPA9p5KummRpGw/9YuY71a8okx9tIKVJlgYAuJXm5e5cu3bNBNQdO3Z0Wq7zGzduzNV7nDt3Lj2IPn78uKkhr1GjRrbrayAfERGRPkVHR+fzU/imoJs13ZmZ5uUun3A1TjdBNwDAt3yx65R0enu9CbiLBwfIlO4NZUbfpgTcAADvJFI7c+aMpKamSoUKFZyW6/yPP/6Yq/fYt2+fPPvss+Lv72/6jL/zzjtSpkyZbNcfM2aMjBgxwqmmm8Dbc0F3cDbLXdV0OzKgAwBgd5eTU2TiZ3tlwZZjZr5hVIS807uJVI8MK+hNAwD4QvbyzENhWJaV6+ExWrVqZfpw51ZISIiZ3nvvPTNp0I+8C7zZvDwzv+z6dLtYzhAoAABfsOPYeRm+IEEOn7lsGn4917am/M/9d0hQAC2+AABeDrojIyMlICAgS6326dOns9R+e9qQIUPMpDXd2swcnqnpluz6aZesLNKgp1w9vlOKndtvFlHTDQCws9Q0S2auPSRvrT4gKWmWVI4Ilam9Gss9NcoW9KYBAAoxj96SDQ4ONpnJV69e7bRc57UGG4VXtgnTsgu69dZ+9w8ksfXr6Yu0SwAAAHZ08vxVefz9b+SNVftNwN25YSX5YtjvCLgBAJ6v6b506ZIcPHgwff7w4cOSkJBg+l3rkGDav7pfv34m23jLli1l9uzZkpiYKIMHDxZvonl5PmXXHzsPGcnJXg4AsKMVO0/K2MW75MKvKRIWHCATusZK96ZV6FYFAPBO0L1lyxaJi4tLn3ckMRswYIB8+OGH0qtXL/nll19k4sSJcurUKTPs1+effy4xMTHiTTQvz6eA4FsKup0yluey3z4AAEXBpeQUGbdsjyzadtzMN44uJW/3aizVSJYGAPBm0N2uXTuTGM2d3//+92a6najpzqfAUNfL85KRnKAbAGAT2xPPybD5CZJ49or4+4kMjaslz3eoTbI0AEDhyF5eEKjpzqeg4q6XZ5e9/KYSIbbZhQAAMMnSpn91UN7+8nvzuEqpYvJ278bSolr2w5cCAOAOERNuCMqmpjsgyG0JVS4XSQkCAGzh2NkrMmJhgvznyDkz/0ijyvJqt1iJKOb+XAgAgE8E3TQv91JNd07K1xVpOVQkvGJ+twAAgAKzLOGEvLxkt1xMTjGtuF7tVl/+q0kU3wgAIN9sE3TTvDyfXNVo91uau9c+MCm//zsAAF7pl334zGWpHhkmTaqWdrnOhV+vm2RpS7afMPPNYkqbZGnRZW7xZjQAAHYNuuFZJ5qNlCo1f8tSDwBAUfL6F/tk5tof0ucHt60hox+802mdrUfPmmRpx89dNcnSXuhQ2yRMCwzI/XCZAADkhKAbrneMEO7wAwCKbg13xoBb6fwD9SuaGu+U1DSZtuagTFvzvaRZItFlipna7WYxJEsDAHiebYJu+nR7ln9ohIffEQCA20OblGe3vGxYiAxfsF22JZ43yx5tUkUmdK0v4aEkSwMAeIdtgm76dHuWFVLSw+8IAMDtoX24XTn6y2V5ZdkeuZScIuGhgfJat1jp2rgKXwsAwKvotASXIsuWo2QAAEWSNiHXPtwZ1SofJu98edAE3C2qlZYvht1LwA0AuC0IuvGbx//3tx2jWDglAwAosjRp2pLft5KhcTWlXIlgOXj6sgT4+8kfO94h8/+7pUSVJncJAOD2IOjGb6re89vjwGKUDAAg1x555BGpWrWqhIaGSqVKlaRfv35y8uTJAivB66lpsua70zL960Py86VrElO2uPxzcEsZ2r62Cb4BALhd/O2USK1evXrSokWLgt6UoisoQ6BNIjUAQB7ExcXJwoULZf/+/bJo0SI5dOiQ9OjRo8DKcPLn35kM5ZqdvEezKPm/F+7NdqxuAAC8yc+yLEts5MKFCxIRESFJSUlSsiTJwPLs29ki16+ItBnuja8HAOAj563ly5dLt27dJDk5WYKCgm57WfyY9Kv0mr1JRj5QR7o0rJyv9wIAID/nLdtkL4eH3P3fFCUAIF/Onj0r8+bNk1atWrkNuDUg1ynjxYunVIwIlS9HtJXAANs06gMAFFGciQAAgEeMGjVKwsLCpGzZspKYmCjLli1zu/7kyZNNDYFjio6O9ug3QcANACgMCLoBAIBL48ePFz8/P7fTli1b0tcfOXKkbN++XeLj4yUgIED69+8v7nqxjRkzxjTJc0zHjh3jmwAA2I5t+nRrIjWdUlNT5cCBA7brGwcAsKfC3Kf7zJkzZnKnWrVqJmN5ZsePHzc11xs3bpSWLVsW+bIAAEB8vU/3kCFDzOT44AAAIH8iIyPNdCsc9/Qz9tkGAMAX2SboBgAABWPz5s1matOmjZQuXVp++OEHeeWVV6RmzZq5ruUGAMCu6NMNAADypVixYrJ48WLp0KGD1KlTRwYOHCixsbGydu1aCQkJoXQBAD6Nmm4AAJAvDRo0kDVr1lCKAAC4QE03AAAAAABeQtANAAAAAICXEHQDAAAAAOAltgm6dYzuevXqSYsWLQp6UwAAAAAAMPwsx0CaNqEDk5cqVUqOHTvmdoByAAAKgwsXLkh0dLScP39eIiIixJdxDgcA2PEcbrvs5RcvXjR/9cMDAFCUzl++HnRzDgcA2PEcbrua7rS0NDl58qSEh4eLn5+fx+5eUHNOud0O7G+U3e3GPlfw5aanYT1ZV65cWfz9bdPrq0DO4b62P/N57Y3v1974fu0ht+dw29V064eNiory+PvqydsXTuCeRrlRbuxzRQO/1YItN1+v4fb0OdzX9mc+r73x/dob32/Rl5tzuG/fUgcAAAAAwIsIugEAAAAA8BKC7hyEhITIuHHjzF/kHuV2ayi3W0fZUW63E/tb4eRr3wuf1974fu2N79e32C6RGgAAAAAAhQU13QAAAAAAeAlBNwAAAAAAXkLQDQAAAACAlxB0uzF9+nSpXr26hIaGSrNmzWT9+vXiyyZPniwtWrSQ8PBwKV++vHTr1k3279/vtI6mCBg/frwZIL5YsWLSrl072bNnj9M6ycnJ8vzzz0tkZKSEhYXJI488IsePHxdfKkc/Pz8ZPnx4+jLKzbUTJ05I3759pWzZslK8eHFp3LixbN26lXJzIyUlRV5++WVz7NLfYI0aNWTixImSlpZGuWWybt06efjhh83xSn+TS5cudXreU7/Lc+fOSb9+/cw4njrp4/Pnz+fiaIH80O+iatWq5hxeqVIlU+4nT560ZaEeOXJEnn766fTffc2aNU1CuWvXroldTZo0SVq1amXODaVKlRI78pXr0JyOxb54PW0nM2bMkIYNG6aPR96yZUv54osvxNcQdGdjwYIFJih66aWXZPv27XLvvffKgw8+KImJieKr1q5dK0OGDJFvvvlGVq9ebS7uO3bsKJcvX05fZ8qUKTJ16lR599135T//+Y9UrFhR7r//frl48WL6OlquS5Yskfnz58uGDRvk0qVL0qVLF0lNTRW70zKZPXu2OfhkRLllpYFK69atJSgoyByc9+7dK2+++abTxRXlltVf/vIXmTlzpvkN7tu3z5TRG2+8IdOmTaPcMtFjV6NGjUxZueKp/evxxx+XhIQEWblypZn0sQaA8K64uDhZuHChuZhdtGiRHDp0SHr06GHLYv/uu+/MjbVZs2aZG0NvvfWWOQ6MHTtW7EpvKPTs2VOee+45sSNfug7N6Vjsi9fTdhIVFSWvv/66bNmyxUzt27eXrl27ZrmJbXuavRxZ3XXXXdbgwYOdltWtW9caPXo0xXXT6dOnNfO9tXbtWjOflpZmVaxY0Xr99dfTy+jXX3+1IiIirJkzZ5r58+fPW0FBQdb8+fPT1zlx4oTl7+9vrVy50tZle/HiRat27drW6tWrrbZt21rDhg0zyyk310aNGmW1adMm2/Kk3Fzr3LmzNXDgQKdljz76qNW3b1/KzQ09li1ZssTj+9fevXvNe3/zzTfp62zatMks++6779xtEjxs2bJllp+fn3Xt2jWfKNspU6ZY1atXt+xuzpw55ndpN756HZr5WOyL19O+oHTp0tYHH3xg+RJqurO5e6pNWPWuU0Y6v3Hjxtt1P6TQS0pKMn/LlClj/h4+fFh+/PFHp3LTMQjbtm2bXm5artevX3daR5sTxcbG2r5s9a5m586d5b777nNaTrm5tnz5cmnevLmpydDmV02aNJH333+fcstBmzZt5Msvv5QDBw6Y+R07dpga2Iceeoj9LQ889bvctGmTaVJ+9913p69zzz33mGV2P+YVJmfPnpV58+aZ5sjaesZXztGO8zOKFq5Dfft62s5SU1NNyzCt1ddm5r6EoNuFM2fOmJ2iQoUKTst1Xi/CcKOv44gRI8wFvl5gKkfZuCs3/RscHCylS5f2qbLVA8y2bdtMP57MKDfXfvjhB9MPqHbt2rJq1SoZPHiwvPDCC/Lxxx9Tbm6MGjVK+vTpI3Xr1jXBhd6s0CaKuoz9Lfc89bvUv3rTKDNdZudjXmH6PWhfe80Loc1yly1bJr5Am9JrlxI9bqLo4TrUt6+n7WjXrl1SokQJc/Naj0vaLatevXriSwi63dBkDpl/GJmX+aqhQ4fKzp075dNPP/VIudm5bI8dOybDhg2TuXPnmmQo2aHcnGn/xKZNm8qf//xnEzg+++yz8swzz5hAnHJz3w9Q97VPPvnE3Oj56KOP5K9//av5S7nlnSd+l67Wt/Mxz5s0sZ2Wm7tJ+ww6jBw50vSHjY+Pl4CAAOnfv78pe7t+XqXJ4jp16mRaCQ0aNEiKklv5vHbGdahvX0/bSZ06dUw+E+3HrnkYBgwYYHL1+JLAgt6Awkiz0OrJOXMtxOnTp7PUevgizdSrTX8126QmR3DQJENKy00zxboqN11Hm01pkqyMtUO6jjb7syNtgqqfTzOPOmhLCi0/TRriyFhJuTnTfSjzXdA777zTJERS7G+uaZAxevRo6d27t5lv0KCBHD161LSy0JMc5ZY7nionXeenn37K8v4///wz55NbvEB17NvZqVatmtP5XKc77rjDHD+io6PNRV9RadaY18+rAbcmkNPPp0k7i5q8fl674jrUt6+n7Sg4OFhq1aplHmvXQU1O+s4775jkj76Cmu5sdgwNkDSjYEY6b9fAMDe0dkBPiIsXL5Y1a9aYYSwy0nm9wMxYbnpBqlkaHeWm5apNXjOuc+rUKdm9e7dty7ZDhw6mWY3e4XNMesB54oknzGMd0olyy0ozl2ceQkP7KcfExJjH7G+uXblyRfz9nQ/tehPRMWQY5ZY7nionDX60v97mzZvT1/n222/NMrse87wdjGjXCXdTdi2KHDXcOsybHT+vDrGow9ppC6E5c+ZkOQ7Y/fu1E65Dfft62lfKILkIHYs9oqAzuRVWmo1Ws9L+/e9/N9lnhw8fboWFhVlHjhyxfNVzzz1nMoR+/fXX1qlTp9KnK1eupK+jmX51ncWLF1u7du2y+vTpY1WqVMm6cOFC+jqajTMqKsr617/+ZW3bts1q37691ahRIyslJcXyFRmzlyvKLavNmzdbgYGB1qRJk6zvv//emjdvnlW8eHFr7ty5lJsbAwYMsKpUqWKtWLHCOnz4sPktRkZGWi+++CLl5mJEge3bt5tJT4dTp041j48ePerR32WnTp2shg0bmqzlOjVo0MDq0qXLLR49kBvffvutNW3aNPN96nl7zZo1ZjSEmjVrmiz0dqNZ82vVqmX2v+PHjzudo+1Kf6f6/U6YMMEqUaJE+m9Zf9d24EvXoTkdi33xetpOxowZY61bt85ck+zcudMaO3asGeUjPj7e8iUE3W689957VkxMjBUcHGw1bdrUp1L5u6IHQleTDteRcZidcePGmaF2QkJCrN/97nfmYjWjq1evWkOHDrXKlCljFStWzFx8JiYmWr4kc9BNubn22WefWbGxsWZf0qFSZs+e7fQ85ZaVBoS6b1WtWtUKDQ21atSoYb300ktWcnIy5ZbJV1995fKYpjcuPLl//fLLL9YTTzxhhYeHm0kfnzt3Lg9HDOSVXtjFxcWZ70W/u2rVqpkbJBqQ2pGeh7M7R9uV/k5dfV79XduFr1yH5nQs9sXraTvRYUxjbu7H5cqVszp06OBzAbfy038KurYdAAAAAAA7KnodfgAAAAAAKCIIugEAAAAA8BKCbgAAAAAAvISgGwAAAAAALyHoBgAAAADASwi6AQAAAADwEoJuAAAAAAC8hKAbAAAAAAAvIegGAAAAfMS1a9ekVq1a8u9//1sKqxYtWsjixYsLejMAjyHoBgAAALxs/Pjx0rhx4wIv59mzZ0tMTIy0bt1aCqs//elPMnr0aElLSyvoTQE8gqAbAAAAKCSuX7/u1fefNm2aDBo0SG5Hjfqt6ty5syQlJcmqVas8uk1AQSHoBgAAAHLw8ccfS9myZSU5Odlpeffu3aV///5uX/vhhx/KhAkTZMeOHeLn52cmXab08cyZM6Vr164SFhYmr732mnmuVKlSTu+xdOlSs25Gn332mTRr1kxCQ0OlRo0a5v9ISUnJdju2bdsmBw8eNEGtw5EjR8z7anPuuLg4KV68uDRq1Eg2bdrk9NpFixZJ/fr1JSQkRKpVqyZvvvmm0/O6TLf9ySeflIiICHnmmWfSP8eKFSukTp065r179Oghly9flo8++si8pnTp0vL8889Lampq+nsFBATIQw89JJ9++qnbcgWKCoJuAAAAIAc9e/Y0geHy5cvTl505c8YElE899ZTb1/bq1Uv+8Ic/mKD11KlTZtJlDuPGjTNB965du2TgwIG5+i60Frhv377ywgsvyN69e2XWrFkmyJ00aVK2r1m3bp3ccccdUrJkySzPvfTSS/LHP/5REhISzDp9+vRJD+C3bt0qjz32mPTu3dtsozaV1ybgjhsHDm+88YbExsaa9fV5deXKFfnb3/4m8+fPl5UrV8rXX38tjz76qHz++edm+sc//mGavP/zn/90eq+77rpL1q9fn6uyAAq7wILeAAAAAKCwK1asmDz++OMyZ84cE4CrefPmSVRUlLRr1y7H15YoUUICAwOlYsWKWZ7X981tsO2gwbX2ex4wYICZ15ruV199VV588UUTxLuitdqVK1d2+ZwG3I4acK0x1xsEWitet25dmTp1qnTo0CE9kNagXAN9DbK1Ztuhffv25n0cNmzYYJrLz5gxQ2rWrGmWaU23Bto//fSTKZN69eqZGvavvvrK6UZElSpVJDEx0fTr9vennhBFG3swAAAAkAvaZDo+Pl5OnDhh5jUA16Azc7PvvGrevHmeX6O1yRMnTjSBq2PS7dNadK1dduXq1aumKborDRs2TH9cqVIl8/f06dPm7759+7IkXtP577//3qlZuKvPoU3KHQG3qlChgmlWrtubcZnj/8p4o0ID7szN+YGiiJpuAAAAIBeaNGli+jtr/+4HHnjANLXWftX5pX25M9KaXcuy3CZY04BUa6S1qXZm2QXWkZGRZptdCQoKSn/suIngyB6u25L5xkLm7XP1OTK/r+O9XS3LnKn87NmzJmDX4Bso6gi6AQAAgFzSzN9vvfWWqe2+7777JDo6OlevCw4OdqoVdqdcuXJy8eJFk3DMEchqX+uMmjZtKvv37zdjbuflpoE29XYVRLujTcC1qXhGGzduNM3MNemZN+zevdt8RsAOaF4OAAAA5NITTzxhAu73338/T/2wtUn14cOHTfCsCdjcNZu+++67TS3v2LFjTb/qTz75JEvSsldeecXUuGtSsz179pgm4AsWLJCXX3452/fVvtMayOv6eaFJ4L788kvTZ/zAgQMm8/i7777r1H/b0zSJWseOHb32/sDtRNANAAAA5JJm/tZhwrRPcrdu3XJdbvqaTp06mcBXa7LdDYdVpkwZmTt3rsnu3aBBA7OuBtcZafN2zZy+evVqadGihdxzzz0m4VlMTEy276tDnmlzdE0Alxda47xw4UKTgVyzk2vAr/3JMyZR8yS9qaE16TllhQeKCj/LVYcMAAAAAC7df//9cuedd5qhsIoa7dOtzeK1Bj08PFwKo5EjR0pSUpIZSgywA2q6AQAAgFzQ5F5a27tmzRoZMmRIkSwzrTmfMmWKGT6ssCpfvrxpyg7YBTXdAAAAQC77ZZ87d86MV525P7OOa3306FGXr5s1a5bpCw7ANxF0AwAAAPmkAXfmYb0yjkNdWJtyA/A+gm4AAAAAALyEPt0AAAAAAHgJQTcAAAAAAF5C0A0AAAAAgJcQdAMAAAAA4CUE3QAAAAAAeAlBNwAAAAAAXkLQDQAAAACAlxB0AwAAAAAg3vH/ARJFKz2uPRlFAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 3.781e-06 @ epoch 155\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35837e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "iter=1  t=0.31s  best_y=1.35833e+06  x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "STOP: local minimum. best_y=1.35833e+06 x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 161 rows, 8712 columns and 17510 nonzeros\n",
      "Model fingerprint: 0xa451b6af\n",
      "Variable types: 8704 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [7e-02, 2e+00]\n",
      "  Objective range  [2e+01, 2e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [2e-02, 1e+02]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 0 rows and 427 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 8285 columns, 16656 nonzeros\n",
      "Variable types: 8277 continuous, 8 integer (0 binary)\n",
      "Found heuristic solution: objective 1352717.7570\n",
      "\n",
      "Root relaxation: objective 1.348549e+06, 423 iterations, 0.01 seconds (0.02 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 1348548.84    0    3 1352717.76 1348548.84  0.31%     -    0s\n",
      "H    0     0                    1348552.5929 1348548.84  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (423 simplex iterations) in 0.03 seconds (0.06 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.34855e+06 1.35272e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.348552592927e+06, best bound 1.348548835986e+06, gap 0.0003%\n",
      "[CHECK DFN] obj(x_ip)=1.34855e+06  ip_y=1.34855e+06  rel_err=5.324e-07\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2000, 8)  mean(mean)=25  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(2000,)  mean=2.02e+06  std=4.17e+05  min=6.96e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=8\n",
      "  model: params=14,408 layers=[5, 400, 4] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzsnQW4G2XWx8/Ert/arbsLVdpSWlpK8SKLU6w4H+6yCyy6i0ORpbizCxQtTnEoFKkCpUILddfrNzbzPeedTPLOZDSe3PN7nrQ3yWTmzWQymf97zvkfQZIkCQiCIAiCIAiCIAiCSDmu1K+SIAiCIAiCIAiCIAgS3QRBEARBEARBEASRRijSTRAEQRAEQRAEQRBpgkQ3QRAEQRAEQRAEQaQJEt0EQRAEQRAEQRAEkSZIdBMEQRAEQRAEQRBEmiDRTRAEQRAEQRAEQRBpgkQ3QRAEQRAEQRAEQaQJEt0EQRAEQRAEQRAEkSZIdDvghRdeAEEQDG9ff/01ZJPVq1ezcdx///0Jr+Of//wnHHHEEdC5c2e2rjPPPNNw2b/++guOPfZYaNmyJZSXl8NBBx0ECxYs0F32tddeg+HDh0NxcTF06tQJrrjiCqirq4tbDh/D53AZXBZfg6814r333gOPxwPbtm1j9x966CE2pp49e7Lx77fffoav3bp1K3t/VVVVUFpaCmPHjoUvvvhCd9nPP/+cPY/L4fL4Ony9lmAwCLfddhv06NEDioqKYMCAAfCf//wH7IKvu/XWWyFbxzYeQ3aWMzreJUmCPn366O77HTt2wPXXXw+DBg2CsrIyaNGiBds/U6dOhV9//TVr37MtW7ZAmzZt2LrffPNNx69fsmQJ+6zx9fPmzUv4OPvggw/g9NNPhyFDhoDX62XrSyd2jul169bBMcccA7169Yp+ZiNGjIBHH30UQqGQ7W3dfvvt7HMXRRHykZtuugn23HPPvB0/QeQ7eB4qKSmB3bt3Gy5z6qmnsnMnntPtgufZbPzmWnHnnXfCzJkzdX9vcLxWv9Xp4KWXXoK2bdtCbW1txra5fv16dk04ceJEdq2JnxdeI2ipqamBO+64g113dOjQgV2T4m/pPffcA01NTXHLr1y5kl17dOvWjR1XvXv3hquuuopdp/DgMkcffXRa3yPRfCDRnQDPP/88/PDDD3E3vCjLdx588EF20vnb3/4GPp/PcDkUuRMmTIA//vgDnnvuOXj99dfZiQ1PeMuXL1ct+7///Q9OPvlkGD16NHz88cdwyy23sJMmimMt+NiLL77IlsFl8TX42ldeeUV3HG+99Rbsu+++7IcAeeKJJ2DNmjWw//77Rx/Tw+/3wwEHHMDEz8MPPwzvvvsutG/fHg499FD45ptvVMvi/cmTJ7PncTlcHgULvh7Xw3PRRRfBXXfdBRdffDHMmjWLXShcfvnl7Ae0kKioqIBnn3027nHcV3/++Sd7XjuZsvfee7PP/dxzz2WTJXhc/N///R+sWrUKFi1alLXvGX5WOMGTCOFwGM4++2wmWpM9zt555x348ccfmTgdNmwYpBO7x3R9fT1UVlYy0YmfGU6AjR8/Hi699FK44IILbG1r48aNcO+99zLh7XLl50/ONddcw45TPDcRBJF5zjnnHHaNYXQtUF1dzc6hGDTA81q+Yya6cWI/06K7oaEBbrjhBvj73/8e9/ueTlAc47UCXo8edthhhsutXbuWBV3w+uCpp55iv1fHH388m6DAYwIDAvz1K16PfP/99/Cvf/0LPvroI3Yd8PTTT8OBBx6omlzF13/44Yfw5Zdfpv29Es0AibDN888/j99aae7cuTm511atWsXGd9999yW8jnA4HP27rKxMOuOMM3SXu/baayWv1yutXr06+lh1dbVUVVUlnXjiidHHQqGQ1LFjR+nggw9Wvf5///sfG+tHH30UfezDDz9kj73yyiuqZQ866CCpU6dObF08gUBAatmypfToo4/qjn+PPfaQJk6cqDv+6dOns23NmTMn+lgwGJQGDRok7bXXXqplR48ezR7H5xW+//579vrHHnss+tjixYslQRCkO++8U/X68847TyopKZF27NghWdG9e3fplltukbJ1bOMxZGe5c889l70n/Mx5TjvtNGns2LFx+/65555jr/vyyy9118t/bpn8nr355ptSeXm59OKLL7JtvvHGG45ej9+1zp07Sw8//LDumJ0cZ/w+uPjii9nr0oXdY9oI/I57PB6pqanJctnrrruO7SP+/WWK+vr6lK3rkksukfr16yeJopiydRIEYQ/8/cfrgJEjR+o+//jjj7Pz1/vvv+9ol+JrsvGba4XR9Rf+RuGYv/rqq4yeK/F3obi4WNq1a5eUSfjfDfx9xfeO1wha6urq2E3vNxpfM3v27OhjTz/9NHvs888/Vy2L1274+IIFC1SPH3HEEew6lCCSJT/DDnkApsBccskl8OSTT0K/fv1Y+ilGsPRSpRcvXgxHHXUUtGrVKppSrRdRwbSqq6++mqV64vratWvHZv6WLVsWt+y0adNYijWm2GAKKUbQ7GA3EoUzyhhN7t69e/QxjIhhpPr999+Ppp7idjdt2gRnnXWW6vUnnHACGxuuh18nPobP8eBrMVr2008/qR7H6CHObmM0OZHx9+/fn+0bBUxTP+200+Dnn3+GDRs2sMfw/7lz57IUI3xeYdy4cexz5cePs9L4G659r3i/sbERPvnkE0gFOJuLxxfOAGvBWWicEd6+fTu7/9lnn7Fjq0uXLuzYwtTv888/P/p8omD2AfLqq69GH8PPAjMPMPKrRUnZ6tixo+76shEB3blzJ5vdxpQ0TDFzyooVK+Dmm2+Gxx57jB37yRxnTvfB5s2b2eeInyt+3vhdx+iHnZRvJ8e0EZhFguN1u92mywUCAZYRccopp6jeH18KY+dchVELJRUeoyxYyoJZDzwYkcB1YokLRjjwfIopg0rZBkY7MIUf0+MxnXDgwIHsPoIZGHgfU+j32msv3TIB3F+Y2fPVV19Z7h+CIFILnmvOOOMMmD9/Pvz222+6mVH4+4IZPBjJxKwzvObC8wpeK+H1yuzZsxPe/uOPP84ykHB9eA7C0iiM/GrPrZi91bVrV3ZexjI5PBcp6e4YqcdrOLzGw1Kd1q1bs/MaZhvx4HkMs4zwOlApq8IsQjxPKddHkyZNij7Hp1srGUv4m4Tny3322SeunMnsXGn2/o888kiW4q13rfvyyy+zcyhuE/eTcm5NFru/i3juxpsWPJ8rpVIKWIKA4GfAo7w3beYbnvtxv2IWH0EkA4nuBFNK8eKWv+FjeheKjzzyCEurxFpRFKgoVvi6UUzFxovd33//nS379ttvsx8KrK/ElEwFrKHBtE4U8SjiUNhiKjVeJKOo5Zk+fToTWyjOMC0HT94ozlEUpQIUkHjyGTp0aNxz+Bg+j/XeyoSC8jgPnvTwR0t5XlkWT9q8EOBfyy+LoMDDHyz8YXMKrsto/Ah+HmbjVx7Tjh/FCNYT2Rl/oqBgwx90bV0THoP//e9/2Q+jku6MnxPuI/zB/PTTT5lIxMkLPJaw/jxR8Acdf6yxtEABBTj+QE6ZMiVueUV0Ys0yTk5o66YS/Z7pLaN306vFveyyy5jYwwsGp+DkCqbJo5DDUoxkjzMnoODGCwksX8DPE8swMPUSyxrOO+88y9c7Oab594v7cdeuXTBjxgx27OHFo/a7qgWPNfys8QJRDzvnKkwnxYkjPObwGEMRj+PAi9Dvvvsubp048YeTS2+88QY7Ryr88ssvzFMAJ6bwPIsXXLgslrI888wzLJ0Tx4Dbxs8Vz2M8I0eOZBfcmGpIEETmwQldFHn8746Sco2TmCjKUZzjhCqC3238vqIgx2AFnjMS8QTBYAmKeKwrxklJ/A278sor2fmKF9xYDofPY20wnpfxvIbnGTxfIVi6g2PDchVcB57P8LcYz0NYL62AE4o4MYjnQqWsCid3Dz/88GipGp47lefwcQR//w8++GB2rkTBjmV/KOwPOeQQXR8Ro3OlXl01TnQYncdxH6PPB17r4nUZbhODIcp1IP8bYueWSpS08D322CP6GNZo40Q7/obhbzCWv3377bdw9913s+snvA7lweMGx49p6ASRFEnHypsRStqr3s3tdquWxccw/Xbz5s2q9KgBAwZIffr0iT520kknSUVFRdLatWtVr588ebJUWloq7d69m92//fbb2To/++wzy/TyIUOGqFKxf/75Z/b4q6++mpL0pg0bNrD13XXXXXHPYWo4n057xx13sPubNm2KWxZTzjFdU6Fv377SIYccErfcxo0b2Tr4tG18f5jK/sADDxiO3yy9HFPjzz///LjHcdx8iruSBv/DDz/ELft///d/ks/ni97H9KP+/fvrbg+Xw+VTlV5+7LHHSl26dFGlXmGqvll6HabFYjrxmjVr2HLvvvtuwunlmOaF6W34N6bVKynLZ555puG+x2MY94PynenZs6d0wQUXSL/88kvC3zPchtGy/E17HH/wwQfsGPjtt9/YfeW92E0v/89//iO1atUq+v02Som3e5xpMUsvx/VhSjx+jjz3338/e83vv/9uOnYnx7QCfteVfYklFDfeeKNkh3vuuYe9hj8POjlX4fGNKaW4HH+s19bWSu3atZPGjRsXfQy/N/jam2++Wfd7hefj9evXRx9btGgRWx7LX/jUypkzZ7LH33vvvbj17LPPPtKYMWNsvXeCIFIPnvPxtx/LyxSuvvpq9p39448/dF+D5xj87TvggAOkY445xnF6OZaWYCmbGWeffTY73y9ZssT2e1HGdc45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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 1.654e-06 @ epoch 542\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35785e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "iter=1  t=0.31s  best_y=1.35778e+06  x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "STOP: local minimum. best_y=1.35778e+06 x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 410 rows, 7248 columns and 14504 nonzeros\n",
      "Model fingerprint: 0x163f7fba\n",
      "Variable types: 7240 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [7e-02, 1e+00]\n",
      "  Objective range  [1e+01, 2e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [3e-01, 1e+02]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 0 rows and 1477 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 410 rows, 5771 columns, 11549 nonzeros\n",
      "Variable types: 5763 continuous, 8 integer (0 binary)\n",
      "Found heuristic solution: objective 1352492.3458\n",
      "\n",
      "Root relaxation: objective 1.350599e+06, 385 iterations, 0.00 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 1350599.42    0    3 1352492.35 1350599.42  0.14%     -    0s\n",
      "H    0     0                    1351740.4176 1350599.42  0.08%     -    0s\n",
      "H    0     0                    1351735.7943 1350599.42  0.08%     -    0s\n",
      "     0     0 1350601.35    0    3 1351735.79 1350601.35  0.08%     -    0s\n",
      "H    0     0                    1350647.4364 1350601.35  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (385 simplex iterations) in 0.03 seconds (0.05 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 4: 1.35065e+06 1.35174e+06 1.35174e+06 1.35249e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.350647436407e+06, best bound 1.350601346487e+06, gap 0.0034%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=1.35065e+06  ip_y=1.35065e+06  rel_err=4.547e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2000, 8)  mean(mean)=25  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(2000,)  mean=2.02e+06  std=4.17e+05  min=6.96e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MaxAffine ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=8\n",
      "  model: params=14,400 n_pieces=1600\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAqxBJREFUeJzs3QdYU1cbB/A/e8kQEReguDcu3Nu6a92jdc86ah0d1q97apfV1l1Xta1aZ1urddU9ceDCLQoqDlBBUNnf854YDBsUSEj+v+e5Sm4uyclNyL3vPe95j1liYmIiiIiIiIiIiCjHmef8QxIRERERERERg24iIiIiIiKiXMSebiIiIiIiIqJcwqCbiIiIiIiIKJcw6CYiIiIiIiLKJQy6iYiIiIiIiHIJg24iIiIiIiKiXMKgm4iIiIiIiCiXMOgmIiIiIiIiyiUMul/QkiVLYGZmlu6yc+dO6NPVq1dVO7777rscebxt27YlvbbQ0NBk9505cwajR49GgwYN4ODgkOnrl98fN24cSpUqBRsbGxQpUgTt27fHvXv3Um0bHx8Pd3d3/PDDD+r23r17MWzYMNSuXVv9rjyXvNb0/PTTT6hYsaLa1tvbG59++iliY2NTbXfnzh0MGjQIbm5usLe3V69l+/bt6e4LuV+2k+3l9+T3s+KTTz5Rr1sfZF/J82dlO1nkdaXls88+S9pGd98nJiZixYoVaNKkiXrPbG1t4eHhgbZt22LBggVpPkdaS3rPmx3Lly9H06ZN1WdL3vvixYujU6dO2L9/f5Z+X17Ljz/+mPTZKVasGEaNGoX79++nuf21a9cwZMgQ9TyyfYkSJdC1a9dk2zRv3jzD133r1i3kpOx8prUeP36M8uXLZ/u74/Lly+p1HzhwAPnRhQsXYG1tjWPHjum7KUSkQ75H7ezs8ODBg3T3S9++fWFlZYXbt2/n+PEwr3311VdYv359qvUBAQGqvRmd7+SWpUuXonDhwnj48GGePef169cxfvx4NGvWDC4uLur9kvPulCIiIvDll1+q42vRokVRoEABVKtWDV9//TWePHmSavtLly6hf//+8PLyUp+rMmXKYOLEiQgLC0u2nWzTpUuXXH2NZDoYdOeQxYsXqxPNlEutWrVgLCIjIzF8+HAVUKTlyJEj6iDh6uqKVq1aZfhYN2/eRL169fDvv//iww8/xNatWzFnzhyULVsWMTExqbbfvXs37t69i27duqnbEjRI0CtfmA0bNszwueSLWIJ7+d3NmzerCwNyQBszZkyy7aKjo1W75bFnzJiBP//8UwVr7dq1w65du5JtK7flAoHcL9vJ9tIe+X15HGPh6OiIVatWpTrISjAqBz4nJ6dUvzN58mS8+uqrqFSpkgqyN23ahC+++CJpX6XUo0ePNP925HPxouQA2qhRI8yePRtbtmzBtGnT1AmZBOIp39O0vP3225gwYQI6d+6MDRs24L333sPvv/+O1q1bp7poc/r0aXURSP6XQFU+0/J8BQsWTLadtCXla5XPnJws1q9fX50w5JTsfKZ1yb6PiorK9vPJ/pJ9I4F9fiQXGuTEXd5zIjIcQ4cOVcGTfP+mJTw8HOvWrcPLL7+svuPyu4yCbuk0yOug+9GjR/jf//6HSZMmqfOCvCLB8W+//aYuhnbo0CHd7YKCgjB9+nR1zj1//nz89ddf6txCLlDIZ0LOWbTkXFKOtfv27cPnn3+OjRs3qvPBn3/+GS+99BISEhKStpXf/+eff/Dff//l+mslE5BIL2Tx4sXyl5zo5+dnkHsyMDBQte/bb7994ccaM2ZMYs2aNRM/+OAD9Zh3795Ndn98fHzSz6tWrVLb7NixI83H6ty5c2KJEiUS7927l6XnHj16dGKdOnXSfC55bfJc8lpTCg0NTbS1tU0cMWJEsvVffvllopmZWeKZM2eS1s2aNUs9zv79+5PWxcbGJlauXDmxbt26yX7f19dXrZf7tfbt26d+f/bs2Zm+no8//jixZMmSifogbZTnz8p2/fr1S7Szs0ucP39+svu2bdum7h8+fHiyff/o0aNEGxubxAEDBqT5mLrvm/Y55HOVlx48eJBoZWWV2L9//wy3u379eqKFhUXi2LFjk63//fffVbt190lCQkJijRo11PLkyZNst2nJkiXqMRcsWJCYk7LzmdY6dOhQorW1ddLfcFa/OwICAtT2//77b2Jei4uLe679npYjR46o1yF/z0RkGORvvHjx4om1a9dO8/45c+aov9u///47V46Hec3BwSFx4MCBqdZndm71vKKiojK8X85r5Fzq/v37iXlJ95xBzrPltct5d0qRkZFqSUl7frhnz56kdT///LNaJ+cxur766iu1/tixY8nWv/zyy4mtW7fOoVdEpow93XlI0mLeeOMNzJs3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Q36Qov+Jd+APAAAAAEAySrwBPwAAAAAAJAiCbgAAAAAAPELQDQAAAACARwi6AQAAAADwCEE3AAAAAAAeIegGAAAAAMAjBN0AAAAAAHiEoBsAAAAAAI8QdAMAAAA+ceXKFenSpYt89dVX0lj169dPNm/eHO/DAOoNQTcAAADgsVdffVX69OkT93J+7733JDs7W+677z5prF555RWZPXu2XLt2Ld6HAtQLgm4AAACgkbh69aqn+y8sLJTJkydLQ7So/1fDhw+Xqqoq2bVrV70eExAvBN0AAABALT788ENp06aN/PXXXyHrR40aJRMnToz63pUrV8prr70mX3/9taSkpNii65Q+LioqkkceeURatGghb7zxhr3WunXrkH1s2bLFtg22fft2ufvuu+W6666Tzp072//j77//rvE4Dh8+LCdOnLCg1vXTTz/ZfrU79+DBg+X666+XO++8Uw4cOBDy3k2bNsntt98uzZo1k5ycHFm8eHHI67pOj/3JJ5+UjIwMefrppwPnsWPHDunevbvte/To0XLp0iVZtWqVvSczM1Oee+45+eeffwL7atKkiTz88MOybt26qOUKJAqCbgAAAKAWY8aMscBw27ZtgXXnzp2zgPKpp56K+t6xY8fKjBkzLGg9c+aMLbrONW/ePAu6y8vLZdKkSTF9FtoK/MQTT8jzzz8vx48fl+LiYgtyFyxYUON7Pv/8c+nWrZvccMMN1V576aWXZObMmXLkyBHb5vHHHw8E8IcOHZLHHntMxo0bZ8eoXeW1C7h748D11ltvSa9evWx7fV398ccfsnz5clm/fr2UlpbKvn375NFHH5WdO3fa8tFHH1mX940bN4bsq3///vLFF1/EVBZAY9c03gcAAAAANHbNmzeX8ePHS0lJiQXgas2aNdKxY0e5//77a31vy5YtpWnTptK+fftqr+t+Yw22XRpc67jngoICe64t3fPnz5cXXnjBgvhItFX7lltuifiaBtxuC7i2mOsNAm0Vz83NlSVLlkh+fn4gkNagXAN9DbK1Zdv1wAMP2H5cX375pXWXX7Fihdx22222Tlu6NdD+7bffrEx69uxpLex79+4NuRHRoUMHOXXqlI3rTk2lnRCJjSsYAAAAiIF2mS4rK5OKigp7rgG4Bp3h3b7rqm/fvnV+j7Ymv/766xa4uosen7aia+tyJJcvX7au6JHccccdgcc333yz/a2srLS/3377bbXEa/r8hx9+COkWHuk8tEu5G3Crdu3aWbdyPd7gde7/K/hGhQbc4d35gURESzcAAAAQg7vuusvGO+v47oceesi6Wuu46v9Lx3IH05Zdx3GiJljTgFRbpLWrdriaAusbb7zRjjmStLS0wGP3JoKbPVyPJfzGQvjxRTqP8P26+460LjxT+fnz5y1g1+AbSHQE3QAAAECMNPP30qVLrbV7yJAh0qlTp5jel56eHtIqHE3btm3l4sWLlnDMDWR1rHWwvLw8+e6772zO7brcNNCu3pGC6Gi0C7h2FQ+2f/9+62auSc+8cOzYMTtHIBnQvRwAAACI0YQJEyzgfv/99+s0Dlu7VJ88edKCZ03AFq3b9D333GOtvHPmzLFx1WvXrq2WtGzu3LnW4q5Jzb755hvrAv7xxx/Lyy+/XON+dey0BvK6fV1oErhPP/3Uxox///33lnn8nXfeCRm/Xd80idqDDz7o2f6BhkTQDQAAAMRIM3/rNGE6JnnkyJExl5u+Z9iwYRb4akt2tOmwsrKyZPXq1Zbdu3fv3ratBtfBtHu7Zk7fvXu39OvXT+69915LeJadnV3jfnXKM+2Orgng6kJbnDds2GAZyDU7uQb8Op48OIlafdKbGtqSXltWeCBRpDiRBmQAAAAAiGjo0KHSo0cPmwor0eiYbu0Wry3orVq1ksZo1qxZUlVVZVOJAcmAlm4AAAAgBprcS1t79+zZI88++2xClpm2nC9atMimD2usbrrpJuvKDiQLWroBAACAGMdlX7hwwearDh/PrPNa//zzzxHfV1xcbGPBAfgTQTcAAADwP2nAHT6tV/A81I21KzcA7xF0AwAAAADgEcZ0AwAAAADgEYJuAAAAAAA8QtANAAAAAIBHCLoBAAAAAPAIQTcAAAAAAB4h6AYAAAAAwCME3QAAAAAAeISgGwAAAAAA8ca/ZknBW+zFl+8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ===================== MDVSP DATASET =====================\n",
    "N_SEEDS = 1\n",
    "VARY_DATASET_SEED = False\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "SILENCE_LOCAL_SEARCH = False\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "dataset_type = \"mdvsp\"\n",
    "dataset_params = dict(\n",
    "    K=2000,\n",
    "    filename=\"RN-8-3000-05.dat\",\n",
    "    x_min=0,\n",
    "    x_max=50,\n",
    "    noise_std=0.0,\n",
    "    seed=0,\n",
    "    max_trips=2000,\n",
    "    max_succ=50,\n",
    ")\n",
    "\n",
    "Xtmp, _, _ = make_mdvsp_dataset(**dataset_params)\n",
    "in_dim = int(np.asarray(Xtmp).shape[1])\n",
    "print(f\"[MDVSP] inferred in_dim={in_dim} from Xtmp shape={np.asarray(Xtmp).shape}\")\n",
    "\n",
    "train_base = dict(\n",
    "    epochs=1000,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=1,\n",
    "    plot_points=128,\n",
    "    plot_chunk=128,\n",
    ")\n",
    "\n",
    "# ---- DFN (learnable A) ----\n",
    "dfn_params = dict(\n",
    "    input_dim=in_dim, layer_sizes=[16, 128, 16], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=-2.0\n",
    ")\n",
    "\n",
    "# ---- DFN (fixed A = I) ----\n",
    "L1 = 5\n",
    "LK = in_dim + 1 - L1\n",
    "assert LK > 0, f\"in_dim too small for DFN_AfixI with L1={L1} (got in_dim={in_dim})\"\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=[L1, 400, LK],\n",
    "    p_list=[1, 1],\n",
    "    seed=0,\n",
    "    alpha=5e-3,\n",
    "    beta=-2.0,\n",
    "    A_fixed=np.eye(in_dim, dtype=np.float32),\n",
    ")\n",
    "\n",
    "# ---- other models ----\n",
    "mlp_params  = dict(in_dim=in_dim, hidden_dims=[128, 128], out_dim=1)\n",
    "maff_params = dict(in_dim=in_dim, n_pieces=1600)\n",
    "lset_params = dict(in_dim=in_dim, n_pieces=1600, T=0.05)\n",
    "\n",
    "lr_map = dict(DFN=1e-1, MLP=1e-3, MaxAffine=1e-3, LSET=1e-3)\n",
    "time_limit = 500\n",
    "\n",
    "# feasible integer box + feasible x0 / sum_eq\n",
    "xmin  = np.full(in_dim, int(dataset_params[\"x_min\"]), dtype=int)\n",
    "xmax  = np.full(in_dim, int(dataset_params[\"x_max\"]), dtype=int)\n",
    "\n",
    "rng = np.random.default_rng(train_base[\"seed\"])\n",
    "x0    = rng.integers(xmin, xmax + 1, size=in_dim, dtype=np.int64)\n",
    "delta = 4\n",
    "sum_eq = int(x0.sum())\n",
    "\n",
    "runs = [\n",
    "    (\"MLP\",        \"MLP\", mlp_params),\n",
    "    (\"DFN\",        \"DFN\", dfn_params),\n",
    "    (\"DFN_AfixI\",  \"DFN\", dfn_Afix_params),\n",
    "    (\"MaxAffine\",  \"MaxAffine\", maff_params),\n",
    "    (\"LSET\",       \"LSET\", lset_params),\n",
    "]\n",
    "\n",
    "_ = run_benchmark(\n",
    "    dataset_type=dataset_type,\n",
    "    dataset_params=dataset_params,\n",
    "    runs=runs,\n",
    "    train_base=train_base,\n",
    "    lr_map=lr_map,\n",
    "    x0=x0, xmin=xmin, xmax=xmax,\n",
    "    delta=delta, sum_eq=sum_eq,\n",
    "    n_seeds=N_SEEDS,\n",
    "    vary_dataset_seed=VARY_DATASET_SEED,\n",
    "    vary_model_init_seed=VARY_MODEL_INIT_SEED,\n",
    "    strict_ip_check=STRICT_IP_CHECK,\n",
    "    ip_check_tol=IP_CHECK_TOL,\n",
    "    silence_local_search=SILENCE_LOCAL_SEARCH,\n",
    "    allow_plots_multi_seed=ALLOW_PLOTS_MULTI_SEED,\n",
    "    time_limit=time_limit,\n",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3ca3984-8094-4fd0-bd5e-863b40801930",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:dfn]",
   "language": "python",
   "name": "conda-env-dfn-py"
  },
  "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.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
