{
 "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": [
      "(10, 8) (10,) \n",
      " [[284. 307. 453. 571.  20.  86. 494. 570.]\n",
      " [149. 187. 522. 254. 164. 497. 154. 245.]\n",
      " [386. 330.  51.  16. 520. 452. 503. 323.]\n",
      " [491. 198. 272. 473.  74. 182.  74. 272.]\n",
      " [587.  80. 230. 242. 543. 122. 301. 157.]] \n",
      " [2.8892958e+07 2.2397388e+07 2.6657474e+07 2.1041728e+07 2.3339302e+07] \n",
      " 3.6817302e+06 \n",
      "\n",
      "(10, 10) (10,) \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",
      " [ 665.  226.  993. 1351.  851.] \n",
      " 296.35287 \n",
      "\n",
      "(10, 10) (10,) \n",
      " [[-5. -9.  0.  7.  3. -9.  3. -3. -6. -1.]\n",
      " [ 8. 10. -8.  1.  5. -5. -5. -5. -6.  8.]\n",
      " [-6. -6. -8. -8.  6. -4.  6.  2.  8.  1.]\n",
      " [ 6.  7. -9.  1. -1. -4. -1. -2.  0.  7.]\n",
      " [ 7.  3.  4. 10.  3. -3. -9.  1. -6.  2.]] \n",
      " [16987.797  9943.988  8211.554  5990.925 11936.206] \n",
      " 2931.8052 \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# NOTE: MDVSP requires that `filename` exists on disk.\n",
    "X, y, _ = make_mdvsp_dataset(\n",
    "    K=10, filename=\"RN-8-3000-05.dat\", x_min=0, x_max=600, noise_std=0.0, seed=1, max_trips=5000, max_succ=50\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\", y.std(), \"\\n\")\n",
    "\n",
    "X, y, _ = generate_bipartite_subset_matching_dataset(\n",
    "    K=10, num_nodes=10, c_min=1, c_max=1000, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\", y.std(), \"\\n\")\n",
    "\n",
    "X, y, _ = generate_convex_quadratic_dataset(\n",
    "    K=10, dim=10, eigen_min=1.0, eigen_max=20.0, x_min=-10, x_max=10, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\", y.std(), \"\\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": {},
   "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": null,
   "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": "8edf3f97",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-2.41  std(mean)=579  min=-1e+03  max=1e+03\n",
      "  y: shape=(2000,)  mean=2.56e+08  std=9.14e+07  min=2.9e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | MLP ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=18,049 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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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.987e-03 @ epoch 253\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.36507e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=1.36507e+08 x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -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 1282 rows, 779 columns and 20107 nonzeros\n",
      "Model fingerprint: 0x4dec286a\n",
      "Variable types: 513 continuous, 266 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [5e-07, 2e+01]\n",
      "  Objective range  [9e+07, 9e+07]\n",
      "  Bounds range     [1e-01, 1e+02]\n",
      "  RHS range        [3e-03, 2e+01]\n",
      "Presolve removed 852 rows and 443 columns\n",
      "Presolve time: 0.04s\n",
      "Presolved: 430 rows, 336 columns, 4865 nonzeros\n",
      "Variable types: 223 continuous, 113 integer (103 binary)\n",
      "\n",
      "Root relaxation: objective 9.887731e+07, 137 iterations, 0.00 seconds (0.00 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 9.8877e+07    0   41          - 9.8877e+07      -     -    0s\n",
      "H    0     0                    1.099030e+08 9.8877e+07  10.0%     -    0s\n",
      "     0     0 1.0958e+08    0   47 1.0990e+08 1.0958e+08  0.29%     -    0s\n",
      "     0     0 1.0985e+08    0    5 1.0990e+08 1.0985e+08  0.05%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 1\n",
      "  Gomory: 36\n",
      "  Cover: 38\n",
      "  Implied bound: 7\n",
      "  Clique: 1\n",
      "  MIR: 64\n",
      "  Network: 1\n",
      "  RLT: 1\n",
      "  Relax-and-lift: 9\n",
      "  BQP: 1\n",
      "  PSD: 2\n",
      "\n",
      "Explored 1 nodes (246 simplex iterations) in 0.18 seconds (0.10 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 1: 1.09903e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.099029730900e+08, best bound 1.098956696072e+08, gap 0.0066%\n",
      "[CHECK MLP] obj(x_ip)=1.09903e+08  ip_y=1.09903e+08  rel_err=2.648e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-2.41  std(mean)=579  min=-1e+03  max=1e+03\n",
      "  y: shape=(2000,)  mean=2.56e+08  std=9.14e+07  min=2.9e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=16,725 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+naQAAu/1JREFUeJzs3QeYE1XXB/B/2vZl6b333kGqgihNUQEFFTsWFBXEyutn4/UVK2IBO2IXC2AXsNBVOgJL732pu2xN/Z5zQ3YndbO7yZbs//c8IclkMpmdhJk5c889V+dwOBwgIiIiIiIiopDTh36RRERERERERMSgm4iIiIiIiCiM2NJNREREREREFCYMuomIiIiIiIjChEE3ERERERERUZgw6CYiIiIiIiIKEwbdRERERERERGHCoJuIiIiIiIgoTBh0ExEREREREYUJg+4gzZ49Gzqdzu9t8eLFKEn79u1T6/Hyyy8Xehn/93//h8svvxx16tRRy7rlllv8zrtnzx6MGDECFStWREJCAi699FKsW7fO57xffvklOnbsiJiYGNSuXRsTJ05Eenq613wyTV6TeWReeY+815/vv/8eRqMRJ06cUM+nT5+u1qlRo0Zq/fv16+f3vSkpKervq1q1KuLi4tCzZ0/8/vvvPuf97bff1Osyn8wv75P3e7JYLHjmmWfQsGFDREdHo2XLlnjjjTcQLHnf008/jZL6bctvKJj5/P3eHQ4HmjZt6nPbnzp1CpMnT0br1q0RHx+PpKQktX1uvPFG/Pvvv8X6/+zjjz/GtddeixYtWkCv16vtXlDyvcr6y/csvzf53uX71wr0txw7dszr/66/2+DBgxFqwfym165di/Hjx6Ndu3ZITExEjRo1cMkll+CPP/4o0GdNmTJFfe92ux1l0RNPPIHOnTuX2fUnigTDhw9HbGwszp4963eeMWPGwGQy4fjx40EvV/axJXHczc9zzz2H+fPne01PTk5W65vf8Toc5NhZrVo1nDt3rtg+89ChQ+q88KKLLlLnm/J9ybHVU1paGv73v/+pc4+aNWuq81I5dr3wwgvIzs72mn/Xrl3q/KN+/frqd9WkSRNMmjRJnatoyTxXXXVVWP9GKj8YdBfQhx9+iL/++svrJidlZd2rr76qdjhXXHEFoqKi/M4nQW7fvn2xY8cOzJo1C1999ZXaqcnObvv27W7zfvbZZ7juuuvQrVs3/PLLL3jqqafUDlOCY08y7aOPPlLzyLzyHnnv559/7nM9vv32W1x44YXqICDefvtt7N+/HxdffHHuNF9ycnIwYMAAFWS/9tpr+O6771RAIcHNkiVL3OaV50OGDFGvy3wyvwQs8n5ZjtY999yDqVOnqkBlwYIF6iRhwoQJ6uAZSSQA++CDD7ymy7bavXu3et3zYkqPHj3U93777beriyXyu7jzzjuxd+9ebNiwoVj/n33yySfYsmULunfvrg60BSUHdvle5fcq37N87/Idy/fui6+/pUqVKrmv16pVy+ff+uijj6rX5XcUSsH+pr/44gusWrUKt912m5rv/fffVxcZZD45+QrGkSNH8OKLL6rAWy5wlEUPPfSQ+p3KvomISsbYsWPVeYa/84HU1FTMmzdPNRzIvq2sCxR0y0Xe4g66MzMz8Z///EcdlzyP8eEkwbGcL8g56dChQ/3Od+DAAdXwIucI7777rjrPuPrqq9UFCvlNSKOA9hxWzklWrFiB//73v/j555/V8fu9995TF5a1F1jl/T/99FOBLzYT+eSgoHz44YfyP9axevXqUrnF9u7dq9bvpZdeKvQybDZb7uP4+HjHzTff7HO+hx9+2GEymRz79u3LnZaamuqoWrWqY9SoUbnTrFaro1atWo6BAwe6vf+zzz5T6/rzzz/nTvvpp5/UtM8//9xt3ksvvdRRu3ZttSwts9nsqFixouPNN9/0uf5t2rRxXHTRRT7Xf8aMGeqzVq5cmTvNYrE4Wrdu7ejevbvbvN26dVPT5XWXFStWqPfPnDkzd9rmzZsdOp3O8dxzz7m9/4477nDExsY6Tp065chPgwYNHE899ZSjpH7b8hsKZr7bb79d/U3ynWvdcMMNjp49e3pt+1mzZqn3/fHHHz6Xq/3eiuP/mfbzLrvsMrXdg3Xy5ElHTEyM484773Sb/r///U99/1u2bAnZ39KvXz9HXFyc13YuqmB/08ePH/d6r/w/bN++vaNJkyZBfdYjjzziqFOnjts2Ly4ZGRkhW9a9997raN68ucNut4dsmUQUPNn3yLlAly5dfL7+1ltvqX3YDz/8UKDNKu8pieNufvydg3399ddqnf/8889i3V/KsUGOfWfOnHEUJ+2xQ46l8rfLsdVTenq6unmSc2J5z7Jly3Knvffee2rab7/95javnL/J9HXr1rlNv/zyy9W5KFFRlc2mh1JO0l/uvfdevPPOO2jevLlqHZL0Sl+p0ps3b8aVV16JSpUq5aZU+2pRkZSqBx98EI0bN1bLq169urrqt23bNq95p02bplJeJb1GUkj//vvvoNY72JYouZosrckNGjTInVahQgXV8vfDDz/AarWqafK5R48exa233ur2/muuuUatmyxHu0yZJq9pyXulteyff/5xmy6t1HJlW9sKWJD1l9Ri2TYukqZ+ww03qJa9w4cPq2lyv3r1apVeJK+79OrVS32v2vWXK9Jy/Pb8W+V5VlYWfv31V4SCXMmV35dc/fUkV6DlavDJkyfV80WLFqnfVt26ddVvS1K/77rrrtzXC0uyD1wtoS7yXUjmgbSKenKla0mLri/F3QJalM+T71FaW3x9z/L9+2qZKAzJGJAW6VGjRqn/W1qSmi7fo3yv8n270ttd/+8CKchvWvYxngwGA7p06YKDBw/m+1lms1llRFx//fVu21zbFSaYfZW0WLhS4aWFRbqySCaAlrRGyDKli4u0bsj+1JXFIN0HpKXjxx9/RKdOnVQqYatWrdRzIRkY8ly6PUj2w5o1a7zWQbaXZPb8+eef+f7dRBR6su+5+eabVbeXTZs2+cwokmOMZPFIS6ZkIMl5l+xbZF8m5yzLli0r9Oe/9dZb6NChg1qe7Ieke5G0/HruXyWDq169emrfLF3lZH/kSneXY4ecx8l5nnSxqly5stq3SSaRluzLMjIy1Lmgq5uRZBLKvsp1jtS/f//c17Tp1q6sJTluyD6zd+/eXl3nAu0vA/39w4YNUynevs53JYNM9qPymbKdXPvX4jpey/5bbp5kny60xyzpgiDkO9By/W1yvuS5/5ftKsdloqJg0F1ANptNndxqbzLN14ni66+/rtIqv/nmGxWgSrAij10kFVtOdiXVVeadO3euOkhI/0pJyXSR/jN9+vRRQbyc3EtgK6nUcpIsQa3WjBkzVLAlwZmk5MiOW4JzCYpCQQJI2fG0b9/e6zWZJq9Lf2/XBQXXdC3Z4ckBy/W6a17ZYWsDAe17tfMKCfDkYCUHtYKSZflbfyHfR6D1d03zXH9JaZe+RMGsf2HJhQE5mHv2aZLf4KeffqoOitJHV8j3JNtIDpYLFy7Ek08+qS5eyG/Js/9xQcjBXA7U0rXARQJwOTiOHj3aa37XxY2bbrpJBaWefaYK+//M1zy+bqHsi+v6HqWvmJac7Ml29/U9S8AnJ4xygiUXpoL5Lci2lSBe0vE9A245iZC0dvk+pRuGpF1Kt4Y77rgj6PUP5jfti2xPOXFt06ZNvp8lvzX5ruXk0Jdg9lWSSioXjuQ3J78xCeLPnDmjTkCXL1/utUzZvnJx6euvv1b7SJeNGzeqmgJyYUr2s3KyJfNKVxZJm5dUTlkH+Wz5vmQ/piUXGuRkW9IMiahkyEVdCfK0xx5XyrVcMJegXPa1p0+fVtPl/7f8n5WAXBosZL9RmLog0mAiQbz0K5YLk3Ice+CBB9Q+SxtwS5c4eV36Bsu+WfZtsq+RfZaQ7juybtJlRZYh+zQ5Hsu+SNtlRy4qysVB2R+6uhvNnDkTl112WW53Ndl/ul6T6ULOAQYOHKj2lxKwS9c/Oe4MGjTIZ80af/tLX/2q5UKHv325bOM333xTne/KuZl8pjSIuM4FhRzPgjleB3PxuCBcaeHaY5b00Za+3HIBRM73pAvc0qVL8fzzz6tzKDkX1ZLfjay/pKETFUmR28rLCVeqqK+bwWBwm1emSfrtsWPH3FKjWrZs6WjatGnutGuvvdYRHR3tOHDggNv7hwwZotJKz549q55PmTJFLXPRokX5ppe3a9fOLRV71apVavoXX3wRktSmw4cPq+VNnTrV6zVJDdembUvKrTw/evSo17ySci7pmi7NmjVzDBo0yGu+I0eOqGVo07bl75NU9ldeecXv+gdKL5fU+Lvuustruqy3NsXdlQb/119/ec0r6cVRUVG5zyX1qEWLFj4/T+bzTEcuSnr5iBEjHHXr1nVLu5JU/UCpdZIWK+nE+/fvV/N99913hU4vlxQvSW2Tx5JW70pZvuWWW/xue/kNy3Zw/Z9p1KiRY9y4cY6NGzcW+v+ZfIa/ebU3f90kCpNeLt0F5P+sL/J71nal+OWXXxyPP/64+k6WLFmiukLI9yb/tzZs2OD3M+T3LSnZsr/wJL/bhIQE9T1qvfzyy+pv1aa3+1KQ37Qv8vfI++fPn+/IzwsvvKDm1e4HC7Kvkt+3pJPKfNrf+rlz5xzVq1d39OrVK3ea/L+R9z755JNe6yHfr+yPDx06lDtNtr/ML91ftGmV8nfJ9O+//95rOb1793ZccMEF+f7dRBQ+st+X4790MXN58MEH1f/bHTt2+HyP7Gfk+DdgwADH8OHDC5xeLt1LpDtbILfddps6t0hOTg76b3Gt19ixYx2dOnUqUnq57McqV67sGDZsmNt02Xd26NDBretcoP2lL3PmzFHz//33316vyfQaNWo40tLScqfJPl+v17udJ7rOGYK5+TsXCZRe7oucX8i+3/M7d51bSnc47edec801juzsbJ/LkmPy6NGjg/pcIn/cmxUpX3I10vMqmFx59STpPdpiHnL1VVoBJQ1UrhpKaqhcgZP5JBVJS1q65SqpXMGU4l7yWFq1pcBDfuSKp3yWi6tFSwqMhZKvv9nfa/7mDXY+z9ck7VZSpH0VYysL619Uku0grXWS7iRXtYVcyZdWdkmtc5Fq1NIaKlehJUVf2+K7detWVTCvsOSKv6SjSYuD/F4lZfmVV14JWAFa0u7kSrG0gK5cuVJdWZdWRvk/5UpZL8j/M8n8CKaKqqvlP1SC/Z7l/6628rgU/ZP/n9JKLt+LZ0qhNoVdWk1eeuklr9ckZU9aGyTDQ9siIN+7tJ7I/w3JlpEsAG3hGMlC0KbpBfub1pLvSorISeuAtD7nR35zsjx/2z+/fZVkAskypHKtdt2lxXnkyJHq+5fiPpLO6CLTfZF0ThmVwcX125IWDO37XdN97S8lRVV+50RUciSzR7KmJJtQ/r/LflBaeKW4a7NmzXLnk+OLFNSSVnBtgUjJsisoyS6Sllw5TsnIF5Ky7blfk/M02Td7Hrc8SauytIBL9o22pdwzpbmg5JgqrejS2u/ZWizHIcmelM/TpmD72196kv2wvy5HQv5ubXE1OfeVebX7UckWCnb/WZgMRk/SjUmyluT8Wo5dWpJ5IMcwOX5IhpPMI1leUlRNzovknMkz61L+HlfXQ6LCYtBdQLJD7dq1a77zeaYZa6dJyqUE3XLvq5+ra4fjSsOV/kmSChMMbVVkIf2/hWe6ZGFJ3x85kfaVIuxK6ZLUIu26yLye1URlXtd8rnmDWaaQFH3ZgRdmqKeCfJZ2/X3N67n+vqpwy0FO+rZq5y0qCbDkdyOBtgTdcgCRExCpqO0KYiTAltfkYCkBrwR6crCV6VK1s6i/B/kNSPAv3SKkn5pcFJKTnkDkNyDvcfWHlnQu+VtkvT2D7mD+n0lanDaw9CeUfcble5a/1zPYc/0m5HcZiPxmJZ0wUJ0FSaGWLhhyYulJ+gZK9xJXnzRPrv76cjFPW4lfTsSkS0JBftNa8luTfuRy4cTXxQBf5Dcm66kNrAuyrwpUC0D2kfJblt++9nvwVzfA8+9yjc7gb7qvIWbkpDhU+1EiKhzp2nTfffepfZIEjXIhV/aLMjSUi9SKkIuD48aNU4GUBMiyH5JjoVxwLijp0yuBrFS3ls+UfY+kkj/77LOqxoTrPE3O6wKRi+VSp0P6ZT/88MPqnFCCO+kC5pkyX1CufuOyffyRfbw26Pa3v/Tk2u/5uzDguS937c+1+0u5WCoXP4PhGfAWlAT7ciFAliNp9Z77efmtyPmazOfaBnL+IhdkpO+/BOJyzNTi/p9CgUF3mGjH4fWc5tpByb1nn2ztVUXXlVTpKyyt46WB9DOSYMdXIROZJq9L3yltv1eZLq1vLnLwkgJw2kBL5pX+TfKadofr+py2bduqeznYSZ+p+++/v9B/g3yWv/XXfpbrXqZ7DlUh01yvu5Yp/b7kO9ZecPFcZijIyYOcBEjAKwX2pN+rXMnXFveSq7ZyJV0CLe3Bw1cBtsKSFm5psZUWBWkBLShp+ZULA9K3TVrl/V1F98czsPTHFXCGgvY3fcEFF+ROl+9dAt5gvme5UODvQoBsB2nNlqvtvraH7BOkRdjf9nZdsPPMAnDtSwrym3aRk1vpWy7bUb7rYLM25DPlgpNn60qwXPtJf/tI2YZyETBcGSW+TlhDnTVBRAUj5xhy7iABsOwbJFiVVlZtEVZp+ZYsFglmtYoyvrTrgrHsz+SCsfQXl5ZUKbAoNXuCOU+T9ZLCkXPmzHHbV3kOP1oYrn3TG2+8oS6s++LZ+FGQfblrHxhsoO5JjtX++oR7kiEaC9uoIoG0qw+29N/3dSFEAm7JfPL8W+RCivBV20T+9sKuE5ELC6mFiVxdc115FJLuKTtaScl17QQkaJAUc1eQrU2tldYb145TWgNlx15axgmUAhmyLtpqkHIwk6u4Eiy4gmYJSmSn5hnwSEu1FK7QpofLMmWaFOHQkmIgEki4AhxJoZIAJ9i0KH/rL0G/tiK6K0VNPscVuMhOWdLKZLq2iJe0Ukrqq3b9JVVJDmCeleflb5eTBG2acSjIwV9a4+RChXyGFCvTps25Dqau1kMXCcZCRbaPXK2XwiOeV4W15P+Br2Jmsk137typfuueFVGDIX+LpKvld5NKraEi36Nc8fb8Tctz2eZSoCW/kwkZG9TfSZH835cid5JC6Yuc5MkJgexHJBPA8+b67Up1fu1018lCQX7Trr9LAm4p4CcpegUJal2/x8JWfJW/QdZXLippMxrkpNdVSNEz2yCcpCiQ9uIhEZUM2T/K/kuybqSlW1K+tfsC2U95Hvv+/fdfr1EPCkMuIMo52eOPP64uKroKr8o0Gd1A9qP+yHpJNo12PyrnM766Gnm2FGunC8/XJOVdjqOSTu/r2CA3VyZPQRV1X65NLw/mVtj0chmrWwJu+W3IOap2hB0tWb5cIPFMF3f9PjwDdTk/lPNd7v+pqNjSXUBywuuruqKcBMuVTu2VQUlTkXQm2UlL5UkJ9LTDhsmVUlcfTWkxlBQYSWuR/iTS/8Y1nIH0aZSAXQK7xx57TJ00yw5XrhzKSXiwVw/zI8uTFCkhOy25Yuiqti59eF1/n/QdleEhpE+mVKuUg4BUfZQgUBvgSIus/B3SKiupqXJ1WoKsRx55RKVkaQNROWDJtLvvvhtpaWmqNV0CSunfKgGCK0VV1kda4ySd2ZMM9SP9eIQsQ07UXesvVzBdO2CpgCqVP+XKuKy3tCjK9yMHS+kn7ZmGJOsl80r1UmmJlO9A1kHbsiyVMeVEQL5TWVf5PKkYLn3KJAUtlOnlroOgBB1StVoOBvI5nq/Lb1LWVbaDfL6kJUu16FCS7Zcf+a1IgCxDR8l2kd+1HPAkiJMTFvnte54MBPP/TIKywpCTErm5TngkVdz1O5GDquvAKv8f5MKYrJ/chGzH//u//1P/r+WxtNS7AnsJTrUHZanBIK350jIt1WSlJVn+P8gJl6Q8+kstl/5lUm3WF/n/Jt+hjHog2R6yDeT/nfzu5eRTWqLzS3EM9jctfQ/lNy0pgfL/V6oDa8nwW54ntlpy8uMK6H1VS8+PtGTL9hozZozaz8k6SIuQnGhLhkcwv71QkVR32XdJWisRlSwJIGWfIn2j5fjmeZFS9heyj5XjsZy7yLFd9p3SylyY6tgyMoRcPJfAVhoS5Lghx145lrlaR2X50q9b9vkylJhkRcl+Ss5hpJq5HJNlvaRxQva7kgYux25ZT1mm7F+05P3SUivHbXldWvNlf+/KRpJjvkyTi8Dyd0lmkLRyywVwaZWV5cu5jZzTSdab3Hu2/AdLGiPk75d9eWFrwci6BtM10xfX8dlVDV3O9SRdXZtOL8cxOReW7Ac5jspzubnIcdF1bBw/frw615bjoBz7XH265VxNsgHkmON5wUbOE0J1rk3lmN8SaxR0VWW5vffee7nzyvPx48c7Zs6c6WjSpImqaCmViKVysKdNmzapapNJSUmqcrBUmfRVmfHMmTOOCRMmOOrXr6+WJ9V7pfLytm3b3CoCv/TSS17vDaY6Z37VoD0rZe7atctx1VVXOSpUqKAqrUtV0LVr1/pcrlQDb9++vfr7atas6bj//vtVBWJPMk1ek3lkXnmPZ9X1evXq+f1bpNKnv/X33KZSXfOmm25S1T5jYmIcPXr08FsdfuHChep1mU/ml/cdP37caz6ppirrJt+RrL9Us3799dcdwQq2ernLu+++m1spPzU11et1qaIqVdUTExMdlSpVUpU5pVK+5++hMNXLA/GsXi7rIdVlu3bt6qhWrZrDaDSq9ZF5Pvnkk0L/PyssV+VWXzftdnFVW/X1nbz22mvq+5XvWb5vmUdbTVdMnDjR0bp1a7X95W+WStw33HCDY/v27T7Xa8WKFUFVlD1x4oT6fyIV4GVfIL/JLl26qMri6enpQW2DYH7Tgf4/BfN7EX379nUMHTrUbVpB91VSUVyqhsu6SkVf2dfItvL1ncq28fX/SvaVvj5L9tPBrNsHH3ygtrVnJXYiKhmyD5b/q7KP9ZSTk+N46KGHVMVp2W907txZ7Udkn+Y5WkUw50cfffSRo3///qpKt+zzZV8+atQox7///us238GDB1UVczmHkf2Faz7tvvX55593NGzYUI2C0apVK3VMc+2/tGSEBRkxQc6v5DXtMXX69Olq/y8jenie38hIGbK/k/26rINsA3kuVc+D2V/6c+ONN/rc1r72o0K2c6CRQwoi0HEo2Oront/xunXrVFVzGVFEvovGjRs7br/9dq/RhMQTTzyhKub7q2xOFCyd/FPSgX+kkZYsuZIm1S4pdKSlTa64ylVHz3GSI4GkAEs/6VCmQxOVJEkDl1EbJGtGWz28rJEiO1LMUlpHiIjKG2ldllZ9ae3W1jOJdJL1KZmXkqlXmNo1RFrs001lhqTVyzWiSAy4iSKR9BGXEzVJxSyrpGiSdCHw1yWAiCjSSWq4VF4vb/tB6d4o9Yakfg1RUTHoJiKisGX9SJVh1xBfZZH055YCd65RGYiIyqNXXnlFXUQtShX4skaOW5LhVJhir0SemF5OVEowvZyIiIiIKPIw6CYiIiIiIiIKE6aXExEREREREYUJg24iIiIiIiKiMDEiAoseHDlyBImJiaqIDxERUWkmozJIcSIpOKfXl+9r4TyGExFRJB7DIy7oloC7Xr16Jb0aREREBXLw4EHUrVu3XG81HsOJiCgSj+ERF3RLC7frD69QoUJJrw4REVFAaWlp6mKx6/hVnvEYTkREkXgMj5ige8aMGepms9nUcwm4GXQTEVFZwS5ReduAx3AiIoqkY3jEdB4bP348kpOTsXr16pJeFSIiIiIiIqLICrqJiIiIiIiIShsG3URERERERERhErF9uomIKLRDOZnNZm7SQjCZTDAYDNx2RERE5ZTOIYOLRVgFuaSkJKSmprKQGhFRCEiwvXfvXhV4U+FUrFgRNWvW9FlohcctbgsiIiqbgj2GR0xLNxERhZ5clz169KhqqZUhMfR69koq6PbLzMxESkqKel6rVi3+TImIiMoZBt1EROSX1WpVQWPt2rURFxfHLVUIsbGx6l4C7+rVqzPVnIiIqJxhkwUREfnlqpMRFRXFrVQErgsWFouF25GIiKicYdBNRET58tUXmYLH7UdERFR+RUzQLZXLW7dujW7dupX0qhAREREREVEplGm2FvtnRkzQPX78eCQnJ2P16tUhW+bZRS8j482+OLPs3ZAtk4iIypaGDRti+vTpJb0aREREVETfbTiM3s//gfUHzqA4RUzQHQ5btycj/uS/2L5jW0mvChERFUC/fv0wceLEkGwzuZh75513cvsTERGVUWnZFkz8cj0mfLkBZzIt+GjlvmL9fFYvD0RvUnc6m7mYvg4iIiquobykSJzRmP9hsFq1asWyTkRERBR6a/adxsQ5G3DoTBb0OuD+Ac1wb/+mKE5s6Q7AYXBW69XZWG2WiKisuOWWW7BkyRK89tprqoCZ3GbPnq3uFyxYgK5duyI6OhrLli3D7t27ceWVV6JGjRpISEhQdUF+++23gOnlspz3338fw4cPV1XJmzVrhu+//74E/lIiIiLyx2qzY9qiHRj1zl8q4K5XORZfj+uJiZc0h9FQvGEwW7oDOR90gy3dRES5LcRZFucwYsUt1mQIqgq4BNs7duxA27ZtMWXKFDVty5Yt6v6RRx7Byy+/jMaNG6NixYo4dOgQhg4dimeffRYxMTH46KOPMGzYMGzfvh3169f3+xnPPPMMXnzxRbz00kt44403MGbMGOzfvx+VK1cO4V9MREREhXHgVCYmzFmP9QfOqucjOtXBM1e2QWKMM5O5uBkjqXq53FxjyoaE4Xx6uZ0t3UREQgLu1k8uKJGNkTxlEOKi8j9sJSUlqXHFpRW6Zs2aatq2bc7aHBKEX3rppbnzVqlSBR06dMh9LsH3vHnzVMv1vffeG7A1/brrrlOPn3vuORV4r1q1CoMHDy7S30hERERFaxyYu+4wnvxuMzLMNiTGGPHsVW1xZcc6KEnGSKpeLre0tDR1whUSrvRyO/t0ExFFAkkt18rIyFCt1j/++COOHDkCq9WKrKwsHDhwIOBy2rdvn/s4Pj4eiYmJSElJCdt6ExERUWCpmRY8Pn8Tfvz3qHrevWFlTBvdAXUrxeXOI1XL957MQKOq8ehUvxKKS8QE3eGgOx9069nSTUSUm+ItLc4l9dlFJQGy1sMPP6z6eUvKedOmTREbG4urr74aZnPgi60mk3t6mqS92+32Iq8fERERFdw/e07hgTkbcCQ1Gwa9Dg9c0gx392uqHrs8/8tWvL1kT+7zcRc1xmNDWqE4MOgOQGd0tXQzvZyISO0PdbqgUrxLmqSXB9PdSIqpSaq4FEUT6enp2LeveIcRISIiosKx2OyY/tsOzFy8Gw4H0KBKHF67thM61qvoNp+0cGsDbiHPB7WpWSwt3qX/zKkksaWbiKhMkorj//zzjwqgpSq5v1Zoad2eO3euKp4mFxSeeOIJtlgTERGVAXtPZqixtzceSlXPR3WtiyeHtUFCtNHnvP6WURxBN4cMC0BndKYPGtjSTURUpjz00EMwGAxo3bq1GmfbXx/tV199FZUqVUKvXr1U4D1o0CB07ty52NeXiIiIgi+W9tXqg7js9WUq4K4QY8SM6zvjxas7+Ay4hfThLsj0UGNLdwB6Y7Tz3mEtli+DiIhCo3nz5vjrr7/cpkkaua8W8T/++MNtmhTl1PJMN5eDvaezZ51DkhAREVH4nM004z/zNuHnTcfU8x6NK2PaqI6oXTE24PukNVv6cGtTzO++qHGxFVNj0B0AC6kRERERERGVvJW7T2LSnI04lpYNo16HBwe2wJ0XNnYrlhaIFE2TPtysXl7K6E3Olm6Dg4XUiIiIiIiIipvZase0RTvwzlJnsbTGVeNVsbR2dQs+TLS0bBfnUGER19I9Y8YMdQumWm2w9CZn9XIjg24iIiIiIqJitftEOiZ8uR6bD6ep59d1r4cnLm9dJkZS0SpbaxuA9MGTW1paGpKSCn7VwxfD+T7dBvbpJiIiIiIiKhYOhwNfrj6IKT8kI8tiQ8U4E54f0R6D29Ysk99AxATd4UwvNzLoJiIiIiIiCrvTGWY89u2/WJh8XD3v3bSKKpZWo0JMmd36DLoDMBiZXk5ERERERFQclu08gQe/2oiUczkwGXR4ZFBLjO3TCPogi6WVVgy6AzC4WrrBQmpEREREREThkGO14aVft+P95XvV82qJ0Zh9aze0qR2absMlTV/SK1CaGaOcQbcJHKebiIiIiIgo1HYeP4erZqzMDbjFiXM5eHzepojZ2Ay6AzCyTzcREREREVFYiqV98tc+XP7Gcmw96qxOrrXhYCrmrD4QEVueQXcAhvNDhrGlm4iofGnYsCGmT59e0qtBREQUkU6m5+D2j9bgie+2IMdqR00/RdI2HjyLSMA+3QGYzqeXG3V2wG4D9Ibi+l6IiIiIiIgizuLtKXjo639V4B1l0OOxIS0RG6XH5LmbvebtUK8iIgGD7kAbx5R3xcVmNcMQFVsc3wkREREREVFEybbY8MKv2/Dhin3qefMaCXjt2k5oVauCej5n9UGVUu7SqV4SRnerj0jA9PIATNHOlm5hMWcXx/dBRERF9M4776BOnTqw2+1u06+44grcfPPN2L17N6688krUqFEDCQkJ6NatG3777TdudyIiojDZfuwcrnxzRW7AfUuvhvj+3j65AbeYP74PXhjZDtd3r6fu543vEzHfB1u6AzCd79MtLOYclN3h2ImIQsThACyZJbM5TXGALv9xOq+55hrcf//9+PPPPzFgwAA17cyZM1iwYAF++OEHpKenY+jQoXj22WcRExODjz76CMOGDcP27dtRv35kXFEnIiIqLcXSPlq5D8/9sg1mqx1VE6Lw0tUd0L9ldZ/zS8t2pLRuR2TQPWPGDHWz2WwhW6bJaILVoVd9uiXoJiIq9yTgfq52yWyG/xwBouLzna1y5coYPHgwPv/889yg++uvv1bT5bnBYECHDh1y55fge968efj+++9x7733hvVPICIiKi9k2K+Hvt6IJTtOqOf9W1TDi1d3UGNwlzcRk14+fvx4JCcnY/Xq1SFbpl6vg+X8dQkbg24iojJjzJgx+Pbbb5GT47xg+tlnn+Haa69VAXdGRgYeeeQRtG7dGhUrVlQp5tu2bcOBA5ExLAkREVFJ+2PbcQyevlQF3NFGPaZc2QazbulWLgPuiGrpDhcJumNhhtXClm4iIpXiLS3OJfXZQZJ0cenT/dNPP6k+28uWLcO0adPUaw8//LBKNX/55ZfRtGlTxMbG4uqrr4bZbA7jyhMREZWPYmnP/bwVH/+1Xz1vWTMRr1/XCc1rJKI8Y9CdD6vOuYkYdBMRwdmnOogU75ImgfSIESNUC/euXbvQvHlzdOnSRb0mAfgtt9yC4cOHq+fSx3vfPmdhFyIiIiqc5CNpmPDleuxMSVfPx/ZphIcHtUCMicMuM+jOhyu9nEE3EVHZSzGXFu8tW7bghhtuyJ0urdtz585Vr+l0OjzxxBNelc6JiIgoOHa7A7NW7MWLv26H2WZXKeQvX9MBFzWvxk14HoPufFhhUvc2C9MOiYjKkosvvlgVT5Oq5Ndff33u9FdffRW33XYbevXqhapVq+LRRx9FWlpaia4rERFRWXQ8LVsVS1u286R6fkmrGmq4ryoJ5bPvtj8MuoNJL3dI0M1xuomIyhIpmnbkiHf/84YNG+KPP/7wKsapxXTzgps6darKIJCidJLeLxc1XnjhBbRo0aIQSyMiotJu4ZZjePTbf3Em04IYkx5PXN4a13evr7LIKEKrl4eL7XyfbjsLqREREfm1ZMkSdfHi77//xqJFi2C1WjFw4EBVLZ6IiCJHptmK/8zbhDs/WasC7ta1KuDH+/pgzAUNGHD7wZbufFh1zvRyO1u6iYiI/Pr111/dnn/44YeoXr061q5diwsvvJBbjogoAmw+nIr7v1yPPSecF1TvurAxJg1sjmgji6UFwqA7Hzm6WHVvy8nMb1YiIiI6LzU1Vd1Lv3q/x9icnNyx1AX71hMRld5iae8t24OXF26HxeZAjQrRmDaqI3o3rVrSq1YmMOjOh8UQK9XUYMt2lr4nIiKiwBwOByZNmoQ+ffqgbdu2AfuBP/PMM9ycRESl2NHULDz41Uas3H1KPR/UpgaeH9EeleKjSnrVygwG3fmwStAtV3fM7JNGREQUjHvvvRf//vsvli9fHnC+yZMnq+Bc29Jdr149bmQiolLil01H8djcTUjNsiDWZMBTw1pjdLd67LtdQAy682EzOoNuRw5buomofLdcUuGVp3HA77vvPnz//fdYunQp6tatG3De6OhodSMiotJl5e6TeO23nfhn72n1vF2dJLx2bUc0rpZQ0qtWJjHozofNGO98wJZuIiqHTCaTupp94sQJVKtWjVe2C3Gxwmw2q+2n1+sRFRUV0X+rBNzz5s3D4sWL0ahRo5JeJSIiKoRJc9Zj7vq8ITc71auIOXf1RJSRA19FVNA9fPhwdcAeMGAAvvnmmxJdF4cpzvnAwkJqRFQ+x7qW1spDhw5x7OoiiIuLQ/369VXgHalkuLDPP/8c3333HRITE3Hs2DE1PSkpSY3bTUREpZvN7sBT3212C7jF+oNnseVIKjrVr1Ri61bWlcqg+/7778dtt92Gjz76qKRXBY4oZ0u3nkE3EZVTCQkJaNasGSwWS0mvSpm9cGE0GiM+S+Ctt95S9/369fMaOuyWW24pobUiIqJgHD6bhQfmbMCq8+nknvaezGDQHWlBd//+/VVLd2mgO9/SrbeypZuIynfgKDcif9jvn4iobPrx3yP4z9xNSMu2IsakR7bFuw5Jo6rnu9xSoYQ8z00KpwwbNgy1a9dWV/Xnz5/vNc/MmTNVX6+YmBh06dIFy5YtQ6kV7SwWYGDQTUREREREESI9x6qGArv38/Uq4O5QryJ+nXAhxl3U2G2+uy9qzFbu0tbSnZGRgQ4dOuDWW2/FyJEjvV6fM2cOJk6cqALv3r1745133sGQIUOQnJys+ruVNoZo51Udoy2rpFeFiIiIiIioyNYdOIOJX27AgdOZ0OuAe/s3xX0DmsFk0OOxIa0wqE1NlVIuLdzsy10Kg24JoOXmz7Rp0zB27Fjcfvvt6vn06dOxYMEC1Rds6tSpBf68nJwcddOO8RlK+vMt3SYb08uJiIiIiKjsstrsmLl4N177facqnFanYixeHd0R3RtVLulVi2jF2qdbhk1Zu3YtHnvsMbfpAwcOxMqVKwu1TAnUn3nmGYSLMcYZdEfZs8P2GUREREREROF08HSmKpa2Zv8Z9fyKDrXx36vaIinW5Dbf879sxdtL9uQ+l3Rzaf2mwivWsUtOnjwJm82GGjVquE2X566hRcSgQYNwzTXX4Oeff1ZD1axevdrvMidPnozU1NTc28GDB0O6zlGxDLqJiIiIiKjs+m7DYQx9bZkKuBOijXh1dAe8fl0nr4B7/YEzbgG3kOcyncpY9XLPYVOk4ql2mqSbBys6OlrdwsUUm6juYxzs001ERERERGVHWrYFT87fjPkbnGNvd2lQCdNHd0S9ys4RmjxJP25/09m3u4wE3VWrVlVDzmhbtUVKSopX63dBzZgxQ92kJT2UolxBN/L6jRMREREREZUkaX0OVOxszb7TmDhnAw6dyVLF0u4f0EwVTDMa/Cc7+xsajEOGlaH08qioKDVE2KJFi9ymy/NevXoVadnjx49XFdADpaIXRky8K+g2A/bQBvREREREREQFJf2uh89ciUlfbVT38lxbLG3aoh0Y9c5fKuCuVzkWX4/riYmXNA8YcAsJ3jlkWBlo6U5PT8euXbtyn+/duxcbNmxA5cqV1ZBgkyZNwo033oiuXbuiZ8+eePfdd3HgwAGMGzcOpVFMnDPoFrbsczDEVSzR9SEiIiIiovLLX79rGearSnw0JsxZj/UHzqrpIzrVwTNXtkFijHvf7UA4ZFgZCLrXrFmD/v375z6XIFvcfPPNmD17NkaPHo1Tp05hypQpOHr0KNq2basKpjVo0KBUppfHxSXA6tDDqLMjOzMN8Qy6iYiIiIiohPjrd/3VmoP4YeNRpOdYkRhjxLNXtcWVHesU6jOkxZt9uENH55AqZhFExulOSkpSlcwrVKhQ5OXJ5jn7dF1U0qXj1M3LUKVR+5CsJxERUTiOW2UZtwURUXAt3ZJS7k/3hpUxbXQH1K3ku1gaFf9xq1j7dJdFUlU9UxerHmelO9M0iIiIiIiISoKvftfCoNfhoYHN8cWdPRhwlzIlMmRYWZOpiwMcQE5GakmvChERERERlXMPDmyBE+dyMHfdYQlT0KBKHF67thM61mP9qdIoYoLucPXpFtn6eMAGWDLY0k1ERERERCXbp3vil+ux8ZCzQbB7o8qYOKAZA+5SLGLSy8M1ZJgwG5zj1Vky2dJNRERERETFT2pNfbX6IC57fZkKuKOMzlBu1d7TuP79f9yGDaPSJWKC7nAyG51Btz07raRXhYiIiIiIypmzmWaM/3wdHvn2X2SabWhbuwLMVrvXsGFSZI1KHwbdQbAZE9Q9g24iIiIiIipOK3efxODpy/DzpmMw6nV4dHBL3NKrYYGGE6OSFTF9usPJFuUMupFzrqRXhYiIiIiIygFpyZ62aAfeWbobMshz46rxqlhau7pJflu0G1V1ZuhS6RIxLd1SRK1169bo1q1byJdtj0pU9zoG3UREREREFGa7T6RjxFsr8PYSZ8B9Xfd6+PH+Pirg9jds2N0XNVbTqfQxRlIhNbm5BigPqWjnQOd6S3pol0tERERERASo1us9J9Kx60QGZq/YhyyLDRXjTHh+RHsMblvTa97mNRLxwsh2MBn0qoWbAXfpFTFBdzjpYpxBt5FBNxERERERhZhUHpdCaFq9m1bBtFEdUaNCTMB5pcV7ROe6/E5KsYhJLw8nQ6wz6I6ysqWbiIiIiIhCR1qtPQNuMenS5l4Bt695WbW89GPQXZCg28ZqgEREREREFBo5Vhum/7bT52v7T2UGXZ2cVctLN2MkFVKTm81mC/myo+KcfcRj7Ay6iYiIiIio8KS1WoJkGf7rrSV7sPVoWtCVyP1VJ2fV8tItYoLucBZSi46vqO5j7d5Xm4iIiIiIiPwF19oiZ776bsdHG9CuThL+3nM630rkrqrl2mWwannpFzFBdzjFJDiD+DhkQdXs1+lKepWIiIiIiKiU8lXsbFCbmj77bmfk2FTAPbxTbfRtVi3fSuSPDWmlluUZ0FPpxaA7CLEJzh+yAXbAkglEcdB5IiIiIiLy5q/Y2dHUrICba976I7ipZ8PcINpXS7mLPGewXXYw6A5CfEIF2Bw6GHQOWDJTYWLQTUREREREBShq9t2Go0G9V4JpXy3l0sJNZROrlwchPsaEdMSqx1nnzob7OyEiIiIiojIqUFGztnUq5PteDgsWeRh0ByHKqEc64tTjrHNnwv2dEBERERFRGSUt1Xdd2MhtWqzJgA9v6YYf7+uLeff0wrRRHVQfbi1XQTQOCxZ5Iia9PJxDhoksnTPozs5gSzcREREREfl24lwOth1Lz33epX5FvHNTV1RNiHbrjz2ic13Vh9uz3zaHBYs8ERN0h3PIMJGlj4OzjlpqyJdNRERERERl3x/bjuPhr//FqQwzoo16PH5ZK9zYowF0fkY/8lUQjcOCRZ6ICbrDLccQz6CbiIiIiIi8ZFtseO7nrfj4r/3qecuaiXj9uk5oXiOxUFuLw4JFFgbdQTJL0G0BbFlp4f1GiIiIiIiozEg+koYJX67HzhRnSvnYPo3w8KAWiDEZirRcDgsWORh0B8lqdFYhtGcz6CYiIiIiijSBxsX2xW53YNaKvXjx1+0w2+yolhiNV67pgAubVyuW9aWyg0F3kGwmZ2qII/tcOL8PIiIiIiIqZgUdF/t4WjYe+nojlu08qZ5f0qoGXhjZDlXOF0sj0mLQHSRblDPo1uUw6CYiIiIiihT+xsUe1KamzxbvhVuO4dFv/8WZTAtiTHo8cXlrXN+9vt9iaUQMuoMV7Qy69RYG3UREREREkSLQuNjaoDvTbMWzP23F5/8cUM9b16qA16/riKbVC1csjcqPiAm6wz1Oty7G+Z/JYGbQTUREREQUKYIZF3vz4VTc/+V67DnhDNDvurAxJg1sjmhj0YqlUfmgR4SQMbqTk5OxevXqsCxfH1NB3Zusvq+EERERERFR2eMaF1vr7osaq+lSLO2dJbsxfOYKFXDXqBCNz26/AJOHtmLATeWvpTvcjLFJ6j7KxqCbiIiIiCiS+BoX+2hqFh78aiNW7j6l5hnUpgaeH9EeleKjSnp1qYxh0B3shopztnRHM+gmIiIiIoo42nGxf9l0FI/N3YTULAtiTQY8Naw1Rnerx2JpVCgMuoMUFV9R3cc6Mgu3pYmIiIiIqFTLyLFiyg/JmLPmoHrerk4SXru2IxpXSyjpVaMyjEF3kGISnEF3nATdDgfAIQGIiIiIiCLGxoNnMXHOBpViLqf64y5qggcuaY4oY8SUwaISwqA7SDEJzlQTI2yAJQuIigvn90JERERERMUwRvfulHRsOHgWX64+CKvdgVpJMZg2qiN6NqnC7U8hwaA7SAmJFWB36KDXOeDISYOOQTcRERERUZn1/C9b8faSPW7TLmtXC88Nb4ekOFOJrRdFHuZKBCk+JgrpiFGPc9JTw/mdEBERERFRmFu4PQNuYTKAATeFHIPuIMWZDEhHrHqcmX4m9N8EERFRGbd06VIMGzYMtWvXVhV+58+fX9KrRETkJT3Hiud+3upzy8zfcFQF5EShxKA72A2l1yETzn7c2elnQ/olEBERRYKMjAx06NABb775ZkmvChGRT+sOnMHQ15Zh9T7/gbUUUiMKJfbpLoAsfRzgAMwZTC8nIiLyNGTIEHUjIiptbHYHZvy5C6/9vlM9rpYQhUpxUdiRku41b6Oq8SH5TGkxlwBeluca/5vKp4gJumfMmKFuNpstbJ+Ro4+HKl6eyaCbiIhKr4MHD2Lfvn3IzMxEtWrV0KZNG0RHR6O0ycnJUTeXtLS0El0fIooMc1YfUMN/dahXEaO71cfB05mY9NWG3NbtptXjsSslAyfSzV7vvfuixiEJkD2LtI27qDEeG9KqyMulsiligu7x48ermxywk5KSwvIZOUZn0G3LZD8PIiIqXfbv34+3334bX3zxhQq6HQ5H7mtRUVHo27cv7rzzTowcORJ6fenoXTZ16lQ888wzJb0aRBRBrpqxHBsOOhvIPl91EDP/3IXTGRacy7EiIdqIsX0aqdZuTxMGNEW/FtVDEnD7KtImzwe1qckW73KqdBx1y4gsY0Xng8xTJb0qREREuSZMmIB27dph586dmDJlCrZs2YLU1FSYzWYcO3YMP//8M/r06YMnnngC7du3x+rVq0vF1ps8ebJaT9dNLhYQERWlhdsVcLvsP52lAu4uDSrhlwl90aCKs0aTpwZVQpcC7q9POPuKl18R09JdHHKiKgPyfyjzdEmvChERkVtL9u7du1Uquafq1avj4osvVrennnpKBeDSKt6tW7cS34KS8l4a096JqGySlHJf2tWpgDl39oDRoMfJ9LwuLVrLdp7AiM51Q7Ie/vqEh6qvOJU9bOkuAFtcFXVvyGJLNxERlR4vvfSSz4Dbl6FDh+Lqq68O+zoREYWSpGzPXXco4HBebev47mJ6Q48GKuAW0po9vFNtr3nmrT8SsqHC5DOkD3c4+opT2cSW7gLQxVVV96YctnQTERF5Sk9Px65du3Kf7927Fxs2bEDlypVRv359bjAiCltRsgOnMvH12kNe7+1UL0kVU9Pq26yaCrJ9pX+HKjCW9ZM+3KxeToJBdwEYE52tCNFmFlIjIqLS6dSpU3jyySfx559/IiUlBXa73e3106fDd+F4zZo16N+/f+7zSZMmqfubb74Zs2fPDtvnElHkyq8omRSNnLvuMJ76fgvSc6xIjDHi8va1oANQKT4KTaolqGVog+niSv+Wz2TrNgkG3QUQnVRd3cdbffcXISIiKmk33HCD6t89duxY1KhRAzqdnHoWj379+rlVTSciKip/xccWb09B8pE0/LL5KJbvcnb97N6wMqaN7oC6leJU6/iMP3f7bB13pX9rg3mmf1M4MegugNiKNdR9gj0NsNsAvSFc3wsREVGhLF++XN06dOjALUhEZZ6/1ufXfs/ryiKXFh8c2Bx392sKg14X1JBdTP+m4sRCagWQWNnZ0q2HA8hiazcREZU+LVu2RFZWVkmvBhFR2IqSeZL8mt5Nq6qAuyBDdsmypWI5U8Ap3Bh0F0DlxHicdTivtjkyToTrOyEiIiq0mTNn4vHHH8eSJUtU/+60tDS3GxFRWSOt0vPu6YXJQ1qiRoXofANqDtlFpQ2D7gKoHB+FFEdF9Tjr1MFwfSdERESFVrFiRaSmpqpxuWWM7kqVKqmbTJd7IqKyRmpF7Dyejtd+34njab7H2dYG2hyyi0ob9ukugBiTAUd0NdAch5GVsgdx7iMVEBERlbgxY8YgKioKn3/+ebEXUiMiCrWzmWb8Z94m/LzpmHreo3FlNK2WgE//ORCwCBr7bFNpwqC7gE6ZagJWwHxyb3i+ESIioiLYvHkz1q9fjxYtWnA7ElGZtnL3SUyasxHH0rJh1Ovw4MAWuPPCxqrv9sgudfMdA5tDdlFpUSrTy3/88Ud1stCsWTO8//77KE0y4+qqe9spBt1ERFT6dO3aFQcPsgsUEZVdZqsdz/+yDWPe/0cF3I2rxmPePb1xd78mucXSWASNypJS19JttVoxadIk/Pnnn6hQoQI6d+6MESNGoHLlyigN7BXrA2mAMS0vpYWIiKi0uO+++zBhwgQ8/PDDaNeuHUwmk9vr7du3L7F1IyISMqSXq5VaaFusd59Ix4Qv12PzYWfhx+u618MTl7dGXJTR7X2sOE5lSakLuletWoU2bdqgTp066vnQoUOxYMECXHfddSgNoqo0Ag4ACVmHS3pViIiIvIwePVrd33bbbbnTpF+3FCKSe5vNxq1GRCXm+V+2eo2h7XJh86pYvfcMsiw2VIwz4fkR7VW18l83H8OynScwb/2R3HllGDHpt01ULtPLly5dimHDhqF27drq4D5//nyfw5k0atQIMTEx6NKlC5YtW5b72pEjR3IDblG3bl0cPlx6Atz42s1hdeiRYEsFzuwv6dUhIiJys3fvXq/bnj17cu+JiIqDtErPXXdI3Wun+Qu4xdIdJ1XA3btpFSyYeCE2HDyD4TNXYtJXG90CbiHL0S6bqFwF3RkZGejQoQPefPNNn6/PmTMHEydOVGOISqGXvn37YsiQIThwwJmuLVfiPZWmyqu1q1XFv47Gzif78i4WEBERlTSLxYL+/furY3GDBg183oiIiqM12xUsy7089xxL258rOtTCJ7ddgCNnswIG6MEujygig24JoJ999lnVD9uXadOmYezYsbj99tvRqlUrTJ8+HfXq1cNbb72lXpdWbm3L9qFDh1CrVi2/n5eTk4O0tDS3Wzg1qBKPlfY26rF51+KwfhYREVFBSP9tOS6WpovVRFS++GrNdrVKa8fS9kcKpen1uqAC6mCWR1TuqpebzWasXbsWAwcOdJsuz1euXKked+/eXQ13IoH3uXPn8PPPP2PQoEF+lzl16lQkJSXl3iSAD6dqidHYntBdPdZv/wnITg3r5xERERW0kNoLL7ygCpMSERU3f8GyTJfiZ9IXOxBJIw8mQPc1NjdRaVWshdROnjypCrjUqFHDbbo8P3bMOeC90WjEK6+8otLj7HY7HnnkEVSpUsXvMidPnqyqnbtIS3e4A++EZhdi+8a6aGE9BKz/DOh5T1g/j4iIKFj//PMPfv/9dyxcuFBVL4+Pdz9xnTt3LjcmEYWNv2BZpks30joVYxFl0MNssyPWpEeWxe417+LtKSq7dHin2m59uUd0qo0+zaqxejmVOSVSvdwz7c1VUdXliiuuULdgREdHq1tx6t2sKj5aNwjP6T+AY9U70F1wF6A3FOs6EBER+VKxYkWMHDmSG4eISoSrNVubYi6t0vUqx+H2j9bg920patqFzavhll4NcNvsNV7LeO33XbmPJfDuy0CbyrhiDbqrVq0Kg8GQ26rtkpKS4tX6XZpd0qoG/hfVD6n2L5B0Zh+w9XugzfCSXi0iIiJ8+OGH3ApEVOy0Y2jLUF6D2tTMfZ6aZcHg6ctwMj0HRr0Ol7evhRt7NkCXBpW9WrM9yWs39WzIVHIq04q1T3dUVJQaImzRokVu0+V5r169irTsGTNmoHXr1ujWrRvCLcZkQP/2jTDb5uxr7vhhAnBie9g/l4iIKFgnTpzA8uXLsWLFCvWYiChUQ395emDOeq9q5dLiPbRdLXywfC9u+XC1CrgrxZlgtTswf8MRjHzrLzWftGLnh1XKqawLeUt3eno6du3KSwmRcUE3bNiAypUro379+qr/9Y033oiuXbuiZ8+eePfdd9VwYePGjSvS544fP17dpE+3FFQLt9v7NMIVa65Cb/sWdM3eAXx9K3DHH4ApJuyfTURE5I8MFybF1D7++GNVG0VIltlNN92EN954A3Fxcdx4RBQUCYq1aeKSNi6t2J4Bt68xtFvWTMSUH5NxOsOSO/1MpsVrvhdGtst3PVilnMq6kLd0r1mzBp06dVI3IUG2PH7yySfV89GjR6thwqZMmYKOHTti6dKlqkJ5WRs7tHG1BNzYtyXGmR/AKUcFIGUL8PuUkl4tIiIq5+S4u2TJEvzwww84e/asun333Xdq2oMPPljSq0dEETD0l3Yef6nhD379r1vA7Y/JoA9Y0ZxVyikShLylu1+/fqowWiD33HOPuoWSpJfLTaqjF5cJA5qpnc1D++7Ch1EvAX/PAJoOcN6IiIhKwLfffotvvvlGHY9dhg4ditjYWIwaNQpvvfUWvxciKvLQX4HmETZ74HjAZdnOE3h1dCe3PuCuZctjDgtGkaBY+3SHk6SWJycnY/Xq1cX2mdK3+50bu2J3xd742HqpmuaYfw+QcarY1oGIiEgrMzPTZ3HS6tWrq9eIiIo69Fd+8+h1wB19GwX1Oa5xuSW4HtG5rrrXPiaKBBETdJeUpFgTZo7pjJdxA3ba60CXfgz44lrAai7pVSMionJI6qU89dRTyM7Ozp2WlZWFZ555Rr1GRFSQob8CpXrL49v7NHSbJynGiF8nXojHL2vt9f6LW/oumsZCaRTpSmSc7kjTtk4SJl/RGffNuw9fRv0XFQ+tAt67GLj9NxZWIyKiYvXaa69h8ODBqFu3Ljp06ACdTqcKmsbExGDBggX8NogoaJ5Df3m2PCcfScOSHSdznw/rUAsvXd1BZYP6er/4Y5v3aAoslEaRTufIrwN2GaHt071jxw6kpqaiQoUKxfb5shkf/GojMjbOwztR050Th70OdLm52NaBiIjKHteoG6E8bknL9qeffopt27ap45MMqTlmzBjVr7u8bQsiCv043B3qVsSsFXvx4q/bYbbZUS0xGq9c0wEXNq9W4Iro0nr+qEdFdKKyItjjVsQE3aXhgJ1tseHOT9Zi2J7/4hrjUtiik2AYtxSo5J52Q0RE5MJAMw+3BVHpC7ClddszUK6eGI2Ucznq8SWtaqhhv6okRBd6+USRftxienkISSrN69d2xKiZ96Np2hF0ytkFx5yboJM0c2NUKD+KiIjIL8n4Wrx4MVJSUnLH6nZxDeFJROSLZ4A9vFNtr2HBXAG3aFItrkABt3AVSyMqL9jSHQa7UtJxxxvz8a3+UVTWpQOX/hfofX84PoqIiMq4ULfuvvfee7j77rtRtWpV1KxZU/XpdpHH69atQ2nFlm6ikiUt0MNnrizw++bd04tBNJVLaUEewyOmern055Y+a926dSvpVUHT6gl4dPQATLWOUc8ti18ELHlVZImIiMLl2Wefxf/+9z8cO3ZMFVBbv3597q00B9xEVPIKW0Wc1ceJAouYoLskxukOZHDbWqh54a046qgMk+UcrH+/XdKrRERE5cCZM2dwzTXXlPRqEFEZVNgq4qw+TlROgu7S6L4BLfCpcbh6bFn6KmDN6/9CREQUDhJwL1y4kBuXiEIyNnd+PMfuzi99fe66Q+qeqDxhIbUwijLqUf/Se3Hkl3mobTmNzDWfI67HreH8SCIiKueaNm2KJ554An///TfatWsHk8nk9vr997PGCFF546tauL8K4jIcWEK0Eek5VpgMOlhsgQc6GtimZqEKtElwL+N4E5UHLKQWZna7A7NenIjbs2cj3VQZCY/tAAzuJ0BERFR+hbp4WKNGjfy+JoXU9uzJO+ktbVhIjSj0fAW7wnPafRc3w5QfkjFnzUE1rX3dJAxtVwvP/7It4PKnjeqAEZ3rFqpAGwuwUVnHIcNKCb1ehwaXPYQT38xDNctp5CT/hOh2V5X0ahERUYTau3dvSa8CEZUSEuxqg2vh+dw17bsNR3A0NRsy4MHdFzXBxEuaY8uR1JD05/ZXaE2mc+gwKg8ipk93aape7mlAm7pYZLpYPT69bFZJrw4RERERlQMFqSouAXetpBh8cUcPPDK4peomWZg+3gUJzFmAjcqLiAm6S1v1cs/WbnvHG9TjWilL4Ni3vKRXiYiIIsjzzz+PzMzMoOb9559/8NNPP4V9nYio5BUkqG1SLR6/TrgQPRpXcZsu/a4lDfz67vUKHdj7Ct4LUoCNqKyLmKC7tBt0UV/8bO+hHh9Y8nFJrw4REUUQuehcv3593H333fjll19w4sSJ3NesViv+/fdfzJw5E7169cK1114bkr7jRFR6+KsK7ivYvbhlNXRr6B3s7j6RgZs//Mfn8mU513StV6TA3hW8Sx9wuX+URdSoHGH18mJSLTEa6c2uAnb/jejDvndoREREhfHxxx+rwFq6Wo0ZM0YVZTMYDIiOjs5tAe/UqRPuvPNO3HzzzWo6EUWG/KqCy+NBbWrijT924o9tJ9TNnw0HUzFn9QGM7lbf6zVXAK/9rIK2Vsu8bN2m8ohBdzGq2+FiYDdQ07wPyDwNxFUuzo8nIqII1r59e7zzzjt4++23VQC+b98+ZGVloWrVqujYsaO6J6LyUShNgmzP4DZQsK218eBZn0G3NoD3NdQYEfnHoLsYtW/RBLvttdBEfxSnd/6Fyh0uK86PJyKickCGBevQoYO6EVFkC6YquM3uwDs+Kpb706FexYCvs7WaqBz36S7N1ctdEqKNOBLt7FeTsuffkl4dIiIiIirDrdz7T2UE7Gd98HQmrn33L/y65VhQy+xUL8lvKzcRFZ4xkqqXy801QHlplZnUFDi5AjjKoJuIiIiIgguwF29PUY/7taiOBVuO+RxvW9vP+rsNh/F/8zbjXI4VsSYDsiy2gJ9xUfOq+Oi2C/h1EIVBxATdZYW5Tg/g5EeoI4G33QboDSW9SkRERERURgqlvfb7Lp/zXdKyGtrUSUK3hpVx86xVWLLD2Ye7S4NKGNymBv7387aAn7Nkx0kV3LOfNlHoMeguZk26DUbGhmgk2lORczQZ0XXaFfcqEBEREVEZLZTmz2/bTqibpy4NKqJrw+CK92r7ghNR6ERMn+6yolWdStiqb6YeH9q0rKRXh4iIiIjKWKG0gnh36V517zled1HG3CaigmFLdwlUlT1dqQNwejOM274DBt0tE4t7NYiIKIKMGDEi6Hnnzp0b1nUhotAJVRAswbvncF+e/cILOuY2EQWPQXcJMDbsAZz+DA3O/g3z0lcRddGkklgNIiKKENoCog6HA/PmzVPTunbtqqatXbsWZ8+eLVBwTkSlQ/8W1fDndve08WqJUThxzlzg4F073Jfcc8xtouLBoLsENOt5BbDuPvX4yJof0ZBBNxERFcGHH36Y+/jRRx/FqFGj8Pbbb8NgcBbrtNlsuOeee1ChQgVuZ6IyWkBNSwLuepVicfBMVr7LubhlNZ99xV0t3iM61w3J+hKRfwy6S0C9ahXxtO4ePO2YCXt2WkmsAhERRahZs2Zh+fLluQG3kMeTJk1Cr1698NJLL4X182fOnKk+4+jRo2jTpg2mT5+Ovn37hvUzicpjATVXwN26ViJu690INocDJoM+t1X7jT924o9tJ3Jv0qdbUsw9g3nXdCIKn4gppDZjxgy0bt0a3bp1Q1kw4rKh6r6y5XhJrwoREUUQq9WKrVu3ek2XaXa7PayfPWfOHEycOBGPP/441q9fr4LtIUOG4MCBA2H9XKLyXEAt+eg5NKmegNHd6qtWa1f6uATaWhJoz1l9wCuYl+cS5BNR+ERM0D1+/HgkJydj9erVKAtqNWgJu0OHikjDuRM8GSEiotC49dZbcdttt+Hll19WLd5yk8e33367ei2cpk2bhrFjx6rPatWqlWrlrlevHt56662wfi5ReS+gtnh7SlBB+8aDZ8NWJZ2I/GN6eQmpVq0adhgao7l9N/as/hUdht5ZUqtCREQRRALsmjVr4tVXX1Up3qJWrVp45JFH8OCDD4btc81msyrY9thjj7lNHzhwIFauXOnzPTk5OermkpbGLlcUubT9qPOrEi6vS9p3sGN0Bxu0d6hXEZ+vOhj0/EQUGhHT0l0WnazaXd2bdy4u6VUhIqIIodfrVYB9+PBhVbFcbvJYpmn7eYfayZMnVcG2GjVquE2X58eOHfP5nqlTp6oq666btIoTRSLpRz185kpM+mqjupfn+Rl3URO0qxNc8cN+Lar7DNq1ZEgwSUH3NZ1DhRGFF1u6S1BCqwFAyhdodGYFHDYrdAZ+HUREFJp+3YsXL8bu3btx/fXXq2lHjhxR1csTEhLCuol1Op3bcxnCzHOay+TJk1WBN21LNwNvKg9F0eS5DNflL9hdufskJs3ZiGNp2dDrALsj77WO9ZKw4WBqvkGz57jcrnn8TSei8GGUV4Ka97wcqYvjUVV3Fvs3LUODjv1LcnWIiCgC7N+/H4MHD1bFyyR1+9JLL0ViYiJefPFFZGdnq6HEwqFq1aqqJd2zVTslJcWr9dslOjpa3Ygimb/+0jLdM+A1W+2YtmgH3lm6Gw4H0LhqPF67thOsdrtbkBxsqrp2XO5gphNReDC9vATFxMRie3wX9fjEhp9LclWIiChCTJgwAV27dsWZM2cQGxubO3348OH4/fffw/a5UVFR6NKlCxYtWuQ2XZ7LUGVE5ZXF5nvUAM9+1LtPpGPEWyvw9hJnwH1d93r48f4+aFc3SQXI2srkns+JqHRjS3cJszToB2xdigqHl5X0qhARUQSQauUrVqxQQbBWgwYNVN/ucJJU8RtvvFEF/T179sS7776rWtzHjRsX1s8lKg18tT57jontKyVcumB8ufogpvyQjCyLDQnRRlzdpS6u7FgbcVE8VSeKBPyfXMLqd78c2DoFTczbkHb2JCpUrFrSq0RERGWYjMUtBc08HTp0SKWZh9Po0aNx6tQpTJkyRVVOb9u2LX7++WcV8BNFMs/gWoqVSb9pXwH3CyPbqYJm4nSGGY99+y8WJh9Xz+tUjMXhs1mYvXKfug3vVBt9m1VzC+QLUgWdiEoHBt0lrF6jFtivq4sGOISdf/+ELoNvLulVIiKiMkz6cMv42NLKLKSIWXp6Op566ikMHTo07J9/zz33qBtReS+UFm303YvTZHBOX7bzBO7/Yj3OZFpg1OtwQ4/6mL1yv9u889YfUTfhqjruGdxLYTQiKt3Yp7sUOF7N2dctZ/tvJb0qRERUxk2bNg1LlixB69atVeE0qV7esGFDlVr+wgsvlPTqEZWbQmn+1K0Ui2d/TMaNH6xSAbew2h04cDoz4Psk2PYV3EvQT0SlG1u6S4HENgOBlK/Q4MxfsFhtMBnDN44qERFFtjp16mDDhg348ssvsXbtWpVuPnbsWIwZM8atsBoRhYZnQTTt2Nk5VrtboDy6a1089X0yth5N85r/j20nCvX5vqqgE1HpEjEt3TNmzFBX9bt164aypmn3QTDDiDo4gflzPy/p1SEiojLKYrGgcePG2Lt3L2699Va8+eabmDlzJm6//XYG3ERhIgGvK/XbZUSn2j4D4a/XHlIBd3y07waW/i2qhSzoJ6LSI2KC7vHjxyM5ORmrV69GWWOKrYDDjUepx7WS34Pd7ijpVSIiojLIZDKpsbmlHzcRFR/pVy1Fz1zmrj+CB+as90oHl1O86onReOO6Tj6Xc/+AZph3Ty9MG9XBbXmuiueewb22CjoRlV5MLy8l6g6aCLz1OfpgI+av2oarehR/UYwssw3P/pSMwW1rqkqZRERU9tx3332q7/b7778Po5GHeaKiCLZSuMznKnjm4vncJeVcDirFRakAWhuUawNo1zjcN/Vs6PX5UhWd1cuJyhYejUsJU/XmsEEPA+xo9Mc9QI8/i30d3l26B5/9c0Dd9j1/WbF/PhERFd0///yD33//HQsXLkS7du0QH++eejp37lxuZqJCDgPmr1J4QYupyfyyrPwCaJnmOd3XNCIq3Rh0lxY6HbLi6yIh4wCSzM6xGovboTOBq2YSEVHpV7FiRYwcObKkV4MoIocBkyDZV8Bb0H7VrvkZQBOVDwy6SxHHDd8C73RDLUcKdh09g6a1ivcqJrsAEhGVfR9++GFJrwJRmeev5dqzUrg2/fyqjrUwf8PR3NdiTQbMHNMZ32887JZqzn7YROUPg+5SJLFGE5zTJyHRnoq/v3sbTcdNLtbPP5qaXayfR0RE4ZOSkoLt27eromrNmzdH9erVubmpXAu2f3aglmvtdM/0c60aFaLx0/19UTUhGv1bVs/tm22x2WEy6NW6MEWcqPyImOrlEUFvwKlWY9TDhMNLcfena/3Ouu9kBtKyLSH76NQsCzbu3IePTVMxXL8sZMslIqLilZaWhhtvvFGN133RRRfhwgsvVI9vuOEGpKam8uugckkC5OEzV2LSVxvVvTwv6DBg2hZqX+nnWsfTcnDwdF63PXnfsp0n8Oi3m4JeByKKHAy6S5kGnQep+/76Ddi05V+czTR7zbP7RDr6vbwYQ18LXXC8/2Q6/o25ExcaNuHVqLdCtlwiIipeMia3FFP78ccfcfbsWRVoy+M1a9bgjjvu4NdB5Y6//tkyPRApdOYavkvuH9UUUQumcJp2Hhk+zLOaeTDrQESRgUF3KaNr2Ae2qi2RpMvEK6a3MWv5XmRbbMg0W3Pn+XNbCi7Sb4Th7N6Qfa7pzM6QLYuIiErOTz/9hFmzZmHQoEGoUKECEhMT1eP33ntPvUZU3gTqn50f19BdhUkF338qQwXVvoYTK8g6EFHZxz7dpY3BCMO1nwFvdsEF+m2454+1eP2PXagcH4U/HrwIFeOiUPfcv/go6gU1+yd/X4LRXeshyui8fnLgVCY++2c/9pzMwKujOyIhOrivWGfNCuufRURExaNKlSpISkrymi7TKlXiMENU/gTTPzvY/t92uwP//SkZH/+1P9/Pfe33XerWv0W1Aq8bEUUWtnSXRlWbwqEzqIefRD2PaJhhzjiLuz9dpw4AFc78mzvrE/M3o//Li/Hjv0fgcDhw4Ut/4p2le7Ao+TjeWrwr6I+02+1h+VOIiKh4/d///R8mTZqEo0fzqigfO3YMDz/8MJ544gl+HVTu5Nc/O9j+38fTstV51ocr9sFmd6hpQ9vWwPXd6wX8/D+3n/A5fUSn2iymRlROsKW7FKeZY+8StNbvx/aYW3DakYCL97yC/i+fwh2xqeh1fr44ZOPwWeDez9fjxLAc9TweWTDDhG/XHsa6/Wdx50WN0bRaAnalpKNfi2qqkq0nm9VW7H8jERGF3ltvvYVdu3ahQYMGqF+/vpp24MABREdH48SJE3jnnXdy5123bh2/AioXpH+2jLGdX/Vyf/2/JdNwxp+7cC47r7uf+Hnzcbwwsh0+X3Uw4Odf3LIa/th2wi3gnja6U5H+JiIqOxh0l1ZXvAG81j73aWVdOjbE3IU7zJNgMZsBk3N6csxtGJTzPLY76uOZH5KxLOpR1NM7d+qXnnsRf6XVxV97TsEIK6oiFZOvHYArO9bx+jirzT3ollZzX8E5ERGVbldddVVJrwJRqSSBdn59s/31sX7+l21+3yNDgElLeqBq5vdd3Ezdgh2yjIgiS6kMuocPH47FixdjwIAB+Oabb1AuVWoA3LYQmDXQbfJ7UdOw1e5suXBZEP0YJpnH4Wf7BbkBt3jEOAdzbP3wl701HjV+iZuMi/DfFa/gyo63Y/W+01i24wTuG9BMHSyslhy3ZVpsDkQZGXQTEZU1Tz31VFDzffHFF8jIyEB8PPuUEgXTx/qqjrUxf8MRn++RYmtyL0OCeerSoGLQQT8RRaZS2af7/vvvx8cff1zSq1Hy6l8A3LUUiK7gNrmV/oDXrNOi3saG6Dvdpl1qWIv3o17BlpixKuAWXY7NwebDqbjm7b9UgbZv1h5S021mz6CbfbyJiCLZXXfdhePHj5f0ahAVmqSCz113KKTDbklQfNeFjdymxUcZ8NntF2D6tZ28+oaLBVuOqXtpxPBl7f6zHJebqJwrlUF3//791RAnBKBWB2DyQeC+/Pvdxegs+c6TgCxc/sZydNDtwt2G73HoVJqabrNku81nsbr3WSIiosgi3YiIyip/xc6K6lhqNjYddp4biQsaVcbyRy9G76ZV1XPpF+7JNd52fpXIOS43UflV4KB76dKlGDZsGGrXrq36/M6fP99rnpkzZ6JRo0aIiYlBly5dsGzZslCtb/lVpQnw8G7AGOt83qAP0OlGwBhToMVcaNiEerrj+C76STxq+hLdzvyqpm8/fNJtPnMOhxAjIiKi0sdfsbOitnj/uvkoBk1fipW7TyHWZFAF0r68swcqxUcFNea3ryrpvuYjovKnwH26pf9Xhw4dcOutt2LkyJFer8+ZMwcTJ05UgXfv3r1VldQhQ4YgOTk5t4qqBOI5Oe7pzGLhwoUqmCc/4qsCYxcAB/52BtxRccCVbwKph4DdfwIH/wb2LAF63Q/89QaQdRa49Wdg1mDAnJ67mJGGvIsgiem7sSvlHDbuSwHyjimweqSbExEREZUG+QW+gcbZ9iUjx4opPyRjzhpnBfL2dZMwfXRHNK6WUOAxv11V0hdvT1FjdAf7fiKKbAUOuiWAlps/06ZNw9ixY3H77ber59OnT8eCBQvUECZTp05V09auXYtQkeBdG8CnpeWlBEVsurnctJLqAp1vdN5c2o4E7FYgsQbw2EFnQL7pG2DNB5honJs7W6rVhJHTluImg/sBLHrrN0DNe8P+5xAREREVRH6Br6Saa1vCpfVZgmFfNh48i4lzNqgAXQZtufuiJph4SXNEGX0ng7pas7XL9xzz21UwLcdqDzgfEZUfIa1ebjabVUD92GOPuU0fOHAgVq5ciXCQQP6ZZ54Jy7LLtPgqeY/1eqBBL6BSQ+DQKuBYXmXNYxnOgmlTTB+5vb3KkseB/gy6iYiIqHQJFPj6Sz2PNurRr0X13KDXZnfg7SW78eqiHbDaHaiVFINXR3dEj8aa8ycNbct5sGN+BzsfEUW+kAbdJ0+ehM1mQ40aNdymy/Njx5yVHYMxaNAgrFu3TqWy161bF/PmzUO3bt18zjt58mRMmjTJraW7Xr16RfgrIliF2sDl04H3B+ROSk09i2sMi33OPuLNJZhzd1+/1TiJiKjsatCgAUwmU0mvBlGh+Ato/aWeS6q33C5uWQ3XdauP95fvxT97T6vXLmtXC88Nb4ekON//H/y1nAcTRHOYMCIK2zjdUmDNs0Kq57RAJB09WNHR0epGQarbFRjxHjD3DvW0ni4Fdxt/8Dnr3kNHsP7AWXRvVJmbl4iojLjllltw22234cILLww43+bNm4ttnYjCwVdAm1+f6T+2nVA311Bgz1zZFiM71/F7nuqv5VwCfrZcE1GwQtqEWbVqVRgMBq9W7ZSUFK/W71CbMWMGWrdu7bdFnDTaj4Lt0v+ph410/jMQFkY/im9W7+WmIyIqQ86dO6e6dTVr1gzPPfccDh8+XNKrRFRsgqkg7vLSNe1xdZe6ARuGAhVtIyIqkaA7KipKVSZftGiR23R53qtXL4TT+PHjVYX01atXh/VzIoWhgnOcyTb6/X7nqaZLxfENwWcdEBFRyfv2229VoH3vvffi66+/RsOGDVUB1G+++QYWi6WkV48o7CT1e949vTBhQNOA820/dg5z1x0KONRYfkXbiIjCEnSnp6djw4YN6ib27t2rHh84cEA9l/7V77//PmbNmoWtW7figQceUK+NGzeuoB9F4VSnc1CzfRT1Ar8HIqIypkqVKpgwYQLWr1+PVatWoWnTprjxxhvVsJxyXN65c2dJryJRWEgALYG0uH9Ac3Rr6L/ftfTxnvTVRgyfuVL12/Zchtz7ajlnFXIiCnuf7jVr1qB///65z11FzG6++WbMnj0bo0ePxqlTpzBlyhQcPXoUbdu2xc8//6wKtlApUqlR0LNabXYYWUyNiKjMkePwwoUL1U26fw0dOhRbtmxR3bFefPFFFYATlXWuyuLLdp7AvPVHcqfXrBCDY2nZ6nGlOBPOZPrP9HD1016w5ZjPommsQk5ERaFzSJWzCCB9uuUm1dN37NiB1NRUVKhQoaRXq3Rb8Tqw6Il8Z0t95ASS4qKKZZWIiMobGXUjKSkpZMctSSH//vvv8eGHH6pgu3379rj99tsxZswYJCYmqnm+/PJL3H333Thzxn9abSRsC4p8npXFPcWaDJg6oh3sDodq1Q5E0tGl9duTpKqzaBoRFeW4FZbq5SVB+nTLzfWHUxB63RdU0J2ZeQ5JcXnjVlpsdg4jRkRUStWqVQt2ux3XXXedSi3v2LGjz6E5K1asWCLrRxSqlm05HwkUcIvR3eriqk51Avbbzo98FoNuIioKDsBcnkm1zqvecp/W816cTmjuNik7PS338b6TGWjz5AL898fk4lpLIiIqgFdffRVHjhxR2V++Am5RqVIlVZOFqCy2bEsfbGm1fvTbTfnOP3vlfvWe/KqaSz/tfi2q+3yNRdOIqKgipqVbm15OBdDxeqD9tcCGz4DaHYGa7VCxZntg3p25s2Rl5AXdr/++E2abHR8s34snLm/NTU1EVMpIwTSiSORrzOxguPpre/bNFq7HrpZsCcy1n8GiaUQUChETdDO9vAj0eqBz3kmavv0oIKkucmZfhWiYYc5IzX3NYncgHlnIQEzRvjAiIiKiAghmbOyO9ZKw4WCqz/dKYO26uXimjbNoGhGFQ8QE3RTitPOGvXHKUBW1bUew6qcPcSjTgMv79UaNzJ3YEnMH5tr6ALg85Jv97K5VSN/zD+peeq9zPYiIiIgCpHnHmPS4pktdjOhcVz2X9POipIh7BuZEREXFoJv8ytbFqvs7dXOBxXOBfqm45PSXatoIw/KwbLmKn14KKe2zO6oimvRjiiQRERE5SSB8a+8G+HDF/txNUispBl+P64m6leJypzFFnIhKGwbd5JdV7z1MmMFhLpYtlrJ7A4NuIiIiyvXPnlNYuCVFPdbrgOu618eUK9vCIE80mCJORKVNxATdLKQWenadyWua0V48QTcRERGRkKHBpv+2AzMX74bDATSoEofXru0Eh8OB7zYcdiuE5itF3DXEmK/5iIiKQ8QE3SykFnp2vXfQbXBYUBzYm5uIiIgkWJ745XpsPOQsjjaqa108OawN3vxjp1uVcUkplxZuTzJcWDDzERGFU8QE3RR6Nl/p5WzpJiIiojBxtUo3rBKHXSkZePqHLcg021AhxoipI9rjsva1fA4d5hoWTNuSHex8REThxqCb/LJ5pJfb7Q4YC9DSfehYCmJjY1ElKZFbmYiIiALybJV26dG4MqaN6ojaFWMDDh3mGhZM+zyY+YiIwo1BN/ll9fh5mC3moIPukydPoO7bzXDYUQV4xvsASkRERBSoVVrc2KM+nr7CvViav+G/PKcHOx8RUbjpEUGF1Fq3bo1u3bqV9KpEDJtHz2pzTlbQQffRZOeQYnV0pwr12Q726iYiIio3dh4/53O6tEh7VieXadI3W+vuixr7LKYWzHxEROEWMS3dLKQWenq7e4BtycmGKcigu8XKh4v02SykRkREVD7sPpGOt5fuKVCrdLDDgnH4MCIqDSIm6KbQ0zlsbs8t5mzUdBwP6r1R2Sf4lRAREZFfMuTXl6sPYsoPyciy2BBt1CPHag+6VVo7LFggwc5HRBQuDLrJL71H0H1k8QeoCUeBt5jdZofekE9PBhl4U8f2bSIiorLMc0xsf2Nkn84w47Fv/8XCZOfF/N5Nq6hiaUfOZnFMbSKKOAy6KeiW7vRtfwIG5+OTjgqoGuS2s9mt0Bu8hx/LZc4A3u4D1OvBb4OIiChCqo93rJeEDQed42trx8hetvME7v9iPc5kWmDU6/Do4JYY26cR9HodalSIYas0EUUcBt3kl95hdXveUHdM88NxD8gDsVktMJkCBN2b5wKn9zhvBWG3A/qIqQVIRFSm/e9//8NPP/2EDRs2ICoqCmfPni3pVaISrj6uDbiFvC4t2d9vPJo7zWp34FRGjgq4iYgiFSMWCrqlu74+r5+2AXl9roIJugPKLsSJWXoK8Epz4NfJBX8vERGFnNlsxjXXXIO7776bWzdCg+q56w6pe1/8jYntSRtwa4Nxf8slIooEERN0c8iw0KsQoHFaD7vqi3UuO/9q5lZbPq3i2Wne0/Lr3/33TCDjhPOeiIhK3DPPPIMHHngA7dq1K+lVoTCkjQ+fuRKTvtqo7uV5Yce+jjXpCxS05xfsExGVBfpIGjIsOTkZq1evLulViRj1kryj7tOOhNyWbqk4+sWqA77TvrVP/bV0n9oNzL8Habv+KsTalYE0NJsVsGSV9FoQERGFNG3cV8u0rzGx29ROdHter1IsZozp7PNzfAXtwQT7RERlAft0k18Gg8HHxChIZnmMzoLfox7E8vR3ADRxn8cjLd1qNftcvvXjETCm7kOFQN/Bsc1ApYZAdIL7e+2O0v/jfbs3cGoX8Oh+r/UnIiIgJydH3VzS0nxkPlGJ8tcCLdM9h+HSjol9JtOMtxY7g3WDXoebezbA/13WWvXdluBcG8j7GhrMX7Avy+fwX0RU1kRMSzeFwWXTgDj3GuV6Xd5Ppon+KJpkbfZ6m11aeDUcNhvOZJgxf/1hZJnzAnIJuAPa/aczcJXK5loZp3BsW2Fax4vZiW3SzA/H4bUlvSZERIXy9NNPQ6fTBbytWbOm0Ft36tSpSEpKyr3Vq1eP31Qp4y9t3N/0VrUqYNPhVPz3x604mZ6D5jUS8ON9ffDksDa5xdIkOJ93Ty9MG9VB3T86pFWBgn0iorKm1DcWUgmq2RZ4eBdOT22NyuYjapIablvTkG33kT5ts1ncrubYrGbcMXs1Nh48i+svqI/nhuff308dljd/63xyZq/7i6+2QV1r2Unb3nkiA83dM+6ISobdDsehVdDVbA9ExfFboHzde++9uPbaawPO07Bhw0JvycmTJ2PSpEluLd0MvEsXV9p4fi3TYvuxc2oosO3Hz6nnt/RqiMeGtESMyTtzTt4fqMW6oME+EVFpxqCbAtPpEG3I6z8dY9QB2i7avoJuqw0mzXO7zaYCbvHd+sNBBd0q6vZXTK0sBNwOR+5DS/CjqxGF1dHfXketlU8hpVJnVJ/wJ7c25atq1arqFi7R0dHqRqWbNm1cgl7PYNnhcOCjlfvw3C/bYLbaUTUhCi9d3QH9W1YvlmCfiKi0Y9BN+Yoz6YDzca4uviqQlTd02Ipth3Fk1QFc271+7jSbR3q5tHznPtYEo4HpAE0qe5ljd98GRKVBzt8fqPvqZ9aV9KpQBDpw4ABOnz6t7m02mxqvWzRt2hQJCaxrUdZ5tkxLn2sJwivFmTB75X4s2eE8N+jfohpeuqYDqiZEhz3YJyIqKxh0U750tTsCaYfU4+whryHhk4G5r9XUnYb9+/uBWv8B6nVX0+yaIFtkbPwec6PmY7e9Nl5zBE5T1DqVaUWVMvr9SMV21yUD6fMY0TJOAnsWAy0vB0wxJb02FIC9LFT9pzLrySefxEcffZT7vFOnTur+zz//RL9+/UpwzSjUpIq4Z5GzaKMej1/WCjf2aBDS415+aehERGVBGW5KdMdxusPo8leBLrcAdy2Fvbp7sZNbjQtwvfFP4INL/RZSa7X5ZXTW78I1xqV4Wf9mUB9Z49xmbD+eHtS87yzZjdLGqh0mLdKD7tmXAd+OBf74b0mvSfl0Yjtw7niQM0f4b5FK1OzZs1WaseeNAXdk8VVVXNzTvwkSoo3YcL47mWtejrFNRBRBLd0yTrfcpAiLVEClEEqoDgx7TT00ZGbmO7ukFfrTUbczqI9seHoFTlS6LKh5p/6yDXde2LhUtSjbNEF3aVqvsFVpF8nfAYP+V9JrU76cPQjMcGaY4OnUfGe3l+UuG0RUIlxp5K707uW7Tvqc79VFecd313jd2uBcpkm6OBFReRQxQTcVD70+wE/GmgMYo1VqtT8mBN/XWeejSJs/dgegqfdW4qRiu4sOHv3Y7TZg9QdAw95AjTbFv3IUOY5uDPki/9l5FOu37sLYy3rDpIYrIKLy6oE56zFvvXP0EtGzSWWs3nsm3/f5agnnGNtEVJ7xjIoK9oMJdBKenQqc3gPj/iV+ZzHogi2kBs9QNSBbxhngm9uAnYtQGlgtmpZuh93ttYy/ZgG/PAy81cv7jVvmAW92B44no6yRNNKwkos6Moyc9CGPMMdSs1Xl34ycohfgk2JG0xZuh12uRHmwB7HLj/tkMMatuxwLFv1a5HUhosgJuMVfu0/DanegYZXCDTnIMbaJqLxiSzcViF4f4KRdCqi93gkVQ7RNvVqIA7AuegZREpDJLYg023DTVmxXLdsa29cvRWd/b/z6Fuf9vDuBcctRlpzLtqJCOD9g6UvOW5WmwH1rEUnGzfweHdOX4fmDY/Df0T0K8E7v/yM3z1ql7pvWSMQVHWp7vJp/Okg7/T51X3XPfABDEXaWbODoBqBuN7mqF/7PI6KgUso9A26Xq7vUxUtXt1d9tyWIttjsePTbTUFtVY6xTUTlFYNuKhBDoP7JtryU6lDQI7gBruvqTmD/7i0oTT3F7Na8FkuHR2E5aSUIKhApYzLMtrAG3Y4t850h46ldKG1OnMuBUa9DpfioQr1/ZvajqG06je+3ySgB80KyTkfOenfPcBRzIbXTGWYs23lCDfkTY/ITUH99M7DjV6D//wEXPYyScjQ1Cxk5NjStzqGtiAK1SI+5oL6qVaKtKi7ze46nLUc6jrFNROTEoJsKJFDMbbeag+uvkHUWiM2/PdwzLduf5dETsNHcEQUm/a53LgAa9AbiKiOUbJIKfZ7dUYiUYUPhgrdIdroEh5CTVO07P1mDupXi8PQV7v3ws8w2dPvfb+rxnueGQq8veGBbW3da3fd0rC/YG32k9FdGGmrpTkGHlt6zF6ioXxEC9P0rVXeTMb8mYOvRNNzTrwkeGey9PooE3OKft4sUdMuFj6oJUYUuXNhz6h/qfu3/XYIqIRhfmKgs+2HjYZ/TR3Sq7XP4Ln/jaXOMbSIiJ/bppgIJdEKbkRlk4TPptxzMZ2mDbldw4affsKEwge3SF4E5NwAfX4lQcxs2zaOae1CtjQZeD/N0LgT9nQvr38Op+G1rCmavdKZea6Wcy8tKyLHaJUIvli4VItvivU3WRN+Nn6IfR7VzySXX0v3hEOCLa5F61NnytTA5/yHN7Of/b6fnWJFtCS7LxWXhlmPqwsdjQaa4+nKb4RdMNn6Gfaf8t/ARRTq5wPjkd5vx53bv2hn9mlfFtNHOsdd9kUB7ROe6bkG5r2lEROURg24qtDX69m7PzZa81t2AYpIKnl7u6hft0T/axeDwXzHd34nFmX8+cz459i/COWSYw+4eGAUT9tj1JpQ1BWtFLcTyQ7W7SjsCfHUzsG9F0G+xWG14wfguJhi+9XpNr9Ohp34Luui2Q79yOvBiI+fY2cVg27FzPtbHGbzWPePs2x2WbRikGjpnlePqifm3HGearep25dOzMPy5Lwv0OdMW7VD3c9YcLOSaAk+aPsFdxp8Qc2proZdBVJoUdIxsKeh4wwf/4OO/9vt8/YqOdTjuNhFRIbE5jQrN3OlWYO0Duc+3rf4DvYN6p6PALd0yBJdBWn89AlgXk8Ps3Sc6IwWoWN/n/IvW78KgHN9FYvIlLXKeAWbO+eAnOlHd2TWF1Bye45YHEZymZNhQ09cLslwZti3Sx/72IWS10X+dDCTPd96CLLoXd3oLRhsXn382y+01ozkVX0SdH5/8/Cy2Xx6D4abQ9M0uyFaRCvKuX4bDx5jchWrpTk9x3mq2DW5+zYWxawxL0MpxABmJN+b7NqvNhkP7D+L36IfVn+VwXK8ya6Siu/QHNwRI2y9sSrkvegtbuqnse/6XrQUaI/vXzUdVMbTULAuijXpn1o4Hqc8w6au8YQo57jYRUfDY0k0F9oTlFnxu7Y9jNfu7Te+94/ngFhBkkTCdI+/kfeK7PzofBBt0v9MXmN4OOOY73bTC9q99Bws56YFXau5dwBtdAHNm3jRJJZ9a13k7H2y7FVLzs86BnMryEWJmngZebAJ8cytC6Y3fd2LW8r2Feq/01y0O2w6moLFd0/oiw8MdXuc+k3wPf80E9i4NvLBzxwr8+Xprtt+h0Qxm722w/5Tm91GQz0HhU9PlYtDzv2zLe+4jEC1INkLuvC83A97unW/rfUZWDr547wX8vfrv3GnXG//Ac6YP0MhwKqjPjE4/kPvYarPjZFomfvzvSMx85f8Cvk/WNBqFL+To/p2Geeg7ojCTlm3PcbLlua8Wb7mo9eg3/2Lcp+tUwN2+bhJ+mdBXBdSefbk9q5n7WyYREXlj0E0F9oltIP5jvQN6Y+GKfWVkeKfE+qLXtHS/ceoOIDsNDk3wEzDoPrkjcP9xTUAvTix5H3jvYmBqHWdwq6Xtn/3vl8Dp3cAuZ+EsJUcTdJ1/r12TXi7ByHcbDquCW4FaG3OseesUHR3jPcOmr4Gc1KD7xAfj0JlMzFz0L174cYPPcZ1zLX8VWPWe1+Rv3pyM4rDn3RvcJ8jQcO+5X/TBH/8FFkwGvr8vb5pcREk97OxnLYXzZPvHBte9wR/PzWTXe/8/kH7JxcEtWHTY8c7SvBNtnc/fWRFahA/+E/DlZXNexnWHn0OPX7yHGauZ4x4A+OvPrl1nszkH25bMURkG92W8GfC9bS2bsT3mFjxg/NpZqFH+L/81A8FyaL7UcA83T1RSlcc9p288eBaXv7FcdcuQa2xS8PCbcb3QuFqCahWfd08vTBvVQd33aVatQJ9FREQRGnTPmDEDrVu3Rrdu3Up6VcqNwlRpFlsPpsAcRKEkr+Jor7bxDrTOi4KfPt0SuB9c5dXi7VmwqtqfDzrHCpY4bacrjRjAj5OAl5oA5467nY3n7FqSWzArJyMvRfnhr9dh06FUt/Tyb9bsw4QvN2DKj87CVv4aG7XpfDqDd59uWzBDjRVQZkYGtkSPxaroe9wqrrs5sx/47Wng54e8+tQ/YfoUxWGoIXDAp+w5/72d0RQ7e7W18/ZaB+ClpoA5A8fNsUVaF5tHdwFXAbCCXOj4es1BNbatpyIlSXvWO3D90CxZISmkdvhs4AyVmin+x5WvlOO7ErKWzuM/hyUnG9GWvAta9hWv+33vuKy31f0E4zzg75nA4bXAgv/k+5m5y3Yr2liEbAOiUsDfWNiu6XIsmfHnLox8a6UKmmslxeCLO3qoEQaijHqfRdDyWyYREZWToHv8+PFITk7G6tWrS3pVyo2AY3YHsHjzAXy6XJMG64fRszhaThp0Z/PST7Wi/BVSSz8BfHAp8HafoJuwlu4+mxfgrvkAyD4LrHoXDk3wEr3ufexb/CGw9CVEz8gbrmzFjhQMe3M57Joxy02wopnuEOavlzGYhe/tZrPlrZ9d+m172OIvldtuhyPtKArDkLpPFd5K0mXC+HITNcyTlwxNFVs/mQYlMQa0J5/jn7v+ntQDziyBA39h97m8bWvOzicNXC6sHFrjNga9W2V6X33280lQnvTKezg3/yF8umSzj1cLFsDrPFq6r9RrA18dsOBx4H81gUNrnbMUoe/zYR/jfmsZ7f4LKUbbgxjZwOFw++stlmy3fun6RU94v2f9Z8DrndHYprnQsuQFFJRdU3He7zcgdRuOrGdTOJV6EiR7pofLuNnig+V7cMWby/HSgu1qn3lZu1r4dcKF6NG4SqGWyarkRETBYSE1KrSO9fMfa9uXh0xfY/3iDfk265kcQVZDV4GtJuiWVunzMk/uR5zribQ+n0+JDxR/H1y3AA+n1sO0Wy91m75572G00zw/se5HNEx3ju3rEqWzqLN2bZ/uqaYP1P0/9tZAVk/ff7bdBseJvAsRdp13S3fm+fR0T/tmDkfDk4tx7KqvULPjIBSEQ9M6qjOnAzsWAO1Huc+kLSwlreFRIWrZWPh/wIkdwHVfAHpD4ZfjcGDTZ5PR7nhegZ9A4uITgPNdjNPPpaJyTO4vxNvK14HfnkKT2Bq5k+weffS12zAYXxmfVPcL1scBF3+IUHE4bHgtambeBAlY/3KmZTt+nwLdzd+5Vy+XzIB/3gUuexmoULvI12gN9gB9qoMI9iX7xKrpYmEx5+T/vu/uQSjYtd+hv53Du/2BUzuBaz8HWl4Wks8lCpb0nfYcAzsQz3GzF2w5huEzV+a+bjLoMHVEe4zsXCfoQoT+xuImIqL8MeimAlv/xKU4m2VBnYqFT9PtpNuZ7zxe/bQDcEsvf6V57sMTaZlo4HpizcoNugO1KN5m/BXf75EWUvegO+WUe19vizHB673R59fD4dEaKi7QJ+PMO5fDYWzm/aE/PoDK6z7KfWrT+QpCfZ8YScAtji94pcBBt1dKso+A4/SpE6jsWi9zJgxxzmcHT2eiXsE+Le8zpOV45RvO5/tXAo36orD2bFiMdrve8n7hfB9uN5+OREzNYblPc3J8tMDa7dj+8b2Iqt8VjVa/piZFZeVdyLF7ppf7Cbp/3XwMD3+9Ed0aVcaTl7dGQ480zNrWg0Uep1vbp9tht7v9QrTn0UfTcuAVVrvGp5f6BtfP8V625++tKBfJgrgwIYu3a74zmzkHumJKxpJtl/fEz3cgAbf8v9/4FUwMuqkUVyJ3kaBYbit3nfQqrGaxOdCkWnyBK/+7lklEROU0vZyKT6X4qGLpx+WVXh6A4fzYxAFb3zR9lvPLNL/C8Jfb83WbN+NcqnuVVovJO+geYViGCkh3bx3WqHR2k+/GO03ArVbV5/Ww0KdvB9NKe/JEXup6dpYzHfvXTYfx+MvT3ear4zieWyzObzG22ZfDMXsoHC80zJ2ckR1cNXt/zqX7qTjv5ztodeyH3MfmLO95ti3+HC32fYZGSx9wDs+WT59uf9tw3KdrcS7Hij+2pWDgqz4qquv0sJmzkJ0emuq/Ns+0d01q9omM8xeDfO3yZdzyIH5t+XUfCJRe7lm40PfnOdzGtw+qpTs/QXYp0V44cWgryGecguWPqcDZvAskO46zcBSVzkrkvqw7cAb3fbHe52ssgkZEVHwYdFPYPGsZU6T3V7OfKPI6GG3ZfvojF6xFsfOZX3F6hXsqcN8T3q2Ddxl/wqyol1Ft/89F6vts9ZFenn/8UcBCa4fXot6fE9w/d/uC3AJxLtlpeS38Oef7QB9c8Do+jvLuO7tosXu6vRspxrZvGXT7V0JnyetLvedEcNXs/YmKq+D7Be2wbn5I0G1ZPRuO48m5AVpaSl7dAIePtHfPLAZfLd1x1lTMNE3H9YbfMT/qCUzWeaeRx1nPIv25psh8uYNb4PnX7lM4cS7YrhV537nNqzCbW7u3c25fPyI/qf2ev9P8fn9RATJTdEGl4Dtg11wYs8nQgoE+dNM3+S9Rii8ueyXf+dz66WsC9ROf3Q7T0ueR/vbA3GlZFhZao9JXidyT1CV5/feduObtv3Aqw/f/TRZBIyIqPgy6KWw+sA3JfbzFnpvkXayibBm+xwcvxLhAknaupYfvQKKrfgcMlqIFkr4C6PyC9bRMi8+K2H69dzFi0txbUIzJ3wIb3CuSZ51v3Rbbf3wdq394B3ekO6tFe6qWsgIFJV+FpKq7UqXNVrtqnTmST+Gu3HX2sxez5eTfIqlb/wlMP02A7q2ewOejneujCcAyLd7fg1chNR8BZTPrTgw1rFJjVHfU78atxgXA17e6VdFvYt6OJKSjMjTF6xwOPP3+Vxj0wk/5rvv5N+Stl8d6aNNGXb8dX78hmyPA78rt/0ngw0VUgPRyXRAt3fG6HDg0Vf9rLfuPs1+6LzLft2PzXaYu7TDw+5R85/NXgT7usPP3nJCtzQYo2YKBVL4Upmq47E+vffcvTFu0QwXfV3SojVt7ux+DWQSNiKh4sU83Fc3EzcD0tj5furV3E8BZNBnPWm9AfV0KXjB5j/UcTlHaqsmalm59EEGAGt+5sAINO+TZeqepip7Lo7XZ+T7t8h1Iy7Fi8+FU9Do/qa9uPd76+gfcfe35vrqFte0noPNNeR+lCTJ7nvoWkJsfukIMt/TNmkP4+Jc/8fSw1rildyPc+fFqbNyxB2dQASseuzjf2gGeQbCLJTsd+ZVn0+/TpH3vXOD8G+x5gd/ZbDs8T21thS2ktmWu8xaAVJFfEP0YDjmqSmeF/JepCRbdhr0S2oD1/GNf6eWHU82o73f59qCbugO1dPv9/yDjqGtEp+ZdBEpIWQPUv85jOQ5g9x9Iy8iEn/yGwvFTSM2si0Y8PC4mMOamYuSqGq5NMQ8UMH+34TD+b95m1bUlIdqIZ69qi6s61VGvXdGhDougERGVEAbdVDQV62GfvQYa6vMKTbk8cXmr3KD7/YmjsHbpj4CvUZLCKMGq6fcmrV612quH+mCKtMn4zoXkq5Ca376yS170Po/P76KAw47r3v0bW46kYV9M3uSrt94HwD3o3nYwBT999wUuHXoN2jcOpkp13tqk51ixeu8J9AhyT6EC1tmXA5UaAlc6K2crmhZMT3tPOVukn/4hWQXdA/a8iNkxv6lp83dvQJ0ujQJ+pr+g15KVBs2m8cnoq3VWE1TXQYqP1+3+i3CFSF2dZpi2IIcM01bMP/+qd0u3j8A5zex//R1/PJu7lPwKLkUhQHq5v9/z78+4Pa194AePN7o/te9YCP0Xo0IbcHsOGaZp9DbrorySTrR95YmKQzBVw9OyLXjquy2Yt955sbhLg0qYProj6lXOG52BRdCIiEoOzx6oyEabfYyf6zpJH7cCuOUnxFdv6ByqqSR9cS2w+AVg0VOIywkuqCksq6YglKfmZ/PGUpYU6iPrnS2s+bcMav672q0q4PZUTec9zva2WePw4MknceTDvNbrgM4HVzuOn1N9AhORf99ol5qpG1W/baz/BC/8ui03Zdzm0aKp1U63BzNM01Ff57xwc6PRGXCL2kcD9BHP5wKHNb8xuH21zkoFcE1Lty8x694v0pBhIaUJZrWBo3CPkZ1PTD6KEzr85QPodNAtnxb0qsQECLpzW5KzzrpNzti+2H1dPLO8PQLcPf/8iHBwHzJMM2yZPtrH3GzqptJlzb7TGPraMhVwG/Q6PHBJc8y5s4dbwE1ERCWLLd1UZK/fORT42M+LNfNSz/Um9zThU45ErLG3wCDDmuL7FhY/p+58J8SHjsXiv6U7yXws9/HNL3yMRdFbfLYMpqRlo3J8FIwGvVcUZc8N6vPvm36V43d1P9iwOuj133P0BM68dTma2GtitNE9MAokW1MN/O3FO3F5+1poVj0RC9fuwuV+3vOI6St131gn2+U2t9cM+WUkWHO8hvBS7HZYpfp1PmI9U4elldsjfdxT4po3gA3vAVe8iSP1L8f36w/iQYSPXLjw28qsCRa9Crpphp2TFu7sle+gQ8751BMNW7DlDYoQa6qW7o1fAvPuAi55BugzUU0/eS7LLX3f4XGxSefxoSfTc9AUoXU204yvVu3D3a510GxHmwTdnpu1qBXViQo47ra/IcOsNjte/2MX3vxjJ+wOoF7lWEwf3Um1chMRUenClm4qsgsaVwlqPl20+1X3KrpzsEXoT9AWIJ1aa1H0Iz6nZ6enYtlLI/Hqm+7Dcrn837Q3cINhEVZHu0IFzwWk4dCO9Vj+8igUnA4n//kaF+i3FSjg9mx1Xhj1qBpr+b1le/Dqz76HrNFqpjvkc10CWj7dd5DssMEaxHfgGlc9l90CXT5Bd259gLm3Y/S7f2HZDh8p6CEiJ9Pdn/sdh85kBtHS7TF+uOZxyjkzYhb6/q2dMzvw4Yq96vHHK533vre9Lqjxwv0G3fPGOZ/89pRmie7vk8BBq8Yx999fOMLdd2e9i7vXDM19rg26rWzppjCQIHr4zJWY9NVGdS/PCzpk2C+bjuKad/5S2Ujy/2ZE5zr4+f6+DLiJiEoptnRTsTFEeae6bbI3VlWeI01hCopp9bT8DZX1e0ZS0Sd5vf6c+XnAe1QxJ5sVlmltUdecirqF+Ox0sxXxSYW7GKItUNdMfxi7T23Cwi3RXuOe+2LU2d0rzHu01vq0+3fYmzTxWVzNYsk/6I7Ruc8j40Tnl16udfB0FqrJeofJywt3qHupQjxtVEev17X9yR0eleu1cbA9QLgar8vGMz8k49bYZbhpodQE8Mf/byI1y4KKAd6puktIC7FmpWa8/TrG290vtFgy3McerndgPsIadR/4G4+cfNxjVfMJutnSTUXgL4iWPtu+Wrz9DQ02cc4G5FjtSIwx4n/D26kK5UREVHpFZjMjlUqGKO8q1LNsg/Gc5Tqsb+e7X3hZFVR19IKQFOMgZrM7dMg6fQgms3ff7mDtOJ4OXZT/4WgC8RxGLUcfjbamw5hgDFy1O9fMCwoU3+TAhOkLk72m22zWgP3q/ZH3BNXSfV4//XrMjX4a4eavIdktFdqjpVubqt1L792FwaWzfhfuMPwIfO8ecHc+MS/o9Uvf+F3+Ld2a/tnSMj7+mPf/+Vr2Y4GXU9So+9wxYNV7yMk4i8fnbQJmDfKeRztWuM77ylZw/xOJQjPutr+hwSTg7t6wMn6Z0JcBNxFRGVDqgu6DBw+iX79+aN26Ndq3b4+vv/66pFeJCuFfe6OgWrpj4+LxT+0bca5S4SuFl0Y6P2N4F4oMKTazBy7Ykv94w5Kuf/b4gYAtkvnTwaL314wemMmjD7a0Nt+Y5l54LKAz+7zHkA6QurxpfwreMk33E3QHHzwXNuieHfUSSpRmXb0Kumku/FTUBR6z/HHT517TYmzuxe90bgnr7ir95ayV4M+RMxmwaw435iCyEHwqarz7waXAzw9h+zfPYu2qvIKGWh3/eQBY8dr5z/NxiGT1cirGcbddQ4a5/QQBPDyoBb64swfqVmKxNCKisqDUBd1GoxHTp09HcnIyfvvtNzzwwAPIyAh8wkilx3vWoXjYciduMT/q9Zox2nsAp1X/uQTz7u4FvclXlWBglnWw2/O99hooC3xViS6sXSu/A05sC2peSSM+d8J/0H3hM3PV0DKBSIhrK0TAKhpY3YNmKWamM0YVallqXaRf9qndfl/vqt+BKJ33BQ6b1aZSxQvKJgXwHIX728Ohse4IrjP8Dr2fddL2437j9x0eLwZbIS1IAbI3UhIDlyZsoDsGvT3vgkxOduH26dUy3dNyC+ys8/9G630f4dfox/zPt+hJdbEnzuY9QgDTy6kofAXRgcbdttjsqiK563pTzQoxmDe+N8b3b6qmExFR2VDq+nTXqlVL3UT16tVRuXJlnD59GvHxhUt3peJ1xFEFX9v6+XzNZPDunxtldF730Rl9B90jH/8U1/93Gj6PcrakfWAbiuWWtlgcHc560UVX3X4iZMt6YeEOvBdkw7O0JmafPer39Y0xd2LnimxUyNoQYCk62K1BjGMehDpbZyEltjpQyGx3hzUHu9cvhnev7cDsdmvAsdL9sVnNMGjSi0vaH9EPqfsXdxrw5arquKZrPfcTbU0K+T97TkplOJ+vhUKgodHOOgLvn7vp3S8ImLOyCrUOjdIKX/9BLgC5DnjG/Krii0VPoGH21tCnuFO5F8y420Jen/jlemw85NyBjupaF08Na4P46FJ36kZERKFu6V66dCmGDRuG2rVrq6FT5s+f790tc+ZMNGrUCDExMejSpQuWLVuGwlizZo0ae7ZevXqFej8Vn4csd+EnW3d8bhugnreuVcFrHn2F2vjH3tLn+w2aoPtJy83qPsVREUmxJrTr1DNvGVFxyHb4bjl9zHI7IlFBirJJS7c541zAeZotux9YMyvAB0qwG5qgu+bhBWh0qnD//xVrDk6dLvgFDCmkVpjxs3XH/oXB6n9M8ZLyiO1drP3uDaw74F5orOv2V3IfD9G7B6SOAqTJB8VVtC35e6/fj8NWsN+LuZAt3YWWnQZrmv+LUT6tfMP3dJ0O2/bsxz+btyPldOFrJ1D5JoH2iM51fQbcUvPgq9UHcdnry1TALcfBmWM648WrOzDgJiIqowp8uVRSvTt06IBbb70VI0eO9Hp9zpw5mDhxogq8e/fujXfeeQdDhgxR6eL169dX80ggnpPj3Zq0cOFCFcyLU6dO4aabbsL77xegPyiVmFoXjcW0TUfxx9gLsGT7CQxs450GbjTqMdr8BHZE3+SVEqwz5QXSf9tb47Kc51CvUXO8DeDO/i2B83WgLu/cENe07AN85ny+1V4frfTOlNEsTTC+1t4MXfQ7EQlq6k4HPa+0dOusfoaXCpouZEG3SLQUvtVfWrpRwIBO3PXRKvTHMbQp4Psq/nArUmLaoVTw6Mv+kuld/J71UN7L5ky3NteHTO71L5YkH0JPUwhXRy5iyDp9daN6nl6tI3bv3IZWfUdAV8DvKCOzmIPu5+vBu3NLYemQ9uPjuOD0D1hRfxyq3/ZCyJZMJOPG/2feJvy8yVlUsEfjymrkgtoVvQuREhFRBAfdEkDLzZ9p06Zh7NixuP12Z6uj9M9esGAB3nrrLUydOlVNW7t2bcDPkIB8+PDhmDx5Mnr16lXQVaQS8ODAFuomrr/AeXHFk16VotbhNssjeNc0DU9YbsUrPlq6rTAgLbEZZl/XRz03mvJOlyUNvX71ynmfaxmHn6P/ox6bNWNomR3BRRtjzQ/ig6i81sKSNNVynRq3+DHTl27Tp5g+CnoZibos1DqzpkjrkZFjxabdx9EdJU8F3ZaCX0TYfzIdKYZz/odVCyCmtLR0+xhn3GLNy3pIO7gFSQHe7vk7Kqr56w+hXr/TcHb+AXSzL0cHRwb+3vMXYoIclz533easwrcoo3Q62LKdv5G4BO+MHqLCWrn7JCbN2Yhjadkw6nV4aFAL3NG3MftuExFFgJAWUjObzSqgHjhwoNt0eb5y5cqgliFpVbfccgsuvvhi3Hijs0UlvwA9LS3N7UalU6U4Z0v0cns7DI37HENuyBt/2qAJrMf2aYRlj/ZHtURnIG6IygvI9QaTOtF91HKHKthmT8wbm7Re1bwT4MSEvD6mG+zuRWu0frd3wadWZ0q8P6mO4qkO+7e9FY44qhZ5ObVT1xfp/RdaV2J8xpsoDaQFtVL6rgK/z6Sz4gnTp4X6zFh74PT84uIrZbv210Ngt9lwLDUbWzYFvngZanrYMf3HvM+Mdzhbq1semQdoiqQF4wHbbJRZcvHQ7PzbExIZdFPRma12PP/LNox5/x8VcDeuGo959/TGuIuaMOAmIooQIa3GcfLkSdhsNtSo4Z5aLM+PHQs8/qrLihUrVIq6DBfm6i/+ySefoF073ymf0nr+zDPPhGDtKdykaNra/7tE1QKoHO/eL1sflRd0N6ueAJNB71bRPpchSr12x4Sn1HKqRVuAac6XhrStCZy/tmPX571Hb4qVsbT80ga6N5gn49MoZ0aG1n57dTTQpyCcLDCqIb8oT48D7xZqc8yJ+m+hN2O8vXS0dEv1dc8ddHv9Xhw5uAu93paxtTeiVwjTx4MJuldv3+9erO38dF0BW7r7GPyPG1766aCT7AsdUKGC7wJYRMHafSIdE75cj82HnQ0G13Wvjycub4W4KBZLIyKKJGHZq0sw5Nl67TnNnz59+qjiacGSFPRJk/JaTKWlm4XXSq8qCb6rlBs0w0pJsTQtbQBuSayj7ptWT3RO0FSodmgKjukNecuLjokDznchXWJrj4sM/7otPw15n6ftF671g70n7tV/h3Ayl2DQne0wIUYXumHOCkPG5DboQjPMVa0C9IP3FIdslAYyZrivHXTiXy+irq4Paujci6qFW23daVSCdxZABWTAUMCW7rLM5gBiHFnOoDspUII/kX9yXvTl6oOY8kMysiw2VIwz4fkR7TFYLh4TEVHECWnQXbVqVRgMBq9W7ZSUFK/W71CJjo5WNyrbjCYjHrfchgRk4eLzgbWLjJA0xjwZVZCGkRWbur/RkPcTrp2k6futucijbfV+0noLlhjyLtKINE36eI6fTsBvWIdji70h3op6LeDfIUF7rK5wAcid/VrgzyWH3aqxP28qnkKCvXLewLqYcShJqYhHZZSOVubSwN+wbYnbv8Hy6G+KfX3GGX/AZfq/fb7WIDu4ceQjQbbVgYpwFgKNiT1/8Y+oAE5nmPHYt/9iYfJx9bxP06p4ZVQH1KgQunJ/RERUuoS0WS0qKkpVJl+0aJHbdHke7oJoM2bMQOvWrdGtW7ewfg6Fh1Gvx2e2S/CObRiMmpZtVwC9wt4O39t7q+Iy/tRMzGulzjBWBKq3Vjd7TF4K6H5HTdxV7RPV4n2r+WE1LVNT1/jpEV28lisfuXjyYDwy6dGgAsdAXrV4V/x3ubhtHVzXqVru8/V2jwsMYXQaFfCc5bpi+zyf6+Bg/1jPlu7Spp7edyX6RHv5GTrrojPfooX+kHqsi04o6dWhMmbZzhMYPH2pCrhNBh0eH9oKH9/WnQE3EVGEK3DQnZ6ejg0bNqib2Lt3r3p84IBz2CZJ9ZZhvmbNmoWtW7figQceUK+NGxfeVrTx48erYclWr14d1s+h8JCTD1+PPTWsGiCojclL9VRJyuOWq1vTzv1zp8vwK7XqNcHNlsfwp70T6leWZOK8YN0Q7Xv5tZJi0ahqvN9A+EfbBRiZ8xSy8xmY6LoB/muCR5liEKfPC7S2O+rhactNuN88Pnfs8nB4zTpC3R9y5AX8vnxlvSjoZfobjz2/wJ/yZB0t20PeHarRH8fqDwvrZ3xoHYQSZSqeIotUtqw/cAZz1x1S9y45Vhue/TEZN36wCinnctC0egLmj++NOy5sDH2Ai8lERFRO08vXrFmD/v3zghhXf+qbb74Zs2fPxujRo9UY21OmTMHRo0fRtm1b/Pzzz2jQoEFo15wiirZ12+DjBGTRAxfibJYFdXyNVTrsNeDYZqBxP/fpeoO6i75gLLKsVvye3Qwze3VRQX1slAGXt6+F6okx+GTOAcDZcAWT9P/2oF2bu8wPYFXMeLfX37FehqnWMerxKX0VNHQc9VrGlxiEa3s0Qc2LxgJLfbeYR0XHwGHJcqv2PjtzsHP7wFqgocOCCVZuNS5Qjz87X709xVEx4HuSHQ1wn/levBHlv7L5VkdDfGPtgwnGgg8IZTElBix4J/60dUBT3RG/La6lzVxbH4wwLHebtsjWGZca1uX73hrzr0FZI/8X7jL+pB4f7Po4ElJ3ouaBH0KybPl9Vted9aqDUKKiAme2UPkhAfbekxmqJXve+iO508dd1BgjO9fF/V9uwNajzmJpN/Soj8eHtlbHISIiKh8K3NLdr18/VQDE8yYBt8s999yDffv2qeG8ZAixCy+8EOHG9PKyzaQJtLWF01ya1UhEt4Z543O76XILcNnLzqF8zpPxrnPpDYjtew8uv/RSVTU9McaERwe3RJvaSWpYsn5t88YVN0X5COo1WrdojkU29xR0kyZSXB/t/tplOc/hbvME7Oj8JDB4qoyN5nfZUVHR0Fnzinh9MvaC3McXNA2+JoK0judnls0ZzIsv7uqN927qimPw3r5ZhgS3bfqDvRduMuddNPjIeqnb/E2fXI8djW/CTOuV6vk8W+/c1762Bt4PWPWBswRaZM/GtGr/w0DzC3gqhC3/I3KeDtmyMrrd6/b8Petl2Gp3H7d+QzF2GyhuWZrS5tGx8dDpQ9ODSX5Hv9i8uw5ZUcJBSzT7dBPw/C9bMXzmSkz6aqNbwC3eXrIHl72+XAXccvx5/6auePaqdgy4iYjKmYgZn4jp5ZHT0q0PstJ9INn64NM+c6q0VoHRClsbFfh6ywvgp4/uiPRmV7i9KjXHXRYkjkSyPS+rY5+jBn6xXwBrEEW59aZoZOrzgtyk2LwA/ZVrOgZsTf0/y62a533xhvWqgJ9lduQtu3JiLC5tXQOPj7o4d9oxh7Mf/IqWj+dO0/kIdK68bxrQ7z9uF0xm3dIN1018EWnX/YgnNOt1KrZhwHWyG/1f8JCicuunDMNbN3ZBFmKw3xG6wozrHM1DshwZVs42wD2Al8J8FXTnS+efV79m0cdiL60sjryW55i4BDg0F5GKwgSrGlLPk7ba/yGPMe5PJTQPa/p5eqtrgTg/FwKpXLVwS2AdiNlmx4XNq+HXiX1xSevwFJUlIqLSLWKCbirbjG79uAs/bNR/LGOx2t4cS6rfGPR7oqJMGGp+DmMs/0FUtPeQYdpW84pxURh+4wS310868vqSx8XG4lXrSK+goKqfodK0LcHQm7C5+uX41tZXpXHXqxyH167tiM/vuAA1NZXZvdbvyhno1aVTvhXYtf545JK8vynGuY6dGtfABnsTnHYkYEDOy+iTMx2WFnnB+xmHd9GopIR4r+9LAu8G1ZIQ36yPW5G69nUCtwraAgTdpxwV1Li1rgsRhUkrXp/YD2vtzdTjrfZ6CLUYnRnRRvdd6sOXdUCSa7y685IqRO4wU60S87pHxMTFw5wVXDX6c47AGSbRfoJuO/SYZR2cW5vg0pwXc1/bVfsK/G7vjKKS7hepmhEOXBIuf67Iy6ayT1LK83Nb74aYfUs31Z2JiIjKJwbdVCqYQpSG+rltAK4xP41MQ4UCVU53qP8KOkQZ8w9YtWns4n3bUHXfrk4SEmKMsGt6gT87vANGdKqD2/s28tk/eZmtXd4EvR4GUwwetNyt0rjFlR3roFcTZwveRPM9SHPEqj7BWv1b1UKjynknc8EEpPGVagJ1uwN1ukIX7yygJoH9kt6f4uVW3yADsTjkqI42dSri1+bPYEHUpYjtPMqrZV9njAaqOgNZT9I3//XrNen2mnHUxdU5T+KsI69PrENTlOqqnClu8/ZuUVvdJ0QbvVpUg2U1xGKk+RmVpr7Anpeq/OroDgiFOOQgyqDHk5Zbcqe1a1ADCTr31l57XBWUZTmaLAlP1Vr3zX0cHxuHnKz8A5Jg6gnUTtD7/F3bHHr813oDBuU8jw2Vh6Jtnbzl6PQGt99qMMwO73T1D2xDEAWr98zsz02AKrAZyKgudfDksDYslkZEVM6VcBWa0PbplpvNVrCTLCqNLd2F17xGAnYcT8eVHZ1BWjC06exRJu//Ej86+mJ0gPd/Pn4AjqVmq8rof+85hTmb8y4gDGxXB1df4Lt1wwA77u7fHFiRN21MjwZYlHwcg9rU9Jr/n8RL0CG1F+40/ORWiEtv0MOu+d07LyD4N8N6BcbL3zx2oXOC5u+fMKi1c707pSDTbEP9KnGof/1ECfkhibopGWtg3a4JniXobj0cGHQcqOvd5/by9rWBub6D7jWOlthqb4CehmT1fHelvrj09Beq1XODw73fc4/mtd3GX/fV6pkfx/nx2nM01erF8E518dA3d+Fl0zsoikRdltqWdn1eUBob535CnuGIhi2+FkqCY9Qn0H0VfAaIP29ar8SDJu9xwlfqu6Ba5bwLCnHRRjSv4v49SQ2A4YYVqKDLdJue34Uik86KLo1rAs5BMnLVqhSP5y7sgN+31sJjQ1oCJ3cBXzlf00XFYoO9YNtaLpl5qlExAVGZPoZvk98+lWuu4mnDO9X26sstY2/fe3ET9Ggcud1JiIioHAbd0qdbbmlpaUhKitz0zUgl42/HRxmQYbahbqXCD8Pz3fg+OJKahSbVgh8/V9twbdKkB39cdRI2HjNj+PV3BXx/x3oVgfPZyhIsn2xVE9jtfG40+C/0VDnOiGY13FvkpSX3m7t9j2n/9biemL/+MCznqgHrv3Dbdg57/mM6f2K9RGUCyFBkqv56gL7z/VpU9zn9yctb45ntP+dNkEBWltPznnw/Hw4H7A4d9DpnOnrtpBhsz6iLnnAG3acqd8KVyVNw0FFdvYacvLc2r5U31nphg25tMOzpylseBj7LC7rPIhEVcQ6FUSE+BjjfuB3nEXR3znkHryQEdxKe5ojzCk6LQlerfYHfkx5XFwmZ50v7qxTu4fjMdonPoDs+IRGnqnZDdUccdjrqolOUEYkdhgIr8rIW5Bf3gOVufBD1itt7o+WiW4BeJQa7GTqDd9ePhtUqoFf3+riuu7NY3Z4zef/f9FEJ6nvslP021scEN2Sl67ep9eLorjDM9rFyIag9QWW7eJq2L7fUArU7nLU4pPZH/5bVAwbq0kLeqb77fo2IiCIX08upVJAWzLVPXIrkKYMQYyp8RWIZgqUgAbfzs91TzV06t2mJ55/5L/q0dq8+rVz4iPN+wFMey9Khbd28FFeDj0rsLnqHDajoY9l+yMWIey9uBl18ZdxifhhWh6Qy36zSuDOjA4+xLZbb22Kro4HqB1tY0vL97phOhQo85O/Vhi4rJw9AzKCn8L51CH7t+YVKpd/oaKrG6/7a48KDXtMCufTh/hjZvZHPiwqBVyAv6HY43Ne7bzP37RcNc+7jPbrgvyPRrGZeca2YaPfW0A/v6AtdbP7Ft241P4ybzY9iua0NQkECeMRVDWoc9WctzuHvxNnhn+MY8t63u80EdGudl4WwxJYXyEfBgixdLLrlvIVrzE86h/6r3gq4Ly8ro3G8Gdd0qev1mdrv1xej3YzsWO8gRlLI3Zaj+f+mi47D1imD8fS1RRs9w2jybtHeZA9cFJDKX/E0Cbi71K+I3x+8yG/Ara1yLvfynIiIyoeIaemmsq8owXZRaNPLpdU4d7opxufwZUr//wCdbvAdNOv0PoN4r8+V/qb1LwCGvAhUaRL0+vZuWhXTf+uEtjkfIBvReEqvx+lKHfGc5TrscXin1f9o64FO+p1YZi94S6cvBl3gAMk/uwr4DZp+ttf2bQv0/TL3+eKH+qlh3OKjjdiZ2B3Nzq06/1arW+Dfo1ktYKP70qvUaQoc/83vpzs0w7XpfLRoasVqmtm1AeEpRyKq6AK3gNetkgjsO/85Ht+/9M//4ZymCd+PP+3OCxv/s96AufqnEKvLuwhQEKsdrfCm5QpVUX+1pg/yT7YL8JW1H16JetvrPQ5NTQK9MQpGhyW3dP3r13VCtsUG/O/88u0tcJHhX+e8NjO6NqgEmz4KzappWvg1v+04+zn0aVsL2OT+mW5D/PlgcFjQokUrnE+KyHO+y0DucjTPDdGJ6iKcXMzB/MJnFBhNJpgT6iIqPa/FX2oD7Ai4xlQei6ddf0F9v0UzfQXq8lyyo9jiTUQU+djSTeVes+oJaFkzET0bV1HFbtZXHoxdUS3R4oIh/reNBOqVGvhs6XUY8k66NDG8F0m1Vi64C2iaTyuthoxX/uClzVXAXadirPoMm0OHd23D8Ju9i/p7tO613I++Oa/lVhJvWyf4InM+1WhbuPdJn+58WsYbVo1XAbdoOuHHvBcqubcsmnwM7ZZtqoDdAfrwOnSFu8boFhBqWosvz3lWjYm+y+5+oaNTO9+t05bzRboSNUPB5UcyE9rnvO/+dz1+HKdqXZT79MzI852YfbA1H4ol9g44gYpu274S0hGr8w7+jw58260QoMFoRIzO6nVx7EHLODVe/Sxb3v8Rnd2CxBgTNj09ED/fn1dQTathvAVI8m7p1uXT0m2wW1C3uY9K5Dr3C3UGTXcOQ3TgAlfSv/xT6wAMNz+Tb0t31E3fuk0zBzFCAEUmuegkdTd8aRwgy8pfoB5M9XMiIir7IiboliJqrVu3Rrdu3sWciPIbI1yCBBmaS3S6fw6a/ucfGEzefUiDca56V1Vh/D3r0NzCX1oypvYJRxLeq6B6VhfKfQOaYdXjA/DDfX3UZ/RtXhWxJgO6N6yspt3cKy9InT++N6Zf1wXLH+2Puy5qjPdu6ooikZbLO/4AJno0V+bH4YDFGHjYMC1VGf2ev4Gbf/QKun2Np26PSsKjhgf9L9BmVn3SRWyCd7XsVL3vCtragPB4jb65AfQ2XRN0HT0Zd1ofxDJbW1xr/j/1mrFBT2DAk8A1H7ktJ+t8ATe5UFIQ0n9d2/oMUwyONb8u96mxvv99XtdrHsHUEe3wx4N5QbrY7Gjo1pqf+7e2GobB7fIuIhiNUYgzeFfuXhJ7Ce6wPOg2JJze7myNl6Hd5P+Ulr29c30rD54M1GwHXDnD7XW9R5E9TwaHGYitBNzxJw73+q/f9HLtc2NM4G4mxx2V8X/WsdjtqBNwPlNUFFC9JTbH9ww4X3m3b98+jB07Fo0aNUJsbCyaNGmCp556CmZz4bI0SqPkI2kY9sZy/LL5mNdrd1/UOGCLtb8q5/lVPyciosgQMenlLKRGRSEt3KGi1xtwh+Uh9fgOH69/arsUn9ouQRdj/n17A9GO+VohxoQNT12qhl6TvyWmYWdgVV6hN1XsDcDkIa0QEnU0Q4Hl4wPrEFxpWIE1Na/FBb36A9/cCrQaFtybpU+wD1HR3hXhz1Trjo6VE9B4+afoWyUd8WeSMc74A9rr9+YGhbf1aaSKbs35qxGW/bZKjeP89Pn3PxjzDN7PdI7Bvt9eHQ30Kc73OfJauivXb4P+219BqiMe258bovotT/qqDm60/CdvReRCS9+84D/LmIRYayo2R3eG9FSvVTEWl+U8h0nGr7Gp+XhM3H273z9/79Sh2Hw4DTW/qwGcyKuOrC0qJttC+oB/GPWS1/uNUTG5RcaU+zcAx/5FxU0NEPvvG17zx8ZEw2TUpGgbjNBLVfr9y91a+Ye2q4WP/9qPGhWipdnXuZ1s/oMr/VUzgQH/l9fKLV0zvsu76CSD9gWiUtxFnc6wnNKM/a3339Jtis2vIGPgz1xg64pdjtq4Pdp5kcSmyZSYOabo439Hmm3btsFut+Odd95B06ZNsXnzZtxxxx3IyMjAyy+/jLLMbndg1oq9ePHX7TDb7KoLzCvXdEBijDHoomjy+riLGrulmOcXqBMRUeSImKCbqLSoXznwyf5Tw1rj9d934n/DC5mm7Ue0UROAtLoCuOINoLam6FkJ+a/1RjxrHYM7TZWha9vbOa63jxTjgtAG3ZLi/Z2tF+6vUA0Pda+PZjUSVPX1C56rgJ/NPbAv5no1n+58UCj9fK/t1QL37J3uVvDo9zPV0MIxG+MMP+AXe3csjH7U+T4JzlpcBuxbhpo9RmFKPZs66VaFwtQY8zpN2TVv0Xf9gW2/vY9qvcbnVqg/GtccYzMexsN1W+RWuleaDQT6PIAfDG0QH21QWQzt6iYBo94FvroJuOhh5zpphquKiopBm8b1gfNdjnfY66C5/jD+trdCD8+VqdxI3V5pDWzOSsjte+4SF2VAi5Ztgc3O5/Gx0cDI94G/3gS63pY7nwzPJS32g9vWxJ7XaqKx/hhWRPVEY38bQfq2B/jO80svN7mCbpXyHuW/kJrm4pkpOq+l+8OW7+LWbXfmPj/hqIAvbBf7/Ky99hqI1+Xg6MC3UDcxPvf/1bdVxyExbadKqX+2XckM+1aaDR48WN1cGjdujO3bt+Ott94q00F3Slo2Hvx6I5btPKmeX9KqBl4Y2Q5VzvfdLkjQ/NiQVqoPN6uXExGVPwy6iUJMCn3NuqUrKsX5Tk+/tXcj3NKroc/U85CRZXe+CaVBt4aVsHrfGVzd+XzQJenFRRQdk5einYlonEEF1Z9Y+huP7ua72ri2JVbmm3WLe1r29d3r47N/DuA120iMlHU9X7QrSmKuaz8DbBZpOkbfZt6F7RYmH0eVeN/ft75aU7S87nm3aV/d1RNbj6ZhYJsawBLNC2O+VndeW6hac2D837lPTRXzUsClWNv9l3cFztdEe8M6HKmIx1p7c2yBf8cqdkJbzHabJoUDTS0HwB5bWdUmMMVVlCgXGHS+ctp5kkJ+10XOAmm31XgVcYdXoselN6MgFrR6Dr2S/4tVXaeh+6anclvMxR3mSaivO44nTJ+p50bkpbibjJqCeB6F6rQt5lGxeWm7N48ahV1PP42meme2wAU5M92q+JsdBkTpnAX+Tt+6HMcsVtxyfmx4lxRDLVxsnqYeP1ugv7T8Sk1NReXKRcvoKUkLtxzDo9/+izOZFsSY9Hji8tZqP1GUfbcE6WzdJiIqfxh0E4XBxS1rBHw9rAF3KfPFHT2Qlm1FZT9BaWHEaPp0u/o7S6pnIHp74Krh/xnaCn2aVkWzGonOfpbnh5euFHd+LHJNC6vWi1e3R6sV+zCic+C+wVpNqyeoW2E1adUJv9adCGOF6pASfFHVW+S+1iYxE8+n9lKVlAPZU6kPxpofxP9Ms1BTdybvBWM09NJfX/pZS8Cdj9dvH4jNhy9QBf4KYtDo8TiRdhsGVIiFY/szbkH3Iruz7oAr6Na2dCfE511wsRrdt6E9vjq+tPZDDky4PC7JrQVcisK5GtQl4G5SLR67T2TgkcEtcPrPCqgJ5zbo0sj3cE82TTcDyt/u3bvxxhtv4JVX3Mdk95STk6NuLmlpaSW+ebPMNvz3p2R8/s8B9bxN7Qp47dpORfo/S0RE5RsLqRFRWElRrVAG3GqZ2lR6qYpdJQ4XNQ88VrnhfKEvf6Rq+pB2tdSJtSt1XH1WfJWA76sYF4UHLm2OBlUKVxDJVdW8IOSizeDbn8Elo873i9YbsOL8mN7GVkNV0bxnrwzcfcFsc+B3exfs8VXxXVKzY4Krci/p8j0aV3HbZsGqVsEZQOua9Pf5+ouW0er+P7a81PCEmLwLLi2a511sEFabA49Z78RT1lsRZXQ/vLkVoztf32DjUwNxT7+mSNXl/7faZCDmcujpp59Wv7dAtzVr1ri958iRIyrV/JprrsHtt/uvWSCmTp2KpKSk3Fu9evVCtu4yTNfcdYfUfbA2H07FZW8syw2477qwMebe04sBNxERFUnEtHSzkBpR+XR1l3p44ap+XsXwPr6tOz7+ax/grKOG0/rAwbOXMd8CS18ErngT4WTWmWDSjF1eWDdbHkWSJQMvt+qAupXyKyIGmK3OZt/s81XVS9SQF7DsbBXs370Vc215w43Z+jyADksG4IUbLsybV5cXTFep1chtMTUqxKiaCka9DvFR7oe3GTF34pXMx/G69Sq8OLI9BrSqnptxssHYAS2s+wOuYnkNuu+9915ce+21Aedp2LChW8Ddv39/9OzZE++++26+y588eTImTZrk1tIdisD7+V+2uhUtkyJm0qc6ULG095btwcsLt8Nic6gigdNGdVTdR4iIiIoqYoJuIiqf9Ocrtnu6sHk1dZv84tPocW4hjH0eK9iCm13ivIWZjPkcj+wiL2fJYwOx4//buw/oqMo2geNPQgkthBIgQCAIiLSEGkBFAakSVBZFQVCwrbLUD0X4AD+KYgGFPQJSXE9EAcEj4AKrKKJSBAWlCESaUkNVKREQCLl7nted2UwyM0lwbiYz8/+dM87MnTvjzcNtz33f97kn06RtDi3+DleuZzjHxPtdsSj5JuYRmb33r6pym0e3l3OXr0mdSpHyjw51zBh8p/BMh61SrsM4tLV9zbNtJDwsLNs68WPheKn7Z7K5v/2hRNekbmnZ/nLqRLh8dr2F/I+HRRzR+RZZu++MafkMJdHR0eaRG6mpqSbhbtasmSQnJ5ttMycRERHm4Uvasp054Vb6XouYuRtPffL8nzL8w+2y8effzPvODSrJqz0SpKyPe+gAAEIXSTeAgNawdpzXz/85ZJDsPdlPmscVzFvzaNLtC1pNPC/3AK/wf9WXJ6f3ktbhu2Te9c7y1w3T/CO61P8nOBVLFzMP5ZJwqzLVRDq9JFKygtsx51oMzh1t1NaE250hnRtJn/96UHo281xhvWHVKNn7UhfXuwTApYW7bdu2Ur16dVOt/MyZM87PYmJi8jVSWh3c0/SsSfeqXSdk5JKdcv7yNSlepJCMv7e+PNi8WkjV3QAA2I+kG0BAspKmipW6VYrXT/I6n97DPK9FvvLTVT917+7bKk4OnP5DWt/cRGYdbSkdG/j3Nli6PHtPpkmH+t6LEBq3Dc7z74dlGdOdmXYh3jKmg8cK9A4k3J59/vnncuDAAfOIjXW9eGHlcxE6Uwgxh+kXr6TLxBUpsvj7o+Z9QmyU/OdDjaVmBYqlAQB8L2gKqQEILWGJT0h495l/3QM6gC0u1M08r72ekK//X21BfvX+BOmWUEX+mdRAmvv5woQuz5SejUwXYDvk1HCp9153N0wBudO/f3+TXLt75DdtzdYx3JkNaFPT2cq94+g56TZ9g0m4db34j7a15KNnbiPhBgDYJmhaumfOnGke16///YJEAJBflhXqIt9cqiYpVpzsJey2+fc7a8rwD3dIx9y0pCPgadE0vYCjXcq1hVsTbi2GN3vtzzJt9T5Jz7CkclQxmfZQY1N9HwAAOwVN0k31cgCBKKxQIdlm3ezvxQh6PZrGSuNqZUx1c4QGTbQdrdvHz12WfyzeLt8d/N28T4qvLC//W7xElfBNTQUAAEIi6QaAQKS3t0L+YLxuaFr543EZvXSnXPgzXUoWLSQT7mso9zetSrE0AEC+IekGAD9iHDFgjz+upMu4/94tS7YeM++1p4MWS6vhodAaAAB2IekGAD+qF1Nafjnj/hZHAG7cwAVbzb3VtTPJoHa1ZXD7mz3eUg4AADuRdAOAH028r4GULl5EeiVW498B8KHhHevI4d8umqr4Bfm2gQCA4EfSDQB+VL5UhLzSI55/A8DHGlUrI18MbyOFad0GAPgZ/awAAEBQIuEGABQEJN0AAAAAANgkaJLumTNnSv369SUxMdHfiwIAAAAAQHAl3QMHDpSUlBTZsmWLvxcFAAAAAIDgSroBAAAAAChoSLoBAAAAALAJSTcAAAAAADYh6QYAAAAAwCYk3QAAAAAA2ISkGwAAAAAAm5B0AwAAAABgk8ISZCzLMs8XLlzw96IAAJAjx/HKcfwKZRzDAQDBeAwPuqQ7LS3NPFerVs3fiwIAQJ6OX1FRUSEdMY7hAIBgPIaHWUF2aT0jI0OOHz8ukZGREhYW9revXGjyfvToUSldurTPljEUEDvixvoWGNhW/R83PQzrwbpKlSoSHh7ao758eQz/u9g2iGNBwbpIHAsK1sUbP4YHXUu3/rGxsbE+/U09oSLpJnb5iXWOuOU31jn/xi3UW7jtPIb/XWwbxLGgYF0kjgUF62Lej+GhfUkdAAAAAAAbkXQDAAAAAGATkm4vIiIiZNy4ceYZeUPsbgxxI275jXWOuIFtg31MwcZ+mjgWFKyLNy7oCqkBAAAAAFBQ0NINAAAAAIBNSLoBAAAAALAJSTcAAAAAADYh6fbirbfekptuukmKFSsmzZo1k/Xr10uoeuWVVyQxMVEiIyOlYsWK0r17d9m7d6/LPFoeYPz48ebm8MWLF5e2bdvK7t27Xea5cuWKDB48WKKjo6VkyZJy7733yrFjxySU4hgWFibDhg1zTiNunqWmpkrfvn2lfPnyUqJECWncuLH88MMPxM6L9PR0GTt2rNl36XZYs2ZNmThxomRkZBC3LNatWyf33HOP2Wfpdvnxxx+7fO6rbfPs2bPyyCOPmPt46kNfnzt3Loe9BQqKQ4cOyRNPPOHcpmrVqmWKrF69etXfixZwJk2aJLfddpvZn5cpU8bfixMwOB+1d18P3+QB8I6k24PFixebxGjMmDGybds2ueOOO+Tuu++WI0eOSChau3atDBw4UL799ltZvXq1ObHv1KmTXLx40TnP5MmTZerUqTJjxgzZsmWLxMTESMeOHSUtLc05j8Z02bJlsmjRItmwYYP88ccf0q1bN7l+/boEO43J3LlzJSEhwWU6cXNPE5Xbb79dihQpIp9++qmkpKTIG2+84XKiRuyye+2112T27NlmO/zpp59MjKZMmSLTp08nblno/qtRo0YmVu74av16+OGHZfv27bJq1Srz0NeaeCMw7Nmzx1y0mjNnjrnoMm3aNLONjR492t+LFnD0QkXPnj1lwIAB/l6UgMH5qP37evgmD0AOtHo5smvRooX1zDPPuEyrW7euNWrUKMJlWdbp06e16r21du1aE4+MjAwrJibGevXVV53x+fPPP62oqChr9uzZ5v25c+esIkWKWIsWLXLOk5qaaoWHh1urVq0K6rimpaVZN998s7V69WqrTZs21tChQ8104ubZyJEjrdatW3v8nNi5l5SUZD3++OMu03r06GH17duXuHmh+7Nly5b5fP1KSUkxv/3tt98659m0aZOZtmfPHm+LhAJs8uTJ1k033eTvxQhYycnJZltCzjgftXdfD9/kAcgZLd0ersRqF1a9gpOZvt+4cWNO1zFCwvnz581zuXLlzPPBgwfl5MmTLjHTe/m1adPGGTON6bVr11zm0a4+DRs2DPq46tXBpKQk6dChg8t04ubZ8uXLpXnz5qZVRLsyNWnSRN5++21il4PWrVvLmjVrZN++feb9jh07TAts165dWefywFfb5qZNm0yX8pYtWzrnadWqlZkW7Pu9YD8GOo5/gF04H0Wg5AHIWeFczBNyfv31V9M1sFKlSi7T9b2ehIU6vVA4fPhwc3KvJ5fKERd3MTt8+LBznqJFi0rZsmVDKq7a7XTr1q2me2pWxM2zX375RWbNmmXWNe3GuXnzZhkyZIhJfB599FFi58HIkSPNwbBu3bpSqFAhsy/TcZS9e/dmncsDX22b+qwXjbLSacG83wtmP//8sxmuocNdADtxPopAyQOQM1q6vdBiC1lXsqzTQtGgQYPkxx9/lA8++MAnMQvmuB49elSGDh0q8+fPNwX5PCFu2ekYyqZNm8rLL79sWrmffvppeeqpp0wiTuy8j//T9W3hwoXmYs+8efPk9ddfN8/ELe98sW26mz+Y93uBQovk6b+Bt8f333/v8p3jx49Lly5dTA+cJ5980m/LHuhxRN5wPopAyQPgGS3dbmgVWm0hytoKcfr06WytHqFGq/Rqt1+tBBkbG+ucrgWGlMascuXKbmOm82hXKS2QlbllSOfRaqbBSLuf6t+n1e8dtOVR46cFPRyVH4lbdroe1a9f32VavXr1ZMmSJeY1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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) = 4.164e-03 @ epoch 722\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.54624e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=1.54624e+08 x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -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, 8714 columns and 17660 nonzeros\n",
      "Model fingerprint: 0x011f4309\n",
      "Variable types: 8704 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [9e-10, 1e+00]\n",
      "  Objective range  [2e+02, 5e+11]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [2e-03, 4e+01]\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 2293 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 6421 columns, 13069 nonzeros\n",
      "Variable types: 6411 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 1.336001e+08\n",
      "Found heuristic solution: objective 1.266804e+08\n",
      "\n",
      "Root relaxation: objective 1.107001e+08, 134 iterations, 0.00 seconds (0.00 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 1.1070e+08    0    2 1.2668e+08 1.1070e+08  12.6%     -    0s\n",
      "H    0     0                    1.107858e+08 1.1070e+08  0.08%     -    0s\n",
      "     0     0 1.1070e+08    0    2 1.1079e+08 1.1070e+08  0.08%     -    0s\n",
      "     0     2 1.1070e+08    0    2 1.1079e+08 1.1070e+08  0.08%     -    0s\n",
      "*    1     0               1    1.107106e+08 1.1070e+08  0.01%   1.0    0s\n",
      "*    2     0               1    1.107011e+08 1.1070e+08  0.00%   1.0    0s\n",
      "\n",
      "Explored 3 nodes (136 simplex iterations) in 0.06 seconds (0.09 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 4: 1.10701e+08 1.10711e+08 1.2668e+08 1.336e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.107011262689e+08, best bound 1.107011262689e+08, gap 0.0000%\n",
      "[CHECK DFN] obj(x_ip)=1.10701e+08  ip_y=1.10701e+08  rel_err=5.663e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-2.41  std(mean)=579  min=-1e+03  max=1e+03\n",
      "  y: shape=(2000,)  mean=2.56e+08  std=9.14e+07  min=2.9e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=17,610 layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=0.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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XYLOEx0j+rH8/vvvFZFIgxd0LVH8uVXox5x+qN96662qaSTA6cdx1KhRMfNHBjcuvfRSRWxqY6as3md68+i9RGJxf/rpJ+Xao3sqETS4cuWVVypC7owzzjAUnAQNkGmhaUVFRVU/4GauMxLc1ImgWHE6n9988w2uuOIKPPbYY7jqqqsStt3MtuxC1xqda+oc6iHyrPrwww+VgSO65ugaIxG/d+9epQP622+/xayTBv5ocGnSpEnKMzLC/PnzlZwCNDBFz1nqbNG8999/P958800lfpLaQNum80rPMTUU90+d7a+++sqx48MwjDloUJdEnvq3JxLnTAPmJMpJnO/Zs0eZTvc33bMkyMlgQc8NK3lByGBCIp7iimlgkn7HbrnlFuWZpRbcgwYNUr6n2GB6NtOzjZ419MwiSktLlbbddtttyjromUa/x/QsonjpCDSoSIOD9Dyk/+lFA7ynnnqq8qyKPD8j39F0gvoAJ510kvK8JMH+8ccfK8J+2LBhujlrjJ6XWmgwmgY6jJ7ldIxfeuklpb9LfTPaJhlEIn3ByO+myO+1yOCxGei3nejZs2fVNIrRplhuGgCh/h7lE/r111/x+OOPK30o6ouqoeuG2v/111872jamBmLaNl5Dibi96r38fn/UvDSN3G+3bdsW5RrVvXt3JbY1wvnnn6/EAGtdWk855RQllpJilIiHHnpIWefUqVMTupf37t07yhX7zz//VKZ/9NFHpvbXyJWUYjRpfY899ljMd+Qarnbbplhm+rx169aYecnlnNw1Ixx00EHysGHDYubbsmWLsg612zbtH7myUwyOEfHcy8k1/pprromZTu1Wu7hH3OAplljL1VdfrbgJRyDXI3In1oPmo/mdci8fMWKEEo+udrsiV/14rnXkFkvuxOvXr1fmo5gnq+7l5OIVid8mt/qIy/Jll11meOzpGqbjELlnKJaK4oTnz59v+T6jbRjNq34lcon+7rvvlJhuigUT4cUXX1TisiP3t55LPJ2bRo0aKbFkasg1j2Le1feJmeuMrluKO6PzqObpp59W1rF48eK4bTezLS1m3cufeOIJZVvq56CZZxUdQ3InpfnU1zrlCGjWrJl8+OGHV02j+4aWve+++3TvK3oeb9q0qWravHnzlPkp/EXtVklx+DT9888/j1kP5R+gGH6GYVIHPffp918dJnTrrbcq9+2K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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) = 8.480e-02 @ epoch 957\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.94829e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=1.94829e+08 x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -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 412 rows, 8870 columns and 17750 nonzeros\n",
      "Model fingerprint: 0xdcfddfe6\n",
      "Variable types: 8860 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-03, 1e+00]\n",
      "  Objective range  [9e+01, 5e+11]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [2e-02, 1e+01]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 3 rows and 4242 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 409 rows, 4628 columns, 9265 nonzeros\n",
      "Variable types: 4618 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 1.782510e+08\n",
      "\n",
      "Root relaxation: objective 1.619617e+08, 383 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 1.6196e+08    0    3 1.7825e+08 1.6196e+08  9.14%     -    0s\n",
      "H    0     0                    1.619662e+08 1.6196e+08  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (383 simplex iterations) in 0.03 seconds (0.05 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.61966e+08 1.78251e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.619661890554e+08, best bound 1.619617239265e+08, gap 0.0028%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=1.61966e+08  ip_y=1.61966e+08  rel_err=1.818e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-2.41  std(mean)=579  min=-1e+03  max=1e+03\n",
      "  y: shape=(2000,)  mean=2.56e+08  std=9.14e+07  min=2.9e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | MaxAffine ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=17,600 n_pieces=1600\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# ===================== Quadratic DATASET =====================\n",
    "N_SEEDS = 1\n",
    "\n",
    "VARY_DATASET_SEED = False\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "\n",
    "SILENCE_LOCAL_SEARCH = False\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "dataset_type = \"quadratic\"\n",
    "dataset_params = dict(\n",
    "    K=2000, dim=10, eigen_min=10, eigen_max=50.0,\n",
    "    x_min=-1000, x_max=1000, noise_std=0.0, seed=0\n",
    ")\n",
    "in_dim = int(dataset_params[\"dim\"])\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=5,\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",
    "dfnA_layer_sizes = [5, 400, 6]\n",
    "assert dfnA_layer_sizes[0] + dfnA_layer_sizes[-1] == in_dim + 1, \"Need |L1|+|LK| = dim+1 for A_fixed=I\"\n",
    "\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=dfnA_layer_sizes,\n",
    "    p_list=[1, 1],\n",
    "    seed=0,\n",
    "    alpha=5e-3,\n",
    "    beta=0.0,\n",
    "    A_fixed=np.eye(in_dim, dtype=np.float32),  # shape (dim, dim)\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",
    "\n",
    "time_limit = 500\n",
    "x0    = np.array([5,-2,1,-1,7,3,0,2,-3,-1], dtype=int)\n",
    "xmin  = np.full(in_dim, -100, dtype=int)\n",
    "xmax  = np.full(in_dim,  100, dtype=int)\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",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e1000bc1-6ad1-4e81-a1e5-e8b71262b2ae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17338b1f-eb58-4251-adbe-4c6f6da0343d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fdc998c-5ecd-4cdd-bef1-44ec947693c6",
   "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
}
