{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f5b14808",
   "metadata": {},
   "source": [
    "# DFN"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2efb5921",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce8269a4",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "from __future__ import annotations\n",
    "\n",
    "import cppimport\n",
    "\n",
    "import sys, time, math, io, contextlib\n",
    "from pathlib import Path\n",
    "from typing import Optional, List, Tuple, Dict, Any\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from IPython.display import display\n",
    "\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "_TOL = 1e-9"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "417583e0",
   "metadata": {},
   "source": [
    "## LEMON"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "62767112",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "repo = Path().resolve().parent\n",
    "if str(repo) not in sys.path:\n",
    "    sys.path.insert(0, str(repo))\n",
    "\n",
    "lemon_mcf = cppimport.imp(\"lemon_mcf\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15e6bd1b",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "88381d28",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'status': 1, 'flow': array([1., 2., 0.]), 'potential': array([-2.,  0., -1.]), 'reduced_cost': array([0., 0., 4.]), 'at_capacity': array([False,  True, False]), 'total_cost': 4.0}\n",
      "{'value': 4.0, 'flow': array([2., 2., 2., 2.])}\n"
     ]
    }
   ],
   "source": [
    "n = 3\n",
    "src    = np.array([0, 0, 1], dtype=np.int64)\n",
    "dst    = np.array([1, 2, 2], dtype=np.int64)\n",
    "cost   = np.array([2.0, 1.0, 3.0], dtype=np.float64)\n",
    "cap    = np.array([5.0, 2.0, 4.0], dtype=np.float64)\n",
    "supply = np.array([3.0, -1.0, -2.0], dtype=np.float64)\n",
    "\n",
    "out_min_cost_flow = lemon_mcf.solve_mcf(n, src, dst, cost, cap, supply)\n",
    "print(out_min_cost_flow)\n",
    "\n",
    "n = 4\n",
    "src = np.array([0,0,1,2], dtype=np.int64)\n",
    "dst = np.array([1,2,3,3], dtype=np.int64)\n",
    "cap = np.array([3.0,2.0,2.0,4.0], dtype=np.float64)\n",
    "out_max_flow = lemon_mcf.max_flow(n, src, dst, cap, 0, 3)\n",
    "print(out_max_flow)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75235271",
   "metadata": {},
   "source": [
    "## Dataset generators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67763cc2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def make_mdvsp_dataset(\n",
    "    K: int,\n",
    "    filename: str,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    max_trips=None,\n",
    "    max_succ=None,\n",
    "):\n",
    "    \"\"\"Multiple-Depot Vehicle Scheduling (MDVSP) dataset.\n",
    "\n",
    "    Returns:\n",
    "      X: (K, m) integer-ish capacities (float32)\n",
    "      y: (K,) min-cost-flow objective values (float32)\n",
    "      gt: dict containing the fixed network pieces (for later evaluation)\n",
    "    \"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "\n",
    "    with open(filename) as f:\n",
    "        m, n, l = map(int, f.readline().split())\n",
    "        f.readline()  # blank line\n",
    "        trips = np.loadtxt(f, max_rows=n, dtype=np.int64)[:max_trips]\n",
    "        D = np.loadtxt(f, max_rows=l, dtype=np.int64)\n",
    "\n",
    "    p, s, q, e = trips.T\n",
    "    ntr = len(trips)\n",
    "\n",
    "    # node ids\n",
    "    SS = 0\n",
    "    depS = 1 + np.arange(m)\n",
    "    depT = 1 + m + np.arange(m)\n",
    "    trS  = 1 + 2*m + np.arange(ntr)\n",
    "    trT  = 1 + 2*m + ntr + np.arange(ntr)\n",
    "    TT = 1 + 2*m + 2*ntr\n",
    "    N = TT + 1\n",
    "\n",
    "    src, dst, cost, cap = [], [], [], []\n",
    "\n",
    "    # depot boundary arcs (capacity is what we learn/provide per sample)\n",
    "    for d in range(m):\n",
    "        src += [SS, int(depT[d])]\n",
    "        dst += [int(depS[d]), TT]\n",
    "        cost += [0.0, 0.0]\n",
    "        cap  += [0.0, 0.0]\n",
    "    idxSS = np.arange(0, 2*m, 2)  # arcs SS->depS\n",
    "    idxTT = np.arange(1, 2*m, 2)  # arcs depT->TT\n",
    "\n",
    "    # trip arcs (always cap=1)\n",
    "    src += trS.tolist()\n",
    "    dst += trT.tolist()\n",
    "    cost += [0.0] * ntr\n",
    "    cap  += [1.0] * ntr\n",
    "\n",
    "    # depot-to-trip and trip-to-depot arcs\n",
    "    for d in range(m):\n",
    "        # depS -> trS\n",
    "        src += [int(depS[d])] * ntr\n",
    "        dst += trS.tolist()\n",
    "        cost += (5000 + 10 * D[d, p]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "        # trT -> depT\n",
    "        src += trT.tolist()\n",
    "        dst += [int(depT[d])] * ntr\n",
    "        cost += (5000 + 10 * D[q, d]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "    # feasible trip successor arcs (trT -> next trS)\n",
    "    order = np.argsort(s)\n",
    "    p2, s2 = p[order], s[order]\n",
    "    max_succ_eff = ntr if max_succ is None else int(max_succ)\n",
    "\n",
    "    for i in range(ntr):\n",
    "        travel = D[q[i], p2]                          # time from trip i end depot -> next trip start depot\n",
    "        feas = np.flatnonzero(s2 >= e[i] + travel)[:max_succ_eff]\n",
    "        j = order[feas]\n",
    "        if j.size:\n",
    "            src += [int(trT[i])] * j.size\n",
    "            dst += trS[j].tolist()\n",
    "            cost += (8 * travel[feas] + 2 * (s[j] - e[i])).astype(float).tolist()\n",
    "            cap  += [1.0] * j.size\n",
    "\n",
    "    src = np.asarray(src, dtype=np.int64)\n",
    "    dst = np.asarray(dst, dtype=np.int64)\n",
    "    cost = np.asarray(cost, dtype=np.float64)\n",
    "    cap0 = np.asarray(cap, dtype=np.float64)\n",
    "\n",
    "    # sample capacities X and compute y via max-flow + min-cost-flow\n",
    "    X = rng.integers(x_min, np.asarray(x_max) + 1, size=(K, m)).astype(np.float64)\n",
    "    y = np.empty(K, dtype=np.float64)\n",
    "\n",
    "    for k in range(K):\n",
    "        cap_k = cap0.copy()\n",
    "        cap_k[idxSS] = X[k]\n",
    "        cap_k[idxTT] = X[k]\n",
    "\n",
    "        Fmax = lemon_mcf.max_flow(N, src, dst, cap_k, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, dtype=np.float64)\n",
    "        supply[SS] = Fmax\n",
    "        supply[TT] = -Fmax\n",
    "\n",
    "        y[k] = lemon_mcf.solve_mcf(N, src, dst, cost, cap_k, supply)[\"total_cost\"]\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = dict(\n",
    "        type=\"mdvsp\", N=int(N), SS=int(SS), TT=int(TT),\n",
    "        src=src, dst=dst, cost=cost, cap0=cap0, idxSS=idxSS, idxTT=idxTT\n",
    "    )\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n",
    "\n",
    "\n",
    "def generate_bipartite_subset_matching_dataset(\n",
    "    K: int, num_nodes: int, c_min: int, c_max: int, noise_std: float = 0.0, seed: int = 0\n",
    "):\n",
    "    \"\"\"Assignment-style dataset: choose a subset of left nodes, match to right nodes with min cost.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    C = rng.integers(c_min, c_max + 1, size=(num_nodes, num_nodes)).astype(np.float32)\n",
    "\n",
    "    X = np.zeros((K, num_nodes), dtype=np.float32)\n",
    "    y = np.zeros((K,), dtype=np.float32)\n",
    "\n",
    "    for k in range(K):\n",
    "        mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        while not mask.any():\n",
    "            mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        idx = np.flatnonzero(mask)\n",
    "        X[k, idx] = 1.0\n",
    "\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        y[k] = C[idx, :][r, c].sum()\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = {\"type\": \"assignment\", \"C\": C.astype(np.float32)}\n",
    "    return X, y, gt\n",
    "\n",
    "\n",
    "def generate_convex_quadratic_dataset(\n",
    "    K: int,\n",
    "    dim: int,\n",
    "    eigen_min: float,\n",
    "    eigen_max: float,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    x_star_zero: bool = False,\n",
    "):\n",
    "    \"\"\"y = (x - x*)^T Q (x - x*) + noise, with Q symmetric PSD.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    U, R = np.linalg.qr(rng.standard_normal((dim, dim)))\n",
    "    U *= np.sign(np.diag(R) + 1e-12)\n",
    "    Q = U @ np.diag(rng.uniform(eigen_min, eigen_max, dim)) @ U.T\n",
    "\n",
    "    x_star = np.zeros(dim, dtype=np.int64) if x_star_zero else rng.integers(x_min, x_max + 1, size=dim)\n",
    "\n",
    "    X = rng.integers(x_min, x_max + 1, size=(K, dim)).astype(np.float32)\n",
    "    d = X - x_star\n",
    "    y = np.einsum(\"bi,ij,bj->b\", d, Q, d) + noise_std * rng.normal(size=K)\n",
    "\n",
    "    gt = {\"type\": \"quadratic\", \"Q\": Q.astype(np.float32), \"x_star\": x_star.astype(np.int64)}\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1dfc62e4",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "89201b4a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 8) (50,) \n",
      " [[ 5.  5.  8. 10.  0.  1.  9. 10.]\n",
      " [ 2.  3.  9.  4.  3.  9.  2.  4.]\n",
      " [ 7.  6.  0.  0.  9.  8.  9.  5.]\n",
      " [ 8.  3.  4.  8.  1.  3.  1.  4.]\n",
      " [10.  1.  4.  4.  9.  2.  5.  2.]] \n",
      " [489783.12 366182.16 447190.56 325780.94 376081.84] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[0. 1. 1. 0. 0. 0. 0. 1. 0. 1.]\n",
      " [1. 0. 0. 0. 0. 0. 1. 1. 0. 0.]\n",
      " [0. 1. 0. 0. 1. 0. 1. 0. 1. 1.]\n",
      " [1. 1. 0. 0. 1. 1. 1. 1. 0. 1.]\n",
      " [0. 1. 0. 1. 1. 0. 0. 0. 1. 0.]] \n",
      " [ 9.  4. 13. 17. 11.] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[-47. -87.  -1.  69.  25. -87.  30. -31. -55. -14.]\n",
      " [ 75.  94. -72.  13.  53. -48. -46. -52. -58.  78.]\n",
      " [-57. -55. -75. -75.  56. -43.  61.  17.  72.  11.]\n",
      " [ 53.  62. -88.  12.  -9. -43. -10. -18.  -2.  64.]\n",
      " [ 65.  25.  42.  92.  28. -26. -84.  11. -54.  19.]] \n",
      " [1.5913905e+06 9.7035825e+05 7.8526031e+05 5.9535256e+05 1.0773938e+06] \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# NOTE: MDVSP requires that `filename` exists on disk.\n",
    "X, y, _ = make_mdvsp_dataset(\n",
    "    K=50, filename=\"RN-8-3000-05.dat\", x_min=0, x_max=10, noise_std=1.0, seed=1, max_trips=200, max_succ=5\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_bipartite_subset_matching_dataset(\n",
    "    K=50, num_nodes=10, c_min=1, c_max=10, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_convex_quadratic_dataset(\n",
    "    K=50, dim=10, eigen_min=1.0, eigen_max=20.0, x_min=-100, x_max=100, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70071f5f",
   "metadata": {},
   "source": [
    "## Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "07278db8",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _ste_round(x: torch.Tensor) -> torch.Tensor:\n",
    "    return x + (torch.round(x) - x).detach()\n",
    "\n",
    "class _MCFValue(torch.autograd.Function):\n",
    "    \n",
    "    @staticmethod\n",
    "    def forward(ctx, n_nodes, src, dst, cost, cap, supply):\n",
    "        n = int(n_nodes)\n",
    "\n",
    "        src = src.to(dtype=torch.int64).contiguous()\n",
    "        dst = dst.to(dtype=torch.int64).contiguous()\n",
    "\n",
    "        m = int(src.numel())\n",
    "        if (dst.numel() != m) or (cost.numel() != m) or (cap.numel() != m) or (supply.numel() != n):\n",
    "            raise ValueError(\"Bad shapes for MCF inputs.\")\n",
    "        if torch.abs(supply.double().sum()) > _TOL:\n",
    "            raise ValueError(\"Require sum(supply)=0\")\n",
    "\n",
    "        def as_np(t: torch.Tensor, dtype):\n",
    "            return t.detach().cpu().contiguous().view(-1).numpy().astype(dtype, copy=False)\n",
    "\n",
    "        out = lemon_mcf.solve_mcf(\n",
    "            n,\n",
    "            as_np(src, np.int64),\n",
    "            as_np(dst, np.int64),\n",
    "            as_np(cost, np.float64),\n",
    "            as_np(cap, np.float64),\n",
    "            as_np(supply, np.float64),\n",
    "            tol=_TOL,\n",
    "        )\n",
    "        if out[\"status\"] != 1:\n",
    "            raise RuntimeError(f\"LEMON failed (status={out['status']})\")\n",
    "\n",
    "        flow = out[\"flow\"]\n",
    "        pot = out[\"potential\"]\n",
    "        red = out[\"reduced_cost\"]\n",
    "        at = out.get(\"at_cap\", out.get(\"at_capacity\", None))\n",
    "        if at is None:\n",
    "            at = np.abs(flow - as_np(cap, np.float64)) <= _TOL\n",
    "\n",
    "        ctx.flow, ctx.pot, ctx.red, ctx.at = flow, pot, red, at\n",
    "        return cost.new_tensor(float(out[\"total_cost\"]))\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, g):\n",
    "        dev, dt = g.device, g.dtype\n",
    "        flow = torch.as_tensor(ctx.flow, device=dev, dtype=dt)\n",
    "        pot  = torch.as_tensor(ctx.pot,  device=dev, dtype=dt)\n",
    "        red  = torch.as_tensor(ctx.red,  device=dev, dtype=dt)\n",
    "        at   = torch.as_tensor(ctx.at,   device=dev, dtype=torch.bool)\n",
    "\n",
    "        grad_cost = flow\n",
    "        grad_cap  = torch.where(at, red, torch.zeros_like(red))\n",
    "        grad_sup  = pot.mean() - pot\n",
    "\n",
    "        return None, None, None, grad_cost * g, grad_cap * g, grad_sup * g\n",
    "\n",
    "\n",
    "class DFN(nn.Module):\n",
    "    def __init__(\n",
    "        self,\n",
    "        input_dim: int,\n",
    "        layer_sizes,\n",
    "        p_list,\n",
    "        big_cost: float = 1e6,\n",
    "        big_cap: float = 1e6,\n",
    "        seed: int = 0,\n",
    "        A_fixed=None,\n",
    "        alpha: float = 1e-6,\n",
    "        beta: float = -0.0,\n",
    "    ):\n",
    "        super().__init__()\n",
    "        self.alpha = float(alpha)\n",
    "        self.beta  = float(beta)\n",
    "\n",
    "        layer_sizes = list(map(int, layer_sizes))\n",
    "        if len(layer_sizes) < 2 or len(p_list) != len(layer_sizes) - 1:\n",
    "            raise ValueError(\"Need len(layer_sizes)>=2 and len(p_list)=len(layer_sizes)-1\")\n",
    "\n",
    "        self.n = int(sum(layer_sizes))\n",
    "        if self.n <= 0:\n",
    "            raise ValueError(\"sum(layer_sizes) must be > 0\")\n",
    "\n",
    "        # node indices per layer\n",
    "        layers, off = [], 0\n",
    "        for s in layer_sizes:\n",
    "            layers.append(torch.arange(off, off + s, dtype=torch.long))\n",
    "            off += s\n",
    "\n",
    "        L1, LK = layers[0], layers[-1]\n",
    "        if L1.numel() == 0 or LK.numel() == 0:\n",
    "            raise ValueError(\"First/last layer must be non-empty.\")\n",
    "\n",
    "        self.fix_node = int(LK[-1].item())\n",
    "        boundary = torch.cat([L1, LK[:-1]], 0)\n",
    "        self.register_buffer(\"boundary\", boundary)\n",
    "\n",
    "        gen = torch.Generator().manual_seed(int(seed))\n",
    "\n",
    "        def bipartite(U: torch.Tensor, V: torch.Tensor):\n",
    "            su, sv = int(U.numel()), int(V.numel())\n",
    "            return U.repeat_interleave(sv), V.repeat(su)\n",
    "\n",
    "        def sample_edges(U, V, p: float):\n",
    "            s, t = bipartite(U, V)\n",
    "            if p < 1.0:\n",
    "                keep = torch.rand(s.numel(), generator=gen) < float(p)\n",
    "                s, t = s[keep], t[keep]\n",
    "            return s, t\n",
    "\n",
    "        # learnable arcs between consecutive layers (both directions)\n",
    "        sf, tf, sb, tb = [], [], [], []\n",
    "        for i, p in enumerate(map(float, p_list)):\n",
    "            if not (0.0 <= p <= 1.0):\n",
    "                raise ValueError(\"p_list entries must be in [0,1]\")\n",
    "\n",
    "            s, t = sample_edges(layers[i], layers[i + 1], p)  # forward\n",
    "            sf.append(s); tf.append(t)\n",
    "\n",
    "            s, t = sample_edges(layers[i + 1], layers[i], p)  # backward\n",
    "            sb.append(s); tb.append(t)\n",
    "\n",
    "        src_param = torch.cat([torch.cat(sf, 0), torch.cat(sb, 0)], 0)\n",
    "        dst_param = torch.cat([torch.cat(tf, 0), torch.cat(tb, 0)], 0)\n",
    "        if src_param.numel() == 0:\n",
    "            raise ValueError(\"No learnable arcs (increase p_list / layer sizes).\")\n",
    "\n",
    "        s1, t1 = bipartite(L1, LK)\n",
    "        s2, t2 = bipartite(LK, L1)\n",
    "        src_fixed = torch.cat([s1, s2], 0)\n",
    "        dst_fixed = torch.cat([t1, t2], 0)\n",
    "        m_fixed = int(src_fixed.numel())\n",
    "\n",
    "        self.register_buffer(\"src\", torch.cat([src_param, src_fixed], 0))\n",
    "        self.register_buffer(\"dst\", torch.cat([dst_param, dst_fixed], 0))\n",
    "        self.register_buffer(\"cap_fixed\",  torch.full((m_fixed,), float(big_cap),  dtype=torch.float32))\n",
    "        self.register_buffer(\"cost_fixed\", torch.full((m_fixed,), float(big_cost), dtype=torch.float32))\n",
    "\n",
    "        nb = int(boundary.numel())\n",
    "        input_dim = int(input_dim)\n",
    "\n",
    "        m_param = int(src_param.numel())\n",
    "        self.cap_raw  = nn.Parameter(torch.zeros(m_param) + 0.542)\n",
    "        self.cost_raw = nn.Parameter(torch.randn(m_param) + 1.0)\n",
    "        self.b_raw    = nn.Parameter(torch.zeros(nb))\n",
    "\n",
    "        if A_fixed is None:\n",
    "            A = torch.zeros(nb, input_dim)\n",
    "            rows = torch.arange(nb)\n",
    "            A[rows, rows % input_dim] = 1.0\n",
    "            self.A = nn.Parameter(A)\n",
    "        else:\n",
    "            A_fixed = torch.as_tensor(A_fixed, dtype=torch.float32)\n",
    "            if A_fixed.shape != (nb, input_dim):\n",
    "                raise ValueError(f\"A_fixed must have shape {(nb, input_dim)}, got {tuple(A_fixed.shape)}\")\n",
    "            self.register_buffer(\"A\", A_fixed)\n",
    "\n",
    "    def forward(self, w: torch.Tensor) -> torch.Tensor:\n",
    "        capP  = _ste_round(F.softplus(self.cap_raw))\n",
    "        costP = self.cost_raw\n",
    "        b     = _ste_round(self.b_raw)\n",
    "        A     = _ste_round(self.A) if isinstance(self.A, nn.Parameter) else self.A\n",
    "\n",
    "        cap  = torch.cat([capP,  self.cap_fixed.to(w.device, w.dtype)], 0)\n",
    "        cost = torch.cat([costP, self.cost_fixed.to(w.device, w.dtype)], 0)\n",
    "\n",
    "        def one(w1: torch.Tensor) -> torch.Tensor:\n",
    "            supply = torch.zeros(self.n, device=w1.device, dtype=torch.float64)\n",
    "            supply[self.boundary] = (A.double() @ w1.double()) + b.double()\n",
    "            supply[self.fix_node] = -supply.sum()\n",
    "            return _MCFValue.apply(self.n, self.src, self.dst, cost, cap, supply)\n",
    "\n",
    "        out = one(w) if w.dim() == 1 else torch.stack([one(wi) for wi in w], 0)\n",
    "        return self.alpha * out + self.beta\n",
    "\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dims, out_dim):\n",
    "        super().__init__()\n",
    "        dims = [in_dim] + list(hidden_dims) + [out_dim]\n",
    "        layers = []\n",
    "        for a, b in zip(dims[:-2], dims[1:-1]):\n",
    "            layers += [nn.Linear(a, b), nn.ReLU()]\n",
    "        layers += [nn.Linear(dims[-2], dims[-1])]\n",
    "        self.net = nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.net(x)\n",
    "\n",
    "\n",
    "class MaxAffine(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int):\n",
    "        super().__init__()\n",
    "        self.W = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        return (x @ self.W.T + self.b).max(dim=1).values\n",
    "\n",
    "\n",
    "class LSET(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int, T: float = 0.01):\n",
    "        super().__init__()\n",
    "        self.T = float(T)\n",
    "        if self.T == 0.0:\n",
    "            raise ValueError(\"T must be nonzero\")\n",
    "        self.A = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        z = (x @ self.A.t() + self.b) / self.T\n",
    "        return self.T * torch.logsumexp(z, dim=-1)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7cca0120",
   "metadata": {},
   "source": [
    "## Training Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0a7db872",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _split_train_val_test(X: torch.Tensor, y: torch.Tensor, *, val_frac: float, test_frac: float, seed: int):\n",
    "    N = int(X.shape[0])\n",
    "    n_test = int(round(test_frac * N))\n",
    "    n_val  = int(round(val_frac  * N))\n",
    "    n_train = N - n_val - n_test\n",
    "    if n_train <= 0:\n",
    "        raise ValueError(\"splits too large; train set would be empty\")\n",
    "\n",
    "    g = torch.Generator().manual_seed(int(seed))\n",
    "    perm = torch.randperm(N, generator=g)\n",
    "    i_tr = perm[:n_train]\n",
    "    i_va = perm[n_train:n_train + n_val]\n",
    "    i_te = perm[n_train + n_val:]\n",
    "\n",
    "    return (X[i_tr], y[i_tr]), (X[i_va], y[i_va]), (X[i_te], y[i_te])\n",
    "\n",
    "\n",
    "def _fit_standardizer(Xtr: torch.Tensor, ytr: torch.Tensor, *, eps: float):\n",
    "    x_mean = Xtr.mean(0, keepdim=True)\n",
    "    x_std  = Xtr.std(0, unbiased=False, keepdim=True)\n",
    "    x_std  = torch.where(x_std < eps, torch.ones_like(x_std), x_std)\n",
    "\n",
    "    y_mean = ytr.mean()\n",
    "    y_std  = ytr.std(unbiased=False).clamp_min(eps)\n",
    "\n",
    "    return {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std}\n",
    "\n",
    "\n",
    "def _apply_standardizer(X: torch.Tensor, y: torch.Tensor, scaler):\n",
    "    Xn = (X - scaler[\"x_mean\"]) / scaler[\"x_std\"]\n",
    "    yn = (y - scaler[\"y_mean\"]) / scaler[\"y_std\"]\n",
    "    return Xn, yn\n",
    "\n",
    "@torch.no_grad()\n",
    "def _mse_norm(model: nn.Module, loader: DataLoader, device: str):\n",
    "    model.eval()\n",
    "    tot, n = 0.0, 0\n",
    "    for xb, yb in loader:\n",
    "        xb, yb = xb.to(device), yb.to(device)\n",
    "        pred = model(xb).squeeze(-1)\n",
    "        tot += F.mse_loss(pred, yb, reduction=\"sum\").item()\n",
    "        n += yb.numel()\n",
    "    return tot / max(n, 1)\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def _predict_in_chunks(model: nn.Module, X: torch.Tensor, *, chunk: int):\n",
    "    out = []\n",
    "    for i in range(0, int(X.shape[0]), int(chunk)):\n",
    "        out.append(model(X[i:i + chunk]).squeeze(-1))\n",
    "    return torch.cat(out, 0)\n",
    "\n",
    "\n",
    "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": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def eval_true_obj(gt, x):\n",
    "    if not isinstance(gt, dict):\n",
    "        return np.nan\n",
    "\n",
    "    x = np.asarray(x).reshape(-1)\n",
    "    t = gt.get(\"type\", None)\n",
    "\n",
    "    if t == \"quadratic\":\n",
    "        Q = np.asarray(gt[\"Q\"], float)\n",
    "        xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "        d = x.astype(float) - xs\n",
    "        return float(d @ Q @ d)\n",
    "\n",
    "    if t == \"assignment\":\n",
    "        C = np.asarray(gt[\"C\"], float)\n",
    "        idx = np.flatnonzero(x > 0.5)\n",
    "        if idx.size == 0:\n",
    "            return 0.0\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        return float(C[idx, :][r, c].sum())\n",
    "\n",
    "    if t == \"mdvsp\":\n",
    "        N, SS, TT = int(gt[\"N\"]), int(gt[\"SS\"]), int(gt[\"TT\"])\n",
    "        src = np.asarray(gt[\"src\"], np.int64)\n",
    "        dst = np.asarray(gt[\"dst\"], np.int64)\n",
    "        cost = np.asarray(gt[\"cost\"], float)\n",
    "        cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "        idxSS = np.asarray(gt[\"idxSS\"], np.int64)\n",
    "        idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "        cap = cap0.copy()\n",
    "        cap[idxSS] = x.astype(float)\n",
    "        cap[idxTT] = x.astype(float)\n",
    "\n",
    "        Fmax = lemon_mcf.max_flow(N, src, dst, cap, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, float)\n",
    "        supply[SS] = Fmax\n",
    "        supply[TT] = -Fmax\n",
    "        return float(lemon_mcf.solve_mcf(N, src, dst, cost, cap, supply)[\"total_cost\"])\n",
    "\n",
    "    return np.nan\n",
    "\n",
    "\n",
    "def local_search_l1_int(\n",
    "    f,\n",
    "    x0,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    delta: int,\n",
    "    sum_eq=None,\n",
    "    max_iters: int = 10_000,\n",
    "    print_every: int = 1,\n",
    "):\n",
    "    x  = np.asarray(x0,    int).ravel()\n",
    "    lo = np.asarray(x_min, int).ravel()\n",
    "    hi = np.asarray(x_max, int).ravel()\n",
    "    n = int(x.size)\n",
    "    delta = int(delta)\n",
    "\n",
    "    assert lo.size == n and hi.size == n\n",
    "    assert np.all(x >= lo) and np.all(x <= hi)\n",
    "    if sum_eq is not None:\n",
    "        sum_eq = int(sum_eq)\n",
    "        assert int(x.sum()) == sum_eq\n",
    "\n",
    "    def eval_batch(X):\n",
    "        y = np.asarray(f(X), float).reshape(-1)\n",
    "        return y\n",
    "\n",
    "    def ok(z):\n",
    "        if np.any(z < lo) or np.any(z > hi):\n",
    "            return False\n",
    "        if sum_eq is not None and int(z.sum()) != sum_eq:\n",
    "            return False\n",
    "        return True\n",
    "\n",
    "    # integer deltas with exact L1 = k\n",
    "    def deltas_exact(k):\n",
    "        d = np.zeros(n, int)\n",
    "\n",
    "        def rec(i, rem):\n",
    "            if i == n:\n",
    "                if rem == 0:\n",
    "                    yield d.copy()\n",
    "                return\n",
    "            for t in range(rem + 1):\n",
    "                if t == 0:\n",
    "                    d[i] = 0\n",
    "                    yield from rec(i + 1, rem)\n",
    "                else:\n",
    "                    d[i] = +t\n",
    "                    yield from rec(i + 1, rem - t)\n",
    "                    d[i] = -t\n",
    "                    yield from rec(i + 1, rem - t)\n",
    "            d[i] = 0\n",
    "\n",
    "        yield from rec(0, k)\n",
    "\n",
    "    t0 = time.perf_counter()\n",
    "    y = float(eval_batch(x[None, :])[0])\n",
    "    hist = [{\"iter\": 0, \"t\": 0.0, \"best_y\": y, \"x\": x.copy()}]\n",
    "    print(f\"iter=0  t=0.00s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    for it in range(1, int(max_iters) + 1):\n",
    "        cand = []\n",
    "        for k in range(1, delta + 1):\n",
    "            for dlt in deltas_exact(k):\n",
    "                z = x + dlt\n",
    "                if ok(z):\n",
    "                    cand.append(z)\n",
    "\n",
    "        if not cand:\n",
    "            print(f\"STOP: no feasible neighbors. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        Y = eval_batch(np.stack(cand, 0))\n",
    "        j = int(np.argmin(Y))\n",
    "        if float(Y[j]) >= y:\n",
    "            print(f\"STOP: local minimum. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        x, y = cand[j], float(Y[j])\n",
    "        hist.append({\"iter\": it, \"t\": time.perf_counter() - t0, \"best_y\": y, \"x\": x.copy()})\n",
    "        if it % max(1, int(print_every)) == 0:\n",
    "            print(f\"iter={it}  t={hist[-1]['t']:.2f}s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    return x, y, hist\n",
    "\n",
    "\n",
    "def _scaler_np(scaler):\n",
    "    xm = scaler[\"x_mean\"].detach().cpu().numpy().reshape(-1)\n",
    "    xs = scaler[\"x_std\"].detach().cpu().numpy().reshape(-1)\n",
    "    ym = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    ys = float(scaler[\"y_std\"].detach().cpu())\n",
    "    return xm, xs, ym, ys\n",
    "\n",
    "\n",
    "def solve_dfn_ip_gurobi(dfn, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    x_mean, x_std, y_mean, y_std = _scaler_np(scaler)\n",
    "\n",
    "    cost = np.r_[dfn.cost_raw.detach().cpu().numpy(), dfn.cost_fixed.detach().cpu().numpy()]\n",
    "    cap  = np.r_[torch.round(F.softplus(dfn.cap_raw.detach())).cpu().numpy(), dfn.cap_fixed.detach().cpu().numpy()]\n",
    "\n",
    "    A = dfn.A.detach().cpu().numpy()\n",
    "    if isinstance(dfn.A, torch.nn.Parameter):\n",
    "        A = np.round(A)\n",
    "    b = np.round(dfn.b_raw.detach().cpu().numpy())\n",
    "\n",
    "    src = dfn.src.detach().cpu().numpy().astype(int)\n",
    "    dst = dfn.dst.detach().cpu().numpy().astype(int)\n",
    "    boundary = dfn.boundary.detach().cpu().numpy().astype(int)\n",
    "    fix = int(dfn.fix_node)\n",
    "    n = int(dfn.n)\n",
    "    m = int(src.size)\n",
    "    alpha = float(dfn.alpha)\n",
    "    beta  = float(dfn.beta)\n",
    "\n",
    "    out = [[] for _ in range(n)]\n",
    "    inn = [[] for _ in range(n)]\n",
    "    for e in range(m):\n",
    "        out[src[e]].append(e)\n",
    "        inn[dst[e]].append(e)\n",
    "\n",
    "    M = gp.Model(\"DFN_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    f = M.addVars(m, lb=0.0, ub=cap.tolist(), vtype=GRB.CONTINUOUS, name=\"f\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq)\n",
    "\n",
    "    xm_over_xs = x_mean / x_std\n",
    "    s = [0] * n\n",
    "    s_boundary = []\n",
    "    for r, v in enumerate(boundary):\n",
    "        const = float(b[r] - (A[r] * xm_over_xs).sum())\n",
    "        expr = const + gp.quicksum((A[r, j] / x_std[j]) * x[j] for j in range(d) if A[r, j] != 0)\n",
    "        s[v] = expr\n",
    "        s_boundary.append(expr)\n",
    "    s[fix] = -gp.quicksum(s_boundary)\n",
    "\n",
    "    for v in range(n):\n",
    "        M.addConstr(gp.quicksum(f[e] for e in out[v]) - gp.quicksum(f[e] for e in inn[v]) == s[v])\n",
    "\n",
    "    flow_cost = gp.quicksum(cost[e] * f[e] for e in range(m))\n",
    "    M.setObjective((alpha * flow_cost + beta) * y_std + y_mean, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No solution (Gurobi status {M.Status})\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None)}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_mlp_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    base, a_out, b_out = model, 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base, a_out, b_out = model.base, float(model.a), float(model.b)\n",
    "\n",
    "    if not hasattr(base, \"net\"):\n",
    "        raise ValueError(\"Expected an MLP with attribute .net (nn.Sequential).\")\n",
    "    linears = [L for L in base.net if isinstance(L, torch.nn.Linear)]\n",
    "    if not linears:\n",
    "        raise ValueError(\"No Linear layers found in base.net\")\n",
    "\n",
    "    W = [L.weight.detach().cpu().numpy().astype(float) for L in linears]\n",
    "    b = [L.bias.detach().cpu().numpy().astype(float) for L in linears]\n",
    "\n",
    "    W[0] = W[0] / xs[None, :]\n",
    "    b[0] = b[0] - W[0] @ xm\n",
    "\n",
    "    W[-1] *= a_out\n",
    "    b[-1] = a_out * b[-1] + b_out\n",
    "\n",
    "    u = np.maximum(np.abs(x_min), np.abs(x_max))\n",
    "    preLU = []\n",
    "    for k in range(len(W) - 1):\n",
    "        U = np.abs(W[k]) @ u + np.abs(b[k])\n",
    "        preLU.append((-U, U))\n",
    "        u = np.maximum(0.0, U)\n",
    "\n",
    "    M = gp.Model(\"MLP_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    prev = [x[i] for i in range(d)]\n",
    "\n",
    "    for k in range(len(W) - 1):\n",
    "        Lk, Uk = preLU[k]\n",
    "        h = W[k].shape[0]\n",
    "\n",
    "        a = [M.addVar(lb=float(Lk[j]), ub=float(Uk[j]), name=f\"a{k}_{j}\") for j in range(h)]\n",
    "        z = [M.addVar(lb=0.0, ub=float(max(0.0, Uk[j])), name=f\"z{k}_{j}\") for j in range(h)]\n",
    "\n",
    "        for j in range(h):\n",
    "            M.addConstr(a[j] == b[k][j] + gp.quicksum(W[k][j, i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "            Lj, Uj = float(Lk[j]), float(Uk[j])\n",
    "            if Uj <= 0.0:\n",
    "                M.addConstr(z[j] == 0.0)\n",
    "            elif Lj >= 0.0:\n",
    "                M.addConstr(z[j] == a[j])\n",
    "            else:\n",
    "                s = M.addVar(vtype=GRB.BINARY, name=f\"s{k}_{j}\")\n",
    "                M.addConstr(z[j] >= a[j])\n",
    "                M.addConstr(z[j] >= 0.0)\n",
    "                M.addConstr(z[j] <= Uj * s)\n",
    "                M.addConstr(z[j] <= a[j] - Lj * (1 - s))\n",
    "\n",
    "        prev = z\n",
    "\n",
    "    if W[-1].shape[0] != 1:\n",
    "        raise ValueError(f\"Expected scalar output, got out_dim={W[-1].shape[0]}\")\n",
    "\n",
    "    y_norm = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == b[-1][0] + gp.quicksum(W[-1][0, i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "    M.setObjective(ys * y_norm + ym, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_maxaffine_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    base, a_out, b_out = model, 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base, a_out, b_out = model.base, float(model.a), float(model.b)\n",
    "\n",
    "    W = base.W.detach().cpu().numpy().astype(float)\n",
    "    b = base.b.detach().cpu().numpy().astype(float)\n",
    "\n",
    "    Weff = W / xs[None, :]\n",
    "    beff = b - (Weff @ xm)\n",
    "\n",
    "    Weff *= a_out\n",
    "    beff  = a_out * beff + b_out\n",
    "\n",
    "    K = int(Weff.shape[0])\n",
    "\n",
    "    M = gp.Model(\"MaxAffine_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    t = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"t_norm\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(t >= beff[k] + gp.quicksum(Weff[k, j] * x[j] for j in range(d) if Weff[k, j] != 0.0))\n",
    "\n",
    "    M.setObjective(ys * t + ym, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n",
    "\n",
    "\n",
    "def solve_lset_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm, xs, ym, ys = _scaler_np(scaler)\n",
    "\n",
    "    A = model.A.detach().cpu().numpy().astype(float)\n",
    "    b = model.b.detach().cpu().numpy().astype(float)\n",
    "    T = float(model.T)\n",
    "    if T == 0.0:\n",
    "        raise ValueError(\"T must be nonzero\")\n",
    "\n",
    "    Aeff = A / xs[None, :]\n",
    "    beff = b - (Aeff @ xm)\n",
    "    K = int(Aeff.shape[0])\n",
    "\n",
    "    lin_lo = np.empty(K, dtype=float)\n",
    "    lin_hi = np.empty(K, dtype=float)\n",
    "    for k in range(K):\n",
    "        a = Aeff[k]\n",
    "        lo = beff[k]\n",
    "        hi = beff[k]\n",
    "        pos = a >= 0\n",
    "        lo += (a[pos] * x_min[pos]).sum() + (a[~pos] * x_max[~pos]).sum()\n",
    "        hi += (a[pos] * x_max[pos]).sum() + (a[~pos] * x_min[~pos]).sum()\n",
    "        lin_lo[k], lin_hi[k] = lo, hi\n",
    "\n",
    "    z_lo = lin_lo / T\n",
    "    z_hi = lin_hi / T\n",
    "    m_lo = float(np.max(z_lo))\n",
    "    m_hi = float(np.max(z_hi))\n",
    "\n",
    "    w_lo = float(np.min(z_lo - m_hi))  # <= 0\n",
    "    u_lo = float(np.exp(max(-700.0, w_lo)))\n",
    "    s_lo = max(1e-12, K * u_lo)\n",
    "    s_hi = float(K * 1.0)\n",
    "    v_lo = float(np.log(s_lo))\n",
    "    v_hi = float(np.log(s_hi))\n",
    "\n",
    "    yN_lo = float(T * (m_lo + v_lo))\n",
    "    yN_hi = float(T * (m_hi + v_hi))\n",
    "    y_lo  = float(ys * yN_lo + ym)\n",
    "    y_hi  = float(ys * yN_hi + ym)\n",
    "\n",
    "    M = gp.Model(\"lset_ip_stable_bounded\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    M.Params.FuncNonlinear = 1\n",
    "    M.Params.FeasibilityTol = 1e-9\n",
    "    M.Params.OptimalityTol  = 1e-9\n",
    "    M.Params.IntFeasTol     = 1e-9\n",
    "    M.Params.NumericFocus   = 3\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    z = M.addVars(K, lb=z_lo.tolist(), ub=z_hi.tolist(), vtype=GRB.CONTINUOUS, name=\"z\")\n",
    "    for k in range(K):\n",
    "        lin = beff[k] + gp.quicksum(Aeff[k, j] * x[j] for j in range(d) if Aeff[k, j] != 0.0)\n",
    "        M.addConstr(z[k] == lin / T, name=f\"zdef_{k}\")\n",
    "\n",
    "    m = M.addVar(lb=m_lo, ub=m_hi, vtype=GRB.CONTINUOUS, name=\"m\")\n",
    "    w = M.addVars(K, lb=w_lo, ub=0.0, vtype=GRB.CONTINUOUS, name=\"w\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(m >= z[k], name=f\"m_ge_z_{k}\")\n",
    "        M.addConstr(w[k] == z[k] - m, name=f\"wdef_{k}\")\n",
    "\n",
    "    u = M.addVars(K, lb=0.0, ub=1.0, vtype=GRB.CONTINUOUS, name=\"u\")\n",
    "    for k in range(K):\n",
    "        M.addGenConstrExp(w[k], u[k], name=f\"exp_{k}\")\n",
    "\n",
    "    s = M.addVar(lb=s_lo, ub=s_hi, vtype=GRB.CONTINUOUS, name=\"s\")\n",
    "    M.addConstr(s == gp.quicksum(u[k] for k in range(K)), name=\"sumexp_shifted\")\n",
    "\n",
    "    v = M.addVar(lb=v_lo, ub=v_hi, vtype=GRB.CONTINUOUS, name=\"v\")\n",
    "    M.addGenConstrLog(s, v, name=\"log_shifted\")\n",
    "\n",
    "    y_norm = M.addVar(lb=yN_lo, ub=yN_hi, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == T * (m + v), name=\"y_norm_def\")\n",
    "\n",
    "    y_raw = M.addVar(lb=y_lo, ub=y_hi, vtype=GRB.CONTINUOUS, name=\"y_raw\")\n",
    "    M.addConstr(y_raw == ys * y_norm + ym, name=\"y_raw_def\")\n",
    "\n",
    "    M.setObjective(y_raw, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution found. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], dtype=float)\n",
    "    y_star = float(y_raw.X)\n",
    "\n",
    "    info = {\n",
    "        \"status\": M.Status,\n",
    "        \"runtime\": M.Runtime,\n",
    "        \"gap\": getattr(M, \"MIPGap\", None),\n",
    "        \"sol_count\": M.SolCount,\n",
    "        \"obj_gurobi\": float(M.ObjVal),\n",
    "        \"obj_bound\": float(getattr(M, \"ObjBound\", float(\"nan\"))),\n",
    "    }\n",
    "    return x_star, y_star, info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d4858979",
   "metadata": {},
   "source": [
    "## Test Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "569f2165",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_ip(model_type, model, scaler, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    if model_type == \"DFN\":\n",
    "        return solve_dfn_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MLP\":\n",
    "        return solve_mlp_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MaxAffine\":\n",
    "        return solve_maxaffine_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"LSET\":\n",
    "        return solve_lset_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise ValueError(model_type)\n",
    "\n",
    "\n",
    "def suppress_stdout(fn, *args, silence: bool = False, **kwargs):\n",
    "    if not silence:\n",
    "        return fn(*args, **kwargs), \"\"\n",
    "    buf = io.StringIO()\n",
    "    with contextlib.redirect_stdout(buf):\n",
    "        out = fn(*args, **kwargs)\n",
    "    return out, buf.getvalue()\n",
    "\n",
    "\n",
    "def make_obj(model, scaler, device, chunk: int = 4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def obj(Xraw):\n",
    "        Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "        if Xraw.dim() == 1:\n",
    "            Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "        outs = []\n",
    "        B = int(Xraw.shape[0])\n",
    "        for i in range(0, B, int(chunk)):\n",
    "            Xb = Xraw[i:i+chunk]\n",
    "            try:\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)  \n",
    "                y  = (yn * ys + ym).reshape(-1).detach().cpu() \n",
    "                if y.numel() != Xb.shape[0]:\n",
    "                    y = y.expand(Xb.shape[0]).contiguous()\n",
    "                outs.append(y)\n",
    "            except Exception as e:\n",
    "                obj._err_count += int(Xb.shape[0])\n",
    "                if obj._err_first is None:\n",
    "                    obj._err_first = repr(e)\n",
    "                outs.append(torch.full((int(Xb.shape[0]),), float(\"inf\"), device=\"cpu\"))\n",
    "\n",
    "        return torch.cat(outs, 0).numpy()\n",
    "\n",
    "    obj._err_count = 0\n",
    "    obj._err_first = None\n",
    "    return obj\n",
    "\n",
    "\n",
    "def safe_raw_mse(obj, Xraw, yraw):\n",
    "    yp = np.asarray(obj(Xraw), dtype=float).reshape(-1)\n",
    "    yt = yraw.detach().cpu().numpy().reshape(-1) if torch.is_tensor(yraw) else np.asarray(yraw, float).reshape(-1)\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "    mask = np.isfinite(yp)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions were non-finite (inf/nan)\"\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def safe_norm_mse(model, scaler, device, Xraw, yraw, *, chunk=4096):\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "    if Xraw.dim() == 1:\n",
    "        Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "    yraw_t = yraw\n",
    "    if torch.is_tensor(yraw_t):\n",
    "        yraw_t = yraw_t.to(device=device, dtype=torch.float32)\n",
    "    else:\n",
    "        yraw_t = torch.as_tensor(yraw_t, dtype=torch.float32, device=device)\n",
    "    yraw_t = yraw_t.reshape(-1)\n",
    "\n",
    "    preds = []\n",
    "    B = int(Xraw.shape[0])\n",
    "    try:\n",
    "        with torch.no_grad():\n",
    "            for i in range(0, B, int(chunk)):\n",
    "                Xb = Xraw[i:i+chunk]\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)\n",
    "                if yn.numel() != Xb.shape[0]:\n",
    "                    yn = yn.expand(Xb.shape[0]).contiguous()\n",
    "                preds.append(yn.detach().cpu())\n",
    "    except Exception as e:\n",
    "        return np.nan, f\"model forward failed in safe_norm_mse: {repr(e)}\"\n",
    "\n",
    "    yp = torch.cat(preds, 0).numpy().reshape(-1)\n",
    "    yt = ((yraw_t - ym) / ys).detach().cpu().numpy().reshape(-1)\n",
    "\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "\n",
    "    mask = np.isfinite(yp) & np.isfinite(yt)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions or targets were non-finite (inf/nan)\"\n",
    "\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "\n",
    "def t_to_best(hist, y_best):\n",
    "    for r in hist:\n",
    "        if abs(float(r.get(\"best_y\", np.inf)) - float(y_best)) < 1e-12:\n",
    "            return float(r.get(\"t\", float(\"nan\")))\n",
    "    return float(\"nan\")\n",
    "\n",
    "\n",
    "def check_ip_matches_obj(name, obj, x_ip, y_ip, *, strict: bool, tol: float):\n",
    "    y_obj = float(np.asarray(obj(np.asarray(x_ip)), dtype=float).reshape(-1)[0])\n",
    "    y_ip  = float(y_ip)\n",
    "    rel = abs(y_obj - y_ip) / (abs(y_obj) + 1e-12)\n",
    "    print(f\"[CHECK {name}] obj(x_ip)={y_obj:.6g}  ip_y={y_ip:.6g}  rel_err={rel:.3e}\")\n",
    "    if strict and rel > tol:\n",
    "        raise RuntimeError(f\"{name}: IP objective != obj() (rel_err={rel:.3e})\")\n",
    "    return rel\n",
    "\n",
    "\n",
    "def mean_se(x):\n",
    "    x = pd.to_numeric(pd.Series(x), errors=\"coerce\").to_numpy()\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = int(x.shape[0])\n",
    "    if n == 0:\n",
    "        return np.nan, np.nan\n",
    "    m = float(x.mean())\n",
    "    se = float(x.std(ddof=1) / np.sqrt(n)) if n > 1 else 0.0\n",
    "    return m, se\n",
    "\n",
    "\n",
    "def fmt_mean_se(m, se):\n",
    "    if not np.isfinite(m):\n",
    "        return \"nan\"\n",
    "    if not np.isfinite(se):\n",
    "        return f\"{m:.6g}\"\n",
    "    return f\"{m:.6g} ± {se:.3g}\"\n",
    "\n",
    "\n",
    "def repr_solution(xs: pd.Series, seeds=None):\n",
    "    xs = xs.dropna().astype(str)\n",
    "    xs = xs[xs != \"None\"]\n",
    "    if xs.empty:\n",
    "        return None\n",
    "\n",
    "    # With seed information: show per-seed if solutions differ\n",
    "    if seeds is not None:\n",
    "        df = pd.DataFrame({\"seed\": pd.Series(seeds), \"x\": xs})\n",
    "        df = df.dropna()\n",
    "        df[\"x\"] = df[\"x\"].astype(str)\n",
    "        if df.empty:\n",
    "            return None\n",
    "        if df[\"x\"].nunique() == 1:\n",
    "            return df[\"x\"].iloc[0]\n",
    "        df = df.sort_values(\"seed\")\n",
    "        return \"\\n\".join([f\"seed={int(r.seed)}: {r.x}\" for r in df.itertuples(index=False)])\n",
    "\n",
    "    # No seed info: keep compact\n",
    "    if xs.nunique() == 1:\n",
    "        return xs.iloc[0]\n",
    "    vc = xs.value_counts()\n",
    "    top = vc.index[0]\n",
    "    n_unique = int(vc.shape[0])\n",
    "    return f\"{top} (+{n_unique-1} other)\"\n",
    "    \n",
    "\n",
    "# -----------------------------\n",
    "# Ground-truth optimum solvers\n",
    "# -----------------------------\n",
    "\n",
    "def solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    Q  = np.asarray(gt[\"Q\"], float)\n",
    "    xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "    n  = int(xs.shape[0])\n",
    "    assert Q.shape == (n, n)\n",
    "\n",
    "    m = gp.Model(\"gt_quadratic\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    x = m.addVars(n, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(n):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(n)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    expr = gp.quicksum(float(Q[i, j]) * (x[i] - float(xs[i])) * (x[j] - float(xs[j])) for i in range(n) for j in range(n))\n",
    "    m.setObjective(expr, GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT quadratic solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(n)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_assignment(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    C = np.asarray(gt[\"C\"], float)\n",
    "    n_rows, n_cols = C.shape\n",
    "    k = int(sum_eq)\n",
    "    if k > n_cols:\n",
    "        raise RuntimeError(f\"sum_eq={k} exceeds number of columns={n_cols} (infeasible)\")\n",
    "\n",
    "    m = gp.Model(\"gt_assignment\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    z = m.addVars(n_rows, vtype=GRB.BINARY, name=\"z\")  # select row i\n",
    "    y = m.addVars(n_rows, n_cols, vtype=GRB.BINARY, name=\"y\")  # assign row i to col j\n",
    "\n",
    "    m.addConstr(gp.quicksum(z[i] for i in range(n_rows)) == k, name=\"k_rows\")\n",
    "    for i in range(n_rows):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for j in range(n_cols)) == z[i], name=f\"assign_row_{i}\")\n",
    "    for j in range(n_cols):\n",
    "        m.addConstr(gp.quicksum(y[i, j] for i in range(n_rows)) <= 1, name=f\"assign_col_{j}\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(C[i, j]) * y[i, j] for i in range(n_rows) for j in range(n_cols)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT assignment solve failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(z[i].X)) for i in range(n_rows)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status)}\n",
    "\n",
    "\n",
    "def solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    N  = int(gt[\"N\"])\n",
    "    SS = int(gt[\"SS\"])\n",
    "    TT = int(gt[\"TT\"])\n",
    "    src  = np.asarray(gt[\"src\"], np.int64)\n",
    "    dst  = np.asarray(gt[\"dst\"], np.int64)\n",
    "    cost = np.asarray(gt[\"cost\"], float)\n",
    "    cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "    idxSS = np.asarray(gt[\"idxSS\"], np.int64)\n",
    "    idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "    E = int(src.shape[0])\n",
    "    k = int(idxSS.shape[0])\n",
    "    assert idxTT.shape[0] == k, \"Expect idxSS and idxTT to be same length\"\n",
    "\n",
    "    out_edges = [[] for _ in range(N)]\n",
    "    in_edges  = [[] for _ in range(N)]\n",
    "    for e in range(E):\n",
    "        out_edges[int(src[e])].append(e)\n",
    "        in_edges[int(dst[e])].append(e)\n",
    "\n",
    "    idxSS = idxSS.astype(int)\n",
    "    idxTT = idxTT.astype(int)\n",
    "    var_arc_to_i = {int(idxSS[i]): i for i in range(k)}\n",
    "    var_arc_to_i.update({int(idxTT[i]): i for i in range(k)})\n",
    "    var_arcs = sorted(var_arc_to_i.keys())\n",
    "\n",
    "    m = gp.Model(\"gt_mdvsp_true_opt\")\n",
    "    m.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        m.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    m.Params.NonConvex = 2\n",
    "\n",
    "    x = m.addVars(k, vtype=GRB.INTEGER, name=\"x\")\n",
    "    for i in range(k):\n",
    "        x[i].LB = int(xmin[i])\n",
    "        x[i].UB = int(xmax[i])\n",
    "    m.addConstr(gp.quicksum(x[i] for i in range(k)) == int(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    f = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, name=\"f\")\n",
    "\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            m.addConstr(f[e] <= x[i], name=f\"cap_var_{e}\")\n",
    "        else:\n",
    "            m.addConstr(f[e] <= float(cap0[e]), name=f\"cap_fix_{e}\")\n",
    "\n",
    "    F = m.addVar(vtype=GRB.CONTINUOUS, lb=0.0, name=\"F\")\n",
    "\n",
    "    # flow conservation: out - in = F at SS, = -F at TT, else 0\n",
    "    for v in range(N):\n",
    "        out_sum = gp.quicksum(f[e] for e in out_edges[v])\n",
    "        in_sum  = gp.quicksum(f[e] for e in in_edges[v])\n",
    "        rhs = F if v == SS else (-F if v == TT else 0.0)\n",
    "        m.addConstr(out_sum - in_sum == rhs, name=f\"flow_{v}\")\n",
    "\n",
    "    y = m.addVars(N, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"y\")\n",
    "    m.addConstr(y[SS] == 1.0, name=\"ySS\")\n",
    "    m.addConstr(y[TT] == 0.0, name=\"yTT\")\n",
    "\n",
    "    z = m.addVars(E, vtype=GRB.CONTINUOUS, lb=0.0, ub=1.0, name=\"z\")\n",
    "    for e in range(E):\n",
    "        m.addConstr(z[e] >= y[int(src[e])] - y[int(dst[e])], name=f\"dual_{e}\")\n",
    "\n",
    "    dual_obj = gp.QuadExpr()\n",
    "    for e in range(E):\n",
    "        if e in var_arc_to_i:\n",
    "            i = var_arc_to_i[e]\n",
    "            # bilinear term: x_i * z_e\n",
    "            dual_obj += x[i] * z[e]\n",
    "        else:\n",
    "            dual_obj += float(cap0[e]) * z[e]\n",
    "    m.addConstr(F == dual_obj, name=\"strong_duality\")\n",
    "\n",
    "    m.setObjective(gp.quicksum(float(cost[e]) * f[e] for e in range(E)), GRB.MINIMIZE)\n",
    "    m.optimize()\n",
    "\n",
    "    if m.Status not in (GRB.OPTIMAL, GRB.TIME_LIMIT, GRB.SUBOPTIMAL, GRB.INTERRUPTED):\n",
    "        raise RuntimeError(f\"GT mdvsp true-opt failed, status={m.Status}\")\n",
    "\n",
    "    xsol = np.array([int(round(x[i].X)) for i in range(k)], dtype=int)\n",
    "    return xsol, float(m.ObjVal), {\"status\": int(m.Status), \"F\": float(F.X)}\n",
    "    \n",
    "\n",
    "\n",
    "def solve_true_opt(gt, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    \"\"\"Top-level dispatcher for ground-truth optimum.\"\"\"\n",
    "    if not isinstance(gt, dict):\n",
    "        raise RuntimeError(\"No ground-truth structure found (gt must be a dict).\")\n",
    "    t = gt.get(\"type\", None)\n",
    "    if t == \"quadratic\":\n",
    "        return solve_true_opt_quadratic(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"assignment\":\n",
    "        return solve_true_opt_assignment(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if t == \"mdvsp\":\n",
    "        return solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise RuntimeError(f\"Unknown gt type: {t}\")\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "# Benchmark runner\n",
    "# -----------------------------\n",
    "def run_benchmark(\n",
    "    *,\n",
    "    dataset_type: str,\n",
    "    dataset_params: dict,\n",
    "    runs: list[tuple[str, str, dict]],\n",
    "    train_base: dict,\n",
    "    lr_map: dict,\n",
    "    x0: np.ndarray,\n",
    "    xmin: np.ndarray,\n",
    "    xmax: np.ndarray,\n",
    "    delta: int,\n",
    "    sum_eq: int,\n",
    "    n_seeds: int = 1,\n",
    "    vary_dataset_seed: bool = False,\n",
    "    vary_model_init_seed: bool = True,\n",
    "    strict_ip_check: bool = False,\n",
    "    ip_check_tol: float = 1e-4,\n",
    "    silence_local_search: bool = False,\n",
    "    allow_plots_multi_seed: bool = True,\n",
    "    time_limit=None,\n",
    "):\n",
    "    seeds = list(range(int(n_seeds)))\n",
    "\n",
    "    learn_rows, opt_rows, spec_rows, fail_rows = [], [], [], []\n",
    "    gt_rows = []\n",
    "\n",
    "    gt_cache_by_seed = {}\n",
    "\n",
    "    for seed in seeds:\n",
    "        print(f\"\\n\\n===================== SEED {seed} =====================\")\n",
    "\n",
    "        for name, model_type, model_params_base in runs:\n",
    "            # ---- per-run params ----\n",
    "            dp = dict(dataset_params)\n",
    "            if vary_dataset_seed and \"seed\" in dp:\n",
    "                dp[\"seed\"] = int(seed)\n",
    "\n",
    "            mp = dict(model_params_base)\n",
    "            if vary_model_init_seed and \"seed\" in mp:\n",
    "                mp[\"seed\"] = int(seed)\n",
    "\n",
    "            tp = dict(train_base)\n",
    "            tp[\"seed\"] = int(seed)\n",
    "            tp[\"lr\"] = float(lr_map[model_type])\n",
    "\n",
    "            # avoid plot spam unless explicitly allowed\n",
    "            if (n_seeds > 1) and (tp.get(\"plot_every\", 0) not in (0, None)) and (not allow_plots_multi_seed):\n",
    "                tp[\"plot_every\"] = 0\n",
    "\n",
    "            # ---- TRAIN ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                out = generate_and_train_simple(dataset_type, dp, model_type, mp, tp)\n",
    "            except Exception as e:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=repr(e)))\n",
    "                learn_rows.append(dict(seed=seed, model=name, train_time=np.nan, best_epoch=np.nan,\n",
    "                                       best_val=np.nan, test=np.nan, train_err=repr(e)))\n",
    "                continue\n",
    "            train_time = time.perf_counter() - t0\n",
    "\n",
    "            if isinstance(out, tuple) and len(out) == 4:\n",
    "                model, data, hist, spec = out\n",
    "            elif isinstance(out, tuple) and len(out) == 3:\n",
    "                model, data, hist = out\n",
    "                n_params = sum(p.numel() for p in model.parameters())\n",
    "                spec = dict(n_params=int(n_params), extra=\"\", train_params=tp)\n",
    "            else:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=f\"Unexpected return: {type(out)}\"))\n",
    "                continue\n",
    "\n",
    "            # ---- model spec (seed 0 only) ----\n",
    "            if seed == seeds[0]:\n",
    "                spec_rows.append(dict(\n",
    "                    model=name,\n",
    "                    n_params=int(spec.get(\"n_params\", np.nan)),\n",
    "                    details=str(spec.get(\"extra\", \"\")),\n",
    "                    lr=float(spec.get(\"train_params\", {}).get(\"lr\", tp[\"lr\"])),\n",
    "                    batch_size=int(spec.get(\"train_params\", {}).get(\"batch_size\", tp[\"batch_size\"])),\n",
    "                    epochs=int(spec.get(\"train_params\", {}).get(\"epochs\", tp[\"epochs\"])),\n",
    "                ))\n",
    "\n",
    "            device = data[\"device\"]\n",
    "            scaler = data[\"scaler\"]\n",
    "            obj = make_obj(model, scaler, device, chunk=int(tp.get(\"plot_chunk\", 4096)))\n",
    "            gt = data.get(\"true\", None)\n",
    "\n",
    "            # ---- compute GT optimum (once per seed) ----\n",
    "            if seed not in gt_cache_by_seed:\n",
    "                t_gt0 = time.perf_counter()\n",
    "                try:\n",
    "                    x_gt, y_gt, gt_info = solve_true_opt(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=False)\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    # evaluate with the existing helper to be extra sure\n",
    "                    y_gt_check = float(eval_true_obj(gt, x_gt))\n",
    "                    if np.isfinite(y_gt_check) and abs(y_gt_check - float(y_gt)) / (abs(float(y_gt_check)) + 1e-12) > 1e-6:\n",
    "                        fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT_CHECK\",\n",
    "                                              error=f\"gt solver mismatch: solver={y_gt:.6g} eval_true_obj={y_gt_check:.6g}\"))\n",
    "                    gt_cache_by_seed[seed] = dict(x=str(np.asarray(x_gt, int).tolist()),\n",
    "                                                  true_y=float(y_gt_check if np.isfinite(y_gt_check) else y_gt),\n",
    "                                                  runtime=float(gt_time),\n",
    "                                                  err=None)\n",
    "                except Exception as e:\n",
    "                    gt_time = time.perf_counter() - t_gt0\n",
    "                    gt_cache_by_seed[seed] = dict(x=None, true_y=np.nan, runtime=float(gt_time), err=repr(e))\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"GT_OPT\", error=repr(e)))\n",
    "\n",
    "            # ---- learning metrics: best val (normalized) + test loss (normalized) ----\n",
    "            test_norm, err_te = safe_norm_mse(model, scaler, device, data['raw']['Xte'], data['raw']['yte'], chunk=int(tp.get('plot_chunk', 4096)))\n",
    "            if err_te:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"EVAL_TEST\", error=err_te))\n",
    "\n",
    "            if obj._err_count > 0:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"OBJ\",\n",
    "                                      error=f\"obj() had {obj._err_count} forward failures; first={obj._err_first}\"))\n",
    "\n",
    "            val_curve = np.asarray(hist.get(\"val_mse_norm\", []), dtype=float)\n",
    "            best_ep = int(np.argmin(val_curve) + 1) if val_curve.size else np.nan\n",
    "            best_val = float(np.min(val_curve)) if val_curve.size else np.nan\n",
    "\n",
    "            learn_rows.append(dict(\n",
    "                seed=seed, model=name,\n",
    "                train_time=float(train_time),\n",
    "                best_epoch=best_ep,\n",
    "                best_val=float(best_val),\n",
    "                test=float(test_norm) if np.isfinite(test_norm) else np.nan,\n",
    "                train_err=(err_te),\n",
    "            ))\n",
    "\n",
    "            # ---- LOCAL SEARCH ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                obj_ls = obj\n",
    "                (ls_out, _ls_log) = suppress_stdout(\n",
    "                    local_search_l1_int, obj_ls, x0, xmin, xmax,\n",
    "                    delta=delta, sum_eq=sum_eq, print_every=0,\n",
    "                    silence=silence_local_search\n",
    "                )\n",
    "                x_best, y_best, ls_hist = ls_out\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=str(np.asarray(x_best, int).tolist()),\n",
    "                    y=float(y_best),\n",
    "                    true_y=float(eval_true_obj(gt, x_best)),\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=float(t_to_best(ls_hist, y_best)),\n",
    "                    iters=int(len(ls_hist) - 1),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ls_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"LS\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ls_time),\n",
    "                    t_best=np.nan, iters=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"LS\", error=repr(e)))\n",
    "\n",
    "            # ---- IP SOLVE (learned objective) ----\n",
    "            t0 = time.perf_counter()\n",
    "            try:\n",
    "                x_ip, y_ip, info = solve_ip(\n",
    "                    model_type, model, scaler, xmin, xmax, sum_eq,\n",
    "                    time_limit=time_limit, verbose=True\n",
    "                )\n",
    "                ip_time = time.perf_counter() - t0\n",
    "\n",
    "                rel_err = check_ip_matches_obj(name, obj, x_ip, y_ip, strict=strict_ip_check, tol=ip_check_tol)\n",
    "                if rel_err > ip_check_tol:\n",
    "                    fail_rows.append(dict(seed=seed, model=name, stage=\"IP_CHECK\",\n",
    "                                          error=f\"rel_err={rel_err:.3e} (tol={ip_check_tol})\"))\n",
    "\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=str(np.asarray(x_ip, int).tolist()),\n",
    "                    y=float(y_ip),\n",
    "                    true_y=float(eval_true_obj(gt, x_ip)),\n",
    "                    runtime=float(ip_time),\n",
    "                    status=(info.get(\"status\") if isinstance(info, dict) else None),\n",
    "                    gap=(info.get(\"gap\") if isinstance(info, dict) else None),\n",
    "                    ip_rel_err=float(rel_err),\n",
    "                    err=None,\n",
    "                ))\n",
    "            except Exception as e:\n",
    "                ip_time = time.perf_counter() - t0\n",
    "                opt_rows.append(dict(\n",
    "                    seed=seed, model=name, method=\"IP\",\n",
    "                    x=None, y=np.nan, true_y=np.nan,\n",
    "                    runtime=float(ip_time),\n",
    "                    status=None, gap=None, ip_rel_err=np.nan,\n",
    "                    err=repr(e),\n",
    "                ))\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"IP\", error=repr(e)))\n",
    "\n",
    "    # ---- build DFs ----\n",
    "    spec_df  = pd.DataFrame(spec_rows).drop_duplicates(\"model\").sort_values(\"model\").reset_index(drop=True)\n",
    "    learn_df = pd.DataFrame(learn_rows).sort_values([\"model\", \"seed\"]).reset_index(drop=True)\n",
    "    opt_df   = pd.DataFrame(opt_rows).sort_values([\"model\", \"seed\", \"method\"]).reset_index(drop=True)\n",
    "\n",
    "    fail_df = pd.DataFrame(fail_rows)\n",
    "    if fail_df.empty:\n",
    "        fail_df = pd.DataFrame(columns=[\"seed\", \"model\", \"stage\", \"error\"])\n",
    "    else:\n",
    "        for c in [\"stage\", \"model\", \"seed\"]:\n",
    "            if c not in fail_df.columns:\n",
    "                fail_df[c] = np.nan\n",
    "        fail_df = fail_df.sort_values([\"stage\", \"model\", \"seed\"]).reset_index(drop=True)\n",
    "\n",
    "    gt_df = pd.DataFrame([dict(seed=s, **d) for s, d in sorted(gt_cache_by_seed.items())]).sort_values(\"seed\")\n",
    "\n",
    "    # ---- per-seed gaps ----\n",
    "    gap_seed_df = pd.DataFrame(columns=[\"seed\", \"model\", \"ls_vs_ip_pct\", \"ip_true_vs_gt_pct\"])\n",
    "    if not opt_df.empty:\n",
    "        pivot_y = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"y\", aggfunc=\"first\")\n",
    "        pivot_true = opt_df.pivot_table(index=[\"seed\", \"model\"], columns=\"method\", values=\"true_y\", aggfunc=\"first\")\n",
    "\n",
    "        if (\"LS\" in pivot_y.columns) and (\"IP\" in pivot_y.columns):\n",
    "            ls_vs_ip = 100.0 * (pivot_y[\"LS\"] - pivot_y[\"IP\"]) / (np.abs(pivot_y[\"IP\"]) + 1e-12)\n",
    "        else:\n",
    "            ls_vs_ip = pd.Series(index=pivot_y.index, dtype=float)\n",
    "\n",
    "        # IP true vs GT optimum true\n",
    "        gt_true = gt_df.set_index(\"seed\")[\"true_y\"] if not gt_df.empty else pd.Series(dtype=float)\n",
    "        ip_true_vs_gt = []\n",
    "        for (seed, model), row in pivot_true.iterrows():\n",
    "            ipt = float(row.get(\"IP\", np.nan))\n",
    "            gtt = float(gt_true.get(seed, np.nan))\n",
    "            if np.isfinite(ipt) and np.isfinite(gtt):\n",
    "                ip_true_vs_gt.append(((seed, model), 100.0 * (ipt - gtt) / (abs(gtt) + 1e-12)))\n",
    "            else:\n",
    "                ip_true_vs_gt.append(((seed, model), np.nan))\n",
    "        ip_true_vs_gt = pd.Series({k: v for k, v in ip_true_vs_gt})\n",
    "\n",
    "        gap_seed_df = pd.DataFrame({\n",
    "            \"seed\": [k[0] for k in ip_true_vs_gt.index],\n",
    "            \"model\": [k[1] for k in ip_true_vs_gt.index],\n",
    "            \"ls_vs_ip_pct\": [float(ls_vs_ip.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "            \"ip_true_vs_gt_pct\": [float(ip_true_vs_gt.get(k, np.nan)) for k in ip_true_vs_gt.index],\n",
    "        })\n",
    "\n",
    "    # ---- LEARNING SUMMARY (mean ± SE over seeds) ----\n",
    "    learn_sum_rows = []\n",
    "    for model in sorted(learn_df[\"model\"].unique()):\n",
    "        sub = learn_df[learn_df[\"model\"] == model]\n",
    "        m, se = mean_se(sub[\"train_time\"]); train_time_s = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"best_val\"]);   best_val_s   = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(sub[\"test\"]);       test_s       = fmt_mean_se(m, se)\n",
    "        learn_sum_rows.append(dict(model=model, train_time=train_time_s, best_val=best_val_s, test=test_s))\n",
    "    learn_summary_df = pd.DataFrame(learn_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- OPTIMIZATION SUMMARY ----\n",
    "    opt_sum_rows = []\n",
    "    gt_x_repr = (repr_solution(gt_df.get(\"x\", pd.Series(dtype=str)), gt_df.get(\"seed\", None))\n",
    "                if not gt_df.empty else None)\n",
    "    m, se = mean_se(gt_df.get(\"true_y\", pd.Series(dtype=float))); gt_true_s = fmt_mean_se(m, se)\n",
    "    m, se = mean_se(gt_df.get(\"runtime\", pd.Series(dtype=float))); gt_time_s = fmt_mean_se(m, se)\n",
    "\n",
    "    for model in sorted(opt_df[\"model\"].unique()):\n",
    "        sub = opt_df[opt_df[\"model\"] == model]\n",
    "        row = {\"model\": model}\n",
    "\n",
    "        ls = sub[sub[\"method\"] == \"LS\"]\n",
    "        ip = sub[sub[\"method\"] == \"IP\"]\n",
    "\n",
    "        row[\"LS_x\"] = repr_solution(ls[\"x\"], ls.get(\"seed\", None))\n",
    "        m, se = mean_se(ls[\"y\"]);       row[\"LS_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"true_y\"]);  row[\"LS_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ls[\"runtime\"]); row[\"LS_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"IP_x\"] = repr_solution(ip[\"x\"], ip.get(\"seed\", None))\n",
    "        m, se = mean_se(ip[\"y\"]);       row[\"IP_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"true_y\"]);  row[\"IP_true_y\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(ip[\"runtime\"]); row[\"IP_time\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        row[\"GT_x\"] = gt_x_repr\n",
    "        row[\"GT_true_y\"] = gt_true_s\n",
    "        row[\"GT_time\"] = gt_time_s\n",
    "\n",
    "        gsub = gap_seed_df[gap_seed_df[\"model\"] == model] if not gap_seed_df.empty else pd.DataFrame()\n",
    "        m, se = mean_se(gsub.get(\"ls_vs_ip_pct\", pd.Series(dtype=float))); row[\"LS_vs_IP_%\"] = fmt_mean_se(m, se)\n",
    "        m, se = mean_se(gsub.get(\"ip_true_vs_gt_pct\", pd.Series(dtype=float))); row[\"IP_true_vs_GT_%\"] = fmt_mean_se(m, se)\n",
    "\n",
    "        opt_sum_rows.append(row)\n",
    "\n",
    "    opt_summary_df = pd.DataFrame(opt_sum_rows).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "    # ---- Print tables ----\n",
    "    print(\"\\n=== MODEL SPECS (from seed 0 run) ===\")\n",
    "    if not spec_df.empty:\n",
    "        print(spec_df[[\"model\", \"n_params\", \"details\", \"lr\", \"batch_size\", \"epochs\"]].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== LEARNING SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not learn_summary_df.empty:\n",
    "        print(learn_summary_df.to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\")\n",
    "    if not opt_summary_df.empty:\n",
    "        cols = [\n",
    "            \"model\",\n",
    "            \"LS_x\", \"LS_y\", \"LS_true_y\", \"LS_time\",\n",
    "            \"IP_x\", \"IP_y\", \"IP_true_y\", \"IP_time\",\n",
    "            \"GT_x\", \"GT_true_y\", \"GT_time\",\n",
    "            \"LS_vs_IP_%\", \"IP_true_vs_GT_%\",\n",
    "        ]\n",
    "        print(opt_summary_df[cols].to_string(index=False))\n",
    "    else:\n",
    "        print(\"None\")\n",
    "\n",
    "    print(\"\\n=== FAILURES / WARNINGS (if any) ===\")\n",
    "    if fail_df.shape[0] == 0:\n",
    "        print(\"None\")\n",
    "    else:\n",
    "        print(fail_df.to_string(index=False))\n",
    "\n",
    "    return spec_df, learn_df, opt_df, fail_df, learn_summary_df, opt_summary_df, gt_df\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e88e7a1f",
   "metadata": {},
   "source": [
    "## Tests"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "3ac79bcb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ASSIGNMENT] inferred in_dim=10 from Xtmp shape=(1000, 10)\n",
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.503  std(mean)=0.5  min=0  max=1\n",
      "  y: shape=(1000,)  mean=760  std=384  min=6  max=1.92e+03\n",
      "\n",
      "\n",
      "=== Run: assignment | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=16,725 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAxFlJREFUeJzs3Qd4U2XbB/B/VhcdUEah7A1lTwVlichwAYrgBMWBoqK+LvRzvipOxAHu/ToQBRcooiBb2SAblFX2bGnpSnK+6z4h7clskiZNm/x/15UmOTk5OT1JTs59nvu5H52iKAqIiIiIiIiIKOj0wV8kERERERERETHoJiIiIiIiIgohtnQTERERERERhQiDbiIiIiIiIqIQYdBNREREREREFCIMuomIiIiIiIhChEE3ERERERERUYgw6CYiIiIiIiIKEQbdRERERERERCHCoNtHH3/8MXQ6ncfLH3/8gXDavXu3uh4vv/xywMv4v//7P1xyySWoW7euuqwxY8Z4nPfff//F8OHDUbVqVSQmJmLAgAFYs2aN23m/+uordOzYEXFxcUhPT8c999yDnJwcl/lkmjwm88i88hx5ric//PADjEYjjh49qt6fMmWKuk6NGzdW179v374en3vkyBH1/6tRowYSEhLQo0cP/P77727n/e2339THZT6ZX54nz3dWVFSEp556Co0aNUJsbCxatWqFN954A76S5z355JMI12dbPkO+zOfp864oCpo1a+Z22x8/fhwTJ05ERkYGqlSpgpSUFHX7XH/99diwYUO5fs9uvvlmtG3bVv3sxsfHo0WLFnjggQdw7Ngxn5exZ88e3HTTTepnVd5r+c4MGzbM7bzff/89+vTpg+TkZPV/b9OmDd59912HeQoLC/H444+rn92YmBg0bNhQ3V55eXkIBV8+0/v27VP/pyZNmhS/Z506dcKbb74Js9ns82s9/fTT6vtutVpRGT322GPo3LlzpV1/ospO9kOyrz516pTHea699lqYTCYcPnzY5+XKb0o4fnNL89xzz+G7775zmb5582Z1fUv7rQ6FTz/9FDVr1sTp06fL7TUzMzPVY0L5/ZTfa3m/5BjBWXZ2Np599ln1uKN27drqMWm7du3wwgsvID8/32X+nTt3qsceDRo0UD9XTZs2xX333acep2jJPEOHDg3p/0jRhUG3nz766CMsX77c5SIH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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.042e-03 @ epoch 989\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=549.96  x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\n",
      "STOP: local minimum. best_y=549.96 x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\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 17635 nonzeros\n",
      "Model fingerprint: 0xd41c1284\n",
      "Variable types: 8704 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 3e+01]\n",
      "  Objective range  [3e-03, 2e+06]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [4e-02, 5e+01]\n",
      "Presolve removed 0 rows and 1035 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 161 rows, 7679 columns, 15560 nonzeros\n",
      "Variable types: 7669 continuous, 10 integer (10 binary)\n",
      "\n",
      "Root relaxation: objective 5.232863e+01, 117 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   52.32863    0    2          -   52.32863      -     -    0s\n",
      "     0     0   52.32863    0    2          -   52.32863      -     -    0s\n",
      "     0     2   52.32863    0    2          -   52.32863      -     -    0s\n",
      "*    1     0               1      54.4684617   54.46846  0.00%   2.0    0s\n",
      "\n",
      "Explored 3 nodes (142 simplex iterations) in 0.02 seconds (0.02 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 1: 54.4685 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 5.446846171877e+01, best bound 5.446846171877e+01, gap 0.0000%\n",
      "[CHECK DFN] obj(x_ip)=54.4685  ip_y=54.4685  rel_err=8.104e-07\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.503  std(mean)=0.5  min=0  max=1\n",
      "  y: shape=(1000,)  mean=760  std=384  min=6  max=1.92e+03\n",
      "\n",
      "\n",
      "=== Run: assignment | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,610 layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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m4iIihmDbiIiIvKqEydOYM6cOZg5c6bL/bKysuTJxNsN7RhwExFRScDJTUREROTQG2+8IafXuDr9/vvvVre5cOGCLDUfMGAARowY4XJk33nnHdmAxnSqVq0a/yeIiMjnsHs5ERG57bodFxeHoKAgjlQ+ZWRkyA7fpa17+bVr1+TJFfHcMP1NIuDu2rUr2rRpg4ULF0ItG07mLdMtAu+SOBZERES22L2ciIgKTKPJWedep9Mx6C6A9PR0+VOr1ZaqZ6VYx1ycPHH+/HkZcLdo0QILFixwG3ALAQEB8kREROTLOKebiIicf0j4+SE4OBhXr16VAaMngRTlUhRFBtxXrlxBRESE+SCGrxEZ7i5duqB69eqyW7l4vphER0cX62MjIiIqbgy6iYjIKTFnNyYmRpaYnz59miOVTyLg9uXgc+3atTh+/Lg8xcbG2h14ICIiKssYdBMRkUv+/v6oW7euLDGnvBMVAr6a4TYZPny4PBEREZE9Bt1EROSWKCu3bQBGRERERO5xch4RERERERFRIWHQTURERERERFRIGHQTERERERERFRKfm9Nt6pIqFionIiIq6UyfV+zyzc9wIiLyzc9wnwu6U1NT5c9q1aoV90MhIiLK0+dXeHh4mR4xfoYTEZEvfoarFB87tG40GnHhwgWEhYXJ9WULeuRCBO9nz55FuXLlvPYYywKOHceNz7fSga/V4h838TEsPqyrVKkiu8SXZQX5DOdz2bs4nhzLkorPTY5lSeLpZ7jPZbrFHxsbG+vV+xRfqBh0c+yKEp9zHLeixudc8Y5bWc9we/MznM9l7+J4cixLKj43OZYlhSef4WX7kDoRERERERFRIWLQTURERERERFRIGHS7EBAQgEmTJsmflDccu/zhuHHcihqfcxw3X8HnMsezpOJzk+NZUvG5WXR8rpEaERERERERUUnBTDcRERERERFRIWHQTURERERERFRIGHQTERERERERFRIG3S589NFHqFmzJgIDA9GiRQts2bIFZdU777yDVq1aISwsDJUrV8ZDDz2EI0eOWO0j2gO88cYbcnH4oKAgdOnSBQcPHrTaJysrC8899xwqVqyIkJAQPPjggzh37hzK0jiqVCq88MIL5m0cN+fOnz+PoUOHokKFCggODkbTpk3xxx9/cOxc0Ov1eO211+R7l3gd1qpVC1OmTIHRaOS42di8eTP6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wEClVq1ayoQJE5SsrCyOm42NGzc6fF8TBy68+fy6fv26MmTIECUsLEyexPmbN296+I5BeSU+l5x9ZlH+iNeEo/EUryFyj98ni+Y9m7z7vZ68SyX+KYwMOhEREREREVFZx0lORERERERERIWEQTcRERERERFRIWHQTURERERERFRIGHQTERERERERFRIG3URERERERESFhEE3ERERERERUSFh0E1ERERERERUSBh0ExERERERERUSBt1ERERERGWETqdDnTp18Ouvv6KkatWqFVasWFHcD4PIaxh0ExEREREVsjfeeANNmzYt9nH+5JNPUKNGDXTo0AEl1cSJE/HKK6/AaDQW90Mh8goG3UREREREJUR2dnah3v+cOXMwYsQIFEVGPb/69OmD27dv46effvLqYyIqLgy6iYiIiIjc+OKLL1ChQgVkZWVZbX/kkUfw5JNPurztwoULMXnyZOzbtw8qlUqexDZBnJ83bx769euHkJAQTJ06VV4XERFhdR/ffvut3NfS6tWr0aJFCwQGBqJWrVryd+j1eqePY/fu3Th+/LgMak1OnTol71eUc3ft2hXBwcFITEzE9u3brW67fPlyNGrUCAEBAYiLi8PMmTOtrhfbxGMfPnw4wsPDMXLkSPPfsWbNGtSvX1/e96OPPoq0tDQsWrRI3qZ8+fJ47rnnYDAYzPel0WjQu3dvfP311y7Hlai0YNBNREREROTGgAEDZGC4atUq87Zr167JgPKpp55yedvHH38c//jHP2TQevHiRXkS20wmTZokg+79+/cjKSnJo/8LkQUeOnQoxowZg+TkZMyfP18GuW+99ZbT22zevBn16tVDuXLl7K6bMGECXn75Zezdu1fuM2jQIHMA/8cff+Cxxx7DwIED5WMUpfKiBNx04MBkxowZSEhIkPuL64X09HR88MEHWLp0KX788Uf88ssv6N+/P/73v//J05dffilL3v/73/9a3Vfr1q2xZcsWj8aCqKTzK+4HQERERERU0gUFBWHw4MFYsGCBDMCFxYsXIzY2Fl26dHF729DQUPj5+SE6OtruenG/ngbbJiK4FvOehw0bJi+LTPebb76JcePGySDeEZHVrlKlisPrRMBtyoCLjLk4QCCy4g0aNMCsWbPQrVs3cyAtgnIR6IsgW2S2Te699155PyZbt26V5fIff/wxateuLbeJTLcItC9fvizHJD4+XmbYN27caHUgomrVqjhz5oyc161WM09IpRufwUREREREHhAl02vXrsX58+flZRGAi6DTtuw7r1q2bJnn24hs8pQpU2TgajqJxyey6CK77EhGRoYsRXekSZMm5vMxMTHy55UrV+TPQ4cO2TVeE5ePHTtmVRbu6O8QJeWmgFuIioqSZeXi8VpuM/0uywMVIuC2LecnKo2Y6SYiIiIi8kCzZs3kfGcxv7tnz56y1FrMqy4oMZfbksjsKorissGaCEhFRlqUattyFlhXrFhRPmZHtFqt+bzpIIKpe7h4LLYHFmwfn6O/w/Z+TfftaJttp/IbN27IgF0E30SlHYNuIiIiIiIPic7fs2fPltnu7t27o1q1ah7dzt/f3yor7EqlSpWQmpoqG46ZAlkx19pS8+bNceTIEbnmdl4OGohSb0dBtCuiBFyUilvatm2bLDMXTc8Kw4EDB+TfSOQLWF5OREREROShIUOGyID7008/zdM8bFFSffLkSRk8iwZsrsqm27RpI7O8r776qpxXvWTJErumZa+//rrMuIumZgcPHpQl4MuWLcNrr73m9H7F3GkRyIv980I0gfv555/lnPGjR4/KzuMffvih1fxtbxNN1O67775Cu3+iosSgm4iIiIjIQ6Lzt1gmTMxJfuihhzweN3GbXr16ycBXZLJdLYcVGRmJr776Snb3bty4sdxXBNeWRHm76Jy+bt06tGrVCm3btpUNz2rUqOH0fsWSZ6IcXTSAywuRcf7mm29kB3LRnVwE/GI+uWUTNW8SBzVEJt1dV3ii0kKlOJqQQUREREREDvXo0QMNGzaUS2GVNmJOtyiLFxn0sLAwlERjx47F7du35VJiRL6AmW4iIiIiIg+I5l4i27thwwaMGjWqVI6ZyJxPnz5dLh9WUlWuXFmWshP5Cma6iYiIiIg8nJd98+ZNuV617Xxmsa716dOnHd5u/vz5ci44EZVNDLqJiIiIiApIBNy2y3pZrkNdUku5iajwMegmIiIiIiIiKiSc001ERERERERUSBh0ExERERERERUSBt1EREREREREhYRBNxEREREREVEhYdBNREREREREVEgYdBMREREREREVEgbdRERERERERIWEQTcRERERERERCsf/A6f017q/m52+AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 2.978e-03 @ epoch 350\n",
      "\n",
      "iter=0  t=0.00s  best_y=551.456  x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\n",
      "STOP: local minimum. best_y=551.456 x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\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: 0x94766c77\n",
      "Variable types: 8860 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 2e+00]\n",
      "  Objective range  [3e-03, 2e+06]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [4e+00, 5e+01]\n",
      "Presolve removed 1 rows and 3139 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 411 rows, 5731 columns, 11471 nonzeros\n",
      "Variable types: 5721 continuous, 10 integer (10 binary)\n",
      "\n",
      "Root relaxation: objective 5.877496e+01, 623 iterations, 0.01 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               0      58.7749562   58.77496  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (623 simplex iterations) in 0.05 seconds (0.03 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 1: 58.775 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 5.877495616603e+01, best bound 5.877495616603e+01, gap 0.0000%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=58.775  ip_y=58.775  rel_err=1.227e-07\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.503  std(mean)=0.5  min=0  max=1\n",
      "  y: shape=(1000,)  mean=760  std=384  min=6  max=1.92e+03\n",
      "\n",
      "\n",
      "=== Run: assignment | MLP ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=18,049 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA/shJREFUeJzsnQWY3FTbhp/ZWa27u7tAW6BYcVq0WMuHQ4FCcefD/uLuLU5x6Ae0OJRSqFNvKXV3t92u787kv95kMnNycpLJzPrue1/X7M5kTpITmSTPec2naZoGhmEYhmEYhmEYhmGKnYTiXyTDMAzDMAzDMAzDMCy6GYZhGIZhGIZhGKYEYUs3wzAMwzAMwzAMw5QQLLoZhmEYhmEYhmEYpoRg0c0wDMMwDMMwDMMwJQSLboZhGIZhGIZhGIYpIVh0MwzDMAzDMAzDMEwJwaKbYRiGYRiGYRiGYUoIFt0MwzAMwzAMwzAMU0Kw6I6Bjz76CD6fz/E1depUlCWbNm3S+/Hiiy/GvYyHH34YZ599Npo3b64v6+qrr3Zsu2HDBlxwwQWoU6cOatSogdNOOw2LFi1Stv3qq6/Qp08fpKamolmzZrjjjjuQmZlpa0fT6DtqQ21pHprXiR9++AGJiYnYu3ev/vnVV1/V+9S2bVu9/4MGDXKcd8+ePfr2NWjQANWqVcMxxxyDKVOmKNv+8ccf+vfUjtrTfDS/TEFBAUaPHo02bdogJSUFXbp0wRtvvAGv0Hz/93//h7I6t+kc8tLO6XzXNA0dOnRQ7vv9+/fjwQcfRLdu3VC9enXUrl1b3z9XXHEFli5dWqq/sxEjRqBHjx76uZuWloZOnTrh3nvvxb59+zzNH8t59tdff+m/jUaNGum/k169euH1119HIBBwnCcnJ0fvU1F/z254Pafleczj4HVfEY8//rh+3IPBICoijzzyCI444ogK23+GqegMHTpUv1YfOnTIsc1ll12GpKQk7N692/Ny6VpWFvfcaDz99NP47rvvbNNXrFih9zfavbok+OSTT9CwYUMcPny41Na5bds2/ZnwxBNP1O/XdLzoGUEmIyMDTz31lH4vbtKkiX6v7dmzJ5577jnk5uba2q9bt05/9mjVqpV+XrVv3x533XWX/pwiQm3OP//8Et1GpurAojsOxo0bh7///tv2ooeyis4rr7yiX3TOPfdcJCcnO7YjkXv88cdjzZo1+PDDD/G///1Pv7DRBW/16tWWtp9//jkuvfRS9O/fH7/++isee+wx/aJJokWGpn388cd6G2pL89C8X3zxhbIf3377LU444QT9RkC8/fbb2Lx5M04++eTwNBV5eXk45ZRTdJH92muv4fvvv0fjxo1x5plnYtq0aZa29Hnw4MH699SO2pP4oPlpOSI333wznnnmGYwaNQqTJk3SHxRuv/12/QZamahZsyY++OAD23TaV+vXr9e/lwdTjj76aP24k+ClwRI6L2644QZs3LgRS5YsKdXfWVZWlr5uOq9+/vlnvU/vvvuufmPPz8+POr/X84zOk1NPPRWFhYV477339Ico+o3QOUE3eDeRR30sKWI5p8VjeP311+sDYrGwY8cOPP/887rwTkiomLece+65Rz9P6drEMEzpc9111+nPGE7PAunp6Zg4caJuNKDrWkXHTXTTwH5pi+7s7Gz897//xf3332+7v5ckJI7pWYGeR4cMGeLYbsuWLfpgOD0f0L2cnjEuuugifYCCzgkyCIjPr/Q8MmvWLDzxxBP45Zdf9Gc2ukfT/VocXKX56Rnhzz//LPFtZaoAGuOZcePG0a9Wmz9/frncaxs3btT798ILL8S9jEAgEH5fvXp17aqrrlK2u/fee7WkpCRt06ZN4Wnp6elagwYNtEsuuSQ8rbCwUGvatKl2+umnW+b//PPP9b7+8ssv4Wk///yzPu2LL76wtD3ttNO0Zs2a6csSyc/P1+rUqaO9+eabyv53795dO/HEE5X9HzNmjL6u2bNnh6cVFBRo3bp10wYMGGBp279/f306fW8ya9Ysff6xY8eGpy1btkzz+Xza008/bZn/+uuv19LS0rT9+/dr0WjdurX22GOPaWV1btM55KXdiBEj9G2iYy5y+eWXa8ccc4xt33/44Yf6fH/++adyueJxK6vfGR1LWu+UKVOitvV6nl122WVaSkqKlpmZaZlOv4datWop55k7d66WnJysff3110X+PTvh9ZwWGTVqlNa3b1/t4Ycf1tvt3bvX07ruu+8+rXnz5pZ9VlpkZWUV27JuueUWrVOnTlowGCy2ZTIM4w26/9NzwJFHHqn8/q233tKvSz/++GNMu5TmKYt7bjScnr/M+8Jff/1VqtdKui+kpqZqBw8e1EoT8b5BzwS07fSMIEP3WPk+S9D9k+aZMWNGeNp7772nT/vjjz8sbenZjaYvWrTIMv3ss8/Wn0MZpqhUTLNDBYBcYG655Ra88847upsouRqTe6XKVXrZsmU477zzULdu3bBLtcqiQm5Vd999N9q1a6cvj9xVaeRv1apVtrYvv/yy7vpKLjbkQjpnzhxP/fZqiaIRZbLytW7dOjytVq1auqX6xx9/1C17BK13586duOaaayzzX3zxxXrfaDniMmkafSdC85K1bO7cuZbpZKWm0W2yJsfT/86dO+v7xoTc1C+//HLMmzcP27dv16fR//nz5+suRvS9ycCBA/XjKvafRqXpHi5vK30md+HffvsNxQGN5tL5RSPAMjQKTSPCpuvv5MmT9XOrRYsW+rlFrt833nhjTK7BKsj7gPjyyy/D0+hYkOfBtddea2tvumw1bdpUubzyYAE1LdbicXbCa3/J1ZGOB7mviZCbHB0PGbKy0/6jUfd+/fo5LnfXrl36caTjSsun3zpZP8zfnRuxnNMmM2bM0K0H77//Pvx+v4ctj2wPeUT85z//sewzMRTGy7WKrBamKzxZWchdn7weRMgiQcukEBeycND1lFwGzbANsnb89NNP6Nu3r348unbtqn8myAODPlPYw4ABA7BgwQJbH2h/kWcPhQswDFO60HXnqquuwsKFC/Hvv/8qPaPo/kIePGTJJK8zeuai6wo9K9HzCl3H4uWtt95C79699eXRNYhCo8jyK19byYOqZcuW+nWZvILoWmS6u5Olnp7h6BmPwqvq1aunX9fI20iErmPk6UTPgWY4D3lI0XXKfD466aSTwt+J7tamxxI9j9H18thjj7WFzbldK922/5xzztHvXapn3U8//VS/htI6aT+Z19ai4vVeS9duesnQ9ZzYunWr5b5M0DEQMbdNvjfTtZ/2K3nxMUxRKPsn3QoIxWLSw634UsVn0oMixW6SW+U333yjC1QSK/TehFyx6WF3+fLletsJEyboNwqKrySXTBOKoTnuuON0EU8ijoQtubjSQzKJWpExY8boYovEGbnl0MWbxDmJouKABCRdfCg2VYam0fcU720OKJjTReiiRzct83uzLV20ZdFjziu2JUjg0Q0rVndXc1lO/SfoeLj135wm95+EG8UTeel/vNDAAN3Q5bgmOgc/++wz/cZIMboEHSfaR3TD/P333/Hoo4/qgxd0LlH8ebzQDZ1u1hRaYEICnG6Qw4YN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5MmT9O9//9unxwTgLwi6AQAAAABc+Nvf/kaNGjWiiooKxfXDhw+n22+/3fC+8+fPp6lTp9K6desoIiJCXPg6xl/PmTOHrr/+ekpMTKTnn39e3JaamqrYx+LFi8W2so8//pi6d+9OcXFxlJ+fLx6jqqpK9zhWr15N27dvF0Gt3e7du8V+uZy7f//+lJCQQAUFBfTDDz8o7vvBBx9Qx44dKTY2lvLy8ujll19W3M7X8bHfcccdlJKSQvfee6/jeXzyySd0ySWXiH3feOONdPbsWXr77bfFfdLS0ujBBx+k6upqx76ioqLommuuoffff99wXAGCBYJuAAAAAAAXRowYIQLDjz76yHHdkSNHREB55513Gt535MiR9Lvf/U4ErQcPHhQXvs5u8uTJIuhev3493XXXXaZ+FpwFHj16NI0fP55KS0tp7ty5IsidNm2a7n2+/fZbatu2LTVs2NDptieffJJ+//vf09q1a8U2t9xyiyOAX7VqFd1000108803i2PkUnkuAbefOLB78cUXqVOnTmJ7vp2dO3eO/vKXv9CCBQvo888/p2+++YaGDRtGn376qbj8/e9/FyXv//znPxX7uvTSS+m7774zNRYAga6Bvw8AAAAAACDQxcfH06233kpvvfWWCMDZu+++S9nZ2VRSUuLyvklJSdSgQQPKyspyup33azbYtuPgmuc9jxkzRnzPme7nnnuOHn30URHEa+GsdrNmzTRv44DbngHnjDmfIOCseLt27WjmzJk0cOBARyDNQTkH+hxkc2bbbsCAAWI/dt9//70ol589eza1atVKXMeZbg60Dx06JMakQ4cOIsP+9ddfK05ENG/enMrKysS87shI5AkhuOEVDAAAAABgApdMf/HFF7R//37xPQfgHHSqy77dVVRU5PZ9OJv87LPPisDVfuHj4yw6Z5e1nD9/XpSia+nSpYvj66ZNm4r/y8vLxf+bNm1yarzG32/btk1RFq71PLik3B5wsyZNmoiycj5e+Tr7Y8knKjjgVpfzAwQjZLoBAAAAAEwoLCwU8515fvfVV18tSq15XrW3eC63jDO7NpvNsMEaB6SckeZSbTW9wDojI0Mcs5bo6GjH1/aTCPbu4Xws6hML6uPTeh7q/dr3rXWdulP5sWPHRMDOwTdAsEPQDQAAAABgEnf+fuWVV0S2+4orrqCcnBxT94uJiVFkhY1kZmbS6dOnRcMxeyDLc61l3bp1oy1btog1t905acCl3lpBtBEuAedScdny5ctFmTk3PbPChg0bxHMECAUoLwcAAAAAMGnUqFEi4P7rX//q1jxsLqnetWuXCJ65AZtR2XSPHj1ElveJJ54Q86rfe+89p6ZlzzzzjMi4c1OzjRs3ihLwhQsX0lNPPaW7X547zYE8b+8ObgK3dOlSMWd869atovP4a6+9ppi/7WvcRO2qq66ybP8A9QlBNwAAAACASdz5m5cJ4znJN9xwg+lx4/sMGjRIBL6cyTZaDis9PZ3eeecd0d27c+fOYlsOrmVc3s6d05csWULFxcXUs2dP0fAsNzdXd7+85BmXo3MDOHdwxvkf//iH6EDO3ck54Of55HITNV/ikxqcSXfVFR4gWETYtCZkAAAAAACApiuvvJLat28vlsIKNjynm8viOYOenJxMgeiRRx6hkydPiqXEAEIBMt0AAAAAACZwcy/O9n711Vc0bty4oBwzzpzPmDFDLB8WqBo3bixK2QFCBTLdAAAAAAAm52UfP35crFetns/M61rv2bNH835z584Vc8EBIDwh6AYAAAAA8BIH3OplveR1qAO1lBsArIegGwAAAAAAAMAimNMNAAAAAAAAYBEE3QAAAAAAAAAWQdANAAAAAAAAYBEE3QAAAAAAAAAWQdANAAAAAAAAYBEE3QAAAAAAAAAWQdANAAAAAAAAYBEE3QAAAAAAAABkjf8D81+FEtCs81QAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 2.305e-04 @ epoch 654\n",
      "\n",
      "iter=0  t=0.00s  best_y=548.961  x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\n",
      "STOP: local minimum. best_y=548.961 x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\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: 0x3db6447c\n",
      "Variable types: 513 continuous, 266 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [5e-06, 8e+01]\n",
      "  Objective range  [4e+02, 4e+02]\n",
      "  Bounds range     [4e-01, 8e+01]\n",
      "  RHS range        [5e-04, 8e+01]\n",
      "Presolve removed 388 rows and 102 columns\n",
      "Presolve time: 0.07s\n",
      "Presolved: 894 rows, 677 columns, 15497 nonzeros\n",
      "Variable types: 443 continuous, 234 integer (234 binary)\n",
      "\n",
      "Root relaxation: objective -5.008929e+02, 515 iterations, 0.01 seconds (0.03 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 -500.89286    0  105          - -500.89286      -     -    0s\n",
      "H    0     0                      53.8081301 -500.89286  1031%     -    0s\n",
      "     0     0 -282.80987    0  129   53.80813 -282.80987   626%     -    0s\n",
      "     0     0 -259.98120    0  125   53.80813 -259.98120   583%     -    0s\n",
      "     0     0 -258.00896    0  127   53.80813 -258.00896   579%     -    0s\n",
      "     0     0 -257.87367    0  126   53.80813 -257.87367   579%     -    0s\n",
      "     0     0 -257.70721    0  127   53.80813 -257.70721   579%     -    0s\n",
      "     0     0 -257.70714    0  127   53.80813 -257.70714   579%     -    0s\n",
      "     0     0 -204.81961    0  132   53.80813 -204.81961   481%     -    0s\n",
      "     0     0 -174.71428    0  137   53.80813 -174.71428   425%     -    0s\n",
      "     0     0 -171.75511    0  136   53.80813 -171.75511   419%     -    0s\n",
      "     0     0 -170.25666    0  136   53.80813 -170.25666   416%     -    0s\n",
      "     0     0 -169.88299    0  137   53.80813 -169.88299   416%     -    0s\n",
      "     0     0 -169.80061    0  136   53.80813 -169.80061   416%     -    0s\n",
      "     0     0  -93.14550    0  139   53.80813  -93.14550   273%     -    0s\n",
      "     0     0  -79.46131    0  137   53.80813  -79.46131   248%     -    0s\n",
      "     0     0  -77.01063    0  136   53.80813  -77.01063   243%     -    0s\n",
      "     0     0  -76.49795    0  136   53.80813  -76.49795   242%     -    0s\n",
      "     0     0  -76.41428    0  137   53.80813  -76.41428   242%     -    0s\n",
      "     0     0  -45.64445    0  141   53.80813  -45.64445   185%     -    1s\n",
      "     0     0  -29.35215    0  140   53.80813  -29.35215   155%     -    1s\n",
      "     0     2  -29.35215    0  140   53.80813  -29.35215   155%     -    1s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 4\n",
      "  Gomory: 21\n",
      "  Cover: 142\n",
      "  Implied bound: 79\n",
      "  MIR: 487\n",
      "  StrongCG: 18\n",
      "  Flow cover: 53\n",
      "  Zero half: 1\n",
      "  RLT: 16\n",
      "  Relax-and-lift: 8\n",
      "\n",
      "Explored 253 nodes (15910 simplex iterations) in 1.42 seconds (2.26 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 1: 53.8081 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 5.380813009947e+01, best bound 5.380813009947e+01, gap 0.0000%\n",
      "[CHECK MLP] obj(x_ip)=53.8081  ip_y=53.8081  rel_err=4.578e-07\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.503  std(mean)=0.5  min=0  max=1\n",
      "  y: shape=(1000,)  mean=760  std=384  min=6  max=1.92e+03\n",
      "\n",
      "\n",
      "=== Run: assignment | MaxAffine ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,600 n_pieces=1600\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA94AAAGGCAYAAACNL1mYAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAmsdJREFUeJzt3Qd4U1UbB/B/96J0UHZLKXuXMmXJkqkoG0URFFQQFUVxfE5cgIOhAgIquEFkiIAM2ZsCZZZNoWUWCt3Qme95T0hN23SSNKP/3/MEmpub5PQmvfe+97znPXYajUYDIiIiIiIiIjIJe9O8LBEREREREREx8CYiIiIiIiIyMfZ4ExEREREREZkQA28iIiIiIiIiE2LgTURERERERGRCDLyJiIiIiIiITIiBNxEREREREZEJMfAmIiIiIiIiMiEG3kREREREREQmxMC7kBYsWAA7O7s8b5s3b4Y5nT9/XrXjiy++KPZrvPPOO3jooYdQtWpV9VojRozIc91z586hf//+8Pb2RpkyZdCtWzccOHDA4LoLFy5E06ZN4erqiipVquDll19GYmJirvVkmTwm68i68hx5bl5WrFgBR0dHXL9+Xd2fPn26alNQUJBqf6dOnfJ8bnR0tPr9/Pz84O7ujjZt2mDDhg0G1/3333/V47KerC/Pk+fnlJaWhokTJ6J69epwcXFBvXr18PXXX6Ow5HkffPABzPXdlu9QYdbL6/uu0WhQq1Ytg9s+JiYGb731Fho0aAAPDw94eXmp7TNs2DAcPny4RP/OfvrpJzz66KOoW7cu7O3t1XYvrvDwcPVZS9v27duX6/G1a9eiXbt2cHNzU79znz59cOzYsXxf8/bt26hTp849/z3npzDf6aioKPTr1w81atTI+sxCQkLwzTffID09vdDv9eGHH6rPPTMzE9bo3XffRbNmzay2/US2QPZFsh+NjY3Nc53HH38cTk5OuHbtWqFfV/az5jjuFuTTTz/F8uXLDR5zpL0FHa9NQY6d5cuXR0JCQom958WLF9V5YceOHdX5pnxecp6QU3x8PD755BN17lGpUiV1Xtq4cWNMmTIFd+7cybX+mTNn1PlHtWrV1PeqZs2aGD9+vDpX0Sfr9O3b16S/I5UuDLyLaP78+di1a1eum5yYWbtp06apnc7DDz8MZ2fnPNeTQLdDhw44deoUfvjhB/zxxx9qxyY7vJMnT2Zb99dff8Vjjz2Gli1b4p9//sH777+vdpoSIOcky3788Ue1jqwrz5Hn/vbbbwbbsWTJEtx///3qQCC+/fZbXLhwAV26dMlaZkhKSgq6du2qAu0ZM2bgr7/+QsWKFdGzZ09s2bIl27pyv1evXupxWU/Wl6BFni+vo+/555/HpEmTMHbsWBVwyYnCuHHj1AHUlnh6euL777/PtVy21dmzZ9XjOS+o3HfffepzHzVqlLpgIt+LZ599FhERETh48GCJ/p39/PPPKvht1aqVOtgWV0ZGBp5++mkVuBoi3xf57lSoUEF9V+X7efr0afW3I9spv0AvKSkJplLY77S0oWzZsqo98pnJRbD27dvjxRdfxOjRowv1XpcvX8Znn32mgm+5yGGNXnvtNfU9lX0TEZnHyJEj1XlGXucDcXFxWLZsmeo8kH2btcsv8JYL/CUdeCcnJ+N///sf3njjjVzHeFOSAFnOF+SctHfv3nmuFxkZqTpf5Bxh7ty56pg1cOBAdZFCvhPSMaB/DivnJDt27MBHH32E1atXq/O2efPm4YEHHsh2kVWev2rVKmzcuNHkvyuVEhoqlPnz58tfrSY0NNQit1hERIRq3+eff17s18jIyMj62cPDQzN8+HCD602YMEHj5OSkOX/+fNayuLg4jZ+fn2bw4MFZy9LT0zWVK1fWdO/ePdvzf/31V9XW1atXZy1btWqVWvbbb79lW7dbt26aKlWqqNfSl5qaqvH29tZ88803BtvfsGFDTceOHQ22f+bMmeq9du7cmbUsLS1N06BBA02rVq2yrduyZUu1XB7X2bFjh3r+rFmzspYdPXpUY2dnp/n000+zPf+ZZ57RuLm5aWJiYjQFCQwM1Lz//vsac3235TtUmPVGjRqlfif5zPU98cQTmjZt2uTa9j/88IN63saNGw2+rv7nVhJ/Z/rv9+CDD6rtXhzyt1a1alXNjBkzDLa5bt26miZNmmgyMzOzlsnfjLOzs2bo0KEGX3PPnj3q8cWLF9/z33NeCvudzov8jTs6Omru3LlT4Lqvv/662kb627ykJCUlGe21XnjhBU2dOnWyfZZEVHLkHEDOBZo3b27w8dmzZ6t92N9//12k15XnmOO4W5C8zsF0x4ZNmzaV6P5Sjg2urq6aW7duaUqS/rFDjrHyu8t5Qk6JiYnqlpMcQ+U527Zty1o2b948tezff//Ntq6cv8nyAwcOZFv+0EMPqXNRImOwzi4ICyepMC+88ALmzJmjUkYlFVVSLQ2lTR89ehSPPPIIfHx8stKrDfWsSHrVq6++qtI+5fWkF02u/p04cSLXulOnTlXp1pJqI+mku3fvLlS7C9sjJVeVpVc5MDAwa5n0jEmP9d9//52Vhirve+XKFTz11FPZnj9o0CDVNnkd/deUZfKYPnmu9Jrt2bMn23LprZYr3NKrXJz2S5qxbBsdSVl/4oknsHfvXly6dEktk/9DQ0NVqpE8rtO2bVv1ueq3X65MyzE85+8q9yV1eM2aNTAGuaIr3y+5CpyTXImWq8I3btxQ99evX6++W/7+/uq7JWngzz33XNbjxSVZCOL333/PWiafhfTqSg9wTrrUrcqVKxt8vZLuCTXG+0nP9XvvvYdZs2ap776h31myP6RnWT4vHfmbadSokfq+SI+5vtTUVLX95Mp7ixYt8nzvq1evqs9RPlf5vOVvXXpACpP+XZTvdF4km0S2oYODQ77rye8jmRFDhw7Nts31h8UUZl8lPRe6tHjpaZFhLZL9oE96JeQ1ZbiL9HLI/lSXzSBDCaTHY+XKlSpVXtIK69evr+4LycSQ+5JOL1kQhoYMyPaSDJ9NmzYVuH2IyPhkfzN8+HDs378fR44cMZglJccY2edKj6ZkoMl5l+xb5HxJzlm2bdtW7PefPXs2goOD1evJfkiGSkkPcM79q2RyBQQEqH2zDJuT/ZEu9V167OU8Ts7zZOiOr6+v2rdJ5pE+2ZdJxpGcC+qGWUlGoeyrdOdInTt3znpMP/Val70kxyXZZ8pQp5zD6PLbX+b3+8tQKUn3NnS+K5lksh+V95TtpNu/ltTxWvbfcstJ9um6oVM6MhxByGegT/e7yflSzv2/bNf8MtWICouBdxHJybKc4Orfcp5A604Wv/rqK5Vi+eeff6oTbglY5GcdOTGXE15Je5V1ly5dqg4UMt5S0jN1ZDyNpHhKIC+BnAS3krYqJ8oS2OqbOXOmCrgkQJP0HNl5S4AugZExSBApO58mTZrkekyWyeMy/lt3UUG3XJ/s9OSgpXtct67stPWDAf3n6q8rJMiTA5Yc2IpKXiuv9gvdGNy82q9blrP9EpDI2KLCtL+45OKAHNBzjnGS7+Avv/yiDoy61Gf5nGQbyQFz3bp1KlCUCxjyXZLx6MUlB3Q5WMswAx0JwuUAOWTIkFzr6y5wPPnkkyrgzDmGqrh/Z4bWMXQz9thcucAiKfMSzMmwjLyCTiEXyXKSZZK2l/MgLvsK+XuV1Lf8gm45kZChDPJ5ypAMScGUIQ7PPPNMgW0vynda//eV7Xjr1i0sWrRIfffk5DHn32pO8l2Tz1pOEA0pzL5K0krl4pF85+Q7JoG8tENOQrdv357rNeXin1xgWrx4sdpH6hw6dEjVGJCLU7KflRMuWVeGtXz33XcqrVPaIO8tn6vsx/Q1b95cnXBLyiERmYdcmJRAT//Yo0u/lovmEphLgH7z5k21XP6+5W9WgnLptJD9RnHqhEiniQTyMs5YLk7KceyVV17JNiRIgm4ZHiePy1hh2TfLvk32NbLPEjKUR9omw1fkNWSfJsdj2RfJ+GkdubAoFwhlf6gbZiUXeR988MGsoWuy/9Q9JsuFnAN0795d7S8laJdhgBLc9+jRw2ANm7z2l4bGWcvFjrz25bKNpfaHHMPk3EzeUzpFdOeC+seRwtyMSZci3rBhw6xlMmZbxnbLcUzO92Q43NatWzF58mR1DiXnovrkeyPtl5R0ontmlH7zUkCXAmvo5uDgkG1dWSapuFevXs2WJlWvXj1NrVq1spY9+uijGhcXF01kZGS25/fq1Uvj7u6uiY2NVfc//PBD9Zrr168vMNW8cePG2dKy9+7dq5b//vvvRklzunTpknq9SZMm5XpM0sT1U7g/+eQTdf/KlSu51pX0c0nd1Kldu7amR48euda7fPmyeg39FG75/SSt/csvv8yz/fmlmkua/HPPPZdrubRbP91dlxK/a9euXOs+++yzKiVYR9KQJLXYEFlP1jdWqnn//v01/v7+2VKwJG0/vzQ7SZGV1OILFy6o9f76669ip5pLupekucnPkmKvS18eMWJEnttevsOyHXR/M0FBQZrRo0drDh06VOy/M3mPvNbVv+U1ZKK4qeZff/21xsfHJ+vv21B6vHw2vr6+mq5du2Z7rqTpeXp65hrqEBYWpr6Xa9asyXfoiHxvy5Qpoz5HfV988YVa/9ixY/m2vSjfaR35W9dtSxlO8fbbb2sKY8qUKeo5+vvBouyrZBtKaqmsp/9dT0hI0FSoUEHTtm3brGXydyPPfe+993K1Qz5f2R9fvHgxa9nBgwfV+jIURj/Fcvny5Wr5ihUrcr1Ou3btNK1bty7U705EpiH7fTn+y3AznVdffVX93Z46dcrgc2Q/I8c/2R/369evyKnmMtREhrbl5+mnn1b78PDw8EL/Lrp2jRw5UhMSEnJPqeayH5NjTp8+fbItl31ncHBwtmF0+e0vDVm0aJFaf/fu3bkek+UVK1bUxMfHZy2Tfb69vX2280TdOUNhbnmdi+SXam6InF/Ivj/nZ647t5ShcfrvO2jQoDyHUMmQqSFDhhTqfYnyk3+XBeUiVyVzXg3TTyXVkVQf/QIfchVWegMlJVSuHkqaqFyJk/UkLUmf9HjL1VK5kikFv+Rn6d2Wog8FkSuf+imgup4tKTpmTIZ+57wey2vdwq6X8zEpDiXp0oYKtFlD+++VZD1Ir52kPsnVbSFX9KW3XdLsdKRKtfSKytVoSdfX7/k9fvx4nr21hSFX/iU1TXoe5Psq6ctffvllnutLgS5JwZMrxtITunPnTnWFXXob5W9Kl75elL8zyQApTHXVvIqfFYf8HUnPqfRk5FfAR3r/JWVceq/lJqnhUnVVqrNKb7duHSFX+KUnR/YP0jORH0nfk14HyfTQ7xmQz116UeRvQ7JmJBtAv5iMvJd+yl5hv9NCPl/Z90hPjeyzPv/8c9UzXFDFfvnOyevltf0L2ldJRpC8hmwz/bZLz/OAAQPU5y/bUlIbdWS5IZLaKbM16Oi+W9KTof983XJD+0tJV5XvORGZj2T4SPaUZBXK37vsB6WnV4pW1q5dO2s9Ob5IkS3pDdcvGinZdkUlWUbSoyvHKZkRQ9K3c+7X5DxN9s05j1s5Se+yHD8kC0e/xzxnenNRyTFV9tHS65+z11jOIyWLUt5PPx07r/1lTrIf1u0DDZHfW7/gmhwbZV39/ahkDRV2/1mcTMacZEiTZC/J+bWcZ+iTDATJpJLjh2Q6yTqS7SXHajkvknOmnBld8vvohiES3QsG3kUkO9X8xl/q5Ew51l8m6ZcSeMv/hsa96nY6upRcGa8kaTGFUa5cuWz3damuOVMni0vGAsnJtKF0YV16l6QZ6bdF1s0ZpMi6uvV06xbmNYWk68tOvLjTQBX2vfTbb2jdnO03VJ1bDnSSdqy/7r2SIEu+NxJsS+AtBxE5CZEK6rpARoJseUwOmBL0yrQacsCV5VLN816/D/IdkAsAMkRCxq3JhSE58cmPfAfkObpx8JLaJb+LtDtn4F2YvzNJkdMPLvNizDHkEkzLGG05YdFNa6MLpCVdTQJS3bgxueghyz7++GP1sy7YlN9fTgR0gaCchElKnqQF6l5TgnQh21aWyUmNfLYyVlCGmujGqOWkG78vF/T0K/TLyZikiBflO62/39Ltu+Q7JfuAN998U10skDHTeZHvmLQzr7HgBe2r8qsNIPtI+S7Ld18/cM6rjkDO30s3a0Neyw1NPyMnxsbajxJR8cgwJ5lZQY5/sh+Wi7myX5Rpo3SkdoSkEcvsCxJMSZAs+yE5FspF56KSMb4SzErVa3lP2fdIWrns26XmhO48Tc7r8iMXzAcPHqzGaU+YMEHtVyXAk+FgOdPni0o3jly2T15kH68feOe1v8xJt9/L6+JAzn25bn+uv7+UC6ZyAbQwChrGVBAJ+OVigLyOpNjn3M/Ld0XO12Q93TaQ8xe5KCO1ACQYl2OmPu7/yVgYeJuIjMXMa5luJyX/5xyjrX91UXdFVcYOSy+5JZBxRxLwGCpuIsvkcRlLJSTY0y2XXjgdOYBJUTj9YEvWlfFO8pj+Tlf3PhLsCDngyRiql156qdi/g7xXXu3Xfy/d/7I85zQWskz3uO41ZRyYfMb6F11yvqYxyAmEnAhI0CtBmYyDlSv6+oXd5OqtXFGXYEv/AGKoKFtxSU+oBJTSsyDzZxaVTAUngZyMdZPe+byupuclZ3CZF13QaQyyXeVgLcFnTnKgl6BbFzzL91hOAGXcm0xHJX/PcpCXXm0pKKY7SZPXlIBdv7dGR04U5RYWFqZOWuQ1pGc4r+2tu2iXMxtAty8pync6L7piNVJsLL/AW95TLjrl7GUpLN1+Mq99pFxQyfk5GDOzxNBJqzGzJ4io6OQcQ84dJAiWfYMErHJhUr8wq/SASzaLBLT67mX+ad1FY9mfyUVjGT8uPaqyH5QaPoU5T5N2yb5famXo76tyTk1aHLp9k2QiycV1Q3J2gBR2f6l7bdkHFjZYz0mO1XmNEc9JjpfF7ViR47NuTLaM5zd0MUSCbrnwnfN3kYspwlCtE/ndi9smIn0MvE1ErrLJFUjdjk5SP2VnK+m5uh2BBA4SRMpJpH5qjaTZSi+ObucpvYIS4Eiap1yNMzcpmiG9dFIlUpcmLwc0uZoraTq6wLl169ZqxyZBj37RLemxlp5A/VRxeU05kEphDv11pUCIbBt5LV06lQS3hU2Ryqv9UihFUp51r6tLV5P7us9CdswSZMhySePV9dxJ5WVJg5UUWB1JW3rnnXdUe6WAk4787nKiIKlexiQnAJI6Jhcr5D2kgJl+Cp3ugJqzuJcEZMYi20eu2stFlJxXh/XJ34GuErY++ZuQ6uDyXc9ZKbUwzJFqLhdXcvaGSsV6uYIuFyD0C7joX+nXXYSSKrKyb9BPy5feY7mIoU++43JyKT028vcgF7uEnOhJD4/sRwwF/zpStd+Qonyn86Kr7K1rU15038e8ijEWRH4Haa9cWJK26r7TcuKrK66o39ttapKVYMwLaERU/HRz2d/KsBfZH8r+U39fIPuKnMe+w4cPq+F7OYf2FZVcRJRzMrmoKEW6pDiXBN6yTCp7y340r/2vtEuyavQDXtnX56xqbqjHWH+5yPmYpL/LcVRS66XKuDHp78sNHeMKoyRSzWUubwm65dxCgm79mXdyvr4chyV1XH8Ikm62jJzBupwfyvlufvOIExUWA+8ikithhqouyomwBBf6J/sSJEtvleyopSKlBCj6U4rJFVPdmE0JrCUdRlJcZHyJBFW6lFU5GZagXYI7OUmXE2fZ6coVRDkRL+xVxILI60m6lJAdl1w51FVhlzG9ut9PToLlACNps9KbJwcCqQYpAYlMU6EjJ/Xye0jvrIxxlUBCAq3XX39dpWfpB6Ny0JJlY8aMUWm2clIvQaUENRIk6AIEaY+c/Epqc04yDZCM6xHyGnLFU9d+uZKp2wlLiqxUBJUr5NJu6WmVz0cOmDJuWp8EVNIuWVeCdemZlc9A2qDfwywHIzkZkM9U2irvJ5XEZYyZpKMZM9VcdyCUwEOqWcsBQd4n5+PynZS2ynaQ95cUZakibUyy/Qoi3xUJkmVaKdku8r2WngFJt5aTFvnu61J8i/J3ltfJTUHkxERuupMeSRXXfU8kM0OXnSF/D3JxTNqnSxU31JOg+87JiYV+erwc+OVEQ4JO+Qyk6q58n+R7r39iJJ9VznGHuteU31dOJHTk700+Q5kNQbI+ZBvI352sLyegcjJaULpjYb/T8l2WiyaSmSAnJ9KTL3+PcoFMniu/b3507ZagvjiBt1yokf3H448/rvZzsg+RniE52Za2FOa7ZyyS9i77LklxJSLzkv2s7FOkA0D2rXLs1Sf7C0kxl32YnLvIsV32ndLbXJyq2TJjhFxAl+BWOhPkuCHHXjmW6XpJ5fVlnLfsL2WaMbnYqttnSpVz2cdLu6SDQva7khIux25pp7ym7F/0yfPlGCLHbXlcevVlf6+7+CfHfFkmKdDye0mGkPR2y0Vw6Z2V15dzGzmnk+w3+T9nBkBhSYeE/P6yLy9ubRhpa2GGaRqiOz7rqqTLuZ5c0NZPrZfjmJwLSxaEzH4h9+WmI8dF3bFRhozJubYcB+XYpxvjLedq0lkmx5ycF23kPMFY59pUyuVbeo0KVW1ZbvPmzctaV+6PHTtWM2vWLE3NmjVVpUupaC4VhXM6cuSIqkLp5eWlKgpL9UlDFRulGvK4ceM01apVU68nVX2lIvOJEyfyrYKsa09hqmXnVyU6ZwXNM2fOaPr27aspW7asqsAu1UL3799v8HWlSniTJk3U71epUiXNSy+9pCoT5yTL5DFZR9aV5+Ssxh4QEJDn7yIVQPNqf85tKlU3n3zySVUF1NXVVXPfffflWTV+3bp16nFZT9aX5127di3XelJlVdomn5G0X6q2f/XVV5rCKmxVc525c+dmVdCPi4vL9bhUV5Vq61JFW6pwS8VOqaCf8/tQnKrm+clZ1VzaIVVnW7RooSlfvrzG0dFRtUfW+fnnn4v9d1Zcuoquhm7620VXhbWgzySv7bJjxw5VBVv+RmT2gkaNGqnq4/rVePOS39/z9evX1d+JVIaXfYF8J5s3b66qjScmJhZqGxTmOy2VvR944AFVsVY+M6mmLpVx5TstlXgLo0OHDprevXsX+ncztL2l0rhsR2mrVPqVfY1sW0OfqWwbQ39Xsq809F6yny5M277//nu1rXNWaCci85gxY4b6W23QoEGux1JSUjSvvfaaqkQt+41mzZqp/YicI+ScxaIw+/gff/xR07lzZ7UvlGO7zLYwePBgzeHDh7OtFxUVpaqbyzmM7C906+nvWydPnqypXr26OibUr19fHdN0+y99MvOCzKQg51fymP4xdfr06Wr/LzN95Dy/2bJli9rfyX5d2iDbQO5LNfTC7C/zMmzYMIPb2tB+VMh2zm9GkaLI75ygsFXTc37GBw4cUNXOZYYY+Sxq1KihGTVqVK5ZhsS7776rKunnVfGcqCjs5B9zB/+2RtKI5IqaVMEk45EeQ7nyKlcfdam7tkTGD0nKnH7WAJE10w0dkewZ/ZQ+ayOFd6TApfSSEBGVNtLLLL370uutG6JXGkj2p2RgSsZecWrZEOVkvHK/RCYmKfZyncgWg24iWyR1HORkTdIyrZUUUpIhA5ISSkRUGkmauFRkL237QRnqKDWJpJ4NkTEw8CYiIpNl/8iYcN30X9ZIxndLwUvdbA1ERKWRFAWVC6n3Uh3e2shxSzKdilMAlsgQppoTWQimmhMRERER2SYG3kREREREREQmxFRzIiIiIiIiIhNi4E1ERERERERkQo6wwUIIly9fhqenpyrsQ0REZMlktgYpWCRF6OztS/f1cB7DiYjIVo/hNhd4S9AdEBBg7mYQEREVSVRUFPz9/Uv1VuMxnIiIbPUYbnOBt/R06375smXLmrs5RERE+YqPj1cXjHXHr9KMx3AiIrLVY7jNBd669HIJuhl4ExGRteDwKB7DiYjIdo/hpXswGREREREREZGJMfAmIiIiIiIiMiEG3kREREREREQmZHNjvImIyDTTPKWmpnLTFoOTkxMcHBy47YiIiEoxBt5ERJQvCbgjIiJU8E3F4+3tjUqVKrGAGhERUSnFwJuIiPKk0Whw5coV1WMr02XY23OEUlG3X3JyMqKjo9X9ypUr89tGRERUCjHwJiKiPKWnp6vAsUqVKnB3d+eWKgY3Nzf1vwTfFSpUYNo5ERFRKcSuCyIiylNGRob639nZmVvpHuguWqSlpXE7EhERlUIMvImIqEB2dnbcSveA24+IiKh0Y+BNREREREREpUJyarpZ3tciA+9+/frBx8cHAwcONG9DDi0E5nQEtn5u3nYQEZHZVK9eHdOnT+cnQEREZOX+OngJ7SZvRFjkrRJ/b4sMvF966SX89NNP5m4G4uNuAVcOIv7kVnM3hYiIiqBTp054+eWXjbLNQkND8eyzz3L7ExERWan4O2l4ZdFBjFt4ELeS0/DjzvMl3gaLDLw7d+4MT09PczcDf8dUUf87Xg2TOWHM3RwiIjLiNF9Ssb0wypcvz4ruREREVmr/hZvoPWMbloVdgr0d8PIDtfHFoGDrD7y3bt2KPn36qKlnpJjM8uXLc60za9YsBAUFwdXVFc2bN8e2bdtgiXyCQnBH4wT3jAQg5qy5m0NERIUwYsQIbNmyBTNmzFDHIbktWLBA/b927Vq0aNECLi4u6thz9uxZPPLII6hYsSLKlCmDli1b4t9//8031Vxe57vvvlPDoqRaee3atbFixQp+NkRERBYkPSMT09afwqBvd+HirdsI8HXD4tFt8PIDdeDoUPL9z0Z/x6SkJAQHB+Obb74x+PiiRYtU+t/bb7+NsLAwdOjQAb169UJkZCQsTZ0qPjiqCVI/Z14MNXdziIgsoqdYipKY4ybvXRgScLdp0wbPPPMMrly5om4BAQHqsddffx2TJk3C8ePH0aRJEyQmJqJ3794q2JZjUo8ePdTF44KOSRMnTsTgwYNx+PBh9fzHH38cN2/eNMo2JiIionsTGZOMwXN2YcaG08jUAP1DqmL1Sx3QPNAX5uJo7BeUIFpueZk6dSpGjhyJUaNGqfvSiyA9ELNnz1YnQ0WVkpKibjrx8fEwlsByHtiqqYUWOIWkc3vg2fQxo702EZE1up2WgQbvrTXLe4d/2APuzgUftry8vNS849IbXalSJbXsxIkT6v8PP/wQ3bp1y1q3XLly6mKxzscff4xly5apHuwXXngh3171xx7THhM+/fRTfP3119i7dy969ux5T78jERERFZ9cpJeU8vf+OobElHR4ujri476N8EjTqupxKaoWcSMJQX4eCKnmA6sOvPOTmpqK/fv3480338y2vHv37ti5c2exXlOCdel5MAUnB3tc9WwEJK+GJmqvSd6DiIhKjqSZ58zSkmPIypUrcfnyZTXu+/bt2wX2eEtvuY6Hh4eqSxIdHW2ydhMREVH+4m6n4Z3lR/H3ocvqfqvqvpg6JBj+Pu7q/uR/juPbLeey1h/dsQbe7FUfNhl437hxAxkZGWosnT65f/Xq1az7kup34MABdULk7++veh9k3J0hb731FsaPH5+tx1uXUmgMyZVaAueAMreOA7dvAW4le2WEiMiSuDk5qJ5nc733vZIgWd+ECRNU1tUXX3yBWrVqwc3NTU1lKReK8+Pk5JTtvoz7zszMvOf2ERERUdHtjbipqpZfir0NB3s7vPJAbYzpVEv9rOvp1g+6hdzv0bBSifV8l2jgrX+CkjMlQH+ZnAQVlhTIkZupVPIPwtkzlVHT/gpwYSdQ70GTvRcRkaWTfXVh0r3NTVLN5UJvQaTAmqSNS6E0IWO+z58v+SlGiIiIqOjSMjIx49/TmLX5jBrLHVjOHdOHNM0VTEt6uSGyvKQC7xIt5+bn5wcHB4dsvdtC0vNy9oIX1cyZM9GgQYM8e8aLq3ZFT+zMbKi9E2GZ1deJiAi5KpHv2bNHBdGSbZVXb7T0ci9duhQHDx7EoUOHMHToUPZcExERWYHzN5Iw8Ntd+GaTNuge1Nwfq17qYDCQljHdhuS13OoDb+mBkOnD1q9fn2253G/btu09vfbYsWMRHh6O0FDjVh9vXNUrK/DOjNhi1NcmIiLTeO2119SFXrkgK/Nw5zVme9q0afDx8VHHIKlmLkOdmjVrxo+FiIjIQmk0GvyxLwq9v9qGQ1GxKOvqiJlDm+HzQcEo42I4K0+CcRnTrW9MxxolWmDN6PmCkqZ35syZrPsRERGqJ8HX1xfVqlVT47GHDRumCtzIdC9z585VJ0SjR4+GJars5YrT7k2BdMA+OhxIvA6UKW/uZhERUT7q1KmDXbt2ZVsmKeWGesY3btyY60Kuvpyp54amNYuNjeXnQUREZGJxyWn437IjWHXkirrfOsgX04Y0RRVvtwKfK4XUZEy3zVQ137dvHzp37px1X1f4bPjw4ViwYAGGDBmCmJgYNaWLzK3aqFEjrF69GoGBgbDU8YzVA6rh+NlqqG8fCUivd+OB5m4WERERERFRqbHrbAzG/3EQV+LuwNHeDuO718Fz99fMKqBWGBJsl3TAbbLAu1OnTgZ7A/Q9//zz6mZMMsZbboUpplNUTQO8sPV0Y23gfeZfBt5EREREREQlIDU9E1PXn8KcrWchYab0Vs94tCma+Htb1fYv0THepmSqMd4iOMAbmzJDtHdOrwMyjR/cExERERER0X/OXk/EgNk78e0WbdD9aMsArHqpvdUF3cLy54SxAPLB7tfUQbzGHWWTY4BLB4AA41ZPJyIiIiIiIqgM6oWhUfjw73DcTsuAt7sTJvdvjJ6NKlvt5rGZHm9T8nJzQu1KvtiS2US74NQaczeJiIiIiIjI5txKSsXoX/bjraVHVNDdrlY5rBl3v1UH3TYVeJtqHm+d1jV8sTFDl26+1iTvQUREREREVFrtOHMDPWdsxdpj1+DkYIe3e9fHz0+3RiUvV1g7mwm8TTnGW9xXoxw2ZwYjE3bA1SNA3CWTvA8REREREVFpkpKegU9XH8fj3+3BtfgU1CzvgWXPt8Mz99eAfRGqllsymwm8Ta1VdV/cQlmEZdbSLmCvNxERERER0T05E52A/rN2Yu7Wc+r+462rYeWLHdCoqpdNbVkG3oXk4+GMepU8sUGXbn6S47yJiIiIiIiKW0Dtl90X8NDX23Hscjx8PZwx78kW+KRfY7g5O9jcRmXgXcR087WZd8eQn90I3L5loo+FiIjMqXr16pg+fTo/BCIiIhOISUzBMz/twzvLj+JOWiY61PbDmnEd0K1BRZvd3jYTeJu6uJroWKc8zmqq4oxdIJCZBhxfabL3IiIiIiIisjVbT11Hzxnb8O/xaDg72OPdhxrgx6daoUJZ6y+gVioCb1MXVxNtapaDi6M9lqa21i44ttRk70VERERERGQr7qRlqHm5n/xhL64npKB2hTL464V2GNk+yGYKqJWKwLskuDo5oG3NcliZ2Ua74NwWIOmGuZtFRER65syZg6pVqyIzMzPbdnn44YcxfPhwnD17Fo888ggqVqyIMmXKqEypf//9l9uQiIjIRE5dS0DfmTvww44IdX94m0D8/WJ71K9cttRscwbeRdSlXgVEairijGNtQJMBhP9lmk+GiMgSaTRAapJ5bvLehTBo0CDcuHEDmzZtylp269YtrF27Fo8//jgSExPRu3dvFWyHhYWhR48e6NOnDyIjI0244YiIiEpnAbUfd55Hn6+348TVBPiVccb8ES0x8ZFGqlOzNHE0dwOsTed6FYC/jmHxnVZ4y/E0cHQp0HKkuZtFRFQy0pKBT6uYZ2v/7zLg7FHgar6+vujZsyd+++03dO3aVS1bvHixWi73HRwcEBwcnLX+xx9/jGXLlmHFihV44YUXTPorEBERlRaSTv76n4ew6eR1db9T3fL4fGAwynu6oDSymR7vkiiuJvx93FGnYhn8nX53nPeFHUD8FZO+JxERFY30bC9ZsgQpKSnq/q+//opHH31UBd1JSUl4/fXX1THD29tbpZufOHGCPd5ERERGsulENHrN2KqCbmdHe0x8uKHq6S6tQbdN9XhLcTW5xcfHw8vLy+S93nOuJSLCrRGCbh8FwpcD940x6XsSEVkEJ3dtz7O53ruQJHVcxnivWrVKXZDdtm0bpk6dqh6bMGGCSjv/4osvUKtWLbi5uWHgwIFITU01YeOJiIhKRwG1yf+cwIKd59X9epU8MePRENSt5InSzmYC75LUuW4FzNlyDovutMKbOAocWczAm4hKBzu7QqV7m5sE0/3791c93WfOnEGdOnXQvHlz9ZgE4SNGjEC/fv3UfRnzff689gSBiIiIiuf4lXiMWxiGU9cS1f2n2wXh9Z51S91Y7rww8C6GFoE+8PVwxp9JLfG6+8+wv7QfuHwQqNK0OC9HREQmSjeXnu9jx47hiSeeyFouvdxLly5Vj9nZ2eHdd9/NVQGdiIiICiczU6N6uCevOYHU9Ez4lXHBF4OaoFPdCtyEtjjGuyQ5OtijR8OKuAEvHPXsoF0ovd5ERGQxunTpogqqnTx5EkOHDs1aPm3aNPj4+KBt27Yq+Jaq5s2aNTNrW4mIiKxRdPwdjFgQig9Xhqug+4H6FbD25Q4Mug1gj3cx9WpUGb/vjcKPCS3wJTZqq5t3+wiw57UMIiJLIIXULl/OPR69evXq2LhxY7ZlUiNEH1PPiYiI8vdv+DW8vuQwbialwsXRHu881ABPtK6msskoNwbexdSmZjl4uzvh7+SGmOLpCceEy0DkTqB6++K+JBERERERkUW7nZqBT1aH45fdkep+/cpl8fVjTVGrAguo5cdmumdLajoxHScHe3RvUBGpcMKhsh21Cw/8VCLvTUREREREVNKOXY5Dn2+2ZwXdz3QIwvKxbRl0l6bAW9IEw8PDERoaWmLv2atxZfX/V7F3e7nDVwAp2ip+REREREREtlJAbd7Wc+g7cwfORCeigqcLfhnZGm8/2AAujqxaXhhMNb8H7Wr6wdPVEVuSAnCnQnW4xp8HTqwCgofcy8sSERERERFZhGvxd/DqH4ew/cwNdV+yficPaKJmeaJS2ONtDs6O9ujWoKJMbIvd7l20C/cvMHeziIiIiIiI7tnaY1fRY/pWFXS7OTlgUv/GmDOsOYPuYmDgfY8eaqJNN59yvTU0sNMWWIu7dK8vS0RkUTQajbmbYNU4TzgREVmT5NR0vLX0CJ77eT9ik9PQuKoXVr7UHo+1YtXy4mKq+T3qULs8ynk443iSJ+L9m8LrRhhw6Hfg/tfu9aWJiMzOyclJTQty/fp1lC9fnlOEFOOCRWpqqtp+9vb2cHZmWh4REVm2IxfjMG5hGM7dSILMDPbc/TUxvlsdle1LxcfA2wjVzfsEV8GCneexwrEXhiEMCP0eaP8KYM9CA0Rk/XNh+/v74+LFi5zb+h64u7ujWrVqKvi2VZMmTcLSpUtx4sQJuLm5oW3btpgyZQrq1q1r7qYREVEhZGRqMHfrOXy57iTSMzWoVNYVU4cEo21NP24/I2DgbQT9QqqqwPuzS/XxhIcX7GRO7ws7gKD7jfHyRERmVaZMGdSuXRtpaWn8JIp58cLR0dHmswW2bNmiZhiRaT3T09Px9ttvo3v37mrGEQ8PD3M3j4iI8nEl7jZeWXQQu8/dVPd7NaqkxnN7uzNTy1gYeBtBE38v1PDzUOkYERUeQI3IJcChRQy8icimgke5EeVlzZo12e7Pnz8fFSpUwP79+3H//bwQTURkKcIibyHiRhKC/DwQUs0Hq49cUeO5426nwd3ZAR883BCDmvvb/AXjkmYzgffMmTPVLSMjo8TfW76U0uv95fpT+PV2W7yLJUD4cqD3Z4Azr/ITEVHpExcXp/739fU1d1OIiOiuyf8cx7dbzmVtj7qVyuDk1UT1c7C/F6Y/GqICcjI+mxlsJultks4WGhpqlvfvG1JV/f/DxUpI96oOpCYCx/82S1uIiIjMXVRu/PjxaN++PRo1apTneikpKYiPj892IyIi0/V06wfdQoJu6dd+oXMt/DmmLYNuE7KZwNvcAnzd0bK6DzQaOxzw7a1dGPaLuZtFRERU4l544QUcPnwYv//+e4EF2by8vLJuAQEBJdZGIqLSRtLLDXm+c0281qOuKhpNpsOta4Je769jmksCOnB+G3DrgjHfgoiIyKK9+OKLWLFiBTZt2qQq4ufnrbfeUinpultUVFSJtZOIqLQp42J4lPED9SuWeFtKIwbeRvRQ4ypwdrDHtmg3JFZtr114aKEx34KIiMhi08ulp1umFNu4cSOCgoIKfI6LiwvKli2b7UZERMZLLV964KL6/+9Dl/Hq4kO51hnTsYYqsEamZzPF1SyBl7sTutSrgDXHruJfl67oi23AwV+B+ycANjx3KxERkdRa+e233/DXX3/B09MTV69eVRtFUshlXm8iIjJfETWdkGreeKZDDdxJy8iqak4lg4G3kfVvVlUF3p9fqI1HXDxhF3sBOL8VqNHJ2G9FRERkMWbPnq3+79SpU65pxUaMGGGmVhERlT6GiqiJwS388Wm/xnDkWG6zYOBtZJ3rVYBfGWdcSkxFVKNHUO3ML8COGQy8iYjI5lPNiYjI/M5Ea6cHy+m+GuUYdJsR85+NTKoBypzeYnZKL8DOATi7Ebh+ythvRURERERElCXqZjK+3x5hcItwfm7zYuBtAoNaaKdDWXzWHqlBXbULD7PIGhERERERGa9omr7lYZfQe8Y2nLiakOs5LKJmfkw1N4E6FT0R7O+FQxfjsM39AXTFOuDQIqDzOyyyRkRERERERimaNrpjDTzfuRbeXX4Ufx28nOfzujesxC1uZuzxNpGBd3u9p0XWhMbVC4i/qJ3Xm4iIiIiIyAhF0+R+1y+3qKDbwd4OPfMIsCNuJHF7m5nNBN4zZ85EgwYN0LJlS1iCh5tUgbOjPY5GpyCm+kPahQd+MneziIiIiIjICuUVPF9PSEE1X3csHt0Gz3WsYXAdju82P3tbmj80PDwcoaGhsJQ5vXs10l5x+i29i3bhsWVAbKR5G0ZERERERFYnr+C5c93yWPVSezSr5qPm5Zb0c30c320ZbCbwtkRDW1VT/397qgzSA+8HNBnA3rnmbhYREREREVmZpgHeKsjW161+Bcx/qhU8XZ2ylr3Zqz6WPd8WUwcHq//f6FXfDK2lnBh4m1CrIF/UqlAGyakZ2OY7QLvwyJ8y2akp35aIiIiIiGxIXHIaXvw9DJtOXlf3a5T3wNxhzTFvuOFhttLz3b+Zv/qfLAMDbxOys7PDY3d7vadFBEDj5AEkXAGi9prybYmIiIiIyEamCdt9Lga9ZmzFysNX4Ghvhwk96mL9Kx1ZqdzKcDoxExvQrCqmrDmBw1fv4GbjXih3+k9g7xygWmtTvzUREREREVnpNGGvdq+L6f+ewqzNZ1XCbPVy7pjxaAiCA7zN2lYqHvZ4m5i3uzMealxZ/fxTRi/twmPLgbhLpn5rIiIiIiKy0mnCes3YhpmbtEH34Bb+WPVSBwbdVoyBdwkY2lqbbj7ntAfSA9pqi6yFziuJtyYiIiIiIiucJuxMdCK83Jww6/Fm+GxgMDxcmKxszRh4l4DmgT6oXaEM7qRlYnu5u0XWDv4OZGaUxNsTEREREZGVTRPWqGpZrHm5A3rfzZ4l68bAu4SKrOl6vb+ICILG1QtIvApc2FkSb09ERERERFbmgz4NUdnLzdzNICNh4F1C+of4w8XRHkev3UFMQE/twkMLS+rtiYiIiIjIwsZ2/xEaiY9XhRt8PPJmcom3iUyHgXcJ8XJ3wkNNqqiff0+7X7vw6BLgdmxJNYGIiIiIiCykinm/WTvx+pIj2H8htkgp6GSdGHiXIF26+TdnfJFRvgGQfpu93kREREREpciBCzdzVTHPaUzHGgip5lNibSLTY2m8EtSsmjfqVfLEiasJ2FOuL9peDwf2/QC0fk4GgpdkU4iIiIiIqITdTErFeyuOGXxsXNdaCCznoXq6GXTbHvZ4m6nI2pRLTaBx8gBunAQu7CjJZhARERERUQnbdvo6ek7fiqOX4g0+3qluBfRv5s+g20ZZZOC9cuVK1K1bF7Vr18Z3330HW9I3pCrcnBxw6Homrgc9rF0ovd5ERERERGRzUtIz8PHKcAz7fi+iE1JQq0IZDGxeNds6TC23fRaXap6eno7x48dj06ZNKFu2LJo1a4b+/fvD19cXtqCsqxP6BFfGH/su4qe0LngNvwPhK4DEaKBMBXM3j4iIiIiIjOT0tQS8tPAgjl/R9nIPuy8Q/+tdH27ODni8dSAibiQxtbyUsLge771796Jhw4aoWrUqPD090bt3b6xduxa2ZGjrQPX/3NOeSK/cHMhMA8J+NneziIiIiIjICDQaDT5dHY5eX21TQbeHiwP+17sePurbSAXdQsZxM7W89DB64L1161b06dMHVapUUWOaly9fnmudWbNmISgoCK6urmjevDm2bduW9djly5dV0K3j7++PS5cuwZYE+3uhQeWySE3PxHafR7QLd80C0u6Yu2lERERERHQPbiSmoNPnmzF3awTSMzRqWVJKBj5dfUJNI0alk9ED76SkJAQHB+Obb74x+PiiRYvw8ssv4+2330ZYWBg6dOiAXr16ITIyMuvqUE4SwNtqkbVPIhtCU7YqkHwDOG1bPftERERERKXJ5pPReODLLbhwM9ng4zKNWFjkrRJvF9lg4C1B9Mcff6zGZRsydepUjBw5EqNGjUL9+vUxffp0BAQEYPbs2epx6e3W7+G+ePEiKleunOf7paSkID4+PtvNGjzStArcnR1w+kYKrgQ8qF14aKG5m0VERERERHdJkLz0wMUCg+U7aRmY+PcxjJgfitjbaQUG51T6lOgY79TUVOzfvx/du3fPtlzu79y5U/3cqlUrHD16VAXfCQkJWL16NXr06JHna06aNAleXl5ZNwnirYGnq5MKvsWCpDbahSdXA1ePmLdhRERERESk0sL7zdqJ8X8cUv/nlSZ+8moCuk/bivk7zqv7DzbOu9OQSq8SDbxv3LiBjIwMVKxYMdtyuX/16lX1s6OjI7788kt07twZISEhmDBhAsqVK5fna7711luIi4vLukVFRcFaDG2lLbK24LQbUurenVos9HvzNoqIiIiIqJSTHm5JC88vTVyGyC7YEYHeM7YhUi+1PMDXDaM71sjztWW+bip9zFLVPOeYbfnS6i97+OGHcerUKZw5cwbPPvts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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.362e-03 @ epoch 671\n",
      "\n",
      "iter=0  t=0.00s  best_y=546.694  x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\n",
      "STOP: local minimum. best_y=546.694 x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\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: 0x3f2acfcd\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [4e-07, 1e+00]\n",
      "  Objective range  [4e+02, 4e+02]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [2e+00, 4e+00]\n",
      "Found heuristic solution: objective 546.6938370\n",
      "Presolve time: 0.01s\n",
      "Presolved: 1601 rows, 11 columns, 17610 nonzeros\n",
      "Variable types: 1 continuous, 10 integer (10 binary)\n",
      "\n",
      "Root relaxation: objective 3.810471e+01, 15 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               0      38.1047116   38.10471  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (15 simplex iterations) in 0.02 seconds (0.03 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 38.1047 546.694 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 3.810471160686e+01, best bound 3.810471160686e+01, gap 0.0000%\n",
      "[CHECK MaxAffine] obj(x_ip)=38.1047  ip_y=38.1047  rel_err=9.530e-07\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.503  std(mean)=0.5  min=0  max=1\n",
      "  y: shape=(1000,)  mean=760  std=384  min=6  max=1.92e+03\n",
      "\n",
      "\n",
      "=== Run: assignment | LSET ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,600 n_pieces=1600 T=0.05\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAtShJREFUeJzs3Qd4FNXXBvA3PRBSgJBQkkDohN6r0qQqShGxIShYUUEUxS5YsCIWQNRP1L+KWAAVUaRJEaX30DskEEIJECB1v+fczSSzm9nNpmw22by/51nIzk52Z2c3M3PuPfdcD5PJZAIRERERERERFTnPon9KIiIiIiIiImLQTURERERERORE7OkmIiIiIiIichIG3UREREREREROwqCbiIiIiIiIyEkYdBMRERERERE5CYNuIiIiIiIiIidh0E1ERERERETkJAy6iYiIiIiIiJyEQXc+fPnll/Dw8LB5+/vvv+FKR44cUdvx7rvvFvg5XnjhBdx0002oUaOGeq6RI0faXPfQoUMYPHgwQkJCUKFCBfTq1QubN282XPf7779HixYt4O/vj+rVq2PcuHG4fPlyrvVkmTwm68i68jvyu7b8+uuv8Pb2xpkzZ9T9adOmqW2Kjo5W29+tWzebv5uQkKDeX2hoKMqXL4+OHTti2bJlhusuXbpUPS7ryfrye/L71tLS0jBp0iTUqlULfn5+aNiwIT766CM4Sn7vlVdegau+2/IdcmQ9W993k8mEunXrGu77s2fP4tlnn0VMTAwCAgIQHBys9s/w4cOxffv2Yv07+/rrr3H77bejQYMG8PT0VPvdUcnJydm/GxgYqN5L48aN8dprr6nH9Oy9l1OnTlmsu3DhQtxzzz1o2rQpfHx81DrO5Oh32vp3tO1PTEx0+LUmT56sPvfMzEyURi+++CJatWpVarefqLQbNGgQypUrhwsXLthc56677lLHztOnTzv8vHIsc8U5Ny9vvPEGFixYkGt5bGys2t68ztXOIOfNKlWq4NKlS8X2midOnFDXhF27dlXXmvJ5yXnV2sWLF/H666+r646qVauqa1I5l7711lu4du1arvUPHDigrj2ioqLU96pOnToYP368uk7Rk3UGDhzo1PdIZQeD7gKYPXs2/v3331w3uSgr7d5//3110Ln55pvh6+trcz0Jcq+77jrs27cPX3zxBX744Qd1YJMD3t69ey3W/fbbb3HHHXegbdu2+OOPP/Dyyy+rg6YEx9Zk2VdffaXWkXXld+R3v/vuO8Pt+Pnnn3H99derE4H45JNPcPToUfTo0SN7mZGUlBT07NlTBdkffPABfvnlF4SHh6Nv375YuXKlxbpyv1+/fupxWU/Wl+BDfl+eR++RRx7BlClTMGbMGCxevFhdKIwdO1adQN2JBJv/93//l2u57KuDBw+qx60bUzp06KA+99GjR6vGEvlePPDAAzh8+DC2bt1arH9n//vf/7Br1y60a9dOnWzzQxpWpHFBTtDy/ZPvxJAhQ1Rgecsttxj+jtF7qVy5ssU68+fPx3///aeC0+bNm8OZ8vOd1n+G999/v2oQy4+4uDi8/fbbav9IA0dp9NRTT6nvqRybiKj4jRo1Sl1j2LoWSEpKUsdQ6TSQ41ppZy/olob94g66r1y5gueeew7PPPNMrvO7M0lwLNcKcj3av39/m+sdO3ZMdbrI9cGnn36qrjFuvfVW1UAh3wk5Z+uvX+V65J9//sGrr76KRYsWqWu2zz77DDfccINF46r8/u+//47ly5c7/b1SGWAih82ePVv+ak0bNmwokXvt8OHDavveeeedAj9HRkZG9s8BAQGmESNGGK43YcIEk4+Pj+nIkSPZy5KSkkyhoaGm2267LXtZenq6qVq1aqbevXtb/P63336rtnXRokXZy37//Xe17LvvvrNYt1evXqbq1aur59JLTU01hYSEmD7++GPD7W/cuLGpa9euhts/ffp09Vpr167NXpaWlmaKiYkxtWvXzmLdtm3bquXyuOaff/5Rvz9jxozsZTt37jR5eHiY3njjDYvfv//++03lypUznT171pSXmjVrml5++WWTq77b8h1yZL3Ro0er9ySfud7dd99t6tixY659/8UXX6jfW758ueHz6j+34vg707/ejTfeqPZ7YT399NNquw8ePFig96LfpjFjxqjfcxZHv9N6sk0tW7Y0vfDCC2q9M2fOOLxfatSoYfH+iktycnKRPdejjz5qql+/vikzM7PInpOIHCPnf7kOaN26teHjM2fOVMel3377LV+7VH7HFefcvNi6/vrxxx/VNq9YsaJYj5VyXvD39zedP3/eVJz05w05j8p7l/OqtcuXL6ubNbkelt9ZvXp19rLPPvtMLVu6dKnFunLtJss3b95ssfymm25S16FEhVU6ux1KAUmBefTRRzFr1izUr19fpRpLD5ZRqvTOnTtVD1nFihWzU6qNelQkrerJJ59E7dq11fOFhYWplr89e/bkWnfq1KkqxVpSbCSFVHrQHOFoT5S0KEtvcs2aNbOXBQUFqZ7q3377Denp6WqZvG58fDzuvfdei98fOnSo2jZ5Hv1zyjJ5TE9+V3rL1q1bZ7FceqmldVt6kwuy/ZIeLPtGI2nqd999N9avX4+TJ0+qZfL/hg0bVIqRPK7p1KmT+lz12y+t0nIOt36vcv/q1av4888/URSkNVe+X9ICbE1aoaVFWEv9XbJkifpuRUREqO+WpH4/+OCD+UoNNiLZB2LOnDnZy+SzkJ7f++67L9f6WspWtWrVDJ+vuHtAnfF6WmaF/nvirG2S1HT5HOVzlc9b/tal90P7u7MnP99pzerVq1Xvweeffw4vLy+HtzM1NVVlRNx5550W708/FMaRY5X0Wmip8NLLIkNZJFtAT3ok5DlliIv0cMjxVMtikOED0tshKfwtW7ZU6YSNGjVS94VkYMh9GSog2Q8bN27MtQ2yvySzZ8WKFQ6/fyIqGnLcGTFiBDZt2oQdO3YYZhPJ+UUyeKQnU7LO5JpLjityrSTXK3IcK6iZM2eqDCR5PjkGydAo6fm1PrZK9lZkZKQ6LktWkByLtHR36amXazi5xpPhVZUqVVLHNck20pPjmAxVkutAbTiPZBHKcUq7PurevXv2Y/p0ay1jSa7H5HjZuXPnXMPm7B0r7b3/AQMGqBRvo2tdyR6TY6i8puwn7dhaWI6eF+XYLTdrcjwXx48fz14mQxCEfAZ62nuTayXrY7/sV8niIyoMBt0FkJGRoS5u9TdZZnSh+OGHH6q0yp9++kkFqBKsyM8aScWWi11JdZV1582bp04UMr5SUjI1MoamS5cuKoiXIE4CW0mllotkCWr1pk+froItCc4kLUcO3hKcS1BUFCSAlINPs2bNcj0my+RxGe+tNShoy/XkoCcnLe1xbV05aFsHLdrv6tcVEuDJCSu/6a7ac9nafiGfh73t15ZZb78EXjKeyJHtLyhpGJATuvW4JvkOfvPNN+rEKGN0hXxOso/khPnXX3/hpZdeUo0X8l2SNOmCkhO6nKxlaIFGAnA5QQ4bNizX+lrjhoxZlsYJ63FTBf07M1rH6OaMsbjSwCLPLWPJpEHlvffeU3/fMkbMmgR8ctEoF1nSMFWY74IE3HIhIcMX5POUYRiSeinDGiT9Oy/5+U4L+XuW55dxdflN7ZfvmnzWcoFoxJFjlaSTSsORfOfkOyZB/Pnz59VF6Jo1a3I9p+xfaVz68ccf1TFSs23bNlVTQBqm5DgrF1yyrgxlkcYESeeUbZDXls9L3rde69at1QW3pBoSUfGTBl0J8vTnHS3lWhrLJSiX4+y5c+fUcvnblr9XCcils0KOGQWpCSKdJRLEy7hiaZSUc9gTTzxhUcNDAm4ZDiePy9AjOS7LcU2OM3K8EjJ0R7ZNhqvIc8jxTM7FchyS8dIaaVCUhkE5FmrDkWbMmIEbb7wxe6iaHDu1x2S5kPN/79691bFSAnYZ9ifnnD59+hjWq7F1rDQaVy0NHbaO47KPP/74Y3WtK9dl8prSGaJdB+rPl47cipKWFi51VzQyRlvO09IAItd6MnRq1apVePPNN9X1k1yH6sn3RrZf0tCJCqXQfeVliJYqanTz8vKyWFeWSfrtqVOnLNKjGjZsaKpbt272sttvv93k5+dnOnbsmMXv9+vXz1S+fHnThQsX1P3Jkyer51yyZEme6eVNmza1SMVev369Wj5nzpwiSW86efKker4pU6bkekxSw/Vp26+//rq6Hx8fn2tdSTmXdE1NvXr1TH369Mm1XlxcnHoOfdq2vD9JZX/vvfdsbr+99HJJjX/wwQdzLZft1qe4a2nw//77b651H3jgAZOvr2/2fUk/atCggeHryXqyflGllw8ePNgUERFhkXolqfr20uskLVbSiY8eParW++WXXwqcXi5pXpLeJj9LWr2Wsjxy5Eib+16+w7IftL+Z6Oho00MPPWTatm1bgf/O5DVsrau/2RomUZj0cvl70r/Gvffea5GuLf744w/T888/rz6TlStXqqEQ8rnJ39bWrVttPre99HL53laoUEF9jnrvvvuu+p1du3bZ3e78fKfFk08+aapdu7bpypUr6r58Px1NL3/rrbfUuvrjYH6OVfL9lpRSWU//Xb906ZIpLCzM1KlTp+xl2na99NJLubZDPl85Hp84cSJ7mex/WV+Gv+hTKxcsWKCW//rrr7mep3Pnzqb27dvn+b6JyDnkmC/nfhlepj9Gyd/svn37DH9HjjFybO7Zs6dp0KBB+U4vl6ElMpTNnvvuu09dV8TGxjr8XrTtGjVqlBq6U5j0cjmGVapUyTRgwACL5XLcbN68ucWwOXvHSiNz585V6//333+5HpPl4eHhposXL2Yvk+O9p6enxTWidr3gyM3WdYi99HIjcm0hx33rz1y7rpShcPrXHTp0qOnatWuGzyVDpIYNG+bQ6xLZUrA8yDJOWiStW8KMKg1Lio++oIe0wEovoKSBSsuhpIZKK5ysJ+lIetLTLS2l0oopxb3kZ+nVliIPeZFWT30KqNajJQXGipK96srWj9la19H1rB+TQlCSIm1UjK00bH9hSbaD9NZJypO0bAtpzZdedkmv00g1aukNlZZoSdHX9/ju3r1bFcwrKGn1l5Q06XWQ76ukLEtvr70K0JJ6J63F0gO6du1a1bouvYzyN6WlrOfn70wyPxyppKr1/Bcl6T2Q9yyvL3+nUiVVenWlp0NLiZO/XblppOif/H1KVVX5XKzTCh0haXvS4yAZHvpeAfncpQdF/jYkW0ayAPTFY2Sb9Kl6jnynpfdIemukJ196XvJLvnPyfLb2f17HKskEkueQXnb9tkuPsxSvk89fCvxISqNGlhuRlE6ZlUGjfbekF0P/+9pyo+OlpKnKZ05EriFZN5IxJZmE8rcux0Dp4ZXCrvXq1cteT84tMiRGesH1xSElwy6/JLNIenLlHCUzV0jKtvUxTa7R5Lhsfc6yJr3KckyVzBt9T7l1SnN+yflUetGlt9+6t1jOQZI5Ka+nT8G2day0Jsdg7fhnRN63vriaXPfKuvpjqGQKOXrsLEj2ojUZwiQZS3JtLdcYepJ5INlTcu6Q7CZZRzK8pKiaXBPJ9ZJ1xqW8H23YIVFBMeguADmotmnTJs/1rNOM9cvk4lyCbvnfaJyrdtDR0nBljJJR2qoR66rIMv5bWKdLFpSM/5ELaaMUYS2tS9KL9Nsi61pXFJV1tfW0dR15TiEp+nIQz89UT3qOvpZ++43Wtd5+oyrccqKTsa36dQtLAiz53kigLUG3nETkIkQqpWtBjATY8picMCXglUBPTriyXCp3Fvb7IN8BCf5lWISMVZNGIbnwsUe+A/I72rh3SemS9yLbbR10O/J3Jqlx+sCyOMdwy9+Btn1y0SENEHJBJoG0vs6ANfnOSkqho3UWrMn4QBleoo1Ls6aN15fGPH0lfrkYkyEJ+flOSzqnNGzJ+9Sm6tGmX5G0ejm22KtkK98x2U5b48DzOlbZqwUgx0j5Lst3Xx8026obYP33p83OYGu50TQzcmFcVMdRIso/Gdb02GOPqXOfBI3SiCvHRGn01EidCEkdfuihh1QgJQGyHIPkPCiNzfklY3olkJXq1vKactyRVHKZJlLqS2jXaHJNZ480lN92221qXPaECRPU9aAEdzL8yzplPr+0ceOyf2yR47s+6LZ1rLSmHfNsNQxYH8e1Y7n+WCkNpdLw6YiC1kXRSLAv52R5Hkmrtz7Gy3dFrtVkPW0fyLWLNMjI2H8JxOV8qcdjPxUFBt1OZD0Pr36ZdpCS/63HZOtbFrXWVBkrLL3jJYH0eEmwY1TMRJbJ4zJ+Skigpy2X3jeNnMCkAJw+0JJ1ZYyTPKY/6Gqv06RJE/W/nPCkN/Hxxx8v8HuQ17K1/frX0v6X5dbTVcgy7XHtOWXsl3zG+gYX6+csCnIBIRcCEvBKMCTjXqU1X1/ETVpupTVdAi39CcSoAFtBSQ+39NhKr4LMkZlf0vMrDQMyvk165W21pNtiHVjaogWczqQVbJFiW3mRhoKCNgTIMUF6hG3tb63BzjoLQDuW5Oc7LePd5Ca9M9akkUEK5hg1NOlfUxqcrHtYHKUdJ20dI2UfSuOHnjPnN5eLVmdkTRCRY+T6Qq4bJACW44IEq9Lwpy/AKj3fksEiwaxeYeaX1hqL5VgmjcUyXlx6UuV4L/V6HLlGk+2SopFz5861OE7ZmqYxP7Tj0kcffaQa1Y1Yd3w4eqzUnluOf44G6tbkPG1rTLg1mZ6xoB0qEkhrY7Bl/L5RQ4icsyTryfq9SEOKMKq5Iu+9oNtEpGHQ7UTSwiatj9qBTtI95WArF6vagUCCBgkg5QJSn1IjqbXSe6MdPKU3UIIbSUeXljhXk548SZGSipBaaryc0KQlV9JztKC5ffv26sAmAY++wJb0VEvxCn16uDynnEilEId+XSkIIvtGnktLo5LA1tHUKFvbL4VRJM1Ze14tTU3ua5+FHJglmJLlkrqr9dhJL6Wkvkraq0bSlV544QW1vVKsSSPvXS4U9GnGRUEuACRlTBoq5DWkWJk+dU47oWq9hxoJxoqK7B9psZcGFOuWYT35O5CLEutAU/4m9u/fr77r1lVRHeHK9HJrWlVraZDK64JC5gd1ZKiIEbnQk94dOY5YB5x6Up3fSH6+00aVuuW7Jt9xaSjRp2sb0b6Ptgov5kXeg7yGNCrJtmrfabnw1Qop6nu5nU0KAxVl4xkRFSzFXBp633nnHXUslMZf/XFAjhPW573t27erYUDWQ/nySxoP5XpMGhOlIJc0SkrQLcukgrccQ20de2W7JJNGH+zKtYzRMCPrnmL9cmH9mKS8yzlU0umlmnhR0h/H9QXJ8qM40stlrm4JuOW6QgJu/ew61s8v1+eSLq4/h2kzYlgH6nJtKNe69uYJJ3IEg+4CkFYwowqLchGsTRukXehLgCwpTXKgluqTEpzopw2T1lJtjKYE1ZIGI6ktMqZEAiptSgO5EJaAXQK7iRMnqotmOehK66FchDvagpgXeT5JkxJy4JJWQ63auozh1d6fXADLCUbGZErFSjkRSOVHScmU6Sg0ckEv70N6ZWWKI2mhliDr6aefVmlZ+kBUTlqy7OGHH1apqxK8SEAp40klQNCCA9keufCVdGZrMtWPjOUR8hzS2qltv7RiagdhSZuV6p/SOi7bLT2s8vnICVPGSVunIsl2yboSqEuPrHwGsg36nmU5GcnFgHymsq3yelIxXMaVSRpaUaaXaydCCTqkarWcEOR1rB+X76Rsq+wHeX1JS5Zq0UVJ9l9e5LsiAbJMHSX7Rb7X0isgY63kokW++1pab37+zmxd3ORFLkzkpl30yNgu7XsiGRlaVob8PUjDmGyf3IS8D5l6Rnro5QJOAkC5Lz0MMhOB/I1qJLCW3nwJOKWirPQky9+DXHRJ2qOe/K1pFyXa1CTaNkkLu5bKLn9v8hnKa0m2h+wD+buT771cgMrFaF5pjo5+p+UCxppW/ddoXKM17fcloC9I0C2NNLK/7rrrLnWck2OI9ArJxbZkeDjy3Ssqkuouxy5JbSUi15FjoRxPpOFfzm1y3tWTY4UcX+VcLNctcl6X46b0MhekOrbMCiEN53LMk04EOWfIeVfOY1rvqDy/jOuW471MJSaZb3KMkusXqWYu52PZLumYkGOupIHLeVu2U55Tji168vtyrJVztjwuvflyrNca/eR8L8sk7Vnel2QFyTlIGr+lV1aeX65r5HpOMt7kf+uef0dJR4S8fzmOF7QOjGyrI8MyjWjnQa0aulznSbq6Pp1ezmFyHSzZDzLDhdyXm0bOidp5ccyYMeo6W86Bct7TxnTLdZp0ksn5xrrBRq4Riuo6m8owmyXWKBd7VZXl9tlnn2WvK/elAvGMGTNMderUUVUtpXK5VA62tmPHDlVxMjg4WFUOlkqTRtUZz58/bxo7dqwpKipKPZ9U75XKy3v27LGoCPzOO+/k+l1HKnTmVQ3aulrmgQMHTAMHDjQFBQWpSutSGXTTpk2GzyvVwJs1a6beX9WqVU2PP/64qkBsTZbJY7KOrCu/Y111PTIy0uZ7kWqftrbfep9Khc177rlHVfz09/c3dejQwWZ1+L/++ks9LuvJ+vJ7p0+fzrWeVFSVbZPPSLZfqrN/+OGHJkc5Wr1c8+mnn2ZXyk9KSsr1uFRSlarqgYGBpooVK6rqnFIp3/r7UJDq5fZYVy+X7ZAKs23atDFVqVLF5O3trbZH1vnf//5X4L+zgtKqtxrd9PtFq7iqX/bPP/+YbrrpJlVVWz5j+e7L3+yrr75qUQVbjBs3zhQTE6P2v7xn+Z27777btHfv3lzbZO99W1exlcrh8nciFeDlWCDfydatW6tK6ZcvX3ZoHzj6nba17xypXi6uu+46U//+/S2W5fdYJRXFpWq4bKtU9ZVjjXwOjm6X/F3JsdLoteQ47ci2/d///Z/a19aV2Imo+H3wwQfq71SOr9ZSUlJMTz31lKo4LceMVq1aqWOIHEetZ6pw5Nroq6++MnXv3l1V6ZZjvhzHb7vtNtP27dst1jt+/LiqYi7XL3Ks0NbTH1fffPNNU61atdSsNY0aNVLnM+3YpSezK8hsCXJ+kcf059Np06apY7/M5mF9bSOzZMixTo7psg2yD+S+VD0v6DFcDB8+3HBfGx1Dhexne7OG5Ie96wFHq6Nbf8abN29WVc1lNhH5LGSGjtGjR+eaSUi8+OKLqmK+rcrmRI7ykH9cHfi7I+nJktY0qXhJRUeqKUurq7Q8auPF3Yn0aEqqnD5bgKg004aLSE9+XunoJZkU2pFiltJDQkRUlkjvsvTqS2+3NiSvLJCMT8m6lCy9gtStIdIr+pK+RE4kafXSTuSOATeRO5K6DXKxJumYpZUUTpLUf+shAUREZYGkhkvl9bJ2DJShjVJ/SGrXEBUWg24iInJq1o8USNSm+CqNZDy3FLfUZmUgIipr3nvvPdWAWpgq8KWNnLMku6kghV6JrDG9nKgEYXo5EREREZF7YdBNRERERERE5CRMLyciIiIiIiJyEgbdRERERERERE7iDTcsehAXF4fAwEBVwIeIiKgkkxkZpDiRFJvz9CzbbeE8hxMRkTuew90u6JaAOzIy0tWbQURElC/Hjx9HREREmd5rPIcTEZE7nsPdLuiWHm7tjQcFBbl6c4iIiOy6ePGiaizWzl9lGc/hRETkjudwtwu6tZRyCbgZdBMRUWnBIVE8hxMRkXuew91m8Nj06dMRExODtm3bunpTiIiIiIiIiNwr6B4zZgxiY2OxYcMGV28KERERERERkXsF3UREREREREQljduN6SYiIudM5ZSamspdWwA+Pj7w8vLiviMiIiqjGHQTEZFdEmwfPnxYBd5UMCEhIahatSqLpREREZVBDLqJiMgmk8mE+Ph41VMrU2J4enJUUn7335UrV5CQkKDuV6tWjd82IiKiMoZBNxER2ZSenq6CxurVq6N8+fLcUwVQrlw59b8E3mFhYUw1JyIiKmPYZUFERDZlZGSo/319fbmXCkFrsEhLS+N+JCIiKmNKZNA9aNAgVKxYEbfeequrN4WIiACORS4kDw8Pfo+IiIhcZMux85i3+YT63xVKZHr5448/jvvuuw9fffWVqzeFiIiIiIiISqk3/9iNT1Yeyr4/qkstvHhT42LdhhLZ0929e3cEBga6ejOAo2uB2f2Bn0e7ekuIiMiFatWqhWnTpvEzICIiKkW2HDtvEXCL/1tzBHPWHyvdQfeqVaswYMAAVXRH0ukWLFiQa50ZM2YgOjoa/v7+aN26NVavXo2S6FDiFeDoP7i8Z7mUoHX15hARUT5069YN48aNK5J9tmHDBjzwwAPc/0RERKXI4cRkw+U/bDxeuoPu5ORkNG/eHB9//LHh43PnzlUXQc8//zy2bNmC6667Dv369cOxY8Xb2uCI0wENkG7yRIW0s8DFOFdvDhERFfF0XlKd3RFVqlRh9XYiIqJSJjo0wHD58/0ble6gWwLo1157DYMHDzZ8fOrUqRg1ahRGjx6NRo0aqXQ9mft15syZKGkaRYVjrylS/XzlyHpXbw4RETlo5MiRWLlyJT744AOVdSW3L7/8Uv2/ePFitGnTBn5+firT6uDBg7jlllsQHh6OChUqoG3btli6dKnd9HJ5ns8//1wV/pTK5PXq1cOvv/7Kz4eIiKiESM/IxMp9Z2BdyvThrrXRplYl9y2klpqaik2bNmHixIkWy3v37o21a9cW6DlTUlLUTXPx4kUUlZDyvljpUx+NM47i/L5/Ub75oCJ7biKi0to7fDXNPI1YcSvn4+VwFXAJtvft24cmTZpg8uTJatmuXbvU/08//TTeffdd1K5dGyEhIThx4gT69++vGoxl2JMU8ZRhUnv37kVUVJTN15g0aRLefvttvPPOO/joo49w11134ejRo6hUqXhP5ERERGTp+LkrGDd3KzYdNVcr71q/CnrHhCOmehBaRlVEcSvWoDsxMVHN+Sq9CXpy/9SpU9n3+/Tpg82bN6tU9YiICMyfP1/1PBiZMmWKuvBxlgsVmwKJS+ARt8Vpr0FEVFpIwB3z0mKXvHbs5D4o7+vYaSs4OFjNLS690FWrVlXL9uzZo/6XILxXr17Z61auXFkNi9JI8C3nHem5fvTRR+32pt9xxx3q5zfeeEMF3uvXr0ffvn0L/B6JiIiocOZvOYEXF+zC5ZR0BPp547VBTXBLixpwJZdMGWbdUyE9J/plkvrnqGeffRbjx4+36OmWdPWi4hXZBkgEKiXtBDIzAc8SWfCdiIgcJKnletLAK423CxcuRFxcnBrnffXq1TxrjTRr1iz754CAADXrRkJCAj8HIiIiF0i6moaXftmJX7aaa3G1qVkR7w9rgchK5V3+eRRr0B0aGgovLy+LXm0hFynWvd+OkjF5cps+fbq6SU96UapapwWubPZD+cwrwNn9QJUGRfr8RESliaR4S4+zq167KEiArDdhwgTV2Csp53Xr1kW5cuVw6623qiFR9vj4+Fjcl8bjTGmcJSIiomK14cg5jPt+K05euAovTw+M7VkPj3SrA2+vktFhWqxBt6T6yRRhS5YsUcVnNHJfitgUxpgxY9RNerolrbCoNIqohB2maLT32IPUYxvgy6CbiMowCSwdTfF2NTnnONIQK8XUJFVcOy9dvnwZR44cKYYtJCIiosJIy8jEh8v2Y/qKA8g0AVGVymPa7S3QygXjtu0p8isnuVg5cOBA9v3Dhw9j69atqrCMFKSRVPDhw4er9L6OHTvi008/VSl8Dz30UKFe11k93dWD/bHUsx7aYw8uHViHyq3vLtLnJyIi55CK4+vWrVMBtFQlt9ULLb3b8+bNU8XTpFHhxRdfZI81ERFRCXf0bDLGfr8VW49fUPeHtIrAKzfHINDfMhOtJCjy/vaNGzeiZcuW6iYkyJafX3rpJXV/2LBhatoVKWTTokULrFq1CosWLULNmjUL9brSyx0bG4sNGzagKMkF2MVKTcx34jYX6XMTEZHzPPXUU2pIU0xMjJpn29YY7ffffx8VK1ZEp06dVOAtxTxbtWrFj4aIiKgEMplM+HHjcfT/YLUKuAP9vfHRHS3x3m3NS2TALTxMstVuREsvT0pKQlBQUJE85/T5yzBm22Cke3jD+/k4wNuvSJ6XiKiku3btmspYio6OVtNpUdHvR2ect0or7gsiIrIn6UoanluwA79vj1f320VXUsXSaoSUQ0k+b5WMkeVFQFLLpTfD1tRihRFRqwHOmgLhbUoHTu0s8ucnIiIiIiIi2/47dBb9PlilAm5vTw9M6NMAc+7v4LKAOz/cJuh2Vnq5aFwjGNsy66ifM09sLPLnJyIiIiIiIuNiaW//uQd3fPYf4pKuoVbl8vjp4U4Y072uqlReGrhN0O1M0aEVsMujrvo5+fB6V28OERERERGR2zucmIwhM9dixt8HIYOib2sTgd8fvw4tIkNQmpSOeV9cWL1cSAvKhZCmwMWfgJMspkZEREREROQsJpMJP2w8jkm/xeJKagaCy/lgyuCm6N+0Wqnc6W4TdDtrnm6NZ2QrYBcQePkQcC0J8C/61yAiIiIiIirLLlxJxbPzduCPnafU/Y61K2PqsOaoFlzyx27bwvRyB0VH1cKxzCrmO3FbnPiREBERERERlT1rDySi77TVKuCWYmkT+zXEN6Pbl+qA2616up2tcfUgbDfVQRTOwHRyCzxqd3P1JhEREREREZV6qemZeG/JXny66pAau107NAAf3N4STSPcI7vYbXq6nTllmGhQNRC7TNHq52vHOa6biIiIiIiosA4kXMbgmf9g1kpzwH1HuygsfLyL2wTcbtXT7ewx3f4+XjgfHAMkA6a4rUX+/ERERERERGWpWNqc9ccxeeEuXEvLREh5H7w5uBn6NqkKd+M2Pd3FwatGC/V/+cvHgKsXXL05RETkRLVq1cK0adO4j4mIiIrYueRUPPi/TXhu/g4VcHepG4rF4653y4DbrXq6i0N0ZASO76mCSM8zwKntQPT1rt4kIiIiIiKiUmP1/jN48odtSLiUAh8vDzzdpyFGdYmGp6cH3BWD7nyIqR6EHaZoROIMICnmDLqJiIiIiIjylJKegXf+3IvP1xxW9+tUCcCHd7RE4+ruM3bb7dPLnV1ITTSuFoydmbXUz6knOG0YEVFJNWvWLNSoUQOZmZkWy2+++WaMGDECBw8exC233ILw8HBUqFBBnTuWLl3qsu0lIiJyZ/tPX8LA6WuzA+67O0Rh4WPXlYmA262CbimiFhsbiw0bNjjtNYLL++BUQEP1c8ZJBt1EVAZJWdHUZNfc5LUdNHToUCQmJmLFihXZy86fP4/FixfjrrvuwuXLl9G/f38VaG/ZsgV9+vTBgAEDcOzYMSftOCIiorJZLO1//x7BTR+twe74i6gU4IvP72mD1wY2RTlfL5QVTC/PJ4/qzYEjQLmLh4FrFwH/IOd8MkREJVHaFeCN6q557efiAN8Ah1atVKkS+vbti++++w49e/ZUy3788Ue1XO57eXmhefPm2eu/9tprmD9/Pn799Vc8+uijTnsLREREZUXi5RQ889N2LNuToO5fVy8U7w1tjrAgf5Q1btPTXVyiImripKmy+c6pHa7eHCIiskF6tH/++WekpKSo+99++y1uv/12FXAnJyfj6aefVsOSQkJCVIr5nj172NNNRERUBP7em4C+01argNvXyxMv3RSDr+5tVyYDbsGe7nxqXD0IOzOjUcPrLBC/FajV2TmfDBFRSeRT3tzj7KrXzgdJF5cx3b///rsas7169WpMnTpVPTZhwgSVav7uu++ibt26KFeuHG699VakpqY6aeOJiIjc37W0DLz15x7M/ueIul8/vAI+uL0lGlUr29nBDLrzqXGNIHyXWQt9vDYi4+RWlJ2RCEREMsbGw+EUb1eTQHrw4MGqh/vAgQOoX78+WrdurR6TAHzkyJEYNGiQui9jvI8cMV8gEBERUf7tPXUJY7/fgj2nLqn7IzvVwsR+DeHvw4jJ252ql8stIyPDqa9TNcgfR/zqA5lA2onNDLqJiEp4irn0eO/atQt333139nLp3Z43b556zMPDAy+++GKuSudERETkWLG0r9YewRt/7EFqeiZCK/jinVubo3vDMO4+dxvTXRzVy4VcnGVWNRff8btw0FxRl4iISqQePXqo4ml79+7FnXfemb38/fffR8WKFdGpUycVeEv18latWrl0W4mIiEqbM5dScO+XG/DKb7Eq4O7eoAr+GHs9A2537ekuThGRNXHqZEVU9ThvLqYW1cHVm0RERAakaFpcXO4x6LVq1cLy5ctzNd7qMd2ciIjItuV7TmPCj9txNjkVvt6eeL5/I9zTsabqpCRLDLoLIKZaEHZkRqOq13kgbiuDbiIiIiIiKjPF0t5YtBtf/3tU3W9YNRAf3tES9cMDXb1pJRaD7gJoXD0Yv2VGo5fXZmTGb3WfHH0iIiIiIiIbdsdfxONztmB/wmV1/77O0Xi6bwMWS8sDg+4CiA4NwD7POurntOOb4VeQJyEiIiIiIioFMjNNmL32CN6SYmkZmagS6Id3hzZH1/pVXL1ppQKD7gLw8vRAWlgT4Czgc/4AkHYV8ClX9J8OERERERGRCyVcvIYnf9yG1fsT1f0bGoXhrSHNULkCux4dxaC7gKpF1EZiYhBCcRFIiAVqmOd+JSIiIiIicgdLYk/jmZ+341xyKvy8PfHCTTG4u30Ui6Xlk9sMR5Y5umNiYtC2bdtieb3GNYIRm1nTfCd+e7G8JhGRK+fgpILjHOBERFSaXE3NwPPzd+D+rzeqgFsKSf/+eBcM78Dq5GW6p1umepHbxYsXERwc7PTXi6kehH9MtXA9dsAUvx0sjE9E7sjHx0e1Zp85cwZVqlRhy3YBGitSU1PV/vP09ISvr69zPigiIqIisvNkEsZ+vwUHzySr+/dfF42n+jSAn7cX93FZD7qLm5TE/xzR6ue0k1vByygictd5riMiInDixAnOW10I5cuXR1RUlAq8iYiISmqxtM/XHMI7i/ciLcOEsEA/TL2tBbrUC3X1ppV6DLoLyN/HC8kVY4BLgNeZXUBGOuDF3UlE7qdChQqoV68e0tLSXL0ppbbhwtvbm1kCRERUYp1KkmJpW/HPgbPqfu+YcLw5pBkqBbBrsSgwSiyEkIgGuBzrjwoZ14Cz+4GwRkXyoRARlcTAUW5E9kyZMgXz5s3Dnj17UK5cOXTq1AlvvfUWGjRowB1HRFRC/bnzFCbO244LV9JQzscLLw2Iwe1tI9lYXISY51YIMTUqYrcpynyHxdSIiKiMW7lypaqv8t9//2HJkiVIT09H7969kZxsHhdIREQlx5XUdDw7bzse+maTCrib1gjGwse74I52rE5e1NjTXQiNqwdhV2YttPXcB5zaDjQfVnSfDBERUSnz559/WtyfPXs2wsLCsGnTJlx//fUu2y4iIrK0/cQFjPt+Kw4lJsPDA3jw+joY36s+fL3ZJ+sMDLoLoVG1IPxsqpVdTM2nqD4VIiIiN5CUlKT+r1SpkuHjKSkp6qaRGUiIiMg5thw7j4MJl7HtxAXMWX8c6ZkmVA3yx9RhzdGpDoulOROD7kIILueDs4ENgGuAh/R0yzy20lRERERUxsl0aePHj0eXLl3QpEkTm2PAJ02aVOzbRkRU1rz5x258svKQxbJ+TapiyuCmCCnPYmnOViLzBxYuXKiKrki13M8//xwlWbnqTZBq8oJ36kXgwjFXbw4REVGJ8Oijj2L79u2YM2eOzXWeffZZ1Ruu3Y4fP16s20hEVFZ6uK0Dbm3+bQbcZbSnW4quSMv4ihUrEBQUhFatWmHw4ME2U9NcrWGNyth/IAKNPY6ax3VXrOnqTSIiInKpxx57DL/++itWrVql5nm3xc/PT92IiKhog+zDicmIDg1A/fBATFm023C9I2evoFXNkhljuZsSF3SvX78ejRs3Ro0aNdT9/v37Y/HixbjjjjtQEjWuYS6m1tjzqLmCeaMBrt4kIiIil6WUS8A9f/58/P3334iOjuYnQUTkwjTyoHLeuHg13XBdCcqplKaXS6v2gAEDUL16dTW324IFC3KtM2PGDHUi9vf3R+vWrbF69ersx+Li4rIDbiEt5CdPnkRJ1bh6MHZlFVPLiNvm6s0hIiJyGZku7JtvvsF3332HwMBAnDp1St2uXr3KT4WIyAVp5BJwh1bwxc3Nq1ksf7hrbbSMqsjPpLT2dMtcnM2bN8e9996LIUOG5Hp87ty5GDdunAq8O3fujFmzZqFfv36IjY1FVFSUaiW3JsF7SRUW6IcTfnWBTHPQ7eXqDSIiInKRmTNnqv+7deuWa+qwkSNHumiriIjKhg+X7TdcPu6Geri7Qy3c2zkn7ZwBdykPuiWAlpstU6dOxahRozB69Gh1f9q0aSp9XE7UUsVUern1PdsnTpxA+/btbT6fq6cbkQYBz2pNkXnCA75XTgHJiUAAS+4TEVHZY9RwTkRExdPLvWLvGZuZuUICbQbbZaB6eWpqKjZt2oTevXtbLJf7a9euVT+3a9cOO3fuVIH3pUuXsGjRIvTp08fmc0qgHhwcnH2LjIxEcasTUQ2HTVXNd+KZYk5ERERERMXj0rU0vP67cbG0Hg2rMNAua0F3YmIiMjIyEB4ebrFc7suYL+Ht7Y333nsP3bt3R8uWLTFhwgRUrly5RE830rh6EGJNWVXLpYI5ERERERGRk20+dh43frgGG4+eN3z8sR71+BmU1erl1mO0JR1Nv+zmm29WN0do041Mnz5d3SSod0XQ/UNmLQzw+g+ZcdtK5uTnRERERETkFtIzMjF9xUF8uHw/MjJNqBFSDm1qVcQvW+Oy12GxtDIadIeGhsLLyyu7V1uTkJCQq/e7IBVT5SZjuiXNvDjVqhyAA1611c/pJ7fBt1hfnYiIiIiIysr82wG+Xvhs9eHs3u1bWlTHqwObIMjfByM71WKxtLIedPv6+qopwpYsWYJBgwZlL5f7t9xyS6Ge25U93Z6eHsgIbwqcAXySDgMplwG/CsW+HURERERE5P7zb4sKft54bWATDGyZM90yi6WVkaD78uXLOHDgQPb9w4cPY+vWrahUqZKaEmz8+PEYPnw42rRpg44dO+LTTz/FsWPH8NBDD5Xanm4RGRGF+IRKqOZxDji9E4jqUOzbQERERERE7j//tnh3aDP0bWI5/zaVkaB748aNqgiaRoJsMWLECHz55ZcYNmwYzp49i8mTJyM+Ph5NmjRRFcpr1swqRFZKybjuXRtroprXOXMFcwbdRERERERUSMv3JBguv5Ja/Bm+VEKC7m7duuU5T+cjjzyibkXJlenl2vx3y0y1cAO2wBS/DZal4oiIiIiIiPJXLO3D5QcwfUVOFrFedGgAd2cp4TaFtiW1PDY2Fhs2bHDJ69cLr4C9iFY/p53gXN1ERERERFQwR88mY+isf/Hhsv3INAH1wy3rRbEyeenikinD3JGftxeuVm4MJAHeZ/cC6amAN+uYExERERGRYyRjeN7mk3jpl51ITs1AoL83Xh/UFDc3r55dvVx6uKVgGpUebhN0uzq9XFSJqIsLFwIQgmTgzG6gWnOXbQsREREREZV8WjBdpYIf5m48joXb49XydrUqYeqw5oioWF7dZ2Xy0sttgm5XVy8XTSJCELu9Jjp5xQLx2xl0ExERERFRvqYC8/L0wPhe9fFQ1zrqZyr93GZMd4mpYG6qZb5zarurN4eIiIiIiErZVGBvDGqCMd3rMuB2I27T010SNKoWhG+ygu7UE1vBEd1ERERERGSUTr409pThjom7cJU7zM24TdBdEsZ0l/f1RlJwI+AK4JmwC8jMBDyZTEBERERERMbp5OT+3CYidPWUYZrgyEa4ZvKBd3oycI5/UEREREREZDud3Fq3BmHcXW7GbYLukiKmRmXsMUWZ75zifN1ERERERAT8FXs6z93A+bfdk9ukl5eoYmqZtdDC86C5gnmTIa7eJCIiIiIiKmZzNxzDtuMX0LhGEI6fu4ZZKw8arvfWkKbw8fLk/NtujEF3EWtcPRgLs4qppZ3cBp+ifgEiIiIiIirRBk5fg63Hk3Itb1g1EHtOXbLo2R7WNitLltyW2wTdJaGQmggu74MzFeoDKQDitwEmE+DB+fWIiIiIiMqCdxbvMQy4h3eIwqsDm2ZXL48ODUDLqIou2UYqXm4zprukFFIT/tWbId3kCZ+Uc8CleFdvDhERERERFVN18ukrjNPIMzJN6n8JtAe3imDAXYa4TdBdktSPqIKDpurmOzKum4iIiIiIynR18uaRIcW6PVRyMOh2giY1grEza1w3TjHoJiIiIiJy10B73uYTWH/4LD5Ytt/mei0jgzl2uwxzmzHdJa2C+azMWhjitQbpJ7dyJxMRERERuWEquSPzbo/pXgcT+jQslm2ikok93U4QFuSPk/511c8ZcezpJiIiIiIqC6nkHWpXsrgv1ckZcJPb9HSXlOrlGu9qTYETgN/l48C1JMA/2NWbRERERERERWDHidzVycVtbSLxTN+GrE5O7tnTXZKql4takZE4YQo13zm9y9WbQ0RERERERWDVvjN4f+k+w8e0acBYnZzcMuguaZrUCMLuzKyJ7k/tcPXmEBERERFRPgukyf+aa2kZmPxbLO75Yj3OX0lDxfI+uVLJOe82uXV6eUnTuHow5plqohc2q3HdXq7eICIiIiIiyneBtIe61lY914/P2YI9py6pZSM61sSz/Rthd/xFppJTnhh0O0lExXI44l1b/Zx6civKOeuFiIiIiIjIaQXS5P4Xa44gNSMTlQN88c7QZujRMFw9Jj3b7N2mvDDodhIPDw9khjUFEgDfc/uAjDTAyzIFhYiIiIiISo7DicmGyyXg7tagCt65tTmqBPoV+3ZR6cYx3U4UFlUPl0zl4JWZCiTud+ZLERERERFRIXu5v/3vqM3HH+9RlwE3FQiDbidqElERu00spkZEREREVNLHcQ+asRabjl2wuc6Rs1eKdZvIfbhN0C1zdMfExKBt27YoKRpXD0JsZk31c2b8dldvDhERERERWZm74Viucdy2pgMjKtNBd0mbp1tEh1bAAc9o9fO1E9tcvTlERERERGTVw/3Mz3lP7zu4ZXUWTKMCYyE1J/Ly9MC1yjHAecArYSdgMkmFNWe+JBEREREROTB++++9CQ71cEvAPXVYS+5TKjAG3U4WFNUU6ec84Zd6HrgUDwRVd/ZLEhERERGRg/NwG2lTMwSd64aiW4Mw9nBToTHodrIGEVVwcEt1NPA4AZzawaCbiIiIiKgEj99+a0hTDGubVQyZqAi4zZjukqph1SDEmszF1FTQTUREREREJXL89sNdazPgpiLHnm4nqx8eiN9NNTEI/6hiav7OfkEiIiIiIrKw6eg5uz3cY3vWZSo5OQ2Dbicr5+uF84ENgKucNoyIiIrH8ePHceTIEVy5cgVVqlRB48aN4efnx91PRGXS6YvX8Oy8HXZ7t5/o1aBYt4nKFgbdxcCzalPgMFDu0lEg5TLgV6E4XpaIiMqQo0eP4pNPPsGcOXNU0G2SGTOy+Pr64rrrrsMDDzyAIUOGwNOTo8uIqGxYvOsUJv68HeevpBk+zvHbVBxK5Fl30KBBqFixIm699Va4g8jIKJwyVYQHTEBCrKs3h4iI3MzYsWPRtGlT7N+/H5MnT8auXbuQlJSE1NRUnDp1CosWLUKXLl3w4osvolmzZtiwYYOrN5mIyKnTgc1ZfxQPfL0RD/5vkwq4m9QIwrC2ERbrcfw2leme7scffxz33XcfvvrqK7hNMbXMmqjqdR44tR2IbOfqTSIiIjciPdkHDx5UqeTWwsLC0KNHD3V7+eWXVQAuveJt27Z1ybYSETkz2P5w2X6s2HvGYvmDXWvjyV4N4OvtidvbRuFwYjKiQwM4FRiV7aC7e/fu+Pvvv+EuGlUPwgJTFHpgKzLitsPL1RtERERu5Z133nF43f79+zt1W4iIStrc230bV1UBt2gZVZHBNpX89PJVq1ZhwIABqF69Ojw8PLBgwYJc68yYMQPR0dHw9/dH69atsXr1apRl1YP9ccy7lvo5JW6XqzeHiIiIiMiterjtVSaXnm2iUhV0Jycno3nz5vj4448NH587dy7GjRuH559/Hlu2bFGFW/r164djx45lryOBeJMmTXLd4uLi4I6kcSI9tJH62fvsXkBX3IaIiKgonT17FmPGjEFMTAxCQ0NRqVIlixsRkbtZsPWk3ccllZyoVKWXSwAtN1umTp2KUaNGYfTo0er+tGnTsHjxYsycORNTpkxRyzZt2oSikpKSom6aixcvoiQKrtEIaWe84Jt+CbgYJwtcvUlEROSG7r77bjW+W87F4eHhquGXiMgdJaekY/JvsZi78bjNdaRYmqSUE7nNmG6pkioB9cSJEy2W9+7dG2vXroUzSCA/adIklHT1alTG4S1VUd/jJJCwm0E3ERE5xZo1a9RNstKKmwxBk/Hlci0QHx+P+fPnY+DAgcW+HUTk/rYdv4Cx32/BkbNXIG2LLSJCsOX4hezHezSsgsd61GPATe4XdCcmJiIjI0O1rOvJfZmyxFF9+vTB5s2bVSp7RESEOmnbqrL67LPPYvz48RY93ZGRkShpGlULwj5TJOpDgu5YoN4Nrt4kIiJyQw0bNsTVq1dd8traELR7771XzQdORFTUMjJN+GTlQby/ZB/SM02oFuyP94e1QIfaldXYblYmpzJTvdw6lc1kMuUrvU3S0R3l5+enbtOnT1c3CfpLovrhFbDcZJ4b8FrcTvi7eoOIiMgtSTFTyTh76aWXVL0UHx8fi8eDgoKc9tp5DUEjIiqMkxeu4om5W7H+8Dl1/8am1fDGoKYILm8+zrEyOZWJoFsKtnh5eeXq1U5ISMjV+13UpGiM3KSnOzg4GCVNeV9vJFWoC1wD0uJ3MegmIiKnCAkJQVJSkpqX26gBvCQ1TpeWuixE5HoLt8fhuXk7cPFaOgJ8vTDpliYY0qoG61ZQ2Qu6fX19VWXyJUuWYNCgQdnL5f4tt9yCss4jvBFwFCh34QCQmQl45rt4PBERkV133XWXOh9/9913Jb6QWmmpy0JErnM5JR0v/7ILP28+oe63iAzBtGEtUIsVyakUyXfQffnyZRw4cCD7/uHDh7F161Y1DUlUVJQaXz18+HC0adMGHTt2xKeffqqmC3vooYfgTCU9vVyERjZEyhEf+GVeAy4cASrVdvUmERGRm9m5c6easrNBgwYo6UpLXRYico3v1x/DO4v34mxyKjw9gEe718VjPevBx4sdV+TmQffGjRvRvXv37PvayXLEiBH48ssvMWzYMDVH6OTJk1XlUhlPtmjRItSsWRNlOb1cNKheEftNNdDE44i5gjmDbiIiKmLS6H38+PFSEXRrdVmIiKyLpd3+6b/YcOR89rIBzaphfO+Sf1wjKpKgu1u3bmpcmD2PPPKIuhWn0tDT3bBqIDaYItAER5B+ahe8G97o6k0iIiI389hjj2Hs2LGYMGECmjZtmquQWrNmzVy2bUREtmiVx2W89rRl+7E7/pLF479si8fIzuc5BRiVSk6pXu4KpaGnO6JiOfzkFaV+vnJiB5xXP5aIiMoqyTgT9913X/YyGdddHIXU8hqCRkRk5M0/duOTlYfy3DkSlEuFcqLSxm2C7tJALnauhjQALkhJ992u3hwiInJDEui6Sl5D0IiIjHq4HQm4RTSLp1EpxaC7uHd4tcYq6A64dBjISAO8LNP+iIiICiotLU0FvQsXLkRMTEyx70hHhqAREekD7hkrcrJj9Ho0rILle85k33+4a232clOp5TZBd2kY0y3CI+ricqw/KsiE3WcPAmENXb1JRETkJmT8tsx7XZKnCSOisk0bu71yXwJ+2Rpvc73HetRTN1lXeriZVk6lmdsE3aVhTLeoXzUI+00RaOlxAEiIZdBNRERFXkjtrbfewueffw5vb7c5zRNRGRq7re/VZrBN7oBn42LWoGog/sqMQEvPA0iN3wXfJoOLexOIiMiNrVu3DsuWLcNff/2lqpcHBARYPD5v3jyXbRsRlV2OjN2+s10khraJZKBNbsdtgu7Skl5eKcAXcb7RQObfqoK5r6s3iIiI3EpISAiGDBni6s0gIrJIJ9936mKee4QBN7krtwm6S0t6uUip1ABIBLwS97h6U4iIyM3Mnj3b1ZtARKQ8MXcL5m+Jc2hvsFAauTO3CbpLE9/qTVTQXSH5GJB2FfAp5+pNIiIiN3PmzBns3btXFVWrX78+qlSp4upNIqIyxJGAe3DL6uhSrwoLpZHbY9DtApERNXFuWwVU8rgMJO4DqjV3xWYQEZEbSk5OVsXUvv76a2RmZqplXl5euOeee/DRRx+hfPnyrt5EIioDKeW2Au6xPeuiZuUABtpUpni6egPKovrVzBXMlYTdrt4cIiJyI+PHj8fKlSvx22+/4cKFC+r2yy+/qGVPPvmkqzePiNw40H5/yV5M/WuPzbm3RbcGYRjcKoLF0qhMcZue7tJSSE3UC6uAnzMj0d5zD66e3Ily7OgmIqIi8vPPP+Onn35Ct27dspf1798f5cqVw2233YaZM2dyXxNRkQbbr/0ei01HL+S5rqSTcwowKovcJuguTYXUAvy8caZcbSANuHZyBziim4iIisqVK1cQHh6ea3lYWJh6jIiouOfd1gLuqcNacudTmeQ2QXdpkx7aEIgHfM7udfWmEBGRG+nYsSNefvllNabb399fLbt69SomTZqkHiMiKgpzNxzLM+Dm+G0iMwbdLlKuemMVdFe4Fg+kXAb8KrhqU4iIyI188MEH6Nu3LyIiItC8eXNVvXzr1q0qAF+8eLGrN4+IylAPt4zfZjo5EYNul4mMqIGzGwNR2eMScHY/UJ3pNkREVHhNmjTB/v378c0332DPnj0wmUy4/fbbcdddd6lx3UREhR3D7UjAzXm3iXKwp9tF6lYJxAFTDVT22AMkMugmIqKiI8H1/fffz11KREVu58kku4+3rhmCF26MYQ83kTsG3aWpermoExaABZnVzBXM42JRrpmrt4iIiNzFvn378PfffyMhISF7rm7NSy+95LLtIqLS7Z8DiXh/6X7Dx4a1icDt7aIYbBO5c9BdmqqXi/K+3kj0rwWkA1fjd7OCORERFYnPPvsMDz/8MEJDQ1G1alU1plsjPzPoJqL8ppPvP30Jaw+exS/b4mAyASHlfHDhappFKvkz/RpxxxK5e9BdGqVWrAecATxlTDcREVEReO211/D666/jmWee4f4kokIF2x8t34/le85YLL+zfRReuLER9p66hMOJyYgODWDvNlEeGHS7kG/VhiroDkw+CmSkA178OIiIqHDOnz+PoUOHcjcSUYEC7b/3JmDxrlPYc+qy4TpDW0eojE2pSs7K5ESO8XRwPXKCKhF1cMXkBy9TOnD+CPcxEREVmgTcf/31F/ckEeV7GrBBM9big2UHbAbcQoLyeZtPqACdiBzDrlUXqhcehEOmamjicQRI3AuE1nXl5hARkRuoW7cuXnzxRfz3339o2rQpfHx8LB5//PHHXbZtRFQyzd1wzKFpwIQE5ZqHutbGRI7lJsoTg24XqhtWAStN1dEER5B6ag98G97oys0hIiI38Omnn6JChQpYuXKluulJITUG3URk3cPtaMBtTX6vT+OqTDMnygODbhcKKe+LOJ9IIBO4fDIWlVy5MURE5BYOHz7s6k0golJCUsQdCbhl7u0udUMterk1UkyNY7uJ7OOYbhe7FpyVUn5mr6s3hYiIiIjKkA+X7ctzncEtq+PnhzujW4Mww8elejkRlZGge/r06YiJiUHbtm1RmniFNVD/B1w6BDXxIRERUT69+eabuHLlikPrrlu3Dr///jv3MVEZt2LPaazYm2jz8YZVK2D+I50wdVhLdV96s2UMt57Mz81ebqIylF4+ZswYdbt48SKCg4NRWoRENETGHg/4ZSQDl04BQdVcvUlERFTKxMbGIioqSlUuv/nmm9GmTRtUqVJFPZaenq4eX7NmDb755hvEx8fj66+/dvUmE5GL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DQ1VN0ecPHlSBdytW7fG7Nmz8wy4hZ+fn7oRERG5MwbdREREVCjSw92tWzdERUWpKcLOnDmT/VjVqlW5d4mIqExj0E1ERESF8tdff+HAgQPqFhERYfGYm81MSkRElG8spEZERESFMnLkSBVcG92IiIjKOgbdRERERERERE7CoJuIiIiIiIjISRh0ExERERERETkJg24iIiIiIiIiJ3G76uVa0RaZqJyIiKik085XLDrGczgREbnnOdztgu5Lly6p/yMjI129KURERPk6fwUHB5fpPcZzOBERueM53MPkZk3rmZmZiIuLQ2BgIDw8PIqk9UIC+OPHjyMoKKhItrEs4H7jfuN3rnTg36rr95uchuVkXb16dXh6lu1RX4U5h/O7XHS4L7kvSyJ+L7kvSyJHz+Fu19MtbzYiIqLIn1cuqhh0c78VF37fuO+KG79zrt1vZb2HuyjP4fwuFx3uS+7LkojfS+7LksaRc3jZblInIiIiIiIiciIG3UREREREREROwqA7D35+fnj55ZfV/+Q47reC4X4rOO477rfixO9bycPPhPuyJOL3kvuyJOL3svi5XSE1IiIiIiIiopKCPd1ERERERERETsKgm4iIiIiIiMhJGHQTEREREREROQmDbjtmzJiB6Oho+Pv7o3Xr1li9ejXKsilTpqBt27YIDAxEWFgYBg4ciL1791qsIyUCXnnlFTVBfLly5dCtWzfs2rXLYp2UlBQ89thjCA0NRUBAAG6++WacOHECZWk/enh4YNy4cdnLuN+MnTx5EnfffTcqV66M8uXLo0WLFti0aRP3mx3p6el44YUX1LFL/gZr166NyZMnIzMzk/vNyqpVqzBgwAB1vJK/yQULFlg8XlR/l+fPn8fw4cPVPJ5yk58vXLjgwNGCCurIkSMYNWpU9t9BnTp1VFHU1NRU7tQCeP3119GpUyd1HA4JCeE+zAdeSxbP8ZqK7lqenINBtw1z585VQdHzzz+PLVu24LrrrkO/fv1w7NgxlFUrV67EmDFj8N9//2HJkiXq4r53795ITk7OXuftt9/G1KlT8fHHH2PDhg2oWrUqevXqhUuXLmWvI/t1/vz5+P7777FmzRpcvnwZN910EzIyMuDuZJ98+umnaNasmcVy7rfcJFDp3LkzfHx88McffyA2NhbvvfeexQUf91tub731Fj755BP1N7h79261j9555x189NFH3G9W5NjVvHlzta+MFNX3684778TWrVvx559/qpv8LIE3Oc+ePXtUQ9OsWbNUQ8n777+v/i6ee+457vYCkMaKoUOH4uGHH+b+ywdeSxbf8ZqK7lqenESql1Nu7dq1Mz300EMWyxo2bGiaOHEid1eWhIQEqXxvWrlypbqfmZlpqlq1qunNN9/M3kfXrl0zBQcHmz755BN1/8KFCyYfHx/T999/n73OyZMnTZ6enqY///zTrfftpUuXTPXq1TMtWbLE1LVrV9PYsWPVcu43Y88884ypS5cuNvcn95uxG2+80XTfffdZLBs8eLDp7rvv5n6zQ45l8+fPL/LvV2xsrHru//77L3udf//9Vy3bs2ePvU2iIvb222+boqOjuV8LYfbs2epvgBzDa8niOV5T0V3Lk/Owp9tGi66ksErLj57cX7t2rbPaP0qdpKQk9X+lSpXU/4cPH8apU6cs9pvMA9i1a9fs/Sb7NS0tzWIdSRVq0qSJ2+9baVm88cYbccMNN1gs534z9uuvv6JNmzaqd0VSoFq2bInPPvuM+y0PXbp0wbJly7Bv3z51f9u2baoHtn///vy+5UNR/V3++++/KqW8ffv22et06NBBLXP3Y15JPGdp5ysiZ+O1JJXGa3lyHm8nPneplZiYqFIDw8PDLZbLfbkII/NYx/Hjx6sLfLnAFNq+MdpvR48ezV7H19cXFStWLFP7VlJPN2/erFJUrXG/GTt06BBmzpypvmeSErp+/Xo8/vjjKvC55557uN9seOaZZ9RJtGHDhvDy8lLHMhmPeccdd/D7lg9F9Xcp/0ujkTVZ5s7HvJLm4MGDaoiFDFEhKg68lqTSeC1PzsOebjukUIP1l9N6WVn16KOPYvv27ZgzZ06R7Dd33rfHjx/H2LFj8c0336iifLZwv1mS8ZitWrXCG2+8oXq5H3zwQdx///0qEOd+sz+GUL5r3333nWro+eqrr/Duu++q/7nf8q8o/i6N1nfnY54zSWE72W/2bhs3brT4nbi4OPTt21dlzYwePdpl2+4O+5Lyj9eSVBqv5anosafbgFShlR4i616IhISEXL0eZZFU6pXUX6kkGRERkb1cigwJ2W/VqlUz3G+yjqRcSZEsfe+QrCOVUd2RpKDK+5MK+BrpfZT9JwVBtKqR3G+W5DsUExNjsaxRo0b4+eef1c/8vhmbMGECJk6ciNtvv13db9q0qeqZlYqlI0aM4H5zUFF9v2Sd06dP53r+M2fO8HxSwItE7bttS61atSwC7u7du6Njx46qiCUVfF9S/vBakkrjtTw5D3u6DUi6oARIUtVPT+67a2DoCOmZkZP0vHnzsHz5cjUVi57clwtM/X6TC1KplKjtN9mvUo1av058fDx27tzptvu2Z8+e2LFjh6pYrN1krPJdd92lfpYpnbjfcpPK5dbTWMg45Zo1a6qf+X0zduXKFXh6Wh7apRFRmzKM+80xRbWfJNiTdH8ZHqFZt26dWuauxzxnBzIydMLeTcsokikHZZo3yZiZPXt2rr+Lsi4/+5Lyj9eSVBqv5cmJnFikrVSTarRSlfb//u//VPXZcePGmQICAkxHjhwxlVUPP/ywqlr6999/m+Lj47NvV65cyV5HKv3KOvPmzTPt2LHDdMcdd5iqVatmunjxYvY6UhU+IiLCtHTpUtPmzZtNPXr0MDVv3tyUnp5uKiv01csF91tu69evN3l7e5tef/110/79+03ffvutqXz58qZvvvmG+82OESNGmGrUqGFauHCh6fDhw+pvMTQ01PT0009zvxnMKLBlyxZ1k9Ph1KlT1c9Hjx4t0r/Lvn37mpo1a6aqlsutadOmpptuuqmARw9yhFSRr1v3/9u7s9iY+jCO408tXWgtta+VEmttpUgkYidcEDsVW7iy3FgiiqrlhiCxhNaFfQ0iKmIJFesVIbZYEjRECJpGaGo7b54nmWZmOh0zrx5t9ftJpp2emXN65nRmOr/z/Jc29vd4/fq1z/8shE9fE/rayMjIcGJjY4teN/oaQsn4LPn33q9Rep/l4Q5CdxDbt293EhISnMjISCc5ObnSD6evb3KBLjqFiPc0O+np6TbVTlRUlNOvXz/7sOqtoKDAmTdvnhMfH+/ExMTYh8/c3FynMvEP3Ry3wLKzs52kpCR7LumUfVlZWT63c9yK00Coz62WLVs60dHRTmJiopOWluYUFhZy3Pzk5OQEfE/TExel+fz6+PGjk5qa6sTFxdlFr+fl5YXxjoFw6f+lkv5nIXz6mgh0LPU1hOD4LPl33q9Rep/l4Y4I/eJmJR0AAAAAgMqKDk4AAAAAALiE0A0AAAAAgEsI3QAAAAAAuITQDQAAAACASwjdAAAAAAC4hNANAAAAAIBLCN0AAAAAALiE0A0AAAAAgEsI3QAAAEAl8e3bN2nTpo3cuHFDyquUlBQ5efJkWe8GUGoI3QAAAIDLVq1aJd26dSvz45yVlSUJCQnSt29fKa9WrFghS5culV+/fpX1rgClgtANAAAAlBPfv393dftbt26V2bNny9+oqP9fI0eOlPz8fDl//nyp7hNQVgjdAAAAwG/s27dP6tWrJ4WFhT7Lx44dK9OmTQu67p49eyQjI0Pu3bsnERERdtFlSq/v3LlTRo0aJTVr1pS1a9fabXXq1PHZxqlTp+y+3rKzs6VHjx4SHR0tiYmJ9jt+/PhR4n7cuXNHnj9/bqHW4+XLl7Zdbc49YMAAqVGjhnTt2lVu3brls+6JEyekU6dOEhUVJa1atZKNGzf63K7LdN9nzJghtWvXljlz5hQ9jjNnzki7du1s2+PGjZMvX77I3r17bZ26devK/Pnz5efPn0Xbqlq1qowYMUIOHz4c9LgCFQWhGwAAAPiN8ePHWzA8ffp00bIPHz5YoJw5c2bQdSdOnCgLFy600Pr27Vu76DKP9PR0C93379+XWbNmhfS30Crw1KlTZcGCBfLo0SPJzMy0kLtu3boS17l69aq0bdtWatWqVey2tLQ0WbRokdy9e9fuM3ny5KIAf/v2bZkwYYJMmjTJ9lGbymsTcM+JA48NGzZIUlKS3V9vV1+/fpUtW7bIkSNH5Ny5c3LlyhUZM2aMnD171i779++3Ju/Hjx/32VavXr3k2rVrIR0LoLyrVtY7AAAAAJR3MTExMmXKFNm9e7cFcHXw4EFp3ry59O/f/7frxsbGSrVq1aRx48bFbtfthhq2PTRca7/n6dOn289a6V6zZo0sWbLEQnwgWtVu2rRpwNs0cHsq4Fox1xMEWhVv3769bNq0SQYNGlQUpDWUa9DXkK2VbY+BAwfadjyuX79uzeV37NghrVu3tmVa6dag/e7dOzsmHTt2tAp7Tk6Oz4mIZs2aSW5urvXrrlKFOiEqNp7BAAAAQAi0yfSFCxfkzZs39rMGcA2d/s2+w9WzZ8+w19Fq8urVqy24ei66f1pF1+pyIAUFBdYUPZAuXboUXW/SpIl9f//+vX1//PhxsYHX9Odnz575NAsP9Di0SbkncKtGjRpZs3LdX+9lnt/lfaJCA7d/c36gIqLSDQAAAISge/fu1t9Z+3cPGzbMmlprv+o/pX25vWll13GcoAOsaSDVirQ21fZXUrCuX7++7XMg1atXL7ruOYngGT1c98X/xIL//gV6HP7b9Ww70DL/kco/ffpkgV3DN1DREboBAACAEOnI35s3b7Zq9+DBg6VFixYhrRcZGelTFQ6mQYMG8vnzZxtwzBNkta+1t+TkZHny5InNuR3OSQNt6h0oRAejTcC1qbi3mzdvWjNzHfTMDQ8ePLDHCPwLaF4OAAAAhCg1NdUC965du8Lqh61Nql+8eGHhWQdgC9Zsunfv3lblXbZsmfWrPnToULFBy1auXGkVdx3U7OHDh9YE/OjRo7J8+fISt6t9pzXI6/3DoYPAXbp0yfqMP3361EYe37Ztm0//7dKmg6gNHTrUte0DfxOhGwAAAAiRjvyt04Rpn+TRo0eHfNx0neHDh1vw1Up2sOmw4uPj5cCBAza6d+fOne2+Gq69afN2HTn94sWLkpKSIn369LEBzxISEkrcrk55ps3RdQC4cGjF+dixYzYCuY5OroFf+5N7D6JWmvSkhlbSfzcqPFBRRDiBOmQAAAAACGjIkCHSoUMHmwqrotE+3dosXivocXFxUh4tXrxY8vPzbSox4F9ApRsAAAAIgQ7updXey5cvy9y5cyvkMdPK+fr16236sPKqYcOG1pQd+FdQ6QYAAABC7Jedl5dn81X792fWea1fvXoVcL3MzEzrCw6gciJ0AwAAAH9IA7f/tF7e81CX16bcANxH6AYAAAAAwCX06QYAAAAAwCWEbgAAAAAAXELoBgAAAADAJYRuAAAAAABcQugGAAAAAMAlhG4AAAAAAFxC6AYAAAAAwCWEbgAAAAAAxB3/AakHrHlQci/yAAAAAElFTkSuQmCC",
      "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.031e-04 @ epoch 979\n",
      "\n",
      "iter=0  t=0.00s  best_y=548.256  x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\n",
      "STOP: local minimum. best_y=548.256 x=[1, 1, 1, 1, 0, 0, 0, 0, 0, 0]\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: 0xa30f3f82\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     [3e-04, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-12, 2e+03]\n",
      "  RHS range        [4e+00, 8e+02]\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.02s\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 (10 binary)\n",
      "\n",
      "Root relaxation: objective -4.048558e+02, 1773 iterations, 0.03 seconds (0.12 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 -404.85576    0 1582          - -404.85576      -     -    0s\n",
      "     0     2 -404.23073    0 1582          - -404.23073      -     -    0s\n",
      "     3     8 -401.11734    2 1578          - -401.11734      -  63.7    5s\n",
      "* 1544   779              66      74.4284090 -332.04692   546%  24.3    6s\n",
      "* 1598   747              12      32.0615223 -277.65380   966%  24.4    6s\n",
      "* 1628   747              11      13.5435486 -277.65380  2150%  24.0    6s\n",
      "* 1899   789              34       0.4468577 -251.61665      -  21.7    7s\n",
      "* 1976   816              42       0.1937162 -251.61665      -  21.0    7s\n",
      "* 1978   816              43       0.1306032 -251.61665      -  20.9    7s\n",
      "* 2082   773              44       0.1148357 -251.61665      -  20.2    7s\n",
      "* 2151   796              45       0.1108945 -251.61665      -  20.2    8s\n",
      "* 2449   841              48       0.1103403  -96.25151      -  17.8    8s\n",
      "* 2587   837              51       0.1102623  -76.68130      -  16.8    8s\n",
      "* 2589   837              52       0.1102591  -76.68130      -  16.8    8s\n",
      "* 2769   889              54       0.1102396  -63.87909      -  15.8    8s\n",
      "* 2771   889              55       0.1102380  -63.87909      -  15.8    8s\n",
      "  2967   617   -7.00613   87    2    0.11024  -61.07452      -  14.8   10s\n",
      "  2968   621  -61.07452   10 1136    0.11024  -61.07452      -  15.4   15s\n",
      " 10932   212 infeasible   53         0.11024  -38.87108      -   4.4   20s\n",
      " 11329   208  -38.87088   54    4    0.11024  -38.87089      -   4.2   25s\n",
      " 19284   150  -32.89402   50    2    0.11024  -32.91830      -   2.5   30s\n",
      " 28127   206 infeasible   59         0.11024  -32.78383      -   1.8   35s\n",
      " 35805   192  -32.74797   58    2    0.11024  -32.74797      -   1.5   40s\n",
      " 43656   186  -32.70899   58    1    0.11024  -32.71650      -   1.3   45s\n",
      " 52851   201 infeasible   61         0.11024  -32.67053      -   1.2   50s\n",
      " 60614   184 infeasible   65         0.11024  -32.63767      -   1.1   55s\n",
      " 67729   176 infeasible   47         0.11024  -25.20410      -   1.0   61s\n",
      " 73966   203  -11.74280   51    2    0.11024  -25.14853      -   0.9   65s\n",
      " 87819   183  -11.66702   53    1    0.11024  -11.70008      -   0.8   70s\n",
      " 100625   206 infeasible   59         0.11024  -11.66973      -   0.7   75s\n",
      " 111867   177  -11.60831   55    1    0.11024  -11.61243      -   0.7   80s\n",
      " 123371   191  -11.56142   57    1    0.11024  -11.57207      -   0.7   85s\n",
      " 134383   215  -11.39692   58    1    0.11024  -11.42175      -   0.6   90s\n",
      " 145142   183 infeasible   54         0.11024  -11.38202      -   0.6   95s\n",
      " 156447   189  -11.31177   55    2    0.11024  -11.34777      -   0.6  100s\n",
      " 167093   158 infeasible   56         0.11024  -11.29634      -   0.6  105s\n",
      " 174638   137   -9.26890   44    2    0.11024   -9.29189  8529%   0.6  110s\n",
      " 179919   339 infeasible   41         0.11024   -9.25851  8499%   0.6  115s\n",
      " 193389 11051   -5.40907  356    1    0.11024   -9.23980  8482%   0.5  120s\n",
      " 208371 23808   -5.40907 1067    1    0.11024   -9.19947  8445%   0.5  125s\n",
      " 226964 41459   -5.40907 1866    1    0.11024   -9.18818  8435%   0.5  130s\n",
      " 257676 71955   -5.40907 3002    1    0.11024   -9.18513  8432%   0.4  135s\n",
      " 309764 123692   -5.40907 4853    1    0.11024   -9.18513  8432%   0.3  140s\n",
      " 360333 174262   -5.40907 6658    1    0.11024   -9.18513  8432%   0.3  145s\n",
      " 410592 224395   -5.40907 8462    1    0.11024   -9.18513  8432%   0.3  150s\n",
      " 462530 276136   -5.40907 10319    1    0.11024   -9.18513  8432%   0.2  155s\n",
      " 512312 326002   -5.40907 12087    1    0.11024   -9.18513  8432%   0.2  160s\n",
      " 563611 377259   -5.40907 13928    1    0.11024   -9.18513  8432%   0.2  165s\n",
      " 613585 427191   -5.40907 15712    1    0.11024   -9.18513  8432%   0.2  170s\n",
      " 662394 475944   -5.40907 17455    1    0.11024   -9.18513  8432%   0.2  175s\n",
      " 710226 523735   -5.40907 19163    1    0.11024   -9.18513  8432%   0.2  180s\n",
      " 759214 572695   -5.40907 20912    1    0.11024   -9.18513  8432%   0.1  185s\n",
      " 807522 620891   -5.40907 22637    1    0.11024   -9.18513  8432%   0.1  190s\n",
      " 853385 666781   -5.40907 24274    1    0.11024   -9.18513  8432%   0.1  195s\n",
      " 902393 715790   -5.40907 26024    1    0.11024   -9.18513  8432%   0.1  200s\n",
      " 948932 762342   -5.40907 27686    1    0.11024   -9.18513  8432%   0.1  205s\n",
      " 997065 810448   -5.40907 29404    1    0.11024   -9.18513  8432%   0.1  210s\n",
      " 1044771 858097   -5.40907 31107    1    0.11024   -9.18513  8432%   0.1  215s\n",
      " 1088461 901603   -5.40907 32273    1    0.11024   -9.18513  8432%   0.1  220s\n",
      " 1105742 917417   -9.17584   46    2    0.11024   -9.17584  8424%   0.1  225s\n",
      " 1123561 934450   -9.16801   47    2    0.11024   -9.16840  8417%   0.1  230s\n",
      " 1140547 950598   -9.16243   50    2    0.11024   -9.16243  8412%   0.1  235s\n",
      " 1157148 965765   -9.14940   48    2    0.11024   -9.15057  8401%   0.1  240s\n",
      " 1178963 987081   -5.40907 34979    1    0.11024   -9.14093  8392%   0.1  245s\n",
      " 1211387 1019201   -5.40907 36169    1    0.11024   -9.13701  8388%   0.1  250s\n",
      " 1261346 1069160   -5.40907 37963    1    0.11024   -9.13701  8388%   0.1  255s\n",
      " 1310876 1118637   -5.40907 39723    1    0.11024   -9.13701  8388%   0.1  260s\n",
      " 1358416 1166202   -5.40907 41421    1    0.11024   -9.13701  8388%   0.1  265s\n",
      " 1405794 1213566   -5.40907 43123    1    0.11024   -9.13701  8388%   0.1  270s\n",
      " 1454630 1262416   -5.40907 44858    1    0.11024   -9.13701  8388%   0.1  275s\n",
      " 1496854 1304640   -5.40907 46376    1    0.11024   -9.13701  8388%   0.1  280s\n",
      " 1540295 1347983   -5.40907 47918    1    0.11024   -9.13701  8388%   0.1  285s\n",
      " 1583638 1391410   -5.40907 49466    1    0.11024   -9.13701  8388%   0.1  290s\n",
      " 1631760 1439392   -5.40907 51185    1    0.11024   -9.13701  8388%   0.1  295s\n",
      " 1681234 1488770   -5.40907 52952    1    0.11024   -9.13701  8388%   0.1  300s\n",
      "\n",
      "Explored 1682636 nodes (113549 simplex iterations) in 300.01 seconds (607.69 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 0.110238 0.11024 0.110259 ... 0.446858\n",
      "\n",
      "Time limit reached\n",
      "Best objective 1.102379803110e-01, best bound -9.137014298613e+00, gap 8388.4449%\n",
      "[CHECK LSET] obj(x_ip)=71.8376  ip_y=0.110238  rel_err=9.985e-01\n",
      "\n",
      "=== MODEL SPECS (from seed 0 run) ===\n",
      "    model  n_params                                                  details    lr  batch_size  epochs\n",
      "      DFN     16725 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "DFN_AfixI     17610   layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "     LSET     17600                                     n_pieces=1600 T=0.05 0.001           8    1000\n",
      "      MLP     18049                                        hidden=[128, 128] 0.001           8    1000\n",
      "MaxAffine     17600                                            n_pieces=1600 0.001           8    1000\n",
      "\n",
      "=== LEARNING SUMMARY (mean ± SE over seeds) ===\n",
      "    model  train_time        best_val            test\n",
      "      DFN 1098.83 ± 0  0.00104204 ± 0  0.00102212 ± 0\n",
      "DFN_AfixI 1718.37 ± 0  0.00297787 ± 0  0.00227942 ± 0\n",
      "     LSET 200.501 ± 0 0.000103127 ± 0 0.000119732 ± 0\n",
      "      MLP  221.62 ± 0 0.000230489 ± 0 0.000224721 ± 0\n",
      "MaxAffine  181.61 ± 0  0.00136189 ± 0   0.0012964 ± 0\n",
      "\n",
      "=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\n",
      "    model                           LS_x        LS_y LS_true_y        LS_time                           IP_x         IP_y IP_true_y       IP_time                           GT_x GT_true_y        GT_time  LS_vs_IP_% IP_true_vs_GT_%\n",
      "      DFN [1, 1, 1, 1, 0, 0, 0, 0, 0, 0]  549.96 ± 0   547 ± 0  0.0148189 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]  54.4685 ± 0    49 ± 0 0.0677362 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]    49 ± 0 0.00580404 ± 0 909.684 ± 0           0 ± 0\n",
      "DFN_AfixI [1, 1, 1, 1, 0, 0, 0, 0, 0, 0] 551.456 ± 0   547 ± 0  0.0375427 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]   58.775 ± 0    49 ± 0  0.183815 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]    49 ± 0 0.00580404 ± 0  838.25 ± 0           0 ± 0\n",
      "     LSET [1, 1, 1, 1, 0, 0, 0, 0, 0, 0] 548.256 ± 0   547 ± 0 0.00144242 ± 0 [1, 0, 1, 0, 1, 0, 0, 0, 0, 1] 0.110238 ± 0    75 ± 0   301.092 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]    49 ± 0 0.00580404 ± 0  497239 ± 0     53.0612 ± 0\n",
      "      MLP [1, 1, 1, 1, 0, 0, 0, 0, 0, 0] 548.961 ± 0   547 ± 0 0.00103017 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]  53.8081 ± 0    49 ± 0   1.48779 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]    49 ± 0 0.00580404 ± 0 920.219 ± 0           0 ± 0\n",
      "MaxAffine [1, 1, 1, 1, 0, 0, 0, 0, 0, 0] 546.694 ± 0   547 ± 0 0.00114371 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]  38.1047 ± 0    49 ± 0 0.0850487 ± 0 [1, 0, 1, 1, 1, 0, 0, 0, 0, 0]    49 ± 0 0.00580404 ± 0 1334.71 ± 0           0 ± 0\n",
      "\n",
      "=== FAILURES / WARNINGS (if any) ===\n",
      " seed model    stage                          error\n",
      "    0  LSET IP_CHECK rel_err=9.985e-01 (tol=0.0001)\n"
     ]
    }
   ],
   "source": [
    "# ===================== ASSIGNMENT DATASET =====================\n",
    "N_SEEDS = 1\n",
    "VARY_DATASET_SEED = False\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "SILENCE_LOCAL_SEARCH = False\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "dataset_type = \"assignment\"\n",
    "dataset_params = dict(\n",
    "    K=1000,\n",
    "    num_nodes=10,\n",
    "    c_min=1,\n",
    "    c_max=1000,\n",
    "    noise_std=0.0,\n",
    "    seed=0,\n",
    ")\n",
    "\n",
    "Xtmp, _, _ = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "in_dim = int(np.asarray(Xtmp).shape[1])\n",
    "print(f\"[ASSIGNMENT] inferred in_dim={in_dim} from Xtmp shape={np.asarray(Xtmp).shape}\")\n",
    "\n",
    "train_base = dict(\n",
    "    epochs=1000,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=1,\n",
    "    plot_points=128,\n",
    "    plot_chunk=128,\n",
    ")\n",
    "\n",
    "# ---- DFN (learnable A) ----\n",
    "dfn_params = dict(\n",
    "    input_dim=in_dim, layer_sizes=[16, 128, 16], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=-2.0\n",
    ")\n",
    "\n",
    "# ---- DFN (fixed A = I) ----\n",
    "L1 = 5\n",
    "LK = 6\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=[L1, 400, LK],\n",
    "    p_list=[1, 1],\n",
    "    seed=0,\n",
    "    alpha=5e-3,\n",
    "    beta=-2.0,\n",
    "    A_fixed=np.eye(in_dim, dtype=np.float32),\n",
    ")\n",
    "\n",
    "# ---- other models ----\n",
    "mlp_params  = dict(in_dim=in_dim, hidden_dims=[128, 128], out_dim=1)\n",
    "maff_params = dict(in_dim=in_dim, n_pieces=1600)\n",
    "lset_params = dict(in_dim=in_dim, n_pieces=1600, T=0.05)\n",
    "\n",
    "lr_map = dict(DFN=1e-1, MLP=1e-3, MaxAffine=1e-3, LSET=1e-3)\n",
    "time_limit = 300\n",
    "\n",
    "# feasible integer box + feasible x0 / sum_eq\n",
    "xmin  = np.full(in_dim, 0, dtype=int)\n",
    "xmax  = np.full(in_dim, 1, dtype=int)\n",
    "x0    = np.array([1, 1, 1, 1] + [0] * (in_dim - 4), 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",
    ")\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "92dbc0ee-bbe1-4fdd-8782-44ece09dda4b",
   "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
}
