{
 "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 = lambda x: float(np.asarray(obj(np.asarray(x))).reshape(-1)[0])\n",
    "                (ls_out, _ls_log) = suppress_stdout(\n",
    "                    local_search_l1_int, obj_ls, x0, xmin, xmax,\n",
    "                    delta=delta, sum_eq=sum_eq, print_every=0,\n",
    "                    silence=silence_local_search\n",
    "                )\n",
    "                x_best, y_best, ls_hist = ls_out\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=str(np.asarray(x_best, int).tolist()),\n",
    "                    y=float(y_best),\n",
    "                    true_y=float(eval_true_obj(gt, x_best)),\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=float(t_to_best(ls_hist, y_best)),\n",
    "                    iters=int(len(ls_hist) - 1),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=np.nan, iters=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"LS\", error=repr(e)))\n",
    "\n",
    "            # ---- IP SOLVE (learned objective) ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                x_ip, y_ip, info = solve_ip(\n",
    "                    model_type, model, scaler, xmin, xmax, sum_eq,\n",
    "                    time_limit=time_limit, verbose=True\n",
    "                )\n",
    "                ip_time = time.perf_counter() - t0\n",
    "\n",
    "                rel_err = check_ip_matches_obj(name, obj, x_ip, y_ip, strict=strict_ip_check, tol=ip_check_tol)\n",
    "                if rel_err > ip_check_tol:\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"IP_CHECK\",\n",
    "                                          error=f\"rel_err={rel_err:.3e} (tol={ip_check_tol})\"))\n",
    "\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=str(np.asarray(x_ip, int).tolist()),\n",
    "                    y=float(y_ip),\n",
    "                    true_y=float(eval_true_obj(gt, x_ip)),\n",
    "                    runtime=float(ip_time),\n",
    "                    status=(info.get(\"status\") if isinstance(info, dict) else None),\n",
    "                    gap=(info.get(\"gap\") if isinstance(info, dict) else None),\n",
    "                    ip_rel_err=float(rel_err),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ip_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ip_time),\n",
    "                    status=None, gap=None, ip_rel_err=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"IP\", error=repr(e)))\n",
    "\n",
    "    # ---- build DFs ----\n",
    "    spec_df  = pd.DataFrame(spec_rows).drop_duplicates(\"model\").sort_values(\"model\").reset_index(drop=True)\n",
    "    learn_df = pd.DataFrame(learn_rows).sort_values([\"model\", \"seed\"]).reset_index(drop=True)\n",
    "    opt_df   = pd.DataFrame(opt_rows).sort_values([\"model\", \"seed\", \"method\"]).reset_index(drop=True)\n",
    "\n",
    "    fail_df = pd.DataFrame(fail_rows)\n",
    "    if fail_df.empty:\n",
    "        fail_df = pd.DataFrame(columns=[\"seed\", \"model\", \"stage\", \"error\"])\n",
    "    else:\n",
    "        for c in [\"stage\", \"model\", \"seed\"]:\n",
    "            if c not in fail_df.columns:\n",
    "                fail_df[c] = np.nan\n",
    "        fail_df = fail_df.sort_values([\"stage\", \"model\", \"seed\"]).reset_index(drop=True)\n",
    "\n",
    "    gt_df = pd.DataFrame([dict(seed=s, **d) for s, d in sorted(gt_cache_by_seed.items())]).sort_values(\"seed\")\n",
    "\n",
    "    # ---- per-seed gaps ----\n",
    "    gap_seed_df = pd.DataFrame(columns=[\"seed\", \"model\", \"ls_vs_ip_pct\", \"ip_true_vs_gt_pct\"])\n",
    "    if not opt_df.empty:\n",
    "        pivot_y = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"y\", aggfunc=\"first\")\n",
    "        pivot_true = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"true_y\", aggfunc=\"first\")\n",
    "\n",
    "        if (\"LS\" in pivot_y.columns) and (\"IP\" in pivot_y.columns):\n",
    "            ls_vs_ip = 100.0 * (pivot_y[\"LS\"] - pivot_y[\"IP\"]) / (np.abs(pivot_y[\"IP\"]) + 1e-12)\n",
    "        else:\n",
    "            ls_vs_ip = pd.Series(index=pivot_y.index, dtype=float)\n",
    "\n",
    "        # IP true vs GT optimum true\n",
    "        gt_true = gt_df.set_index(\"seed\")[\"true_y\"] if not gt_df.empty else pd.Series(dtype=float)\n",
    "        ip_true_vs_gt = []\n",
    "        for (seed, model), row in pivot_true.iterrows():\n",
    "            ipt = float(row.get(\"IP\", np.nan))\n",
    "            gtt = float(gt_true.get(seed, np.nan))\n",
    "            if np.isfinite(ipt) and np.isfinite(gtt):\n",
    "                ip_true_vs_gt.append(((seed, model), 100.0 * (ipt - gtt) / (abs(gtt) + 1e-12)))\n",
    "            else:\n",
    "                ip_true_vs_gt.append(((seed, model), np.nan))\n",
    "        ip_true_vs_gt = pd.Series({k: v for k, v in ip_true_vs_gt})\n",
    "\n",
    "        gap_seed_df = pd.DataFrame({\n",
    "            \"seed\": [k[0] for k in ip_true_vs_gt.index],\n",
    "            \"model\": [k[1] for k in ip_true_vs_gt.index],\n",
    "            \"ls_vs_ip_pct\": [float(ls_vs_ip.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "            \"ip_true_vs_gt_pct\": [float(ip_true_vs_gt.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "        })\n",
    "\n",
    "    # ---- LEARNING SUMMARY (mean ± SE over seeds) ----\n",
    "    learn_sum_rows = []\n",
    "    for model in sorted(learn_df[\"model\"].unique()):\n",
    "        sub = learn_df[learn_df[\"model\"] == model]\n",
    "        m, se = mean_se(sub[\"train_time\"]); train_time_s = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"best_val\"]);   best_val_s   = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"test\"]);       test_s       = fmt_mean_se(m, se)\n",
    "        learn_sum_rows.append(dict(model=model, train_time=train_time_s, best_val=best_val_s, test=test_s))\n",
    "    learn_summary_df = pd.DataFrame(learn_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- OPTIMIZATION SUMMARY ----\n",
    "    opt_sum_rows = []\n",
    "    gt_x_repr = (repr_solution(gt_df.get(\"x\", pd.Series(dtype=str)), gt_df.get(\"seed\", None))\n",
    "                if not gt_df.empty else None)\n",
    "    m, se = mean_se(gt_df.get(\"true_y\", pd.Series(dtype=float))); gt_true_s = fmt_mean_se(m, se)\n",
    "    m, se = mean_se(gt_df.get(\"runtime\", pd.Series(dtype=float))); gt_time_s = fmt_mean_se(m, se)\n",
    "\n",
    "    for model in sorted(opt_df[\"model\"].unique()):\n",
    "        sub = opt_df[opt_df[\"model\"] == model]\n",
    "        row = {\"model\": model}\n",
    "\n",
    "        ls = sub[sub[\"method\"] == \"LS\"]\n",
    "        ip = sub[sub[\"method\"] == \"IP\"]\n",
    "\n",
    "        row[\"LS_x\"] = repr_solution(ls[\"x\"], ls.get(\"seed\", None))\n",
    "        m, se = mean_se(ls[\"y\"]);       row[\"LS_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"true_y\"]);  row[\"LS_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"runtime\"]); row[\"LS_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"IP_x\"] = repr_solution(ip[\"x\"], ip.get(\"seed\", None))\n",
    "        m, se = mean_se(ip[\"y\"]);       row[\"IP_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"true_y\"]);  row[\"IP_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"runtime\"]); row[\"IP_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"GT_x\"] = gt_x_repr\n",
    "        row[\"GT_true_y\"] = gt_true_s\n",
    "        row[\"GT_time\"] = gt_time_s\n",
    "\n",
    "        gsub = gap_seed_df[gap_seed_df[\"model\"] == model] if not gap_seed_df.empty else pd.DataFrame()\n",
    "        m, se = mean_se(gsub.get(\"ls_vs_ip_pct\", pd.Series(dtype=float))); row[\"LS_vs_IP_%\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(gsub.get(\"ip_true_vs_gt_pct\", pd.Series(dtype=float))); row[\"IP_true_vs_GT_%\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        opt_sum_rows.append(row)\n",
    "\n",
    "    opt_summary_df = pd.DataFrame(opt_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- Print tables ----\n",
    "    print(\"\\n=== MODEL SPECS (from seed 0 run) ===\")\n",
    "    if not spec_df.empty:\n",
    "        print(spec_df[[\"model\", \"n_params\", \"details\", \"lr\", \"batch_size\", \"epochs\"]].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== LEARNING SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not learn_summary_df.empty:\n",
    "        print(learn_summary_df.to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not opt_summary_df.empty:\n",
    "        cols = [\n",
    "            \"model\",\n",
    "            \"LS_x\", \"LS_y\", \"LS_true_y\", \"LS_time\",\n",
    "            \"IP_x\", \"IP_y\", \"IP_true_y\", \"IP_time\",\n",
    "            \"GT_x\", \"GT_true_y\", \"GT_time\",\n",
    "            \"LS_vs_IP_%\", \"IP_true_vs_GT_%\",\n",
    "        ]\n",
    "        print(opt_summary_df[cols].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== FAILURES / WARNINGS (if any) ===\")\n",
    "    if fail_df.shape[0] == 0:\n",
    "        print(\"None\")\n",
    "    else:\n",
    "        print(fail_df.to_string(index=False))\n",
    "\n",
    "    return spec_df, learn_df, opt_df, fail_df, learn_summary_df, opt_summary_df, gt_df\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e88e7a1f",
   "metadata": {},
   "source": [
    "## Tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8edf3f97",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-0.0226  std(mean)=6.07  min=-10  max=10\n",
      "  y: shape=(2000,)  mean=9.91e+03  std=3.68e+03  min=1.14e+03  max=2.5e+04\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=16,725 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=0.0\n",
      "  train: device=cpu  epochs=250  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAwgVJREFUeJzs3QeYU2XWB/B/ksn03hlg6L03FQRBUQE79t7Xht21t0/X7q6CK9jX3hU7iIBIU3qTPvQ+vbe0+z3nvZNMJpNMgamZ/+95QpKbdicJuffcc97zGjRN00BEREREREREDc7Y8E9JRERERERERAy6iYiIiIiIiBoRM91EREREREREjYRBNxEREREREVEjYdBNRERERERE1EgYdBMRERERERE1EgbdRERERERERI2EQTcRERERERFRI2HQTURERERERNRIGHQ3gg8++AAGg8Hn6Y8//kBz2rNnj1qPf//730f1+NWrV2PKlCkYMGAAIiIikJSUhFNPPRW///57tfv+3//9n9f3IDg42Otzf/HFFxg8eLC6PSUlBXfffTeKioq83tdutyMxMRGvvvqquvzKK69g4sSJ6NChA0JDQ9GnTx889NBDyMvLq/ZYX5/NCy+8UO2+GRkZuPbaaxEfH6+ed+TIkZg/f3693uvm+MxlnTt37lyn+8k6ymfp7b3eu3cvjEajuo98nu62bNmCq666Cl27dlWfmbxHQ4cOxe23346CgoJqr+HrdKzq8530Rf52+b7J907+FvkeyvfRU01/R+/evV332759O/75z39i2LBhiI6ORmxsLE488UR88803aCz//e9/1ToEBQWhS5cueOqpp2C1WqvcZ+bMmbjsssvQvXt3hISEqO/IFVdcgbS0tHq91vjx43HLLbegtTrppJPU501ELd/kyZPV75W37bmT/I6ZzWakp6fX+Xm9bddagueeew7ff/99teWbN29W6yv7Fk3to48+QkJCAgoLC5vsNQ8cOKB+p8eOHau2o/J5yT62J9nfePbZZzFu3DgkJycjPDxc7Q+8+OKLKCsrq3b/HTt2qH2X1NRU9b3q1q0b7r33XmRnZ1e5n9znvPPOa9S/kdqOgOZeAX/2/vvvV9kJd+rbty9as88//xwrVqzA9ddfj0GDBqG4uBhvvvmm2gn/8MMPcfXVV1d7zK+//oqoqCjXdQniPH366ae48sorceONN6pAWoKWBx98UG1kfvvtt2r3X7RoETIzM3H++eejtLRUbYgkmJDHS/C3Zs0aPPPMM/jpp5+watUq9cPq7sILL8R9991XZZn8ALsrLy9Xf5ds6KdNm6aC/OnTp6vgft68eWpD4A9kR8Vms+HLL7/EDTfcUO17LIGsexAt1q5dq4JIObjxxBNPqOAtKysL69evV8GqBJyRkZGu+8v7X58guLG/k57ke7Ry5Up14KVnz5747LPP1PfJ4XDg8ssvd93vr7/+qvbY5cuXqx0D2TF0ku/sL7/8ojbaI0aMcL2/F110kQqG5T1rSLLD8fjjj6sDTaeffrr6Wx577DEcPHgQb7/9tut+shMiOyWPPvqoOliyf/9+tYMnB0uWLVuGfv361fpaP/zwA5YuXap2wlqrf/3rXzjttNNw6623olevXs29OkRUA9kuSRAqv8u33XZbtdvz8/Px3Xff4ayzzlIHXVs7+U2WfRTPgE/2h2T7IcFlXQ6qN5SSkhI88sgjap9M9geaigTHsm8oB8HPOOMMta33Zt++fZg6dara3krwLEH34sWL1X7h3Llz1cl5gF/2G0844QS1fyLbAdnvk/2ZJ598EgsWLFAH8Z37qPJ42Y+XfZdTTjmlyf5u8lMaNbj3339fk7d25cqVLfLd3b17t1q/l19++agen56eXm2ZzWbTBg4cqHXr1q3K8ieffFK9VmZmZo3PKY9v166ddvrpp1dZ/umnn6rHz5o1q9pjbrvtNm348OGux2dlZVW7z9dff60e//HHH1dZLsumTJlSy1+qadOnT1f3/fPPP13LrFar1rdvX+24446r83u9YMECraldc801WqdOnep0v7CwMO3SSy/VRo0aVeU2h8OhnuMf//iH+jvk83S6+uqr1eMKCgq8Pq881vM1Gkt9vpPe/PLLL+rv++yzz6osP+2007SUlBT1XDW59tprNYPBoKWlpbmWyXfe/T1wOvPMM7XQ0FCtrKxMayjy3Q8ODtZuuummKsufffZZtV6bNm2q8b06ePCgZjabtRtuuKFOryffffm+NIfi4uIGe67+/fur7zYRtWzyGyy/xcOGDfN6+xtvvKF+w3/66ad6Pa/ndq2lkO2lbDd97dM09D5Fbb+rM2bMUNuY3NxcrSnZ7XbXZdmnlr9d9rE9FRUVqZMn2c+VxyxevNi17J133lHL5s2bV+W+zz33nFq+Zs2aKsvPOusstS9AdKxYXt7M5MiblOK+9dZbKrsmZaGSCfdW1rpx40ace+65iImJcZW/ShbPk2RlJYMrWSx5PsnOyhHCrVu3VruvlGRLGaocFZSyacl01Uaez5PJZFJltJI1OxryuocPH8Z1111XZblkBWXd5Ai2O9lWyrILLrjA9fpxcXHVnve4445T50e7XvIakgWT98YpICBAZeQlsypZxIYgR7M7deqksqqejj/+eJWFdJJMu5TGyucQFhamSqheeumlamXE9SVZ4j///BPbtm1zLZNsvpSXe34uQsqw5EixfD7eNETZeF0d63dSPmf5O+T75k7+7kOHDqlMti9Savf111+rqgcp2XaSagtv74F8JyVrkJOTU2W5VGOcc845qgxd/n8PGTIEX331FepCKkmkhM7zc5Lr8n/FvUzR23slJfUyLKMu75VkBOS7LxkFb8NqJFMg2WP5++X/pFQQyHvoTr7n8p11lsLLOkk1gpQSupNsTv/+/VVVy6hRo9TwDvmeOodtvPzyyypzLxkfqaSQ+0uFjPxfkIy//F1SYSMVCDJMxJP8DZI5a8pySSKqP/k9v+aaa1QW8u+//652u1RktWvXDpMmTVKZTMmGy76U/K7L74tkKSXzebTeeOMNVUUlzyeZXvntksyvO9kfuOmmm9CxY0cEBgaq3x/JVjvL3eU3WvbNZN9Nfpfkt172LaRyyJ38tkm1luzfOYcuyW+b/MY6t1Enn3yy6zb3cmvZZkuFl2yb5fdSqtE8h8M5h/1JNaCsn+xTSnl1bX//2WefrUq8ve3Dfvzxx6rqTV5T3qeff/4ZDcFbVaQ3si8kp7rsA0pln3CvvhTOv81z+KNsJ+R93blz51H8BUSVGHQ3IhlnLCWl7idZ5unHH3/Ea6+9hqefflqN95TgS8pa3cd+SiAkO52bNm1S95VxmbJBkbGysvPqJDuPo0ePVkG87HBLabWU2UpAL0GtOwnepORGSnKkfEd+5CU4lzKt+pK/TTZovkpTJTCUjaaUfcnOtZQCeR5QEAMHDqyyXH4cZePmvN1JgkP5e5xBty/OcmZv6yU727KjLjv9EpzJRtuTvK7nOrmvp3weDUECCXlPPMuv5UCJBDjuwZT88Eu5s2zkZMMmZXcSfNx8883HtA4yBlq+e//73/9cy9577z0V4Pfo0aPa/WVnQT4DGUe3cOFCVeJfG8//D3LyPNDg7T7eTnqS4ui/k56fs+wwyAEVb5+z5/fPnRwgk/87MqyhLiQolXFx7sGvLJOdIzlgJv9fZSdMdswuueQSr+PXvK2/8/+ZO9kJleC3pvUXu3btUgdX6vJeyXdO/i/L98IbeR/k/638/5LfJulnIAep3ElQLmWKUt4tv39S4icHDuQ3ToYouJPvmDxevvOzZs2qUloqv2FS5i7n7777rvr/IjuG8n9CdrzluyzrIDtM3j4f2ZGVz665+2wQUd22kxLkuW+jnCXXsp2UoFx+m5wHNKVcWIb4yLZdkhDy//1o/q/Lb7z87siBVTlAKwcx77nnHvXb4R5wyzAiuV3Km2fPnq32rSSwy83NdQ1Xk3WToVfyHFIqLftrcmDSfaiODGGSfRPZH5PLcpoxYwbOPPNMVXYu5DfPeZssF5988okaWiQBtwTsctBWAvsJEyZ47UMjrysHiuWgsWx3fJGDoXKgQwJ9b+Q9fv3119U+7LfffqteUw50ynbFSbbXdd22NyRv+4CS5JCScjkAIvtw0s9FDuzK0DLZfsi+gDv53sj6y/aH6Jgcc66cfJaXezuZTKYq95VlISEh2pEjR6qUUfXu3Vvr3r27a5mUcgYFBWn79u2r8vhJkyapUtW8vDx1/emnn1bPOXfu3FpLngcMGFClbHbFihVq+eeff17vT/XRRx9Vj/3++++rLP/oo49UiauUh//+++/aCy+8oMXGxmpJSUnagQMHXPeT+8jjDx8+XO25peS8Z8+eVZbdfffdav1rIs8vryMl6O4lSuLyyy9XpeuLFi3SvvnmG/U+yus/9thjVe4nJbc333xzteeWcnNv5chHW14uJeuyrrJe7h544AEtMDDQa+m8kL9LHivvs3y3cnJyjrq8XEiZXXJysnrO7Oxs9Z374IMPVKm0ZxmelEefd955Vb7bQ4YMUd+FjIyMaq/h6//E+PHjq9zX1/08T95KzOrynfSmR48e2oQJE6otP3TokHoOKTvz5fjjj9eio6O10tLSWl/HWdY2bdq0Ksvl/7u8d/K+e5a1ybALz++vJymRls/KG/m/4zlsw5285rhx47TIyMhqvy/eyP8VWV9fv3sy7MPdSy+9VOX/9pYtW7zeb/ny5Wr5I4884lo2duxYtWz+/Ple/18NGjSoynszdepUtfycc86p9nshy/Pz86sst1gsqvz+wQcfrPXvJqLmJ78J8fHx6v+u03333af+f2/fvt3rY2Q/R37nZFszefLkepeX33777eo3vibXX3+92l/YvHlznf8W53rJsB75/T+W8nIpD5d9q7PPPrvKcvl9lN9J9+FwzmF/TzzxRJ3W88svv1T3X7ZsWbXbZLnsu7gPM5P9WaPRqD3//POuZbK+dd22y++7NzWVl3uzfv16tX/t+Zk7t+0jR46s8roXXXSRz2Ff7du31y655JI6vS6RL2yk1ojkyKXnETNv5aZSCuTe+EOO1EqGS5plyBFGKfuUo3VyPylbcieZbjmiKkc7pbmXXJastmQtayNHR+W1PLN6kvGqD8kwSRMnOWoo5e/uPEtQ5UipnCRLKhkoaU5Wl5Jkz+WS6Zej3r7I0WQ5SizbBGle5VmiJJl9d5IxlyOccqTzzjvvVJnI2tapttvqw1myLkevpdJAjo5LVYRks+U9dS+ddzb8kAyfZ4mylNZKOfrRkoy6HK2W75GU8EqJnJSzSTm0J6kQkKP60sF8zpw5qjxaMt7yXZCj5rJ+7g2q5Mi9HE325N5sTUgDsLqQYRFH85305Wg+ZzlKLqXn0jndV0d+J3lP5X5SznfHHXdUaRQjGVrnbALuR/rlOyyZZal0kd8SzyyA/P91rtvRrL/8/5CssFQESIbC8/fFGykV91ai7iQl8u7cf1ekgZtk9Z2/XZ5lgPI3SkZGPjsnKX301cBG3h/3/9vO31tn5sdzuVSTSLm6k2TkpaSwoYaJEFHjkt8rqZaTChnZbstvomR4x4wZU6UiS7ZB0kBSsuCSYXby1ty2NvLbJJlcqUC89NJLVVWSVBB5/r7Lvo3nPp8nySpLBlwajrpnymvbftRGqv9kf0Cy/Z7bCdk3lP0teT33EuzaKgWdnMODfP3uy9/t3lxN9mflvu77klJNWNdtu5TlHyvZf5GmerJNk/0Bd1J5IPsFsl8j+4JyH6kGk4or2X5J5t6z6k3+Hm4n6Fgx6G5E8uM7fPjwWu8nO6K+lsm4WQm65VxKRX39ODmnOZCSSs8O3L54joGWIErUpUzYScq2pKxZxjFJiXNdN2ByYMB9/LhzXeTv8Ow8KhsSKVdykjIy2Xn2tcGQH1QpW5UfSDlYIWVldSFBrwQ4EjzKuDDnenlOIeFcJ+G+XsdKDiL85z//UaVs8p5KIOs5zl3+btm5kGBWDljIWFbZWMt7IgFdfT47b6S8XA7uSPmebLRkB0PGaHkLut2/584dDQniZIdCyuukk7b7mGQJjury/0HKquvC/YDRsX4nj/ZzlvJ7UVtpuXyWUson30vZyLsHwc7xflJyKCdvnCXXzrFo7n+rBK+y/jJeUD4n+bw8/wbZ4fEkn5Wst+ywSiliXQ9OyHespu7Atf2uON9nX79nngf9vN3PyfNzkYNENS33NnWM/P851v83RNQ0nAct5bdP9gGk5Fd+Q6W3g3uvGjngKlMaSiAlAbJsL2SbJAeJ60uSBxLIvvPOO+o1ZUiUlJLL7Cjym+7c95J9tZpIsuDiiy9WB7Lvv/9+tZ8nwZ2Ml/Ysma8v53ZE3h9fZFvgHnTX9Nvqzvn76OvAgLd+OvK77/67KmPh67pt9wx460u2IXIgQJ5HDuJ6bg/ku7Ju3Tp1P+d7IPtVckBGDvDKNloOXrjjdoIaAoPuFuDIkSM+lzl/zOTcc0y2+xFI51FXydB6NiNqLLLRk512+XGSo8r1yfrKDr97hso5FlXGDblPqSYbOskCyhFmJ8nISdDunrFyD7gly7979271Y+ttPHZN6yQ818tb0xbnMm/rcLTk75YDEs6gUc4lCJExWk4yDkyOVsvGWwJkJ9mANGTwLwcgZMdCdgbqQ74DMtZNsuW1jSP2xTOw9MUZcDbEd1I+ZxlfJ9839w1+TZ+zxWJRlQgS0Na0MyEBt4whk/GA8t11BoBOzv+7Dz/8sArMvXFWDHhmCpzZfvf/P+6VDvI7IgG75/o7A255v+TAgeeY65rI+npWWNSH8zdNfs88d1Ll98wzg9TYDfnkN8PzNYmoZZKKKdkfkABYfkMkWJUsq3sTTDmQKONwPbdfx9IwUQ5+y0m2v1KxJdVmkkmV6jLZFtdl30vWS36zpfrO/XfNPRN/tJy/Yf/973/VdFjeeB4sretvq/O55Xe/roG6J6mC8zUm3JPsvx3tdGgSSDvHYMv4fW8HQmR/qX379tX+FjmQIrztu8jf3pRTtJF/YtDdAkhwKEcpnT+IUlYsP8rSTdL5gyHZRynllZ1S99IbKWGXzJbzR1YytDL/b2PPKSjNnWSnXXbWpXSnPjvGkuFOS0tTZdxOEijID6A8r5TWO0kzOWly4R6MSOAiR4t9BdzSvEMaxEn35/qQAEoCPvesoDQDkQYqUkLsDGac5WxyvSHKoNzJRl2aTC1ZskQ1wZOMsXtG1/k+O7OHQjYusgPSUORvlpOUuPvaeAvZ4fG2AZbvqMzp7S27WhdHW15+LN9J+XvlPZTvlvv3TzLA8hl7K9mX8kYJaOUAgy8yV7cE3NIsRw6YuH9u7gG1lEVKuaGzSY4vvioFpHxQjsTLe+C+rs6O4u5zvcr35R//+IcKuJ0NF+tDsgHu3dDry/m7JP+HnDs5zs9dslAyf3hTke+qZL/dD/QRUcsvMZeDqlLJJJluOfjqXuEjv3mev7UbNmxQw/DqMoSmJpIplv0sOegqv6syxEiCblkm+xAyFMh9WJU7WS856Oq+bZIDo57dy71lit2XC8/bpORdhspIOb10E29IzpJ8aeJal2ab3jRFeblUAkrALfvQEnC7JyY8n1/2u6UaUoJvJ/l+CM9AXfb5pPu5DGciOhYMuhuRHC3z1olRgmn3McNyFFF2RKX0SX7QpUulZHfdpw2To6pS+ixHCiWolnIZKYGRsScyVsc59cHdd9+tAnYpFZUpcyRzKj/OcpRRjsrW9UhjbWOSZKMn2T3JyEppszsJdp0bBpk6QoIgKT92lkHLhlLKqh544AHXYySwlL9DyrjkOeVItgTmch8p35KgwnmEUn74PUvL5W+UDp0y3lnKm+V9dy9fl/fbOSWGvL5smORAhvy4ylRCku2TAEmm0nDPeknWV8ZZy1F0Ge8t43rk85ENq3REbmjyd0ugLedy9NszkyvvhWy05XZ5byRgkKP5zu6oDUE+J/fO+b5I+bZ025bPQjKp8hnK9/bVV19V1QLSndqdZM59TUnn/p2pSwn6sXwnJUiWk2x0JfssZIdJ3ls54CEHDKSjq2S+paO2BIfeStnlOyNZF+mq7Y0cOJGdMvmuy9QyntUIEug5x7NL8CvrIN9h+cxlR0COrEsQKtO6yN9XE/k9eOyxx9RviFyW6gjZwZHvsxyIcA8q5WCXrLt8tyVD7v6ZyHtU28Eq2amR7JJkeKTipL5kh1S+O5KRke+J/N0ylEHWXXaIpVKiqTj/9ob4XSSipiHbCKlik229sy+FO9nXkbJy2W+S33jZXstvvhyoPZru2HKQUn7rJbCVA80SKD///PNqv8t54NDZC0VmdZDfe/ltle2jbENkmy6Bq6yXVKnJgXwpA5dATtZTnlP2d9zJ4yVwlIPvcrtk8+W301m1JOPVZZlsr+Xvkgoi+U2VKi/Zdsjzy/6KlL3LAV05r2/lmpMcyJW/X34vPXt21JWs69Fs24Vzf8TZDV2GADqnKnWW08t+nPyOSzJAtm9y3X2aSNnXcwbTMhRP9p9lmy/7yc4x3TJcQJJfMiOL5wEbGbrF7QQdM58t1qhRupfLSToYO8n1KVOmaDNmzNC6deumul9KZ2DprO3p77//Vp0po6KiVEdr6UjprYtjbm6udtddd2mpqanq+RITE7UzzzxT27p1a5XOvy+//HK1x9alk2dNnag9O09K13Xpwi6dOGVdpJv2LbfcojpHeiPdwAcOHKj+Pumifeedd2qFhYWu26W7uLeO3M6/ydfJvQvojz/+qI0ePVpLSEjQAgICtIiICG3MmDE+u7ZLJ86rr75adQYNDg7WTjjhhBq7wx9N93J30sFcHnPiiSd6vf2nn35Sn72si3TUvP/++7XZs2dXe52j6V7ui7fu5XPmzFEdW/v27au+k/JeSqft888/X/vrr7+qvUZNn09aWlod3pmG+U46O7d6fibyPZPvm3zv5Psn30Nf3wnp8i3dWeV74YvzdXydPF9fOq1efPHF6v+r/F+R9TjllFO0N998s87vg3RFl27lsv7y/1/Wwb3Lr5DvhK91qsv3RTqAh4eHq67k3n73pMOsO2fXWve/Vzrqvvjii2pd5W+VbsRXXnmltn///mqdivv161dtHXz9hjlfSzr81mXdrrrqqlpnQSCilkd+6+T/tGx/PJWXl2v//Oc/1fZRtpNDhw5Vs1h42ybWZZ/nww8/1E4++WTVpVt+W1NSUtRv9YYNG6rcT36/ZJsov93yu+a8X3p6uus+MoNL586d1WwTffr0UfuDzm2Fu3Xr1ql9AJmdRm6T30L3WRq6dOmiZgzx7Oa9cOFCtb8n+yuyDvIeyHX330Tn68l2va7kt9Lbe+3ch/Uk77O37utHo6btaF27o3t+xmvWrFFdzTt06KA+i65du2o33nij1xk8Hn/8cbWN8tXZnKiuDPLPsYfudLSkzEiOuklnTKqdZOwkMyYNx1oDyeDJUWjp2CwZQiJ/II2MpFJASisbe8x1Y5GKBikzlMoMyWQREZF3kl2WrL5ku49lhpTWRkrVpfJNKtrcZ9UgOhpV51EiauGkLLy1BNxE/kpK2WU8nIyBb60k2JaZHuo7pp2IqK2R0nDppSPl8G2JDC+TvkLSbZ7oWDHoJiKiepFxbzImrjVPtSXj6aXR3LFOT0NE1BZIwkOy3cfSBb61kV40sq2TJnVEx4rl5USNiOXlRERERERtG4NuIiIiIiIiokbC8nIiIiIiIiKiRsKgm4iIiIiIiKiRBPhj04NDhw4hIiKi1U5lQ0REbYvM3ikNimQaM6OxbR4P5/abiIj8dfvtd0G3BNwdO3Zs7tUgIiKqt/3796NDhw5t8p3j9puIiPx1++13QbdkuJ1/uEwJQ0RE1NIVFBSoA8bObVhbxO03ERH56/bb74JuZ0m5BNwMuomIqDVpy8OiuP0mIiJ/3X63zYFjRERERERERE2AQTcRERERERFRI2HQTURERERERNRI/G5MNxERNd6UThaLhW/vUTCbzTCZTHzviIiI2iAG3UREVCsJtnfv3q0Cbzo60dHRSE5O9stmaW+88YY67dmzR13v168fnnjiCUyaNKm5V42IiKjZMegmIqIaaZqGw4cPq0ytTIthNHJkUn3fv5KSEmRkZKjr7dq187tvnMxN+sILL6B79+7q+ocffohzzz0Xa9euVQE4ERFRW8agm4iIamSz2VTQmJKSgtDQUL5bRyEkJESdS+CdmJjod6XmZ599dpXrzz77rMp8L1u2jEE3ERG1eQy6iYioRna7XZ0HBgbynToGzgMWVqvV74Juz+/L119/jeLiYowcOdLn/crLy9XJqaCgoInWkIiIqGkx6CYiojrxx7HITcnf37+///5bBdllZWUIDw/Hd999h759+/q8//PPP4+nnnqqSdeRiIhatrX7crE7qxhd4sMwJDUG/oJBdx04HBqMRv/eWSIiIjoWvXr1wrp165CXl4dvv/0W11xzDRYuXOgz8H744Ydx7733Vsl0S88AIiJqm16YvQVvLtzlun7L2K54aFKfBn+dEosNoYFNGwazG04N5vzyDWY+dyWW/PZt030iRETU4nTu3BlTp05t7tVo0WT4gTRSGz58uMpiDxo0CNOmTfN5/6CgIERGRlY5ERFR281wv+kWcAu5LssbsrHplyv34cQXfseWw007pIlBdw0SD8zB+ZafoG3+oek+ESIiahDjxo3D3Xff3SDPtXLlStx0000N8lxthezcuI/ZJiIi8kVKyuuzvL5yiy249ZM1ePDbv5FbYsXHy/aiKbG8vAYx/U8HDn+FzvkrUGa1I9jsv41viIjaYlAoTb8CAmrfFCYkJDTJOrVWjzzyiJqTW8rDCwsL8cUXX+CPP/7Ar7/+2tyrRkRErUCX+LB6La+PpTuycO9X65BeUI4AowH/nNAL/xjTFU2Jme4adBp2OmwwopPhCNZuWN90nwoRER2Ta6+9Vo0nlvJmaWAmpw8++ECdz5kzR5VAS3nz4sWLsXPnTjWndFJSkmoANmLECMybN6/G8nJ5nnfffReTJ09WXcl79OiBH3/8sc1+aunp6bjqqqvUuO7x48dj+fLlKuA+7bTTmnvViIioFRiSGqPGcLu7dWzXY2qmVm6z47lZW3DFu8tVwN01Pgzf3XYibhnbDaYm7tfFTHcNDMFROBjWD52K/8bhtbOBYUOb7pMhImrBGeJSqz6NWFMLMZvq1AVcgu3t27ejf//+ePrpp9WyTZs2qfMHHngA//73v9G1a1dER0fjwIEDOOOMM/DMM88gODgYH374oZp3etu2bUhNTfX5GtJ5+6WXXsLLL7+M//73v7jiiiuwd+9exMbGoq157733mnsViIiolXtoUh9M6JfcIN3Ld2QU4s7P12Fzxdjty49PxWNn9mnyBmpODLpr4ehyMrDxb0QeWswu5kREgAq4+z4xp1nei81PT6jTBjMqKko19pIsdHJyslq2detWdS5BuHsGNi4uTjX9cpLgW6a7ksz17bffXmM2/bLLLlOXn3vuORV4r1ixAhMnTjymv5GIiKitGpIac0zBtiQGPlm+D8/8vBnlNgdiQs148YKBOL2fvi/QXFheXov2wyap82H2v7EzPb8pPhMiImpEUlrurri4WGW/ZWoryXxLibkE6Pv27avxeQYOHOi6HBYWhoiICGRkZDTaehMREZFvWUXluPHDVXj8+40q4B7TIx5z7j6p2QNuwUx3LQJTj0OpIQQxKMLqbWvQo90pTfPJEBG1UFLiLRnn5nrtYyUBsrv7779fjfOWknOZ8iokJAQXXnghLBZLjc9jNpurXJeyd4fDcczrR0RERPWzYFsG7v96PbKKLAg0GfHgpN64blRnGJt47LYvDLprYwpAelhvdC5ai6Ldq4BxDLqJqG2T4LK5xkTVh5SXS3fy2kgzNSkVl6ZooqioCHv27GmCNSQiIqJjITNMvTB7Kz74U99u90wKx7RLh6BPu0i0JC2yvPznn39WHVClG6x0h21u1kS9hDAoc0NzrwoREdWRdByXLtoSQGdlZfnMQkt2e+bMmVi3bh3Wr1+Pyy+/nBlrIiKiFm7L4QKc8/oSV8B97ajO+PH20S0u4G6RQbfNZsO9996L33//HWvWrMGLL76InJycZl2niC76+L/k4m2wO7RmXRciIqqbf/7znzCZTGqstsyz7WuM9quvvoqYmBiMGjVKdS2fMGEChg7lbBVEREQtkcOh4b0lu3Hu60uxPb0I8eFBeP+6Efi/c/ohuAGGoTWGFlcfKJ1f+/Xrh/bt26vrMo2LjLVzdohtDgm9TgDmA72xB7sz8tA9+eg76hERUdPo2bMn/vrrryrLpIzcW0ZcDvS6mzJlSpXrnuXm0h3VU15e3jGuMREREdUkvaAM//x6PRanZanr43sn4sULB6rAuyVr8Ez3okWLVKYgJSVFjfv7/vvvq91nxowZ6NKli5oPddiwYWo8ndOhQ4dcAbfo0KEDDh48iOZkiu+OEkMIQgwW7Nm2rlnXhYiIiIiIqK2Zs+kIJk5dpALuYLMR/zqvP969ZniLD7gbJeiWqVdkvtPXX3/d6+1ffvkl7r77bjz66KNYu3YtxowZg0mTJrnK/rxlDyR4b1ZGIzLCeqmLqpkaERERERERNboSiw0Pz/wbN3+8GrklVvRtF4mf7xiNq07o1PxxYnOVl0sALSdfXnnlFdxwww248cYb1fWpU6eq8vE33ngDzz//vMpyu2e2Dxw4gOOPP97n85WXl6uTU0FBARqDLWkQULQO1n2rYbE5EBjQ4obDExERERER+Y2/D+Tjri/WYldWsbp+80ldce/pPREU0DLHbvvSpJGjzHm6evVqnH766VWWy/U///xTXT7uuOOwceNGFXgXFhZi1qxZqqmNLxKoR0VFuU4dO3ZslHVPHTRWnZ9gW4WZq7034yEiIiIiIqJjY3doeOOPnZg8Y6kKuJMjg/Hpjcfj4TP6tLqAu8mDbpmyReZMTUpKqrJcrh85ckRdDggIwH/+8x+cfPLJGDJkCO6//37ExcX5fM6HH34Y+fn5rtP+/fsbZd0De0+CxRSOjsZMLFvwA2x271PPEBERERER0dE5lFeKK95dhhd/3QqbQ8Ok/smYfdcYnNg9vtW+pc3Svdyz9l7GcbsvO+ecc9SpLoKCgtSp0QWGwjDwQmDtBxhbPAfLd1/Rqj94IiIiIiKiluTnDYfwyMy/UVBmQ2igCf93dj9cNLxDqxm73SIy3fHx8WrOVGdW2ykjI6Na9rslMg+/Wp1PMq7A3gPN21GdiIiIiIjIHxSV23DfV+tx+2drVcA9qGM0frlzDC4e0bHVB9xNHnQHBgaqKcLmzp1bZblcHzVqFFq8lKHICu6MYIMV2Lu0udeGiIiIiIioVVuzLxdnTFuMb9ccgNEA3HFKd3xzy0h0iQ+Dv2jw8vKioiLs2LHDdX337t1Yt24dYmNjkZqainvvvRdXXXUVhg8fjpEjR+Ltt99W04XdcsstaPEMBhTH9kP8oT0wZlf+jURERERERG3d2n252J1VrALmIakxNd7XZndg+oKdeO33NNU4rX10CF69ZDCO6xILf9PgQfeqVatUEzQnCbLFNddcgw8++ACXXHIJsrOz8fTTT+Pw4cPo37+/6lDeqVOnY3rd6dOnq5M0amtM5qSewKFfEF60q1Ffh4iImlfnzp1x9913qxMRERHV7IXZW/DmwsoY6ZaxXfHQpD5e77s/pwR3f7kOq/fmquvnDk7B0+f2R1SI2S/f5gYPuseNG6cao9XktttuU6eGNGXKFHWSebpl6rDGEtmhL7AWaGc7oCZqDw1sll50RERERERELSbD7R5wC7k+oV9ylYy3xInfrzuIx7/fpMZxRwQF4F/n9cd5Q9rDnzFirKfw9vrRmm6GQ9iVUYT+HaIb43MhIiIiIiJqFaSk3NfyIRVBd36pFY99vxE/rT+krg/vFKPKyTvGhsLfNWkjNb8Q2w0OGBBtKMaBQweae22IiMiLt956C+3bt4fD4aiyXKajlOFOO3fuxLnnnqtmzggPD8eIESMwb948vpdERERHwVfTM+fy5buyVbM0CbhNRgPuPa0nvrjphDYRcAsG3fUVGIo8sz69WcH+TY3wkRARtXAyhMhS3DynWoYvOV100UXIysrCggULXMtyc3MxZ84cXHHFFarp5xlnnKEC7bVr12LChAk4++yzVWNPIiIiqh/JZssYbne3ju2K/u2j8PKcrbj0nWU4mFeKTnGhqjP5neN7IMDUdkJRlpcfhaKILojNOQJ7xvaG/0SIiFo6awnwXErzvPYjh4DA2qcQkRkzJk6ciM8++wzjx49Xy77++mu1XK6bTCYMGjTIdf9nnnkG3333HX788UfcfvvtjfonEBER+SNpmiZjuJ3dy6NDA3HBG39iw4F8dftFwzrgyXP6ITyo7YWgfnN4QTqX9+3bV5UINjYtroc6D8zb2eivRURER0cy2t9++y3Ky8vV9U8//RSXXnqpCriLi4vxwAMPqO1GdHS0KjHfunUrM91ERETHmPGePKQ9tqcXqnJyCbijQsyYccVQvHzRoDYZcAu/+aubqnu5iJIO5mlAdOle1XWvrX55iKiNMofqGefmeu06knJxGdP9yy+/qAOyixcvxiuvvKJuu//++1Wp+b///W90794dISEhuPDCC2GxWBpx5YmIiPxbbrEFD83cgDmb0tX1kV3j8Molg9AuKgRtGaPFoxCd2k+d9zLsw5q9uTipZ0JDfy5ERC2XwVCnEu/mJoH0+eefrzLcO3bsQM+ePTFs2DB1mwTg1157LSZPnqyuyxjvPXv2NPMaExERtV5L0rJw39frkF5QDrPJgH+e3gv/GNMVRqMBbR2D7qORMgQOGNHBkIWftm7GST3HNvgHQ0REDVNiLhnvTZs24corr3Qtl+z2zJkz1W0GgwGPP/54tU7nREREVLtymx3/nrMN7yzera53TQjDa5cOUU3UyM/GdDepoAjkRfVWF8t2LG3utSEiIh9OOeUU1Txt27ZtuPzyy13LX331VcTExGDUqFEq8Jbu5UOHDuX7SEREbdbafbmYueaAOq+rtPRCnDf9T1fAfcXxqfjljjEMuD0w032UArqcCKzbjMTc1Siz2hFsNh3tUxERUSORpmmHDlUff965c2f8/vvvVZZJXxB3LDcnIqK24oXZW/Dmwl2u6zL9l3Qj90XTNHyybC+e+WULym0OxIYF4sULBuK0vvrUylQVM91HKaLnGHU+zLANa+pxNIiIiIiIiKilkMy2e8At5LqvjHdWUTlu+HAVHv9hkwq4pb/Vr3ePYcBdAwbdR8mQOkqd9zbux/rtejkFERERERFRayobl3m167p8wdYMTJy6CL9vzUBggBFPnt0XH1w7AokRwQ2+3v4kwJ/m6ZaT3W5vmhcMT0BBWCdEFu9FUdpSYFLjzw9ORERERETUkGXjXeK9z0jivlyG0z4/aws+/Guvut4rKQLTLhuM3smR/DDaUqZbxuJt3rwZK1eubLLX1FJHqvOYrFWqax8REREREVFrKhsfkhqjgnF3t47tqpaLzYcKcPZ/l7gC7utO7Iwfbj+RAXdbzHQ3h8ieJwFbvsAQbMXfB/IxvHNsc68SERERERFRjWXjzoDaSbLfE/olq9skwy23Oxwa/rd0N176dRssdgfiw4Pw74sGYlyvRL679cSg+xgYOunjugcYduF/Ow4x6CYivyadSunocR5wIiJqSnUpG3cngbYzGE8vKMM/v16PxWlZ6vqpfRJVd/K48KBGXGP/xaD7WMR0RnFQAsLKM5G97U/g1P4N9sEQEbUUZrMZBoMBmZmZSEhIUJepfgcrLBaLev+MRiMCAwP59hERUaNzlo27l5i7l437MmfTETz07QbkllgRbDbi8bP64vLjUrn9PwYMuo+FwQBbhxOAnT8hIn0lSizXIzSQbykR+d9c1x06dMCBAwc4d/UxCA0NRWpqqgq8iYiImoK3snFfSiw2/Ovnzfh8xX51vV9KJKZdOgTdE8P5YR0jRojHKELGde/8CYO1Lfhp/SFcMiL1WJ+SiKjFCQ8PR48ePWC1Wpt7VVrtgYuAgABmCYiIqMm5l437suFAHu7+Yh12ZRVLXhE3ndQV953WS00LRseOQfcxMlaM6x5m3I5rlqUx6CYivw4c5URERET+we7Q8ObCnXh17nbYHBqSI4PxysWDMKp7fHOvml9h0H2sEvvCHtEBYYUHkHB4ITYcGIaBHaIb5MMhIiIiIiJqDAfzSnHPl+uwYneOun7GgGQ8N3kAokPZe6Sh+U29wPTp09G3b1+MGDGiaV/YaIRp0EXq4mTTEny39mDTvj4REREREVE9yLDYiVMXqYA7NNCEly8ciOmXD2XA3Uj8JuieMmUKNm/ejJUrVzb9iw+8RJ2NM67Dzr37mv71iYiIiIiIalFYZsW9X63DHZ+vRWGZDYM6RmPWnWNw0fCO7DvSiFhe3hAS+6A8vh+CsjahS/pcWO0TYDb5zfEMIiIiIiJq5VbvzcXdX67F/pxSGA3A7Sd3xx3jezBuaQIMuhuIeeAFwO+bcAI2YNuRQvRvH9VQT01ERERERHRUbHYHXl+wA//9fYdqnNY+OgRTLx2MEZ1j+Y42EQbdDcSYeoI6H2zciQUH8hl0ExERERFRvazdl1unObXret992SUqu71mX566ft7gFDx9Xn9EBpv5yTQhBt0NJWUwHDChnSEHe3ZvB45PxYHcEpX1Ht8nqcFehoiIiIiI/M8Ls7fgzYW7XNcnD0nBq5cMqdN9bxnbFQ9N6uO6rmkaZq45iCd/3ISichsiggLwzOT+OHdw+0b+K8gbDjxuKIFhKIruqS5q+/VmblM+XYMbPlyF5buyG+xliIiIWprnn39ezR4SERGBxMREnHfeedi2bVtzrxYRUashWWv3IFp8t/YQ7vlybZ3uK9dlucgvsapGafd9vV4F3CM6x2DWXWMYcDcjBt0NyJSqT1eWWLAROzKKsP6AlHFo+PtgfkO+DBERUYuycOFCNYvIsmXLMHfuXNhsNpx++ukoLi5u7lUjImoVpEzcGwm8ncF0bfeV5ct2ZWPStEX4ecNhmIwG/PP0nvjippHoGBvaKOtNdcPy8gYU2uV4YMNHGGRIw0PfbsCTAR+pubvfPPghgK4N+VJEREQtxq+//lrl+vvvv68y3qtXr8ZJJ53UbOtFRNRayLhsXySYdh+z7eu+S3dkYebag9A0oFNcKKZeMrjWceHUNJjpbkCGDsep84GGXdi69yAuM/2OaEMxIg8taciXISIiatHy8/UKr9hY351xy8vLUVBQUOVERNRWSXAsY7i98Qyy5b4yhttdQkQQvl2jB9wXD++g5t5mwN1y+E3QPX36dPTt21eNKWs2cd3hCIlFsMGK+wK+VuciuHBv860TERFRE5LmPffeey9Gjx6N/v371zgOPCoqynXq2LEjPyciatOkaZpn4H3r2K5eg2dpmjbz1pG4aFgHBAUYkVlYjqgQM2ZcMRQvXTgIYUEsaG5JDJpsHf2IHCmXjbccZY+MjGz6FZj1ALDiraqL7MfhhId+QWxYYNOvDxERtXjNvu1qQDK2+5dffsGSJUvQoUOHGjPdcnJ/DyTw9of3gIjoWNRlKrCcYosazvrb5nR1fVS3OPzn4kFoFxXCN78Fbr95CKShDbumWtDdxXAEOzOLEBvGCeiJiMh/3XHHHfjxxx+xaNGiGgNuERQUpE5ERFSVBNo1lYYvTsvEfV+tR0ZhOcwmA+6f0As3ju4Ko9HAt7KFYtDd0JL6ATK2+8AK16JOhnT8mF6IEZ0ZdBMRkf+RojkJuL/77jv88ccf6NKlS3OvEhGR3ym32fHyr9vw7pLd6nq3hDBMu3QI+rePau5Vo1ow6G4Mx92kB929zoRj268INZQj45D85+jUKC9HRETU3CXln332GX744Qc1V/eRI0fUcim5CwlhqSMR0bHanl6IOz9fi61HCtX1K09IxaNn9EVIoIlvbivAoLsxDLwIiGoPJPZF8X9HI6JkP0qOpAEY1ygvR0RE1JzeeOMNdT5u3LhqU4dde+21zbRWRET+UUn00V978dysLSi3OVSPqJcuGIhT+yY196pRPTDobiydRqkze3RXoGQ/7Fk7YHdoapJ6IiIif+JnPVmJiFoE6Uj+wDfrsWBbpro+tmcCXr5oIBIjgpt71aitThnWUoW376XO48oPYMXunOZeHSIiIiIiauF+35qOiVMXqYA7MMCI/zu7Lz64bgQD7laKme7GfoPju7s6mP+w7iBGdotr7JckIiIiIqJWqMxqV6XkUlIueidHqGZpvZIjmnvV6Bgw093Y4rqps+6Gg5j192HVdZCIiIiIiMjdpkP5OOu/S1wB9/UndsH3U05kwO0HmOlubO2HQTMFohsOo335TizYOggT+yc3+ssSEREREVHL53Bo+N/S3Xjp122w2B1IiAjCvy8apMZwk39gpruxhcTA0HOiuniBaRE+Xa4fuSIiIiIiorZh7b5czFxzQJ27O5Jfhqv/twLP/LJFBdyn9knCr3eNYcDtZ5jpbgqDLwe2/IjzTEvxQtpl2JVZhK4J4U3y0kRERERE1HxemL0Fby7c5bp+y9iueGhSH/y68QgemrkBeSVWBJuNePysvrj8uFQYDJztyN/4TdA9ffp0dbLbW+CY6e6nAqHxiC/JwknGDfhkWQ88cXbf5l4rIiIiIiJqRJLZdg+4hVzfkVGEeVsy1PX+7SMx9ZIh6J7IpJy/8pvy8ilTpmDz5s1YuXIlWhyTGRh4savE/KtV+3Eor7S514qIiIiIqM3zVfrdEHZnFXtdLgG3JLRvGdsNM289kQG3n/OboLvFG3SpOjvdtAbG8jzc99V61TSBiIiIiIiar/R78ow/ce9X69W5XG9IXeLDvC6PCwvEpzcej4cm9VbzcJN/4yfcVJIHAon9YIYN5weuwF+7svHgtxtQWGZtslUgIiIiIqKaS78bMuM9JDUGVxyfWmVZt4Qw/H7fOIzqFs+Poo1g0N1UpH5k8GXq4p0xf6rg++vVB3DO60tRXG5rstUgIiIiIiLfpd++lh9NafqP6w+pkwgKMOKOU7pj3r1jERVq5kfQhvhNI7VWYcDFwPx/ITZ/M1Z1mo7zs27Bzixg/tYMnDMopbnXjoiIiIiozfBV+u1reV27kgupZn3yh02Yufaguj64YzSmXToYneLq9tzkX5jpbkoRScAlnwCBEYhKX47Pgp5DJIowd3N6k64GEREREVFbJ6XfEii7u3VsV7X8WErTV+/NwRmvLVYBt9EA3Dm+B76+ZSQD7jaMme6m1vN04Ma5wIfnIKk4DR8GvoTrtz4Ni20QmygQERERETUhyUxP6JesSsolw12XgLumEvQ3/tiJeVvSIf2SO8SEYOolgzG8c2wDrzW1Nsx0N4fEPsDVP0ALisQQ4w4Msq7D8t3ZzbIqRERERERtmQTa5w/toM7rOn2YrxL03zbrAff5Q9pj1l1jGHCTwqC7uST1haFi7u4JxpX4deORZlsVIiIiIqK2rj7Th3krTRcRwQFq7PYrlwxGZDCbpZGOQXdz6nO2OjvdtArfrNqLHRmFzbo6RERERERtka8x2q/O3eYz633r2O44sVuc6/pxnWMx+64xOHdw+0ZfX2pdGHQ3p04nQguJQZyhEIMdW/HIzI1wSD0KERERERE1GV9jtKfN3+E16/3XzmxMnLYIS3dmI8BowP0TeuHzm05Ah5jQJlpjak0YdDcnkxmGXmeoi+eZl2HFnhx8s/pAs64SEREREVFbU9s0Yc7O5BabAy/+uhWXv7sMh/PL0DkuFN/cOgpTTu4Ok7QqJ/KCQXdz63+BOrvE9DuGGrbj2VlbkFVU3txrRURERETUZvgao+1u+a5snP/GUtWhXNOAS4Z3xC93jlFzcBPVhEF3c+s+HhhwMYyaHTNC3oCjNB9XvbdC/Wcus9qbe+2IiIiIiNrM9GGTh6T4vP3VeWnYeLAA0aFmvHnlULx44UCEBXEGZqodg+6W4Mx/A9GpSHak49nAD7DlcIEqW3ns+43NvWZERERERG2ClI9/t/aQz9vLbQ6c2D0Ov951Eib2b9ek60atm98E3dOnT0ffvn0xYsQItDrBUcAF7wEGE84xLsGHQ9NgMECN716wNaO5146IiIiIqM02UxNmkwGPntEHH19/PJKjgpt0vaj185uge8qUKdi8eTNWrlyJVqnjccC4h9TFsZv/D+93WQADHHjku79VwwYiIiIiImr6ZmodYkLw/ZQT8Y+TusLIZmnUloNuvzDmPmDo1QA0jDv0Dh4J+V51RfxjG7PdRERERESN3Uzt4uEdqizrlxKJufeMRb+UKL75dNQYdLckRhNwzn+BM/+jrt6gzcQwwzbMXHOwudeMiIiIiMhvaZqGD5buxvfr9DHd4UEBeOSM3njmvP6YvfGwGu9NdLTYbq8lGnEjsH8ljBu+wCvmNzBpa3fkFg9ATFigz4c4pxmLDw9qwhUlIiIiImrZJGCW8dpSPi7ZbE8ZhWV44JsN+GNbpro+rlcCXr5wEN5bsguTZ/zpup9MKSYdzonqi0F3S3XGy8CuBehUlI5JtqX4acNAXD2ys9e7Wu0OTJy6WJWl//XweJhNLGAgIiIiorYTOPvywuwteHPhLp+B8/wt6Srgzi62IDDAqJqlXT2yE9btz6vyOCHXJ/RLrtfrEwkG3S1VcCRwwm3AvCdxU8DPuHXJBFxxfCeYvDRvOJxXhtvK3oEBGo7kn4iOsaHNsspERERERA2ttsC5pkDdV+DcOzkSz83ago+X7VXLeydH4LXLhqBnUkSNncxlOYNuqi+mRFuy4ddBCwxHL+MBdM5dil/+PqwWl1nt2OP2Q5B+5CCuD/gV1wXMQVYGx38TERERkX/wFTjXZYy1r8B5SVoWzn59iSvgvmF0F9Wd3Blw19TJ3Ndyopow6G7JgqNgGH69unhzwM+YsWAHHA4Nt36yGuP+/Yfrx6bgyG7XQwrS9R8PIiIiIqLWrqaMc218BcjT5qdhR0YREiOC8NH1x+Hxs/oi2Gyqch/JZktG3d2tY7syy01HheXlLd0Jt0Fb9gaOx1aEpq/G/d9EYUFFk4eF2zPVf/zS7MpAuyx7fzOuLBERERFRwzmWjLMzcPbMlNscGk7rm4QXLxiI2BoaFUsJu5SiH81YciJ3DLpbush2MAy6BFj7icp237ymJ7oYDuME42b8vT9e3cWRWxlo2/MONOPKEhFRc9u/fz/27NmDkpISJCQkoF+/fggK4swWRNQ6eQuc65NxlqB5X04Jft+SgTKbAyFmE544uy8uHdERBoOhTq/PYJuOFYPu1mDUnSroPs20GmPsG/CS+W20M+Tgwf1R0LTjYCrS5xMUpsLKy0RE1Dbs3bsXb775Jj7//HMVdMt8s06BgYEYM2YMbrrpJlxwwQUwGjmyjIhal6PNOP/r5014b8ke1/WE8EB8cfNIdEsIb8S1JaqOW97WIKEXMPBSGKHhg8CXVMAtBljW40BuKUJL9QZrIqj0SDOuKBERNbW77roLAwYMQFpaGp5++mls2rQJ+fn5sFgsOHLkCGbNmoXRo0fj8ccfx8CBA7Fy5Up+SETU6kigff7QDnUOuL9aua9KwC0yiywoKLU20hoS+cZMd2sx6UVg758w5e9zLTreuFXNIdjemgFUVMdEWDKabx2JiKjJSSZ7586dqpTcU2JiIk455RR1evLJJ1UALlnxESNG8JMiIr9kd2h4448deGXudq+3c8ovag4MuluLkGjggneBTy8Cek0CNnyBHsaD+GTTdgxFtutucfYs1eHc6GU+byIi8j8vv/xyne97xhlnNOq6EBHVlczC09ANyg7kluDeL9djxR69KtQbTvlFzYFBd2uSejzwsJ7pztu9GtGFaSjcugDJFeXmIhnZyCoqQ2JkSDOuKBERERGRdy/M3lKlMZo0SpNx28fih3UH8dj3G1FYZkNYoAlPn9sf29ML8Naiyql1OeUXNRcG3a2UsfOJwN9pOF1bCpNRgx1GmOBAsMGKnRlHkBjZpblXkYiImlh2djaeeOIJLFiwABkZGXA4HFVuz8nxnf0hImqqDLfnFF5yXRqlHU3Gu6DMiid/2ITv1h5U14ekRmPqJYPRKU6fUmxi/3ac8ouaHYPuViqy9zjg7w8w0aQ3xMkNSESAvQzRWh4K0vcA3Rl0UxslQYatFAisff5OIn9z5ZVXqvHdN9xwA5KSkuo0HQ4RUVOSknJv/tiWUe/geNWeHNz95TrVWFhGVt5xSg/ccUp3BJgqe0Vzyi9qCRh0t1ZdxsJhDoXRWqKu5gYkINBYhmhLHkqyKputEbU5X1wO7F0K3LkOCItr7rUhalJLlixRp0GDBvGdJ6IWydeY6mnzd9S53Nxmd+C133fg9d/T4NCADjEhmHbpYAzrFNso60x0rDhlWGsVGgvjyCmuq5EJHVEakqQu2/P08hqiNmn/MqC8AMjc2txrQtTkevfujdLSUr7zRNRiSeZZguqaSLm5lKF7sze7GBe++Rdem68H3OcPbY/Zd41hwE0tGoPu1mzUHa6LSdHhcISnqMt56XugaVozrhhRM5aWl+Xrl53nRG3IjBkz8Oijj2LhwoVqfHdBQUGVExFRSyBZ7O9uG4VXLh6Eu8Z3r1MZuuzbfr1qP86YtlhNmRsRHIDXLhuCVy4ejIhgcxOtOdHRYdDdmgVHARe8B0R3Ak64BandeqvFXYvWYsHW9Ho9VXpBGaz2qg13iFodyXBrFd/jsrzmXhuiJhcdHY38/Hw1L7fM0R0TE6NOslzOiYhaUsb7/KEdMK5XYq1l6HklFtz+2Vrc/80GFFvsOK5LLH69+yScM0hPOBG1dAy6W7sBFwJ3bwDaD0P48MtgNQRhuHE7Fv7yWZ2z3dv3HsDGlyfis3fqPtcr+YHMbcDUAcCq9+E3St1K0Y4m0y3/Z2bdDyx7o0FXi6ipXHHFFQgMDMRnn32G+fPn4/fff1cn6WYu541p0aJFOPvss5GSkqIauH3//feN+npE5L/l5u5Te/25MwuTpi3GL38fRoDRgPsn9MLn/zgB7aM5PS61Hn7TSG369OnqZLfb0WZFpsA+4iaYV/wXlxa8j/mbL8Op/drV+rD0VT9gvGktdqVnAXiwSVa1tflixT5sPJSPp87pD5O0x/QHO38H8vYBG78Fhl8Hv3CsQbeMA1/xNhAQDBx/C8DOz9TKbNy4EWvXrkWvXr2a/LWLi4tVA7frrrsOF1xwQZO/PhG1HjJe271TuZSby5Rh7sssNgdembsdby3aqY6Jy3JpljawQ3Rzrz5R2w26p0yZok4yZi0qKgptVfC4e1G2+n30wT5889tXGN/3zlqnjHFkbFPnyY4MWG12mANMTbS2rUf27Ocw1rYdK/t+ghN6+kkpU1HFEISCQ/AbbkF3WWEOguv7+Lz9+rmtTC9VlyEcRK3I8OHDsX///mYJuidNmqRORESeQbW7F2ZvqTJPt7NTufvUXjsyinD3l2ux8aDei+LSER3x+Fl9ERbkN6ELtTH85vqb0Fg4Bl4KrH0XQ3JmYcXuK3F815qnTQop2Kk/1FCO/YcPoGPHTk20sq2DjHW/yvEDIk0lmLVxHtDzaviFogz9vPCwXlbtD1ldt6C7IDer/kF3fkXQLYqzGHRTq3PHHXfgrrvuwv33348BAwbAbK7aXGjgwIHNtm5E1Dbc8+VafLf2kNfpvyQYdw+4hVyXLLcE3DI08rMV+/CvnzejzOpAaKBJzbt96zjvzdaIWgsG3X4o9LirVdB9mnEVTnr/dwzs0QW3jO2GYZ28N9GJL9vrupxzcIcedNttQMZmIHmAfwRjxyA7Nw/JBn0+dBxYDkAPuuUIbnSIGTFhgWhxHbyNxrpnumWudynFDmn95VqWohw4Pw176VE0Uis4WPWgRFy3Bls3oqZwySWXqPPrr7/etUyqnWRHVs5b0hCs8vJydXJid3Ui/wu4PYNqz47kTrI8NTYUD377N+ZtqWwGXGKx48VftyG/1FrjvN1ELR0bqfmjdoNgTeiHIIMND+N/SN72Ma5643c8+M0GV3M1h0xsKMm80jJ0cFT+OBYd0bPejiVTgbfGQPOnJltHqSCzMvuZlLdOnR/JzETOa+Ow6LXKHdsWYd9y4LkUYOlrtd61KNstwJRstx8oyc88pjHdlux9lVeK3Z6LqJXYvXt3tdOuXbtc5y3J888/r4aDOU8dO3Zs7lUiomMgWWzPgNvJGWy7dyR3J93JJ05brAJuaZZWn3m7iVoDBt1+yjz0SnV+nulP/Mv8AX4NehCOtR/jo0/+hw+euwWvvvwkisptOLh7KwINlZkPW85udZ65aqY6P7ziG7R17sFpH3saMvOLcWTVDxhm3I6JZbNhs1rRUhQsmg7YSpG56rta72twlpe3lnHdmgbL5tnQCnwfICgrzHZdNlnqH3SXZlUG3daC+k27R9TcrFYrTj75ZNXQrFOnTl5PLcnDDz+spjdznmQsOhG1Xr6y2DUF205P/7wFmYXl6J4YjrvG96j38xO1dCwv91fDrgVy9+jNoPYsQWr+frxsfhvQE9nKRz8PQc/Qqj9gATKm1VKCuMKt6np01lrAYQeMbbe5WnlOZUAq4943blyG8N0L1HWpJkg/tAtJnZq+aVE1lhIE7/pNXQzI31PzfR12hFhzjy7TbSkGPr8U6HoyMOZeNJWDa2ah/U+XIy1yJHrc+6vX+1gLc1yXzZbCer+GsfCA63Jx9iG0/oJ7aktk/LaUa9fWPLOlCAoKUicial3N0aTXjdlkrNYkzVdgff6QFNf9agqcrxnZCQ+f0QdbDhfgP3O31ztwJ2rJGHT7q8BQ4IyX9MvlhdCWTMXO1fMQUHQY5gAj2jsOI279W8hM1pvqWGGCGXaElh7E4c1L0Q569jtUK0HJ/nUI7TQMbU6OlGIaYC84UmVxcdoS9Mr+03U9/+DWlhF0p81BoKNUXYxx5ADlRUBQuPf7FmfBCIfralnOgbo3Hdu9GNi9CDi8ARh9T8OP+d/wFTD7QeDyr4COI1yLM7b+hfYAEgo2+mz85iipPJAQZK9n0O1wILSsMrtdls9MN7XORmovvvgi3n33XQQENO0mvqioCDt27HBdl5L2devWITY2FqmpqU26LkTUsDw7jjud0jsBd5zSw9V5XJqmud9PAu5XLhlSa+D86Bm98Y+T9D4q3p7Hfd5uotaIQXdbEBQBw/jH0e2Ux7AnuwTtLDuBt8dgomEZVhzOB0zA7tCB6FmyFrGWwzi4YQHcZ/fet3Yeevtr0C1Nx1a/D3QZC8S7dca0lADvjAcMRgSEj69yYKLXga8QZa/MqJalp6ElsP09s8p/aEfObhjbDai5iVqF4qz9voPuHfOAwnRgyBX69Sx9ijmU5enPE5GMBrX2Y6A0B9j0XZWgOyBHf5+jUQhLQQYCo5KqPdRYXhl0BztK6t5UThRnwKTZXFft8jcTtTLLly/H/Pnz8dtvv6nu5WFhVXdwZ87Uhw41hlWrVqnydqd779UrYa655hp88MEHjfa6RNS4vHUcd/p9a6Y6OTuUe5tv2137mBB0jAnB/lw9SSCuGZnqCridanseotaGQXcbIiWH+hHGgSjuOBZh+xdipGmzuq2808nAlrVI1jKRs/8vtewQ4pGCLNh2L4Xf2jQT+OVeaF3GwnDNj5XLM7bogR+ADvbV6nxj1CkYkDcfKbbKEmQl261mv7lYS2FI00vL87VQRBlKkH9wO2J8BN1aUTrc88S2PLemau5sFuDLqwFrMdB+KJDYB8isCLpF5taGCbp/f1YPtq+bBceh9arZhD1zuxwPAqTPQHQqIosqN/iZu9ah/ZAJ1Z7G7DaO2whNH15R167s+VXfA4NMGUbUykRHR+OCCy5oltceN26cq1knEfmPuoyllqBc9jGdZefnD+1Q7T7zNqfjgW83IKfYgkCTEWcNbIcrT0jF0E6xXp/Tfd5uotaOQXcbFXbW87B/eilMBftgQQC6jL0cts1T1RjlIdY16j77ev8DKVufR/v8tdAcDhjqkjEsL0TJvOcRNOwKmJL7oaXL2boI8lNv2bsSQW5Z0bKDG1yZ3w7lermko+s4PLuxPx63TIXRoGGbowN6GQ8gqKByyrVms2cpTPYyHNZiscLRG+ea/kTxkW3wtakqzTmMUImpNSMCDA4YnWO6N/+gdz4/e6o+XdyRv/WAW+xfXj3oztgKdB13bOsu7/vKd/WDHIv/A2O5HjgXHdqKKMl2f30tHGMfQmJ5ZZOzgn0bK4Nu2cn/8Q5AcyDE6jFNWD2mQrPm7oPMaGzVTDAb7AgsZ9BNrc/773PGCSJqWHUdSy3TfTlNHpKCMT0S1GN7J0fi2Vmb8ckyfTveOzkCr102BD2TIvhRUZvB7uVtVVI/mO7ZANy5DoH3rEd4cg/kGyJdNxcbwjHw7Cko1oIRgwJsWOS7G3Z6QRnemL8FucUW7Pr5ZYSunI4jH/+j7usiQZNkVJuBZe8qdR7kKIGWVxk85+7SDzy4C4xJga3fhZhivRPf2kfjP7aL1PLIUrdppo6GBK4vdwdmPVD9NilxzvfIrHuzY646+8M+CHs0vezaluV7eqDCio7saZp+JDq4rKKT+V8zgIOrgJk3q89Ek0C7gnXvCvVZOSS77ZS5peoTf3Yp8NoQwDlHtmSL5fp3t1Z+1tKYr8rfv8lVVaDGc1cILz2II8u+VJctS2cgBGWu2xzpbq97eL2eJV/3KaIc+us6ND2P76jHXN15R/TO/dsr3pNQS+UQAhdm8aiVyMzMxJIlS7B06VJ1mYjoaDnHWNeHTB1271frMXnGnxj5wnxXwH3j6C744fYTGXBTm8Oguy2TRlSxXYAoPcjIjaxsBma++D2EhkVgU/J56ro0YnPO7a3YbSqLWFRmxe/Tp+CmRSMx+/PXgG16V+n2xZtQfMgtOPNlxzxYXxsO20vdmqZM21aun9RlC+KKKrtjpm9f6brsOLKp2kPDYtvjlN6JmO04HvdZb8PB4J5qebz1sP5+HK3fHlNzQmsr3q7MIkv298//AlP7A2+MAtyn9/JCS5unzv9wDIItqrO6HJC3B9j5O5BX/aBAea6e2d7g0DeiYbZcVaKuAlhnILx0Gop2/lX5mD3L1dRiRkuRa5n90AY90P72Rv3z2z5bb0C39efKIFqur/8MSN8EvD4CmHFC1SnKpDGb6wkrD76Y4EDsAb1LfLCtoMr6h+RXjqO3bnQbFlDhEOLUeVF+5RRitSnJ2FPlPZEmgrBWBvrqoMir/YEiBjDUcsl0Yddffz3atWuHk046CWPGjEFKSgpuuOEGlJSUNPfqEVErJWOsv7ttFF65eBBevGAATu6VUOfH5pVYERNqxsc3HIfHzuqLoIC2OyMOtV0Musml2xWvonT0w8D9OxHYZ6Ja1vO8h1S57WDbBvw2dzZQeAT48Gw4nm0HvJCKvJeH4rLyb2AyaBi7/w10tVSWHu/5/X81v7vL3gA+uQDm3B0IsBTgwPw31WJH3gFsn3Y2Nr1zY2VmsbxQlR67gsKjIaXG/x2mB34Fh6Clb4QZlXNsZ++oCLo1DdGF1aeqiExMxQld4xAUoP+36dWzN8o0M8ywATLVmmRw9y3X17Umaz/Vy6nFroWuLLUBGhyL/q0vl79VgnEJQmW9133m+/lydsOQs0N9TluCh6JdF72sv0PeSuDjyfpJ1k2qCez632uXz1Eqxs2dYNFM+vhnWRdbKbSK0d7aopcRsHeR62XCC3YAB1aoy+WaFGIDpsNr9ED776+BuU+47mvb+H3lmHmnLy4HstOArO36OpXomWSbvK4PgZpb0Cvr69A38vElelZalG6oWoVRrgUgQ9ML60uy9wOZ1T9Lb+x5ekVBbnh39Z4oxZUBtn3T90DBAaBi7DxRSyTNyxYuXIiffvoJeXl56vTDDz+oZffdd19zrx4RNXEDtJlrDqjz2u7z5cp9td5XMt4yVvuSEal4/7rjqgThtbnntJ6q3JyorWLQTS6GpH4IOfUhICzetSy6XRfsSJ6kLqcsfQSbZ1yhposyOvSMZAe7nkWVceHtDVmuoEfE7/pez9gKTYN1229w7NfLubFxJvDrw+riX/a+6jx0+/cyGTMsb45Dz9xF6HfwaxxaO1vdVvTdPcD8p2F7b6IK1q1vnAT7zFv1gFTs/UvvNi4NuUpzvZcDS5AvwbGUkX92CfI3/17105fxy/KQgoMIc1QNnOVviolLQkigCWcObAejAbhweCr2VpRylx/aCHx9DfC/04Fpg4Dlb3svRZZs7w+3Ab/cB2yfA8x5VC1ebO+v3/73N2oqrrIlr6uri+z6hsy68oPK91Iy19Jd3WmzHuCu1npicI9UhCS5dWEX2TuA5W8C0wYCL3QCvrwSiVl68BydmIqMipHfDgkq1efRB8scfWCwl6sx0nbNgHStYlz0us/V2VJHP7W8Cmd2W35Ydv2hTyl2oLJ6QM0bL++VjJyWEvVPzldl6FpFo74tjo6uu+5xVO9MLn43HKdKxyO1fL10PXN7lQZrogBhsJj1cWLJ8+4Epo9A9mbfgb1TUKH+XY5O6YFsROnr6pw2zGGHoSIAz9rilpknamG+/fZbvPfee5g0aRIiIyPV6YwzzsA777yDb775prlXj4iacIovKe12lnjL9ZruI+Oxa7pvbUF4beXnA9rr21WitopBN9Wqx8XPojggGgONu9G3dJXKcp5v/Rce6PgpFnS6C3tOexd7O13ouv+6DlegUAtBkiMde358TgXBuZ9cC/PnF0F77zTkfn0HtG9lzLeGjx0TcK31ARRooYi1ZUD74EwEl2W6MqnWBS+ibNMshG/9Wl0PsJUAvz4Ec/p6mDZ8Bscbo4Htv0H7+lp9LPKil/QxxFt/gfbF5XD8p7cK5G1F2bAu+a96DoshEDiyAVFLn1XXlzv6qPP4Yj0jmrVzrTrf7mivOoGLHEM0TCb9v8tzkwfgz4fGY2S3OBww6JOrBXxzDbDlJ/0NKMkGZt+vZ3kPrALm/6uyJHnJq5Vv7JdXAel/I1cLx13W2zHXPlTNnW1//ywEW/NwQIvH3do9KNBCYM7fDW3PIkDKyKcNVtUGKmu9bbb+/AB+sR+P0T3iEZ8ks1l7mPMIIM3SpCnalp/0cnIZ2p+Sis1aF3XZ8Lc+nnqD1g1TtctdD92udcRfjr6uucDFJq0z9mh613LJsLs7osXAqFmB729T11c7eqjPVxzU4nBe+dMoNkUBh9ZCm3ECzLZCdft79jPUfaS526+O47wG4Lakgdiv6UfKHTNGwvHuqeryZkcn132KjBGwBFT2JxB7V+vr7ZOmIaZcH+ee1KUPciqC7rxMfZlWlOGa19y+b1nNz0XUjKSEPCmp+kGrxMRElpcTteEpvuS6exa7pmnAPO9bFzJX9/jeiV5v4xzbRAy6qQ4C4joj7JpvYDcFqetb+9+LNx68CS/dcBZOvu5pdD7xInSccLfr/r1OvhILU/RGap3XvQz7S90Rs/N71zjdmE0fwaDZMNM+Gk9arsKI7in4M3CUut1gLcEmRyecYX1OZZc7Fa5D4Nf6/NAf207FckdvFZTJZSk1NubvAz67CIaiIyo4OxTYWc90f3E5DFt/gbHoCMo/uxLb37wSZlsRtjhScXHZY8jTwmGoCKJ2dDhfnSdp2chZ8QUsqz5W1w+HdMcug559zTPpY4RFsNmE5KhgNQXb8tCxqhTZBLs60HCV5SF8jDP1O0om/8NzgMX/Bt4crcZoaxu/VTeVGoIBuz62/AnrtRjcuztmd7xXBdimimmvvjJOwse3nYqfHCeq68Uz7wZ+mAJodv0Aw1fX6CfNrt7LT+ynYkyPeLSPCXVlyO+33oQy1ZMbsJsjsHfi+0CHyoA2Mr495oWfpb/38rwSZAf0wOO3XoO5mj5H9r6wAdgfVpGJr3AwoCO2aKnqsryuM0stwe/ntlP0O6XrlQPf2k/CZ3Z92VTbBdiidcIlJfejCCEwVHRNn+sYhvWhI7HLkYwfHKOww1gZRH9lH6e6sgtzh6FYGTBEXTYWZ6hO55L5nhV7FY5UjOMuNUXCFlg16Dbm6B3ofSrJVmO45bmSOvZCUYD+eoXZ+tjzoorGc+p7UrYblkIvTdaIWoCRI0fiySefRFlZ5dCM0tJSPPXUU+o2Imq7U3y5L69tGrCabvcsW5fzM15bjPlbM1S7oNvGdcNXN5+gSs+lBP3BSXpyg6gt45RhVDcdR8B04zw1HndQv/NdU2s5Baf0QdEpz0Mry0d0txE4tdMwfPFqFi4t+QwmzaaC3S8S7sTxZUtxetEP+ASTsKLnPXiqewIuHNYRv/16GbBmHjK0aNxg+SfOPWkEflp1Ki50/KoyjIscA2E79Wlc+usuhKIcCXFx+E9uFp4xvYuzTMtUtvV26x1Is3TAjLD3MN6+WGVV7ZoRqcUH0RcHVbC+qf/9CMztgXP3PI23za8gzlCA8AFn4lD6+0ixH0LsrJtdf1NZ/ADYckKA0m0oNlcG3e4WBo7FB7kD0NGQgVGDByI/04ZnDvTGuKAV6FhUUZpsCgSKjqgx2oaKDuPzHUPwL/MH+Ml+An5yjMRnY7qgQ3Q//Gvq9XjZNB3FWhC0IVeiX0oUlo64A4dWr0FK0W5XJjdcyt+3/aKub405GQ8cvg7dEiPRLioEZVY7zrPeiXhbPnZpKehsOIKbzbNxR8kNmP19EMZ1eRRnaK8h2FGCjh16I35ADHb+9Sa6GfUAOLTLcep19545Df+d/V/0OeU25O8rwedr09DXuFeVh0cMPANvbeyBNGsHvGs/A+ONa/Fa4OsquJ5tPw6DjTuQEGbC6qI4bE06AwsLHfisaDy69xqAq6JD8PEy4JSyf2OoMQ3pWgzMHYdhQrdEnLLgFbUOt/YsACr6v2VE9cd1uUPQzpCNczr2xXeZ92HGjtPQLtiKzDKj+s78Z8LJODJrMZILF8IaGAUERwFuIwQiKt47X4oOb0e4HGhBLDolx2JtUCxQApTl6WPf89L3w31ik40r5mHo+Iv560EtzrRp0zBx4kR06NABgwYNUgcH161bh+DgYMyZU0vFBxH59RRf7strmwbM1+1Seu6eIR/ROQZr9uXB7tCQEhWMVy4ZrPrfiOP0QjoiYtBN9dJuoH7yIfwkvZzYmQ0+5eZX8NynQ1FmjkanPsPx8PGpMJtuxKa96bi0QwKuNVeWJY899Rw8vudlHDa2w+V9euOWsd3wYfCTuHNeNxTEDsCdF0/EdakxyLUEqCOp0y8fisU7svD0vGj8YdqAlKRE3DDkZDz63UbcUHwLhhtOhj2hN0KLD2C67SlkatGY0/Mp3H7xRTjfoeGdxYk4c06SOiAwp0dn2PNvwf6/XkeeFqrGaW9FV0wYfxvSFn8F7P4V6eHej9KO652AbemFaN9jMJ6+eATKbQ7c/tlaPLXtarwb+B8cCe6O/4t6CteZ5yEqfxsy8grxjO0K7NA6qPm0d2jt1UGHUd30cfQdTroWty8wqhLtl0/Us9VXThyNiza8gBctz6GTMQOXlz6IfwT8gnNMf+FN21l48fCl0GDESRUNSuS9l3HNBZq+wXzZdgmm2S6ApSLj/cfuYvyBG1RDuBUJkbh6VBjeWno6njR+iEwtEkP66VntM47rBxynN7cLjMrE1Ssrp4Gb3rMLdhcHYtqWeEzol4RftoRiftkQ2M2h6J0Shev2PwhUzNb1+ZlDEBhgxEd/JeCBib2REB6kNsgdYkLUum44kIcTu8cjo7Acry/YgfbRIejUswtK9waq5nK9hozBrMXp2GpJxe2xYXj8rL64/sNiLM0pVc//8KTeGN8nCQf3nQL8tRCR7bohx1p17FiS9YA+xl4OwXuRvW+rHnQbk9E+2AxLaLIKurV8PcNdlF112rb0TYsAZ9AtDeFkLP7Ai4AQXzOjEzWN/v37Iy0tDZ988gm2bt0KTdNw6aWX4oorrkBISAg/BqI2NMWXe3DsWeLt7T6+7ltTSfrKPXq2+6yB7fDseQMQFarvaxBRVQZNtsh+pKCgAFFRUcjPz1cNZKj1kq+mBLRd48NV0FYXh/JKVRAXGWzG0E4x+HXjETz45QqEhIRiwT9PRkxYoOu+W48UIKfIglHd9YD3zx1ZuPGjVYgPD8KMK4aif/sobD9SgGnfzMcVE0djVPfqXTeLym1YuScHo7vHw1wx5ru43IZzpy+FIXOrGn9cBr0s32nKyd2QWViOr1YdQM+kcPwwZbRq0CYkS/3IzL/RKS4Md53aw/WYj5ftxePf/40QlMMYGIa7x/dATuYhrMsxwxxgRO/kCNx0Ule17uLhmX/jt01H8MaVw3DVe8vVwYC4sEC8e81wLNuVoy6P6BLrOpL9wOfLMHjTi1jm6IsnHnnC9TzuNh3Kx4KtGbDYHLhzfA/syS5R5WU3n9QNd3+5Fgu2ZeKkngkY3ikGr8zVx8f/39l9ce2JdT/UPWfTERV0F5RZ8eq7H6plt117lZoDfuuRQjw0sTeMRgPySix4de52dEsMx9Uj9SnS1FRw0syt68n48/s3MWr7i1Weu/iOzQiL8zLeXZq4ff4w+mybgfkhEzH+wS8x/9OXMT7tGWwOOw5975+LdZ88gsE7pqMMgQiGBUVaCIx9z0bopKf16dL2LgFG3g5M0PsEENUXt118D4gamgTJUiYu23pvQbT7fax2h9qPqem+ss2XZmue+iRHYNZdY1RlDVFbU1DH2JPl5dRiyY937+T6HThJiQ5RJ6dzB6cg2DwSneNDqwTcwvO5Jfhe/sh4hAYGwCTtyWXKtORITL99ss/XCw8KwMm9qjYOCQsKwFtXDcM9X5owLipENVxbsTtH3feMge1wUo94FQQP7BCN0/rqHdGdJPMrpVmeLh3RER8s3Y2dmQa8fuFAnDUwRSZ587lez58/AP86tx8CTEZcPbIT/rd0D545r7/akHrbmF43ri8mb74JJ/SI8xpwCyk5l5NT98RwlbkWEoQfyivDP8Z0QY/ECPyxLQNnD0qpV8AtJvTTm7OlF5RhpaY/txxQkLJ5d9GhgXjq3KrjzBEQBPS/QF0MD6jo9A7gABLRARlI37URXaMTAZPbUfif7wX2LkVIRWbcGqWPJY/t0BtIAyJL9Qy3VqCX3m+KOx2dc5chzpEFbPkK2DkbsOh17IWb5yKCQTe1ANu3b8cff/yBjIwMOJyzHlR44onKqf2IyL/52ubX9z5OckDcmy1HCrFuf16dn4eoLWKmm6iVyC4qVyXYfdrV70CEw6GhsNyGqJCaS76yisrVgQEJ/FtClcMTP2xS1eBPndOv3kfPd+7ejaL3L8DO5Inokr8CQ8pXIid6AGLzNwGTXgKO+4c+hZlM7+ZmXv+XcOqFNyPr4A7EvzNMNcmzPXwYO1+fjAFFS7G450OwD74Gb37yKV4yv4NUQ3rV9f7nDhjCOQ8pNV+mW6YGu/XWWxEfH4/k5OQq/3fk8po1a1rsx8NsP1HLyH57I1V9N320Crkl3gNvaZom04cRtTUFzHQT+Ze48CB1qi8px64t4Ba+MtzNQYKDf53nkcmuh25duiDnwWXoH2LGXzNuBspXIjavYh722Q/CENcdR9bPhZ5XrxSR0lOdx7frouaeDzTYsG3ndgSX63PQB8W0x4g+7fBcwnGYnN4eUyM/xdaSSIwx/o3exv3YtWoOuo278hj+cqJj88wzz+DZZ5/Fgw8+yLeSiGpsgiZjuh/y0VncGZzLsDcZWib9dBw1DEitrTEbUVvH8nIi8kuxzuEEcd0BPWZWHewDYEfxx5ch1FD95y+xk17SDqMJ2QHJaGc7gMO7t2CgNVstjkhorw4I/N85/XDlu0W4qkBvHvh04Mfojf04tO43Bt3UrHJzc3HRRRfxUyCiOs3dLcO6PDPensG5k/ShkR42MmTNHefhJqpd3bpTERG1UmEplUfx77Xeij/tfRGGUkRqhcjWIvGbQZ+7WC53SE5y3bc0XJ+HPP/gdsRqenfW2CR9mXSb/+eEXuqyjP8fMFqf6zwld6Vq8kbUXCTg/u233/gBEFG95+72FZw7bU8vUv1aZO7tu8Z3VyfOw01UN8x0E5Ffaz9gFHb9noL9SMIZl92OLh0extzPHsMJGV9iXdebkRveE/YNy7AloA9GV3SgF6bYzkDenwg4shaBBrtaFp+sB93ilpO6IdBkRFJkMIb0DIHjz9vRzXAI89asxKmjT2yWv5Woe/fuePzxx7Fs2TIMGDAAZnPVoSV33nkn3ySiNqguc3eLjQfza3weCdJl7DabphHVD4NuIvJribFxKLp9JfoGBSAhMlgtazdlGkrK/43xQWbkl1jxbGEghvWrKC2vENm+J7AL6G/fomqC8hCBaHNQlbHyN47p6rq+K/pEdM9bgtCVMwAG3dRM3n77bYSHh2PhwoXq5E6GRjDoJvJ/vqYBq23u7j93ZmHqvLQan5tjt4mODoNuIvJ7XRPCqy0LDdIzgFGhZjxx7XnVbo9O0edJ72E8qM5zTXGIruE1LCPvAmYvwfD8X2HPPwRTlEzrRtS0du/ezbecqA0H2ovTMvHd2kPVbnc2TZMx3J7dyy02B/7z2za8vXgXNA2q+Wp+afUu5Ry7TXT0GHQTEXlhiK3MYgtbaNX52D31HH4q1szujaHYisPzXkO7C17g+0pERI3OV+MzX03T3LPbOzKKcNcXa7HpUIG6ftlxqXj8rD7YdqTQa7aciI4Og24iIm9iOlW52nnYhJp/TE1GbEi+AEOPPAvsXsT3lJrMCy+8oMrGQ0NDa73v8uXLkZWVhTPPPLNJ1o2IGldNjc88SRDtDJw1TcOny/fhmV82o8zqQEyoGS9cMFAF5sIzOCeiY8Ogm4jIm8AwYPQ9QM4u4LibYe40qtb3KaH3SOAIEFeUBthtgIk/sdT4Nm/ejNTUVNW5/JxzzsHw4cORkJCgbrPZbOr2JUuW4JNPPsHhw4fx0Ucf8WMh8vOu5DWNx84uKseD327AvC0Z6vqYHvH490WDVGNQImoc3CMkIvLl1P+r13uT3LkvirRghBvKgOwdQGLV5mxEjUGC6A0bNmD69Om44oorkJ+fD5PJhKCgIJSUlKj7DBkyBDfddBOuueYatZyIWuaY7PqWcde1sZlzPPYf2zLwz683IKuoXM3A8cDEXrj+xC6qOSgRNR4G3UREDaRbYgS2aKkYYdiOsgPrEMygm5rIwIED8dZbb+HNN99UAfiePXtQWlqK+Ph4DB48WJ0TUesYk+1selYX3rqSi5N7JWBi/2TXeOw+7SLxfz9uwgd/7lG390gMx7RLh6BvSmQD/zVE5E3lpLQtyOTJkxETE4MLL7ywuVeFiKjOokMDscukN2Ar3LOG7xw1OZkWbNCgQTj33HNx6aWX4tRTT2XATdSCs9uvzt1WLWCW63JbXTnHYbtbsC0TPZMi1JzaIYEmnPv6UlfAfc3ITvjpjtEMuInaeqZbGsJcf/31+PDDD5t7VYiI6iUnohdQ8Cu0wxt83+n724DsncC1PwMmfeoyIiJqO2rrOO7e9Oxox3XvzCzC2n15eOHXrWpasPjwQLx84SCc3Lvm2TiIqI0E3SeffDL++OOP5l4NIqJ6syYMAAqA8Nwt0h5WUo9V72C3Aus+k96xFeO+61ZCSERErZ9ksGVcdW0dx51jtesy1tvXuO5nf9mC3BJ9vu1TeifipQsHIj6cPR2IWkV5+aJFi3D22WcjJSVFlbF9//331e4zY8YMdOnSBcHBwRg2bBgWL17cUOtLRNSihbbvB5tmRKgtDyg4VP0OhUf0gFv+LUpv+hUkIqJmy25PnvEnps3fUaemZ8773/vVenUu130ZlhpdbZkz4BY9EsMYcBO1pqC7uLhYjRd7/fXXvd7+5Zdf4u6778ajjz6KtWvXYsyYMZg0aRL27dvnuo8E4v379692OnTIyw4qEVEr0ik5DmlaB/3Kvr+q3e7IP+i6nJV+4Jhfb/3+PGw+VHDMz0NERM07n/Zd47vju9tG4cFJfbze39tY73u+XKsC8tX78mp87rcW7a7XOHEiaubycgmg5eTLK6+8ghtuuAE33nijuj516lTMmTMHb7zxBp5//nm1bPXq1Wgo5eXl6uRUUMCdTyJqPt0SwjDHMQh9jPugbZ0Fw4CqDSFLsvYhvOJyaY5kvY9eicWGS99ehsAAI9Y8fhpMnPKFiKjVzqddbnO4Ssh93d99rLcE3N+trXvCqj7jxImoBY/ptlgsKqB+6KGHqiw//fTT8eeff6IxSCD/1FNPNcpzExHVV8fYUPyuDcet+Ala2m8w2CxAQKDr9tLsA66g21ZwbEF3VqEFpVa7OhVbbIgMZlO2tuj888+v831nzpzZqOtCREc/n7ZksqUTuQTGvu7vPta7PgF3XdeBiFrBlGFZWVmw2+1ISkqqslyuHzlS953LCRMm4KKLLsKsWbPQoUMHrFy50ud9H374YeTn57tO+/fvP6a/gYjoWMicqLkxA5GpRcFoKQT2VO1pYc2tLCl3FGUc02vllZTj+YB38FjAxygqsx3Tc1HrFRUV5TpFRkZi/vz5WLVqlet2ORguy+R2ImoeEkhPHpJS6/2cGW5v93eO9Xa/n68y9ZoeS0R+0r1cGqy50zSt2rKaSDl6XQUFBakTEVFL0b9DDOZuHIrLAxYA22YB3ce7btMKKsd0m0oyj+l1SrIP4DJ5DQBpxYVAdMgxPR+1Tu+//77r8oMPPoiLL74Yb775Jkwmk1omB8Nvu+02FZATUfMZ0yOh1uy0TPM1c80BLE7LrHZfvQWn7lBeqdfHnz8kBfec1ktdvnpk51o7nxNRKwy64+Pj1UbeM6udkZFRLftNROSvBneMxtwNw3E5FgBpv1W5zVRU+fsYWJZ1TK9jyavcISspyAXac+7Vtu5///sflixZ4gq4hVy+9957MWrUKLz88svNun5EbVldyrunL9hZY/n5SSpwP4ivVx/wGnC/cskQ13UJtBlsE/lheXlgYKDqTD537twqy+W6bOyJiNqCwakxWO7oA5v8xObtA3L3um4LKa2cJizUknNMr2MvOOy6XF7ErrQE2Gw2bNlSfVohWeZwOPgWETUjCYBvGdvVY1n1qb5qcscXa1XALQWkU07uhq9vPgGvXDxIdT13D7iJqJVnuouKirBjR+X8grt378a6desQGxuL1NRUdTT9qquuwvDhwzFy5Ei8/fbbarqwW265paHXnYioRerTLgI2Uyg2OLpiqHEHsHcpENMJcDgQbqkcxx1hz1PLYKzl+KemAVlpQEznKk3Z4NaIzVbMoJuA6667Dtdff73aTp9wwgnqLVm2bBleeOEFdRsRNa+HJvVRzdKk7NtbCXltsossaB8dogLt47vGqWUjujTSyhJR8wXd0pzl5JNPdl2XIFtcc801+OCDD3DJJZcgOzsbTz/9NA4fPqzm35aGaJ06dUJjmj59ujrJ2DUiouYUFGBC35RILDvcVw+6dy8GBl8u84XBBDscmgFGg4YA2ICyPCA0tuYnlGZsH54NDL0GOOc112Kj25hwa0l+Y/5J1Er8+9//RnJyMl599VW1DRbt2rXDAw88gPvuu6+5V4+ozZOu4xJwW+2Oegfc4uxBKXjmvP6ICuFsFUR+HXSPGzdONUariTRskVNTmjJlijrJPN3s0EpELWFc918H++I2/AjsWaIvrGiilokoBGsWRBlKAOlgXlvQfXC1fp65tcriwNLKrLm9JK+h/wRqhYxGowqw5STbQ8EGakQtwwuzt6hx2XU1vFM0NhwogMXuQIjZhOfO74/zBrevV3NiIvLDMd1ERFQ5Tm+1oydsMAH5FeO6C/SsxmEtFpmaPo7Ptu1XYPlbgMzn7UtexVSIpVUD65DyykZsmsdt1LbHdc+bNw+ff/65a+f80KFDangYETV+Jlu6j8u55/K6BNwyTvvZ8/rjpB7xWLU3TwXcwzrF4Ld7TsLkIR0YcBO1Uo0yZRgRUVvXLyUSJQjG31o3DDFsB5a/CUdMF3Wk84gWh2hDEbrjEALmP6k/QMZ9n/wYUJQOdB4tcy9WPpk0YxOlVXfiwq1u3c/L9awmtW179+7FxIkTVS+V8vJynHbaaYiIiMBLL72EsrIyNZUYETVNJluapskY7trm1XaXEhWCGX/sxMG8UpiMBtw1vgduG9cNASZjtRJ1TgVG1How6CYiagSd4sJgNhnwtnUS3gjcDiybAUNghCvTbQwwV510dfMP+klc+D+g/wWVt+U7M925elO1ioA8ylbZ/dzIoJsA3HXXXaqR6fr16xEXpzdZEpMnT8aNN97I94iokXjLZMt1aZomXctlDHddPPbDRvUznxobiqmXDsZQj/m1awrsiajlYnk5EVEjMJuM6JYQjtmO47Gr/11qmcFSiDRHe/wYMAFlgZUBETqeABjdmuLsW155Wfa+nOXlDqt0TKu47ECMVpn5DrAy001Qc3Q/9thjagpPd9LM9OBBvacAETU8X5ls5/JDeaV1eh75yb9wWAfMumtMtYDbV2DvWcpORC0PM91ERI2kR1IEth4pxG/xV+OWs7pgR1YZJv2Rgk4JUQjRFgLlFXc8exoQGgds+g6YfT+Q6TbPsmS3rcVVrweGAaU5CEDlbA1mC4NukmMxDq+zeBw4cECVmRNR45BS7/os98ZkAKZdNgRnDUypd2Av2XQiarn8JtMt04X17dsXI0aMaO5VISJSeiaGq/PtGUXA8OuwKfkc2BCAhIggZEb2VbdZEYBrfylAYUA00GGY/sCMrdXHcztVNEwrz9Ong3IKtLNJFkGN4Z46darrrZBGatJA7cknn8QZZ5zBt4iokUjQK6Xe7m4d29UVDI/rlVjrc9g1qDm4GzOwJ6Lm4TeZbk4ZRkQtMdMttqcXqvOsIr1DeXx4EPZGnYUH92ZhgX0wMrZl4teNR3DRgF76A4szgJIcfSox53hup4pmaiXZBxHktjjIxqCbgFdeeQWnnHKKOggtjdMuv/xypKWlIT4+XnUzJ6LGI+O3gwKMriDbM/t8Su8E/L41s8bnqClr7Qzs3UvM3QN7Imq5/CboJiJqaXom6ZnuHRlFagqZ6Qt2qOvtooIREWLGW/aTXfddtisHFw3vCESl6lOMyZzcnUZ5yXTrQXdZrj79WLkWgCCDDaEOBt0EtG/fHuvWrcMXX3yB1atXq3LzG264AVdccQVCQnxn0Ijo2Hg2OCu3OVxB9OK0THy3Vv/Nrk1tWWtpmibBPbuXE7UuDLqJiBqxg3lggBFlVgfu/Wq9WtYrKQLXj+6CtHQ9SI4IDkBhmQ3LdmWr7ralkd0QKUF3xpaKoNsj012ml5db8/QduN1aO/Q27EeoVvt0NAu2ZcBoMGBsz4SG/2Op2VmtVvTq1Qs///wzrrvuOnVqajNmzMDLL7+Mw4cPo1+/fqrUfcyYMU2+HkRNyVeDs5rm5e7fPhJd4kLx04Yj9c5ay32Y3SZqXRh0ExE1EpljNTI4wFVWfsvYbrjv9J6qs3lyZDBm3TkGKdHBGP7MPDUn62VvL8OpB8NwSwBgO7JF/UDbc/fB5CXTrRXqO2oHAjqit2M/wrViaJqmxvB6U2qx4+aPVsNoBP7+vwlqHci/mM1mNTe3r+9AY/vyyy9x9913q8D7xBNPxFtvvYVJkyZh8+bNSE1NbZZ1Impo3ubIrusc3O42HixQp8lDUjCmRwLn3Cbyc9zrIiJqROcMaq/Obz+5Ox6c2MsV7Epg1DclEtGhgRjQIUotW7U3Fzs0/f7bN65U56WZe9T5HkeSOrcV63NzG0r0cYF5IZ3UeZihXAVcvhSWW2GxO1TW3Vn2SP7njjvuwIsvvgibzdYs48mllF3mA+/Tp4/Kcnfs2BFvvPFGk68LUWOVkE+e8aeqXJJzuX6sjcyk7Nw9gCci/8RMNxFRI3rkjN647sTO6Bgb6vM+J3SNw9p9etl4RMcBwBEgoWwXcovKEVKwVy3fpHVCZ6SjtCAb0p7N6OxiHpEKVCRZigtyEByc4jPTfYPpF9hhgs1+WsP/odQiLF++HPPnz8dvv/2GAQMGICysajAwc+bMRnldi8WixpA/9NBDVZaffvrp+PPPPxvlNYlaQgm5jK/21uCsPjjlF5H/85tMN6cMI6KWKMBkrDHgFqO6xanziKAA3H7xmbDBhARDAbLWz0KwvQhlmhlrHD3UfaxF2frzWvQyc4TFo1gLVhdLCyuWeVFenI/HzZ/i8YCPYS0va6g/j1qY6OhoXHDBBZgwYQJSUlIQFRVV5dRYsrKy1PzgSUl6RYaTXD9ypHLMqjupzCgoKKhyImqpapojuy7G9YzHXeO7e72NU34R+T+/yXRzyjAiaq1Gd4/H/53dF31TohAXG4u0wF7oYdmMyJX6fMvrtO5AeCJQDjiK9cA6yKoHKMbQWBQbQhGGMpQV6qXn3pSX6Pc3GTTYLBJ0RzbJ30ZN6/3332/Wt9xzPHlNfQaef/55PPXUU020ZkTHpqY5sr1lwT2dM7g9zh/aQQ3v4ZRfRG2P3wTdREStlQQl157YxXX9SMxw9EjfjKS8der65oC+iI1LAg5Vdi8PtulBtDk8HsXGcMCRA0tFQO6NtbRySjG71ffYb/IPGRkZ2LZtm/pu9ezZE4mJiY36ejIPuMlkqpbVlvXwzH47Pfzww7j33ntd1yXTLWPAiVqimubI/ma1xywTXsjsFDJ1pJSjc8ovoraHQTcRUQtT3mEkkP6R63p+/DCER+gl6AGWPImaEeLQSxrDouNRqoJuabKmB+S1Bd02G4NufyWBq1R+yTzdUu4tJBi+5JJL1DCsxioxDwwMxLBhwzB37lxMnjzZtVyun3vuuV4fExQUpE5EjdFRvDF4myM7o6AMnyzbV+PjBneMwoPf/u26LsG7PBcRtR0MuomIWpjw7ifCusoEs8EOu2aAuctIhGl5lWXlZfmu+0bGxKM8IBywAbaSGoLu8spxh3artZH/Amou0jl83bp1aq7ukSNHqky3NDK766678I9//ANfffVVo722ZK2vuuoqDB8+XL3222+/jX379uGWW25ptNckkg7i7tnnYwloJXj/Y1uGujyuV6IrgPcM6p3Lf9t0BPd9vR6FZTYYDYBDq3yu84ekYHSPBJXhdg+4PRuwEVHbwKCbiKiF6dI+CRu0rhhmSMNWLRU9U1NQnm9Wt6kMd7E+XViBFoq4yFDkB0g/c8BRWhmMe7KVl7gus7zcf/3yyy+YM2cORo8e7VomTdXeeecdTJw4sVFfW7Lp2dnZePrpp3H48GH0798fs2bNQqdO+rR2RE3dUfxYgvdp83eoAN75nE4yr/azkwfgXz9vwecrKjPcEnB7m3NbSsq9YcdyoraFQTcRUQuTGBGErwxDMAxpWOwYgHPaR2FnQGUKxZ61EyYAuVo44sKCkG3Wg273DLgnh3um22Zp3D+Amk1cXJzXEnJZFhPT+Fm12267TZ2ImrujeH2C7i9X7vPaCM3bMplXe+7mdBSV273edvXIzlVeu6YGbETUdvjNlGFERP5CSoL/iL8ct1vuwEeBl6JdVDASo8JRoIWo20vTd6jzPIQjNiwQjkC9E7mx3HfQbXfLdDusDLr91WOPPabKvCXT7CTNze6//348/vjjzbpuRA2tIQJayXB7ln/XRgLusCA59Fn7gQBnAzZ3zgZsRNR2MNNNRNQCdUqMwcyDI3FShwQVhCdFBiFfC0ekoRRlGTsQDqDEGAGT0QBHkJ7pNlgKfT6fZnErL2cjNb/1xhtvYMeOHaqkOzU1VS2TcdXSsCwzMxNvvfWW675r1qxpxjUlatyO4nVprlaXqb58ueL4VLy9aHe15Xuzi9Xzur+mtwZsRNS2+E3QLV1Z5eTs1kpE1JqN7ZWAmWsP4rQ++lRPUSFmHDCEoyMyYc9IU8vKzBVzbQdJCA6YrN5LLRVL5W0OGxup+avzzjuvuVeBqEl5C2jr2lzNV3l6XUzq3w5Gg6Fa0C5jwZ3jwd1f070BGxG1PX4TdMsUKXKS6VIaa0oUIqKmcs6gFBzfJU5luIVku7NMSYBjN6LyNqplFnO0OjcG68G32VbDDqS11HXRwUy333ryySfrdL/PP/8cxcXFCAvjuFJq/dwD2vo0V1ucpjelrC9nNl1O8rzS8VwC7bq8JhG1TX4TdBMR+RMJspOjgqssywvpCBQvQ7Bdn3PbEewRdNtrCLpt7kE3M91t3c0334zjjz8eXbtWHWtK1Np4lpHXtbmaPE4an3ka1zMef2zPqrb8ucn9EWw2VSsPr89rElHbxaCbiKiVsMd0Bdz27Qyhseo8IFgf0x1UQ9BttFWO6dbYvbzN0zS3CYWJWilvZeTpBWV1aq7mK1AOMptgkN9Jj8z25cf7nvqOHcqJqDYMuomIWongpJ6A25SvplA9g2IO1YfUBDsqs9mejG6Zbs3O7uVE1Lr5KiP35vwhKdUyzr4C5Tmb0tX5mB7xmNgvGX1TImvNVtfU0I2ISDDoJiJqJeI79QVWV143RySo88Awvbw8RKvMZnsy2SqzP5ynm4haOxlHXVdSFu7ZUdxboCwiggLwr/P647wh7eu1PuxQTkQ1YdBNRNRKdOnUBUVaMMINegAdHBWnzoMqMt2hKAWkbNggxZFVBdjdsuB2jukmIv8pK6/NZyv2q5NnR/Fbx3XHxoMFWLJDH8M9vFMMXr1kMDrGhh7VerFDORH5YvR5CxERtSgJkcE4YEh2XQ+PjlfnIRF69sYooxDdpgZzF+CozHRzTDcRtVY1za0tJd0SWPsij5PHi+W7snHqf/5QAbfRANx7Wk98cdMJRx1wExHVhJluIqJW1NE8J7gjULZHXY+MSVLnIaHhsGsGmAwa7GWFMFXM2+3O7B50M9Pd5nXq1Alms7nNvw/U+vhqgHbX+O6457Re6rJM1fX1Kj277Wn+lnTM25KO6Qt2upY5NKDEYkOAibkoImoc/HUhImpFyiM7uy7HxOljusOCzShGiLpcWqRncTwFuQXdYCM1v3Xttddi0aJFtd5v48aN6NixY5OsE1FD8tUAbVyvxCrXEyKCvN7v9QU7qwTc3rLgREQNzW8y3dOnT1cnu93e3KtCRNRozAndgQygQAtFRIg+j3dQgBG5CEYkSlBeXIDqeW4gUCuHmgdHMNPttwoLC3H66aergPq6667DNddcg/bt69cQiqg12p5eqLLgi9Myvc6/XRecV5uIGovfZLqnTJmCzZs3Y+XKlc29KkREjSay0yB1nm2MU+XmQs6LDfo4xPLiPK9zMgehvHIBM91+69tvv8XBgwdx++234+uvv0bnzp0xadIkfPPNN7Ba2UCP/Le8/MFv/8a9X60/6oC7piw6EdGx8pugm4ioLeg/bCxmd30EGSf/p8ryMoNeXm4pKaz2GIvdgRC4l5fbGn9FqdnExcXhrrvuwtq1a7FixQp0794dV111FVJSUnDPPfcgLS2Nnw61Wg0VGPdIrPo8nFebiBqT35SXExG1BUaTEZOufrDa8jJjGGAHbCX51W+zSNBtqVzgcLtMfuvw4cP47bff1MlkMuGMM87Apk2b0LdvX7z00ksqACdqTWTMtWS6Jw9JqVdGO8RsQqm16vDDtIxivHjBAJhNRhXIu8/hTUTU0Bh0ExH5AYspVAXd9rKCareVWmxIcCsvN3BMt9+SEvIff/wR77//vgq2Bw4cqILrK664AhEREeo+X3zxBW699VYG3dTigumagl/Pubkl8B7TIwFWu0OVlvvSt10Erh7ZGQ/NrH4fCbjPH9qhgf4KIiLfGHQTEfkBi0kvlbSXVi8vLy0tVtOJORkcHNvrr9q1aweHw4HLLrtMlZYPHjy42n0mTJiA6OjoZlk/otqCaZln+6FJfWqdm1sy3RJMS5AuAbvn7WFBJtx5Sg/cPLabz67kHMNNRE2FQTcRkR+wm8OAUkArrx50l5dWbTzEoNt/vfrqq7jooosQHKx3tvcmJiYGu3fvbtL1IvLGWzAt101GA3KLLRjUMRqXjEj12TzN2W38xjFdsXJPLlbv1YPrXskReGBCL4zvk6Suy30kmHd/LY7hJqKmxKCbiMgP2AIqJgrzGnQXVV3gYCM1fyUN04haC1/BtHMe7c9W7MfnK/bhybP7+cxUL9iWgfu/Xo+sIgtMBgPsmoZtRwpxw4erqmTN5XxCv+Ray9iJiBoDg24iIj/gCNSDboOlqPo437Kqy4wsLyeiFkDGY9dm3f58TJ23vdryf4zujO/XHsSHf+1V11NjQ7Evp6TKfSSzLYG2M8CWcwbbRNQcOGUYEZEf0AL1Jlkma/VMt9WjvNzI7uVE1ALGctfUAM3dwu1Z1Zb9uindFXBfd2JnTDm5W72y6URETYlBNxGRHzAE6Zluk7X6Dqat3HNMN8vLiahljeUWFwxtX+fn2J9bivjwIHxw3QhVft4zST/w6InN0oioJWDQTUTkBwzBkercbKtaXinsZR6Zbo3dy4moeYLtmWsO4I9tGV5vP7F7PAZ3jKqyrGeiPjODpxGdYzDn7jEY1yuxSrM0d2yWRkQtBcd0ExH5AVOwnuUx26uP6bZbPMvLmekmouadGsxXVvr7KaPx5cp9WL8/z9W9/OaPV2HOpnTX/U7qEY+7T+2BhdszqzRFY7M0Imqp/Cbonj59ujrZ7fbmXhUioiYXEKpnuoMcHpnu/SsQlq93AnYyMdNNRC2gnNxXVloCbTmVWGx4eOYGV8DdPjoED03qhU2HCnD+G3+5HuvepZzN0oioJfKboHvKlCnqVFBQgKioqqVJRET+LiBED7qD3YPurB3A/ybgBM3RtjLdDgdQXgCERDf3mhBRDc3M7hrfHZ3iwrxO4bXhQB7u/mIddmUVw2AAbjqpK+47TQLufNzx+boau5QTEbU0fhN0ExG1ZUFheoAZopUCmga1l3p4HeAWcJciCCEoh0mrQ9AtzyHkeVqI4nIb/vHRKkzsn4yrR3b2fceZNwJbfgJuXwXEdGrKVSSiejQzk/HYzkBZsuESnMvUXyv25OCV37bD5tCQHBmMVy4ehFHd42sM4GU5g24iaqkYdBMR+YGgivJyIzRAxnBLN/OsqnPblhjDEeKQoNtae8D90bl6wH7NTy0m8N6Qtgv/2n8t/swaB4x80/cdD6yUgexA5lYG3URNzBk8u2evnU3O3EvM3cvJfY33ntQ/Gc+fPwDRoYG1BvDsUk5ELRmDbiIiPxASFgG7ZoDJIEF3kdegu9wUBjiyYdJq6X1RmgvsXqhfLskBwuLQEgRnbEA342GYrEtqvqOssyivPmc5ETUez+DZfay1ryZnvsZ7335yN9x3ei8YPA761RbAExG1RAy6iYj8QFiwGUUIQRRK9KA5IhnISqtyn6CQMMAKmOQfTzYL8PU1QPthQP8LKpeXtpyg22EtV+c1lsfbyvWDDsJ5TkSNzlvw7DnW2luTsy2HC7w+X9eE8GoBtxO7lBNRa8N5uomI/EBYoAm7tWR12XZks95MLHtHlfvEFOldzAO8Ba0HVgDbZgF/TdebkDlJAN9COGxl6jygpvJ4Z5ZbeEyVRkSNp6ax1r6s3puLafOrHhysa7m4BO/nD+3ADDcRtQoMuomI/EBoYAA2O/TmYraD6/HbX6sAWxmsCMAaR3e1PLfbub4zxc6seFkeHMWVgba9OBsthcOmB9sBqCHTXeK2vuXMdBM1lfqMtbbZHZg6bzsufusvpBeUIzyoauEly8WJyN+wvJyIyA8EBhix1dBFv3JkAxb8HY3TAexyJOMay0P48Rwj7GFJiEv72nvQ6syKaw6UZO1FeMXi/NxMxKJl0CrKy801lZdLObyThWO6iZqycVpdxlrvyy7B3V+uxZp9eer6eYNT8PR5/bEzo6jaeG8iIn/BoJuIyE/sNXcDHIApYyNCCjoAZmCnloLYuHh0HjkOe7bpc9sGwEsjNbfx35as3a7Lxc0YdJda7LA6HIgMNusL7OX1y3T7Ki/P2Q2U5QMpgxt0fYnaGm+N0767bVSV4NkZlHeOC8XurBI8+eMmFJXbEBEUgH+d1x/nDWnvc7w3EZG/YNBNROQnLPF9YE83wFyaiROMm9Wy/gOH4+NTjlcNiUwB+rQ7Zm+N1LIrg25H7l7X5bLCLDSXc6cvQXaRBUsfOgXBZhM0aZKm1t8GTdO8N1lyH9Ptq7z84/OA/IPAP7cDoS0lj0/kH43TggKMrvm3fU0FNqJzDF65eDA6xoY24RoTETUfBt1ERH6iU1I8dh1JQQ/DQYw1rlfLUnsOAuL0HdsAc5B+7lmeLZ3L3QJtU37lZWth84zptjs0bE/Xg+bMwnK1c+4MuoMMNlhsDgSaTTUG3ZqlEF57H0vA7bAChUcYdBMdJV8N0qbN36FOk4ek4Lu1h6rdfvlxqSrDbTJ670xOROSP2EiNiMhPdE8MxyatkyswLTJGAN1Pdd1uMuuZ7kCDHdC0ygfm7gbc5u4OKjrguqyVNE/3cgmqU5CFroZDKLVWrJvd4rrdWjG+u6by8qLC/Oq3S1d3CbjVi7DRGtHRqq27uLeAWwzvHMOAm4jaHAbdRER+okdSBDZVdDAXs7o8BoTFu66bKjLdQrO7lZh7zOcdUpbhumwsO/ag+6+d2UhLr19TszKrHd8G/R9+DnwUZUV68GxwC7ot5fr0YTU1UrOXenlNt+dg0E109KR8XMZwN3SwTkTkjxh0ExH5iR6J4ZjjGIGDWhym2c6HpcekKrcHmM2VFeVSUu5lPLcwoDILbrZ6yRbXgwTb3//vefxr2n/r9bjy8nK0M+Qg1FAOW8HhKo3UhM3iPdOtuU1xZrR6KX91e46sHLfx30SkxmnPXHNAndfFQ5P6qMZpd43XpyX05FlBzqnAiKit4phuIiI/0S4qGDmB7XFiuR7gfuaRUTIHBrsu2ywWmJ1XsyqmC/Mi2FZwTOuUtmouXjS/U3HtkTo/zlJWWfptL9GnFjLWobzcVpwtTdsVk7eg2+1gQ1nxsf1tRP7Es+mZjMl+9ZIhtT7O2XU8LaMQs/5Or3KbQwNevGAAzCYjpwIjojbNbzLd06dPR9++fTFixIjmXhUiomYh3bxlXLdTZ4+gO6BiTLewWcuqjukGsNPRrtpzRjgKVafwoxVyaJnrssPuqPPjrGXF1YJu9/Jyax0y3QG26kG3w+3vtpQw6Cby1YlcxmRf87/ldXqDFqdlYkma96aLEnCfP7QDpwMjojbNb4LuKVOmYPPmzVi5cmVzrwoRUbOWmAuZtic5sjKzLcwmE6ya3vHbZrVWaz4mc3p7ijIUI6/Ix/jpOggu2OO6XO5rHLYXttLKgNlRqgfHBmcDNDU02/tzGcsqS8bN9pKqDeNUsF75OJu3Md9EbZCvTuQLt2fhni/X+nxcuc2OZ37ejKveW4GCMo9ZESpwDDcRkR8F3UREJM3Uwl07ukaPAZVy3VoxqsjulvF1VHQo36Mle30LM7MqG6vVV0xp5fRj5SV1D3Kt7nNsl+njyo2Oyky33Vt5uc2CAGvl44xwALYyn0G33a2Enagtqykwloy3tzHe29MLce7rS/HuEr1S5soTUnHD6MpGjoJjuImIdBzTTUTkR8b2TMTUeWk4vW+S19ttcGa6KwJYTYNWqu9Q79MSvT4mJzsd6KJPRVYfmsOOjtY90plNKVfl3N7Xy5O9vKTySnlBtTHdtoo5u6uo+DscmgFGQ0WGW4J3c4jXsnQHpwwjUmRMtq95tZ2ZcLmP+n+tafh42V48+8sWlNsciA0LxEsXDMSpFb85Zw1MUfeXQN75GCKito5BNxGRH+mVHIENT56OAJP3QqbKTHdFAGsthakig7xXqxoQ5xhiEKvloiDn6DLdWfu2IsHgNoa6tO6ZZXt5ZbmrsdxLptvi1n3do0w+F+EI1iwIM5QDFsmuJ1Q+zn0su3s2nY7Js88+i19++QXr1q1DYGAg8vL0cfjUekjTtD1ZxVi7P99nJjyzsBwPfLMeC7Zlqusn9UzAvy8aiMSI4GqN1YiIqBLLy4mI/IyvgFvYDHrQ7XBmiiuywzLWOzyxsjS0XDOjOEgPVovz9B3s+srZsaLKdWs9xlA7LJWZbpMKnAGT5jam21um2xl0axEoRojXwNrmVl5u8NbdnI6KxWLBRRddhFtvvZXvYCvuXu4t4HaWiP++NR0Tpy5SAXdggBFPnt0XH1w7okrATURE3jHTTUTUhtgqfvZdjdQqgu58hCG1fXugIkFZiFBowdFAGZCffXSZbsuBdVVfu7zwqDLdAVa9vNzk1kjNvQu5S2mOK9Nt1BxIlLJ2S9XA2r0BG4PuhvPUU0+p8w8++KABn5Was3u5kOm+zh3cHk/8sBEf/aX3Z+idHIFplw5RVTVERFQ3DLqJiNoQlenWKjPd0kRN8uL5Whi6d+oAbNLvV2wMQ1RMogrC9x86iIzCsnpntIKyt1a5bnfrSF4bzS3Tba5ojmbS3BupeSkvrziAkKeFI8RQcbvHuG33qdICrG7jxqnJlZeXq5NTQQGncGsuf2zzfmBt/f48vLt4N9Iy9P9H15/YBQ9M7IVgs94bgoiI6obl5UREbYi9opGa3aZnjYvz9dLxPIRjQGo8irUgdb3UGI7oOL2xWoRWiM+X76/3a5nKq47rtdcj0w23gDjQpj8uwD3TbfMSdFcE6iUIRjEqDhB4vKbDret5gJ3l5c3p+eefR1RUlOvUsWPHZl0ff81gz1xzwGv38br4cuV+FXAnRAThw+uPwxNn92XATUR0FBh0ExG1IXaDuUrwWZyXpZ8bI5AaG6qCb2EJiABC9GZIHQ0Z+GT5Xlhsjrq9SMXc2EF2PTtWpOkBsMO9I3ltrKWui87ncR/T7S3o1ioC9VItEEWaPqZb88h0uwfdgfbK16Dq/u///g8Gg6HG06pVq476rXv44YeRn5/vOu3fX/8DO1TzGO3JM/7EvV+tV+dy3ZdxvbzPXGDXgFP7JOHXu8ZgbM/KhoRERFQ/LC8nImpDnI3UtIqgtaxAD7rLzVEIDQzAAYME3dmwmiOApP7qtgtMS1BWGoQth4ZhkGdX4sIjwOoPgfBEYPh1wA+3A7sWArcsRohDzyRnIBbhOAStPt3C3YLukIqg2+wWdGteGqlZyoohefpSBKFEXZLkd2HFJS9Bt6PyNWQaJAkiqdLtt9+OSy+9tMa3pHPnqvMy10dQUJA6UdOM0ZbrE/ole+0sLstuGdu1ymMCjAY8dW4/XH5cKv9vEBEdIwbdRERtiL0i6LZXzHltKdI7ftsCI9V5uWS4bYAjKALoex5wyk7Yf38OVwTMx8oDa4DU8ZVPtvlH4NsbpDuZfr3jccDaj/XLexYjTNOD7hxTHLo6DkGrR7dwg1vQHVrxPCa4B936a+7PKcF7S3bjhtFdEFlcpAJsmykYJRXTi1lL8j2C7sox3cGa/hr5JVZMnLZIZfT+dZ5+oIGA+Ph4daLWR+bJ9rXcW9BdXG5DXknl/6+uCWF4+6rh6J6oV74QEdGxYXk5EVEbLC/XKsZ0O0r0cdeOYH1H3BYUpd9Rzo1G4KT7sT1ID0QdmWmVTyTB6+wH9YDbWHH8dtHLbi9kRTD0wLfQXFGW6tFJvCZGW2UpeqhWAjgcXjPdnyzbiw/+3IPPVuxDecU84IbAUFhMoV6nKXNNlSbPi1JVCr/5cAEO55fh961H16WdgH379qk5uuXcbrery3IqKuJc6M3BOa92XZZLs7Sz/rsEX6zcDyn2uGVsN/x610kMuImIGhAz3UREbYjDWV7uzE5XdPw2VIzfjojvCBQD8cmprsfkBXcEyjcgIHdn5ROt+QgoPAREpAADLwaWTgU2fVf5Onn7XUd1y4ITgHLAWI9Mt9FtvLVR2q1bimCWFHwFza4H4OkFeua6sMwKa5n+/AFBYbBpNpWxt3kE3e5l6SZo0KylKLPZ1fUSS+XzU/088cQT+PDDD13XhwwZos4XLFiAcePG8e1sYt7KxZ3zbTvZHRreXLgTr87dDptDQ7uoYPzn4kEY1Y3VDUREDY1BNxFRGywvd5ZnOzuMB4TFqvPu5z8Ox4Y+6DL8GtdjisM7y0TeCC7U5+mFBK5LXtEvj7kXSOyrB91ubDl7ECiP1YJgCIlSjzc4O5I77Kr8HO2HA0Hey1dNNo95uMvyESiZ7oph1871z6koiS21OGCvaNQmQbcKpKVMvsx30K0eV1yAMove+K3YogffVH8yPzfn6G5ZHprUR43hlpJyyXC7B9wH80pxz5frsGK3Prf9mQPa4bnJAxAVqlfCEBFRw2LQTUTUhjiM5iqZ7kBrvjoPiojT7xDVAcYxd1d5jCWqM3AQiCipCLrTNwKFh/Xu5kOv1pcFhEhaufJ1cvao8yKEwhSol7SanEH3398A390EHHczcMZL+rLD64HNPwCj75GVgclePegOMlSWlzvHkZcV5uAC4yKg7EwYnCXpgSHQrA6gTLqXe2TXPbqeFxflo9Qahm6Gg8i0RcNqd8Bs4sgrarkN0rwF0b7IfTzv9+P6Q3j0u79RWGZDWKAJ/3dOP1w4rAObpRERNSIG3UREbbG8vGJMd3DFHNjBUb6nA9Jiu6rzuPID+nRg+Qf054rthuxSID48EIZOI4Gdv7seY8jbp86LDWFwBOrZbJOzZHz/cv284nmU724BMjYDRzYCV3yFAEfVoNtenFUxw3jF81eUl9+Z/zJGB67Cooy9MJr05zeYQ6FJml1YPOYGt3tkugvzYcrPxtzAB7Dc0QcllsmICmHQTS2PTPnlXi4u5eOSza5rMC5DMJ78YRNmrj2orvdMClfBtjRLY+d+IqLGxaCbiKgNZ7rDHHpQGhFdken2whzfreK+RWoMuC33gNp4zN5nwpRn5+G1y4bgnB4TqgTd5kJ9zuUSYxgMFZnuAGcmOnOrfu6WGVcBt0ibA5TkwOwxh3Z5XjpCq/wh+vqPdujzRI8qmovMsB7qsiEwBAa7Hjgbq2W6qwbdZcUFMBdmw2jQ0NV4SHVxjgphiS21ninA5mw64jMYd1q9Nwd3f7kO+3NKYTRIBjwaq/fm4blZW30+hoiIGg4P5xMRtSFaRdANu02Niw6HHghHxSb6fEx0VBQOafqYb2TvRM4hvaHaQU1vuPS9ZM5G3Ahc8B5KT/mXWmasyCiXqaBbD5fN9hI9U56xRX8ut+m7EOaWaV/xNswVmW6Hpg/iLstPr7pSNgtKyivLzY+Ykl0l6QZzGIwy5Zkqaffonu1sIFehvLQADov+HkSipM7N1GSasTIrx4BT804B9se2DK/BuATpwmZ3qEZpF735lwq4O8SE4Jnz+quA29djiIio4THoJiJqk0G3BcUF+hzdIjbOd9AdGxaIPY5k/UrOTjjy9LLwTKMedP+1MxvlmgFa/wvw+KLKqb6EJSAchopmaSqQLsoASvXmTXA2S5PGaiWV64JV/4NZ04P2bOjzh1vzj1R5XoPDgtyMyvL0dEM8AiqCblNQKLSKID7E4va8qiy9atBtLSmAVhF0hxgsKC71GEvuwxu/rsLwJ77H9AU76nR/osaYAqymIH1fdgkueusvTJufBocGTB7SHrPuGoNgs8nnY4iIqHEw6CYiaoPl5RJ052Xr81IXaKEICQ7y+Zg4Cbq1JP1hWTtgKtLHhMa064r48CCUWu1YvTcXaRlF2FNctTTbag6HKUgPGAIdJUDmlspscWHFeGsJuDVH5YOK0hFeUfaerunjU7WizCrPa3RYUX5gveu6wWF3ZcfV60W0U5dD7QUyWXfl/TzGdFtLi9S0YU7lRRXZvuIs4I8Xq447dzNi52vYGHQ9Tjrygc/3jaihSAm5J5kCbFwv7wfL9mQVY9K0RVi7Lw8RwQGYdulgvHrJYEQGm+s1hzcRETUMBt1ERG2IZqxo5eGwoTA3S10sMuql2L7IGOe90DPd1owdCCk5rC4bojvgpB56tnvR9izM2XgEeag6BZjdHIGAYP35AyUodpaWy/zfBQX6Bcl+i9A4oOKgQKRWNehGib6u7o3UtCN/u66HaCWuoDsgOAyB4TEo0yoOABRWBixGj0y3vaywStBtLaoou13xNvDHc8BfM7y+J4Elerl7VJwe3BM15XhucXq/ZNd83O66JYThtd93qCnwjusci9l3jcG5g9u7bvf2GM85vImIqGGxkRoRURuimSoz3UV5eva41FRz0G00GpARmAo4AMORdQi36iXbgbGdcFJiguqGvHB7JmSmrXytarbMERgBU4geiAdrZSja/7crLA8zVozJLq4IusOTJE0NFB5yPT5Di1bnplKPoNthhTlrc5WgOxB6FjsgKBThwWYc0WLR2ZCuT28W28X1OLVemkE1T3OUS6a78nmtpXlwODTs274BnaWa/shuVIxmrzKeO9qerQ5bx6d0qvG9IzpWvsq+ZbkEys75uOduTseXK/djZ2YxAowG3HNaT9wythtM0jmtHnN4ExFRw/OboHv69OnqZLezsQ0RkU8GPeg2OGzISdc7jNuCPcPK6vaH9pdJtxGUv1tdlyxyVFwyRveIV92QtxzWs9ZBqBp0a0FRCKhoamaGDVl71riC7mBYqma6wxMBOSjgFnTnGPV1CyyrOjbbqFkRkafPBS6itEIYDXqJemBIOMyBAUhHDDqjIuh2Pq6i63k+whAjf1B5EQz2yk2hrSQPl72zDA8eTENnI5Cbebha0J2WUYhUg54RD43tUOt7R3QsaisHt9gc+G1zOt5cuFP1KewcF4qplw7B4I76Aav6zOFNRESNw2/Ky6dMmYLNmzdj5cqVzb0qREQtljVQD4CDrPkozdSDVkN0aq2PM0YkYLujskT1kBaH5KgQNab7ybP7ubJp5QisLOsWIVEICq0sOY8vTnNdNmseQXdYon5yU2iO99oQLdhehKjiva7rMYbKLuWBwaGIDDFXlqYXuAXdFfN756Miu28phtGtvDw3OwvLd+egg0HPrAdbqnd0Tjuch3jk61cqxo4TNZaaysF3Zhbhgjf+xBt/6AH3JcM74pc7x9QacBMRUdPym0w3ERHVrjBYD5wjyw7BWKpPjxWRpJde10Saqa1w9EZP40FX0J0UqTdfu2ZUZwzoEIV3F+9Snc7z1oYjGXqwagqOQlBwMCyaCYEGu8p2OwVJplsihYry8jXZZgyMj3dtmKQEvCw4ASiuGA/uJsF2GEZUr2yS1wkOCkZyVDA2VExzphUehrPA1lQR6BeZIgHHYRisxTA6Kpu4lRTkIAjtkFiRyQ6zVwTXbg4f2qeXpsMEo/tUZ0RexmM3RAm3Zzm4BNWfr9iHp3/arBoZSt+FF84fgEkDeBCIiKglYtBNRNSGFIXqQXdU2UEkSPxrAuI6dK/1cTFhgVju6IMrMV9dP6zFYWBUsOv2oakxmHHFMCzdkYX8NWFINuhBd0BoFIIDTChBMAIlelYBeyxSDG7ThlVkun/d64BmCsSwiucsRSAQHKOCbk8RDr2cPVcLr5LlLkUQQgMDVNCdXjEe3JJ7EM7e7KaK8vLSgChIzG+SoNsVkkviOw/tK7Lc+uvkAxKUGysLw/LS96nzsuB4hLotJ3L3wuwtVRqgSbZaguej5SwHzym24OaPV6uScnFi9zj856LB6jtPREQtE4NuIqI2xB7Z0RVM9jRWjIGO7VSnTPc8R2XAkGFMQERQ9U1IQkQQ8tzGdZvDohESKEF3EKIroue/HV2RYqoIuqW0uyLoztKisCy93C3oDoIpLFom664mTNPn1s7WIhGBEgRUjOeWx4QEGhEUYEJpcBIkGW7NO+QWdOvl5ZbAaBV0B9hLYEJlObyjNA8dDZXTk5mke1xZHhASAxj04Lw0Rx8Lr4VXzF1OVIeO43JdstX1zXi7Z8sLy2z459frkVFYDrPJgAcm9MYNo7uoZodERNRyMegmImpDJgztiZyFEYg1FCLOUDFPdrQeiNdEysYzEIN9SEYqjqAkJBmGiiDUnYzx3qtVjuEODItWme5MLRjOhPKugK6wOdbogbKtDFpxhropC1GwFxVCEtyiDIEICI+rcb0KEYpiBCMKehBeqgUi2GzSb4xIBvIAg1sjtYCK8nJ7ULRqDGe2S8BeOUd5gLUIHdyCbqHtXQrDD7cDJ96J/OF3Iqg0U7rCITCmcow7kbv//l7Zu8Bbx/GjzZY7dU8Mx9RLBqN/+yi+8URErQDr4oiI2pCU6BCUhFUG2Q5DQJ2agUnQLf5jOR9L7f2wNXqs1/tFh5hR4JbpDgmPRZDZqAJjp7ywbiqgVqyl0AorM90SeDtJ1jpAMt1ubFrVzVahFoIihLiul1WUl4uAaD0oDirN0MeOqzHdFVOGhejBfJCjFAEOfaoxIVlzz6Dbuu5rPdu9+UfsyixCUkXpvDk6pdb3jdoeyUz/vrXqd6i2TuS+nsdbwD2xfzJ+un00A24iolaEQTcRURsT37GH67ItvB1grMgM12BIxxhVXf2DYzSusD6K8JiqXcadpMzVYo50XQ+JjEZQgFEF0E7lsb0qg25LMQylev14phatAm/X/RCEwKDwKt3Qi90CbFGIEJQZKpfJOPCQikx3RLwedAdIEzYJmlXHdD3oNoVVBt1mt6A70lA96DYeWqVfyNuLg3mlSKpoEqcy6UR1nFf7lN4J9cpyywEeb07vm6SGbBARUevBoJuIqI0JTujmulyX8dwiNS4Up/VJcl1PivTdtMkWpAfOxVoQwkOCVRm6MzAu1wIQlNTdFXTb8vbDoDlUp/K4xHZVg26DZK1Nak5tp1K3AFsUIRQWk9vtWpAK8tU6xsWoRmvu04YFVATdzrL1UJTCrHlmuvVGaraKTWRAod6xHaW5yMrKdGW6OV0Y1SebfccplQe7apNZWI5Pl++r1/MTEVHLxaCbiKitielcebkO47mdbhxTOVdwoKmGzUdwtGu8dURwgCuAFru0dugQG4Hyiuy1LVufazsHEeicEAVjaCzsmj7422IIRlhQAPK1yiCjzFg16LYFhMHitsxiDHI1lUqJCqmcq7tiXLcZetAdHK1P9RUqM4s75wuXOFpluvVy932m6gckyjJ2IZFBNx3lvNp1MX9LOiZOXYQ1+/Jg8uibUJ/nISKiloON1IiI2poYt2Ayqu5B94jOMQgLNKHYYseILvoc2N4YQ2MgFdiShU6qyDpbjKGQRuDbtY5oHxPiynRruXrQLRluGW9+MCYcOVmRSEC+CqBlLLl7prtcAuzKabVhN0fAYgxDRSwNq7EyAy+vI0F3b+z///buA07K6t7/+G9mdsr2wtKWXgJIl6YYpKmIRsSgCCZGUPH+9S8arkaDEkWiXr0YIMZCSUFNEWMUrrFrFEHQG0WQKkpHQHpZytZ57ut3ZqduYXfd2TLzeb9e4+48U3z27LM8833OOb8jsvbvIm0HSULJ2t7OlGzzNVnyTPD2017sxjbfcmQ7PV2k/antYT+b9+hOerpR5XW1KxOUzxQUy3+9uUn+/Knvb6JLs1R5cvy5crqgqEbW+gYA1B1CNwDEdU9360q/TIeJf3TvMFm186gM/oEvtJalMKOjyB6Rb23NpWNJT913CTlmia7PvJ1lfKpH8m0loTvXt9awBuucDI+0yEiUQwfTpbHtuAnQ2SkuORbS052vATuE5U6VgpDHCyJC99ziwTLEsVZk7SIzPNzPnuy7aGC3WZKuZcxLNLX55n4XuTPkRGLrUmuEp5zYKln+dcGZ041KrKtdGRv2HpefL1ojWw74ji1dBuyeSzsHKvETtgGgYSN0A0C8SWspYnOIWMVVGl7uXxJMe/AqUty8t1z5xcNSmNFWhpZsW5J0jbyW21k2WG1lsi4r5l+m69T+QBVy7enOyciTQ5avEFuRwyON9LkhPd2FCckmvPvZPWlSVBh8vCgkdKd5nPKhc7D8R4FTFrjmiHzzTvB1uu52iSwpWTotREGjLmI5G+k6ZmHan1lvvnod7rD3AKq65rYGaa/Xkj98vE2eeGezFBZbZp37WWN7yeBOvukPAIDYQOgGgHjjSBBpc4HI3jUiTXvU+Ntr7/Raq4Oc4wlWMXe5nLLa8s1zbZTiki0aui0R+6mDgfnf7UzoPhNYNqzInmieeyKkJ1vncIf9KEnpUnQquK3YET7nW3u73/2un3jtTrF7S8ag6/Byd6KcEY/WPheHzbecWChbk65iKyjdm3+utcGsN26ltdCu/2q1D+IjUJ9tze3rz29tnr9ii696/yVdm8p/X90zsDwfACB2ELoBIB79bLFI4WkRT7BaeE05v30jM0x8ZEiPuH8ZLw0UToddCu1u0enVjtMlodtKCgwvX+dtIeIQOepsKqnuBDlpSwmG6ojQ7UpKF29BcJvXEV5VXd/vq+9y5bQzU1LyDwQqqLsSHKYoW6IuJ1YGV053cR4O9jbmenIkNW+vJNt887/tnS79Xm2E2BIZqLWQms7rrmjN7b98uivwt/HgqK4yvn8rM4UDABB7qF4OAPHI4YxK4PYvJ7Zi6nD5+cXBJZL8c1O1F1wVaejWHucC3xzq07YkyU52myHmfyy+XK4rmCYfZ442IaTIFdxPyxUeut3JGeJ1BUO51xne0z38HN964nsKgs8pEKe4Euy+4m4h/FXTlaNZN3GlBdcif+Nkp7Dn2rqPqVKbIHaVFaj1vm4/29rdLTMT5fU7B8l1A1oTuAEghhG6AQBR53H6Tjc6Z1UVO9wRT0g3S31p6M4Xl3zi7SaWvaTYWmIwdBc7g+FZJadliBUSuq2E8NA95tyWkp7olH1FqYFtBZLg622PGIp+1BYcDi9NzpHkzOC65P/rPScQyg85moi07F+NVkAs0DD96hffBkJ1eYE6dHt5a2vPvraXdGgcfkwDAGIPw8sBAFHn7+lunFISukMKnvme4AvFjULmsx49XVIxLTFL1x/zvS4hvHc6KS1LCkJDd0RPd6LLIT85r7UcWpEe1tOdmmCXXH2v4GphctSWIdnWcTlobyyNPemSlm6ZoehuW5FZX3yfNJKWckg2Zg6XwQwDjktlDSMvr7CgP2gXey1ZufWw6PLxXit8ze0B7RpFf6cBAHWOnm4AQNQFh5e7A9W/Q1kuXy+z9nb7HT7pC90Juu63X4JHCnXCd4m09CyxuYOh2+YMD+XqJwNam3XA/Qp0TrfDLsXOkKXIxC2n7L7gv9flW1ItM9kt/ygeIp97O8kmq428X9zHVFnf2ebq6jcEYm4YuT98h9JArcXUvj16Wq5b8KmpTq6B+4IOjeSRq7rJ4v9/gfwyZM43ACC20dMNAIg6rcy8YsshGVHSK1gcUfDMcocM7S5x6KSvG9qd6ltTW9kSXFIoTnFqFTYNxpmZsrekl9xwlQ7dOmT9sKSF9XQ7HTbxhgxVL7S7JN+RbIq7HUzq6HvvJJdMK7rZfD+sc2N5+Jsb5ZGi6+Wx5oSleFTRMHItmqY93qHVy/9nzR751ZL1kptXJMkuh8wY3V2u7tOCudsAEIcI3QCAqBvWuYkMuydYmMxKCA/d9pB525ES04JDcG0OlxSVnLq01zkz2WPW6vZzlBG6HXabnHE1EvH67hfanL7gE1KUrdDmlk2ec6VX/heyK3uw7//rCvaoX9k7RzKTXfL6l/ukf9vgRQDEj/LmZfu3a9DW24m8QvnPl9bI4tV7SrZnyG/H9ZY2jcp+PQAg9jG8HABQ+yJCt6637fenif2kebpH5l7f19xPTg+ul21zeqTQ5gvdJyXJDFt3JAZDty2iurlfUWJw+a/CktBud4es/213y/Ksa6Rb/p/kRJN+ge0PXNFVfnpeaxnVM8esobz6wUukbTnhC7FNA3V5w8j9Pt9xRC5/crkJ3DpT4ucX/UBe/n8DCdwAEOfo6QYA1L6IgmeupIzA98O7NJVP7gtWDs9KT5M8yykeW6EZXl4kTrM9r2TJr4SQ0J3gLt3TrbxJjUVKRgcX2Xyvt4cMSy9yuKVZukeKxSGts4LvcfOgduG77eBadTwraxi5Kir2yu8+2CJPf/CNmbutS4E9Ob639G3DqAgAAKEbAFAHbBE93a6UYOiO1CjFJcclWTxyTBxOtxRpT7clvjnYJrAHw3OCp+xeaHtqE5GDvu8tm2/YuCMkdBfbE+UXIzrLDztmy8XnBAM/oAXUQkO2/+a38/Ap+fmiNbJmt2/N+THntpCr+7aQnYdPi91mC3suACA+0dMNAKh1tpCebq9lE09y6UJqfo1S3LLNmyNNHcekMCVHikt6qosSfAE70e2W3d7Gkm07LraU4LzxUInpweHlyZJnvjoTQ0J3gtvM2b68R/Ma+OkQy0uEaW+3sixL/rHqW3notQ1yqqBYUj0J8uiPe8jGvcflp3/4d5mvAQDEJ0I3AKDW6dxsv5PikVRP+BJioXTt7lGFd0qLokNyU2IbaV0yp7uoZJkxndd9bcGDkmTLk3tD5oaHykoJhvzUknHmrpDQbUVUUwfKWyJMh5e3z06R+xevkzfW7TPbB7TLkjnjesuBE3ly54ury3wNPd4AEL8I3QCAWmcPqTKeK0mml7A8GqqPSJocsdLkxJmiQE+3uFICVcb3SSMz5DwppOJ4ZG+5X0pJ6HYnp5dbTR0ob4mwdzfulyWrv5B9x/MkwW6T/7ykk9w6pIOpkv+/2w6X+16EbgCIX4RuAECtc7iCITfX0tBdEqTPQkN1sd1lvreVLBWW6AwG7dDvI+eF+6VYvjDlCZkLTuhGZZcIm7d0q17fMY/rUmC9WmVUelkxAEB8ogwrAKD2Tz4hVcZzJbHCnm6llaCv6dtSRvduIfYEX4BOTvUVqPI47WG94mXJDgndCVJcqpCa5Sy76jniV1lLhCkN3OP7t5LX7xgUFrgru6wYACD+0NMNAKj9k09o6LaSpNNZero1bOtNtW2aKbJNpH0rX9EzT0IwaJc3vDwr2VdsrZX9oOx3NBdTnzxkTe/Qwm6A3y9HdjFf//jxdikstiQjySmPj+khI7s3r/KyYgCA+EXoBgDU/sknYk53yll6ukM5M3zh257lW0PbbrdJk1S3HDlVIFnJwR7tyOHlowrvkzsTFsuK7J/JbN3o9s0JjyzsBqjDJ/Pll6+sk/c37Tf3B3XMlt+M7WXWcz+byGXFAADxjdANAKj9k48nGLrz7MmmCFWljXhYpPsYkbYXBjY9d+MAOX6mUDKSyg7dqe4E2Wk1k7sLb5OuxWlhhdhUZlr5S5Yh/iz7+qDc/fKXcjA3X1wOu9w7srPc9MN25gIPAABVRegGANQ6V8jw8vyEYPitFE+6SPuhYZu65lQcmm22YFjKzS8s2Yng8PIMQjf0AlBhscx8e7P8acV20x4dm6SYegLdcspeig4AgAZZSG337t0ydOhQ6dq1q/Ts2VNefvnlut4lAEANc4X0dBdVNXR/T7rsmGGKp5WEcQqpxb3N3+XKVc+sCATuGwa2kX9OHkTgBgDEXk93QkKC/Pa3v5XevXvLgQMHpE+fPnL55ZdLcjLLbQBArPC4nJJvOcVtK5QiV+0O7c7NK+np1t5vHWJekCvCnO64ZVmWPL9yh/zXW19JQZHXVLqfeU1PGd7FlNsDACD2Qnfz5s3NTTVp0kSysrLkyJEjhG4AiCG6zFeeOMUthWK5gkt31Qavrvnkp0PMNXQnUL081qzedfSsFcQP5ObJPS+vlY++PmjuD+3cWJ64ppc0TnXX8t4CAGJZlYeXL1u2TEaNGiU5OTlmjtySJUtKPefZZ5+Vdu3aicfjkb59+8ry5curtXOff/65eL1eadWqVbVeDwCon3Q97TzxFT2zPLXT090iwxesW2aGBGz/vG56umPK429tkh8/u1Lu+vuX5qvej/T+xv0y8rfLTeB2J9hlxpXdZOHE/gRuAEDdh+5Tp05Jr1695Omnny7z8ZdeekmmTJki06ZNk9WrV8uFF14ol112mezatSvwHA3i3bt3L3Xbu3dv4DmHDx+WG264QRYsWFDdnw0AUE9pyDlplYTfxNpZWukvk86TMee2MMEqILVkveXkJrWyD7Fox44dcvPNN5uL7YmJidKhQweZPn26FBQU1FkP97yPtoVt0/u6XZ0pKJZfLVknk1743Cwz16VZqvzzjkEy4YK2YQX3AACos+HlGqD1Vp7Zs2ebk++kSZPMfZ2f/c4778jcuXPlscceM9tWrVpV4f8jPz9ffvzjH8t9990nF1xwwVmfqze/EydOVPEnAgDURU/3b4qulQH2r+RYVs9a+X/qMOPZ43qHbxz1pMje1SKtBtTKPsSir776yoxKmz9/vnTs2FHWr18vt9xyi7lI/5vf/KbW90eHlJe33emwy88XrZatB33PmTSondwzsrO4Exy1vJcAgHhSo3O69aq2BuqpU6eGbR8xYoSsXLmy0gVNJk6cKMOHD5ef/exnZ32+BvkZM2ZUe58BAHXT0/2W9zxzuyfRU3e/guyOvhuqbeTIkebm1759e9m8ebO52F4XoVsvrpTly93H5JevrJXCYkuapLpl1rW95MIfNK71/QMAxJ8aXTLs0KFDUlxcLE2bhlf81Pvfffddpd5jxYoVZoi6zhXXCuZ6W7duXbnP197w48ePB2665BgAoH7TYbwavFWqp97V9MT3pOdjLYRaER2lpqPTQm81QYum3Tqkfdi2Fhkeef6TnSZwj+jaVN6eMpjADQCoNVH5pBM5J0p7rys7T2rQoEFmmFplud1ucwMANLwh5vlFXkJ3jNm6das89dRTMmvWrDobqTb1snPk0m7NZMmaPfLKqj2y51ieJDodMn1UVxnXvxVztwEADbenOzs7WxwOR6lebV1vO7L3GwAQ33TZMJXmcdb1rqAMDz30kAmnFd10lZFQWhBVh5qPHTs2UNulLkaqncovkhf/vUueX7lTTuYXSY8W6fLGnYNk/IDWBG4AQMPu6Xa5XKYy+XvvvWcKofnp/dGjR9fk/woA0MAlu/UUlC8ZSb6lw1C/TJ48WcaPH1/hc9q2bRsWuIcNGyYDBw6s1Moj0RypdseLq+WDrw6IDrK7bUgHmXJxJ3GVTGcAAKDeh+6TJ0/Kli1bAve3b98ua9asMXO3WrduLXfddZcpgNavX7/AiVeXC7v11ltret8BAA3YvZd2kX9vPyK9W2XU9a6gnNFrequMPXv2mMCtF94XLlwodnvdBty7LukkWw+elP++uqec375Rne4LAAA2SydcV8HSpUvNiTXShAkT5LnnnjPfP/vsszJz5kzZt2+fWX97zpw5Mnjw4Ki29jPPPGNuWsjt66+/NkPV0tLSovr/BACgJmgRsfT09AZ57tIe7iFDhpgL7y+88IKZZubXrFmzOmuDomKvJDjo3QYARE9lz11VDt31XUP+4AIAiE8N+dylF9xvvPHGMh+rykeMhtwGAID4dKKS5y4uAQMAgGqbOHGiCddl3QAAAKEbAAAAAICooacbAAAAAIAoIXQDAAAAABAlhG4AAAAAAKIkZkK3LhfWtWtX6d+/f13vCgAAAAAAsRW6b7/9dtm4caN89tlndb0rAAAAAADEVugGAAAAAKC+IXQDAAAAABAlhG4AAAAAAKIkQWKMZVnm64kTJ+p6VwAAqBT/Oct/DotHnL8BALF6/o650J2bm2u+tmrVqq53BQCAKp/D0tPT47LVOH8DAGL1/G2zYuyyutfrlb1790pqaqrYbLYauXqhAX737t2SlpZWI/sYD2g32o7jruHg77Xu205PxXrCzsnJEbs9Pmd+1fT5OxTHOO1W2zjmaDuOufj4e7Uqef6OuZ5u/WFbtmxZ4++rvwBCN+1WmzjmaLvaxjFXt20Xrz3c0T5/h+IYp91qG8ccbccx13BU9++1Mufv+LycDgAAAABALSB0AwAAAAAQJYTus3C73TJ9+nTzFZVHu1UfbUfb1TaOOdou1nGM024ccw0Hf6+0WyweczFXSA0AAAAAgPqCnm4AAAAAAKKE0A0AAAAAQJQQugEAAAAAiBJCdwWeffZZadeunXg8Hunbt68sX748Wr+HBumhhx4Sm80WdmvWrFngcS0XoM/RxeITExNl6NChsmHDBolHy5Ytk1GjRpm20HZasmRJ2OOVaav8/Hy54447JDs7W5KTk+XKK6+Ub7/9VuK97SZOnFjqODz//PMl3tvusccek/79+0tqaqo0adJErrrqKtm8eXPYczjuqt92HHcN044dO+Tmm28253b9t7ZDhw6meE5BQUFd71qD8Oijj8oFF1wgSUlJkpGRUde7U2/x+TE653tU/5yF0ubOnSs9e/YMrM09cOBAeeuttyRaCN3leOmll2TKlCkybdo0Wb16tVx44YVy2WWXya5du6L2y2iIunXrJvv27Qvc1q1bF3hs5syZMnv2bHn66afls88+M4H8kksukdzcXIk3p06dkl69epm2KEtl2kqPx8WLF8uiRYvk448/lpMnT8oVV1whxcXFEs9tp0aOHBl2HL755pthj8dj23300Udy++23y6effirvvfeeFBUVyYgRI0x7+nHcVb/tFMddw/PVV1+J1+uV+fPnmwubc+bMkXnz5sn9999f17vWIOjFibFjx8ptt91W17tSb/H5Mbrne1T/nIVwLVu2lMcff1w+//xzcxs+fLiMHj06eh2EWr0cpQ0YMMC69dZbw7Z16dLFmjp1Ks1VYvr06VavXr3KbA+v12s1a9bMevzxxwPb8vLyrPT0dGvevHlx3Yb6Z7d48eIqtdWxY8csp9NpLVq0KPCcPXv2WHa73Xr77beteG07NWHCBGv06NHlvoa28zlw4IBpv48++sjc57irfttx3MWWmTNnWu3atavr3WhQFi5caM5RKI3Pj9E736P65yxUTmZmpvWHP/zBigZ6usu5krtq1SpzlSiU3l+5cmV0rn40UN98840ZBqRD9caPHy/btm0z27dv3y7fffddWBvq2ndDhgyhDSNUpq30eCwsLAx7jrZ79+7daU8RWbp0qRlS1alTJ7nlllvkwIEDgXai7XyOHz9uvmZlZXHcfc+28+O4i53fb+TvFqgOPj+iPp+zUD4d+aijIXV0gA4zj4aEqLxrA3fo0CHT+E2bNg3brvc1HMHnvPPOkxdeeMEEnf3798sjjzxi5nrpsAx/O5XVhjt37qQJQ1SmrfQ5LpdLMjMzOSYj6LQPHe7Ypk0bcwHjgQceMEOENGzrxQvazjd3+6677pJBgwaZCzUcd9+v7TjuYsfWrVvlqaeeklmzZtX1riAG8PkR9fWchbLptFgN2Xl5eZKSkmKmInbt2lWigdBdAS3iEHkgR26L97Dj16NHD3PQalGa559/PlDIijasvOq0FcekyLhx4wLtoSeYfv36mQD+xhtvyJgxY2g7EZk8ebKsXbvWzGfnuKuZtuO4q1+0EOWMGTMqfI7Wy9B/H/z27t1r5uXrRbtJkyZJvKpO26FifPZBfTzfo7TOnTvLmjVr5NixY/LKK6/IhAkTzBz5aARvQncZtMKxw+Eo1autQ1YjeyMRpFWhNXzrkHOtnKi0DZs3b04bVsBf8b2ittLn6LC1o0ePhvV263N0dAGCtA01dOtxSNuJqdr+2muvmaqwWjSE4+77t11ZOO7q/oOmTnGqSNu2bcMC97Bhw8zF4gULFkg8q2rboXx8fkRDOWfBR0eRduzY0XyvFxb1AuOTTz5pim3WNOZ0l/ML0CXCtAJgKL1PwCmfLsu0adMm8+FT53hrUAxtQw2NevWINgxXmbbS49HpdIY9R6t0r1+/nvaMcPjwYdm9e3fgAka8tp2OgtAP06+++qp88MEH5jgLxXFX/bYrC8dd3YedLl26VHjT5T/Vnj17zLKMffr0kYULF4rdHt8fharSdqgYnx/RUM5ZKL8tNc9ERVTKs8UArRKt1aL/+Mc/Whs3brSmTJliJScnWzt27KjrXas37r77bmvp0qXWtm3brE8//dS64oorrNTU1EAbaTVurW766quvWuvWrbOuu+46q3nz5taJEyeseJObm2utXr3a3PTPbvbs2eb7nTt3VrqttJp+y5Ytrffff9/64osvrOHDh5vq8UVFRVa8tp0+psfhypUrre3bt1sffvihNXDgQKtFixZx33a33XabOab0b3Tfvn2B2+nTpwNty3FXvbbjuGu4dNWHjh07mn8/v/3227DfL85O/93Vf39nzJhhpaSkBP5t1r8J+PD5MXqflVD98z1Ku++++6xly5aZz49r16617r//frMq0LvvvmtFA6G7As8884zVpk0by+VyWX369KH0foRx48aZYKgXJ3JycqwxY8ZYGzZsCDyuSxLpsmK6HJbb7bYGDx5sAmU80jCoJ5DImy53Vdm2OnPmjDV58mQrKyvLSkxMNBc5du3aZcVz2+kJZcSIEVbjxo3Ncdi6dWuzPbJd4rHtymozvelSP34cd9VrO467hkt/h+X9fnF2+u9rWW2n/04jiM+P0fmshOqf71HaTTfdFMh5+jnyoosuilrgVjb9T3T60AEAAAAAiG/xPZEJAAAAAIAoInQDAAAAABAlhG4AAAAAAKKE0A0AAAAAQJQQugEAAAAAiBJCNwAAAAAAUULoBgAAAAAgSgjdAAAAAABECaEbAAAAiBMFBQXSsWNHWbFihdRX/fv3l1dffbWudwOoMYRuAAAAIMoeeugh6d27d52384IFC6RNmzbywx/+UOqrBx54QKZOnSper7eudwWoEYRuAAAAoJ4oLCyM6vs/9dRTMmnSJKmNHvXq+tGPfiTHjx+Xd955p0b3CagrhG4AAADgLF544QVp1KiR5Ofnh22/+uqr5YYbbqjwtc8995zMmDFDvvzyS7HZbOam25R+P2/ePBk9erQkJyfLI488Yh7LyMgIe48lS5aY54b65z//KX379hWPxyPt27c3/4+ioqJy9+OLL76QLVu2mFDrt2PHDvO+Opx72LBhkpSUJL169ZJPPvkk7LWvvPKKdOvWTdxut7Rt21ZmzZoV9rhu032fOHGipKenyy233BL4OV5//XXp3Lmzee9rrrlGTp06Jc8//7x5TWZmptxxxx1SXFwceC+HwyGXX365vPjiixW2K9BQELoBAACAsxg7dqwJhq+99lpg26FDh0ygvPHGGyt87bhx4+Tuu+82oXXfvn3mptv8pk+fbkL3unXr5KabbqrU70J7ga+//nq58847ZePGjTJ//nwTch999NFyX7Ns2TLp1KmTpKWllXps2rRp8otf/ELWrFljnnPdddcFAvyqVavk2muvlfHjx5t91KHyOgTcf+HA74knnpDu3bub5+vj6vTp0/K73/1OFi1aJG+//bYsXbpUxowZI2+++aa5/fnPfzZD3v/xj3+EvdeAAQNk+fLllWoLoL5LqOsdAAAAAOq7xMRE+clPfiILFy40AVz99a9/lZYtW8rQoUPP+tqUlBRJSEiQZs2alXpc37eyYdtPw7XOe54wYYK5rz3dDz/8sNx7770mxJdFe7VzcnLKfEwDt78HXHvM9QKB9op36dJFZs+eLRdddFEgSGso16CvIVt7tv2GDx9u3sfv448/NsPl586dKx06dDDbtKdbg/b+/ftNm3Tt2tX0sH/44YdhFyJatGghu3btMvO67Xb6CdGwcQQDAAAAlaBDpt99913Zs2ePua8BXENn5LDvqurXr1+VX6O9yb/+9a9NcPXfdP+0F117l8ty5swZMxS9LD179gx837x5c/P1wIED5uumTZtKFV7T+998803YsPCyfg4dUu4P3Kpp06ZmWLnub+g2//8r9EKFBu7I4fxAQ0RPNwAAAFAJ5557rpnvrPO7L730UjPUWudVf186lzuU9uxallVhgTUNpNojrUO1I5UXrLOzs80+l8XpdAa+919E8FcP132JvLAQuX9l/RyR7+t/77K2RVYqP3LkiAnsGr6Bho7QDQAAAFSSVv6eM2eO6e2++OKLpVWrVpV6ncvlCusVrkjjxo0lNzfXFBzzB1mdax2qT58+snnzZrPmdlUuGuhQ77JCdEV0CLgOFQ+1cuVKM8xci55Fw/r1683PCMQChpcDAAAAlfTTn/7UBO7f//73VZqHrUOqt2/fbsKzFmCraNj0eeedZ3p577//fjOv+m9/+1upomUPPvig6XHXomYbNmwwQ8Bfeukl+dWvflXu++rcaQ3y+vyq0CJw//rXv8yc8a+//tpUHn/66afD5m/XNC2iNmLEiKi9P1CbCN0AAABAJWnlb10mTOckX3XVVZVuN33NyJEjTfDVnuyKlsPKysqSv/zlL6a6d48ePcxzNVyH0uHtWjn9vffek/79+8v5559vCp61adOm3PfVJc90OLoWgKsK7XH++9//biqQa3VyDfw6nzy0iFpN0osa2pN+tqrwQENhs8qakAEAAACgTJdccomcc845ZimshkbndOuweO1BT01NlfronnvukePHj5ulxIBYQE83AAAAUAla3Et7ez/44AO5/fbbG2Sbac/5zJkzzfJh9VWTJk3MUHYgVtDTDQAAAFRyXvbRo0fNetWR85l1XeudO3eW+br58+ebueAA4hOhGwAAAPieNHBHLusVug51fR3KDSD6CN0AAAAAAEQJc7oBAAAAAIgSQjcAAAAAAFFC6AYAAAAAIEoI3QAAAAAARAmhGwAAAACAKCF0AwAAAAAQJYRuAAAAAACihNANAAAAAIBEx/8BLST+DQNNBMsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 1.027e-02 @ epoch 220\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=8170.89  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=8170.89 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 17593 nonzeros\n",
      "Model fingerprint: 0x933be072\n",
      "Variable types: 8704 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-01, 5e+00]\n",
      "  Objective range  [6e-02, 2e+07]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [4e-02, 1e+01]\n",
      "Presolve removed 0 rows and 2816 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 5898 columns, 11960 nonzeros\n",
      "Variable types: 5888 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 5640.0605712\n",
      "\n",
      "Root relaxation: objective -4.990706e+02, 151 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 -499.07063    0    5 5640.06057 -499.07063   109%     -    0s\n",
      "H    0     0                     287.3331192 -499.07063   274%     -    0s\n",
      "     0     0 -490.14388    0    4  287.33312 -490.14388   271%     -    0s\n",
      "     0     0 -489.72793    0    5  287.33312 -489.72793   270%     -    0s\n",
      "     0     0 -489.26578    0    5  287.33312 -489.26578   270%     -    0s\n",
      "H    0     0                    -483.3622677 -489.26578  1.22%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 3\n",
      "\n",
      "Explored 1 nodes (158 simplex iterations) in 0.03 seconds (0.04 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: -483.362 287.333 5640.06 \n",
      "No other solutions better than -483.362\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective -4.833622677345e+02, best bound -4.833622677345e+02, gap 0.0000%\n",
      "[CHECK DFN] obj(x_ip)=-483.362  ip_y=-483.362  rel_err=7.645e-08\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-0.0226  std(mean)=6.07  min=-10  max=10\n",
      "  y: shape=(2000,)  mean=9.91e+03  std=3.68e+03  min=1.14e+03  max=2.5e+04\n",
      "\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=17,610 layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=0.0\n",
      "  train: device=cpu  epochs=250  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzsnQe4HGX1xt/ZcmvuTe+NkhAICRAInVClCtKkiYqASpMiiIiKCBZUVEANKPgXVJTee+9IJyEESAKE9J7b7/ad/3O+mW/2m9mZbXfrvef3PMndvt/Ozsx+73fec46m67oOhmEYhmEYhmEYhmGKjq/4L8kwDMMwDMMwDMMwDItuhmEYhmEYhmEYhikhHOlmGIZhGIZhGIZhmBLBopthGIZhGIZhGIZhSgSLboZhGIZhGIZhGIYpESy6GYZhGIZhGIZhGKZEsOhmGIZhGIZhGIZhmBLBopthGIZhGIZhGIZhSgSLboZhGIZhGIZhGIYpESy6S8Btt90GTdM8/7344ouoJF988YUYx+9///uCnv/uu+/ivPPOw8yZM9HS0oLRo0fjS1/6Ep5//vm0x/785z933QYNDQ2ur33nnXdip512EvePGzcOF110Ebq7u10fm0gkMGrUKFx33XXi8h//+EccdthhmDBhApqamrDddtvhRz/6Edrb29Oe6/Xd/OY3v0l77Pr16/Gtb30LI0aMEK+755574rnnnstrW1fiO6cxb7HFFjk9jsZI36Xbtl62bBl8Pp94DH2fKh9//DG+8Y1vYKutthLfGW2jnXfeGd/73vfQ2dmZ9h5e/4rBT3/6Uxx55JEYP368eE16z1yhffeMM87Atttui+bmZvEaRx99tNjXnWT6HPR8leuvvx7HHXccttxyS3H//vvvj1Ly5z//WYyhvr5evOdVV12FWCxme8zKlSvFcbXffvthyJAhYlx0zsqXgw46CGeffTZqlX333VdsB4Zhqp9jjz0WjY2Nrr/nklNPPRXBYBDr1q3L+XXdfteqgV//+td48MEH027/6KOPxHhpblFu/vWvf2HkyJHo6uoq23vm+ntF841f/epX4jd2zJgxGDRokJij/va3v0U4HE57/KeffirmLpMmTRL71dZbb42LL74YmzZtsj2OHnPMMceU9DMyAwcW3SXk1ltvxf/+97+0fyRKapk77rgDb731lhApDz30EP7+97+LST5Nwumk7MaTTz5p2wYvv/xy2mP+85//4JRTTsGuu+6KJ554AldeeaU4uZJocYNeY8OGDeL+UCgkfogmT54shM7jjz+O73znO7j55pux9957i/udfPWrX037br75zW/aHhOJRMTnIpF9ww03iM9Liwwk7l966SX0F2iiEo/Hcdddd7nuxyTInbz//vvYZZddxCTgZz/7mfiO//rXv+LLX/4ynnrqKWzevNn2ePphczse6F8xoMUX+sH8yle+grq6uryee9NNN4lJzIUXXij2HfquabFljz32SFtMchs/7XNyYqhC24MWLQ488EAxWSklNOGg8dPxQNv/3HPPFRM3WiBzTjboWKNtdMQRRxT0XnQcvPbaa7jiiitQq/ziF7/AjTfeiEWLFlV6KAzDZOHMM88U4um///2v6/0dHR144IEHxMIr/UbXOplENy2mllt09/b24sc//jEuu+wy1/lAqcj192r58uXid5jm1zTve/jhh8Ucj+aFtE/oum49luaN9NtOv2H0O0C/+fQ7ecstt4gAUjKZtB5Lz3/sscdcg0oMkzc6U3RuvfVWOrr1t99+uyq37tKlS8X4rr322oKev27durTb4vG4vsMOO+hbb7217fYrr7xSvNeGDRsyviY9f+zYsfohhxxiu/0///mPeP7jjz+e9pxzzz1Xnz17tvX8jRs3pj3mnnvuEc//97//bbudbjvvvPOyfFJdnzt3rnjs66+/bt0Wi8X06dOn67vttlvO2/qFF17Qy81pp52mT548OafHNTc36yeffLK+11572e5LJpPiNb7zne+Iz0Hfp+Sb3/ymeF5nZ6fr69Jzne9RShKJhHWZ3ovesy/7dFdXlz569Gj9oIMOyvr8b33rW7qmafqSJUs8x7T99tvr++23n14KaN9vaGjQv/vd79pu/9WvfiXGtXDhQtcx0TmKvlc6Z+UD7fu0v1SCnp6eor3WjBkzxL7NMEx1Q7/x48aN03fZZRfX+2+66SZxLnvkkUfyel3n71q14PUbJuc0xZ5TZDuv3njjjeI3pq2tTS8nuf5edXd3i39OaJ5Lz3nllVes22655RZx27PPPmt77K9//Wtx+3vvvWe7/cgjj9QPPvjgIn0iZiDDke4KQ1YZsuL+7W9/wzbbbCMixtOnTxc2aycffvihsLwOHTpUWHnJhv3Pf/4z7XFkv7rkkkuE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U1bKg6V6J510Enz++efs+hUrVsBXX33lOoY462/fffelY6hRyrHC8zGbzbrug8d96tSpdDwB4LnnnmMlUJMnT4YzzzwT1q9fL48THTubpqYm9r2uro7Ou208dgI67wbO+6u/twTR3dBnTaK//w0kyoNEtwcbN25kZafDhg1zXY+XURwRNt/4xjfgT3/6EyxatAh+//vfs2ODfV2bNm2Sx4mOYceUcqzweyQSgdraWjonNbDt495774XFixfD9ddfz8rz582bx/q46djZ4ML/BRdcAHvttRdbqKHzbtuOHZ13A4fly5fDLbfcAmeddVZv7woxyKDPmkR//htIlE+oE48ZNGAQg37i6dcNdrEjmDZtGsyZM4eF0txzzz0yyIqOYel05ljROQkwf/58eTzwD8KsWbNg3Lhx8MQTT8Cxxx5Lxw4AzjnnHHjvvfdYPzudd11z7Oi861tgEOXChQuL3gcX5PD/B8HatWtZXz72I59xxhk9sJcD+3gSnYM+JxH99fMDUR4kuj3AhONgMFjgamPJqu5GEg6YCo3iG0vOMekQwWM4YsQIOoZFEInvxY4V3gdL0RobG11uN94HqwsIBzyGKLrxPKRjByy1/dFHH2XJrqNHj6bzrguOnRd03vX+B0NscSrG+PHjXYJ7v/32Y4vFd955Zw/s4cA+nkT50GdNYiD9DSQ6hsrLPcAyXhwRhol9KniZBI4/WM770UcfsQ+f2OONQlE9higaMRGRjqGbUo4Vno/hcNh1H0zp/uCDD+h4amB7w5dffikXMAbrscMqCPzg/NBDD7HSezzPVOi86/yx84LOu94XMFOmTCn6heM/kTVr1rCxjDNnzoS77roLAgH6KLQtx5PoHPRZkxhIfwOJEuhE+NqgAFOiMS36j3/8o/Xhhx9a559/vlVRUWGtXLmyt3etz3DhhRdazz33nPX5559br776qnX44YdblZWV8hhhGjcmmT700EPW+++/b5188snWiBEjrK1bt1qDjebmZmvJkiXsC3/tbrjhBvbzF198UfKxwjT90aNHW88884z19ttvW/PmzWPp8blczhqsxw5vw/Pw5ZdftlasWGE9++yz1pw5c6xRo0YN+mP3/e9/n51T+Du6bt06+dXW1iaPLZ13nTt2dN71X3Dqw6RJk9j/n6tXr3a9v0TnwP+L8f/khQsXWslkUv5/jb8nRHHo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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 1.061e-01 @ epoch 231\n",
      "\n",
      "iter=0  t=0.00s  best_y=9827.15  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=9827.15 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: 0xeece0d5e\n",
      "Variable types: 8860 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-01, 1e+00]\n",
      "  Objective range  [1e-02, 2e+07]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [9e-03, 1e+01]\n",
      "Presolve removed 0 rows and 4135 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 412 rows, 4735 columns, 9479 nonzeros\n",
      "Variable types: 4725 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 5107.9089721\n",
      "Found heuristic solution: objective 2211.5719167\n",
      "\n",
      "Root relaxation: objective 1.119894e+02, 375 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  111.98940    0    3 2211.57192  111.98940  94.9%     -    0s\n",
      "H    0     0                     129.3927823  111.98940  13.5%     -    0s\n",
      "H    0     0                     129.3927821  111.98940  13.5%     -    0s\n",
      "     0     0  126.91814    0    2  129.39278  126.91814  1.91%     -    0s\n",
      "     0     0     cutoff    0       129.39278  129.39278  0.00%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  MIR: 3\n",
      "\n",
      "Explored 1 nodes (493 simplex iterations) in 0.04 seconds (0.10 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 129.393 2211.57 5107.91 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.293927821026e+02, best bound 1.293927821026e+02, gap 0.0000%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=129.394  ip_y=129.393  rel_err=5.971e-06\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-0.0226  std(mean)=6.07  min=-10  max=10\n",
      "  y: shape=(2000,)  mean=9.91e+03  std=3.68e+03  min=1.14e+03  max=2.5e+04\n",
      "\n",
      "\n",
      "=== Run: quadratic | MLP ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=18,049 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=250  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA94AAAGGCAYAAACNL1mYAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA8cRJREFUeJzsnQV4FOf2xk9cSZAAwaW4WwUKhRqUulF3u22pG+2t999bue2lcgvV21J3qAvU0EJxiru7JUSI7v95v9mz+83szFo2ySY5v+cJSZaV2dnJ7rzf+55zYlwul4sEQRAEQRAEQRAEQagUYivnbgVBEARBEARBEARBEOEtCIIgCIIgCIIgCJWMON6CIAiCIAiCIAiCUImI8BYEQRAEQRAEQRCESkSEtyAIgiAIgiAIgiBUIiK8BUEQBEEQBEEQBKESEeEtCIIgCIIgCIIgCJWICG9BEARBEARBEARBqEREeAuCIAiCIAiCIAhCJSLCuxKYMGECxcTEOH798ccfVJ1s3LhRbcfzzz8f1u3nz59Po0ePpp49e1K9evWoadOmdNJJJ9Fvv/3mc93HHnvMdh8kJyfb3vcnn3xCffr0Uf/fvHlzuuOOOygvL8/2umVlZdSkSRN64YUX1M9jx46lU045hVq2bEmpqanUtWtXuv/+++ngwYM+t3V6bZ555hmf6+7evZuuuuoqysrKUvc7cOBA+vXXX0Pa19XxmmOb27ZtG9T1sI14Le329aZNmyg2NlZdB6+nzooVK+jyyy+n9u3bq9cM+6hfv350yy23UG5urs9jOH1VlC1bttA555yjtiMtLY0yMzOpb9++9Morr1BpaWnQ+8Dpa/bs2Z7rulwuevnll6lLly6UlJREzZo1o5tuuokOHDhgus/8/Hy66KKLqHPnzmrfYru6d+9OTz75pPq/yuC///2vZ7vatWtHjz/+OJWUlJiu88svv9DJJ5+s/r5wPfwNnXDCCfTDDz+E9Fgnnngi3XjjjVRTOe6449T7iyAI0Q/e31NSUmw/z5lLL72UEhISaNeuXUHfr93nWjTw1FNP0VdffeVz+fLly9X24tyiqnnvvfeocePGdOjQoSp7zK1bt6r36aFDh1L9+vXV64VzbCs43/jXv/5Fw4YNo+zsbEpPT1fnqM8++ywdPnzY5/pr165V5y6tW7dWx9URRxxBd911F+3bt890PVzn7LPPrtTnKNQt4qt7A2oz77zzjjoJttKtWzeqyXz88cf0119/0TXXXEO9e/dWIuK1115TJ+LvvvsuXXHFFT63+emnn5QYYiDkrHz44Yd02WWX0XXXXafE9OrVq2nMmDHqg2by5Mk+1582bRrt2bOHzj33XCosLFQfRhdffLG6PQTgggULlMj59ttvad68eerNVef888+nu+++23QZ3oR1ioqK1PPCh/1LL72kRMq4ceOUwIeAwYdBbQAnKxCon376KV177bU+xzGEoy6kwcKFC+nYY49VCxyPPPKIEvl79+6lxYsXqwWUe+65hzIyMjzXx/63W5yJBDgG8VgPP/yweg2Li4uVkLz11ltp0aJF9NZbb/m9PW5nJyLPOOMMJU6PPPJIz2V4Xi+++KL6jgUnHJ94/nPnzqU///xT7UsAwQuRjg9ziGAc8zhmn3jiCbUQg+MnkuCkA88Di03Dhw9X2/PQQw/Rtm3b6I033vBcDycWWADA3wlOUPbv36/+fk877TR6//331d9gIL7++muaOXOmOhGrqfzf//2fWoDAogkWRwRBiF7wuQQh+tFHH9HNN9/s8/85OTk0adIkOv3005UZUNOB8MY5ilX04fMGC6oQmMEsrEeKgoIC+uc//6nOyXA+UFVAIOPcEIbMqaeeqs4/7di8ebP6XIZQxmcuhPf06dPVeeGUKVPUFy/y47zxmGOOUecM+BzAOQPOZx599FH6/ffflbnE56i4Pc7jce6CBWpBqDAuIeK88847LuzauXPnRuXe3bBhg9q+5557Lqzb79q1y+ey0tJSV69evVxHHHGE6fJHH31UPdaePXv83idu36xZM9fw4cNNl3/44Yfq9j/88IPPbW6++WbXgAEDPLffu3evz3U+//xzdfv333/fdDkuGz16dIBn6nKNGzdOXXfWrFmey0pKSlzdunVzHXXUUUHv699//91V1Vx55ZWuNm3aBHW9tLQ010UXXeQaNGiQ6f/Ky8vVfVx//fXqeeD1ZK644gp1u9zcXNv7xW2tj1HVXHDBBa74+HjX4cOHQ77tH3/8oZ7zQw895Lls69atrri4ONett95quu5HH32krvvGG28EvN/77rtPXXfdunWuSIFjPzk52XXDDTeYLv/Xv/7liomJcS1btszv7YuLi10tWrRwDRkyJKjHw7GP46U6yM/Pj9h99ejRQx3bgiBEN/iMb968uat///62///qq6+q99Vvv/02pPu1fq5FC/i8xOem0zlNpM8pAr2vjh8/Xn3GHDhwwFWVlJWVeX7GOTWeO86xreTl5akvKzjPxW2mT5/uuezNN99Ul/3yyy+m6z711FPq8gULFpguP/30010nn3xyhJ6RUNeRqHk1gxU4xHJff/116tSpk3LX4IjDMbSydOlSOuuss6hBgwYq1osVQDjMVuDOwslF7JajpFgpXLlypc91Ec+GG4fVQUSo9UitE7g/K3FxcdS/f38V+Q0HPO6OHTvo6quvNl0+atQotW1YydbB5yUuO++88zyP36hRI5/7Peqoo9T3cLcLjwE3DPuGiY+PV64gXH+4iZEAq9pt2rSh8vJyn/87+uijVXybgeOOmCxeB8SXEaf697//7RMpDhUkGGbNmkWrVq3yXAZXFlFz6+vCzilWjPH62BGJCHlFQSwOK9c4PkLlf//7n3oO2C/6cYqyBvw96cBlAV9++WVQ28THkQ5SGWeeeSY1bNhQ/X0jKv/ZZ58Fta1IlCBOZ32d8Dv+Vuwiizpw6RHjs26THXAGcOzDWbArsYFjABcZqRP8TSKRsn37dtN1cZzjmOVYPI5lJGUQK9SBq9OjRw+VFBg0aJAq9cDrwSUczz33nIoSwvlBogLXR1IGfwtw/hGnR9IGMVWUjFjBc4CDVpXRSUEQQgfv4VdeeaVyI//++2+f/0cyC2U/I0eOVI4mXHGcS+Hzictp4ICGy6uvvqoSfrg/OL5474IDrIPzgRtuuIFatWpFiYmJ6v0HrjVH3/EejXMznLvhfQnv9Ti3QIJIB+9tSHHh/I7LnfDehvdYnBOB448/3vN/evQan9lI6eGzGe+XSKVZS+O4BBCpQGwfzikRtQ70/JEAw+eE3Tks0lJIv+ExsZ++++47igR26Ug7cC6Er2DOATmVpqcwAT83aykkPiewX9etWxfGMxAEMyK8KxGcoCO+q3/hMivffPONqhlFBPWLL75QAgyRafzMQAzhxHPZsmXquhMnTlQfKqhNxQksgxPIwYMHKyGPk27ErBEjhaiHsNWBgEP8BvEcRHnwRg9BgchWqOC54UMNEVY7IA7xwYkIGE6wEQuyLiqAXr16mS7HGyQ+4Pj/GQhEPB8W3k5wtNluu3DCjZN1nPhj0QAf3FbwuNZt0rcTr0ckgJjAPrFGsbFYApGjCyq8+V9yySXqgw4fbojgQYD84x//qNA2IDaNY+/tt982iU+I/I4dO/pcHycMeA1QVzd16lQV9w+E9e8BX9bFBrvr2H0ZZoUZXIb/Q701YvM4IcGJTjCCUgd/A/j7wwkMFqYYRNgBjhnrcYoTkCVLljhuE6L6EMj/+c9/1N+3XtYAsYoTJCya4e8VJ2I4Obvwwgtt69ms8N8H/s50cCIKAWz9+wHY79guiGJE7CBYraUXduCYw98yjgs7EGHH/sDfF96bEKu3xtchzBFZRNQb73+I+2Hf4D0O5Qo6OMZwexzzKB/QY6Z4D0PkHd9RToC/F5wc4m8CJ984lrENOGnCdlnBySze96q774YgCMF9TuJ9Vv+M4vg1PichzPHehPIZgPe177//Xn22w4jA33s4f+swQvC+g9IyLMZjIfPOO+809eqA6EZJEv4fUecff/xRnVtB3HH/D5SuYdtQpoT7QGwa52tYnNTLdlCyhHMTnI/hZ3yNHz9elQMhgg7wnsf/h8vBBx98oMqMILoh2rFwC3E/YsQI2740eNwOHTrQ559/rj53nMCCKBY7IPbtwD5GPxWcw2LxGY+Jxc7169f7fA4G8xVJ7M4BYXTg8xefdziHQ28bLO6ixw8+P7CAoIPjBtsfah8UQbClui332hw1t/tCTFUHl6WkpLh27txpilR16dLF1aFDB89liHUmJSW5Nm/ebLr9yJEjXampqa6DBw+q35944gl1n1OmTAkYf+7Zs6d6LOavv/5Sl3/88cchP+cHH3xQ3farr74yXf7ee++puCui4r/99pvrmWeecTVs2NDVtGlTFdtlcB3cfseOHT73jfh5p06dTJfdcccdavv9gfvH4yCOrseVwCWXXKJi7NOmTXN98cUXaj9aY8UgISHB9Y9//MPnvhE9x/URMY5E1BzxdWwrtssaS05MTLSN0QM8L9wW+xnH1v79+8OOmgNE7rKzs9V97tu3Tx1zEyZMUKUC1kge4ttnn3226dju27evOhZ2797t8xhOfxMnnnii6bpO17N+2cXNnn76ac//I2KNbQkHji1a/xYWLVqkLv+///s/0+W//vqruhyvlRXch77dV199tdq/Ovh7x76zXo6IG0owrMevFcSl8VrZgb8dawkHGDFihGebMjIyXBMnTnQFA/5WsL1O73soAdH597//bfrbXrFihe315syZoy7/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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.650e-03 @ epoch 103\n",
      "\n",
      "iter=0  t=0.00s  best_y=7925.2  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=7925.2 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 1282 rows, 779 columns and 20107 nonzeros\n",
      "Model fingerprint: 0xe2f0169f\n",
      "Variable types: 513 continuous, 266 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-06, 5e+01]\n",
      "  Objective range  [4e+03, 4e+03]\n",
      "  Bounds range     [6e-01, 5e+01]\n",
      "  RHS range        [2e-03, 5e+01]\n",
      "Presolve removed 257 rows and 1 columns\n",
      "Presolve time: 0.03s\n",
      "Presolved: 1025 rows, 778 columns, 19619 nonzeros\n",
      "Variable types: 512 continuous, 266 integer (256 binary)\n",
      "\n",
      "Root relaxation: objective -2.602215e+04, 426 iterations, 0.01 seconds (0.02 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 -26022.155    0   98          - -26022.155      -     -    0s\n",
      "     0     0 -10445.450    0  107          - -10445.450      -     -    0s\n",
      "     0     0 -8926.3563    0  112          - -8926.3563      -     -    0s\n",
      "     0     0 -8835.8270    0  114          - -8835.8270      -     -    0s\n",
      "     0     0 -8810.3091    0  113          - -8810.3091      -     -    0s\n",
      "     0     0 -8800.1452    0  115          - -8800.1452      -     -    0s\n",
      "     0     0 -7459.4890    0  119          - -7459.4890      -     -    0s\n",
      "     0     0 -7265.5044    0  116          - -7265.5044      -     -    0s\n",
      "     0     0 -7241.8032    0  114          - -7241.8032      -     -    0s\n",
      "     0     0 -7240.8476    0  114          - -7240.8476      -     -    0s\n",
      "H    0     0                    13208.625221 -7240.8476   155%     -    0s\n",
      "     0     0 -5893.4677    0  120 13208.6252 -5893.4677   145%     -    0s\n",
      "     0     0 -5804.0030    0  122 13208.6252 -5804.0030   144%     -    0s\n",
      "     0     0 -5785.0369    0  121 13208.6252 -5785.0369   144%     -    0s\n",
      "     0     0 -5775.3855    0  122 13208.6252 -5775.3855   144%     -    0s\n",
      "     0     0 -5451.7342    0  122 13208.6252 -5451.7342   141%     -    0s\n",
      "     0     0 -5358.1212    0  124 13208.6252 -5358.1212   141%     -    0s\n",
      "     0     0 -5348.2154    0  126 13208.6252 -5348.2154   140%     -    0s\n",
      "     0     0 -5282.6894    0  126 13208.6252 -5282.6894   140%     -    1s\n",
      "     0     0 -5267.6864    0  122 13208.6252 -5267.6864   140%     -    1s\n",
      "     0     0 -5218.2436    0  128 13208.6252 -5218.2436   140%     -    1s\n",
      "     0     0 -5217.9276    0  128 13208.6252 -5217.9276   140%     -    1s\n",
      "     0     2 -5217.8077    0  128 13208.6252 -5217.8077   140%     -    1s\n",
      "H   43    57                    12980.154586 -4324.9148   133%   207    2s\n",
      "H   44    57                    12958.115489 -4324.9148   133%   206    2s\n",
      "H   47    57                    12576.928484 -4324.9148   134%   203    2s\n",
      "H 1097  1007                    12172.708856 -4293.4423   135%  54.5    2s\n",
      "  2227  1911 -606.65311   51  125 12172.7089 -4186.7138   134%  41.1    5s\n",
      "H 2244  1825                    11911.383120 -4186.7138   135%  40.8    7s\n",
      "H 2251  1738                    11435.111808 -4186.7138   137%  40.6    8s\n",
      "H 2293  1686                    11196.997801 -4186.7138   137%  46.9    9s\n",
      "  2443  1804 -979.00708   24  116 11196.9978 -4186.7138   137%  50.1   10s\n",
      "H 4850  2686                    6560.1356394 -4132.0983   163%  50.0   11s\n",
      "H 6030  2845                    6245.6924927 -4116.7075   166%  47.4   11s\n",
      "H 6035  2713                    6091.5922827 -4116.7075   168%  47.4   11s\n",
      "* 6843  3209             159    6037.3136871 -4082.6411   168%  46.2   11s\n",
      " 24121 16825 -1965.0718   26  112 6037.31369 -3090.8380   151%  33.1   15s\n",
      "*28668  9417             110     216.6142318 -2997.6196  1484%  32.1   15s\n",
      "H30531  8825                      98.6907655 -2990.0049  3130%  31.5   16s\n",
      " 38924 13998 -1504.7064   52  128   98.69077 -2906.4270  3045%  29.4   26s\n",
      " 38935 14005 -1242.4358   52  133   98.69077 -2906.4270  3045%  29.4   30s\n",
      " 38942 14010 -2650.9222   46  132   98.69077 -2906.4270  3045%  29.4   35s\n",
      " 38953 14017 -627.34643   66  134   98.69077 -2906.4270  3045%  29.4   40s\n",
      " 38965 14025 -156.80261   42  134   98.69077 -2906.4270  3045%  29.4   45s\n",
      " 38975 14032 -169.81213   28  134   98.69077 -2906.4270  3045%  29.4   50s\n",
      "*40206 13817             137      58.5387784 -2906.4270  5065%  30.8   52s\n",
      "H44147 13272                    -324.9826914 -2584.5797   695%  32.0   53s\n",
      "H44158 12588                    -347.1229297 -2556.7696   637%  32.0   53s\n",
      " 49510 12925 -908.30107   48  103 -347.12293 -1978.6021   470%  34.4   55s\n",
      " 62271 10399     cutoff   55      -347.12293 -1268.5112   265%  38.8   60s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 16\n",
      "  MIR: 430\n",
      "  Flow cover: 161\n",
      "  RLT: 823\n",
      "  Relax-and-lift: 70\n",
      "\n",
      "Explored 83179 nodes (3109707 simplex iterations) in 64.90 seconds (151.85 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: -347.123 -324.983 58.5388 ... 11197\n",
      "No other solutions better than -347.123\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective -3.471229297290e+02, best bound -3.471229297290e+02, gap 0.0000%\n",
      "[CHECK MLP] obj(x_ip)=-347.122  ip_y=-347.123  rel_err=2.476e-06\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-0.0226  std(mean)=6.07  min=-10  max=10\n",
      "  y: shape=(2000,)  mean=9.91e+03  std=3.68e+03  min=1.14e+03  max=2.5e+04\n",
      "\n",
      "\n",
      "=== Run: quadratic | MaxAffine ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=17,600 n_pieces=1600\n",
      "  train: device=cpu  epochs=250  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAApXxJREFUeJzs3Qd4U1UbB/B/94AOdoECZW9KWbKHyFK2TBVBREWZ4hYVcaEiCCrDjQoCooAsZU+RPaXsXSiU2Ul3vuc9+VLSNGnTNmnS5P97nkBzc5uc3KT33vee97zHRaPRaEBEREREREREFudq+ackIiIiIiIiIgbdRERERERERFbEnm4iIiIiIiIiK2HQTURERERERGQlDLqJiIiIiIiIrIRBNxEREREREZGVMOgmIiIiIiIishIG3URERERERERWwqCbiIiIiIiIyEoYdFvBvHnz4OLiYvK2ZcsW2NKFCxdUOz777LM8/f7+/fsxatQo1K9fH35+fihTpgweeughbNq0Kcu67777rtFt4O3tbfS5Fy1ahIYNG6rHy5Urh/HjxyMuLs7oumlpaShdujQ+//xz9fP06dPRtWtXBAcHw9fXF7Vr18brr7+Ou3fvZvldU5/Nxx9/nGXdqKgoDBs2DCVLllTP26JFC2zcuDFX29oWn7m0OSQkxKz1pI3yWRrb1hcvXoSrq6taRz5PfcePH8eQIUNQpUoV9ZnJNmrUqBFGjx6NmJiYLK9h6pZfly9fRp8+fVQ7ihQpgoCAAISFheGrr75CamqqWc+xZ88edOnSRW2HokWLokOHDvjnn3+yrJfd+6hVq5bJ5w8PD4eXl5dab9++fbCGL7/8UrVBXqdy5cqYPHkyUlJSMq2zdOlSDB48GNWqVYOPj4/6jjz++OM4ffp0rl6rY8eOGDlyJAqrtm3bqv0LEdk/2b/L/srY8VxH9mMeHh64fv262c9r7LhmDz766CMsX77c6HFE2ivnFgXt559/RqlSpRAbG1tgrxkREaH20+3atUNgYKD6vOQc25Ccb3z44Ydo3749goKC1DFczlE/+eQTJCYmZln/zJkz6tylYsWK6ntVtWpVTJgwAbdu3cq0nqzTu3dvq75Hch7utm6AI/vxxx+NnoTXqVMHhdnChQtVgDJ8+HCEhoYiPj4ec+fOVSfhP/30E5588sksv/P333+rQEhHgjhDCxYswBNPPIERI0aoQPrUqVN47bXX1EFm3bp1Wdbftm0bbty4gb59++LevXvqQCTBhPy+BH8HDhzABx98gJUrV6ogR3as+vr164eXXnop0zLZAetLSkpS70sO9DNnzlRB/qxZs1Rwv2HDBnUgcARyoiLB6eLFi/H0009n+R5LIKofRIuDBw+iVatW6uLGO++8o4K3mzdv4vDhw+riycsvvwx/f/+M9WX7G7swYwnyHZTXevvtt9VnmJycjDVr1mDMmDE4dOgQvvvuu2x/f+/evSoIa9asGX755RdoNBp8+umn6rPfvHmzutCi8++//2b5/d27d6sTAzkxNEYuCsnfi3wvr169CmuQEw55/3KhqXPnzuo9vfXWW7hy5Qq++eabjPXkJEROSiZOnKguUsgFCznBk4slu3btQt26dXN8rT///FNdkJCTsMLq/fffR6dOnfD888+jZs2atm4OEWVDjksShP7666944YUXsjweHR2NZcuWoXv37qojoLCTfbKcoxgGfHI+JBdTJbg056K6pSQkJODNN99U52RyPlBQJDiWc0PpjHn44YfV+acxly5dwowZM1SQLMGzBN3bt29X54Xr169XN90FfjlvbN68uTpnkOOAnDPI+cykSZPU8V46lnTnqPL7ch4v5y4PPvhggb1vclAasrgff/xRI5t27969drl1z58/r9o3derUPP3+9evXsyxLTU3VNGjQQFO1atVMyydNmqRe68aNG9k+p/x+2bJlNZ07d860fMGCBer316xZk+V3XnjhBU2TJk0yfv/mzZtZ1lmyZIn6/V9++SXTclk2atSoHN6pRjNr1iy17s6dOzOWpaSkaOrUqaNp1qyZ2dt68+bNmoI2dOhQTaVKlcxar0iRIppBgwZpWrZsmemx9PR09RzPPPOMeh/yeeo8+eST6vdiYmKMPq/8ruFrFLQBAwZo3N3dNYmJidmu16VLF02ZMmU08fHxGcvkfZUsWTLLNjFm2LBhGhcXF83p06eNPi5/a+XLl9fMnDnTKvsG+e57e3trnn322UzLP/zwQ9WuY8eOZfv3e+XKFY2Hh4fm6aefNuv15Lsv3xdb0P+M8qtevXrqu01E9k2O8eXKldM0btzY6ONz5sxR+9aVK1fm6nkNj2v2Qo6Xctw0dU5j6XOKnPars2fPVseYO3fuaApSWlpaxs9y3JT3LufYhuLi4tTN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IiIiIrISBt1EREREREREVsKgm4iIiIiIiMhKGHQTERERERERWYnDBN1SubxOnTpo2rSprZtCRERERERE5FhB96hRoxAeHo69e/fauilEREREREREjhV0ExEREREREdkbBt1EREREREREVsKgm4iIiIiIiMhK3OFgNBqN+j8mJsbWTSEiIjKL7pilO4Y5Ix6/iYjIUY/f7o5UvVxuycnJ6n6FChVs3SQiIqJciY2NRUBAgNO+d8HjNxEROdrx20XjYJfV09PTcfXqVfj5+cHFxcUiVy/kBODy5cvw9/e3SBudAbcbtx2/d4UH/15tv+3kUCwH7HLlysHV1TlHfln6+K2P33FuS3vE7yW3pT3i99I6x2+H6enWkTcbHBxs8eeVkykG3dxuBYnfOW67gsbvnG23nbP2cFv7+K2P33FuS3vE7yW3pT3i99Kyx2/nvJxOREREREREVAAYdBMRERERERFZCYPuHHh5eWHSpEnqfzIft1vecdtx2xU0fue47Rwdv+PclvaI30tuS3vE76V1OFwhNSIiIiIiIiJ7wZ5uIiIiIiIiIith0E1ERERERERkJQy6iYiIiIiIiKyEQXc2Zs+ejcqVK8Pb2xuNGzfG9u3brfU5FErvvvsuXFxcMt2CgoIyHpdyAbKOTBbv4+OD9u3b49ixY3BG27ZtQ48ePdS2kO20fPnyTI+bs62SkpIwZswYlCxZEkWKFEHPnj0REREBZ992w4YNy/I9bN68OZx9202ZMgVNmzaFn58fSpcujd69e+PkyZOZ1uH3Lu/bjt+7wunChQt4+umn1bFd9rVVq1ZVxVKTk5Nt3bRC6cMPP0TLli3h6+uLwMBAWzenUOE5ZsGcI5DljnuUPwy6TVi8eDHGjx+PiRMn4uDBg2jTpg26deuGS5cu5XOTO5a6desiMjIy43b06NGMxz799FNMnz4dX331Ffbu3asC8k6dOiE2NhbOJj4+HqGhoWpbGGPOtpLv47Jly7Bo0SLs2LEDcXFx6N69O9LS0uDM20507do10/dwzZo1mR53xm23detWjBo1Crt27cL69euRmpqKzp07q+2pw+9d3red4Peu8Dlx4gTS09Px9ddfqwubn3/+OebOnYs333zT1k0rlORiRf/+/fH888/buimFCs8xC/YcgSx33KN8kOrllFWzZs00I0eOzLSsVq1amtdff52b6/8m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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.834e-02 @ epoch 214\n",
      "\n",
      "iter=0  t=0.00s  best_y=8092.84  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=8092.84 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: 0x4a00b97b\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-05, 1e+00]\n",
      "  Objective range  [4e+03, 4e+03]\n",
      "  Bounds range     [1e+01, 1e+01]\n",
      "  RHS range        [7e-01, 1e+01]\n",
      "Presolve time: 0.00s\n",
      "Presolved: 1601 rows, 11 columns, 17610 nonzeros\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 972.6487775\n",
      "\n",
      "Root relaxation: objective -1.381076e+03, 4 iterations, 0.00 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 -1381.0763    0    3  972.64878 -1381.0763   242%     -    0s\n",
      "H    0     0                    -1375.849587 -1381.0763  0.38%     -    0s\n",
      "     0     0 -1381.0763    0    3 -1375.8496 -1381.0763  0.38%     -    0s\n",
      "\n",
      "Explored 1 nodes (4 simplex iterations) in 0.02 seconds (0.03 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: -1375.85 972.649 \n",
      "No other solutions better than -1375.85\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective -1.375849586835e+03, best bound -1.375849586835e+03, gap 0.0000%\n",
      "[CHECK MaxAffine] obj(x_ip)=-1375.85  ip_y=-1375.85  rel_err=7.262e-07\n",
      "\n",
      "--- Dataset stats (quadratic) ---\n",
      "  X: shape=(2000, 10)  mean(mean)=-0.0226  std(mean)=6.07  min=-10  max=10\n",
      "  y: shape=(2000,)  mean=9.91e+03  std=3.68e+03  min=1.14e+03  max=2.5e+04\n",
      "\n",
      "\n",
      "=== Run: quadratic | LSET ===\n",
      "  data: N=2000  train/val/test=1400/300/300  dim=10\n",
      "  model: params=17,600 n_pieces=1600 T=0.05\n",
      "  train: device=cpu  epochs=250  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAnrBJREFUeJzt3Qd4U+XbBvC7e9BFC120UDaUUbbspUxFhjLcW1Ec/HFP1E/FiRMQF27BAbhQQPbeZZW9SoFSyuimM9/1vDE1TZM2bZNm3b/rOoScnCQnJ6c55znv8z6vm0aj0YCIiIiIiIiILM7d8i9JRERERERERAy6iYiIiIiIiKyILd1EREREREREVsKgm4iIiIiIiMhKGHQTERERERERWQmDbiIiIiIiIiIrYdBNREREREREZCUMuomIiIiIiIishEE3ERERERERkZUw6LaCL7/8Em5ubianlStXwpaOHz+u1uPtt9+u1vO3bduGSZMmoV27dggMDERERASuuuoqLF++vNyyL774otFt4Ovra/S1586diw4dOqjHo6OjMXnyZGRnZxtdtri4GOHh4Xj33XfV/6dPn46hQ4ciJiYG/v7+aN26NZ566ilcunSp3HNNfTevv/56uWXT0tJw++23o169eup1e/TogWXLllVpW9viO5d1jouLM2s5WUf5Lo1t6xMnTsDd3V0tI9+nvn379uGWW25BkyZN1Hcm26hTp0548MEHkZmZWe49TE01dfLkSYwePVqtR506dRAcHIyOHTvio48+QlFRUaXPl333zjvvRKtWrdTzGzRogJEjR6p93ZBGo8Gnn36Kzp07IygoCGFhYejXrx/+/PNPo6/94Ycfqtf18fFB48aN8dJLL6GwsLDGn7m67zV//nzccMMNaNasGfz8/NQ+ctNNN+HQoUNVeq8rr7wSEydOhKPq27ev+n0hIvsnv+/ye2XseK4jv2NeXl44e/as2a9r7LhmD1577TUsXLiw3PykpCS1vnJuUdu+/vpr1K9fH1lZWbX2nikpKep3Wo6xISEh6vuSc2xDcr7x6quvon///oiMjERAQIA6R33jjTdw+fLlcssfPnxYnbs0bNhQ7VdNmzbFlClTcP78+TLLyTKjRo2y6mckF6Ihi5szZ45GNq3cbtiwodyUkZFh061+7NgxtX5vvfVWtZ7/6KOParp06aKZPn26Ztmy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pDlLCyGRM5BCRpIpIKmV1u5zbS3SBULSDCUzQ1qyiIjIOGldllZ9ae2uyQgpjkZS1aV72o033lhmVA2i6ig7jhKRnZO0cEcJuImclaSyS384qa/gqCTYlu4CVe3TTkTkaiQ1XGrpSDq8K5HaI1JXSKrNE9UUg24iIqoS6fcmfeIceagtGR9eCs3VdHgaIiJXIA0e0tpdkyrwjkZq0cixTorUEdUU08uJrIjp5UREREREro1BNxEREREREZGVML2ciIiIiIiIyEoYdBMRERERERFZiaczFj04ffo0AgMDHXYoGyIici0yeqcUKJJhzNzdXfN6OI/fRETkrMdvpwu6JeCOjY219WoQERFV2cmTJxETE+OSW47HbyIictbjt9MF3dLCrfvgMiQMERGRvcvMzFQXjHXHMFfE4zcRETnr8dvpgm5dSrkE3Ay6iYjIkbhytygev4mIyFmP367ZcYyIiIiIiIioFjDoJiIiIiIiIrISBt1EREREREREVuJ0fbqJiMh6QzoVFBRw81aDl5cXPDw8uO2IiIhcEINuIiKqlATbx44dU4E3VU9ISAgiIyNdulgaERGRK2LQTUREFdJoNDhz5oxqqZVhMdzd2TOpqtsvNzcXaWlp6n5UVBT3OCIiIhfCoJuIiCpUVFSkgsbo6Gj4+/tza1WDn5+fupXAOzw8nKnmRERELsQumytGjx6NunXr4vrrr7f1qhARubzi4mK1Dby9vV1+W9SE7oJFYWEhtyMREZELscug++GHH8bXX39t69UgIiI97ItcM9x+RERErskug+4BAwYgMDAQ9qKkRGPrVSAiIiIiIqIayi0ogsMH3atXr8aIESNU3z+5qr9w4cJyy8ycORONGzeGr68vOnfujDVr1sAefbPhOK58ZyUWJp6y9aoQEZENxcXF4b333uN3QERE5MCFTedtSUav15dj35lMxw66c3JykJCQgI8++sjo4/PmzcPkyZPx7LPPYseOHejTpw+GDRuG5ORk2Jv0zFzUS9+KTTt323pViIioivr376+ON5awZcsW3HvvvfwOiIiIHNDFnALc/+12PPnLblzMLcQ3G084dvVyCaBlMmX69Om46667cPfdd6v70nKwePFizJo1C9OmTYM9uSPtDfzPZyHePzYWeQWD4eftYetVIiIiC17xliJxnp6VHwrr16/P7U5EROSA1h1Ox5Qf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S9xxxx1GH5NK8LbaBrrq5dLCzYCbiIiswdxjl+3yv4iIiMjh3X777Sq4NjbZkgTaYzrFMOAmIiKbY9BNREREREREZCUMuomIiIiIiIishEE3ERERERERkZUw6CYiIiIiIiKyEgbdRERERERERFbi7kzjdMfHx6Nr1662XhUiIiIiIiIi5wq6J02ahKSkJGzZssXWq0JERERERETkXEE3ERERERERkb1h0E1ERERERERkJZ5wMhqNRt1mZmbaelWIiIjMojtm6Y5hrojHbyIictbjt9MF3VlZWeo2NjbW1qtCRERU5WNYcHCwS241Hr+JiMhZj99uGie7rF5SUoLTp08jMDAQbm5uFrl6IQH8yZMnERQUZJF1dAXcbtx23O8cB/9ebb/t5FAsB+zo6Gi4u7tmzy9LH7/1cR+3LG5Pbkt7xX2T27O2mXv8drqWbvmwMTExFn9dOZli0M3tVpu4z3Hb1Tbuc7bddq7awm3t47c+7uPcnvaK+ya3pz3j/lnz47drXk4nIiIiIiIiqgUMuomIiIiIiIishEF3JXx8fDB16lR1S+bjdqs+bjtuu9rGfY7bztlxH+f2tFfcN7k97Rn3T8txukJqRERERERERPaCLd1EREREREREVsKgm4iIiIiIiMhKGHQTERERERERWQmD7grMnDkTjRs3hq+vLzp37ow1a9ZY63twSC+++CLc3NzKTJGRkaWPS7kAWUYGi/fz80P//v2xd+9euKLVq1djxIgRalvIdlq4cGGZx83ZVvn5+XjooYdQr1491KlTB9deey1SUlLg6tvu9ttvL7cfdu/eHa6+7aZNm4auXbsiMDAQ4eHhGDVqFA4cOFBmGe531d923O8c0/Hjx3HXXXepY7v81jZt2lQVSy0oKLD1qjmsV199FT179oS/vz9CQkJsvToOh+eatXOuQJY9BlLVMeg2Yd68eZg8eTKeffZZ7NixA3369MGwYcOQnJxcjc3svNq0aYMzZ86UTrt37y597M0338T06dPx0UcfYcuWLSogHzRoELKysuBqcnJykJCQoLaFMeZsK9kfFyxYgLlz52Lt2rXIzs7GNddcg+LiYrjythNDhw4tsx8uWrSozOOuuO1WrVqFSZMmYePGjVi6dCmKioowePBgtT11uN9Vf9sJ7neOZ//+/SgpKcHs2bPVhc13330XH3/8MZ555hlbr5rDkgsWY8eOxf3332/rVXE4PNes3XMFsuwxkKpIqpdTed26ddNMnDixzLxWrVppnnrqKW6uf02dOlWTkJBgdHuUlJRoIiMjNa+//nrpvMuXL2uCg4M1H3/8sUtvQ/mzW7BgQZW21aVLlzReXl6auXPnli5z6tQpjbu7u+bvv//WuOq2E7fddptm5MiRJp/DbaeVlpamtt+qVavUfe531d923O+cy5tvvqlp3LixrVfD4c2ZM0cdt8h8PNesvXMFsuwxkKqOLd0mrtpu27ZNXdXRJ/fXr19f1esaTu3QoUMqlUdS9SZMmICjR4+q+ceOHUNqamqZbShj/fXr14/b0IA520r2x8LCwjLLyHZv27YttyeAlStXqhSoFi1a4J577kFaWlrpduK208rIyFC3oaGh3O9quO10uN85z/dr+N0SWRvPNcnRj4FUNQy6jUhPT1dppxEREWXmy30JjkjriiuuwNdff43Fixfj008/VdtG+nWdP3++dDtxG1bOnG0lt97e3qhbty73SQPS7eO7777D8uXL8c4776j0/IEDB6p+3Nx2WnLhf8qUKejdu7e6UMP9rmbbjvud8zhy5Ag+/PBDTJw40darQi6G55rkyMdAqjrPajzHZUghBsMdz3Ceqwc7Ou3atUOPHj1UUZqvvvqqtJAVt6H5qrOtuE8C48ePL90eckDo0qULGjVqhD///BNjxozhtgPw4IMPYteuXao/O/c7y2w77nf2RQpRvvTSSxUuIxfk5PdB5/Tp06pfvvRHvvvuu2thLZ17e1L18DyJHPX8gaqGQbcRUuHYw8OjXKu2pKwatkbSf6QqtATfknIulQ6FbMOoqChuwwroKr5XtK1kGUlFu3jxYpnWbllGsgvoP7INJeiW/ZDbDqpq+2+//aYqu8bExHC/s8C2M4b7ne1PDKWLU0Xi4uLKBNwDBgxQF4s/+eSTWlhD596eVHU81yRnOgZS5ZheboSk8coQYVKxT5/cZ4BjmqTz7tu3T518Sh9vCRT1t6EEjVIRkduwLHO2leyPXl5eZZaRKt179uzh9jQg3RtOnjxZegHDVbedZEHIifP8+fNV6r3sZ/q431V/2xnD/c72AUyrVq0qnGT4T3Hq1Ck1LGOnTp0wZ84cuLvzVKgm25Oqh+ea5EzHQDJDNYqvuQSpEi3Voj///HNNUlKSZvLkyZo6depojh8/butVsxuPPvqoZuXKlZqjR49qNm7cqLnmmms0gYGBpdtIqnFLJdP58+drdu/erbnhhhs0UVFRmszMTI2rycrK0uzYsUNN8mc3ffp09f8TJ06Yva2kmn5MTIzmn3/+0Wzfvl0zcOBAVT2+qKhI46rbTh6T/XD9+vWaY8eOaVasWKHp0aOHpkGDBi6/7e6//361T8nf6JkzZ0qn3Nzc0m3L/a562477neOSUR+aNWumfj9TUlLKfL9UPfJbLL/JL730kiYgIKD091r+TqhiPNesvfMssuz5A1Udg+4KzJgxQ9OoUSONt7e3plOnTiyVb2D8+PEqMJSLE9HR0ZoxY8Zo9u7dW/q4DEkkw4rJcFg+Pj6avn37qoDSFUkwKAcBw0mGuzJ3W+Xl5WkefPBBTWhoqMbPz09d5EhOTta48raTA8DgwYM19evXV/thw4YN1XzD7eKK287YNpNJhvXR4X5XvW3H/c5xyXdo6vul6pHfXGPbU367qXI816yd8yyy7PkDVZ2b/GNOizgRERERERERVQ07MhERERERERFZCYNuIiIiIiIiIith0E1ERERERERkJQy6iYiIiIiIiKyEQTcRERERERGRlTDoJiIiIiIiIrISBt1EREREREREVsKgm4iIiIiIiMhKGHQTEREREbmIgoICNGvWDOvWrYO96tq1K+bPn2/r1SCyGAbdRERERERW9uKLL6JDhw42386ffPIJGjVqhF69esFePf/883jqqadQUlJi61UhsggG3UREREREdqKwsNCqr//hhx/i7rvvRm20qFfX1VdfjYyMDCxevNii60RkKwy6iYiIiIgq8fXXXyMsLAz5+fll5l933XW49dZbK3zul19+iZdeegk7d+6Em5ubmmSekP9//PHHGDlyJOrUqYNXXnlFPRYSElLmNRYuXKiW1ff777+jc+fO8PX1RZMmTdR7FBUVmVyP7du34/Dhwyqo1Tl+/Lh6XUnnHjBgAPz9/ZGQkIANGzaUee4vv/yCNm3awMfHB3FxcXjnnXfKPC7zZN1vv/12BAcH45577in9HH/88QdatmypXvv6669HTk4OvvrqK/WcunXr4qGHHkJxcXHpa3l4eGD48OH44YcfKtyuRI6CQTcRERERUSXGjh2rAsPffvutdF56eroKKO+4444Knzt+/Hg8+uijKmg9c+aMmmSeztSpU1XQvXv3btx5551mfRfSCnzzzTfj4YcfRlJSEmbPnq2C3FdffdXkc1avXo0WLVogKCio3GPPPvssHnvsMSQmJqplbrjhhtIAftu2bRg3bhwmTJig1lFS5SUFXHfhQOett95C27Zt1fLyuMjNzcUHH3yAuXPn4u+//8bKlSsxZswYLFq0SE3ffPONSnn/+eefy7xWt27dsGbNGrO2BZG987T1ChARERER2Ts/Pz/ceOONmDNnjgrAxXfffYeYmBj079+/0ucGBATA09MTkZGR5R6X1zU32NaR4Fr6Pd92223qvrR0/9///R+eeOIJFcQbI63a0dHRRh+TgFvXAi4t5nKBQFrFW7VqhenTp+PKK68sDaQlKJdAX4JsadnWGThwoHodnbVr16p0+VmzZqFp06ZqnrR0S6B99uxZtU3i4+NVC/uKFSvKXIho0KABkpOTVb9ud3e2E5Jj4x5MRERERGQGSZlesmQJTp06pe5LAC5Bp2Had1V16dKlys+R1uSXX35ZBa66SdZPWtGlddmYvLw8lYpuTPv27Uv/HxUVpW7T0tLU7b59+8oVXpP7hw4dKpMWbuxzSEq5LuAWERERKq1c1ld/nu699C9USMBtmM5P5IjY0k1EREREZIaOHTuq/s7Sv3vIkCEq1Vr6VdeU9OXWJy27Go2mwgJrEpBKi7SkahsyFVjXq1dPrbMxXl5epf/XXUTQVQ+XdTG8sGC4fsY+h+Hr6l7b2DzDSuUXLlxQAbsE30SOjkE3EREREZGZpPL3u+++q1q7r7rqKsTGxpr1PG9v7zKtwhWpX78+srKyVMExXSArfa31derUCQcOHFBjblflooGkehsLoisiKeCSKq5v/fr1Ks1cip5Zw549e9RnJHIGTC8nIiIiIjLTTTfdpALuTz/9tEr9sCWl+tixYyp4lgJsFaVNX3HFFaqV95lnnlH9qr///vtyRcteeOEF1eIuRc327t2rUsDnzZuH5557zuTrSt9pCeRl+aqQInDLli1TfcYPHjyoKo9/9NFHZfpvW5oUURs8eLDVXp+oNjHoJiIiIiIyk1T+lmHCpE/yqFGjzN5u8pyhQ4eqwFdasisaDis0NBTffvutqu7drl07tawE1/okvV0qpy9duhRdu3ZF9+7dVcGzRo0amXxdGfJM0tGlAFxVSIvzjz/+qCqQS3VyCfilP7l+ETVLkosa0pJeWVV4IkfhpjHWIYOIiIiIiIwaNGgQWrdurYbCcjTSp1vS4qUFPTAwEPbo8ccfR0ZGhhpKjMgZsKWbiIiIiMgMUtxLWnuXL1+OSZMmOeQ2k5bzN998Uw0fZq/Cw8NVKjuRs2BLNxERERGRmf2yL168qMarNuzPLONanzhxwujzZs+erfqCE5FrYtBNRERERFRDEnAbDuulPw61vaZyE5H1MegmIiIiIiIishL26SYiIiIiIiKyEgbdRERERERERFbCoJuIiIiIiIjIShh0ExEREREREVkJg24iIiIiIiIiK2HQTURERERERGQlDLqJiIiIiIiIrIRBNxERERERERGs4/8BnS20xPeRdlUAAAAASUVORK5CYII=",
      "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.170e-02 @ epoch 224\n",
      "\n",
      "iter=0  t=0.00s  best_y=8095.92  x=[5, -2, 1, -1, 7, 3, 0, 2, -3, -1]\n",
      "STOP: local minimum. best_y=8095.92 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",
      "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: 0x02cd1392\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     [8e-04, 4e+03]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-12, 3e+04]\n",
      "  RHS range        [1e+01, 1e+04]\n",
      "Warning: x < 1e-10 in domain of log(x).\n",
      "         Setting lower bound to 1e-10.\n",
      "Presolve removed 3202 rows and 1602 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 9607 rows, 3214 columns, 36821 nonzeros\n",
      "Presolved model has 1601 nonlinear constraint(s)\n",
      "\n",
      "Solving non-convex MINLP\n",
      "\n",
      "Variable types: 3204 continuous, 10 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective -6.622416e+03, 1611 iterations, 0.02 seconds (0.08 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 -6622.4165    0   17          - -6622.4165      -     -    0s\n",
      "     0     2 -6618.4321    0   17          - -6618.4321      -     -    0s\n",
      "  1134   878 -1854.7204   56    2          - -6606.2875      -   6.2    5s\n",
      "  2614  1952 -1977.0918   34    6          - -6191.1986      -  10.3   10s\n",
      "  2875  1987 -1955.6739   54    2          - -6191.1986      -  13.8   15s\n",
      "* 3030  1918              64    -1935.269738 -6191.1986   220%  14.3   16s\n",
      "* 3040  1834              63    -1948.294586 -6191.1986   218%  14.2   16s\n",
      "* 3384  1841              49    -2378.491376 -4765.5068   100%  13.8   16s\n",
      "* 3515  1807              53    -2668.976106 -4765.5068  78.6%  13.3   16s\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=2000, dim=10, eigen_min=1, eigen_max=20.0,\n",
    "    x_min=-10, x_max=10, noise_std=0.0, seed=0\n",
    ")\n",
    "in_dim = int(dataset_params[\"dim\"])\n",
    "\n",
    "train_base = dict(\n",
    "    epochs=250,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=1,\n",
    "    plot_points=128,\n",
    "    plot_chunk=128,\n",
    ")\n",
    "\n",
    "# ---- DFN (learnable A) ----\n",
    "dfn_params = dict(\n",
    "    input_dim=in_dim, layer_sizes=[16, 128, 16], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=0.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",
    "    (\"DFN\",        \"DFN\", dfn_params),\n",
    "    (\"DFN_AfixI\",  \"DFN\", dfn_Afix_params),\n",
    "    (\"MLP\",        \"MLP\", mlp_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
}
