{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "f5b14808",
   "metadata": {},
   "source": [
    "# DFN"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2efb5921",
   "metadata": {},
   "source": [
    "## Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ce8269a4",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "from __future__ import annotations\n",
    "\n",
    "import cppimport\n",
    "\n",
    "import sys, time, math, io, contextlib\n",
    "from pathlib import Path\n",
    "from typing import Optional, List, Tuple, Dict, Any\n",
    "\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from IPython.display import display\n",
    "\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "_TOL = 1e-9"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "417583e0",
   "metadata": {},
   "source": [
    "## LEMON"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "62767112",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "repo = Path().resolve().parent\n",
    "if str(repo) not in sys.path:\n",
    "    sys.path.insert(0, str(repo))\n",
    "\n",
    "lemon_mcf = cppimport.imp(\"lemon_mcf\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "15e6bd1b",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "88381d28",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'status': 1, 'flow': array([1., 2., 0.]), 'potential': array([-2.,  0., -1.]), 'reduced_cost': array([0., 0., 4.]), 'at_capacity': array([False,  True, False]), 'total_cost': 4.0}\n",
      "{'value': 4.0, 'flow': array([2., 2., 2., 2.])}\n"
     ]
    }
   ],
   "source": [
    "n = 3\n",
    "src    = np.array([0, 0, 1], dtype=np.int64)\n",
    "dst    = np.array([1, 2, 2], dtype=np.int64)\n",
    "cost   = np.array([2.0, 1.0, 3.0], dtype=np.float64)\n",
    "cap    = np.array([5.0, 2.0, 4.0], dtype=np.float64)\n",
    "supply = np.array([3.0, -1.0, -2.0], dtype=np.float64)\n",
    "\n",
    "out_min_cost_flow = lemon_mcf.solve_mcf(n, src, dst, cost, cap, supply)\n",
    "print(out_min_cost_flow)\n",
    "\n",
    "n = 4\n",
    "src = np.array([0,0,1,2], dtype=np.int64)\n",
    "dst = np.array([1,2,3,3], dtype=np.int64)\n",
    "cap = np.array([3.0,2.0,2.0,4.0], dtype=np.float64)\n",
    "out_max_flow = lemon_mcf.max_flow(n, src, dst, cap, 0, 3)\n",
    "print(out_max_flow)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "75235271",
   "metadata": {},
   "source": [
    "## Dataset generators"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "67763cc2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def make_mdvsp_dataset(\n",
    "    K: int,\n",
    "    filename: str,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    max_trips=None,\n",
    "    max_succ=None,\n",
    "):\n",
    "    \"\"\"Multiple-Depot Vehicle Scheduling (MDVSP) dataset.\n",
    "\n",
    "    Returns:\n",
    "      X: (K, m) integer-ish capacities (float32)\n",
    "      y: (K,) min-cost-flow objective values (float32)\n",
    "      gt: dict containing the fixed network pieces (for later evaluation)\n",
    "    \"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "\n",
    "    with open(filename) as f:\n",
    "        m, n, l = map(int, f.readline().split())\n",
    "        f.readline()  # blank line\n",
    "        trips = np.loadtxt(f, max_rows=n, dtype=np.int64)[:max_trips]\n",
    "        D = np.loadtxt(f, max_rows=l, dtype=np.int64)\n",
    "\n",
    "    p, s, q, e = trips.T\n",
    "    ntr = len(trips)\n",
    "\n",
    "    # node ids\n",
    "    SS = 0\n",
    "    depS = 1 + np.arange(m)\n",
    "    depT = 1 + m + np.arange(m)\n",
    "    trS  = 1 + 2*m + np.arange(ntr)\n",
    "    trT  = 1 + 2*m + ntr + np.arange(ntr)\n",
    "    TT = 1 + 2*m + 2*ntr\n",
    "    N = TT + 1\n",
    "\n",
    "    src, dst, cost, cap = [], [], [], []\n",
    "\n",
    "    # depot boundary arcs (capacity is what we learn/provide per sample)\n",
    "    for d in range(m):\n",
    "        src += [SS, int(depT[d])]\n",
    "        dst += [int(depS[d]), TT]\n",
    "        cost += [0.0, 0.0]\n",
    "        cap  += [0.0, 0.0]\n",
    "    idxSS = np.arange(0, 2*m, 2)  # arcs SS->depS\n",
    "    idxTT = np.arange(1, 2*m, 2)  # arcs depT->TT\n",
    "\n",
    "    # trip arcs (always cap=1)\n",
    "    src += trS.tolist()\n",
    "    dst += trT.tolist()\n",
    "    cost += [0.0] * ntr\n",
    "    cap  += [1.0] * ntr\n",
    "\n",
    "    # depot-to-trip and trip-to-depot arcs\n",
    "    for d in range(m):\n",
    "        # depS -> trS\n",
    "        src += [int(depS[d])] * ntr\n",
    "        dst += trS.tolist()\n",
    "        cost += (5000 + 10 * D[d, p]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "        # trT -> depT\n",
    "        src += trT.tolist()\n",
    "        dst += [int(depT[d])] * ntr\n",
    "        cost += (5000 + 10 * D[q, d]).astype(float).tolist()\n",
    "        cap  += [1.0] * ntr\n",
    "\n",
    "    # feasible trip successor arcs (trT -> next trS)\n",
    "    order = np.argsort(s)\n",
    "    p2, s2 = p[order], s[order]\n",
    "    max_succ_eff = ntr if max_succ is None else int(max_succ)\n",
    "\n",
    "    for i in range(ntr):\n",
    "        travel = D[q[i], p2]                          # time from trip i end depot -> next trip start depot\n",
    "        feas = np.flatnonzero(s2 >= e[i] + travel)[:max_succ_eff]\n",
    "        j = order[feas]\n",
    "        if j.size:\n",
    "            src += [int(trT[i])] * j.size\n",
    "            dst += trS[j].tolist()\n",
    "            cost += (8 * travel[feas] + 2 * (s[j] - e[i])).astype(float).tolist()\n",
    "            cap  += [1.0] * j.size\n",
    "\n",
    "    src = np.asarray(src, dtype=np.int64)\n",
    "    dst = np.asarray(dst, dtype=np.int64)\n",
    "    cost = np.asarray(cost, dtype=np.float64)\n",
    "    cap0 = np.asarray(cap, dtype=np.float64)\n",
    "\n",
    "    # sample capacities X and compute y via max-flow + min-cost-flow\n",
    "    X = rng.integers(x_min, np.asarray(x_max) + 1, size=(K, m)).astype(np.float64)\n",
    "    y = np.empty(K, dtype=np.float64)\n",
    "\n",
    "    for k in range(K):\n",
    "        cap_k = cap0.copy()\n",
    "        cap_k[idxSS] = X[k]\n",
    "        cap_k[idxTT] = X[k]\n",
    "\n",
    "        Fmax = lemon_mcf.max_flow(N, src, dst, cap_k, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, dtype=np.float64)\n",
    "        supply[SS] = Fmax\n",
    "        supply[TT] = -Fmax\n",
    "\n",
    "        y[k] = lemon_mcf.solve_mcf(N, src, dst, cost, cap_k, supply)[\"total_cost\"]\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = dict(\n",
    "        type=\"mdvsp\", N=int(N), SS=int(SS), TT=int(TT),\n",
    "        src=src, dst=dst, cost=cost, cap0=cap0, idxSS=idxSS, idxTT=idxTT\n",
    "    )\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n",
    "\n",
    "\n",
    "def generate_bipartite_subset_matching_dataset(\n",
    "    K: int, num_nodes: int, c_min: int, c_max: int, noise_std: float = 0.0, seed: int = 0\n",
    "):\n",
    "    \"\"\"Assignment-style dataset: choose a subset of left nodes, match to right nodes with min cost.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    C = rng.integers(c_min, c_max + 1, size=(num_nodes, num_nodes)).astype(np.float32)\n",
    "\n",
    "    X = np.zeros((K, num_nodes), dtype=np.float32)\n",
    "    y = np.zeros((K,), dtype=np.float32)\n",
    "\n",
    "    for k in range(K):\n",
    "        mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        while not mask.any():\n",
    "            mask = rng.integers(0, 2, size=num_nodes, dtype=np.int8)\n",
    "        idx = np.flatnonzero(mask)\n",
    "        X[k, idx] = 1.0\n",
    "\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        y[k] = C[idx, :][r, c].sum()\n",
    "        if noise_std:\n",
    "            y[k] += noise_std * rng.normal()\n",
    "\n",
    "    gt = {\"type\": \"assignment\", \"C\": C.astype(np.float32)}\n",
    "    return X, y, gt\n",
    "\n",
    "\n",
    "def generate_convex_quadratic_dataset(\n",
    "    K: int,\n",
    "    dim: int,\n",
    "    eigen_min: float,\n",
    "    eigen_max: float,\n",
    "    x_min,\n",
    "    x_max,\n",
    "    noise_std: float = 0.0,\n",
    "    seed: int = 0,\n",
    "    x_star_zero: bool = False,\n",
    "):\n",
    "    \"\"\"y = (x - x*)^T Q (x - x*) + noise, with Q symmetric PSD.\"\"\"\n",
    "    rng = np.random.default_rng(seed)\n",
    "    U, R = np.linalg.qr(rng.standard_normal((dim, dim)))\n",
    "    U *= np.sign(np.diag(R) + 1e-12)\n",
    "    Q = U @ np.diag(rng.uniform(eigen_min, eigen_max, dim)) @ U.T\n",
    "\n",
    "    x_star = np.zeros(dim, dtype=np.int64) if x_star_zero else rng.integers(x_min, x_max + 1, size=dim)\n",
    "\n",
    "    X = rng.integers(x_min, x_max + 1, size=(K, dim)).astype(np.float32)\n",
    "    d = X - x_star\n",
    "    y = np.einsum(\"bi,ij,bj->b\", d, Q, d) + noise_std * rng.normal(size=K)\n",
    "\n",
    "    gt = {\"type\": \"quadratic\", \"Q\": Q.astype(np.float32), \"x_star\": x_star.astype(np.int64)}\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1dfc62e4",
   "metadata": {},
   "source": [
    "### Quick sanity checks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "89201b4a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 8) (50,) \n",
      " [[ 5.  5.  8. 10.  0.  1.  9. 10.]\n",
      " [ 2.  3.  9.  4.  3.  9.  2.  4.]\n",
      " [ 7.  6.  0.  0.  9.  8.  9.  5.]\n",
      " [ 8.  3.  4.  8.  1.  3.  1.  4.]\n",
      " [10.  1.  4.  4.  9.  2.  5.  2.]] \n",
      " [490251.12 366100.16 447590.56 326038.94 376371.84] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[0. 1. 1. 0. 0. 0. 0. 1. 0. 1.]\n",
      " [1. 0. 0. 0. 0. 0. 1. 1. 0. 0.]\n",
      " [0. 1. 0. 0. 1. 0. 1. 0. 1. 1.]\n",
      " [1. 1. 0. 0. 1. 1. 1. 1. 0. 1.]\n",
      " [0. 1. 0. 1. 1. 0. 0. 0. 1. 0.]] \n",
      " [ 9.  4. 13. 17. 11.] \n",
      "\n",
      "(50, 10) (50,) \n",
      " [[-47. -87.  -1.  69.  25. -87.  30. -31. -55. -14.]\n",
      " [ 75.  94. -72.  13.  53. -48. -46. -52. -58.  78.]\n",
      " [-57. -55. -75. -75.  56. -43.  61.  17.  72.  11.]\n",
      " [ 53.  62. -88.  12.  -9. -43. -10. -18.  -2.  64.]\n",
      " [ 65.  25.  42.  92.  28. -26. -84.  11. -54.  19.]] \n",
      " [1.5913905e+06 9.7035825e+05 7.8526031e+05 5.9535256e+05 1.0773938e+06] \n",
      "\n"
     ]
    }
   ],
   "source": [
    "# NOTE: MDVSP requires that `filename` exists on disk.\n",
    "X, y, _ = make_mdvsp_dataset(\n",
    "    K=50, filename=\"RN-8-3000-03.dat\", x_min=0, x_max=10, noise_std=1.0, seed=1, max_trips=200, max_succ=5\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_bipartite_subset_matching_dataset(\n",
    "    K=50, num_nodes=10, c_min=1, c_max=10, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")\n",
    "\n",
    "X, y, _ = generate_convex_quadratic_dataset(\n",
    "    K=50, dim=10, eigen_min=1.0, eigen_max=20.0, x_min=-100, x_max=100, noise_std=0.0, seed=0\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "70071f5f",
   "metadata": {},
   "source": [
    "## Models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "07278db8",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _ste_round(x: torch.Tensor) -> torch.Tensor:\n",
    "    return x + (torch.round(x) - x).detach()\n",
    "\n",
    "class _MCFValue(torch.autograd.Function):\n",
    "    \n",
    "    @staticmethod\n",
    "    def forward(ctx, n_nodes, src, dst, cost, cap, supply):\n",
    "        n = int(n_nodes)\n",
    "\n",
    "        src = src.to(dtype=torch.int64).contiguous()\n",
    "        dst = dst.to(dtype=torch.int64).contiguous()\n",
    "\n",
    "        m = int(src.numel())\n",
    "        if (dst.numel() != m) or (cost.numel() != m) or (cap.numel() != m) or (supply.numel() != n):\n",
    "            raise ValueError(\"Bad shapes for MCF inputs.\")\n",
    "        if torch.abs(supply.double().sum()) > _TOL:\n",
    "            raise ValueError(\"Require sum(supply)=0\")\n",
    "\n",
    "        def as_np(t: torch.Tensor, dtype):\n",
    "            return t.detach().cpu().contiguous().view(-1).numpy().astype(dtype, copy=False)\n",
    "\n",
    "        out = lemon_mcf.solve_mcf(\n",
    "            n,\n",
    "            as_np(src, np.int64),\n",
    "            as_np(dst, np.int64),\n",
    "            as_np(cost, np.float64),\n",
    "            as_np(cap, np.float64),\n",
    "            as_np(supply, np.float64),\n",
    "            tol=_TOL,\n",
    "        )\n",
    "        if out[\"status\"] != 1:\n",
    "            raise RuntimeError(f\"LEMON failed (status={out['status']})\")\n",
    "\n",
    "        flow = out[\"flow\"]\n",
    "        pot = out[\"potential\"]\n",
    "        red = out[\"reduced_cost\"]\n",
    "        at = out.get(\"at_cap\", out.get(\"at_capacity\", None))\n",
    "        if at is None:\n",
    "            at = np.abs(flow - as_np(cap, np.float64)) <= _TOL\n",
    "\n",
    "        ctx.flow, ctx.pot, ctx.red, ctx.at = flow, pot, red, at\n",
    "        return cost.new_tensor(float(out[\"total_cost\"]))\n",
    "\n",
    "    @staticmethod\n",
    "    def backward(ctx, g):\n",
    "        dev, dt = g.device, g.dtype\n",
    "        flow = torch.as_tensor(ctx.flow, device=dev, dtype=dt)\n",
    "        pot  = torch.as_tensor(ctx.pot,  device=dev, dtype=dt)\n",
    "        red  = torch.as_tensor(ctx.red,  device=dev, dtype=dt)\n",
    "        at   = torch.as_tensor(ctx.at,   device=dev, dtype=torch.bool)\n",
    "\n",
    "        grad_cost = flow\n",
    "        grad_cap  = torch.where(at, red, torch.zeros_like(red))\n",
    "        grad_sup  = pot.mean() - pot\n",
    "\n",
    "        return None, None, None, grad_cost * g, grad_cap * g, grad_sup * g\n",
    "\n",
    "\n",
    "class DFN(nn.Module):\n",
    "    def __init__(\n",
    "        self,\n",
    "        input_dim: int,\n",
    "        layer_sizes,\n",
    "        p_list,\n",
    "        big_cost: float = 1e6,\n",
    "        big_cap: float = 1e6,\n",
    "        seed: int = 0,\n",
    "        A_fixed=None,\n",
    "        alpha: float = 1e-6,\n",
    "        beta: float = -0.0,\n",
    "    ):\n",
    "        super().__init__()\n",
    "        self.alpha = float(alpha)\n",
    "        self.beta  = float(beta)\n",
    "\n",
    "        layer_sizes = list(map(int, layer_sizes))\n",
    "        if len(layer_sizes) < 2 or len(p_list) != len(layer_sizes) - 1:\n",
    "            raise ValueError(\"Need len(layer_sizes)>=2 and len(p_list)=len(layer_sizes)-1\")\n",
    "\n",
    "        self.n = int(sum(layer_sizes))\n",
    "        if self.n <= 0:\n",
    "            raise ValueError(\"sum(layer_sizes) must be > 0\")\n",
    "\n",
    "        # node indices per layer\n",
    "        layers, off = [], 0\n",
    "        for s in layer_sizes:\n",
    "            layers.append(torch.arange(off, off + s, dtype=torch.long))\n",
    "            off += s\n",
    "\n",
    "        L1, LK = layers[0], layers[-1]\n",
    "        if L1.numel() == 0 or LK.numel() == 0:\n",
    "            raise ValueError(\"First/last layer must be non-empty.\")\n",
    "\n",
    "        self.fix_node = int(LK[-1].item())\n",
    "        boundary = torch.cat([L1, LK[:-1]], 0)\n",
    "        self.register_buffer(\"boundary\", boundary)\n",
    "\n",
    "        gen = torch.Generator().manual_seed(int(seed))\n",
    "\n",
    "        def bipartite(U: torch.Tensor, V: torch.Tensor):\n",
    "            su, sv = int(U.numel()), int(V.numel())\n",
    "            return U.repeat_interleave(sv), V.repeat(su)\n",
    "\n",
    "        def sample_edges(U, V, p: float):\n",
    "            s, t = bipartite(U, V)\n",
    "            if p < 1.0:\n",
    "                keep = torch.rand(s.numel(), generator=gen) < float(p)\n",
    "                s, t = s[keep], t[keep]\n",
    "            return s, t\n",
    "\n",
    "        # learnable arcs between consecutive layers (both directions)\n",
    "        sf, tf, sb, tb = [], [], [], []\n",
    "        for i, p in enumerate(map(float, p_list)):\n",
    "            if not (0.0 <= p <= 1.0):\n",
    "                raise ValueError(\"p_list entries must be in [0,1]\")\n",
    "\n",
    "            s, t = sample_edges(layers[i], layers[i + 1], p)  # forward\n",
    "            sf.append(s); tf.append(t)\n",
    "\n",
    "            s, t = sample_edges(layers[i + 1], layers[i], p)  # backward\n",
    "            sb.append(s); tb.append(t)\n",
    "\n",
    "        src_param = torch.cat([torch.cat(sf, 0), torch.cat(sb, 0)], 0)\n",
    "        dst_param = torch.cat([torch.cat(tf, 0), torch.cat(tb, 0)], 0)\n",
    "        if src_param.numel() == 0:\n",
    "            raise ValueError(\"No learnable arcs (increase p_list / layer sizes).\")\n",
    "\n",
    "        s1, t1 = bipartite(L1, LK)\n",
    "        s2, t2 = bipartite(LK, L1)\n",
    "        src_fixed = torch.cat([s1, s2], 0)\n",
    "        dst_fixed = torch.cat([t1, t2], 0)\n",
    "        m_fixed = int(src_fixed.numel())\n",
    "\n",
    "        self.register_buffer(\"src\", torch.cat([src_param, src_fixed], 0))\n",
    "        self.register_buffer(\"dst\", torch.cat([dst_param, dst_fixed], 0))\n",
    "        self.register_buffer(\"cap_fixed\",  torch.full((m_fixed,), float(big_cap),  dtype=torch.float32))\n",
    "        self.register_buffer(\"cost_fixed\", torch.full((m_fixed,), float(big_cost), dtype=torch.float32))\n",
    "\n",
    "        nb = int(boundary.numel())\n",
    "        input_dim = int(input_dim)\n",
    "\n",
    "        m_param = int(src_param.numel())\n",
    "        self.cap_raw  = nn.Parameter(torch.zeros(m_param) + 0.542)\n",
    "        self.cost_raw = nn.Parameter(torch.randn(m_param) + 1.0)\n",
    "        self.b_raw    = nn.Parameter(torch.zeros(nb))\n",
    "\n",
    "        if A_fixed is None:\n",
    "            A = torch.zeros(nb, input_dim)\n",
    "            rows = torch.arange(nb)\n",
    "            A[rows, rows % input_dim] = 1.0\n",
    "            self.A = nn.Parameter(A)\n",
    "        else:\n",
    "            A_fixed = torch.as_tensor(A_fixed, dtype=torch.float32)\n",
    "            if A_fixed.shape != (nb, input_dim):\n",
    "                raise ValueError(f\"A_fixed must have shape {(nb, input_dim)}, got {tuple(A_fixed.shape)}\")\n",
    "            self.register_buffer(\"A\", A_fixed)\n",
    "\n",
    "    def forward(self, w: torch.Tensor) -> torch.Tensor:\n",
    "        capP  = _ste_round(F.softplus(self.cap_raw))\n",
    "        costP = self.cost_raw\n",
    "        b     = _ste_round(self.b_raw)\n",
    "        A     = _ste_round(self.A) if isinstance(self.A, nn.Parameter) else self.A\n",
    "\n",
    "        cap  = torch.cat([capP,  self.cap_fixed.to(w.device, w.dtype)], 0)\n",
    "        cost = torch.cat([costP, self.cost_fixed.to(w.device, w.dtype)], 0)\n",
    "\n",
    "        def one(w1: torch.Tensor) -> torch.Tensor:\n",
    "            supply = torch.zeros(self.n, device=w1.device, dtype=torch.float64)\n",
    "            supply[self.boundary] = (A.double() @ w1.double()) + b.double()\n",
    "            supply[self.fix_node] = -supply.sum()\n",
    "            return _MCFValue.apply(self.n, self.src, self.dst, cost, cap, supply)\n",
    "\n",
    "        out = one(w) if w.dim() == 1 else torch.stack([one(wi) for wi in w], 0)\n",
    "        return self.alpha * out + self.beta\n",
    "\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, in_dim, hidden_dims, out_dim):\n",
    "        super().__init__()\n",
    "        dims = [in_dim] + list(hidden_dims) + [out_dim]\n",
    "        layers = []\n",
    "        for a, b in zip(dims[:-2], dims[1:-1]):\n",
    "            layers += [nn.Linear(a, b), nn.ReLU()]\n",
    "        layers += [nn.Linear(dims[-2], dims[-1])]\n",
    "        self.net = nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, x):\n",
    "        return self.net(x)\n",
    "\n",
    "\n",
    "class MaxAffine(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int):\n",
    "        super().__init__()\n",
    "        self.W = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        return (x @ self.W.T + self.b).max(dim=1).values\n",
    "\n",
    "\n",
    "class LSET(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int, T: float = 0.01):\n",
    "        super().__init__()\n",
    "        self.T = float(T)\n",
    "        if self.T == 0.0:\n",
    "            raise ValueError(\"T must be nonzero\")\n",
    "        self.A = nn.Parameter(torch.randn(n_pieces, in_dim) / (in_dim**0.5))\n",
    "        self.b = nn.Parameter(torch.zeros(n_pieces))\n",
    "\n",
    "    def forward(self, x: torch.Tensor) -> torch.Tensor:\n",
    "        z = (x @ self.A.t() + self.b) / self.T\n",
    "        return self.T * torch.logsumexp(z, dim=-1)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7cca0120",
   "metadata": {},
   "source": [
    "## Training Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "0a7db872",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _split_train_val_test(X: torch.Tensor, y: torch.Tensor, *, val_frac: float, test_frac: float, seed: int):\n",
    "    N = int(X.shape[0])\n",
    "    n_test = int(round(test_frac * N))\n",
    "    n_val  = int(round(val_frac  * N))\n",
    "    n_train = N - n_val - n_test\n",
    "    if n_train <= 0:\n",
    "        raise ValueError(\"splits too large; train set would be empty\")\n",
    "\n",
    "    g = torch.Generator().manual_seed(int(seed))\n",
    "    perm = torch.randperm(N, generator=g)\n",
    "    i_tr = perm[:n_train]\n",
    "    i_va = perm[n_train:n_train + n_val]\n",
    "    i_te = perm[n_train + n_val:]\n",
    "\n",
    "    return (X[i_tr], y[i_tr]), (X[i_va], y[i_va]), (X[i_te], y[i_te])\n",
    "\n",
    "\n",
    "def _fit_standardizer(Xtr: torch.Tensor, ytr: torch.Tensor, *, eps: float):\n",
    "    x_mean = Xtr.mean(0, keepdim=True)\n",
    "    x_std  = Xtr.std(0, unbiased=False, keepdim=True)\n",
    "    x_std  = torch.where(x_std < eps, torch.ones_like(x_std), x_std)\n",
    "\n",
    "    y_mean = ytr.mean()\n",
    "    y_std  = ytr.std(unbiased=False).clamp_min(eps)\n",
    "\n",
    "    return {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std}\n",
    "\n",
    "\n",
    "def _apply_standardizer(X: torch.Tensor, y: torch.Tensor, scaler):\n",
    "    Xn = (X - scaler[\"x_mean\"]) / scaler[\"x_std\"]\n",
    "    yn = (y - scaler[\"y_mean\"]) / scaler[\"y_std\"]\n",
    "    return Xn, yn\n",
    "\n",
    "@torch.no_grad()\n",
    "def _mse_norm(model: nn.Module, loader: DataLoader, device: str):\n",
    "    model.eval()\n",
    "    tot, n = 0.0, 0\n",
    "    for xb, yb in loader:\n",
    "        xb, yb = xb.to(device), yb.to(device)\n",
    "        pred = model(xb).squeeze(-1)\n",
    "        tot += F.mse_loss(pred, yb, reduction=\"sum\").item()\n",
    "        n += yb.numel()\n",
    "    return tot / max(n, 1)\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def _predict_in_chunks(model: nn.Module, X: torch.Tensor, *, chunk: int):\n",
    "    out = []\n",
    "    for i in range(0, int(X.shape[0]), int(chunk)):\n",
    "        out.append(model(X[i:i + chunk]).squeeze(-1))\n",
    "    return torch.cat(out, 0)\n",
    "\n",
    "\n",
    "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": "813038a0-30b4-4138-b56a-397a9bc381a9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[MDVSP] inferred in_dim=8 from Xtmp shape=(1000, 8)\n",
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(1000, 8)  mean(mean)=24.9  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(1000,)  mean=2.02e+06  std=4.05e+05  min=8.91e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=8\n",
      "  model: params=16,663 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA1m1JREFUeJzsnQd8E/X7xz+X0RZKB1D2XrI3KOIAREFQVETFPVERVBQnbv2ruAV/Cm5xoch0oYAgS0T23rNsKJTuNuv+r+ebXnJJLsmlTZo2fd6v1zW5/c3d9e4+32dJsizLYBiGYRiGYRiGYRgm7BjCv0mGYRiGYRiGYRiGYVh0MwzDMAzDMAzDMEwEYUs3wzAMwzAMwzAMw0QIFt0MwzAMwzAMwzAMEyFYdDMMwzAMwzAMwzBMhGDRzTAMwzAMwzAMwzARgkU3wzAMwzAMwzAMw0QIFt0MwzAMwzAMwzAMEyFYdDMMwzAMwzAMwzBMhGDRHQJTpkyBJEl+h8WLFyOaHDhwQLTjnXfeKfE2nnvuOVx55ZVo0KCB2Nadd97pd9l9+/bh2muvRWpqKqpVq4bLLrsM69at01z2xx9/RJcuXZCQkID69evjkUceQW5urs9yNI3m0TK0LK1D6/rjl19+gclkwqlTp8T4hAkTRJuaNWsm2t+3b1+/6548eVL8vrS0NFStWhXnn38+Fi5cqLnsX3/9JebTcrQ8rUfre2O1WvHyyy+jadOmiI+PR5s2bfC///0PeqH1XnrpJUTr2qZrSM9y/q53WZbRsmVLzWN/+vRpjBs3Du3atUNiYiJSUlLE8bntttuwadOmMv0/++abb3DjjTeidevWMBgM4riHCp1Xaj+dZ7re6LzT+Q/2/0W/oUOHDj7z6Hhp/d7LL78ckUDPNX3o0CEMHToUzZs3d52zrl274sMPP4TNZtO9r1deeUWcd4fDgYrI888/j27dulXY9jNMRYfuQ1WqVMHZs2f9LnPLLbfAbDbjxIkTurdL99hoPHOD8frrr2POnDk+07dt2ybaG+xZHQnouVmrVi3k5OSU2T4PHz4s3gn79Okj3jXpfNE7gjfZ2dl47bXXxHO0bt264p20Y8eOePPNN1FYWOiz/J49e8S7R+PGjcV11aJFC4wdO1a8p6ihZa655pqI/kamEiEzuvnqq69kOmT0+e+///oMWVlZUT2a+/fvF+17++23S7yNqlWryr169ZJHjhwpx8XFyXfccYfmcidPnpTr168vt2/fXp45c6b8+++/yxdeeKGclJQk79ixw2PZ7777TrRrxIgR8qJFi+SPP/5YTklJkS+77DKf7dK01NRUsQwtS+vQut9//71mO26//Xa5X79+rvHWrVvL3bp1k++++265Vq1acp8+fTTXKywslDt06CA3bNhQtG/+/Pny1VdfLZtMJnnx4sUey9I4Taf5tBwt36BBA7E+bUcNtTc+Pl5+66235L///lt++umnZUmS5Ndee03WQ5MmTeQXX3xRjta1TdeQnuXoPN96660+8+k3K/PVxz4nJ0du2bKlXLduXfndd9+V//rrL/nXX38V3y+44AL566+/LtP/s0svvVScP/oN1C467qHw6quvivM6btw48ZvpfNP/y7333ut3nfXr14tro06dOuL/xhs6Xs2bN/f5vdu3b5fDjd5rmvZN/2NffvmlOGdz586VH3zwQXF+7rnnHl37OnLkiJyYmChPnz5drqicPXtW3JfoODAMU/bQ84LuOx999JHf/9EqVarI11xzTUjbpW1G45kbDLpnar1/0X2U2kzPnbIkLy9PPCNK835ZEuh3pqWliWf2TTfd5Ho38Gbz5s1iuUcffVT++eef5YULF8ovvfSSnJCQIPfv3192OBwe7681a9aUmzVrJk+ZMkW8a9K7SLVq1eQuXbrIdrvdteyePXvEs5K2xzClhUV3CChiYPXq1XJ5JByiW32z8XfTJ5544gnZbDbLBw4ccE0jMUQ3vRtuuME1zWazyfXq1ZMHDBjgsT6JaGorvcQrkHCnaVOnTvUR4iTwaVtqLBaLeBH+8MMPNdtPwsaf6KYHN+1rxYoVrmlWq1Vu166dfO6553os27NnTzGd5iv8888/Yv1Jkya5pm3ZskUIsddff91jfRJi9DJw+vRpOVZEN3Uu0G/yFsAkYs8//3yfY09ihdajh5sW6vNWFv9n6v1dccUVIYnujIwM8SC/7777PKZTxwqd/61bt/qsQ9cOPcwffvhhcVz8iW6t6ZFA7zXtD/ofpxcR704nLZ588knxsqY+5mX5ohguqLPhnHPO8Xh5YximbKDnP70HdO/eXXP+5MmTxf2LxHkosOjWd6+k5wI99zIzM+WyRP3coHcCf6I7NzdXDN7Q+zCts2zZMte0zz77TEyjjmQ19O5G09etW+cx/corr9Q0EjFMqLB7eYQgF5gHH3wQn3zyCc455xzhgkrulVqu0lu2bMHVV1+N6tWru1yqv/76a5/lyK3qscceE66etL3atWtj8ODB2LFjh8+y7733nnB5JRcbciFduXKlrnaTq60eZs+ejUsuuQRNmjRxTUtOThau3b/++qvL9ZT2e+zYMdx1110e619//fWibbQd9TZpGs1TQ+sePXoU//33n8d0cgXPysoSbmclaT+5FtOxUSA39VtvvRWrVq3CkSNHxDT6XL16tXAxovkKvXv3FudV3X5yBaNnuPdvpfGCggL8+eefCAfkQk/XF7lHefPUU08hLi4OGRkZYnzBggXi2mrYsKG4tsj1+/7773fNLyk33XST+Pzhhx9c0+hczJw5E3fffbfP8orLVr169TS3p/e8hYvS7I/OI7mraZ1nOv9aLoFvvPEGzpw5I9zfwsHx48fFeaTzSudbcW/X4/IdyjXtD3IxpGNoNBoDLmexWPDFF1/g5ptv9jjm6lAYPfcqCiNRXOGTkpJEKMu///7rsQy5XNI2KcTluuuuE/dTchkkKHyAwmZ+++034R5P7oRt27YV4wS5K9I4udCfe+65WLNmjU8b6Hjt2rULf//9d9DjwzBMeKF7zR133IG1a9di8+bNPvO/+uor8XwZNGiQCDcbNWqUeOei+wq9K9H7yrJly0q8/8mTJ6Nz585ie3QPotCiZ555xufeet9996FRo0bivkxhcnQvUtzd6blB73D0jkehOjVq1BD3tZ9//tljO3Qfy8vLE++BSpgRuU3TfUp5P+rXr59rntrdmsKG+vfvL97H6H55wQUX+ITNBbpXBvr9Q4YMES7eWu+63377rbiH0j7pOCn31rJ6VtO9mwZv6H6uhEopUAgCQedAjfLb6F3J+95Px3Xv3r0l+AUM44ZFdwmw2+3i5VY90DStF8UPPvhAxDPOmDFDCFQSK/RdYefOneJld+vWrWLZWbNmiQcFxVe+9dZbruUohubCCy8UIp5e7knYfvzxx+IlmUStmo8++kiILRJn33//vbh5kzgnURQOSEDSzadTp04+82gazad4b6VDQZmuhm569NBS5ivL0k1bLQTU66qXJUjg0QOLHmyhQtvy136Czkeg9ivTvNtPYoTiifS0v6RQxwA90L3jmuga/O6778SDkWJ0CTpPdIzogTl//ny8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MOgmIiIiIiIi8hEG3S688sorSEtLQ0REBFq2bImvv/4aoWz27Nlo3bo1YmJikJSUhH79+uHgwYN2+4gSAdOnT5cTxEdGRqJz587Yt2+f3T65ubl46KGHkJiYiKioKPzpT3/CqVOnEErtqNPpMGnSJNs2tptjp0+fxtChQ1GpUiVUqFABzZo1w/bt29luLhQUFOCpp56S713iNZieno6ZM2fCYrGw3YrYuHEjbr/9dvl+JV6Tq1evtrtfq9flxYsXce+998p5PMUibv/+++8evFsQuXfs2DGMHDnS9pqvXbu2LACbl5fH5nNj1qxZaN++vfx8qVixItvLCX4f1vazhUoWYwQ6Bt1OrFy5UgZFU6dOxc6dO9GxY0f07t0bJ06cQKj66quvMG7cOGzZsgXr1q2TX+579OiBK1eu2PaZM2cO5s+fj5dffhlbt25FcnIyunfvjkuXLtn2Ee364YcfYsWKFfjmm29w+fJl3HbbbTCbzQh2ok2WLVuGJk2a2G1nuxUnApUOHTogLCwMn332GbKysjBv3jy7L0Zst+Kef/55LFmyRL4G9+/fL9vohRdewMKFC9luRYj3rqZNm8q2ckSr59c999yDXbt2Yc2aNXIRt0XgTaSFAwcOyItqS5culReFXnzxRfke8OSTT7KB3RAXJgYMGICxY8eyrZzg92HtP1uoZDFGwBPVy6m4m266SRkzZozdtszMTGXKlClsrj+cP39eVL5XvvrqK7lusViU5ORk5bnnnrO10fXr15W4uDhlyZIlcv33339XwsLClBUrVtj2OX36tKLX65U1a9YEddteunRJqVOnjrJu3TqlU6dOysSJE+V2tptjjz/+uHLzzTc7bU+2m2N9+/ZV7r//frttd955pzJ06FC2mwvivezDDz/U/PmVlZUlj71lyxbbPps3b5bbDhw44OqUiEpszpw5SlpaGlvQQ8uXL5evbSqO34e1/WyhksUYwYA93U6ufIoUVnGFRU2sb9q0qayuh/i97Oxs+X9CQoL8/+jRo/j555/t2k3MUdipUydbu4l2zc/Pt9tHpN80atQo6NtWXMHr27cvunXrZred7ebYRx99hFatWsleCJFq1Lx5c7z66qtsNzduvvlmrF+/HocOHZLru3fvlj2wffr04fPNC1q9Ljdv3ixTytu0aWPbp23btnJbsL/nUfl+Pls/m4lKit+H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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) = 5.348e-05 @ epoch 711\n",
      "\n",
      "Set parameter Username\n",
      "Set parameter LicenseID to value 2685751\n",
      "Academic license - for non-commercial use only - expires 2026-07-09\n",
      "iter=0  t=0.00s  best_y=1.35742e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "STOP: local minimum. best_y=1.35742e+06 x=[43, 32, 26, 13, 15, 2, 3, 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, 8712 columns and 17517 nonzeros\n",
      "Model fingerprint: 0x98ef0c37\n",
      "Variable types: 8704 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-08, 1e+00]\n",
      "  Objective range  [3e-01, 2e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [3e-01, 1e+02]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 0 rows and 979 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 7733 columns, 15553 nonzeros\n",
      "Variable types: 7725 continuous, 8 integer (0 binary)\n",
      "Found heuristic solution: objective 1355753.6471\n",
      "\n",
      "Root relaxation: objective 1.345776e+06, 139 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 1345776.14    0    4 1355753.65 1345776.14  0.74%     -    0s\n",
      "     0     0 1345784.42    0    3 1355753.65 1345784.42  0.74%     -    0s\n",
      "     0     0 1345789.15    0    3 1355753.65 1345789.15  0.73%     -    0s\n",
      "H    0     0                    1345954.6092 1345789.15  0.01%     -    0s\n",
      "     0     2 1345789.15    0    3 1345954.61 1345789.15  0.01%     -    0s\n",
      "*    3     6               2    1345819.7452 1345789.15  0.00%   2.3    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 1\n",
      "\n",
      "Explored 7 nodes (152 simplex iterations) in 0.05 seconds (0.06 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 1.34582e+06 1.34595e+06 1.35575e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.345819745238e+06, best bound 1.345789307228e+06, gap 0.0023%\n",
      "[CHECK DFN] obj(x_ip)=1.34582e+06  ip_y=1.34582e+06  rel_err=3.538e-09\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(1000, 8)  mean(mean)=24.9  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(1000,)  mean=2.02e+06  std=4.05e+05  min=8.91e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=8\n",
      "  model: params=14,408 layers=[5, 400, 4] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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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.772e-06 @ epoch 928\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35824e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "iter=1  t=0.02s  best_y=1.3582e+06  x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "STOP: local minimum. best_y=1.3582e+06 x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 410 rows, 7248 columns and 14504 nonzeros\n",
      "Model fingerprint: 0x431bf4d8\n",
      "Variable types: 7240 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [7e-02, 1e+00]\n",
      "  Objective range  [9e+00, 2e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [1e+00, 1e+02]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Presolve removed 0 rows and 1398 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 410 rows, 5850 columns, 11707 nonzeros\n",
      "Variable types: 5842 continuous, 8 integer (0 binary)\n",
      "Found heuristic solution: objective 1357670.0382\n",
      "\n",
      "Root relaxation: objective 1.350700e+06, 416 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 1350699.71    0    7 1357670.04 1350699.71  0.51%     -    0s\n",
      "H    0     0                    1353316.1325 1350699.71  0.19%     -    0s\n",
      "H    0     0                    1353097.2059 1350699.71  0.18%     -    0s\n",
      "     0     0 1350709.35    0    7 1353097.21 1350709.35  0.18%     -    0s\n",
      "H    0     0                    1350751.3088 1350709.35  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (416 simplex iterations) in 0.04 seconds (0.06 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 4: 1.35075e+06 1.3531e+06 1.35332e+06 1.35767e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.350751308776e+06, best bound 1.350709346542e+06, gap 0.0031%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=1.35075e+06  ip_y=1.35075e+06  rel_err=4.351e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(1000, 8)  mean(mean)=24.9  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(1000,)  mean=2.02e+06  std=4.05e+05  min=8.91e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MLP ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=8\n",
      "  model: params=17,793 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA9sFJREFUeJzsnQWYG9Xax/9J1uruXipQqtACLQWKU+TiFHdtgULvBT4uzoWLOy3uFylSvEiLVChQd6EtddfdrmaTzPe8k53kzOSMxTabfX990iSTMzNnJrOT8z+veRRFUcAwDMMwDMMwDMMwTNLxJn+TDMMwDMMwDMMwDMOw6GYYhmEYhmEYhmGYFMKWboZhGIZhGIZhGIZJESy6GYZhGIZhGIZhGCZFsOhmGIZhGIZhGIZhmBTBopthGIZhGIZhGIZhUgSLboZhGIZhGIZhGIZJESy6GYZhGIZhGIZhGCZFsOhmGIZhGIZhGIZhmBTBotsFb7/9Njwej+nj119/RXWydu1atR9PPvlk3Nu4++67ceqpp6Jdu3bqti6//HLTtn///TfOOussNG7cGPXr18fxxx+PuXPnStt+9NFH6N+/PwoKCtC2bVvccsstKC4ujmlHy+gzakNtaR1a14yvvvoKOTk52LFjh/r+2WefVfvUpUsXtf/Dhg0zXXf79u3q8TVv3hx169bF4MGD8dNPP0nbTp48Wf2c2lF7Wo/WN1JZWYkHHngAnTt3Rn5+Pvbff3+88MILcAqtd//996O6rm26hpy0M7veFUVBt27dpOd+165duPPOO9GrVy/Uq1cPjRo1Us/PJZdcgoULF6b17+zdd9/F+eefj549e8Lr9arn3Q3Jvs60v12zx0knnYRk4/SaNq6j9Wnnzp2O9/Xggw+q33soFEJN5J577sFBBx1UY/vPMDWdM888E3Xq1MHevXtN21x00UXIzc3Ftm3bHG+X7mXV8Ztrx3//+1988cUXMcuXLl2q9tfutzoV0O9mixYtsG/fvrTtc+PGjeqY8KijjlLHmvR90RjBSFFRER5++GH1t7h169bqmLRPnz547LHHUF5eHtN+1apV6tijY8eO6nW13377YcyYMeo4RYTanHHGGSk9Rqb2wKI7Dt566y38/vvvMQ8alNV0nnnmGfWm849//AN5eXmm7UjkHnHEEfjrr7/w5ptv4uOPP1ZvbHTDW7Fiha7t+++/jwsuuACDBg3Cd999h/vuu0+9aZJoMULL3nnnHbUNtaV1aN0PPvhA2o/PPvsMRx55pPpDQLz88stYt24djjnmmMgyGRUVFTj22GNV8fPcc8/hyy+/RKtWrVRxM2XKFF1bej98+HD1c2pH7Ul80Pq0HZGRI0fikUcewahRo/DDDz+oA4XRo0erP6DZRIMGDfDGG2/ELKdztXr1avVz42TKYYcdpn7vV199tTpZQtfFtddeizVr1mD+/Plp/Tt77733sGTJEhxyyCHqj61bkn2dtWnTRnqsd9xxh/o5XUfJxM01LX6H11xzjToh5obNmzfj8ccfV4U3TXDURP71r3+p1yndmxiGST9XXXWVOsYwGwsUFhbi888/V40GdF+r6ViJbprYT7foLi0txb///W/1N8n4+55KSBzTWIHGoyeffLJpu/Xr16uT4TQ+ePXVV9UxxjnnnKNOUNA1QQYBcfxK45HffvsN//nPfzBx4kR1zPbaa6/huOOO002u0vrffvstfv7555QfK1MLUBjHvPXWW/RXq8yaNSsjz9qaNWvU/j3xxBNxbyMYDEZe16tXT7nsssuk7W677TYlNzdXWbt2bWRZYWGh0rx5c+W8886LLAsEAkqbNm2UE044Qbf++++/r/Z14sSJkWXffvutuuyDDz7QtT3++OOVtm3bqtsS8fv9SuPGjZUXX3xR2v8DDzxQOeqoo6T9Hzt2rLqvGTNmRJZVVlYqvXr1Ug455BBd20GDBqnL6XON3377TV1/3LhxkWWLFy9WPB6P8t///le3/jXXXKPUqVNH2bVrl2JHp06dlPvuu0+prmubriEn7a6++mr1mOg7F7n44ouVwYMHx5z7N998U13v559/lm5X/N7S8Xcm7u+UU05Rz3u86yfrOpMxbNgwpW7dujHnOVGcXtMio0aNUgYMGKDcfffdarsdO3Y42tftt9+utGvXTnfO0kVJSUnStnXjjTcqPXr0UEKhUNK2yTCMM+j3n8YBBx98sPTzl156Sb0vff31165OKa1THb+5dpiNvz755BO1z7/88kta75X0u1BQUKDs2bNHSSfi7waNCejYaYxgpLi4WH0YofEwrTNt2rTIstdee01dNnnyZF1bGrvR8rlz5+qWn3rqqeo4lGESpWaaHWoA5AJz44034pVXXkGPHj1UV2Nyr5S5Si9evBinn346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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) = 5.929e-05 @ epoch 977\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35656e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "STOP: local minimum. best_y=1.35656e+06 x=[43, 32, 26, 13, 15, 2, 3, 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, 777 columns and 19849 nonzeros\n",
      "Model fingerprint: 0x014c38ba\n",
      "Variable types: 513 continuous, 264 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-06, 9e+01]\n",
      "  Objective range  [4e+05, 4e+05]\n",
      "  Bounds range     [5e-01, 9e+01]\n",
      "  RHS range        [1e-03, 1e+02]\n",
      "Presolve removed 281 rows and 22 columns\n",
      "Presolve time: 0.07s\n",
      "Presolved: 1001 rows, 755 columns, 18816 nonzeros\n",
      "Variable types: 499 continuous, 256 integer (248 binary)\n",
      "\n",
      "Root relaxation: objective 7.661702e+05, 444 iterations, 0.01 seconds (0.02 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 766170.165    0  110          - 766170.165      -     -    0s\n",
      "H    0     0                    1352399.7678 766467.371  43.3%     -    0s\n",
      "     0     0 848204.921    0  162 1352399.77 848204.921  37.3%     -    0s\n",
      "     0     0 943312.002    0  155 1352399.77 943312.002  30.2%     -    0s\n",
      "     0     0 943996.203    0  155 1352399.77 943996.203  30.2%     -    0s\n",
      "     0     0 944043.511    0  155 1352399.77 944043.511  30.2%     -    0s\n",
      "     0     0 1013820.98    0  146 1352399.77 1013820.98  25.0%     -    0s\n",
      "     0     0 1017930.70    0  151 1352399.77 1017930.70  24.7%     -    0s\n",
      "     0     0 1022731.89    0  147 1352399.77 1022731.89  24.4%     -    0s\n",
      "     0     0 1023190.01    0  149 1352399.77 1023190.01  24.3%     -    0s\n",
      "     0     0 1023607.27    0  148 1352399.77 1023607.27  24.3%     -    0s\n",
      "     0     0 1023740.34    0  147 1352399.77 1023740.34  24.3%     -    0s\n",
      "     0     0 1023785.67    0  148 1352399.77 1023785.67  24.3%     -    0s\n",
      "     0     0 1086075.62    0  146 1352399.77 1086075.62  19.7%     -    0s\n",
      "     0     0 1089499.73    0  142 1352399.77 1089499.73  19.4%     -    0s\n",
      "     0     0 1089670.75    0  143 1352399.77 1089670.75  19.4%     -    0s\n",
      "     0     0 1089703.55    0  143 1352399.77 1089703.55  19.4%     -    0s\n",
      "     0     0 1116368.41    0  144 1352399.77 1116368.41  17.5%     -    1s\n",
      "     0     0 1120782.13    0  146 1352399.77 1120782.13  17.1%     -    1s\n",
      "     0     0 1120782.13    0  146 1352399.77 1120782.13  17.1%     -    1s\n",
      "     0     0 1126057.79    0  142 1352399.77 1126057.79  16.7%     -    1s\n",
      "     0     0 1126937.96    0  142 1352399.77 1126937.96  16.7%     -    1s\n",
      "     0     0 1126937.96    0  143 1352399.77 1126937.96  16.7%     -    1s\n",
      "     0     0 1147723.66    0  138 1352399.77 1147723.66  15.1%     -    1s\n",
      "     0     0 1148757.33    0  138 1352399.77 1148757.33  15.1%     -    1s\n",
      "     0     0 1148757.33    0  139 1352399.77 1148757.33  15.1%     -    1s\n",
      "     0     0 1169594.77    0  137 1352399.77 1169594.77  13.5%     -    1s\n",
      "     0     0 1173601.96    0  142 1352399.77 1173601.96  13.2%     -    1s\n",
      "     0     0 1174168.72    0  143 1352399.77 1174168.72  13.2%     -    1s\n",
      "     0     0 1174251.01    0  143 1352399.77 1174251.01  13.2%     -    1s\n",
      "     0     0 1183185.64    0  138 1352399.77 1183185.64  12.5%     -    1s\n",
      "     0     0 1184961.21    0  138 1352399.77 1184961.21  12.4%     -    1s\n",
      "     0     0 1185504.88    0  140 1352399.77 1185504.88  12.3%     -    1s\n",
      "     0     0 1185519.05    0  139 1352399.77 1185519.05  12.3%     -    1s\n",
      "H    0     0                    1350573.3305 1185519.05  12.2%     -    1s\n",
      "     0     0 1191411.88    0  138 1350573.33 1191411.88  11.8%     -    1s\n",
      "     0     0 1192130.58    0  140 1350573.33 1192130.58  11.7%     -    1s\n",
      "     0     0 1205452.00    0  135 1350573.33 1205452.00  10.7%     -    1s\n",
      "     0     0 1208434.31    0  135 1350573.33 1208434.31  10.5%     -    1s\n",
      "     0     0 1215234.90    0  135 1350573.33 1215234.90  10.0%     -    1s\n",
      "     0     0 1215675.67    0  137 1350573.33 1215675.67  10.0%     -    1s\n",
      "     0     0 1215754.10    0  137 1350573.33 1215754.10  10.0%     -    1s\n",
      "     0     0 1242878.87    0  124 1350573.33 1242878.87  7.97%     -    2s\n",
      "     0     0 1246848.40    0  133 1350573.33 1246848.40  7.68%     -    2s\n",
      "     0     0 1247103.47    0  135 1350573.33 1247103.47  7.66%     -    2s\n",
      "     0     0 1257299.54    0  131 1350573.33 1257299.54  6.91%     -    2s\n",
      "     0     0 1258144.74    0  128 1350573.33 1258144.74  6.84%     -    2s\n",
      "     0     0 1258591.97    0  132 1350573.33 1258591.97  6.81%     -    2s\n",
      "     0     0 1258663.00    0  131 1350573.33 1258663.00  6.81%     -    2s\n",
      "     0     0 1269353.18    0  130 1350573.33 1269353.18  6.01%     -    2s\n",
      "     0     0 1269951.47    0  132 1350573.33 1269951.47  5.97%     -    2s\n",
      "     0     0 1270157.94    0  131 1350573.33 1270157.94  5.95%     -    2s\n",
      "     0     0 1279488.32    0  125 1350573.33 1279488.32  5.26%     -    2s\n",
      "     0     0 1280410.87    0  126 1350573.33 1280410.87  5.20%     -    2s\n",
      "     0     0 1280647.57    0  129 1350573.33 1280647.57  5.18%     -    2s\n",
      "     0     0 1285756.94    0  124 1350573.33 1285756.94  4.80%     -    2s\n",
      "     0     0 1286011.86    0  126 1350573.33 1286011.86  4.78%     -    2s\n",
      "     0     0 1287998.33    0  131 1350573.33 1287998.33  4.63%     -    2s\n",
      "     0     0 1287998.33    0  131 1350573.33 1287998.33  4.63%     -    2s\n",
      "     0     0 1302545.26    0  121 1350573.33 1302545.26  3.56%     -    2s\n",
      "     0     0 1302545.26    0  128 1350573.33 1302545.26  3.56%     -    2s\n",
      "     0     0 1302545.26    0  127 1350573.33 1302545.26  3.56%     -    2s\n",
      "H    0     0                    1350084.4428 1302545.26  3.52%     -    2s\n",
      "     0     0 1304333.81    0  125 1350084.44 1304333.81  3.39%     -    2s\n",
      "H    0     0                    1350070.0304 1304333.81  3.39%     -    3s\n",
      "H    0     0                    1350058.8805 1304333.81  3.39%     -    3s\n",
      "H    0     0                    1350044.4273 1304333.81  3.39%     -    3s\n",
      "H    0     0                    1349867.2685 1304333.81  3.37%     -    3s\n",
      "     0     0 1315775.23    0  113 1349867.27 1315775.23  2.53%     -    3s\n",
      "     0     0 1315775.23    0   72 1349867.27 1315775.23  2.53%     -    3s\n",
      "     0     0 1315775.23    0  111 1349867.27 1315775.23  2.53%     -    3s\n",
      "     0     0 1316105.08    0  104 1349867.27 1316105.08  2.50%     -    3s\n",
      "     0     0 1316122.87    0  103 1349867.27 1316122.87  2.50%     -    3s\n",
      "     0     0 1316308.28    0  103 1349867.27 1316308.28  2.49%     -    3s\n",
      "     0     0 1319904.62    0  108 1349867.27 1319904.62  2.22%     -    3s\n",
      "     0     0 1320654.49    0  104 1349867.27 1320654.49  2.16%     -    3s\n",
      "     0     0 1320754.66    0  106 1349867.27 1320754.66  2.16%     -    3s\n",
      "     0     0 1320833.49    0  114 1349867.27 1320833.49  2.15%     -    3s\n",
      "     0     0 1323000.99    0   98 1349867.27 1323000.99  1.99%     -    3s\n",
      "     0     0 1323456.40    0   99 1349867.27 1323456.40  1.96%     -    3s\n",
      "     0     0 1323535.74    0  103 1349867.27 1323535.74  1.95%     -    3s\n",
      "     0     0 1324372.85    0  113 1349867.27 1324372.85  1.89%     -    4s\n",
      "     0     0 1324630.17    0  100 1349867.27 1324630.17  1.87%     -    4s\n",
      "     0     0 1324720.36    0  101 1349867.27 1324720.36  1.86%     -    4s\n",
      "     0     0 1324969.81    0   96 1349867.27 1324969.81  1.84%     -    4s\n",
      "     0     0 1325010.36    0   99 1349867.27 1325010.36  1.84%     -    4s\n",
      "     0     0 1325524.82    0   95 1349867.27 1325524.82  1.80%     -    4s\n",
      "H    0     0                    1349804.3172 1325524.82  1.80%     -    4s\n",
      "     0     0 1326300.83    0   88 1349804.32 1326300.83  1.74%     -    4s\n",
      "     0     2 1326300.83    0   88 1349804.32 1326300.83  1.74%     -    4s\n",
      "    32     2     cutoff   11      1349804.32 1337335.95  0.92%  59.4    5s\n",
      "H 1381   306                    1349766.6907 1347906.66  0.14%  10.8    5s\n",
      "* 1509   315              57    1349709.4691 1348119.47  0.12%  10.5    5s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 3\n",
      "  Gomory: 28\n",
      "  Cover: 51\n",
      "  Implied bound: 78\n",
      "  Clique: 3\n",
      "  MIR: 328\n",
      "  StrongCG: 1\n",
      "  Flow cover: 9\n",
      "  Inf proof: 1\n",
      "  RLT: 78\n",
      "  Relax-and-lift: 47\n",
      "  BQP: 18\n",
      "  PSD: 4\n",
      "\n",
      "Explored 3862 nodes (41563 simplex iterations) in 6.34 seconds (9.93 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 1.34971e+06 1.34977e+06 1.3498e+06 ... 1.3524e+06\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.349709469054e+06, best bound 1.349663145275e+06, gap 0.0034%\n",
      "[CHECK MLP] obj(x_ip)=1.34971e+06  ip_y=1.34971e+06  rel_err=2.293e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(1000, 8)  mean(mean)=24.9  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(1000,)  mean=2.02e+06  std=4.05e+05  min=8.91e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MaxAffine ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=8\n",
      "  model: params=14,400 n_pieces=1600\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAArIBJREFUeJzs3Qd4U1UbB/B/d0spZZRN2bPsvbcgoMiWLVsZCogKIu5PZQmCynSA4gBRQEWmbGSVPcpeLbOU0dICnfme94SUJE3SQdKk6f/3PIHk5jY5vUnvve8973mPi0aj0YCIiIiIiIiIrM7V+i9JRERERERERAy6iYiIiIiIiGyIPd1ERERERERENsKgm4iIiIiIiMhGGHQTERERERER2QiDbiIiIiIiIiIbYdBNREREREREZCMMuomIiIiIiIhshEE3ERERERERkY0w6E6HxYsXw8XFxext69atsKdLly6pdnz++ecZfo13330Xzz//PIoWLapea+DAgWbXvXDhArp27YrcuXMjZ86caNOmDQ4ePGhy3aVLl6JGjRrw9vZGkSJFMHbsWERHR6dYT5bJc7KOrCs/Iz9rzl9//QV3d3fcunVLPZ41a5ZqU6lSpVT7W7RoYfZnw8PD1e8XEBCAHDlyoGHDhti0aZPJdf/991/1vKwn68vPyc8bi4+Px0cffYSSJUvCy8sLFStWxFdffYW0kp/78MMPYa/vtnyH0rKeue+7RqNB2bJlTW7727dvY+LEiQgKCoKvry/8/f3V9unfvz+OHj2aaX9n169fV99z+Tzls8yVKxdq166NhQsXIjExMdWfT619U6ZMSV5XtoGldW/cuJG87urVq/HSSy+hatWq8PDwUM/bUlq+07p9iqmbpb9LYx9//LH63JOSkpAVvffee6hVq1aWbT9RVtelSxf4+Pjg3r17Ztfp27ev2nfevHkzza8r+zJ7HHNT89lnn2HVqlUploeEhKj2pnastoUff/wR+fPnx/379zPtPa9cuaLOCZs3b67ONeXzkmOwsaioKHz66afqmFuoUCF1TirH0qlTp+LRo0cp1j937pw69yhevLj6XpUpUwbjxo1T5yn6ZJ3OnTvb9HekbERDabZo0SKNbDL5f/fu3SlukZGRdt2aFy9eVO2bPn16hl8jR44cmgYNGmiGDx+u8fT01AwYMMDkeuHh4ZoiRYpoKleurPnjjz80//zzj6ZJkyYaPz8/zalTpwzW/emnn1S7hg4dqtm8ebNm/vz5Gn9/f02bNm1SvK4sy507t1pH1pWfkZ/9+eefTbbjpZde0rRs2TL5cYUKFTS1atXSDB48WJM/f35N8+bNTf7co0ePNFWqVNEUK1ZMtW/Dhg2aTp06adzd3TVbt241WFcey3J5XtaT9YsWLap+Xl5Hn7TXy8tLM23aNM2WLVs0b7/9tsbFxUXz6aefatKiRIkSmg8++EBjr++2fIfSsp58zv369UvxvPzOuuf1t/39+/c1ZcuW1RQqVEgzY8YMzb///qv5+++/1f3GjRtrfvjhh0z7O5P3DQwM1EyaNEl9b+Uzff311zWurq6aQYMGpfrz8t031S757kq79b//J06cSLHepk2bNB4eHurvTJ98Z8uVK6d58cUXNbVr11avZStp/U7r9imvvfZait8jIiIiTe919epVja+vr2b58uWarOrevXtqv/T999/buylE2ZLst2VfNGfOHLN/oz4+PprOnTun63XlNe1xzE2N7DNNnX/JflTaLMfazBQTE6OOEU9zfpkR8nsGBARonnnmGU3v3r2Tzw2MHTt2TK0nx/I///xTHWc//PBDjbe3t6Z169aapKQkg2N4vnz5NKVKldIsXrxYnWvKuUjOnDk1NWrU0CQmJiave+7cOXWslNcjeloMutNBFwwEBwdrHJE1gm79nY25nb546623VOBw6dKl5GUSDMlOT4IGnYSEBE3hwoU1bdu2Nfh5CaKlrWvWrEleJgGQLPvll18M1pVgRgJ8eS19cXFx6kT466+/Ntl+uSBgLuiWA7e8165du5KXxcfHa4KCgjT16tUzWLdu3bpquTyv899//6mfnzt3bvKy48ePqwD7s88+M/j5YcOGqZOB27dva5wl6JaLC/I7GQfAEog3bNgwxbaXYEV+Tg5upuh/brb+O7tz54767hgbNWqUet/Q0NB0v2Z0dLQ6YMuFp9TIQV7e59tvvzW7DXRtsZW0fqetsU8ZP368OlnT//0y80TRWl599VVN+fLlDU7eiChzyPFfzgPkgqQp8+bNU/sqCc7Tg0F32vaVclyQAPbu3buazKR/3JBzAnNBtxyD5WZMjl3yMzt27Ehe9s0336hlcvFfn5y7yfKDBw8aLH/++edNdhIRpRfTy21EUmBeffVVLFiwAOXLl1ep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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) = 2.403e-05 @ epoch 584\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35833e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "iter=1  t=0.02s  best_y=1.35832e+06  x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "STOP: local minimum. best_y=1.35832e+06 x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 1601 rows, 9 columns and 14408 nonzeros\n",
      "Model fingerprint: 0xb3074556\n",
      "Variable types: 1 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [3e-04, 1e+00]\n",
      "  Objective range  [4e+05, 4e+05]\n",
      "  Bounds range     [5e+01, 5e+01]\n",
      "  RHS range        [4e+00, 1e+02]\n",
      "Presolve time: 0.00s\n",
      "Presolved: 1601 rows, 9 columns, 14408 nonzeros\n",
      "Variable types: 1 continuous, 8 integer (0 binary)\n",
      "Found heuristic solution: objective 1350472.2015\n",
      "\n",
      "Root relaxation: objective 1.349377e+06, 5 iterations, 0.00 seconds (0.00 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "*    0     0               0    1349377.2496 1349377.25  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (5 simplex iterations) in 0.03 seconds (0.03 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 1.34938e+06 1.35047e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.349377249606e+06, best bound 1.349377249606e+06, gap 0.0000%\n",
      "[CHECK MaxAffine] obj(x_ip)=1.34938e+06  ip_y=1.34938e+06  rel_err=2.917e-10\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(1000, 8)  mean(mean)=24.9  std(mean)=14.8  min=0  max=50\n",
      "  y: shape=(1000,)  mean=2.02e+06  std=4.05e+05  min=8.91e+05  max=3.5e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | LSET ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=8\n",
      "  model: params=14,400 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+naQAAy3lJREFUeJzs3Qd4U2XbB/B/0slqGWXPsil7C4IylOEEEXCDgr4KKoqT183nK07EASj6qq8bB+BCEQdboOy9C2UVKKOlha4k33U/6WlPkpM0bdOmSf+/6wolJyfJk5Pk5NznuZ/7MdlsNhuIiIiIiIiIyOfMvn9IIiIiIiIiImLQTURERERERFSC2NNNREREREREVEIYdBMRERERERGVEAbdRERERERERCWEQTcRERERERFRCWHQTURERERERFRCGHQTERERERERlRAG3UREREREREQlhEF3IXzyyScwmUxuL0uWLIE/HTx4ULXj9ddfL/JjPP3007jmmmtQv3599Vhjx451u+6BAwdwww03oGrVqqhcuTKuvPJKbNiwwXDdr7/+Gp06dUJkZCTq1auHhx56CGlpaS7ryTK5TdaRdeU+cl93fvzxR4SGhuLUqVPq+owZM1SbYmNjVfv79evn9r4nT55Ury8mJgYVK1ZEr1698Oeffxqu+8cff6jbZT1ZX+4n93eWnZ2NF154AU2aNEFERARat26Nd955B96S+z3//PPw12dbPkPerOfu826z2dC8eXPDbX/69GlMmTIFcXFxqFSpEqKjo9X2uf3227Fly5ZS/Z6NHz8e7dq1U5/dChUqoGXLlnjssceQnJzs9WMcOnQId911l/qsynst35nhw4e7fG7ke6GtU6tWLQwYMAALFy50ebynnnoKnTt3RvXq1dVnv2nTprjnnnvU85QEbz/TYtu2bRg5ciRq1qypXod8TidMmOD1c02dOlW971arFYHomWeeQZcuXQK2/USBTvatsq8+d+6c23VuvfVWhIWF4cSJE14/rvym+OM3tyAvvfQSFixY4LJ8x44dqr0F/VaXhE8//VT9Bpw/f77UnvPIkSPqmPDyyy9Xv9fyfskxgrPU1FT85z//UccdderUUcek7du3xyuvvIKMjAyX9fft26eOPRo1aqQ+V82aNcPkyZPVcYqerDNs2LASfY1UfjDoLoKPP/4Y//zzj8tFDsoC3Ztvvql2Otdddx3Cw8PdridBbt++fbFnzx589NFH+Oabb9SOTXZ4u3fvdlj3iy++wM0334zu3bvj119/xXPPPad2mhIcO5Nl//vf/9Q6sq7cR+775ZdfGrbj+++/x2WXXaZ+CMR7772nghQJbLRlRjIzMzFw4EAVZL/11lv44YcfULt2bQwZMgRLly51WFeuDx06VN0u68n6ErDI/eVx9CQQmTZtGiZOnIhFixapA4VJkyapH9BgUqVKFfz3v/91WS7bav/+/ep255Mpl1xyiXrfJeCVkyXyuZCgMiEhAZs2bSrV71l6erp6bvlc/fLLL6pNc+bMUT/sWVlZBd5fgtCuXbuqv3KSa/HixZg+fTqqVavmsJ58l9q2bau+V7///jvef/99dVB49dVX4/PPP3dYVw4m5bMun//ffvsNjz76KH7++Wf07NnT5UCguArzmf7777/Ro0cPdVAj3y95Hf/3f/+nTgx449ixY3j11VdV4G02B+ZPjrwX8jmV94aISt+4cePUMYa7Y4GUlBTMnz9fdRrIfi3QeQq65cR+aQfdFy5cwL///W888cQTLr/vJUmCYzlWkOPRq666yu16iYmJqtNFjg/kt1yOMW688UZ1gkI+E9IhoD9+leORlStXqt8yOQkux2wffPABrrjiCoeTq3J/OUb466+/Svy1UjlgI699/PHH8q21xcfHl8mtlpCQoNr32muvFfkxLBZL3v8rVapkGzNmjOF6jz32mC0sLMx28ODBvGUpKSm2mJgY26hRo/KW5eTk2OrWrWsbNGiQw/2/+OIL1daFCxfmLfvll1/Usi+//NJh3SuvvNJWr1499Vh6WVlZtqpVq9reffddw/a3bdvWdvnllxu2f+bMmeq5Vq1albcsOzvbFhcXZ+vRo4fDut27d1fL5XbNypUr1f1nzZqVt2zbtm02k8lke+mllxzuf/fdd9sqVKhgO336tK0gjRs3tj333HM2f3225TPkzXrjx49Xr0nec73bbrvN1qtXL5dt/9FHH6n7/fXXX4aPq3/f/PU9k/dSnvfPP//0uJ7VarV16tRJXTIyMgr9PPK5rV+/vq1v374FrivfD2nTf//7X5svefuZTk9PV9/fq6++Wr3uonj88cfV69W/x6VF2u8r999/v61ly5ZF3g5EVHTy+y/HAV27djW8ffbs2Wr/9dNPPxXqceU+/vjNLYi7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3SQiIiok+d2SObV99bt16NAhDBkyBImJier3cc+ePWjatKk6IS7DtmQqsfKyLYgCSff/LMap81kFrjegdU08MKAF594mCqDfLZ9WL8/KysL69esxaNAgh+VyfdWqVV49hvRuS+OF/JV09lat3J/Fk0BeXqh2kYC7vGgQE42dplj1/xM7Vvq7OUREVAZMmjQJ3bp1w9mzZ1GhQoW85cOHD8eff/7p17YRkXEq+Y2zV3kMuCWNfPqojiqV/KOxPRhwE5XnQmrJycmq8JlzKrhcT0pK8uoxjhw5gnHjxqniaXK5//770aFDB7frT5kyRc096tzTXR5IpsHxynHolLYHFxPWAP1YlZaIqLxbsWIFVq5cifDwcIfljRs3VmO7iajsGPPRGizdk1zgev1a1WKgTRTAQksqGNST4Nl5mTsy3nvTpk1eP1dERIS6zJw5U10k6C9PMmt3AdIWoOIp77cZEREFL5mL2+i3UE5qV6lSxS9tIiLX3u17P1uPE+e9G7vduVE1bkKiAObT9HKpMi6VUZ17tU+ePFnihdAmTpyoirXFx8ejPKnUtKf6W/vCXiA7w9/NISIiP7vyyisxY8aMvOty0jstLQ3PPfccrrrqKr+2jYjs824Pn7XKq4B7Yv9meGJoG242ogDn06BbUtmkp3rx4sUOy+V67969UZKklzsuLg7du3dHedK0RVuctlVBGHJgOb7F380hIiI/mz59OpYuXap+E6VwmlQvb9KkiUotf+WVV/zdPKJyzdt5t0XnhtF4bHDrEm8TEZXB9HI5W75v37686wkJCSodvHr16mpKMBlfffvtt6siLr169cKcOXNUBdV7770XJd3TLRetglx5ERtTGcvQAv2wAad3r0KtRj383SQiIvKj+vXrq9/lr7/+WhU3lXRzqZVy6623OhRWI6LS9+OmgusqtKlbBWN7N8Ho7vapdomoHAbd69atQ//+/fOua0XMxowZg08++QSjR4/G6dOnMXXqVBw/fhzt2rXDwoULVQGXklRex3SbzSYkVY4D0jcg89BafzeHiIj8KDs7W8348fPPP+POO+9UFyIqG37cfAxfrD3s9vbaURF477auHL9NFISKNU93WVQe5/j87PP/4vZ9k3Emoj6qT9nh7+YQEZEff7ekp/uPP/5AmzaBNw60PP6GU/A7n5GN537Yjnkbj3ocu81UcqLA45d5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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 8.922e-07 @ epoch 914\n",
      "\n",
      "iter=0  t=0.00s  best_y=1.35888e+06  x=[43, 32, 26, 13, 15, 2, 3, 0]\n",
      "iter=1  t=0.00s  best_y=1.35883e+06  x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "STOP: local minimum. best_y=1.35883e+06 x=[43, 32, 26, 13, 15, 2, 2, 1]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Set parameter FuncNonlinear to value 1\n",
      "Set parameter FeasibilityTol to value 1e-09\n",
      "Set parameter OptimalityTol to value 1e-09\n",
      "Set parameter IntFeasTol to value 1e-09\n",
      "Set parameter NumericFocus to value 3\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "FeasibilityTol  1e-09\n",
      "IntFeasTol  1e-09\n",
      "OptimalityTol  1e-09\n",
      "NumericFocus  3\n",
      "\n",
      "Optimize a model with 4804 rows, 4813 columns and 24014 nonzeros\n",
      "Model fingerprint: 0x2a2f4ded\n",
      "Model has 1601 function constraints treated as nonlinear\n",
      "  1600 EXP, 1 LOG\n",
      "Variable types: 4805 continuous, 8 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [6e-03, 4e+05]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-12, 4e+06]\n",
      "  RHS range        [9e+01, 2e+06]\n",
      "Warning: x < 1e-10 in domain of log(x).\n",
      "         Setting lower bound to 1e-10.\n",
      "Presolve removed 3202 rows and 1602 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 9607 rows, 3212 columns, 33619 nonzeros\n",
      "Presolved model has 1601 nonlinear constraint(s)\n",
      "\n",
      "Solving non-convex MINLP\n",
      "\n",
      "Variable types: 3204 continuous, 8 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 8.628375e+05, 1697 iterations, 0.02 seconds (0.09 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 862837.542    0 1484          - 862837.542      -     -    0s\n",
      "     0     2 862842.405    0 1484          - 862842.405      -     -    0s\n",
      "     3     8 862859.893    2 1482          - 862842.799      -   6.3    5s\n",
      "*   33    62               6    1314592.1750 863024.654  34.4%  31.0    5s\n",
      "* 1225   736              72    1289795.9973 863065.431  33.1%  15.5    6s\n",
      "* 1229   736              75    1286844.2800 863065.431  32.9%  15.5    6s\n",
      "* 1533   903              52    1286277.3833 863088.145  32.9%  13.4    7s\n",
      "* 1660   966              62    1286266.7904 863088.145  32.9%  12.6    7s\n",
      "* 1870  1132             102    1285972.3502 863088.145  32.9%  11.8    7s\n",
      "* 1975  1191             105    1285931.0548 863088.145  32.9%  11.6    7s\n",
      "* 2126  1282             118    1285930.7279 863088.145  32.9%  11.0    8s\n",
      "* 2563  1470              60    1284913.5042 863089.883  32.8%  10.1    8s\n",
      "* 2569  1470              65    1284833.7302 863089.883  32.8%  10.1    8s\n",
      "  2637  1473 1128400.31   53    4 1284833.73 863089.883  32.8%  10.1   10s\n",
      "  2638  1477 863089.883   16 1499 1284833.73 863089.883  32.8%  10.8   16s\n",
      "* 3114  1445              60    1284818.8818 1246273.97  3.00%  10.5   19s\n",
      "* 3161  1378              61    1284815.6563 1246273.97  3.00%  10.4   19s\n",
      "* 3178  1306              56    1284560.1188 1246273.97  2.98%  10.3   19s\n",
      "* 3425  1307              52    1284229.3211 1246273.97  2.96%   9.6   19s\n",
      "  3616  1336 1249728.39   45    8 1284229.32 1246273.97  2.96%   9.1   20s\n",
      "* 3962  1292              73    1282138.3896 1246273.97  2.80%   8.4   20s\n",
      "* 4666  1216              79    1281372.4399 1246273.97  2.74%   7.2   20s\n",
      "* 5128  1127              82    1280914.6267 1246273.97  2.70%   6.6   21s\n",
      "* 6836  1338              76    1280892.2541 1246344.05  2.70%   5.1   22s\n",
      "* 7103  1418              76    1280846.8474 1246344.05  2.69%   4.9   23s\n",
      "* 8380  1766              77    1280761.9307 1247668.53  2.58%   4.2   23s\n",
      " 10806  2635 1253922.36   55    8 1280761.93 1248990.09  2.48%   3.3   25s\n",
      " 20376  4150 infeasible   63      1280761.93 1253817.48  2.10%   1.9   30s\n",
      " 22764  4154 1253831.36   89    7 1280761.93 1253830.81  2.10%   1.7   35s\n",
      " 28210  3222 infeasible   98      1280761.93 1254101.22  2.08%   1.4   40s\n",
      "\n",
      "Explored 33026 nodes (40106 simplex iterations) in 44.80 seconds (103.42 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 1.28076e+06 1.28085e+06 1.28089e+06 ... 1.28482e+06\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.280761930743e+06, best bound 1.280761930743e+06, gap 0.0000%\n",
      "[CHECK LSET] obj(x_ip)=1.35819e+06  ip_y=1.28076e+06  rel_err=5.701e-02\n",
      "\n",
      "=== MODEL SPECS (from seed 0 run) ===\n",
      "    model  n_params                                                  details    lr  batch_size  epochs\n",
      "      DFN     16663 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "DFN_AfixI     14408   layers=[5, 400, 4] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000\n",
      "     LSET     14400                                     n_pieces=1600 T=0.05 0.001           8    1000\n",
      "      MLP     17793                                        hidden=[128, 128] 0.001           8    1000\n",
      "MaxAffine     14400                                            n_pieces=1600 0.001           8    1000\n",
      "\n",
      "=== LEARNING SUMMARY (mean ± SE over seeds) ===\n",
      "    model  train_time        best_val            test\n",
      "      DFN 1142.19 ± 0 5.34818e-05 ± 0 4.59192e-05 ± 0\n",
      "DFN_AfixI 1202.43 ± 0 1.77214e-06 ± 0 1.82401e-06 ± 0\n",
      "     LSET 388.959 ± 0  8.9218e-07 ± 0 3.08025e-06 ± 0\n",
      "      MLP  183.29 ± 0 5.92857e-05 ± 0 3.78317e-05 ± 0\n",
      "MaxAffine 197.883 ± 0 2.40325e-05 ± 0 5.14683e-06 ± 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 [43, 32, 26, 13, 15, 2, 3, 0] 1.35742e+06 ± 0 1.35835e+06 ± 0  0.0311995 ± 0   [27, 0, 0, 14, 20, 50, 0, 23] 1.34582e+06 ± 0 1.35417e+06 ± 0 0.0999381 ± 0 [1, 24, 6, 1, 27, 34, 17, 24] 1.35277e+06 ± 0 301.751 ± 0 0.862282 ± 0    0.103787 ± 0\n",
      "DFN_AfixI [43, 32, 26, 13, 15, 2, 2, 1]  1.3582e+06 ± 0 1.35836e+06 ± 0  0.0463086 ± 0 [10, 11, 0, 10, 34, 49, 10, 10] 1.35075e+06 ± 0 1.35254e+06 ± 0 0.0846419 ± 0 [1, 24, 6, 1, 27, 34, 17, 24] 1.35277e+06 ± 0 301.751 ± 0 0.551457 ± 0  -0.0167065 ± 0\n",
      "     LSET [43, 32, 26, 13, 15, 2, 2, 1] 1.35883e+06 ± 0 1.35836e+06 ± 0 0.00266817 ± 0    [0, 49, 0, 0, 32, 36, 14, 3] 1.28076e+06 ± 0 1.35622e+06 ± 0   44.9018 ± 0 [1, 24, 6, 1, 27, 34, 17, 24] 1.35277e+06 ± 0 301.751 ± 0  6.09544 ± 0    0.255624 ± 0\n",
      "      MLP [43, 32, 26, 13, 15, 2, 3, 0] 1.35656e+06 ± 0 1.35835e+06 ± 0 0.00196783 ± 0     [0, 3, 0, 0, 31, 50, 0, 50] 1.34971e+06 ± 0 1.35439e+06 ± 0   6.40893 ± 0 [1, 24, 6, 1, 27, 34, 17, 24] 1.35277e+06 ± 0 301.751 ± 0  0.50776 ± 0    0.119755 ± 0\n",
      "MaxAffine [43, 32, 26, 13, 15, 2, 2, 1] 1.35832e+06 ± 0 1.35836e+06 ± 0  0.0567435 ± 0     [0, 0, 0, 0, 50, 50, 0, 34] 1.34938e+06 ± 0 1.35416e+06 ± 0  0.161666 ± 0 [1, 24, 6, 1, 27, 34, 17, 24] 1.35277e+06 ± 0 301.751 ± 0 0.662954 ± 0    0.103344 ± 0\n",
      "\n",
      "=== FAILURES / WARNINGS (if any) ===\n",
      " seed model    stage                          error\n",
      "    0  LSET IP_CHECK rel_err=5.701e-02 (tol=0.0001)\n"
     ]
    }
   ],
   "source": [
    "# ===================== MDVSP DATASET =====================\n",
    "N_SEEDS = 1\n",
    "VARY_DATASET_SEED = False\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "SILENCE_LOCAL_SEARCH = False\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "dataset_type = \"mdvsp\"\n",
    "dataset_params = dict(\n",
    "    K=1000,\n",
    "    filename=\"RN-8-3000-05.dat\",\n",
    "    x_min=0,\n",
    "    x_max=50,\n",
    "    noise_std=0.0,\n",
    "    seed=0,\n",
    "    max_trips=2000,\n",
    "    max_succ=50,\n",
    ")\n",
    "\n",
    "Xtmp, _, _ = make_mdvsp_dataset(**dataset_params)\n",
    "in_dim = int(np.asarray(Xtmp).shape[1])\n",
    "print(f\"[MDVSP] inferred in_dim={in_dim} from Xtmp shape={np.asarray(Xtmp).shape}\")\n",
    "\n",
    "train_base = dict(\n",
    "    epochs=1000,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=1,\n",
    "    plot_points=128,\n",
    "    plot_chunk=128,\n",
    ")\n",
    "\n",
    "# ---- DFN (learnable A) ----\n",
    "dfn_params = dict(\n",
    "    input_dim=in_dim, layer_sizes=[16, 128, 16], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=-2.0\n",
    ")\n",
    "\n",
    "# ---- DFN (fixed A = I) ----\n",
    "L1 = 5\n",
    "LK = in_dim + 1 - L1\n",
    "assert LK > 0, f\"in_dim too small for DFN_AfixI with L1={L1} (got in_dim={in_dim})\"\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=[L1, 400, LK],\n",
    "    p_list=[1, 1],\n",
    "    seed=0,\n",
    "    alpha=5e-3,\n",
    "    beta=-2.0,\n",
    "    A_fixed=np.eye(in_dim, dtype=np.float32),\n",
    ")\n",
    "\n",
    "# ---- other models ----\n",
    "mlp_params  = dict(in_dim=in_dim, hidden_dims=[128, 128], out_dim=1)\n",
    "maff_params = dict(in_dim=in_dim, n_pieces=1600)\n",
    "lset_params = dict(in_dim=in_dim, n_pieces=1600, T=0.05)\n",
    "\n",
    "lr_map = dict(DFN=1e-1, MLP=1e-3, MaxAffine=1e-3, LSET=1e-3)\n",
    "time_limit = 300\n",
    "\n",
    "# feasible integer box + feasible x0 / sum_eq\n",
    "xmin  = np.full(in_dim, int(dataset_params[\"x_min\"]), dtype=int)\n",
    "xmax  = np.full(in_dim, int(dataset_params[\"x_max\"]), dtype=int)\n",
    "\n",
    "rng = np.random.default_rng(train_base[\"seed\"])\n",
    "x0    = rng.integers(xmin, xmax + 1, size=in_dim, dtype=np.int64)\n",
    "delta = 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": "b3ca3984-8094-4fd0-bd5e-863b40801930",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:dfn]",
   "language": "python",
   "name": "conda-env-dfn-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
