{
 "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",
    "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",
    "    # ---- 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",
    "    train_loader = DataLoader(TensorDataset(XtrN, ytrN), batch_size=batch_sz, shuffle=True)\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",
    "    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": 9,
   "id": "569f2165",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_ip(model_type, model, scaler, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    if model_type == \"DFN\":\n",
    "        return solve_dfn_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MLP\":\n",
    "        return solve_mlp_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MaxAffine\":\n",
    "        return solve_maxaffine_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"LSET\":\n",
    "        return solve_lset_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise ValueError(model_type)\n",
    "\n",
    "\n",
    "def suppress_stdout(fn, *args, silence: bool = False, **kwargs):\n",
    "    if not silence:\n",
    "        return fn(*args, **kwargs), \"\"\n",
    "    buf = io.StringIO()\n",
    "    with contextlib.redirect_stdout(buf):\n",
    "        out = fn(*args, **kwargs)\n",
    "    return out, buf.getvalue()\n",
    "\n",
    "\n",
    "def make_obj(model, scaler, device, chunk: int = 4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def obj(Xraw):\n",
    "        Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "        if Xraw.dim() == 1:\n",
    "            Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "        outs = []\n",
    "        B = int(Xraw.shape[0])\n",
    "        for i in range(0, B, int(chunk)):\n",
    "            Xb = Xraw[i:i+chunk]\n",
    "            try:\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)  \n",
    "                y  = (yn * ys + ym).reshape(-1).detach().cpu() \n",
    "                if y.numel() != Xb.shape[0]:\n",
    "                    y = y.expand(Xb.shape[0]).contiguous()\n",
    "                outs.append(y)\n",
    "            except Exception as e:\n",
    "                obj._err_count += int(Xb.shape[0])\n",
    "                if obj._err_first is None:\n",
    "                    obj._err_first = repr(e)\n",
    "                outs.append(torch.full((int(Xb.shape[0]),), float(\"inf\"), device=\"cpu\"))\n",
    "\n",
    "        return torch.cat(outs, 0).numpy()\n",
    "\n",
    "    obj._err_count = 0\n",
    "    obj._err_first = None\n",
    "    return obj\n",
    "\n",
    "\n",
    "def safe_raw_mse(obj, Xraw, yraw):\n",
    "    yp = np.asarray(obj(Xraw), dtype=float).reshape(-1)\n",
    "    yt = yraw.detach().cpu().numpy().reshape(-1) if torch.is_tensor(yraw) else np.asarray(yraw, float).reshape(-1)\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "    mask = np.isfinite(yp)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions were non-finite (inf/nan)\"\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def safe_norm_mse(model, scaler, device, Xraw, yraw, *, chunk=4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "    if Xraw.dim() == 1:\n",
    "        Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "    yraw_t = yraw\n",
    "    if torch.is_tensor(yraw_t):\n",
    "        yraw_t = yraw_t.to(device=device, dtype=torch.float32)\n",
    "    else:\n",
    "        yraw_t = torch.as_tensor(yraw_t, dtype=torch.float32, device=device)\n",
    "    yraw_t = yraw_t.reshape(-1)\n",
    "\n",
    "    preds = []\n",
    "    B = int(Xraw.shape[0])\n",
    "    try:\n",
    "        with torch.no_grad():\n",
    "            for i in range(0, B, int(chunk)):\n",
    "                Xb = Xraw[i:i+chunk]\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)\n",
    "                if yn.numel() != Xb.shape[0]:\n",
    "                    yn = yn.expand(Xb.shape[0]).contiguous()\n",
    "                preds.append(yn.detach().cpu())\n",
    "    except Exception as e:\n",
    "        return np.nan, f\"model forward failed in safe_norm_mse: {repr(e)}\"\n",
    "\n",
    "    yp = torch.cat(preds, 0).numpy().reshape(-1)\n",
    "    yt = ((yraw_t - ym) / ys).detach().cpu().numpy().reshape(-1)\n",
    "\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "\n",
    "    mask = np.isfinite(yp) & np.isfinite(yt)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions or targets were non-finite (inf/nan)\"\n",
    "\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def t_to_best(hist, y_best):\n",
    "    for r in hist:\n",
    "        if abs(float(r.get(\"best_y\", np.inf)) - float(y_best)) < 1e-12:\n",
    "            return float(r.get(\"t\", float(\"nan\")))\n",
    "    return float(\"nan\")\n",
    "\n",
    "\n",
    "def check_ip_matches_obj(name, obj, x_ip, y_ip, *, strict: bool, tol: float):\n",
    "    y_obj = float(np.asarray(obj(np.asarray(x_ip)), dtype=float).reshape(-1)[0])\n",
    "    y_ip  = float(y_ip)\n",
    "    rel = abs(y_obj - y_ip) / (abs(y_obj) + 1e-12)\n",
    "    print(f\"[CHECK {name}] obj(x_ip)={y_obj:.6g}  ip_y={y_ip:.6g}  rel_err={rel:.3e}\")\n",
    "    if strict and rel > tol:\n",
    "        raise RuntimeError(f\"{name}: IP objective != obj() (rel_err={rel:.3e})\")\n",
    "    return rel\n",
    "\n",
    "\n",
    "def mean_se(x):\n",
    "    x = pd.to_numeric(pd.Series(x), errors=\"coerce\").to_numpy()\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = int(x.shape[0])\n",
    "    if n == 0:\n",
    "        return np.nan, np.nan\n",
    "    m = float(x.mean())\n",
    "    se = float(x.std(ddof=1) / np.sqrt(n)) if n > 1 else 0.0\n",
    "    return m, se\n",
    "\n",
    "\n",
    "def fmt_mean_se(m, se):\n",
    "    if not np.isfinite(m):\n",
    "        return \"nan\"\n",
    "    if not np.isfinite(se):\n",
    "        return f\"{m:.6g}\"\n",
    "    return f\"{m:.6g} ± {se:.3g}\"\n",
    "\n",
    "\n",
    "def repr_solution(xs: pd.Series, seeds=None):\n",
    "    xs = xs.dropna().astype(str)\n",
    "    xs = xs[xs != \"None\"]\n",
    "    if xs.empty:\n",
    "        return None\n",
    "\n",
    "    # With seed information: show per-seed if solutions differ\n",
    "    if seeds is not None:\n",
    "        df = pd.DataFrame({\"seed\": pd.Series(seeds), \"x\": xs})\n",
    "        df = df.dropna()\n",
    "        df[\"x\"] = df[\"x\"].astype(str)\n",
    "        if df.empty:\n",
    "            return None\n",
    "        if df[\"x\"].nunique() == 1:\n",
    "            return df[\"x\"].iloc[0]\n",
    "        df = df.sort_values(\"seed\")\n",
    "        return \"\\n\".join([f\"seed={int(r.seed)}: {r.x}\" for r in df.itertuples(index=False)])\n",
    "\n",
    "    # No seed info: keep compact\n",
    "    if xs.nunique() == 1:\n",
    "        return xs.iloc[0]\n",
    "    vc = xs.value_counts()\n",
    "    top = vc.index[0]\n",
    "    n_unique = int(vc.shape[0])\n",
    "    return f\"{top} (+{n_unique-1} other)\"\n",
    "    \n",
    "\n",
    "# -----------------------------\n",
    "# Ground-truth optimum solvers\n",
    "# -----------------------------\n",
    "\n",
    "def solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    Q  = np.asarray(gt[\"Q\"], float)\n",
    "    xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "    n  = int(xs.shape[0])\n",
    "    assert Q.shape == (n, n)\n",
    "\n",
    "    m = gp.Model(\"gt_quadratic\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    x = m.addVars(n, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(n):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(n)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    expr = gp.quicksum(float(Q[i, j]) * (x[i] - float(xs[i])) * (x[j] - float(xs[j])) for i in range(n) for j in range(n))\n",
    "    m.setObjective(expr, GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT quadratic solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(n)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_assignment(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    C = np.asarray(gt[\"C\"], float)\n",
    "    n_rows, n_cols = C.shape\n",
    "    k = int(sum_eq)\n",
    "    if k > n_cols:\n",
    "        raise RuntimeError(f\"sum_eq={k} exceeds number of columns={n_cols} (infeasible)\")\n",
    "\n",
    "    m = gp.Model(\"gt_assignment\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    z = m.addVars(n_rows, vtype=GRB.BINARY, name=\"z\")  # select row i\n",
    "    y = m.addVars(n_rows, n_cols, vtype=GRB.BINARY, name=\"y\")  # assign row i to col j\n",
    "\n",
    "    m.addConstr(gp.quicksum(z[i] for i in range(n_rows)) == k, name=\"k_rows\")\n",
    "    for i in range(n_rows):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for j in range(n_cols)) == z[i], name=f\"assign_row_{i}\")\n",
    "    for j in range(n_cols):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for i in range(n_rows)) <= 1, name=f\"assign_col_{j}\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(C[i, j]) * y[i, j] for i in range(n_rows) for j in range(n_cols)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT assignment solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(z[i].X)) for i in range(n_rows)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    N  = int(gt[\"N\"])\n",
    "    SS = int(gt[\"SS\"])\n",
    "    TT = int(gt[\"TT\"])\n",
    "    src  = np.asarray(gt[\"src\"], np.int64)\n",
    "    dst  = np.asarray(gt[\"dst\"], np.int64)\n",
    "    cost = np.asarray(gt[\"cost\"], float)\n",
    "    cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "    idxSS = np.asarray(gt[\"idxSS\"], np.int64)\n",
    "    idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "    E = int(src.shape[0])\n",
    "    k = int(idxSS.shape[0])\n",
    "    assert idxTT.shape[0] == k, \"Expect idxSS and idxTT to be same length\"\n",
    "\n",
    "    out_edges = [[] for _ in range(N)]\n",
    "    in_edges  = [[] for _ in range(N)]\n",
    "    for e in range(E):\n",
    "        out_edges[int(src[e])].append(e)\n",
    "        in_edges[int(dst[e])].append(e)\n",
    "\n",
    "    idxSS = idxSS.astype(int)\n",
    "    idxTT = idxTT.astype(int)\n",
    "    var_arc_to_i = {int(idxSS[i]): i for i in range(k)}\n",
    "    var_arc_to_i.update({int(idxTT[i]): i for i in range(k)})\n",
    "    var_arcs = sorted(var_arc_to_i.keys())\n",
    "\n",
    "    m = gp.Model(\"gt_mdvsp_true_opt\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    m.Params.NonConvex = 2\n",
    "\n",
    "    x = m.addVars(k, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(k):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(k)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    f = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, name=\"f\")\n",
    "\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            m.addConstr(f[e] <= x[i], name=f\"cap_var_{e}\")\n",
    "        else:\n",
    "            m.addConstr(f[e] <= float(cap0[e]), name=f\"cap_fix_{e}\")\n",
    "\n",
    "    F = m.addVar(vtype=GRB.CONTINUOUS, lb=0.0, name=\"F\")\n",
    "\n",
    "    # flow conservation: out - in = F at SS, = -F at TT, else 0\n",
    "    for v in range(N):\n",
    "        out_sum = gp.quicksum(f[e] for e in out_edges[v])\n",
    "        in_sum  = gp.quicksum(f[e] for e in in_edges[v])\n",
    "        rhs = F if v == SS else (-F if v == TT else 0.0)\n",
    "        m.addConstr(out_sum - in_sum == rhs, name=f\"flow_{v}\")\n",
    "\n",
    "    y = m.addVars(N, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"y\")\n",
    "    m.addConstr(y[SS] == 1.0, name=\"ySS\")\n",
    "    m.addConstr(y[TT] == 0.0, name=\"yTT\")\n",
    "\n",
    "    z = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"z\")\n",
    "    for e in range(E):\n",
    "        m.addConstr(z[e] >= y[int(src[e])] - y[int(dst[e])], name=f\"dual_{e}\")\n",
    "\n",
    "    dual_obj = gp.QuadExpr()\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            # bilinear term: x_i * z_e\n",
    "            dual_obj += x[i] * z[e]\n",
    "        else:\n",
    "            dual_obj += float(cap0[e]) * z[e]\n",
    "    m.addConstr(F == dual_obj, name=\"strong_duality\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(cost[e]) * f[e] for e in range(E)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT mdvsp true-opt failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(k)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status), \"F\": float(F.X)}\n",
    "    \n",
    "\n",
    "\n",
    "def solve_true_opt(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    \"\"\"Top-level dispatcher for ground-truth optimum.\"\"\"\n",
    "    if not isinstance(gt, dict):\n",
    "        raise RuntimeError(\"No ground-truth structure found (gt must be a dict).\")\n",
    "    t = gt.get(\"type\", None)\n",
    "    if t == \"quadratic\":\n",
    "        return solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"assignment\":\n",
    "        return solve_true_opt_assignment(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"mdvsp\":\n",
    "        return solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise RuntimeError(f\"Unknown gt type: {t}\")\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# Benchmark runner\n",
    "# -----------------------------\n",
    "def run_benchmark(\n",
    "    *,\n",
    "    dataset_type: str,\n",
    "    dataset_params: dict,\n",
    "    runs: list[tuple[str, str, dict]],\n",
    "    train_base: dict,\n",
    "    lr_map: dict,\n",
    "    x0: np.ndarray,\n",
    "    xmin: np.ndarray,\n",
    "    xmax: np.ndarray,\n",
    "    delta: int,\n",
    "    sum_eq: int,\n",
    "    n_seeds: int = 1,\n",
    "    vary_dataset_seed: bool = False,\n",
    "    vary_model_init_seed: bool = True,\n",
    "    strict_ip_check: bool = False,\n",
    "    ip_check_tol: float = 1e-4,\n",
    "    silence_local_search: bool = False,\n",
    "    allow_plots_multi_seed: bool = True,\n",
    "    time_limit=None,\n",
    "):\n",
    "    seeds = list(range(int(n_seeds)))\n",
    "\n",
    "    learn_rows, opt_rows, spec_rows, fail_rows = [], [], [], []\n",
    "    gt_rows = []\n",
    "\n",
    "    gt_cache_by_seed = {}\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"\\n\\n===================== SEED {seed} =====================\")\n",
    "\n",
    "        for name, model_type, model_params_base in runs:\n",
    "            # ---- per-run params ----\n",
    "            dp = dict(dataset_params)\n",
    "            if vary_dataset_seed and \"seed\" in dp:\n",
    "                dp[\"seed\"] = int(seed)\n",
    "\n",
    "            mp = dict(model_params_base)\n",
    "            if vary_model_init_seed and \"seed\" in mp:\n",
    "                mp[\"seed\"] = int(seed)\n",
    "\n",
    "            tp = dict(train_base)\n",
    "            tp[\"seed\"] = int(seed)\n",
    "            tp[\"lr\"] = float(lr_map[model_type])\n",
    "\n",
    "            # avoid plot spam unless explicitly allowed\n",
    "            if (n_seeds > 1) and (tp.get(\"plot_every\", 0) not in (0, None)) and (not allow_plots_multi_seed):\n",
    "                tp[\"plot_every\"] = 0\n",
    "\n",
    "            # ---- TRAIN ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                out = generate_and_train_simple(dataset_type, dp, model_type, mp, tp)\n",
    "            except Exception as e:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=repr(e)))\n",
    "                learn_rows.append(dict(seed=seed, model=name, train_time=np.nan, best_epoch=np.nan,\n",
    "                                       best_val=np.nan, test=np.nan, train_err=repr(e)))\n",
    "                continue\n",
    "            train_time = time.perf_counter() - t0\n",
    "\n",
    "            if isinstance(out, tuple) and len(out) == 4:\n",
    "                model, data, hist, spec = out\n",
    "            elif isinstance(out, tuple) and len(out) == 3:\n",
    "                model, data, hist = out\n",
    "                n_params = sum(p.numel() for p in model.parameters())\n",
    "                spec = dict(n_params=int(n_params), extra=\"\", train_params=tp)\n",
    "            else:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=f\"Unexpected return: {type(out)}\"))\n",
    "                continue\n",
    "\n",
    "            # ---- model spec (seed 0 only) ----\n",
    "            if seed == seeds[0]:\n",
    "                spec_rows.append(dict(\n",
    "                    model=name,\n",
    "                    n_params=int(spec.get(\"n_params\", np.nan)),\n",
    "                    details=str(spec.get(\"extra\", \"\")),\n",
    "                    lr=float(spec.get(\"train_params\", {}).get(\"lr\", tp[\"lr\"])),\n",
    "                    batch_size=int(spec.get(\"train_params\", {}).get(\"batch_size\", tp[\"batch_size\"])),\n",
    "                    epochs=int(spec.get(\"train_params\", {}).get(\"epochs\", tp[\"epochs\"])),\n",
    "                ))\n",
    "\n",
    "            device = data[\"device\"]\n",
    "            scaler = data[\"scaler\"]\n",
    "            obj = make_obj(model, scaler, device, chunk=int(tp.get(\"plot_chunk\", 4096)))\n",
    "            gt = data.get(\"true\", None)\n",
    "\n",
    "            # ---- compute GT optimum (once per seed) ----\n",
    "            if seed not in gt_cache_by_seed:\n",
    "                t_gt0 = time.perf_counter()\n",
    "                try:\n",
    "                    x_gt, y_gt, gt_info = solve_true_opt(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=False)\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    # evaluate with the existing helper to be extra sure\n",
    "                    y_gt_check = float(eval_true_obj(gt, x_gt))\n",
    "                    if np.isfinite(y_gt_check) and abs(y_gt_check - float(y_gt)) / (abs(float(y_gt_check)) + 1e-12) > 1e-6:\n",
    "                        fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT_CHECK\",\n",
    "                                              error=f\"gt solver mismatch: solver={y_gt:.6g} eval_true_obj={y_gt_check:.6g}\"))\n",
    "                    gt_cache_by_seed[seed] = dict(x=str(np.asarray(x_gt, int).tolist()),\n",
    "                                                  true_y=float(y_gt_check if np.isfinite(y_gt_check) else y_gt),\n",
    "                                                  runtime=float(gt_time),\n",
    "                                                  err=None)\n",
    "                except Exception as e:\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    gt_cache_by_seed[seed] = dict(x=None, true_y=np.nan, runtime=float(gt_time), err=repr(e))\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT\", error=repr(e)))\n",
    "\n",
    "            # ---- learning metrics: best val (normalized) + test loss (normalized) ----\n",
    "            test_norm, err_te = safe_norm_mse(model, scaler, device, data['raw']['Xte'], data['raw']['yte'], chunk=int(tp.get('plot_chunk', 4096)))\n",
    "            if err_te:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"EVAL_TEST\", error=err_te))\n",
    "\n",
    "            if obj._err_count > 0:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"OBJ\",\n",
    "                                      error=f\"obj() had {obj._err_count} forward failures; first={obj._err_first}\"))\n",
    "\n",
    "            val_curve = np.asarray(hist.get(\"val_mse_norm\", []), dtype=float)\n",
    "            best_ep = int(np.argmin(val_curve) + 1) if val_curve.size else np.nan\n",
    "            best_val = float(np.min(val_curve)) if val_curve.size else np.nan\n",
    "\n",
    "            learn_rows.append(dict(\n",
    "                seed=seed, model=name,\n",
    "                train_time=float(train_time),\n",
    "                best_epoch=best_ep,\n",
    "                best_val=float(best_val),\n",
    "                test=float(test_norm) if np.isfinite(test_norm) else np.nan,\n",
    "                train_err=(err_te),\n",
    "            ))\n",
    "\n",
    "            # ---- LOCAL SEARCH ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                obj_ls = obj\n",
    "                (ls_out, _ls_log) = suppress_stdout(\n",
    "                    local_search_l1_int, obj_ls, x0, xmin, xmax,\n",
    "                    delta=delta, sum_eq=sum_eq, print_every=0,\n",
    "                    silence=silence_local_search\n",
    "                )\n",
    "                x_best, y_best, ls_hist = ls_out\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=str(np.asarray(x_best, int).tolist()),\n",
    "                    y=float(y_best),\n",
    "                    true_y=float(eval_true_obj(gt, x_best)),\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=float(t_to_best(ls_hist, y_best)),\n",
    "                    iters=int(len(ls_hist) - 1),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=np.nan, iters=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"LS\", error=repr(e)))\n",
    "\n",
    "            # ---- IP SOLVE (learned objective) ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                x_ip, y_ip, info = solve_ip(\n",
    "                    model_type, model, scaler, xmin, xmax, sum_eq,\n",
    "                    time_limit=time_limit, verbose=True\n",
    "                )\n",
    "                ip_time = time.perf_counter() - t0\n",
    "\n",
    "                rel_err = check_ip_matches_obj(name, obj, x_ip, y_ip, strict=strict_ip_check, tol=ip_check_tol)\n",
    "                if rel_err > ip_check_tol:\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"IP_CHECK\",\n",
    "                                          error=f\"rel_err={rel_err:.3e} (tol={ip_check_tol})\"))\n",
    "\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=str(np.asarray(x_ip, int).tolist()),\n",
    "                    y=float(y_ip),\n",
    "                    true_y=float(eval_true_obj(gt, x_ip)),\n",
    "                    runtime=float(ip_time),\n",
    "                    status=(info.get(\"status\") if isinstance(info, dict) else None),\n",
    "                    gap=(info.get(\"gap\") if isinstance(info, dict) else None),\n",
    "                    ip_rel_err=float(rel_err),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ip_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ip_time),\n",
    "                    status=None, gap=None, ip_rel_err=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"IP\", error=repr(e)))\n",
    "\n",
    "    # ---- build DFs ----\n",
    "    spec_df  = pd.DataFrame(spec_rows).drop_duplicates(\"model\").sort_values(\"model\").reset_index(drop=True)\n",
    "    learn_df = pd.DataFrame(learn_rows).sort_values([\"model\", \"seed\"]).reset_index(drop=True)\n",
    "    opt_df   = pd.DataFrame(opt_rows).sort_values([\"model\", \"seed\", \"method\"]).reset_index(drop=True)\n",
    "\n",
    "    fail_df = pd.DataFrame(fail_rows)\n",
    "    if fail_df.empty:\n",
    "        fail_df = pd.DataFrame(columns=[\"seed\", \"model\", \"stage\", \"error\"])\n",
    "    else:\n",
    "        for c in [\"stage\", \"model\", \"seed\"]:\n",
    "            if c not in fail_df.columns:\n",
    "                fail_df[c] = np.nan\n",
    "        fail_df = fail_df.sort_values([\"stage\", \"model\", \"seed\"]).reset_index(drop=True)\n",
    "\n",
    "    gt_df = pd.DataFrame([dict(seed=s, **d) for s, d in sorted(gt_cache_by_seed.items())]).sort_values(\"seed\")\n",
    "\n",
    "    # ---- per-seed gaps ----\n",
    "    gap_seed_df = pd.DataFrame(columns=[\"seed\", \"model\", \"ls_vs_ip_pct\", \"ip_true_vs_gt_pct\"])\n",
    "    if not opt_df.empty:\n",
    "        pivot_y = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"y\", aggfunc=\"first\")\n",
    "        pivot_true = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"true_y\", aggfunc=\"first\")\n",
    "\n",
    "        if (\"LS\" in pivot_y.columns) and (\"IP\" in pivot_y.columns):\n",
    "            ls_vs_ip = 100.0 * (pivot_y[\"LS\"] - pivot_y[\"IP\"]) / (np.abs(pivot_y[\"IP\"]) + 1e-12)\n",
    "        else:\n",
    "            ls_vs_ip = pd.Series(index=pivot_y.index, dtype=float)\n",
    "\n",
    "        # IP true vs GT optimum true\n",
    "        gt_true = gt_df.set_index(\"seed\")[\"true_y\"] if not gt_df.empty else pd.Series(dtype=float)\n",
    "        ip_true_vs_gt = []\n",
    "        for (seed, model), row in pivot_true.iterrows():\n",
    "            ipt = float(row.get(\"IP\", np.nan))\n",
    "            gtt = float(gt_true.get(seed, np.nan))\n",
    "            if np.isfinite(ipt) and np.isfinite(gtt):\n",
    "                ip_true_vs_gt.append(((seed, model), 100.0 * (ipt - gtt) / (abs(gtt) + 1e-12)))\n",
    "            else:\n",
    "                ip_true_vs_gt.append(((seed, model), np.nan))\n",
    "        ip_true_vs_gt = pd.Series({k: v for k, v in ip_true_vs_gt})\n",
    "\n",
    "        gap_seed_df = pd.DataFrame({\n",
    "            \"seed\": [k[0] for k in ip_true_vs_gt.index],\n",
    "            \"model\": [k[1] for k in ip_true_vs_gt.index],\n",
    "            \"ls_vs_ip_pct\": [float(ls_vs_ip.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "            \"ip_true_vs_gt_pct\": [float(ip_true_vs_gt.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "        })\n",
    "\n",
    "    # ---- LEARNING SUMMARY (mean ± SE over seeds) ----\n",
    "    learn_sum_rows = []\n",
    "    for model in sorted(learn_df[\"model\"].unique()):\n",
    "        sub = learn_df[learn_df[\"model\"] == model]\n",
    "        m, se = mean_se(sub[\"train_time\"]); train_time_s = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"best_val\"]);   best_val_s   = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"test\"]);       test_s       = fmt_mean_se(m, se)\n",
    "        learn_sum_rows.append(dict(model=model, train_time=train_time_s, best_val=best_val_s, test=test_s))\n",
    "    learn_summary_df = pd.DataFrame(learn_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- OPTIMIZATION SUMMARY ----\n",
    "    opt_sum_rows = []\n",
    "    gt_x_repr = (repr_solution(gt_df.get(\"x\", pd.Series(dtype=str)), gt_df.get(\"seed\", None))\n",
    "                if not gt_df.empty else None)\n",
    "    m, se = mean_se(gt_df.get(\"true_y\", pd.Series(dtype=float))); gt_true_s = fmt_mean_se(m, se)\n",
    "    m, se = mean_se(gt_df.get(\"runtime\", pd.Series(dtype=float))); gt_time_s = fmt_mean_se(m, se)\n",
    "\n",
    "    for model in sorted(opt_df[\"model\"].unique()):\n",
    "        sub = opt_df[opt_df[\"model\"] == model]\n",
    "        row = {\"model\": model}\n",
    "\n",
    "        ls = sub[sub[\"method\"] == \"LS\"]\n",
    "        ip = sub[sub[\"method\"] == \"IP\"]\n",
    "\n",
    "        row[\"LS_x\"] = repr_solution(ls[\"x\"], ls.get(\"seed\", None))\n",
    "        m, se = mean_se(ls[\"y\"]);       row[\"LS_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"true_y\"]);  row[\"LS_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"runtime\"]); row[\"LS_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"IP_x\"] = repr_solution(ip[\"x\"], ip.get(\"seed\", None))\n",
    "        m, se = mean_se(ip[\"y\"]);       row[\"IP_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"true_y\"]);  row[\"IP_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"runtime\"]); row[\"IP_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"GT_x\"] = gt_x_repr\n",
    "        row[\"GT_true_y\"] = gt_true_s\n",
    "        row[\"GT_time\"] = gt_time_s\n",
    "\n",
    "        gsub = gap_seed_df[gap_seed_df[\"model\"] == model] if not gap_seed_df.empty else pd.DataFrame()\n",
    "        m, se = mean_se(gsub.get(\"ls_vs_ip_pct\", pd.Series(dtype=float))); row[\"LS_vs_IP_%\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(gsub.get(\"ip_true_vs_gt_pct\", pd.Series(dtype=float))); row[\"IP_true_vs_GT_%\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        opt_sum_rows.append(row)\n",
    "\n",
    "    opt_summary_df = pd.DataFrame(opt_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- Print tables ----\n",
    "    print(\"\\n=== MODEL SPECS (from seed 0 run) ===\")\n",
    "    if not spec_df.empty:\n",
    "        print(spec_df[[\"model\", \"n_params\", \"details\", \"lr\", \"batch_size\", \"epochs\"]].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== LEARNING SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not learn_summary_df.empty:\n",
    "        print(learn_summary_df.to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not opt_summary_df.empty:\n",
    "        cols = [\n",
    "            \"model\",\n",
    "            \"LS_x\", \"LS_y\", \"LS_true_y\", \"LS_time\",\n",
    "            \"IP_x\", \"IP_y\", \"IP_true_y\", \"IP_time\",\n",
    "            \"GT_x\", \"GT_true_y\", \"GT_time\",\n",
    "            \"LS_vs_IP_%\", \"IP_true_vs_GT_%\",\n",
    "        ]\n",
    "        print(opt_summary_df[cols].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== FAILURES / WARNINGS (if any) ===\")\n",
    "    if fail_df.shape[0] == 0:\n",
    "        print(\"None\")\n",
    "    else:\n",
    "        print(fail_df.to_string(index=False))\n",
    "\n",
    "    return spec_df, learn_df, opt_df, fail_df, learn_summary_df, opt_summary_df, gt_df\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e88e7a1f",
   "metadata": {},
   "source": [
    "## Tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "8edf3f97",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=-0.122  std(mean)=580  min=-1e+03  max=1e+03\n",
      "  y: shape=(1000,)  mean=2.58e+08  std=9.19e+07  min=4.57e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | MLP ===\n",
      "  data: N=1000  train/val/test=700/150/150  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": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA5O1JREFUeJzsnQd4FNXXxk8SUggl9N5774ggIqDSrKAIVuwFrFj52/3sFQtgx65YABsqiNJEpPfeey+BAOnf897J3b0ze2d2drObbDbn9zwLmdkpd+7Mzsx7T4vJzc3NJYZhGIZhGIZhGIZhQk5s6DfJMAzDMAzDMAzDMAyLboZhGIZhGIZhGIYJI2zpZhiGYRiGYRiGYZgwwaKbYRiGYRiGYRiGYcIEi26GYRiGYRiGYRiGCRMsuhmGYRiGYRiGYRgmTLDoZhiGYRiGYRiGYZgwwaKbYRiGYRiGYRiGYcIEi26GYRiGYRiGYRiGCRMsugPgk08+oZiYGNvPjBkzqDDZunWraMerr74a9DYee+wxuvDCC6lmzZpiW9dff73tsps3b6ZBgwZRuXLlqHTp0nT++efT4sWLtct+88031K5dO0pKSqIaNWrQvffeSydOnPBZDvPwHZbBslgH69rx008/UYkSJejAgQNievTo0aJN9evXF+3v2bOn7br79+8Xx1epUiVKTk6mrl270vTp07XL/vnnn+J7LIflsR7Wt5KZmUlPP/001atXjxITE6lZs2b09ttvk1uw3lNPPUWFdW3jGnKznN31npubS40aNdL2/aFDh2jUqFHUokULKlWqFKWkpIj+ufbaa2n58uUF+jv77LPPaOjQodS0aVOKjY0V/R4oOK9oP84zrjecd5x/FfSB07Hs3bvXtHxaWho98cQT1KRJE7HdihUrUq9evWjDhg0Uatxc04sWLaIRI0ZQ69atqUyZMlS1alU677zz6K+//gpoX88884w47zk5OVQUefzxx6lDhw5Ftv0MU9QZOHAglSxZko4ePWq7zNVXX03x8fG0b98+19vFfbgwnrn+eP7552ny5Mk+81evXi3a6+9ZHQ7w3KxcuTIdP368wPa5c+dO8U54zjnniHdNnC+8I1hJTU2l5557Tjxzq1WrJt5J8dx66aWX6PTp0z7Lb9y4Ubx71KlTR1xXDRs2pJEjR4r3FBUsc+mll4b1GJliRC7jmvHjx+eiy/D/v//+6/M5duxYofbmli1bRPteeeWVoLeRnJyce+aZZ+befvvtuQkJCbnDhg3TLrd///7cGjVq5LZs2TL3hx9+yP31119zu3fvnlumTJnctWvXmpb94osvRLtuvvnm3L/++iv33XffzU1JSck9//zzfbaLeeXKlRPLYFmsg3W//PJLbTuuu+663F69enmmmzZtmtuhQ4fcG2+8Mbdy5cq555xzjna906dP57Zq1Sq3Vq1aon1Tp07NveSSS3JLlCiRO2PGDNOymMZ8fI/lsHzNmjXF+tiOCtqbmJiY+/LLL+f+/fffuY888khuTExM7nPPPZfrhrp16+Y++eSTuYV1beMacrMczvM111zj8z2OWX6v9v3x48dzGzVqlFutWrXc1157LffPP//M/fnnn8XfZ511Vu6nn35aoL+z8847T5w/HAPahX4PhGeffVac11GjRoljxvnG7+WWW24xLbdq1Sqf9k+fPj03Pj5e/M5U0EedOnUSv6u33npLXHc//vhj7sMPP5y7dOnS3FDi9pq+//77RZtef/110e6ffvopd8CAAeL8qOfMiV27duWWKlUq97vvvsstqhw9elTclz7++OPCbgrDFEvwvMB9Z8yYMba/0ZIlS+ZeeumlAW0X2yyMZ64/cM/UvX/hPoo247lTkKSlpYlnRH7eL4MBx1mpUiXxzL7yyis97wZWVqxYIZa77777xHMTz6unnnoqNykpKffcc8/NzcnJMb2/VqxYMbd+/fq5n3zyiXjXxLtI6dKlc9u1a5ebnZ3tWXbjxo3iWYntMUx+YdEdAFIMLFiwIDcSCYXoVm82djd98OCDDwrhsHXrVs88iCHc9K644grPvKysrNzq1avn9unTx7Q+RDTaOmXKFM88CHfM++qrr3yEOIQItqWSkZEhXoTfeecdbfsxIGAnuvHgxr7mzp3rmZeZmZnbokWL3DPOOMO0bOfOncV8fC/5559/xPpjx471zFu5cqUQYs8//7xpfQgxvAwcOnQoN1pENwYXcExWAQwR27VrV5++h1jBeni46VDPW0H8ztT9XXDBBQGJ7oMHD4oH+a233mqaj4EVnH8IbSfwkMfxffjhh6b599xzj/jNbdq0KTfcuL2m9+3b57Mufodt2rTJbdiwoat9PfTQQ+JlTe3zgnxRDBV33nlnbpMmTUwvbwzDFAy47+A9oGPHjtrvx40bJ+5fEOeBwKLb3b0SzwU8944cOZJbkKjPDbwT2InuEydOiI8VvA9jndmzZ3vmffDBB2IeBv9V8O6G+YsXLzbNv/DCC7VGIoYJFHYvDxNwgbnzzjvpvffe87iKwr1S5yq9cuVKuuSSS6h8+fIel+pPP/3UZzm4Vd1///3UoEEDsb0qVarQgAEDaO3atT7Lvv7668LlFS42cCGdN2+eq3bD1dYNkyZNot69e1PdunU988qWLStcu3/++WfKysoS87DfPXv20A033GBaf/DgwaJt2I66TczDdypYd/fu3fTff/+Z5sMV/NixY8LtLJj2w7UYfSOBm/o111xD8+fPp127dol5+H/BggXCxQjfS7p16ybOq9p+uILhGW49VkyfOnWKfv/9dwoFcKHH9QX3KCsPP/wwJSQk0MGDB8X0tGnTxLVVq1YtcW3B9fu2227zfB8sV155pfj/66+/9szDufjhhx/oxhtv9FleumxVr15duz235y1U5Gd/OI9wV9OdZ5x/nUugykcffSSu8yFDhnjmnTx5kj788ENx7eP37Q+4peM84rzifEv3dvm7cyKQaxr3GCtxcXHUsWNH2rFjh999ZWRkiOO96qqrTH2uhsK4uVchjES6wsPNHaEs//77r2kZuFximwhxufzyy8X9FC6DAOEDCJv55ZdfqH379sKdsHnz5mIawF0R0wh7OOOMM2jhwoU+bUB/rV+/nv7++2+/x80wTGjBfWfYsGEi5GXFihU+348fP148X/r37y/CzYYPHy7euXBfwX0M7yuzZ88Oev/jxo2jtm3biu3hHoTQov/9738+99Zbb72VateuLe7LCJPDvUi6u+O5gXc4vOMhvKpChQrivvbjjz+atoP7GEKN8B4oQ5HgNo37lHw/QtiR/E51t0bY0Lnnnivex3C/POuss3zC5pzulU7Hf9FFFwkXb9277ueffy7uodgn+kneWwvqWY17Nz5WcD8H6vMKIQgA50BFHhvelaz3fvTrpk2bgjgChvHCojsIsrOzxcut+sE83YviW2+9JeIZv//+eyFQIVbwt2TdunXiZXfVqlVi2YkTJ4oHBeIrX375Zc9yiKHp3r27EPF4uYewfffdd8VLMkStypgxY4TYgjj78ssvxc0b4hyiKBRAQOLm06ZNG5/vMA/fI95bDijI+Sq46eGhJb+Xy+KmrQoBdV11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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) = 9.269e-03 @ epoch 358\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.49165e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "iter=1  t=0.00s  best_y=1.49164e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -2, -2]\n",
      "iter=2  t=0.00s  best_y=1.49162e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -1, -3]\n",
      "iter=3  t=0.00s  best_y=1.49161e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 0, -4]\n",
      "iter=4  t=0.00s  best_y=1.49159e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 1, -5]\n",
      "iter=5  t=0.01s  best_y=1.49158e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 2, -6]\n",
      "iter=6  t=0.01s  best_y=1.49156e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 3, -7]\n",
      "iter=7  t=0.01s  best_y=1.49155e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 4, -8]\n",
      "iter=8  t=0.01s  best_y=1.49153e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 5, -9]\n",
      "iter=9  t=0.01s  best_y=1.49152e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 6, -10]\n",
      "STOP: local minimum. best_y=1.49152e+08 x=[5, -2, 1, -1, 7, 3, 0, 2, 6, -10]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\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  300\n",
      "\n",
      "Optimize a model with 1282 rows, 779 columns and 20107 nonzeros\n",
      "Model fingerprint: 0x9ebd1c32\n",
      "Variable types: 513 continuous, 266 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [3e-07, 8e+00]\n",
      "  Objective range  [9e+07, 9e+07]\n",
      "  Bounds range     [2e-02, 1e+01]\n",
      "  RHS range        [2e-03, 1e+01]\n",
      "Presolve removed 1256 rows and 746 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 26 rows, 33 columns, 241 nonzeros\n",
      "Variable types: 21 continuous, 12 integer (2 binary)\n",
      "Found heuristic solution: objective 1.481006e+08\n",
      "Found heuristic solution: objective 1.475579e+08\n",
      "\n",
      "Root relaxation: objective 1.462593e+08, 35 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.4626e+08    0    2 1.4756e+08 1.4626e+08  0.88%     -    0s\n",
      "H    0     0                    1.462758e+08 1.4626e+08  0.01%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 1\n",
      "  Relax-and-lift: 1\n",
      "\n",
      "Explored 1 nodes (35 simplex iterations) in 0.01 seconds (0.01 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 1.46276e+08 1.47558e+08 1.48101e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.462757646641e+08, best bound 1.462724286768e+08, gap 0.0023%\n",
      "[CHECK MLP] obj(x_ip)=1.46276e+08  ip_y=1.46276e+08  rel_err=3.189e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=-0.122  std(mean)=580  min=-1e+03  max=1e+03\n",
      "  y: shape=(1000,)  mean=2.58e+08  std=9.19e+07  min=4.57e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  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+naQAAvbxJREFUeJzs3Qd8E/X7B/BPki5oS6HsUfbeUwUBGcpSlCGC4hYVRUVx7/F3Txzg3v5UVMCNgAxBUdmzbNmrzJbujPu/nm9IekmTNEnTpk0/79crJLlc7q5JuLvnvs/3+Ro0TdNARERERERERCFnDP0iiYiIiIiIiIhBNxEREREREVEJYks3ERERERERUQlh0E1ERERERERUQhh0ExEREREREZUQBt1EREREREREJYRBNxEREREREVEJYdBNREREREREVEIYdBMRERERERGVEAbdfvrkk09gMBi83hYvXoxw2r17t9qOl19+OehlPPLII7joootQv359taxrr73W67z//fcfRo0ahapVqyIhIQEXXHABVq9e7XHer7/+Gp07d0ZcXBzq1auHO++8E5mZmYXmk2nymswj88p75L3e/Pjjj4iKisLRo0fV86lTp6ptatKkidr+fv36eX1vWlqa+vtq1KiBypUro2fPnliwYIHHeX///Xf1uswn88v75P3uzGYznnzySTRu3BixsbFo3bo13nzzTfhL3vfEE08gXL9t+Q35M5+337umaWjevLnHz/748eN48MEH0bZtW8THxyMpKUl9PldddRXWr19fqv/PPvvsM4wbNw6tWrWC0WhUn3ug5HuV7ZfvWX5v8r3L9683a9YsXH755eozqVSpklrP+PHjsX37do//d73dhgwZglDz5ze9atUqTJo0CR06dEBiYiJq166N888/HwsXLgxoXU899ZT63m02G8qjRx99FF27di23208UCUaOHKn2o6dOnfI6j+xfo6OjceTIEb+XK/vYcBx3i/Lss8/i+++/LzQ9NTVVbW9Rx+uSIMfOmjVr4vTp06W2zv3796vzwvPOO0+db8r3JecJ7jIyMvDMM8+oc486deqo81I5dr3wwgvIzc0tNP+OHTvU+UfDhg3V76pZs2aYMmWKOlfRk3lGjBhRon8jVSAa+eXjjz/W5OOS+7///rvQLT09Payf5K5du9T2vfTSS0Evo3Llyto555yjTZw4UYuJidGuueYaj/OlpaVp9erV09q1a6fNnDlT++WXX7TevXtriYmJ2pYtW1zm/eKLL9R2TZgwQVu4cKH2zjvvaElJSdoFF1xQaLkyrWrVqmoemVfeI+/93//+53E7rr76aq1///7O561atdK6du2qXX/99VrNmjW18847z+P7cnNztfbt22sNGjRQ2zdv3jztkksu0aKiorTFixe7zCvPZbq8LvPJ/PXr11fvl+XoyfbGxsZqL774orZo0SLtgQce0AwGg/bMM89o/mjUqJH2+OOPa+H6bctvyJ/55Hu+8sorC70uf7Pjdf1nf/r0aa158+ZanTp1tFdeeUX7/ffftZ9++kk9Pvfcc7VPP/20VP+fnX/++er7k79Btks+90A8/fTT6nt98MEH1d8s37f8f7nxxhtd5jvrrLO0iy++WPvoo4/U7+jzzz/X2rRpoyUkJGgbN250zie/I09/6/33368+C/n/EEr+/qbvvvturXv37tqrr76qLViwQPvxxx+1YcOGqW3Sf2e+HDhwQIuPj9e+/fZbrbw6deqU2i/J90hE4SHHDNn3TJs2zev/00qVKmkjRowIaLmyzHAcd4si+01P52CyL5VtlmNPacrKylLHieKcYwZD/s4aNWqo4/bll1/uPD9wt2HDBjXfXXfdpf3www/qmPXEE09ocXFx2sCBAzWbzeZyDlu9enWtSZMm2ieffKLON+V8RI7NnTt31qxWq3PeHTt2qOOlLI+ouBh0+8kRDKxYsUIri0IRdOt3NN52+OLee+/VoqOjtd27dzunSTAkO7zLLrvMOc1isWh169bVBg0a5PJ+CaJlW3/99VfnNAncZdqXX35ZKBCXAF+WpZefn69OhN966y2P2y8XBLwF3XLQlnUtW7bMOc1sNmtt27ZVgZJejx491HR53eGvv/5S758+fbpzmgRREog9++yzLu+XQExOBI4fP65FStAtFxfkb3IPgCWI7dmzZ6HPXoIVeZ8c2DzRf2+l8f9Mv74LL7wwoKD72LFj6iB+0003uUyXCyvy/W/atMk57ciRIx6DUPm/c8MNNxS5rn79+qkLYaG+oOfvb9rT9sv/w44dO2rNmjXza1333XefOlHTf+aleZIYKrfddpvWsmVLlxM3Iio9su+Rc4Fu3bp5fP3tt99W+zAJzgPBoNu//aUcG+TYd/LkSa006Y8dcl7gLejO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MuwY4qs8kv7cUuDOMSoDEVFF9Morr6iLqMWpAl/eyHFLMpyCKfZK5I7p5URlBNPLiYiIiIgiD4NuIiIiIiIiohLC9HIiIiIiIiKiihR0jxw5EtWqVXOOv0dERERERERUHpXJ9PJFixapaoGffvopvvvuu4CLHhw8eBCJiYmqiA8REVFZJodhKU4kBeeMxjJ5LbzU8BhORESReAyPQhnUv39/LF68OKj3SsCdkpIS8m0iIiIqSfv27UODBg0q9IfMYzgREUXiMTyqJMY0femll7Bq1SocOnQIs2fPxogRI1zmmT59uppHXm/Xrh2mTp2KPn36hGT90sLt+MOrVKkSkmUSERGVlIyMDHWx2HH8qsh4DCciokg8hoc86M7KykKnTp1w3XXXYfTo0YVenzFjBu68804VeJ977rl49913MXToUKSmpqJhw4bFXr8jpVwCbgbdRERUXrBLFI/hREQUmcfwkAfdEkDLzZtXX30VN9xwAyZMmKCeSyv33Llz8fbbb+O5554L9eYQERERERERhU2pVmzJz89XaeeDBg1ymS7Ply1bFtQy8/LyVLO+/kZERERERERU4YLuY8eOwWq1onbt2i7T5fnhw4edzwcPHowxY8bg119/VR3SV6xY4XWZ0jqelJTkvLGIGhEREREREZUVUWUh511KreunSbq5vx588EFMmTKlUGd2IiIK7VBOkq1EgYuOjobJZOJHR0REVEGVatBdo0YNdeKhb9UWaWlphVq//RUbG6tuRERUMiTY3rVrlwq8KThVq1ZFnTp1WCyNiIioAirVoDsmJgbdunXD/PnzMXLkSOd0eX7JJZeU5qYQEZEfJBNJhneUC6aSRWQ0lmqvpIj4/LKzs9XFZVG3bt1wbxIRERGV96A7MzMTO3bscD6X1pG1a9ciOTlZDQkmqeBXXXUVunfvjp49e+K9997D3r17MXHixGKtd9q0aeomfcaJiCg0LBaLChrr1auHypUr82MNQqVKldS9BN61atViqjkREVEFE/Kge+XKlejfv7/zuaO/9TXXXINPPvkEY8eOxfHjx/HUU0+p1pP27durgmmNGjUq1nonTZqkbtKnWwqqERFR8TkuZEqmEgXPccHCbDYz6CYiIqpgQh509+vXT6XT+XLrrbeqGxERlQ/uBTCJnx8REVG4rdl7EruOZaFJjXh0aVgNZVVYqpeXN+7V1YmIiIiIiCh8np+zGe/88Z/z+cTzmuKBoW2KfF92vgWVY0o3DI6YijjSn7tt27bo0aNHyJb5/pL/MPCVxfhlw6GQLZOIiMqXxo0bY+rUqeHeDCIiItK1cOsDbiHPZbovP6w9gHOfX1jkfKEWMUG39OdOTU3FihUrQrbMxL0LcMPJqdi3Zn7IlklERCVPujrdeeedIVmWHFduuummkCyLiIiIik9SygOZnpFrxp1fr8Hkr9fiZLYZny7bjdLE9HIfztP+Rd2oRfhibxI07WqmmBMRRVC3ISkSFxVV9GGwZs2apbJNRERE5B/pw+3v9JW7T+DOGWux/2QOjAbgjoEtcFv/5ihNEdPSXRKqtxuo7tubN2BHWma4N4eIiPxw7bXX4o8//sDrr7+uLpbKTUbPkPu5c+eqIStjY2OxdOlS7Ny5E5dccglq166NhIQE1UXp999/95leLsv54IMPMHLkSFWVvEWLFvjxxx/53RAREZWSLg2rqT7cerec19SlmJrFasOr87fhsnf/VgF3SnIlfDuxJ+48vyWiTKUbBrOl24eYZn3UfXvDLvwvdTda1O5QWt8LEVGZbSHOMduHESttlaJNfmUcSbC9bds2NSSlDE8pNm3apO7vu+8+vPzyy2jatCmqVq2K/fv3Y9iwYXj66acRFxeHTz/9FMOHD8fWrVvRsGFDr+t48skn8eKLL+Kll17Cm2++ifHjx2PPnj1ITk4O4V9MRERE3kjRtMHt6nisXr73eDYmz1iDNXtPqeejutTHk5e0Q2JcNMIhKpIKqcnNMaZsSCQ1QEalBqiSsx9HU5cA/Rl0E1HFJgF328fmhmXdqU8N9qvaaFJSkhpXXFqh69Spo6Zt2bJF3UsQfsEFFzjnrV69Ojp16uR8LsH37NmzVcv1bbfd5rM1/fLLL1ePn332WRV4L1++HEOGDCnW30hERET+k0BbH2xL48Cs1Qfw2A8bkZVvRWJcFJ4e0R6XdK6PcIqY9PKSKKQmtIbnqvsqR/5BniU8rTtERBQaklqul5WVpVq/ZfQLafmWFHMJ0Pfu3etzOR07dnQ+jo+PR2JiItLS0ir01/T222+rz6VKlSrq1rNnT8yZMyfcm0VERBVEerYZt3+1Bnd/u04F3Gc1TsacyX3CHnBHVEt3SanSph+wdQa6IxW7j2WjVZ3EcG8SEVHYSIq3tDiHa93FJQGy3r333qv6eUvKefPmzVGpUiVceumlyM/P97mc6GjX9DRJe7fZbKjIGjRogOeff159jkJS9aW//Jo1a9CuXbtwbx4REUWwf/87jrtmrMXB9FyYjAbcdX4L3NKvuXpcFjDoLoKhcW9139HwHxYcOsKgm4gqNAku/UnxDjdJL/enu5EUU5NUcSmKJjIzM7F7d+kOIxIppC+83jPPPKNav//55x8G3UREVCLMVhum/r4N0xfvhKYBjapXxuvjuqBzSlWUJWX/zCncqjbEieg6SDYfRs7Ov4EupVtenoiIAicVx//9918VQEvKuLdWaGmVnTVrlgoY5YLCo48+WuFbrENBLnh8++23Kn1f0sy9ycvLUzeHjIyMkKyfiIgi365jWWrs7XX709Xzy7o3wGPD2yEhtuyFuBHTp7skHU3uqu5jDq8O96YQEZEf7rnnHphMJtVXW8bZ9tZH+7XXXkO1atXQq1cvFXgPHjwYXbva9/kUuA0bNqiLHDIk28SJE1VROvkOvHnuuedU4TvHLSUlhR87ERH5JMXSvlmxDxe+sVQF3FXiojDtiq548dJOZTLgFgZNtjrCqpfLUDHp6emqkEsobP/2MbTY9Dp+jx2I8x+cFZJlEhGVB7m5udi1axeaNGmihtSi0H+O0rorAWcoj1vhIn3h5QLHqVOnMHPmTDWeuYyZ7i3w9tTSLYF3JHwWREQUeqey8/HQ7A34dcNh9fycpsl49bLOqFe1Ulg+bn+P4WXzUkCQ1cvl5vjDQymhbgtgE1At96C6suLPOLFEREQVjfSldxRSk0rxMqKIjJv+7rvvepxfWsTlRkREVJRlO49hyox1OJyRiyijAXcPaoWb+jYtM8XSfImYoLskVWvQSt3Xx2Gk55hRtXJMuDeJiIiozJML1fqWbCIiokDlW2x4df42vLvEXiytaY14VSytQ4PQNrSWJAbdfoirZb9qX8dwEhvTTqJq49ol/b0QERGVKw899BCGDh2q0sNPnz6Nr7/+GosXL8Zvv/0W7k0jIqJyaufRTEz+eg02HrAX2rz8rBQ8elHbcjGSil752tpwqVQNWYZ4xGtZOL5/G8Cgm4iIyMWRI0dw1VVX4dChQ6qbV8eOHVXAfcEFF/CTIiKigDOlvl6xD0/9lIocsxVVK0fj+VEdMaR9HZRHDLr9YTDgREw9xOdtR9bhHQD6lPgXQ0REVJ58+OGH4d4EIiKKACey8vHAzPWYl3pEPT+3eXVVLK12lfJb0JVBt59y4xsAedthObmnZL8RIiIiIiKiCmjp9qO4+5t1SDudh2iTAfcNbo0bejeBsRwUS6sQQbd+yLCSYKvaEDgBRKV7HuuViIiIiIiIApdnseKl37bigz93qefNasbjjcu7oF298lMsrUIE3SU5ZJiIqdEE+A9IyDkQ8mUTERERERFVRNuPnMYdX6/F5kP2YmlXntMQDw9ri0oxJkSKiAm6S1qVus3UfXXzYVhtWrkYD46IiIiIiKisFkv74p89ePqXzciz2JAcH4MXR3fE+W0jb6QoY7g3oLyoWtc+bFgDQxoOpeeEe3OIiKgENW7cGFOnTuVnTEREVAKOZeZhwqcr8egPm1TA3adFDfw2uU9EBtyCLd1+MiU3VvdJhmxsPbgPDaq1KsnvhYiIiIiIKOIs3pqGe75drwLvGJMRDwxtjWt7NS73xdJ8YdDtr5jKOBJVF7Uth5C5dyPQjkE3ERERERGRP3LNVrzw2xZ8/Ndu9bxl7QS8Pq4L2tStEvEfINPLA3Aq3p5inntwY0l9H0REVEzvvvsu6tevD5vN5jL94osvxjXXXIOdO3fikksuQe3atZGQkIAePXrg999/5+dORERUQrYePo1L3vrLGXBLy/aPt/WuEAG3YNAdAFutNuo++viWkvo+iIjKNk0D8rPCc5N1+2HMmDE4duwYFi1a5Jx28uRJzJ07F+PHj0dmZiaGDRumAu01a9Zg8ODBGD58OPbu5ZCQREREoT1t0PDJX7sw/K0/sfXIadRIiMHH1/bAExe3Q1x05FQnrzDp5SU9TrdISOkIbAdqZu9QPyCDIXL7HRAReWTOBp6tF54P56GDQEx8kbMlJydjyJAh+PLLLzFw4EA17dtvv1XT5bnJZEKnTp2c8z/99NOYPXs2fvzxR9x2220l+icQERFVFEdP5+Geb9fhj21H1fP+rWrixUs7oWZiLCqaiGnpljG6U1NTsWLFihJbR+1WZ6n71touHDhuH0eOiIjKHmnRnjlzJvLy8tTz//3vfxg3bpwKuLOysnDfffehbdu2qFq1qkox37JlC1u6iYiIQmThliMYMnWJCrhjo4x46pJ2+OjaHhUy4I6olu7SEFOzBU4b4pGILOzbuhoNavQP9yYREZWu6Mr2FudwrdtPki4ufbp/+eUX1Wd76dKlePXVV9Vr9957r0o1f/nll9G8eXNUqlQJl156KfLz80tw44mIiCpGsbRnf92Mz/7eo563rpOINy7vgpa1E1GRMegOhNGIY3FNkZizASf3bgLOZdBNRBWMdKvxI8U73CSQHjVqlGrh3rFjB1q2bIlu3bqp1yQAv/baazFy5Ej1XPp4795tL+xCREREwUk9mIHJX6/B9rRM9fyG3k1w7+BWFarvtjcMugNkrtoEyNkAc9r2kvlGiIgoZCnm0uK9adMmXHnllc7p0ro9a9Ys9ZrU5nj00UcLVTonIiIi/9hsGj76axde/G0r8q02lUL+8phOOK9lTX6EZzDoDlBM3dbAoR9RNWNzoG8lIqJSNGDAAFU8bevWrbjiiiuc01977TVcf/316NWrF2rUqIH7778fGRms00FERBSoIxm5qlja0u3H1PPz29TGC6M7oHpCxey77Q2D7gBVb3MesPpFtLekIj07H0mVYwJdBBERlQIpmnbwYOH+540bN8bChQsLFePUY7o5ERGRb/M2Hcb9M9fjZLYZcdFGPHpRW1xxVkOO8OQBg+4AJTY5C7mIQXXDaazbsgadup4d6CKIiIiIiIjKpex8C57+ZTO+/Hevet62bhW8cXlnNK9VsYulVYghw0pNVAx2xbVRD7N3/RPurSEiIiIiIioVGw+k46I3/3QG3Df3bYrZk3ox4C4CW7qDcLpyIyB3HXDS/mMjIiIiIiKK5GJp7y/9Dy/P2wqzVUPtKrF49bLOOLd5jXBvWrnAoDsI1ioNgBNAdOb+0H8jREREREREZcSh9Bzc/c06LNt5XD0f3K42nh/VEdXiWduqwgXd06ZNUzer1Vri6zJWbajuE3IYdBMRERERUWSas+EQHpi1Aek5ZlSKNuHx4W0xtkcKi6VV1KBbKs/KTYZ9SUpKKtF1JTTpCqwFGudtAyz5qp83EVEk0zQt3JtQrnEccCIiKk+y8ix46qdUzFi5Tz3vUD8Jr4/rjKY1E8K9aeVSxATdpalp6244riWqCuYndixHcuve4d4kIqISER0dra5mHz16FDVr1uSV7SAuVuTn56vPz2g0IiaGF2mJiKhsW7fvFO6csRa7jmXBYAAmntcMd53fEjFRrMEdLAbdQagUG4XVMe1xrvlvHEtdzKCbiCJ6rOsGDRpg//79HLu6GCpXroyGDRuqwJuIiKgssto0vPPHTrw2fxssNg11k+JUsbSezaqHe9PKPQbdQTpWvRtw+G9E7VsW2m+EiKiMSUhIQIsWLWA2m8O9KeX2wkVUVBSzBIiIqMw6cCoHd81Yi+W7TqjnF3aoi2dHdkBS5ehwb1pEYNAd7AfXpDdw+C3UPbUGMOcC0XGh/WaIiMpY4Cg3IiIiiiw/rz+Ih2ZtQEauBfExJjxxcTtc2q0BLxaHEIPuINVvczYOLktGPZyAbdtcGNtdEsrvhYiIiIiIqMRk5lnw+A+bMHO1fUSmTilV8frYzmhcI56feoixc1mQ2tarit9gL6CWseKrUH4nREREREREJWb13pMY9vpSFXAbDcAdA5rju4k9GXCXELZ0B0mq9x1udBGw90ck7FkA5JwEKlUL7bdDREREREQUIharDdMX78TrC7arwmn1q1bCa2M746wmyfyMSxBbuouhZcde2GxriCgtH1j5cei+FSIiIiIiohDadyIb4977B6/O36YC7os71cOvk/sw4C4FDLqLoV/rWvjAOkw9tv7zDmDJD9X3QkREREREFBI/rD2g0slX7jmJhNgovDa2E964vAuSKrE6eWlg0F0MNRJicaThRTisVYMp6wiw8bvQfTNERERERETFkJFrxp1fr8Hkr9fidJ4F3RpVw5zJfTCySwN+rqWIQXcxXXpWU3xiGawea8veBDQtFN8LERERERFR0FbuPqFat79fe1AVS7vz/BaYcdM5SEmuzE+1lDHoLqYh7evgx+jByNZiYUhLBQ6uCc03Q0REREREFESxNOm3fdm7f2P/yRykJFfCtxN74s7zWyLKxPAvHPipF1NctAkDO7fEAlsX+4SVH4bgayEiIiIiIgrM3uPZGPPu33hjwXbYNGBUl/r49Y4+6NaI1cnDiUF3CIztkVKQYr5xFpCfHYrFEhERERERFUnTNMxctR/D3liKNXtPITEuCq+P64xXx3ZGYhyLpYVbxATd06ZNQ9u2bdGjR49SX3f7+knIqd0d+7UaMJizgdTvS30biIiIiIio4knPMeP2r9bg7m/XITPPgrMaJ6tiaZd0rh/uTaNIC7onTZqE1NRUrFixIizrv6xHCv5nOd/+ZNlbLKhGREREREQl6t//jqtiaT+vPwST0YB7BrXEVzedgwbVWCytLImYoDvcRnSpj28wEFlaLJC2Cdj1R7g3iYiIiIiIIpDZasNLc7dg3Pv/4MCpHDSqXhkzb+mF2wa0UME3lS0MukOkauUYdG3VFL9Yz7FP2LUkVIsmIiIq85577jnVxSsxMRG1atXCiBEjsHXr1nBvFhFRxNl1LAuXvr0M0xbtVKMVX9a9AX65ow86p1QN96aRFwy6Q2h01/pYrzVVj22H1ody0URERGXaH3/8obp6/fPPP5g/fz4sFgsGDRqErKyscG8aEVG5tGbvScxavV/dO4qlfbNiHy58YynW7U9HlbgoTLuiK168tBMSYqPCvbnkA7+dEBrQuja+iWsGWIH8A+sQF8qFExERlWG//faby/OPP/5YtXivWrUKffv2Ddt2ERGVR8/P2Yx3/vjP+fzaXo2QdjoPv244rJ6f0zQZr17WGfWqVgrjVpK/GHSHUEyUESmte8C20YC4nDQg8yiQUDOUqyAiIioX0tPT1X1yMseGJSLyl7RqL96a5hJwi0+W7VH3UUYD7h7UCjf1bcq+2+UIg+4Qa1i3NnZvqI2mhsPAkQ1AwoBQr4KIiKhMkxTIKVOmoHfv3mjfvr3X+fLy8tTNISMjo5S2kIio7Lduu6uZGIuPrumBDg2SSnW7qPjYpzvEmtdKQKrWyP7k8MZQL56IiKjMu+2227B+/Xp89dVXRRZfS0pKct5SUlJKbRuJiMpaC7evgFuc06QaA+5yikF3SQTdNnvQzWJqRERU0dx+++348ccfsWjRIjRo0MDnvA8++KBKQ3fc9u3bV2rbSURU1iqSF+Wn9YedRdUCKcBG4cf08hCrlxSH/0z2CubmA+sRG+oVEBERldGUcgm4Z8+ejcWLF6NJkyZFvic2NlbdiIgquiY14v0Ozrs0rOZ3ivrE85rigaFtQrKNFDy2dIeYwWCAsW4H9Tj61A7AnBPqVRAREZU5MlzYF198gS+//FKN1X348GF1y8nhcZCIqCiZeRZUjjEVOZ/ZagsoRV2es8U7/Bh0l4A2LVriuJYIo2YF0jaXxCqIiIjKlLfffluliPfr1w9169Z13mbMmBHuTSMiKrPyLFY8/XMqrvpwObLzrahftRLuvqAlJg9s7nH+aJMx4BR1f1LXqWQxvbwENKwRr/p19zFtBA5vAOp3LYnVEBERlan0ciIi8t/2I6dxx9drsfmQfeSGK89piIeHtUWlGJNqnX59wY6A0tC9veZv6jqVHLZ0l4AG1SrpKphvKIlVEBERERFROb1I+fnfu3HRm3+qgDs5PgYfXN0dT4/ooAJuIf22pT+23i3nNfXZnzuY91DpYEt3CUipVhmfnalgbj24FkX3ziAiIiIiokgjLdaS3i2tzRL8HsvMw/3frceCLWnq9b4ta+LlMR1RKzGu0HulANrgdnVc3l+UYN5DJY9BdwmQgev3xbcDzIDh0Fp7MbXoSiWxKiIiIiIiCnMw7U8l8WEd6mD5rpMq8I4xGfHA0Na4tldjGI0Gr+uRZQcaOAfzHipZDLpLqIJ5zZRWOLQzGXVtJ4Dt84G2F5fEqoiIiIiIqBT5MyyXp0riv244rO5b1k7A6+O6oE3dKqW0xRRu7NNdQprXTsSP1p72J5t/KqnVEBERERFRKfF3WK43Fmz3+P7ezWvgx9t6M+CuYBh0l5BmNROwyNbF/mTH74Alv6RWRUREREREpcCfYbkkAF+09ajH+e4e1BJx0az4VNGUyaD7559/RqtWrdCiRQt88MEHKI+6N0rGClsrpGlVgZwTwM6F4d4kIiIiIiIqBrPVVuSwXOv3n/I4z4DWNdnXuoIqc0G3xWLBlClTsHDhQqxevRovvPACTpw4gfKmYfXKaFijCn63nhmje/fScG8SEREREREF6a4Za3D/TM/DAc/dZO+vvXDLEbwyf5vHeW4f0IKffQVV5oLu5cuXo127dqhfvz4SExMxbNgwzJ07F+VR3xY18K+ttf3J1jkyKF+4N4mIiIiIiIIIuGevOej1denXfcsXq3D9JyuRkWNB9fgYl9c5XnbFFvKge8mSJRg+fDjq1aunqnh///33heaZPn06mjRpgri4OHTr1g1Llxa0Ah88eFAF3A4NGjTAgQMHUB6d16om5tu6IwuVgBM7gV1Lwr1JREREREQUAOmj7Svgdpiz0d7afUPvJvjrgQGYfWsvvHpZJ3V/v1t1c6pYQh50Z2VloVOnTnjrrbc8vj5jxgzceeedePjhh7FmzRr06dMHQ4cOxd69e9XrmofWYAney6OeTWtAi47HbEsv+4S/32JrNxERERFRBBRP8+TCDnXw6EVtVbE0GSt7VNcG7MdNoQ+6JYB++umnMWrUKI+vv/rqq7jhhhswYcIEtGnTBlOnTkVKSgrefvtt9bq0cutbtvfv34+6det6XV9eXh4yMjJcbmVFpRgTBraphS+sF0CDAdg+D9jyS7g3i4iIiIiI/KQvklaUXzYcLjR8GFGp9unOz8/HqlWrMGjQIJfp8nzZsmXq8VlnnYWNGzeqwPv06dP49ddfMXjwYK/LfO6555CUlOS8SQBflgzvVA9btIb40niRfcKyN9naTURERERUTkiL9cTzmrpMizEZQ9IyThVDqQbdx44dg9VqRe3atV2my/PDh+19IKKiovDKK6+gf//+6NKlC+69915Ur17d6zIffPBBpKenO2/79u1DWdKvVU0kVYrG69lDYDNGA/v+AVZ9HO7NIiIiIiKqcKQVetbq/QG3Rj8wtA2+uvFs9Gxqj0vyrTavLeCBtIxTxRAVjpW699GWftz6aRdffLG6+SM2NlbdyqrYKBOGd6qLL/4x4/NKV+GarI+AOfcD9bsDdTuGe/OIiIiIiCqE5+dsVlXGHaT1WoJpf2w8kI6Hv9+I/47aW7Fv7tsUUwa1xGvzt7ksk1XKKexBd40aNWAymZyt2g5paWmFWr8jyW39W2D26gN4/PhAnJ+yE/WP/gF8MRq4eQlQxXt/dSIiIiIiKj5p2dYHx0KeD25Xx2ehM5tNw/tL/8PL87bCbNVQu0osXr2sM85tXkO9LkG7LENSyqWF29eyqOIq1fTymJgYNUTY/PnzXabL8169zlT4DtK0adPQtm1b9OjRA2VNnaQ43HVBS2njx6WHxyO3WksgKw34ahyQdTzcm0dEREREFNG89bP21f/6UHoOrvzwXzw3Z4sKuAe3q43fJvd1BtwOrFJOpR50Z2ZmYu3ateomdu3apR47hgSbMmUKPvjgA3z00UfYvHkz7rrrLvXaxIkTi7XeSZMmITU1FStWrEBZdN25TdCnRQ0cMidgXPptsEbFA4fWAq93Ak7uCffmERERERFFrED7X8/ZcAhDpi7Fsp3HUSnahOdHdcA7V3ZDtfiYEt5SikQhD7pXrlypCqDJzRFky+PHHntMPR87dqwaJuypp55C586dsWTJElWhvFGjRohkJqMBb13RFR3qJ2Ftdg2Mz70P1qjKQP5p4H9jAEteuDeRiIiIiKjCVCAf0Lpmofmy8iy4/7v1uOV/q5GeY0azmvF4aUxHxEQZsXbfqVLcYookBk2qmEUQGadbhg6TSuZVqlRBWZOebcYVH/yDTQczMMi0Au9Fv2Z/odkA4MpZUmUu3JtIRESlqKwft0oTPwsiKo2+3W8u3I6FW44WKqi2bt8p3Dljrc+U80CKr1Hky/DzGF6qfbpLUlnu062XVDkaX954Ds5vUxvzrD0wPv9B+ws7FwIHVod784iIiIiIIpo+4HYUVHtk9gaMfntZkWNsy7yBDjdGFDFBd1nv060n43Z/cE13PDSsNZZpHTDL2ltNT1/4qoyfFu7NIyIiIiKKSN6C6i/+3QuLTUOnBklBL4Mo4oPu8uimvs3w3cSeWFptJKyaAUn//YzcJVPDvVlERERERBHJW+G0uGgjXrq0Ix4f3jboZRB5w6A7zLo1SsaDN16JaYax6nnMoidxcsPccG8WEREREVFEFlS7/tzGLtNqJcaqocDGdE9B10bJhQqu6d1yXlOOxU0Biwr8LRRqtRLj0Pe6p7H+kzXoqG2FZfYknKz/D6olu44BSEREREREwVu99yR+35ymHkv94ku7NcCzIzsg2lTQFimF0ga3q6PSyB2t2o7HErQTVdigWwqpyc1qtaI86tyoJvZe/x32fXg+UmxHMHf6DTjrzm9QLSE23JtGRERERFSuWW0api3agdcXbFeP61ethNfGdsZZTZI9zi/BtT7AZrBNxcEhw8qY/at+RYOfLlePv2v1Ci69fEK4N4mIiMrZMFn79u3D7t27kZ2djZo1a6Jdu3aIjS37F3E5ZBgRlYR9J7Ix5Zu1WLHbXnX84k718H8j2qvixkSlcdyKmJbuSNGg2zDs3zgGDXZ9i4Qt3+Jk1tWoFh8T7s0iIqIybs+ePXjnnXfw1VdfqaBb042GERMTgz59+uCmm27C6NGjYTSypAsRVQw/rD2AR2ZvxOk8CxJio/B/I9phZJcG4d4sqmB41C2D6l9wm7rvj1X4ZOH6cG8OERGVcZMnT0aHDh2wfft2PPXUU9i0aZO66p6fn4/Dhw/j119/Re/evfHoo4+iY8eO5WJ4TSKi4sjINeOuGWsx+eu1KuDu1qga5kzuw4CbwoIt3WWQoW4nZFZpgYSM7TD/8y6+qFkTV57TKNybRUREZZS0ZO/cuVOlkrurVasWBgwYoG6PP/64CsClVbxHjx5h2VYiopK0Zu9JLNyShhkr9iHtdB6MBuCOgS1wW//miNIVSyMqTQy6yyKDAfEDpgDf34Lbon7A5T91Rs3E0aqKIhERkbuXXnrJ7w9l2LBh/ACJKCI9+2sq3luyy/k8MS4Kn1zXQw3RSxROEXO5RyqXt23bNmKu3Bs6XQ6tfndUNuThk6hn8ex3f2H/yexwbxYRERERUZkzZ8Mhl4BbnM61wCjjghGFWcQE3ZMmTUJqamrk9FMzGGC48jtoNVqhmiETt5g/w8g3l2DVHnvVRSIiIk+OHz+ujolyIbpGjRpITk52uRERRRIpGjlz1X7cOWOtx9dlfG2icGN6eVlWqRoMQ54DvhiFcVGLkZ0fh9FvW/HSpR0xpntKuLeOiIjKoCuvvFL1777hhhtQu3ZtGNjKQ0QR6s/tR/HyvG1Yu++U13ma1Igv1W0i8oRBd1nXfCAw5HngtwdwfdRv+E+ri/tmAhsPpGPy+S2RzOHEiIhI588//1S3Tp068XMhonJdEE1aqSVo7tKwWqHX7/hqNX5cd8j5vEfjaujSsKpLivkt5zX1+F6i0saguzw4eyKQdQxY+jKeiv4Eh/OT8enfwKd/78Fzozrg8rMahnsLiYiojGjdujVycnLCvRlEREF7fs5mvPPHf87nE89rigeGtlGPzVYbHpi53iXgFit2n8Sl3Rpg8sDm6nm/VrUYcFOZwaC7PJDUwAGPAMd3wJj6Pd6JfxfP5V2KD/MH4cFZG5CWkYdJ/ZtxGAQiIsL06dPxwAMP4LHHHkP79u0RHR3t8qlUqVKFnxIRldnW7cVb01wCbiHPZRSfqpVjcOfXa7Buf7rH998/c4PzcZ7FxqCbygwG3eUp8B4+FTi0DlEnd+FR4yeoXgV4MWMQXvt9G75ZuQ/jz2mIK85qqHZIRERUMVWtWhXp6elqXG73YkPSv9tqtYZt24iI/G3ddvf18r34af0hZOdbER9rQlae732ZI1BnejmVBVGRNGSY3CL6ZKJSNWDin8C0s4CMA7g1/xOc1zkRV27riwOncvDib1vx4dJduHdwK4zsWh+xUaZwbzEREZWy8ePHIyYmBl9++SULqRFRuWnh9hVwixkr96v7c5om49XLOuOzv3cX+R7pE86gm8oCgyaXviNIRkYGkpKS1FX+iE2hy00H3uwOZKWpp5YeN+PHmhPxysLdKvgW8TEm9G5RQ/V/YdVGIqKKc9yqXLky1qxZg1atWqG8qRDHcCIqZNbq/ZjyzTqfn0yU0YC7B7XCTX2bwmQ0uBRbk37e+tRyh9m39mLQTWXiuBUx43RXKHFJwF0bgXYj1dOoFe9i1L9jMPfcLbjh7NqokRCDrHwr5m46gsGvLcEj32/A8l0nsGF/Omy2iLrGUsi2wxn45s+NsEb430lE5E337t2xb9++sHxAS5YswfDhw1GvXj2Vyv7999+HZTuIqHwpqoGoaY14zL71XNzSr5kz4BbSij2qawOM7dFQFVvTY+VyKksiJr28womKBS79GGg3CvhpsiqylrDgQTyaUAcPX/4e1kV3x2u/b8eSbUfxxT971c0xnMJFHeuhff0kdGsUeUMo/DdtFC4zrcCc3JkYev754d4cIqJSd/vtt2Py5Mm499570aFDh0KF1Dp27Fhi687KylJDlV133XUYPXp0ia2HiCLL3E2Hvb52+VkpePSitqgc4ztskexO6cPta5gxonBhenkkyD4BfH8LsO23gml1O0G7+C38nVUPn/69G79vTivU+ju0fR30a1UTPRonIyEuClXiohEXXc77gT+RpO7+Tb4YZ9/xebi3hoio1FOqjcbCSWzS6lzahdRkXbNnz8aIESP8fg/Ty4kq3vjb8nzk9GWF5kuIjcLLYzphSPs6RY7ZTRQu/h632NIdCSonA1fMAP5bDHx2iX3aoXUwvNsHvbpciV6Xv4Zsm1G1en+9Yp9KMz+elY85Gw+rm0PL2gl4fVwXtKlb/vvRFSQeERFVLLt27UJ5kZeXp276kxciqljjb7esnehx3rsHtVQBt68xu4nKC/bpjiRN+wFPpAO3/A3UOZM+uOYL4OmaqDz7OgypcQyfXHcWVj5yPp4Y3rbQ27cdycTQ15fi+zUHUN5pMsQaEVEFYzab0b9/f5Xm3ahRI4+3suS5555TLQSOW0pKSrg3iYhKsUK5PP/4L88XCjunVPX6HplOVJ4w6I5EtdsCNy4C+t4LxNrTrbH5R+Cd3sA318CQvg/XdkvG9meG4pc7euOqc1xPwu6csRY3fbYSM1ftx86jmeH5G4iIKGDSf1tajiW1uzx48MEHVUqe4xauAnBEFFoSFEtFckdwLPffrvT8/3vDgcIZLqO61FNp5JJS7om36URlFdPLI5UpChjwCNBjAvDVOODgGvv01O/tt9gqiO40Du2qN8f/9Tkfj144BFMXbMf0xTvVbPNSj6hblbgozLmzL+pXrYTypXyccBIRlUQhtRdeeAEffPABoqLK9mE+NjZW3YgoMkhw/caC7Vi09ahzWueUJKzdlx7Qcnq3qOmzqjmHw6XypmwfjQMwbdo0dSutAjHlRmId4KbFgAzHvnMBMO8xIG0TkJcBLH/POVsMgPu634D7nn8V//53XI2VKGN+Z+RacO7zC9G6TiIeu6gtejWvgbJq/mfP4oIQLctiteFEVj5qVYkL0RKJiErHv//+iwULFmDevHmqenl8vOtJ66xZs/hVEFHIufe9dvAVcMdEGZFvsXkNqqW1W/pw65fLocCoPIqYoHvSpEnq5qggR24k1bD5+UCzgcDJ3cCKD4C/33KdZ+WHwIGVOPuC/8OCu8/DzNX71VBjmw9lYMvh07jig38hQyN+dv3Z6N2i7AXfF/z3QsiWdfn7/2DF7pP4ftK5qk8REVF5UbVq1bAN15WZmYkdO3a4FHVbu3YtkpOT0bBhw7BsExGVPE99r4vSJaUq3r26Gz76c5fPoJpDgVEk4JBhFZk5FziwCvjuOiDziOtrEqD3vguo3w3ztqXjg6W7sHz3CefLZzVOxiuXdUJKcmWUBZrVAsP/VXc+/7f6CJx9+6dBL6/xA784x4Z8blTJjWlLRBRJw2QtXrxYFXJzd8011+CTTz6pUJ8FUUUi/bclS9Jf15/bGI9c2BZGac3xMIwYUXnBIcOoaNFxQONzgUn/Alt+BbbPA3YtAXJOADt+t98ADJJW5M7j8Xf15nhoZzvsPmVRAXifFxfhkQvb4JpejRFtCm9NPnNetkqRJyIiu6NHj2Lr1q2qqFrLli1Rs6a9j2RJ6tevnxoPnIgqlkD6WF/WrT4eG97OZZoE2gy2KZKxejkBlaoBXcYDl30K3L8LuH4e0HKIyydjWPs/9Nr0JBZ3/B0vX1CQbv30L5tx3ouL8MPaAx775JQWc25WiQwZxnNHIipvZLiw66+/HnXr1kXfvn3Rp08f1KtXDzfccAOys7PDvXlEFIEcfa/12tX1PP725WeXraELiUoDg24qrOHZwBUzgPEzC7+2/D1cunQYdg7ZhLsHNERslBEH03Mx+eu16PviIjXGdzhaOdyDbkOIqpcz6Cai8mbKlCn4448/8NNPP+HUqVPq9sMPP6hpd999d7g3j4gilPS9nn1rL7wypiMm9G6CrUcyixzuy31oMaJIFTGF1KgEtDgfeCIdsNmArb8CS192Dj1mWvwMbjc8j9sqV8K6+HNx07ExOJxhH+P7vpnrcXaTZEwb3xVV4qLDEnQXV1PDQXQ1bodBuyKkyyUiKmkzZ87Ed999p1K9HYYNG4ZKlSrhsssuw9tvv80vgYhKRINqlTH19+34Y1vBkGHeUtHdq51LS7kE7kSRiC3d5MevxAi0uQi47jfgoteA+Fr26ZoVhvxMdD45F8tNE/Bx+w1IiLLBajFj7fa9uPrD5fg99QjGvLMMT/60qUQ/aWuIg+6Fsffg5eh30e3UnJAul4iopEkKee3atQtNr1WrFtPLiajELNxyBEOmLlEBt2RCPnVJO9zct4nLPI7K5J6qnctztnhTpGJLNwVWeK379fab5F2v+hj4+S7ny/13PIeN8ouKAiyaEeP3P4wJn51Sr8nwW3ee3xJJlUqm5duSH9qg2yElu2QvFhARhVrPnj3x+OOP47PPPkNcXJyalpOTgyeffFK9RkQUSrlmK579dTM++3uPet66TiLeuLwLWta29+ke0r5uocrk+hRzPZnOgmoUiRh0U3CkUJkjAN/wHfDL3UDuqYIflsGGZ6M/wIX5z6KbcRv2aLUx/JXf8N1t/VCrqufCGsVhzXMtDqSFqE83EVF58/rrr2PIkCFo0KABOnXqpKqXy1jZEoDPnTs33JtHRBEk9WAGJn+9BtvT7P23b+jdBPcOboW4aJPPyuTeqp0HUgWdqDxh0E3F1+FSoN0o4Kc7gDWfOyc3Mx7ClrjrCuazAMdeS8L7zZ9Gt2Z10aXn+epkMBRs+a5BN0NuIqqo2rdvj+3bt+OLL77Ali1bVHHLcePGYfz48apfNxFRcdlsGj76axde/G0r8q021EyMxStjOqFvy5oBVTvXp5g7Us+JIlHEBN3Tpk1TN6vVGu5Nqbj9vi95y36zmoGNs4CFTwPpe11mq2FIx407bwd2Alv+7I6UCV8gvlodYMnLQI0WQLsRQa3elueWphSqIcNCshQiotIlwfWNN97Ij52Igib9q/Vp4Y7n0lXwk2W7sXT7MTXf+W1q44XRHVA9ITag5UvRtMHt6hRKPSeKRBETdE+aNEndMjIykJSUFO7NqdhM0UCnsfYWcKl2vvlH4K/X1Us2GGGEfTzv1tkrgTda41RUDVS12Hfc+BZA3U5A20uAU3uBYa8AJj9+prmnS+RPYYs5EZVH27Ztw+LFi5GWlgabjECh89hjj4Vtu4iofHCvLN45JQlr96W7zBMXbcSjF7XFFWc1DDpz0VPqOVEkipigm8ogowlo0N1+u+Ap+6S0zcDX44ETO52zOQNuh0Pr7DdRvTnQeTxgjMLxf79EdJ22qJKfBjTtD1ROLmjRznM9EIQKx+kmovLm/fffxy233IIaNWqgTp06LifD8phBNxH5asneeTSzUGVx94BbvHRpRwzvVJ8fJpEfGHRT6arVBrhjtXpozT6Jdb+8C+PmH9DZlup5/nmP2G8Sf3t6/dKPgWqN1NBlJYMJ5kRUvjz99NN45plncP/994d7U4ioHLdkF8Vs5TkSkb8YdFPYmCpXQ9cxD8Bqux/rDqRj1vLt+G/V7+hg+A/3RX/j30K+sxdqa+o22aiFrm//jZ+tVPfvXdXNe/rU9t/t9y3OD9l6iYiCcfLkSYwZM4YfHhF55GmM7EADbsFK40T+Y9BNYWcyGtAppSo6pfQARvfA6r0ncd4Xo9Aucxn+tbXBpzEvoL1xd0DLNIQo6M4z27A8dadq7z6Z3RHJ8TGFZ5LK6f8bbX/84AEgNiEk6yYiCoYE3PPmzcPEiRP5ARJRId7GyA4EK40TBYZBN5U5XRtWwx8PDcW+E+fh310nMHlxPdSMzsPqgzmohtN4IPorbLfVx36tFt6IecvjMgyaJSTbYtTMWBd3k3p8wnoRAA9BtzlH9zibQTcRhVXz5s3x6KOP4p9//kGHDh0QHR3t8vodd9wRtm0jovArbgv15IHNcdcFrUK2PUQVAYNuKrNSkiur26XdGqjnB07lYNOBdCzc0gkLtqTBZDCgWcbZMEDDnJgH0cJ4wPlegy00Ld0Jtgzn42pvtQRGvgu0keBbR59yzsprRBRm7733HhISEvDHH3+om550kWHQTVRxOYqljexSD7PXHAyqT3e/VrVKcAuJIhODbio36letpG6D2tVxTjuRlY9fNhzC6O8fx/ozLdLCoLkOkRMso245qljbjPHAE74OSiwqQkThtWvXLn4FRFRk8TQJvPu0qKlavo0GAyZ+sQqH0nPVcKkDWtfCzec1xcItaS7vGdC6Jj9ZoiAYg3kTUVkhfayvOqcRMpCAF81jQ55eLiOLB4Qt3URERFQOiqdJS3fD5MpYtvM4Rr+9TAXcdZPi8NVN5+DDa3vgrCbV8cDQNph9ay9nsL1wy1GMnL5MBfBE5D8G3RQxPrQOxW/WHiFt6fZrOS7zsKWbiErf888/j+zsbL/m/ffff/HLL7+U+DYRUdmxeGuax+n3z1yPl+ZuhcWm4cIOdfHb5L44p2nhQVol2NaTAF4CeSLyD4Nuigif33AW8hCDxbZO6rnRZg7Jcv0aekwfdIco2CciCkRqaioaNmyIW265BXPmzMHRowUnyBaLBevXr8f06dPRq1cvjBs3DlWqVOEHTFRBSKv06wt2eHxt59EsxMeY8PKYTnjrii5IquxaeNFXtfNQVEEnqijYp5sigvRJ+r8R7fHnj8vV83jrqZAsNy8vt+hLU/pAO0QF3IiIAvHZZ5+pwHratGkYP3480tPTYTKZEBsb62wB79KlC2666SZcc801ajoRVcy0cj0ZsvX1sZ3R2EdFc2/VzjlON5H/GHRTxLjy7IbQ9ncCNgLVzJ7TqAIVDUuALd0MuokoPDp27Ih3330X77zzjgrAd+/ejZycHNSoUQOdO3dW90RUsXhLK5diabcPaI7bB7ZAtMl360KXhtUw8bymLsE7x+kmCgyDbooYMhROfK1G6nGS9QRgtQCm4v3EY/wIuiV1M8rDYyKicO0LO3XqpG5ERJ6M7lofUwb5P9a2FFQb3K6OSimXFm4JxImoAvbplpS6tm3bokcPeyEtqpiiq9RGjhYDo1Qd372k2MuLQtEt15m5Bf3HM7Lzir1OIiIiolBoW9dz/Ybx59gbKQIhgfaorg0YcBNV5KB70qRJqpDMihUrwr0pFEaNaySgkiHf/uTzkaWSXm7UVSzXrKEp4EZERERUHD+sPYB7vl1faDpTw4lKHzNhKaI0qh6PedZuGGRaFZLlRRmKbunWdMXTrFb26SYiIqLwycg14/EfNmH2mgPqebdG1XBjnybIzrcyNZwoTBh0U0RJqhSNH+vchkFHr4MVRpg0TTo4Br28BoZjRc5j1RVSs9n8KLxGREREFKLq5I5iaf1a1YLVpuHOGWux/2QOjAbgjoEtcFv/5ogqolgaEZUsBt0Uca4fcjbwOWCSft35WUBsQmAL2BVYX3BN17pttTDoJiIiotCbsWIv1u07pYb5GtujoRp/W19RXMbilmYG6fSWklwJU8d2RrdGyfwqiMoABt0UcRrWqo58zYQYgxXmjMOYfzgelWNM6gqwXz4dHtD6bLr0couF6eVEVPpGjRrl97yzZs0q0W0houBarH1VBh8x7U+s3ZeuHn+5fB8+WPoftqdlFZpPAu5+LWvizSu6IDEuml8FURnBoJsiTnJ8LIxn+mJn//QAbt12nXq867lhaiidULPaCtLLrSykRkRhkJSU5HysaRpmz56tpnXv3l1NW7VqFU6dOhVQcE5EpcO9xVrGxJYhuvQt3I6A28FTwO3QKSUJ81OPsP82URnCoJsijlE6MZ2RtHc+AHvQLf2cok7vB/JOA7Xbhmx9mrUg6JZxuomIStvHH3/sfHz//ffjsssuwzvvvAOTyeQs8njrrbeiShXPwwcRUfj6Y+sDbiHPZUxsR4u3pJQHQtLMvQXwRBQerKpAEelvdFD3241NnNMsNg2Y2h54uydw+nDQyzZbbfjs793472imem7T2KebiMqOjz76CPfcc48z4BbyeMqUKeo1Iiobrdsjpy9zCZD1JNXcoVp8TNDrkQBegnsiCi8G3RSR8nvcou6leLnD18v3Fjw5ti3oZX/05y489sMmDHjlD/Xcqmvp5pBhRBRuknGzefPmQtNlmk3XHYaIwkOCYPfWbXfSt9uhWU3vBWHHdm+AyQObO29FBfBEFB5ML6eIZKpUVd3HWgsONE/8lIpr48480UfjOu/8sRMTi1j2it0nXJ5r+pZuK9PLiSi8rrvuOlx//fXYsWMHzjnnHDXtn3/+wfPPP69eI6LwKioIvuW8pi7F1PQBuLtxZzV0zivBvKeWc1/vJ6LSwaCbIlJUZXtRoURDNqohAxZEIRNxuqbwTCD7BFC5YCiNzYcy8PycLZiom80T93jdphsyzMKgm4jC7OWXX0adOnXw2muv4dChQ2pa3bp1cd999+Huu+8O9+YRVXjegmBpqZaRVvQBtxRG3H4kEyajQdWm0RvQuqbLc3mf9OHWt6K7B/BEFB4MuikiRVW2FwtKNmRiTdxE5GrR6Jj3QcEMX19hv3/oEBBTWT08mZXv17JtblG3Pl3TxiHDiCjMjEajCrDllpGRoaaxgBpR2TF3U+G6MhIc33VBK5dpp7Lz8dDsDfh1g+v8tRNjceR0HhZuOapu+mJpci9F2HwNP0ZEpY99uikiRZ9p6XaIM5jRxrCn8Iyn9rpUPb/V9EPA69J043Tb2NJNRGWkX/fvv/+Or776yjlU4sGDB5GZaS8ASURlqz/3oHZ1XJ4v23kMQ6YuLRRwCwm4fRVLk0B7VNcGDLiJyhC2dFNEiquUWGjaD7GPFZ5RTkZ3LQWqN0f8iZ24L3pGkcveeNDecuSppZt9uoko3Pbs2YMhQ4Zg7969yMvLwwUXXIDExES8+OKLyM3NVUOJEVHZ6s8t0yVYzrfY8Or8bXh3yU5v5Wd8vp+Iyia2dFNEqlypiI7ZDjsWAJ9eBLzXD4Zc1wJp3hx1u8Ls0tJtYyE1IgqvyZMno3v37jh58iQqVarknD5y5EgsWLAgrNtGVNF5688tw5HuPJqJUW//pYq6BhJw+1ouEZUNbOmmiBQXXTA+rU9r/2e/zzyMfGuARzhPLd0WBt1EFF5//vkn/vrrL8TEuI7t26hRIxw4cCBs20VUUUnqt76PtXuxM3H/zA2IMhpgsWmoWjkaIzrXxyfLdntcXueUJKzdl+58zmJpRGUfg26KSPGxfgbdxwuG1jAXNFgHxKWQmq6SORFROMg+yephX7R//36VZl7Spk+fjpdeeklVTm/Xrh2mTp2KPn36lPh6icqiu2aswew1B53PHUXPpBr5tEU7XeaVgLtjgyS8f3V3HDyV4zHofmF0B4zt0bBQIE9EZRvTyykiVfK3pduS63wYbEs308uJqCyRPtwS6DpIITUpoPb4449j2LBhJbruGTNm4M4778TDDz+MNWvWqGB76NChqn85UUUiQfHot/9yCbiFtHBLIO4ecDtc3bMRaleJc7aI60mLtgTcgsXSiMoXtnRTRHJU6w2ExeLfkGHu2NJNRGXJq6++igEDBqBt27aqcNoVV1yB7du3o0aNGqqaeUmv+4YbbsCECRPUcwn+586di7fffhvPPfdcia6bqKx4fs5mjxXKHdwDcb1mNROcjzn8F1HkKJNBtxR7Wbx4MQYOHIjvvvsu3JtDFYTN7FogzV+aVpBertnMIdwiIqLA1a9fH2vXrsXXX3+NVatWqQuDEgiPHz/epbBaqOXn56v1PfDAAy7TBw0ahGXLlpXYeonKw5Bg/vDUN1ueM32cqPwrk0H3HXfcgeuvvx6ffvppuDeFKhCrObiWbtdxutmnm4jCx2w2o1WrVvj5559x3XXXqVtpOXbsmOpLXrt2bZfp8vzw4cJjDQsZ0kxuDhkZrkMyEkXKkGBFcfTVJqLIVCb7dPfv379Uir0QuTBnB/WBML2ciMqK6OhoFcQG08UmVNzXrWma1+2RlPOkpCTnLSUlpZS2kij0LdyzVu9XQ38VJaVaJa99tYkoMgUcdC9ZsgTDhw9HvXr11EH0+++/91i5tEmTJoiLi0O3bt2wdOnSUG0vUcAyND/TKfMz/ZrNAJvXlm5wnG4iCrPbb78dL7zwAiylPISh9Bk3mUyFWrXT0tIKtX47PPjgg0hPT3fe9u3bV0pbSxQ6Uhht5PRlmPLNOjX0lwzppSdDgTnuH7uoLf64tz9m39oLr17WSd3fP7QNvw6iCBdwenlWVhY6deqkUtZGjx7ttXKpBN7nnnsu3n33XVW5NDU1FQ0b2q/iSSCuTydzmDdvngrmiULpkFYdVQz7i5wvK+OkX8urikycRBXnc82mq3puZZ9uIgqvf//9FwsWLFDH1A4dOiA+Pt7l9VmzZpXIemVccDm+z58/X9VmcZDnl1xyicf3xMbGqhtReXXNR//ij23HXKbJGNpPj2iHuZuOYOn2Y2oosJa1E/D6uC5oU9d+/sC+2kQVS8BBtwTQcitO5VIptBIq7A9GXo3+EPkLnsEdR27C3FjXwj6e7D2c5vF/xCktHlUNBX20zjZuwW+2s9Rjm02DTSto6TZagyvGRkQUKlWrVvV4Ubw0TJkyBVdddRW6d++Onj174r333lPDhU2cODEs20NU0i3c7gG3w1uLduJwun1Y0mt7NcYDQ1sjzt/hTIko4kSV98qlEsg/+eSTJbJsKuc6XIqYDpdi1B87gUVFB92JyPE4fYGtC0ab/nQ+fydmKvrlvYIbTHNgPdlOIm/nawZbcMXYiIhC5eOPPw7bhzl27FgcP34cTz31FA4dOoT27dvj119/RaNGjcK2TUSh6K8tBdKa1Ih3VhKXab6G/pKAu0ZCDF66tBP6t67FL4GogosKd+VSTwYPHozVq1erVPYGDRpg9uzZ6NGjh9f+YHJlXV/5lIVYSO/sptXx1Lyr8Fj05z4/mOujfvM4fZHVNegWi2PvVveZs2/H3phBsLd7AwamlxNRGSF9qbdu3arqr7Rs2RK1apXOif+tt96qbkSROOb2xPOaqvGzi6pS3r9VTbw0phNqJLD7BBGV0JBhgVQu9UTS0f3F/mBUlOrxMfjeem6RQbc3G7QmXl87tS8Vi82dcGmM/bmRLd1EFGZy8XnSpElqnG65EC6kwJm0Qk+bNk1VCSei4MbclueD29VRrd6eSM20Jy5uh6vOaRTWUQSIKIKHDAumcilRSUuOj8EJVMFaW9Og3p+mVfX62nZbfRhRUEityKA755QM5h3UdhAR+UNqqkgxNRmr+9SpU6oquDxeuXIlbrzxRn6IRH7y1pot0yXNfELvxi7Tk+Ki8NudfXF1z8YMuImo5IJufeVSPXneq1cvlCS5et+2bVuvaehUcVWOsRcuOakFN/Z7DuK8vtbbuBFRsPgXdB/bAbzQCPh0eFDbQUTkj19++QUfffSR6qpVpUoVJCYmqsfvv/++eo2I/OOtNVumpx7McCmiNrxTXfz78PloWTu4cw0iimwBB92ZmZlYu3atuoldu3apx1KdVEj/6g8++EAd8Ddv3oy77rqrVCqXSiqdDEu2YsWKEl0PlT+O9C4NntO80rXKPt+/6J5+WGlr6fG1aIMVY0xLnM+NNh9Dhq370n6/5y91N3PVfoyY9heOZNirmxIRhUL16tU9ppDLtGrV7EWgiKho0potfbj1JvZtglV7TuLit/7E9rRMVKscjc+uPwtvXt6V1cmJKHRBt6SndenSRd0cQbY8fuyxx9Rz6TMmw4RJ5dLOnTtjyZIlrFxKYZf61GB8ZLUPdfe3tS222FKcr63yElAr1/6qrmhflv8Yeua+6XGW7satzsdRmhkHT+XAbC2oaO7N3d+uw9p9p/DCnC2B/TFERD488sgj6tgs1cMdpNvXvffei0cffZSfHVEApGja7Ft74dXLOuHDa7pj06HTePqXzWrsbXEy24xlOz0PG0ZEFHQhtX79+qnCaL6wcimVNZVjohDbciB6bamLI6iGSsjDxjj7WPLH6/YF0uyZG3prbM3RpfG56vHVvZpiyZZDQLbn1m6HnJwc9Hp+Ic5ukowZN/f0a9tO5xWkpxMRFdfbb7+NHTt2qGG6GjZsqKZJxpkUHj169Cjeffdd57wyUggRFd3iffR0Hu75dp0Kst05iqs5hhMjIiqV6uVEZdFVPRvh2i1p6rEhtgqG5j2Hdsbd6Np4AJD2RqH57zHfjAVnHkslUm14W5ifjEY0vKeQx5x57d9dJwq9dirbDE8l2VjblIhCacSIEfxAiULk753H8MaCHfj7v+M+51u8NY1BNxFFftAthdTk5hgehchdv1a1sPS+/qiTFIdokxEvzd2ChVuO4pE+XYDlhT+vGF2BNEffcLMxFtE++m3HGAreY7HakHooA+3qJcFkNGDz4Qz41/ZNRBS8xx9/3K/5vvrqK2RlZSE+3nOxKKLyPtyXVBmXLmLBtkDf/c1azFx9IOTbRkQVT0irl4cTC6mRP1KSK6uAW9w7uDXmTO6DqokJ2JxwdqF5BzQvXIjIbPReyVycbdyC6dFT0chwGI/9uAkXv/UXXvhti882bQ7jSUThcPPNN+PIkSP88CniPD9nM0ZOX4Yp36xT9/JcgvBZq/er+6LYbBoe+2FjQAG3XNgnIor4lm6i4rBGJzgfb0q5AjHpu3DPdeMKzWczxhS5rGGm5ehl3ITO/76vnr+35D88NKxNofn6GdfgUtNSLLA+wC+PiEpdUfVZiMojCaqlj7WePNdPk4rkUiDNk8PpuZjyzVos2+k7nVzvlvOaMrWciHxi0E0EoHntJODMxe92N7zt9TOxmWL9+ryqGrIQi3xV2XyFrbXHeT6JeUndJ5z4GEB/fg9ERETFJCnlRfFW+Oy3jYdwz7frkZlnQbTJALPV94WpAa1r4vYBLRhwE1GRGHQTAYiL9S+Y9jfoFi9Gv4dLTMvwP8tAKW3kdb5q1qP8DoiIiEJA+nD7G5w7gu6sPAue+ikVM1buc74uAXftxBgcOZ3v0qI9qF2dYvcVJ6KKJ2KCbhZSo2Kp1tiv2TRT0enlDhJwi/FRjhroREREVJIkEJb0cfcUc2/B+bp9p3DnjLUeW8j1AbfQziyfwTYRVdigWwqpyS0jIwNJSYULYBH51OsO4NReoM3FPmfTAmjp9lcN82HpXBneimq7lgCzbgIumgq0GhK+7SAiIipmn+6WtRPxwugOqnCqBNdzNx12CcKlxbpjg6qYtmgHXpu/DRabhqqVonEqx/voJILjcRMRKnrQTVQsMZWBEdOLnC1kQXdWQYGW+vn/AUtfAfreg7D5dLj9/quxwBPp4dsOIio1jRo1QnR0ND9xihhSpdy9YNqorg1Uy/RgXVr4sdN5GPTaH9h51N663aJWAmomxmDZzhMBpaUTEVW4IcOISoMWFZqge/d7bpXRF/5f4Zn2rQDWf2tfL6sME5Gfrr32WixZsqTI+TZu3IiUlBR+rhTRVcsdQ4RJoCwBuLRu3/j5KmfALbanZfoVcAfSZ5yISI9BN1EAQtXS3Th9edEzfXg+MGsC8vaswIBX/sBdM9aGZN1EFNlOnz6NQYMGoUWLFnj22Wdx4ID/Yw0TRVrVcsd0qUh+3cfL8fvmtKDXwaHBiChYTC8nCkBJ9OkuysYNUuClnjpxeG1s51JfPxGVLzNnzsTx48fxxRdf4JNPPsHjjz+O888/HzfccAMuueQSppRTRPLWAr3neBa+Xr4X0xfvxN4T2QEtc2z3BujaqJqzbzjTyokIFb2lW6qXt23bFj169Aj3plAkC1F6uTeSRv79mgPYfuR0ia6HiCJb9erVMXnyZKxZswbLly9H8+bNcdVVV6FevXq46667sH379nBvIlHQJGV81ur9ztRxfdVyd68v2IEHZm1QAXfNxNiAWrVfuLQTxvZo6OwXTkSEit7SzerlVBqMMXFeXzsUlYK6loIxPt35U5xc0t5k6BKx+8yqNM2GCifjIPD3NKDHBCC5Sbi3hqjcOnToEObNm6duJpMJw4YNw6ZNm9RF6hdffFEF4ETlvVjaA0PbqMdyLwXTFm9NU8G2u9cu64Q/dxzzOpzYqC710LtFTbZqE1HIRUzQTVQaalfzPhzdttpD8Vp2G7x4MviT2DcXlmDrk80KGE0oF2ZcCRxYBWycBdy9OdxbQ1SumM1m/Pjjj/j4449VsN2xY0cVXI8fPx6JiYlqnq+//hq33HILg26KiGJpEmjrW6JX7PJcFO3DP3fh4+vOclYyN1ttOHgqR73Wr1UttmYTUYlh0E0UAGO095ZuzRiNF66/EHgluKA7O9+C9ftLaLiuP14E/noDuHEBULMVyjwJuMXpg+HeEqJyp27durDZbLj88stVannnzoVrQQwePBhVq1YNy/YRlUSxNAm6n/xpEz7+a7fX9y/aelQF7jIv08WJqDQx6CYK6H+M9/5gmjEKBlPwY97m5FsRhzy8HT0Vv9u6hfZ7WfSM/X7+Y8AVM0K7bCIqU1577TWMGTMGcXHeLxJWq1YNu3btKtXtIiqpYmky/ct/9/gMuB04zjYRhQODbqKA/sd4P4nt1LA64CXo3rnoM5iseT4XvW77Llxp+h39TevUzUGDpv4F/OgUHgq/PQjUagN0vbp01kdEISUF04gqkq+W78W3q/b7Na9UM3e0dhMRlZaoSKpeLjer1RruTaFIZorx+lJy5SjJP/f4WrM/bkezIhZtnjUJiYaUQtN3HTqO+TFvYK2tGWy2YTAaixN8+/Hef6bb7xl0ExFRGSIF0jz5ZqV/AbeQAmty0xdgIyIqacZIql6empqKFStWhHtTqIK0dBcas1uqjBuDv47VxrAHmoeguMWJJWhhPIAxUUtg1aTFuxj8KaFORERUjsREGfHG5V08DhnmjRRg0w85RkRUkiIm6CYq7aDb4N6/u5jVwY+gGjStcFAcjXznY6utmEE3ERFROSUVxj158/LOuLhTPdVyPfvWXpg8sHmxCrMREYVaxKSXE5UKfaAtj/XdtG2WYrUkm2DDKNPSwtM1i/Mxg24iIoo00uIsAbAURPPV1zrfYkNCbBQy8wqOiyM718XgdnWdzx2VyfMsNq/jcRdVmI2IKNTY0k0UbNDtKb28GJJxGo2MhfurRemC7n0nszHh0xVYtvNYkGsJ4KJAcVPZiYiIivD8nM0YOX0ZpnyzTt3Lc3cynvZLc7dg3Pv/qIA7PqYgq2z22kMe3yNjcftyy3lNWUyNiEoNg26iQOirk3tKLy+GBEOO51VqZufju2asw++b03DF+/+ipFmtBcE+lYz9J7Mx/dcVOJ7pu7I9EVGktnC7t0bL8xkr9jqfSwv4pW8vw7RFO9W14IGtayEr31pk/2xvqeNXnJWiUtDvZxE1IipFTC8nCral2D3o1ooXdMegILj21tK993gx+58FkP6en5+PSlHBjztORfv1rbtwq/VrvLfjXtx0xyP8yIioQvEWGN8/cwP+O5qJKJMR7y/dpdLKq8RF4blRHZFnsWLBlrQix9/2ljo+pnsKW7iJqNSxpZsoWO5Bd/tL1V1ufL2gFhePXI/TG1p2OR9bi9ma7qBpGnaknYbF6j0lPj+Pra8l7Sbr1+r+muNTS3xdREThIq3Qs1bvL9Qa7atP9btLdqnWbQm4hRRKu7BjXa/vcZ8uAbh7NXOmlBNRuLClmyhY+uHB7tkOJNirqh655Gs0+rJvwIszGYruQ22wWRGPfGShEoIha5C27q9X7MODszZgaPs6ePvKbh7nzTeHIOi22YATO4HqzUM/XJnkGc57BKhSH+h5q8tLcpKWnmNGzUS3CyNlVD6iUD62lIgoMNLfWp9Crh8f2xEYF1XwTHzx716M7tbA43u8BdOyHunb7U+RNiKikhQxLd3Tpk1D27Zt0aNHj3BvCkWyGC9X5c8E3KJRy05YVvOyEln9eViFTXE34J6oGZ5nsJqBb64G/n3P48tHMuyB9Lt/7FT3czYe9rouc37BUGU4udu+TLPnfude/Xo38FZ3YNmbCLnD64G/3wLmPljopSGvL0GPZ37HnuKm45eSfDCNn4gij/TN9tRnW9/iLYHxC6M7+LU8CZ7lvS1rJ6r3vHpZpyL7Z0ugPaqrPVgnIgqXiAm6J02ahNTUVKxYsSLcm0KRrEEPoPN4oP8jQIcx9mk1WxearU7/m0tk9U9Hf6Tub4v6wfMMG74DUn8A5txrf56bAewqGIZs/6kcZ4t3FHwXSjObdUH3tLPty1z8fGAbvNK+vVj0DEIu77TXlyof24AxpsWYv8n7RYWyxGxg0E1EkdfCLX2z/enL3b1xMmokxBS5zB/WHnBWOpdlbztymsE0EZULTC8nCoSkSI+Ybn8s/atrtADqdS00m6mECpDJWN566/adQuPq8UiqfGZ9uemub/h8JHBgpW6CPcW7o3UTFsQ+iucsVwC40OO6LPqg23Kmv/nuwuOIlwSbZoCxqHR7H0O0/RxrL0o290QnAM1Q1lXIlu7TR4D4moAxyGu/J/cA2ceB+oX//xFR2atK7qn/tdQXke5OT/2UihyzFXFRRgxsUwsT+jTF3E2HCy3jj22uw2XK65I+zlZsIirrIqalm6jUGU1AswFApaqFXjJFFX3FPhgmFBRSW7w1DZdM+wuDpv6hm8MtUHUJuAvcn/cmogw2PBr9hX8t3Q6GAHYZOadQovwYF71adtH9BEtUZhpg9lwgT89c0YLunQuBV1oC314T/DJe7wi83x84UVBokIjKdlVyMaB1TXV/IisfN3++StUXkYBb5Fps+GXDYRVwh2JdRERlBVu6iUqAKSqqxFu6fzvTH9vRT9tZXMwHx6tG9+C8qJZupwCKof3+OIJV9Na5/a3y2EOhNkMgFwlC7dQ+YGp7e6G3Kak+Z822mVTWQqeUwhdwItJfr9vvN/+o7qSKvslogCGYYntHNgLJTUK8gURUHL6qki/cclTdYkxG5FttiDIaYLG57vX9Kazmz7qIiMoKtnQTlYAof1u6pV/45PXI1/wL0uMNBQG2zWOArZu29kuvyzH4EdaazR7GDfcUxJ74z55q7yb3wMYi1+F9+/zhFnR7Wk6wqcuhsGO+/T7jQJGzmhGlshYqjoJv+FhmHrr833zc+9364BYVomH0iCh0PA3X5U4Cbvu8wV9s5BBgRFResKWbqAS49+nO0WJQyeCh5bjbtUC1Rsg3RCOmiMJm7twaBuyWvFzw+PtbCr1c1XpcFSAzBNvS7R50r/0K+H4i0HYE0O0aIOVsZ4X3vSey0bLgjQgpCbL16eXqceEAO6iW05Dxf91djTvQ1HAQFYbue/l6+V6czrXgu1X78fIY6YMf+m4GRFT6HMN1SVeozYcyMC81zeN8K3a7jt1dlFFd6qF3i5ocAoyIyhW2dBOVAPc+3Ue1JM8zGkxBF9LSt3RbJQKX5zknfL6nRV4q8HJLv4Juq8WPoHvJS/b71O/tRdu+ucZLMORlfV5aqH1u3Z6/gRca2wN+j+vSb6798w0qNXzbvCLT9X0KMOD/PeZMxfkKoeCzcU8rDZStpFq60/cDGRXoQkgIPPPMM+jVqxcqV66MqlUrSFcJ8kn6Zr++YIfXgNuhfyt7P299C7Z7S7n0BZfhwV4d24VDgBFRucOWbqKS+I8V7RpEH0VVNMTRwjMa7f8FzYYYPzsyFzBZchCLfAw0rsbsJz+E1mEMzgxi5ps5GwZDpSJns1nMKpiXsa6bugeSMgxZQm17MTlPKdVKEX/Q1t+AHyYBo94Fmp8Pv824Esg9BWz8zmPQLdVwDfqLBKk/ApWTgca9/V+H9MUWV3wDtByMYBzPMqN6APMXWa09ghzLykeNM49txQy6txw6hbYdEVoyHv1r7eyPHz0uV9FCvILIlJ+fjzFjxqBnz5748MMPw705VMYrmOvdMbCFuklRNOmj7ahGLi3l7tOIiMojnkkQlULQfUpL8DzjmT7HwQTdF6a9j57RRzDK9Kd9wsYFfr/XqB96bIWXk2NLLu75dh1mrzmA3XG6IPboNuDTi+zPY6t4XYdrDOmh1fersfb7L0YDT+iGOsvPhinQAFQraO2UCwWOHVtUxj7gm/+zP9Gvw197lgUddG9Py/QddBenFb2cO3Ayxxl0S0t3V8M27NNcW7r8ZbEE1i3DLzIUmXMFOYApMfTriEBPPvmkuv/kk0/CvSlUBrw2f5tf80kLtiOgdg+s5TmDbSKKBAy6iUpAdHSsy/NDWrLnGc+0dFsMrkH6P7Y2OMe42ec6+p2aKeXMg6JaFx1x8C9TPM7Ta9kEXJcrJ8+6VHkJutN0lbjzMryuwxBsy62kqfviKWVc19ItQZxjx7bjvx3oGORnZF9XVMn13rGVQLBYTmi61Ps66eswK/YJVfcAuDLwZdlKoE93Bb4gUtry8vLUzSEjw/s+hcqHXLMVL/y2BUu2u46p7c3tA1qU+DYREYVbxPTpnjZtGtq2bYsePXqEe1OIYDS5RnqvWsYUEXQXBLZrbc2QqwKQkmPQt3T7MML0FyabZureaPS7r7Ih2MBl3z+BB8L6oNta0OptK+4urjhBd1Efk9VDdfgKqNnJpereY6FBP8Sf/g84sDqk25R3pqqys14ClZjnnnsOSUlJzltKSgo/7XJs6+HTuOStv/DxX7v9mp/Vx4moooiYoHvSpElITU3FihUrwr0pRC7G5T+CHu08XMmv1hio0Uo9tBgLgmwLTLCW8H/NWD8rpb8Q/T7uinYNunU9povgI1hZ+gqCdqb4XKEAduNM4PRhWHVDnUnacsHm6LYn/YC9WFoJBt1Ffk7W4IJMr45sAjI91A0ogzTd7zvWcrpYy2q+7QPg/f7A6SMIlVNZBd9NjrniZiSIJ554Qo0C4Ou2cuXKoJf/4IMPIj093Xnbt8+P/5dU5kgtjU/+2oXhb/2JrUdOo0ZCDD6+tgc6p7gWEe2SkmQvhnZZJ3V//9A2YdtmIqLSxPRyohJ2WKuGmlGugeLm2sPRZsIHzgJNVmNBOroE3LZQD7HlpoohO7g3GozYfDgTbX3Nk3MS+PF2NLPs8D7PgqcQNE/p5cveAP56HYivBfOE5c7JTY2HXVvDJWC3WoDXzvwFDx8Gon0UlQu2+rk/w5UVJ71cWnbloo0UiBPHtgNv9wq+73op01+OKW7Q7ZC2dwtqtauNUCuR9PVy5LbbbsO4ceN8ztO4ceOglx8bG6tuVH6Lpa3ffwrfrz2INXtPOSuRvzSmE2okxKJq5Wg1LODJ7HwMbFMbY3s0VPOwnzYRVTQMuolKSObY2Xjw8wXYrdVFV6NrAJZeqSEQ7ahOBtj0Ld2aKYDW5FJmMCLbXEQQsvBpYPNPwS0/yNZnbfNP9k8sKw02b4W1ZGgpCaKtBf1HpWUcyU0CWpe/NP3watLK7h6EB9vS/d9i4LNLgMo1gPt22qftD76lMdxCFXSfyMpDrZAsya1rQAUfB7xGjRrqRuTu+TmbXaqTm4wGPD68La46pxHW7juF+75bh4VbCrJvmtb0UlCUiKgCYNBNVEIS2gzAT7Yc9bhmYqzP8a6tphi3lu4y2vNDbbch4MBZwhZjIEN1+eKp9VkXwJo9jS+ur3CuD6I8Bb76ls1itHS7LtNaeNipYPt0b/nFfp+tK1Kku4CjdzwzDzFRRiTGBT4OfMkq+A1F23Jdh3vzp2ZACRc6cxnHvoIH3YHYu3cvTpw4oe6tVivWrl2rpjdv3hwJCQy4yqMZK/Zi3b5T6JRSFS1rJzqH78qzWAsNByb1DzrUT1JF1DwNFSbTZAgwtnITUUXEoJuoBE0d2xk/rD2ASQOaAwVZzzC4tXzbdOnl0qe7pNPLgyYBUVFBUVZaoUlmiw0+E0iXvw9s+t6/bfDU+qwLYPV9ugsFvvp7YSkI+DwG4vp1SaB3aC1QvTkQW/QQUoZCAX9ogu6D6bmo5z4xunLBY7noEBWD9Bwzuj39O6JNBmx/ZhjKKv0FJqk8L9tbJI+BcAgDcV1QX9HTywPx2GOP4dNPP3U+79Kli7pftGgR+vXrF8Yto2CMmPYn1u6zd1f5crnrxdT4GM8XJBdvTfM5NrcE7Qy6iagiKqPNaUSRYUSX+vj4urNQxb2l0a0YmCWqIGiylumg2+jaCujJwTWFJtmKapn89R5gz59+b4OvQNlqMfvf0u2pVVyXfm4zRLm2ML/XD3ivv5/bqfsO9YG+c1pwQffeE/bsCRdRBS3deTn2IZdSD8q95lLNvazQ/77l9+58rKsa7pOn35OmGw4vpEF32fv8yioZn1uyFdxvDLjLZwu3I+D2JCs/uP8X0kpORFQRMegmCoNqCa7pwJtqXuR83NRwsAynlxtgdASv4VJUS7fV/5ZuzeyhoJwuEF+7X3fSuX6G/f74dr8206VfvofPzGrW9S0PgMdEA92FiF9W2Cu25+dm4feYe/Fp9AuhCUT9sfcf4J0+9nufdEG3btst3roG+NnSvXL3CXR6cp4KGAKSnw0sfh44vOHM1mn+XzAiikCSUl6Uc5tVLzT8V79WvisrzN2kK25JRFSBlNEze6LI1qJVO5fnx6p1dD5uZjzkuaW7uodhx8LR0q0FUXU7lA33Hvt0FwTaNq8t3fZALTe/ILA7cuKUz5butAx9q7IW9O5V81Cp3GIOdsgwDx+mLqg/fdp+oSBp73w0Nx5EX9MGmEsrRfqjwcDh9fZ7P+kvMFnz/b0Q4amlW8Ot/1uN03kW3D/THjz7K/v354DFzwHv9D6zKN2FGbZ0UwUkfbiLcs/gVs7hv14Y3QEtatu73Uw8r6nX90jquVQ8JyKqaBh0E4WBoXVBy7aIjTKp8bxztBg8Yr7Oc0v3DfNQFhiLM9RVKHgYp9ugC5StvqqXq7uC1zMy0gFzLrBtHpCfZZ9oKViWUd+iGmiLp67fvs3qZ0v3R0PsQ58FShcYJhrs/dTjTm4pWJe3CxFh4lqd3+D7M5G/LUtXNM5HIBxUg77NhgMbl3pdvo1BN1VAMrRXx/pVipxP+mdvO3JaXeia8s06jJy+TE2XYPyKs1K89usmIqpoGHQTlZLNCWer+/XtHyiUIxwbZcQ/trZol/cRvrBegJqJHqpRxxZ9AlTSjpzKghHBpJeHrqm7qLjK5m0orjMBtFXX6puVeRr47X7gyzHArJsKBd2D9rxcjA3VfF4I8BgI7/0bmP9YEUXWCn+WUinaPehGfkErvTnPQ8G4cNJ3d9cH3Z7Sy78cC7zUzJn67b24WRAR98ndatktsl3rENh0fctZSI0qoo0H0pFZRL9tCZ6l1dq9cJrj+ZjunoNu9usmooqIQTdRKWl1xw9IGzcHHUfdX+g1CbqFo4W7W2MP4+K6DzkVBruPZsAQRMuf6iMr75O+vmYPhcACrN7ti9eW7jMpw5qupTs3KwNY9Yn9yZafzyzArbU14+CZ9wcW1DU4vMD52OYhO8CqC+4Lvear+JmHTt25+QVBeiWjfV1mTRfM6gLwUpNrL+hWVEu3QQ0o5yPo3jG/oML9GTZPfbqL+npSfwAOrXOdtuD/gJwThWY16JbPoJsqEqn/8O4fOzFy+l/472gWaleJxY19mnic12y1eW21dlQpd081l37frF5ORBVR+M/iiSoIY0wl1Grdy+NrJpPr9a/KsQX/NVfbmuN/lvPxCsIvSgKkYMeX/vM1YOH/QWtzcWDt3ptmAxu+A0ZMB+KScCQjF/V9zO61T3f6fiCpAay6oLvd7oLhjZyy3YKwM8OKaVoANeUteUg5NLeI9HLvfbplGwsl0cvFim+uRre0xQXT5EKAwYDsvHw4agJ3Sn0R2PUmjFFtC9YfSNE2+X5NIRjXe8mLwKCniwy6TboLEjZf/dzzTtvv87NgWP91YNuyf5X67JQn0ousIK9PKfcY4BNFoMPpuZjyzVos23lcPR/crjaeH9URi7YWHgZSRJuMXlutHdMfGNpGjc3tGN+bATcRVVQMuonKAvdW1J63A2u+wO66QzFq11VIiI0qE0F3bdthJP4XYMDjCLL+fks9Nmz+MbA3f3ut/X6WFTi2FV3hfQxYYfN2UUCKez2R7hJQVck7VHi+rKOuz88s7+CpHJ/BvovjO922qXBLt68A0zm//C5yTwGVqgGrPwO2z3PZaWtWMwxRMdh5JB01z0xLzNoLZAHtsNU5n0X6rfshbcmHqLVwCk5e/Bmqdb0ExXLKdVxfPf3FizY5q/yr6O4Iun+5G6Z1X3mYQUO8loXRpjn4xXaO60tHN3tepofvRS1J39JdBodcIwoVSQ+XgFgC7neX/If0HDMqRZtw/bmN0bRmPHYftwfLnjiCaGnN1qeYu7dmy2MG20RU0THoJioDCmXG1moNPHgAKVGV8c7mNHRpaK8ke2zCKsx/5x5cHrUoHJuJBpa9gPehW30zFrP1dNscv2ZLSFvt83VPrc4+g+4zw4odz9S1sEsw/O87QK22QNPzCi/jWEHAq2b3ENxZvfU916c0//aAfT0DHvGYPi1BalRUDD796z+cE+P9T7Lm+xd0S8Atkn68Buha9JBBPvloIXYtpFbA5mvIMEfQvc77RZ97bR/houjFuF6T38qZizWKoXDqu4wnfyaLofCm66uXs6WbItPzczYX6o/dsUES2tZNxLTFBRcOJaj2FVizNZuIqAIF3dOmTVM3n30hicqT2ASVYjykfZ2CaVVTsNDWBZcjsKD7O2tfXGpagrAKRcqyH1que977i5pWdDVq96BbxnB2C9tsOxbCKAGxe7qye4B4htXDOjWLHy3dEnCLhU/jQJe7CrW0m/PzYYzVYNL1i/a4PB8t3b/8MhuVEqpiwHn9dRuH4ss4AHw9Hjj7ZqBJX7/e4rUInstn6nnjNE1DT81eEK22wfWCgVWDa7r+5yOBAyu9rkofaOtbvYkihacCaKJXs+oeC6NJNXJfaeJszSYiqiCF1CZNmoTU1FSsWLEi3JtCFDB/a3SZDAaYC/f2LZJRF5TdnT8Ro/KeQKnzNL52acs56bHV2XWeUx5buvXB3uaNBSnRHrkVTvOUXu5rGC9Phdf2Hi9csMicn6fG4DYWESV769O9Z+9uXLjiWgxYNMJlekAxt7eLBwdW2YvTfTo8uJZuSevXp6h7KHjmrfiZu40H3Yq6+Qi47RtScJHEkHUEyA02vYOo7LHaNLy/1HM3HU+BuL4w2qiuDZgqTkRUkYNuovLM5mfUbTQaYAkiQUUfdM+09cVuTdd6HqRTmud+fp5UQh5wai/CLuuo72wYTYN2aK3rtGx7USG9ExkeKvZKwPjfYnvBM7eWbfdAf8/xLFjyvfdfjtryk19jUJvNeTBbNUTD94UEfV/p3cey8Or8bTiVnY+cY7qgVreNjqBY0qy3/voWju70krK/YwHwdE3gnzMt8r748Rt3uTjw2QhgavuC56cPFbF8KXTneR35FlvQ/x/r/TAWeL6h6wy7lgA7fg9omURlgdSmuOL9f/DrhsMBvY/DfBERFQ+DbqIyoKsuVU/S+3w5rVUKePnu6ceWEPzXX29zHQqmXMjN8Njq7LRpFgzuw0rNvhk4fdgloMvXDdHltOgZ4LNLgNkTC/VN1gf6S7cfxdUvf40v/9zs/SLF/Ps8pk+7s5jzYFr0f3glxnfQq+nSyy9680+8sWA7Hvl+IzRTrHO6Lb/whYTUuR+i1fKHUfNzXeq53hej7Pcy1vnuP71vwMqPgZeaA4fW27fHw7Bnarr+c9vjYXlnUv09v9lauFr9a+1V1XyjMYDf+9/TUH3V1MLTHZ+hXFCR1vsvRheudE9Uhv28/iCGTF2Cf3edQHyMCf1bOcov+sZhvoiIii9i+nQTlWedUqriixvOxuGMXAzr4L0VWqrKHtD8O1HSc28B1IIMuo9H1UZ1yxH1eLvWAK/lXYrZsY+j3MhLh2bzsdtb8ZHn6Ru+dWmplRZmB6vVpoZ805a/Z28fTv0e26NaopXu7ZouXXzlgpn4I7bwWO3BZENY8nNR6R8PAaIbTVcwLDPPvi2r95wEOhZc7LHmZxf6VWT+96/3hUohMr1PLvQ+78932u+/vwW45S/v6eW++nQLDxcGnNyHdJMxuNP3Ab8/AUO3F+C3uQ8hwdN0qSIfXcd1yLyck0DlZP+XTRQG8n/+8R82Yebq/ep555SqmDq2MxrXiFd9u79duQ9fLvc82sALoztgbA+3TA8iIgoYW7qJyojeLWrg0m4NUDnGe1AYE2XE9/e5DuU0z9ot4JZuq5//9TfbXE+2ViUOdGktX6O1QJ5WOgXSQtbS7auQmqfWVWF0/U6M+uBQgk1NQ4Yh0TkpJ881dVw/7FTfdD+HTPvhNtdleMgvt/ga11rHZinYnouNf2FZ7G1ohx0w6FqHbXkFAW2UQcZjt/jsJ61arwN15rNvYN7j8WXNRz93xVfFd7duA1apUH6GUd+yHmw1cunrLxc+3FvUicJIguZZq/ere0/Tv16+F8NeX6oCbqMBuGNAc3w7sacKuIX00x7TPcXjskd1qceAm4goRNjSTVTONEh27Ut9p3kSvqn3A9of+QHocSOw4v1C79ml1XV5no04vGgeq1rA743+xuu6ZlvPRRtjQV/sXBQE2OYzu49YQxGBUhmSlXESthiP7Zi+GaNcsgUGHf/M+di0b5lKZT6QG4ckY8H42d4Ko5lsPsai1lvzedHp5X4OBabpgvM3Yqap+3vM7wK2t53TrXluqdtvdUeUsZ33hZ7wPV66ly1RxdEamj2/1/1zKyTPrSCa65tdvqP9aSfQ6Mxjg0QbZ0j3gqCuNi94CpD+/lfMCObdRCU+5JcM6yXDd3kaCqx+1UqYOq4zejQunJnhaaxtCbhfHduF3xoRUYgw6CYqj675yVkV2gITKo98Dci5EUg52xl05yIGcTWbYnO7KXjrtyhVzGzMVbcBH9uHXqp94UN4/MdNXoPu/VqNQlWxc7SCwaDTtXjERZevZJns0yehVXO9AOEXUzQMRQzLla5LSu6yY7rLa9GH1wKW/UDn8TDZgrtI4Sm9XN9X29/0cufyDCYYvbR0Kyd3oUmMjwsEkm4dqKNbgMMbvL+ua5H35PBvL6GOz2G+dF0A8nKcjw26lm6zJR8FPdkDsPUXdWeb/7gzaD+RmYdk3yUYiIIiLdXehudyvO5paC+Z31MF8hv7NPEYcDtwrG0iopLFoJuoPKrWxPlw5qTz0LSOnJT1cZllvaE1zpq0FE3MVlRauhA/17gT17ToCeBX9bqM//3mwh04ak5CTYPrkEgZWmVckvd/GGP6w2X68byCIPsUEjC0fV3Aez2wMkfLOYUY7Aj8jUYJun0t2IZOBu/LrfnXmX7vCbVh0vxLCS+0Cg+p3r7G3y4qmD1lrIYaKAi6NQ9BdLX8gy5FmC7qWE/3qs9PxKvszfNQ2ctrRfXpzjm62+trmlvad7RW8DcbDQW/W4vFElzQ7aBrjc/JC+67JAqmBVtPAnJPflhzwOP0J35KVTVD3Jejx7G2iYhKTvlqpiIiu6opwKCngYumokNK4VYQkWewhxZx0Sb889BAfHtzTzXk2HtXdcMrYzqhdpU41Xp6cd7TuM98o8t7D1dpj+NIKhRW7c6wubR0X9WzEV7DFep5mla1zH87tda+iZS/Hw38jdY830NebZ2DygY/0sb/dynaWoK8SuGhL7omw5P5QXME3brq4JnGKmpIMIfE78b5XMa8r99yneClAnlR8v/zUeW8iD7dRs175fkm619DlC4boVHuFudjfXq5xVzEOO1F0Kf56wvkEYWCtxZs9z7b3obwWvaf94r6npZDRESlg0E3UXnV63ag+3VeX3YE3SLaZFQBtxjUrg5Gd2ugHkvQfQjV8Y21P5BcMATYsVZXqnv3lOpcXXp5y8YN1VBn0/KHo2Pu+7g8/2E1faOtMV4zj/a4TYe0clrp+ee70CbXrVq33va5Jb4JzTNX+5U27vWiwZFUYOYNBdMMBt/Dp7mRvuA2q80+3vqiZ4GswuOX+6NyjvfxgbUiUu8NPoLcyqd3IwGehxRzuTyw5y8Uiy7jwBBkVwEib7y1YLtPn7vJ8/8jk9GA7o2qBbx8IiIqWUwvJ4pQeSgIkL2x6iti3/C7vVBU497YtUpO6DYWaunephVUuY2vYg+gLTYNGYhHhhaPtrkfIRuxmGj6yfP6YMT4/AfxQvT7aGA4hkiRnyc96EtWo9zUwhP9TC83SEv3+wMAS0HLuMkgjeeBVeLOz8tGnFRrl8A7SDEWe00Bjxzp5V6yCnwF3f62Tif9cHVQy3AuS59xwJZuCjFvLdh7jmepVmpJAffUGi5qV4nF9PHd0K1RNcxYsRf3z9zg9/KJiKhksaWbKEJZTZWKnOf2Ac3V/agu9YH46kDzgUBULPo0t48Frq8G/bWlH7ZoKfjVehbW2priZOWCfuX6qujyLjNMXtf5l60Dvrb0RyQpsup2SfEz6FZDhukCbhEFa8DbbcnJKFbAXfQK8n0Gs8G2LLsEysWl71vPoJtCzFFJ3N3rC3Zg5PRlqr+3t9bqyQNbqIBbyNja7su55bymHouyERFRyWNLN1GEyospuo/1jX2aok+LmmhRy3UYrYbVK2PZAwNwcs4yYKt92kOWCSqgvtV8p3p+c3Thtl15z+w1B5D2e0G69b3mm/BS9Hsu85WnYcb8Ea4049arHvNrPpu5cH/zvjkLgPkLAlqfOdu14F6oGRwXAbxUMffVp9unEAbdLkO3hetiC0U0RyXxxVvTVLCtJy3cl3W3dw9y16ZuFY/L8VUFnYiISgdbuokizP+Zr8QqWwssrTG2yHllKCU5UYsyFd4V1KtaCTG6yTa33UVibJTH90zq3xyxsdLibbfE2tFlni8nnI1YRFiwUsaDL5uf43kXpcqMUShJmu1MS7eXKubBBt219s1BSbR0s5AalRQJkBtV95wK/s3K/YWmeWvFlmmjujZgwE1EFGZs6SaKMB9ah6nbmPjiVxP3NDa0Q+s6rq0qelHSCn6msdKqSzWXPuK9mtdActNEoASzlEPhH1sbnGP0r9J4WS+opdLLQ8CUWTCEWEmIyz3qM+iuYwlu/bUOuw59VxzRh1Y5H9vMZft7p/LNW/9rqYl596BWOLtJMvaeyGYrNhFROcCWbqIIVb9a0X26i2K1FR4b2qFtPe9Bd0x0QaBt8bCbiXK0aJZhN+ffhW8tfSOipds5ZFgZ1+Lgj/ZU8HKyvbYy/r1T+Sat1Df2ca2dUSUuCrNuPVdlFHVvnMxWbCKicoJBN1GEeWZke/RtWVP11y6u7XWHq/u/rW0LvVY3qSCFXMREFexOYqMLkmj0Ld1b0FjdR2nBB933mG/2a77iDE/2vmUY0pHgsyCcCy8ts2WFwRqa9PJSkXOy3ATdRQ1xRlQc0hd7+a6CcbcHtq6Fvx8ciM4pxc9iIiKi0sX0cqIIM/7sRuoWCsej66FD7gfIVFXJC7Suk6j6g+vFmjwH3dLSPTTvOVxhWoD3jWMwUKZFJwa0Hfu1Gs4hxiyaCe9oIzHRMNvne36y9sRNUb8gGKk2++dn8XMXWdbTy51VwcuD7BOAuXyMJRy2qvUU0aRY37cr9+OJnzYhO9+KpErReG5UBwzrUDfcm0ZEREFiSzcReZVnseE0KkPT7SriY0z4+LoeheZ1aenWPZbAdbPWCI9arsdJo73Qz7bWk7Dc1so5z2GtGu7KvwVX599faLn7bDVxRf7DLmN9/6/yVeic+67Pb+4Vy5igv1nzmWBb1uWPqOw0lLafref4Pa+hmC3xC6xdUFp27dsL5GejPNCsQVZTJ/LiVHY+Jn25GvfNXK8C7nOaJmPO5D4MuImIyrkyF3Tv27cP/fr1Q9u2bdGxY0d8++234d4kogrLrTFbGdK+LuomVfI5XE2UybWl28EkFYAkWKlcA5flP14wHVbMtvXBIa16oeXmIAbpWkFBIVlCckIcTsF3a3keCg9pFmjQ7bgvtE1a8MvWO6ZVwWeWC/COZTg+tAwN6L2Zmmv2gS/RxUjnF6laaDIn/LH1vz2w7f0H5YGtjHcroPJl2c5jGDJ1KX7dcBhRRgMeGNoa/5twjhoVgoiIyrcyF3RHRUVh6tSpSE1Nxe+//4677roLWVnlI9WQKNJcflZDtKqdiDsGNHdOi4917ef8/aRzMaprfbxyWSfntGhdS/eNfQveazwTxSfHuwat8WdKnafUK5w+KX3CpbXdOa8hB9XPvH+RtWCdei+aix4uzZf8M8G2xUuf7v+zXAWb5uGKRIAOaDXwmOU6PG+5XC0zELl+XFQwa/btN2lFp0Gf1FzHatfbbGuIkrbRZu/vP2TjFBgXPuXy2gkf2xZObOmmUMi32PD8nC0Y/8G/OJyRi6Y14jH71nMx8bxmzguVRERUvpW5oLtu3bro3LmzelyrVi0kJyfjxImCQiJEVHqkL+Hcu/piyqCCVPAEt/G5pajPq5d1Ru0qcR6D7nsHtyoUdNeqEuuyjMoGe9D9+o1DsbXbEy6vSTEz/Rjh8chF1UrR6vE7lotd+n2LqZZRmG69xO+/8TtrXx8t3Z6DbhsMHquyB+qolhT0e721wus9YL5R3beybPU5n1y8+N56bqm1dHtqpV+h627gLtmQiTKJfbqpmHYezcSot//CO3/shIzQKBc6f76jNzo0CH7fQEREZU/AZ41LlizB8OHDUa9ePVVI6fvvvy80z/Tp09GkSRPExcWhW7duWLp0aVAbt3LlSthsNqSkpAT1fiIKvYS4ooO9aGNBsCppkg6OWms1E+1B93xrV3X/vbWXuk+Mi0Za6ytdlqWvfu4IuqucCbr1QfGD5gkYlvcsXreM8rltj5uvwUV5TzufZ2gFregOjhZuKdrmiaaC7uLXoTxWjKDbWyu83hFU83tZvpa3V6uNUMpGHNbHdnOZ9ol1MMobtnRT0L8dTcNXy/fiojf+xMYDGahaORrvXNlNFUyrHMMat0REqOhBt6R6d+rUCW+99ZbH12fMmIE777wTDz/8MNasWYM+ffpg6NCh2Lt3r3MeCcTbt29f6Hbw4EHnPMePH8fVV1+N9957L9i/jYhKQKJbS3dR43Trq5y3rJ3osoxJ5smYkj8RL5gvd84TZXTdLbm3KK/RmqPBmTHI82APvkW+Fo1UrbFL0Te9C/OewQvmcfjSOhAbtaZ4xXwpbPW74SXLZfjJrShZrxZ1PQb8oW7pLqpfui/urfDHWrgWjrs5/06YNc/fVYbm2kdUMgl8tZzL654yAoIln930mo9g+1n/55wm26ovrucu38sFkLCysZAaBe5EVj5u/nwVHpy1ATlmK3o3r4G5d/bFkPZ1+HESEUWogM8aJYB++umnMWqU59akV199FTfccAMmTJiANm3aqP7Z0lL99ttvO+dZtWoVNm7cWOgmreciLy8PI0eOxIMPPohevewtYN7IvBkZGS43Iio5besV3TpriHFtPZ59ay+M6FwPL13ayRmIP3JhG+QjGrNsfXEI1fHjbfb05miTax9GR+B7bu7ruC7/XnTuNxrVKtv7M8v7C+bz3fdxk9YEb1svdgaXb1pHQbthAXIQp1rJ9aonxeP3KefhOAqKw7m3dHsLyAMJFvUXDQLlHlAf6X6f87EUZptrO8trevwOrb7Lc6nS7m3eR8zXITEuCvOsri3TxSFBfH5UIo63HOecdhIJOO0h60DsstX2K52+1DG9nAK0dPtRDJm6BPNSj6h93cPD2uCz689y6Z5DRESRJ6R9uvPz81VAPWjQIJfp8nzZsmV+p1xde+21GDBgAK66qujCQs899xySkpKcN6aiE5WMmbf0wmtjO6Fbo6JTlo/X6av6Cb9hGaGed2lYDVPHdUGdpIITy4s72y+yiXpJcejYoKp6HG0yYtOZcbKFRbPvpg6gJhbZuqBlnURUijG5FDwTjn7fl3Su52xJvz7/HuRq0bgj/zaXKuvVKkfj2ZEdnEWKMlEZR7WCANsUHYfmtRJQLaW1x79PiqgV1dI919od5+S+iY+sQ4ssdFZclvjaMEYVFFZzBNDeUsbX2FoUDrq9tIp/Yb1AtcSFMuiVz08+++joaPTOex398l5RFz9Ow3OV5lvMd/lMf8/zsu0l7UiNs8OyXip/8ixWPP1zKq76cDnSTuep/YsUobyxb1MYWSyNiCjihTToPnbsGKxWK2rXdu3/J88PHz7s1zL++usvlaIufcWloJrcNmzY4HV+aQ1PT0933mTIMSIKPQm2R3Zp4Ne8jWsl4Trz/XjVcpnXeWKjCoIok651O8pkwPD8Z5zPc+BadM1i1RB/JqiWlHKHG/s2w1tXdMELozui65kLAwttXdEu7yP8aCvImOnasCpWP3oBrjjbtSL3veabnY8dAWx+7S5qDHF3EuD76tM9If9u3GyegqevHowOKQXDoL1luSTgftnexBgKUpsPX70MUdExhS5AeAuUM1EJN+ff5dbS7f3vkVa4YINu/Xr065O+/jEmI/ZrNbFbs6fze2vp3oqG2HSmurnH17UUZGuuv5PScLJq+1JfJ5U/24+cxohpy/DBn7vU8yvPaYifbuuNdn5kDRERUWQokerl+j6cjtZr92ne9O7dWxVPW7t2rfPWoUMHr/PHxsaiSpUqLjciCq/ujZPx2EVt8fG1PbzOE6urcG7QpYZLS7cEjU+Yr1YVyd2H0srMs6DWmUJs+pbu+EqxuKhjPcRFm9TwZTf1baqmu6eBx0QZPe6P9POZos8EcFGV0CfvdfxpbVeoT7cEjp68Zh6N3232VOxWdRJhjioYY/w9y0Uu83pL6fZHNAqC7qi4BJiiCy5AbLfV97n8LC3WJbVd/hZfFwBuPq+p15bwomSicNqsfL870jIRHWUodDHAE6mYP8V8i9d1GKDhC+v5KG1yAYjIGzn3+fzv3bjozT+x+VCGGirxg6u74+kRHZzZOkREVDGENOiuUaMGTCZToVbttLS0Qq3fRBTZru/dBP1b1/L6urRyeuKodv6JdQh6572hKmef27ygtTgrz4K6Z9LU9X26TSgIgGokxOKhYW2w+J5+Kt38w2u6F6xXF+zr6YNoR6uxBIXSwisF3543j3MJ8/Sp4bN1w23t1Wq5rGt9nUuxwdZYFW7LQLxKp3YoTgX0eJPV+Vj6hppiKuNbS1/8Zu2BzGYXnlm+yWv18NO6Ymo2zYhEQ7bPoeNSavh/QVM/hnmmW9E2Z59uq01dYHG4+4KWLi3dm20Fo1bYbBoOo7rq1/+JxbX7kmhkSCtW1sAhLblQMb2DWnKR77PaGHSTZ8cy8zDh05V49IdNyLPY0LdlTfx2Zx+c35bnQkREFVFIg+6YmBhVmXz+/Pku0+V5UQXRimvatGlo27YtevTw3rJGRGWHvh+jvuFZH4g5vHm5fWgxR0u3BIHuLd1GrSAIdWhcIx6vj+uixhL3NISZnn4s8KiYWJcLA+lIwHvWglZqCbVmWfuox9L/XN8KK62u+r/FEpOI4fnPqsJt/3dJOxXg6feZ+pb/f22e+5CLn62u/Ydb14hxGRc9ymTEvZaJmGi+S/WV9hXUSyAsFwAcJGCtixNe1y2fg0mXvu6J/iKE0VDwGTw1xjWYdWQK5ORbXS68tK+fhAwUBN0vWC7HR5YhGJn3JKwygPGZfv2fWQsH3VUM2cWqJt8z7y3cbr7DOda7fRt9L29U3hPO7SJyWLP3JJ75JRXnv/IHFmxJU79xyfr55NoeqJXIYmlERBVVwGcpmZmZzrRvsWvXLvXYMSTYlClT8MEHH+Cjjz7C5s2bcdddd6nXJk6ciJI0adIkpKamYsWKFSW6HiIqWe5Bd4/G1VRaZp8W9oBodNcGKj18ZJf6LkG3yVA46HbQj3trtXmeRx8sR0XHFdoWCRQLHhtVJXTpu31F/sMuw5Rl6dKppQW6YXJBINmsVoJLi3rVxILA94mL2+Ga/PtVMOeJqddtOKob19uoFaSXy4l9tO5igqTYi3wvKeHZiHUZn1z+Hpnmyf8mnK0CemfKvRc58ByUd+rYBYhJBKrUd1mfBN36z1cqpOtb349o1fCU5Wqs0VrApvvOpPOBJ9YAitKd1BJwQd6LWGptj9F5jzun52oxPtcjVdRlGxdaO2O11hIWtnQ77d69W41c0qRJE1SqVAnNmjXD448/rgqshsuMFXvx0Kz16r40PP3LJoycvgzvL92FUzlmVbDxh9vOVVk/LJZGRFSxBZzbuHLlSvTv39/5XIJscc011+CTTz7B2LFj1RjbTz31FA4dOqTG3/7111/RqFFBNWIiIm/9u6WQmp4jMPv0urNwWtfK/drYzpi95oBzPpOHlm5Py7fqIzgA/zeiPT5c+h+MJwumO1p1XS8A6INuqV4e5ey7LZ4yX4Wuxu0u0+T9cnFA+i+f3TQZJtWkX7AcfetxvsWGXMSqYM6TxjUScECrgZqGdPt7bfku63FUYheOFmRvKdenUdmlVVn+nmmWEbguam6hec9tbr/YYYzyHXTnqaA7p/ALUpTu3h32dIanaznXl22WoNvgcmFEtsvTxQubpqkMBQlyo+H5ew4kvVwC5+1aA1xlfqjQUHAORt1FGL0eedOd/eEl7Z3stmzZouqxvPvuu2jevLkaBvTGG29EVlYWXn755VL/mEZM+xNr99n/r3y5fB++Wr4X30/qXWLr+37NfnywdLfLtJPZZuSave+XiIio4gi4pbtfv36qOIj7TQJuh1tvvVVd9ZYxtGUIsb59+4Z6u4koglTStURHG113S/Wr2ls/paXIEXB7opm8B4X6Vib3lu6rzmmEd6/qDpOuZTPqTKtuQlyUS4uvwy39m6NZzYJWaiFDg91mvsOlIJtKyzYa8MDQ1ujfqhaqJ7i2BkeZovH8qA44r2VNjO5WRGV4gwFTLLepodguy3sUf9SyF5j7n2WgWoe0Rjs4gllvgWh+dJJLVfgTSMQxJOGG/Lu9rt4U6zs1Vi4YuHMG0ZI5oAvapbVf+kPrtzku2ujS/ztbK1ifpHE7LiqYvATdP9gK+tV784e1I3bY6qkhyIriqS96A8Mx9Xc6MhvY0l1gyJAh+Pjjj9UQoU2bNsXFF1+Me+65B7NmzUJpk5ZtR8DtIM9LosVbnf/8tQv3fLve4+u7jmWFfJ1ERFT+lEj1ciKiQFSK1gWMuorW8TEmPDisjdf3PXpRWzxtHo8vLf1xulZBC7Mv7i3dokqlKJd0YlOUPdiuqgvyHcOUiSY1/Ssq5p5S2rxWogrAnetNqIRxZzXEp9efpSp0e5KpxamiXjnJbbHPUEcNxbZca4PDcU3QOvdjPGy5vlBfdUeAqk+/17tlqNS+KJj/8Jl+5jIOugTx95pvwoi8p9A99+2CvyXG9SKDu3xDwQWFq/Pvx1ZbA9yChz3O60jV12+ztNZbDQUXCbJ0Qfybl3dxzrtNKyiwpidDj3XMfd/nNr5hGYnz81/GJs3z8GP6dutdZ4YxE1IIT/xta1vkb4kKyDCeyclFF6QLtXX7TgU0PVhHT+fhuk9W4ImfUr1egGlSw/f/GyIiqhgiJuhmITWi8ite19IdpWvpfvvKbqo/tzft61XBB9YL8ZDlRhjdWsi98XRyLC3o+nTi6DNjiFetXBB0J8QWBISJcTGFko/n3dVXFUwqysTzmjkfd23svbq7yNFi0CHvAzVsmaRp64dWk3jP3rpsKFSV3Wy14d+HBuLj63s6p820FqTWxlapqe7fsQzHKlsLzD7zWtNaVfCw5QZ8a+2HtVpz1frtYIotKuguCJKX2DphcP6LWIcWHueVPt3PjGyPStEm5wUCGQvcFp1Q8Lfrgm4ZCq7gQkI01kd39LhcfXE4d+9bhmGVl9R9T+nl31ntGVrHtURcn38fXjVfinvMrrVJvNUHIGDnzp148803i6znIhlxGRkZLrfi6qQrnOjP9GAs3HIEQ6YuweKtR1X3lacuaYeb+zZxmeeW85qiS8NqIVsnERGVX8GPV1PGSCE1uckBOymp4ESRiMo+/Zi1+n6+RQ3JpE9PtveXDm5sZRX86Vq6HduQ5KWlGwbXAF/GDW9ZO1HdpHDahM9W+rUtzVt38vn6bq22SmWWhGq1Rbo/Ufo56+n7n+88mqWC2ISYgmrc8cgreJxgD26ft1zusoy7zm+JSV+u9rgtlSoXBMSe5HsqpObl65OhJcefba/zsfGJwSp9XC4aHIhujM9yL0CaVhVPXtwemw6mY2SXBoW+a32A769nLFd6fa11nURsOXzaJeiea+uBa/PvxVZbQxxFVbxhHVXofWO6F9ElIAI88cQTePLJJ33OIwVMu3cvGJbv4MGDKt18zJgxmDBhgs/3Pvfcc0UuP1BjezRUfbj1KeZdUpLU9OKSPtrP/roZn/29x/nbeePyLur/vhjSvq5KKZcWbgbcREQUcUE3EZU/HeonYcOBdIzTnQxLZXKHovrM6oec8jISWCGelinr3KPVLtTaLsG4t6C7a8Nq+O+ovb/mT7cXtCIPaF1LFU9rVcd+Eu7R9fOA04eAWp6HCHvdMhK3mH7EfeabXbZR/zd6+mja16+CjQcyMLCNvQXdpA/EdenS3lLZNW9RMoC29QouZtoMUap6ujWhLkyZh9S0XAmE3d7ufmHAwWg0ebzgklApGo9lXqcev1MlFtf0KrgocflZKZi2aCfObpIM7XjhrIaeTavj7/+Ou0z7ytIfl0ctwhJrB/jy25190fiBXwr99YttXXy+T8aDj3S33XYbxo3Tj1FfWOPGjV0Cbim22rNnT7z33ntFLv/BBx90FmQVcuE8JcVzF4JASNE06cMtKeXSwh2KgDv1YAYmf70G29My1fMbejfBvYNbOUcLEBJoM9gmIiJ3DLqJKGy+ubkn9p7I9hqgFtVnVl/pvKghea7u2Qhf/rsXt/YvSO/We/i60Zj4ySE1jvazZ5Zbq0pBMa94XQo8qqbgseHNUTcpDhd3qqdalfXbIZXVfWroOua2u9csYzDdcsmZiuB2TWvGu6SXewqQP7/+bPy18xguaFu7UOv3Wltz3Jx/l7q48N6Z9Hl3+kBeWuwv6lgQqLeuW9CPfVvKZWjd/3Ictyag1hf20Sy+Mw7B2ba1WGkrSOH2FsLrh1jTS9RdDNAHMmLywJbqQkePJsnY8lrB+49oVfFrlbHo0rBqoaD7Wct4bNEaYuaZMdWL5ueVmwqkRo0a6uaPAwcOqIC7W7duqqiaP10+YmNj1a0kSKAdimBbqtR/9NcuvPjbVuRbbaiZGItXxnRC35b2bhpERERFYdBNRGEjrZy+WoSLaunWp6Ibi0gvf+qS9nj4wjaI9RJwSnr6b7azzizX6Ewv/37Suc4q5LhuzpkW6jaQEPTuQa1QEqQfe63ERIw/pxEu7lgPeRYrqsRFq1G3HDw1IleLj1H9nx301yH2arWwVbMHIPG6/unulZgdFt59nktKt0vfepsFaNIX1t1bnJP+QUecl/cqDmnVC2Zz28h0rTKSDNlYEdMDnnpl66vF67MMhKSfD2xjv5hg0xVcOztvGjrFVUN/XZ92katFq+rpn1oHe/xbKbSkhVtGN2nYsKEaIuzo0aPO1+rUqVNuP+60jFzc/e06LN1+TD0/v01tvDC6A6pXgCwHIiIKnahIKqQmN6uVY2ISRYoi+3QbA0sv9xZwu79fX1W7s774UqNeKA29m9dQ/UQL2PuWG/xI3daTlPQxeY+hjuGEM+AWEjBIn1PHcEbXndsYQ9rVweGMXOc8+nG/RRVdQGyz2PuHW+LrIluLVeNWZ9uicFxzDa7cv77BeS/gbONm7EkejBs8bK8+7V2fdu67pdyA3Hyrs0+tQyYKD/nlUK1yNNJzzIW2T9+nmwIzb9487NixQ90aNGjg9WJOeTJv02HcP3O9Gm9bhrST0RKuOKuhSxcYIiKiClW9XIqopaamqoIuRBQZmtfyXbwrWte6WVR6eVH079enZZcmaVUff3ZDPHFxO4+v60/2/Y1jVmit8ZOt8MUCfer448Pb4eym1V2W6R5YuPS1t1jUfa1qCeiS965qbY6LKTyGunuwdRjV8YOtNzSj5+u9CbHRXlu69fZHuw75lW22YGj7OnhQNxybXAwI1A9W++e0E577FMuY8RueGIQ7BrZQ1eqpwLXXXqu+b0+38iYn34qHZm/ATZ+vUgF3u3pV8PPtfVTxPwbcRERUoVu6iShySEBz4FQO2umKd3kSbfQ/vbwo+veHK+iWVnWXlnU3+j/Rn5ZuT648x97inVKtcqHXilqmDJt1ddQ8zK95jUoPl8yB5Y9dBEk4GPfeP+o7c12e5+V4u0CSGOe9T7fenKTLkHbyFBZYu6rnOfk2FQzdfF4zfLPoAlyG+YUqs+t5C5w+sA7DdjTA/srtZTw2L9sYjSkX+B56jMqvjQfSccfXa5xFEm/u2xRTBrX0mSVDRERUFAbdRFTmOIbfKoq+z3Fx6eMwfYG2skS/VZef1RA/rz+Erg2rFlkhfuPBdIzp1gBZ+Vb83yXt1fRRXeurdPJezQr6YBcVx8uwWW9YR+LeWgXF6JLOjGUufc79DeK9De/mb3q5xRiLlywFFbVz8u0t7+IpbQJezhuBNAQ+PrIVJiy0dsHsq3ph5PRlzukzbjoHj/+4yWsGApV/Uizt/aX/4eV5W2G2/n97dwLdVJk2cPwplAItbdnXYqGgLFKKQBEFZZNFQOHDAWVRFHGUAYSjsgg4LCPCgMDMuLHoIA4oeAbwE74RRRSQAQa17EVAZQfBBQqySen9zvM6iUmapClNSJr8f+eENulNuH16t+e+7/u8llRKKC4zezWSFrV9KyIHAIA3JN0ACi3HQmrX2vJr4/j2Yj5UXQ4GxxZaTQbWj2gjlRN/q5zuzvI/3G6SCNckVm9YaDdpR3lFcPHvm8uHu7+TAS1q5vpZxYTc3bnLORZfc+CpV0K5UjE+dS93vSfi+HlXc8SecCeXi5VDP17I9f4bK5aSjMOnJcdhznad/umNDQdk9N11zZRPU3qkyrPLdpqfadd7nVYM4em7rEvy1LvbZOM3v1a/73hzJZnao6EpTAgAgD+QdAMotBy7gWtLlb+KtoVqS7drr+wbyuXuIu5Kk2tfe8bmdeOieUo583BnVKe6svXwGXmwebLUr5ogUz7YIy/8j/v5sT3d09Ax0750L3dN2rum/TY+/eKV34ppLnikmTz/f3vk4z0nzfOBLWuaMbrPdLzJFJH7w6IMeb77ry3/YzvXM+PptcCc6tW0upy5cEWa1SzrcT1Q+K3adUJGLd1pCuvpjZ4J99Y3f3vGbgMA/Clskm6qlwORx7HKeF6VzvOTcIZq0q1j3Dd8/evURQFRgBBWLV1S1o/8dc5upYWn3FVl1/Xvf5tzITQbW4JbOrZYrurpnsaE925WXcZ1qZ9rGc3La5SPkxd7NpRGk1ab1xrdUNo+pVqVxJKy9bn29uRKPzOlwm+F+/T/H9Ta/ZzuKPzOX86WSSsyZckXR8zzhkmJ8pf7GzltAwAA+Et0OFUv18fZs2clMdF78SUA4cExMbtawO7ljkl7qHYvn9krTf6yZr9pTQ4EqyBZtw/+/nC6HDl9QWp5SGxKx8bIljHtzJzc3jjm41N6OM/4PaJjHZn+4V7Tyu26jThOMadozYxM24+ckeFLtpneDnrPZVCrWtK6TgXZduSMafHW4QUAAPhT2CTdACKPY9KUk1Owz3JM2gs6/VigVEwo4bHLtj8EenYnTaY9JdyOv2NevFWqH9ymtpl3PDYmOlei7dgzApFHb6zNXveNzFq9T7JzLKmSWEJm3d9I1u49Jb3mbLYv90SrFBl9d72grisAILyEZnMOABSgqNq1KOiY8HBw238rmefV0hxsed0UsSXcuVq6Q3TYAALv+JmL0mfeZtMLQhPuLqlVZNWwO6V4dBGZve5bp2X1+dbDp/mzAAD8hpZuAIWaVuD+5tTPkl6jYAWvCjomPBwkl4szFdFLx+We/iuU5GdO9mgv3csRGVbuOC5jlu2Us5eyJS6mqEzs1kDua1zN9JTRLubu6Ot0MwcA+AtJN4BC7an2N/nlc6qV+a1ydiTzpSJ6sP3+jhRZsf24aa3MT6s4Ld2R5efL2TL+f3fL0oyj5nmj6qVNsTQtsGdjq1bvytPrAABcC5JuAPhvZfAZPdMkieQ75KUmJcr28R0koUT+TmFlYpl3OZIMXpQh6/Z9bwrvDWlTW4a2u9FpmkGlrdk6htuxi/mgVim0cgMA/Cpskm6mDANQUPc1SSKIhURiSd+7wE/pkSqnzl6WOpXjA7pOCL1eMId+PC/Te6Z5HX6iRdM63lzZdCnXFm66lQMA/C3KsgJdr/b6sk0ZlpWVJQkJCcFeHQAAvOK8FbhYZF/NkWiX1m0AAK73eYszEQAACEsk3ACAUEDSDQAAAABAgJB0AwAAAAAQICTdAAAAAAAECEk3AAAAAAABQtINAAAAAECAFAmnebrr168v6enpwV4VAAAAAADCK+kePHiwZGZmyueffx7sVQEAAAAAILySbgAAAAAAQg1JNwAAAAAAAULSDQAAAABAgERLmLEsy3w9e/ZssFcFAIA82c5XtvNXJOMcDgAIx3N42CXd586dM1+rV68e7FUBACBf56/ExMSIjhjncABAOJ7Do6wwu7Wek5Mjx48fl/j4eImKiirwnQtN3o8cOSIJCQl+W8dIQOyIG9tb4cC+Gvy46WlYT9ZVq1aVIkUie9SXP8/hgca+Q2zYbtinON4E39kg52u+nsPDrqVbf9mkpCS/fqb+AUm6id31xDZH3K43trngxi3SW7gDeQ4PNPYdYsN2wz7F8Sayj8WJPpzDI/uWOgAAAAAAAUTSDQAAAABAgJB0e1G8eHEZP368+Yr8IXbXhrgRt+uNbY64gW2A4wrH3FDA+YjYhPN2E3aF1AAAAAAACBW0dAMAAAAAECAk3QAAAAAABAhJNwAAAAAAAULS7cWrr74qNWvWlBIlSkiTJk3ks88+k0g1ZcoUSU9Pl/j4eKlYsaJ0795d9u7d67SMlgeYMGGCmRy+ZMmS0rp1a9m9e7fTMpcvX5ahQ4dK+fLlJS4uTu699145evSoRFIco6KiZPjw4fbXiJtnx44dk379+km5cuUkNjZWGjVqJF9++SWx8yI7O1vGjRtnjl26H6akpMikSZMkJyeHuLlYv3693HPPPeaYpfvle++95/Rzf+2bp0+flgcffNDM46kP/f7MmTN5HC1QWBw8eFAeffRR+z5Xq1YtU9Tnl19+CfaqhYTJkyfL7bffbo7hpUuXlkjGdeW1HYsjlS/X3pHqtddek4YNG9rn5r7tttvkgw8+kFBG0u3BkiVLTGI0duxY2bp1q9xxxx1y9913y+HDhyUSrVu3TgYPHiybN2+W1atXmwv7Dh06yPnz5+3LTJs2TWbOnCkvv/yyfP7551K5cmVp3769nDt3zr6MxnT58uWyePFi2bBhg/z888/StWtXuXr1qoQ7jcncuXPNQcIRcXNPE5UWLVpIsWLFzIE0MzNTZsyY4XTRRuxy+/Of/yyzZ882++GePXtMjKZPny4vvfQScXOhx6+0tDQTK3f8tX316dNHtm3bJqtWrTIP/V4Tb4SHr776ytzUmjNnjrkpM2vWLLMPjhkzJtirFhL05kPPnj1l0KBBEsm4rrz2Y3Gk8uXaO1IlJSXJ1KlT5YsvvjCPtm3bSrdu3XLdGA8pWr0cuTVr1sx64oknnF6rW7euNXr0aMJlWdapU6e06r21bt06E4+cnByrcuXK1tSpU+3xuXTpkpWYmGjNnj3bPD9z5oxVrFgxa/HixfZljh07ZhUpUsRatWpVWMf13Llz1o033mitXr3aatWqlTVs2DDzOnHzbNSoUVbLli09/pzYudelSxdrwIABTq/16NHD6tevH3HzQo9ny5cv9/v2lZmZaT578+bN9mU2bdpkXvvqq6+8rRIKsWnTplk1a9YM9mqElPnz55v9J1JxXXltx2J4vvaGszJlylivv/66Fapo6fZwV1a7sOrdJEf6fOPGjdfrfkhIy8rKMl/Lli1rvh44cEC+++47p5jpfHmtWrWyx0xjeuXKFadltCtRgwYNwj6ueqeyS5cuctdddzm9Ttw8e//996Vp06amhUS7Vd1yyy0yb948YpeHli1bypo1a2Tfvn3m+fbt200LbOfOndnm8sFf++amTZtMl/Jbb73Vvkzz5s3Na+F+3Iv0c6Tt/AhwXQl/HVcUxxZn2rNMe5tpDwDtZh6qooO9AqHohx9+MH/ASpUqOb2uz/UiLNLpjcinnnrKXNzrxaWyxcVdzA4dOmRfJiYmRsqUKRNRcdUDQUZGhume6oq4efbtt9+aMTu6rWk3zS1btsiTTz5pEp+HHnqI2HkwatQoc2KuW7euFC1a1BzLdExl79692ebywV/7pn7Vm0au9LVwPu5Fsm+++cYM59DhMIDiuhKBuPaOdDt37jRJ9qVLl6RUqVJmqFf9+vUlVNHS7YUWc3Dd4F1fi0RDhgyRHTt2yDvvvOOXmIVzXI8cOSLDhg2ThQsXmoJ8nhC33HSMZOPGjeWFF14wrdyPP/64PPbYYyYRJ3bexw3q9vb222+bmz0LFiyQF1980Xwlbvnnj33T3fLhfNwLF1pET/9G3h46ltDR8ePHpVOnTqaHzsCBAyVcXUtswHUlAnPtHanq1KljaqTomHetGdG/f39T/ydU0dLthlah1RYi11aIU6dO5Wr1iDRapVe7/WqlSS1iYKMFhpTGrEqVKm5jpstoFystkOXYMqTLaGXTcKTdT/X30+r3NtryqPHTgiG2KpTELTfdjlzvWNarV0+WLl1qvmebc2/EiBEyevRoeeCBB8zz1NRU0zKrVVD1hETcfOOvOOkyJ0+ezPX533//fcSfTwrDRa5tP/KkRo0aTgl3mzZtTMuLFs0MZ/mNTaTjuhKBuPaOdDExMVK7dm3zvQ5H1B6lf/3rX01Ry1BES7eHP6ImSVop0JE+D9fkMC/aKqMn2WXLlsknn3xipkZxpM/14tIxZnoxqpUXbTHTmGolasdlTpw4Ibt27QrbuLZr1850f9E7cbaHHhj69u1rvtfpnIibe1q53HVqDB2nnJycbL5nm3PvwoULUqSI86FdbyLapgwjbr7xV5w0AdPu/jo8wuY///mPeS1cj3vhlCjpMA1vD1sPJp3eUKeU09458+fPz7UPRnJswHUlAnPtjdzx0mk8Q1awK7mFKq1Gq1Vp33jjDVN9dvjw4VZcXJx18OBBKxINGjTIVB1du3atdeLECfvjwoUL9mW0yq8us2zZMmvnzp1W7969rSpVqlhnz561L6MV4ZOSkqyPP/7YysjIsNq2bWulpaVZ2dnZVqRwrF6uiJt7W7ZssaKjo63Jkydb+/fvtxYtWmTFxsZaCxcuJHZe9O/f36pWrZq1cuVK68CBA2Z/LF++vDVy5Eji5mZWga1bt5qHng5nzpxpvj906JBf981OnTpZDRs2NFXL9ZGammp17dr1Go4eCEVasb527drmb3/06FGncyQssz/pfjVx4kSrVKlS9n1O979IwnXltR+LI5Uv196R6tlnn7XWr19vrnN27NhhjRkzxswc8tFHH1mhiqTbi1deecVKTk62YmJirMaNG0d0iX49CLp76BQgjlPsjB8/3kyzU7x4cevOO+80F6qOLl68aA0ZMsQqW7asVbJkSXPhefjwYSuSuCbdxM2zFStWWA0aNDDbk07ZN3fuXKefE7vcNCHU7euGG26wSpQoYaWkpFhjx461Ll++TNxcfPrpp26Pa3rjwp/b148//mj17dvXio+PNw/9/vTp0z4eMRDq9Dzo6RyJX28EuouN7n+RhuvKazsWRypfrr0j1YABA+w5WoUKFax27dqFdMKtovSfYLe2AwAAAAAQjsJ70BEAAAAAAEFE0g0AAAAAQICQdAMAAAAAECAk3QAAAAAABAhJNwAAAAAAAULSDQAAAABAgJB0AwAAAAAQICTdAAAAAAAECEk3AAAAECF++eUXqV27tvz73/+WUJWeni7Lli0L9moAfkPSDQAAAATYhAkTpFGjRkGP89y5cyU5OVlatGghoeq5556T0aNHS05OTrBXBfALkm4AAAAgRFy5ciWgn//SSy/JwIED5Xq0qF+rLl26SFZWlnz44Yd+XScgWEi6AQAAgDy89dZbUq5cObl8+bLT6/fdd5889NBDXt/75ptvysSJE2X79u0SFRVlHvqa0u9nz54t3bp1k7i4OHn++efNz0qXLu30Ge+9955Z1tGKFSukSZMmUqJECUlJSTH/R3Z2tsf1yMjIkK+//toktTYHDx40n6vdudu0aSOxsbGSlpYmmzZtcnrv0qVL5eabb5bixYtLjRo1ZMaMGU4/19d03R9++GFJTEyUxx57zP57rFy5UurUqWM++3e/+52cP39eFixYYN5TpkwZGTp0qFy9etX+WUWLFpXOnTvLO++84zWuQGFB0g0AAADkoWfPniYxfP/99+2v/fDDDyahfOSRR7y+9/7775enn37aJK0nTpwwD33NZvz48Sbp3rlzpwwYMMCnv4W2Avfr10+efPJJyczMlDlz5pgkd/LkyR7fs379ernpppskISEh18/Gjh0rzzzzjGzbts0s07t3b3sC/+WXX0qvXr3kgQceMOuoXeW1C7jtxoHN9OnTpUGDBmZ5/bm6cOGC/O1vf5PFixfLqlWrZO3atdKjRw/517/+ZR7/+Mc/TJf3f/7zn06f1axZM/nss898igUQ6qKDvQIAAABAqCtZsqT06dNH5s+fbxJwtWjRIklKSpLWrVvn+d5SpUpJdHS0VK5cOdfP9XN9TbZtNLnWcc/9+/c3z7Wl+09/+pOMHDnSJPHuaKt21apV3f5ME25bC7i2mOsNAm0Vr1u3rsycOVPatWtnT6Q1KddEX5Nsbdm2adu2rfkcmw0bNpju8q+99prUqlXLvKYt3Zponzx50sSkfv36poX9008/dboRUa1aNTl8+LAZ112kCO2EKNzYggEAAAAfaJfpjz76SI4dO2aeawKuSadrt+/8atq0ab7fo63JkyZNMomr7aHrp63o2rrszsWLF01XdHcaNmxo/75KlSrm66lTp8zXPXv25Cq8ps/379/v1C3c3e+hXcptCbeqVKmS6Vau6+v4mu3/crxRoQm3a3d+oDCipRsAAADwwS233GLGO+v47o4dO5qu1jquuqB0LLcjbdm1LMtrgTVNSLVFWrtqu/KUWJcvX96sszvFihWzf2+7iWCrHq7r4npjwXX93P0erp9r+2x3r7lWKv/pp59Mwq7JN1DYkXQDAAAAPtLK37NmzTKt3XfddZdUr17dp/fFxMQ4tQp7U6FCBTl37pwpOGZLZHWstaPGjRvL3r17zZzb+blpoF293SXR3mgXcO0q7mjjxo2mm7kWPQuEXbt2md8RCAd0LwcAAAB81LdvX5Nwz5s3L1/jsLVL9YEDB0zyrAXYvHWbvvXWW00r75gxY8y46rfffjtX0bI//vGPpsVdi5rt3r3bdAFfsmSJjBs3zuPn6thpTeR1+fzQInBr1qwxY8b37dtnKo+//PLLTuO3/U2LqHXo0CFgnw9cTyTdAAAAgI+08rdOE6Zjkrt37+5z3PQ9nTp1MomvtmR7mw6rbNmysnDhQlPdOzU11SyrybUj7d6uldNXr14t6enp0rx5c1PwLDk52ePn6pRn2h1dC8Dlh7Y4v/vuu6YCuVYn14Rfx5M7FlHzJ72poS3peVWFBwqLKMvdgAwAAAAAbrVv317q1atnpsIqbHRMt3aL1xb0+Ph4CUUjRoyQrKwsM5UYEA5o6QYAAAB8oMW9tLX3k08+kcGDBxfKmGnL+bRp08z0YaGqYsWKpis7EC5o6QYAAAB8HJd9+vRpM1+163hmndf60KFDbt83Z84cMxYcQGQi6QYAAAAKSBNu12m9HOehDtWu3AACj6QbAAAAAIAAYUw3AAAAAAABQtINAAAAAECAkHQDAAAAABAgJN0AAAAAAAQISTcAAAAAAAFC0g0AAAAAQICQdAMAAAAAECAk3QAAAAAASGD8P0I7try/jFoFAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 6.599e-03 @ epoch 936\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.30011e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=1.30011e+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 300\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  300\n",
      "\n",
      "Optimize a model with 161 rows, 8714 columns and 17680 nonzeros\n",
      "Model fingerprint: 0x815fab84\n",
      "Variable types: 8704 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-09, 1e+00]\n",
      "  Objective range  [8e+02, 5e+11]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [6e-03, 2e+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 1194 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 7520 columns, 15283 nonzeros\n",
      "Variable types: 7510 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 1.285863e+08\n",
      "Found heuristic solution: objective 1.261954e+08\n",
      "\n",
      "Root relaxation: objective 1.255760e+08, 153 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               0    1.255760e+08 1.2558e+08  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (153 simplex iterations) in 0.02 seconds (0.03 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 1.25576e+08 1.26195e+08 1.28586e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.255760139365e+08, best bound 1.255760139365e+08, gap 0.0000%\n",
      "[CHECK DFN] obj(x_ip)=1.25576e+08  ip_y=1.25576e+08  rel_err=4.727e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=-0.122  std(mean)=580  min=-1e+03  max=1e+03\n",
      "  y: shape=(1000,)  mean=2.58e+08  std=9.19e+07  min=4.57e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,610 layers=[5, 400, 6] 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": "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a/i9JhcuPPn+OnPmjDZw4ECtTJkyapHfz5496+Y3Bvk6OY6aHWP9nXwWjdpFPrv+huekBf8O91funLP7o6FDh+bGdRUrVtQ6d+5cZAG3CJB/iianTkRERERERORffHfQEBEREREREVExY9BNRERERERE5CUMuomIiIiIiIi8hEE3ERERERERkZcw6CYiIiIiIiLyEgbdRERERERERF7CoJuIiIiIiIjISxh0ExEREREREXkJg24iIiIiIj+RkZGB5ORkfP/99yipWrZsiSVLlhT3bhB5DINuIiIiIiIve+aZZ9CkSZNib+d58+YhMTERbdq0QUn19NNPY8KECcjJySnuXSHyCAbdREREREQlRGZmplef/4033sDw4cNRFBn1wurRowfOnz+PL7/80qP7RFRcGHQTEREREbmwYMECVKhQAenp6Xbb+/bti/vvv9/pY9955x08++yz2Lp1KwICAtQi24T8PmfOHPTu3RuRkZH4+9//rm4rV66c3XN88skn6r56n332GZo3b46wsDAkJSWp18jKyjLdj02bNuHXX39VQa3NgQMH1PNKd+6OHTsiIiICKSkpWL9+vd1jP/74YzRo0AChoaGoUaMGZsyYYXe7bJN9f+CBBxAdHY0RI0bk/h3Lli1DnTp11HPffffduHz5Mt599131mPLly+ORRx5BdnZ27nMFBQXh9ttvxwcffOC0XYlKCwbdREREREQu9OvXTwWGn376ae6206dPq4DywQcfdPrYe++9F3/9619V0Hrs2DG1yDabyZMnq6B7+/btGDp0qFv/F5IFHjRoEMaMGYO0tDTMnTtXBblTp041fczq1atRu3ZtlC1bNt9tkyZNwmOPPYYtW7ao+wwYMCA3gN+4cSPuuece9O/fX+2jdJWXLuC2Cwc2L730Eho2bKjuL7eLK1eu4PXXX8eiRYuwfPlyfPfdd+jTpw8+//xztfz73/9WXd4/+ugju+dq1aoV1qxZ41ZbEJV0luLeASIiIiKiki48PBz33Xcf5s+frwJw8d577yEhIQEdOnRw+dioqChYLBbEx8fnu12e191g20aCaxn3PGTIELUume7nnnsOjz/+uArijUhWu0qVKoa3ScBty4BLxlwuEEhWvG7dupg5cyY6d+6cG0hLUC6BvgTZktm26dSpk3oem7Vr16ru8rNnz0atWrXUNsl0S6B94sQJ1Sb169dXGfZvv/3W7kJE1apVcejQITWuOzCQeUIq3fgOJiIiIiJyg3SZXrFiBY4cOaLWJQCXoNOx23dBtWjRosCPkWzylClTVOBqW2T/JIsu2WUjV69eVV3RjTRu3Dj398qVK6ufJ0+eVD937dqVr/CarP/yyy923cKN/g7pUm4LuEVcXJzqVi77q99mey39hQoJuB278xOVRsx0ExERERG5oWnTpmq8s4zv7tatm+pqLeOqb5SM5daTzK6maU4LrElAKhlp6artyCywjo2NVftsJDg4OPd320UEW/Vw2RfHCwuO+2f0dzg+r+25jbY5Vir/448/VMAuwTdRacegm4iIiIjITVL5+5VXXlHZ7i5duqBatWpuPS4kJMQuK+xMxYoVcfHiRVVwzBbIylhrvWbNmmHPnj1qzu2CXDSQrt5GQbQz0gVcuorrrVu3TnUzl6Jn3rBjxw71NxL5AnYvJyIiIiJy08CBA1XA/fbbbxdoHLZ0qd6/f78KnqUAm7Nu0zfffLPK8k6cOFGNq37//ffzFS3729/+pjLuUtRs586dqgv44sWL8dRTT5k+r4ydlkBe7l8QUgTu66+/VmPG9+7dqyqPv/nmm3bjtz1Niqh17drVa89PVJQYdBMRERERuUkqf8s0YTIm+c4773S73eQxqampKvCVTLaz6bBiYmKwcOFCVd27UaNG6r4SXOtJ93apnL5y5Uq0bNkSrVu3VgXPEhMTTZ9XpjyT7uhSAK4gJOP84YcfqgrkUp1cAn4ZT64vouZJclFDMumuqsITlRYBmtGADCIiIiIiMnTbbbehXr16aiqs0kbGdEu3eMmglylTBiXR+PHjcf78eTWVGJEvYKabiIiIiMgNUtxLsr3ffPMNRo0aVSrbTDLn06dPV9OHlVSVKlVSXdmJfAUz3UREREREbo7LPnv2rJqv2nE8s8xrffDgQcPHzZ07V40FJyL/xKCbiIiIiOgGScDtOK2Xfh7qktqVm4i8j0E3ERERERERkZdwTDcRERERERGRlzDoJiIiIiIiIvISBt1EREREREREXsKgm4iIiIiIiMhLGHQTEREREREReQmDbiIiIiIiIiIvYdBNRERERERE5CUMuomIiIiIiIjgHf8P2vmdnQsb5G0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 7.255e-02 @ epoch 879\n",
      "\n",
      "iter=0  t=0.00s  best_y=2.02897e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=2.02897e+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 300\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  300\n",
      "\n",
      "Optimize a model with 412 rows, 8870 columns and 17750 nonzeros\n",
      "Model fingerprint: 0x0b272b5b\n",
      "Variable types: 8860 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-03, 1e+00]\n",
      "  Objective range  [7e+02, 5e+11]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [1e-02, 2e+01]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 1 rows and 3536 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 411 rows, 5334 columns, 10677 nonzeros\n",
      "Variable types: 5324 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 2.010670e+08\n",
      "\n",
      "Root relaxation: objective 1.986939e+08, 578 iterations, 0.00 seconds (0.02 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "*    0     0               0    1.986939e+08 1.9869e+08  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (578 simplex iterations) in 0.03 seconds (0.08 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.98694e+08 2.01067e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.986938905286e+08, best bound 1.986938905286e+08, gap 0.0000%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=1.98694e+08  ip_y=1.98694e+08  rel_err=9.325e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=-0.122  std(mean)=580  min=-1e+03  max=1e+03\n",
      "  y: shape=(1000,)  mean=2.58e+08  std=9.19e+07  min=4.57e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | MaxAffine ===\n",
      "  data: N=1000  train/val/test=700/150/150  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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CdnXrbfeKp999llMZQHUBxmX+wAAAACAuq5Zs2by4IMPyrJlyywIVytWrJCOHTvKbbfddtH3ZmVlSUZGhlxzzTU1Xtf9xhpwezTA1nHQJSUl9lxbvGfPni2TJ0+2QN6Ptm5fe+21vq9p0O21hGvLud4k0Nbx7t27y/z586WgoCAQTGtgrsG+Btrawu0ZPHiw7cfz+eefW9f5RYsWSZcuXWydtnhrsH3kyBErk549e1pL+5YtW0JuRnTo0EEOHz5s47wbNqStEPUfZzEAAAAQA+0+vWnTJvnll1/suQbhGniGdwGvrVtuuaXW79FW5VmzZlnw6i16fNqarq3Mfs6cOWPd0v307t078Dg7O9t+Hj161H7u3bu3RjI2fX7gwIGQLuJ+v4d2L/eCbtW+fXvrYq7HG7zO+7+Cb1Zo0B3etR+or2jxBgAAAGJw00032fhnHe995513WrdrHWf9f+nY7mDawuuci5p0TYNSbZnWbtvhIgXXbdu2tWP207hx48Bj70aCl1VcjyX85kL48fn9HuH79fbtty48g/mJEycsaNcAHEgFBN4AAABAjDQj+Kuvvmqt3kOGDJHrrrsupvdlZmaGtA5H065dO/n9998tCZkXzOrY62D5+fmyb98+m5O7NjcOtNu3XyAdjXYH127jwb788kvrcq6J0BJh9+7d9jsCqYKu5gAAAECMiouLLeh+8803azUuW7tXHzx40AJoTcoWrQt1v379rLV36tSpNs565cqVNRKZvfDCC9byronOvvvuO+sO/t5778lzzz0Xcb86llqDed2+NjQx3KeffmpjyPfv328ZyRcuXBgynjveNLHaHXfckbD9A8lG4A0AAADESDOC6xRiOkZ52LBhMZebvqewsNCCX23RjjZVVps2baS0tNSyfufl5dm2GmAH067umlH9448/lr59+0r//v0tCVpOTk7E/ep0aNo1XZPC1Ya2PL///vuWmVyzlmvQr+PLgxOrxZPe2NAW9YtliwfqkwbOb4AGAAAAAF+333679OjRw6bJqm90jLd2kdeW9JYtW0pdNGnSJDl16pRNMwakClq8AQAAgBhowi9t9d28ebM89thj9bLMtAX95ZdftqnF6qqrr77aurUDqYQWbwAAACDGcdonT560+azDxzfrvNeVlZW+71uyZImNDQeQvgi8AQAAgP9Jg+7wKb+C56muq926ASQHgTcAAAAAAAnEGG8AAAAAABKIwBsAAAAAgAQi8AYAAAAAIIEIvAEAAAAASCACbwAAAAAAEojAGwAAAACABCLwBgAAAAAggQi8AQAAAACQxPkPR76TtFCbKRYAAAAASUVORK5CYII=",
      "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.732e-02 @ epoch 486\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.92778e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=1.92778e+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 300\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  300\n",
      "\n",
      "Optimize a model with 1601 rows, 11 columns and 17610 nonzeros\n",
      "Model fingerprint: 0xa0dfc5da\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-08, 1e+00]\n",
      "  Objective range  [9e+07, 9e+07]\n",
      "  Bounds range     [1e+01, 1e+01]\n",
      "  RHS range        [7e-01, 1e+01]\n",
      "Presolve removed 1293 rows and 0 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 308 rows, 11 columns, 3387 nonzeros\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 1.899939e+08\n",
      "\n",
      "Root relaxation: objective 1.896378e+08, 12 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               0    1.896378e+08 1.8964e+08  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (12 simplex iterations) in 0.01 seconds (0.01 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.89638e+08 1.89994e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.896377679295e+08, best bound 1.896377679295e+08, gap 0.0000%\n",
      "[CHECK MaxAffine] obj(x_ip)=1.89638e+08  ip_y=1.89638e+08  rel_err=4.181e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=-0.122  std(mean)=580  min=-1e+03  max=1e+03\n",
      "  y: shape=(1000,)  mean=2.58e+08  std=9.19e+07  min=4.57e+07  max=6.18e+08\n",
      "\n",
      "\n",
      "=== Run: quadratic | LSET ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,600 n_pieces=1600 T=0.05\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.556e-02 @ epoch 792\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.57774e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "iter=1  t=0.00s  best_y=1.57773e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -2, -2]\n",
      "iter=2  t=0.00s  best_y=1.57771e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, -1, -3]\n",
      "iter=3  t=0.00s  best_y=1.5777e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 0, -4]\n",
      "iter=4  t=0.01s  best_y=1.57768e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 1, -5]\n",
      "iter=5  t=0.01s  best_y=1.57767e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 2, -6]\n",
      "iter=6  t=0.01s  best_y=1.57766e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 3, -7]\n",
      "iter=7  t=0.01s  best_y=1.57765e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 4, -8]\n",
      "iter=8  t=0.01s  best_y=1.57764e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 5, -9]\n",
      "iter=9  t=0.01s  best_y=1.57763e+08  x=[5, -2, 1, -1, 7, 3, 0, 2, 6, -10]\n",
      "STOP: local minimum. best_y=1.57763e+08 x=[5, -2, 1, -1, 7, 3, 0, 2, 6, -10]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Set parameter FuncNonlinear to value 1\n",
      "Set parameter FeasibilityTol to value 1e-09\n",
      "Set parameter OptimalityTol to value 1e-09\n",
      "Set parameter IntFeasTol to value 1e-09\n",
      "Set parameter NumericFocus to value 3\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  300\n",
      "FeasibilityTol  1e-09\n",
      "IntFeasTol  1e-09\n",
      "OptimalityTol  1e-09\n",
      "NumericFocus  3\n",
      "\n",
      "Optimize a model with 4804 rows, 4815 columns and 27216 nonzeros\n",
      "Model fingerprint: 0x0f503291\n",
      "Model has 1601 function constraints treated as nonlinear\n",
      "  1600 EXP, 1 LOG\n",
      "Variable types: 4805 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [7e-06, 9e+07]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [2e-12, 2e+08]\n",
      "  RHS range        [1e+01, 3e+08]\n",
      "Warning: Model contains large matrix coefficient range\n",
      "Warning: x < 1e-10 in domain of log(x).\n",
      "         Setting lower bound to 1e-10.\n",
      "Presolve removed 3201 rows and 1601 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 9608 rows, 3215 columns, 36824 nonzeros\n",
      "Presolved model has 1601 nonlinear constraint(s)\n",
      "\n",
      "Solving non-convex MINLP\n",
      "\n",
      "Variable types: 3205 continuous, 10 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 1.486588e+08, 2597 iterations, 0.04 seconds (0.12 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.4866e+08    0 1599          - 1.4866e+08      -     -    0s\n",
      "     0     2 1.4866e+08    0 1599          - 1.4866e+08      -     -    6s\n",
      "  2588  1202 1.5027e+08   14 1599          - 1.4946e+08      -  98.4   10s\n",
      "  4949  1687 1.4966e+08   14  278          - 1.4966e+08      -  84.4   21s\n",
      "  6370  2015 1.5370e+08   79 1596          - 1.5311e+08      -  78.3   25s\n",
      "  7867  2077 infeasible  177               - 1.5316e+08      -  72.8   30s\n",
      "  9171  2153 1.5350e+08   46 1596          - 1.5316e+08      -  69.0   35s\n",
      " 10376  2294 1.5360e+08   86 1596          - 1.5330e+08      -  68.0   40s\n",
      " 11786  2740 1.5377e+08  205 1597          - 1.5332e+08      -  65.8   45s\n",
      " 13311  3214 infeasible   55               - 1.5341e+08      -  64.3   50s\n",
      " 14676  3683 1.5369e+08   46 1598          - 1.5343e+08      -  63.3   55s\n",
      " 15919  4220 infeasible   71               - 1.5344e+08      -  64.3   60s\n",
      " 17083  4595 1.5438e+08   49 1596          - 1.5347e+08      -  64.8   65s\n",
      " 18152  5015 1.5362e+08   64 1597          - 1.5347e+08      -  65.8   70s\n",
      " 19381  5572 infeasible  152               - 1.5349e+08      -  66.2   75s\n",
      " 21598  6270 1.5369e+08   46 1594          - 1.5350e+08      -  65.2   82s\n",
      " 22906  6586 1.5415e+08   85 1597          - 1.5352e+08      -  64.8   86s\n",
      " 23408  6591 1.5428e+08   93 1596          - 1.5352e+08      -  65.3  113s\n",
      " 23432  6944 infeasible   94               - 1.5352e+08      -  65.4  117s\n",
      " 25008  7412 1.5357e+08   47 1595          - 1.5354e+08      -  64.5  122s\n",
      " 26538  7733 infeasible   89               - 1.5354e+08      -  64.4  126s\n",
      " 28107  8061 infeasible  131               - 1.5356e+08      -  63.8  131s\n",
      " 30138  8439 1.5498e+08   66 1593          - 1.5356e+08      -  62.6  136s\n",
      " 31289  8773 1.5488e+08   63 1596          - 1.5357e+08      -  64.0  140s\n",
      " 32987  9116 1.5423e+08   68 1596          - 1.5357e+08      -  64.2  145s\n",
      " 34845  9555 1.5426e+08   90 1594          - 1.5357e+08      -  64.4  151s\n",
      " 36808 10114 1.5391e+08  153 1595          - 1.5357e+08      -  64.3  156s\n",
      " 38641 10601 1.5432e+08   60 1595          - 1.5358e+08      -  64.0  162s\n",
      "*40702  5288             953    1.542819e+08 1.5360e+08  0.44%  62.9  162s\n",
      " 41081  5904 infeasible   64      1.5428e+08 1.5360e+08  0.44%  62.8  167s\n",
      "H41085  5904                    1.542819e+08 1.5360e+08  0.44%  62.8  167s\n",
      "H41146  2873                    1.538995e+08 1.5360e+08  0.20%  63.4  167s\n",
      " 42740  3584     cutoff  106      1.5390e+08 1.5360e+08  0.19%  66.9  177s\n",
      " 45463  5749 1.5388e+08   39 1583 1.5390e+08 1.5362e+08  0.18%  66.6  182s\n",
      " 52052  8467 1.5388e+08   47 1588 1.5390e+08 1.5364e+08  0.17%  63.5  188s\n",
      " 57663 10465 1.5388e+08   57 1585 1.5390e+08 1.5364e+08  0.17%  62.2  194s\n",
      " 63309 12610 1.5389e+08  134 1187 1.5390e+08 1.5370e+08  0.13%  60.4  199s\n",
      " 68896 15187 infeasible   68      1.5390e+08 1.5373e+08  0.11%  58.4  205s\n",
      " 74153 17903 1.5390e+08  204  730 1.5390e+08 1.5374e+08  0.10%  56.3  211s\n",
      " 79109 19739 1.5390e+08  274  757 1.5390e+08 1.5377e+08  0.08%  54.9  215s\n",
      " 83345 21854 infeasible  300      1.5390e+08 1.5378e+08  0.08%  53.5  220s\n",
      " 87713 23809 infeasible  323      1.5390e+08 1.5379e+08  0.07%  52.5  225s\n",
      " 97403 27643 1.5390e+08   49 1583 1.5390e+08 1.5383e+08  0.05%  49.8  232s\n",
      " 101096 29838 infeasible  177      1.5390e+08 1.5383e+08  0.05%  49.3  237s\n",
      " 104638 31394 infeasible  308      1.5390e+08 1.5384e+08  0.04%  49.0  240s\n",
      " 107766 33798 infeasible  124      1.5390e+08 1.5384e+08  0.04%  49.2  245s\n",
      " 115225 38815 infeasible   83      1.5390e+08 1.5387e+08  0.02%  49.0  253s\n",
      " 119575 39945 1.5389e+08   58 1580 1.5390e+08 1.5387e+08  0.02%  48.2  256s\n",
      " 125674 41851 1.5390e+08   77  860 1.5390e+08 1.5388e+08  0.02%  47.9  262s\n",
      " 127566 43041 infeasible   92      1.5390e+08 1.5388e+08  0.01%  48.4  266s\n",
      " 130344 44993 infeasible  104      1.5390e+08 1.5388e+08  0.01%  48.4  270s\n",
      " 137770 48420 infeasible  129      1.5390e+08 1.5388e+08  0.01%  47.8  276s\n",
      " 141742 49758 infeasible  141      1.5390e+08 1.5388e+08  0.01%  47.4  280s\n",
      " 146883 51613 infeasible  165      1.5390e+08 1.5388e+08  0.01%  47.1  286s\n",
      " 152750 53212 infeasible  189      1.5390e+08 1.5388e+08  0.01%  46.9  292s\n",
      " 157349 54456 infeasible  204      1.5390e+08 1.5388e+08  0.01%  46.2  295s\n",
      "\n",
      "Explored 160815 nodes (7380622 simplex iterations) in 295.93 seconds (1418.22 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 1.53899e+08 1.54282e+08 1.54282e+08 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.538994723113e+08, best bound 1.538849046094e+08, gap 0.0095%\n",
      "[CHECK LSET] obj(x_ip)=1.53899e+08  ip_y=1.53899e+08  rel_err=1.019e-07\n",
      "\n",
      "=== MODEL SPECS (from seed 0 run) ===\n",
      "    model  n_params                                                  details    lr  batch_size  epochs\n",
      "      DFN     16725 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "DFN_AfixI     17610   layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "     LSET     17600                                     n_pieces=1600 T=0.05 0.001           8    1000\n",
      "      MLP     18049                                        hidden=[128, 128] 0.001           8    1000\n",
      "MaxAffine     17600                                            n_pieces=1600 0.001           8    1000\n",
      "\n",
      "=== LEARNING SUMMARY (mean ± SE over seeds) ===\n",
      "    model  train_time       best_val           test\n",
      "      DFN 872.612 ± 0 0.00659917 ± 0 0.00764962 ± 0\n",
      "DFN_AfixI 1437.33 ± 0  0.0725477 ± 0  0.0729459 ± 0\n",
      "     LSET 73.6794 ± 0  0.0355598 ± 0  0.0447374 ± 0\n",
      "      MLP 58.2908 ± 0 0.00926861 ± 0  0.0074731 ± 0\n",
      "MaxAffine 62.2516 ± 0  0.0473212 ± 0  0.0480771 ± 0\n",
      "\n",
      "=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\n",
      "    model                               LS_x            LS_y       LS_true_y        LS_time                                        IP_x            IP_y       IP_true_y       IP_time                                        GT_x       GT_true_y        GT_time  LS_vs_IP_% IP_true_vs_GT_%\n",
      "      DFN [5, -2, 1, -1, 7, 3, 0, 2, -3, -1] 1.30011e+08 ± 0 1.56023e+08 ± 0   0.032576 ± 0 [10, 10, -10, -10, -10, 10, -10, 1, 10, 10] 1.25576e+08 ± 0 1.51873e+08 ± 0 0.0660879 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.51797e+08 ± 0 0.00483037 ± 0 3.53151 ± 0   0.0497059 ± 0\n",
      "DFN_AfixI [5, -2, 1, -1, 7, 3, 0, 2, -3, -1] 2.02897e+08 ± 0 1.56023e+08 ± 0  0.0703491 ± 0 [10, -10, 10, -10, -10, 10, -10, 1, 10, 10] 1.98694e+08 ± 0 1.52332e+08 ± 0 0.0807985 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.51797e+08 ± 0 0.00483037 ± 0 2.11559 ± 0    0.352565 ± 0\n",
      "     LSET [5, -2, 1, -1, 7, 3, 0, 2, 6, -10] 1.57763e+08 ± 0 1.56078e+08 ± 0  0.0156386 ± 0 [10, 10, -10, -10, -10, 10, -10, 1, 10, 10] 1.53899e+08 ± 0 1.51873e+08 ± 0   296.166 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.51797e+08 ± 0 0.00483037 ± 0 2.51066 ± 0   0.0497059 ± 0\n",
      "      MLP [5, -2, 1, -1, 7, 3, 0, 2, 6, -10] 1.49152e+08 ± 0 1.56078e+08 ± 0  0.0113748 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.46276e+08 ± 0 1.51797e+08 ± 0 0.0741294 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.51797e+08 ± 0 0.00483037 ± 0 1.96614 ± 0           0 ± 0\n",
      "MaxAffine [5, -2, 1, -1, 7, 3, 0, 2, -3, -1] 1.92778e+08 ± 0 1.56023e+08 ± 0 0.00149371 ± 0 [10, 10, -10, -10, -10, 10, -10, 1, 10, 10] 1.89638e+08 ± 0 1.51873e+08 ± 0 0.0772177 ± 0 [10, 1, -10, -10, -10, 10, -10, 10, 10, 10] 1.51797e+08 ± 0 0.00483037 ± 0 1.65599 ± 0   0.0497059 ± 0\n",
      "\n",
      "=== FAILURES / WARNINGS (if any) ===\n",
      "None\n"
     ]
    }
   ],
   "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=1000, 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 = 300\n",
    "x0    = np.array([5,-2,1,-1,7,3,0,2,-3,-1], dtype=int)\n",
    "xmin  = np.full(in_dim, -10, dtype=int)\n",
    "xmax  = np.full(in_dim,  10, dtype=int)\n",
    "delta = 2\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
}
