{
 "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": {},
   "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, 16) (50,) \n",
      " [[ 9. 10. 15. 19.  0.  3. 17. 19.  5.  6. 18.  8.  5. 17.  5.  8.]\n",
      " [13. 11.  1.  0. 18. 15. 17. 11. 17.  6.  9. 16.  2.  6.  2.  9.]\n",
      " [20.  2.  8.  8. 18.  4. 10.  5.  0. 15.  1.  5. 10. 10.  2. 20.]\n",
      " [15. 20.  1. 15.  6. 11. 19.  5. 15.  3.  6. 20.  8. 10.  6.  2.]\n",
      " [ 8. 13.  9. 16.  7. 12. 16. 19.  8.  0. 15. 11. 18.  9.  7.  1.]] \n",
      " [1.67628e+06 1.55810e+06 1.40920e+06 1.65442e+06 1.72315e+06] \n",
      " 247649.94 1.03678e+06 2.04339e+06 8.251122\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-16-3000-05.dat\", x_min=0, x_max=20, noise_std=0.0, seed=1, max_trips=200, max_succ=5\n",
    ")\n",
    "print(X.shape, y.shape, \"\\n\", X[:5], \"\\n\", y[:5], \"\\n\", y.std(), y.min(), y.max(), y.max()/y.std())\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": {},
   "outputs": [],
   "source": [
    "def _split_train_val_test(X: torch.Tensor, y: torch.Tensor, *, val_frac: float, test_frac: float, seed: int):\n",
    "    N = int(X.shape[0])\n",
    "    n_test = int(round(test_frac * N))\n",
    "    n_val  = int(round(val_frac  * N))\n",
    "    n_train = N - n_val - n_test\n",
    "    if n_train <= 0:\n",
    "        raise ValueError(\"splits too large; train set would be empty\")\n",
    "\n",
    "    g = torch.Generator().manual_seed(int(seed))\n",
    "    perm = torch.randperm(N, generator=g)\n",
    "    i_tr = perm[:n_train]\n",
    "    i_va = perm[n_train:n_train + n_val]\n",
    "    i_te = perm[n_train + n_val:]\n",
    "\n",
    "    return (X[i_tr], y[i_tr]), (X[i_va], y[i_va]), (X[i_te], y[i_te])\n",
    "\n",
    "\n",
    "def _fit_standardizer(Xtr: torch.Tensor, ytr: torch.Tensor, *, eps: float):\n",
    "    x_mean = Xtr.mean(0, keepdim=True)\n",
    "    x_std  = Xtr.std(0, unbiased=False, keepdim=True)\n",
    "    x_std  = torch.where(x_std < eps, torch.ones_like(x_std), x_std)\n",
    "\n",
    "    y_mean = ytr.mean()\n",
    "    y_std  = ytr.std(unbiased=False).clamp_min(eps)\n",
    "\n",
    "    return {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std}\n",
    "\n",
    "\n",
    "def _apply_standardizer(X: torch.Tensor, y: torch.Tensor, scaler):\n",
    "    Xn = (X - scaler[\"x_mean\"]) / scaler[\"x_std\"]\n",
    "    yn = (y - scaler[\"y_mean\"]) / scaler[\"y_std\"]\n",
    "    return Xn, yn\n",
    "\n",
    "@torch.no_grad()\n",
    "def _mse_norm(model: nn.Module, loader: DataLoader, device: str):\n",
    "    model.eval()\n",
    "    tot, n = 0.0, 0\n",
    "    for xb, yb in loader:\n",
    "        xb, yb = xb.to(device), yb.to(device)\n",
    "        pred = model(xb).squeeze(-1)\n",
    "        tot += F.mse_loss(pred, yb, reduction=\"sum\").item()\n",
    "        n += yb.numel()\n",
    "    return tot / max(n, 1)\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def _predict_in_chunks(model: nn.Module, X: torch.Tensor, *, chunk: int):\n",
    "    out = []\n",
    "    for i in range(0, int(X.shape[0]), int(chunk)):\n",
    "        out.append(model(X[i:i + chunk]).squeeze(-1))\n",
    "    return torch.cat(out, 0)\n",
    "\n",
    "\n",
    "import json, hashlib\n",
    "\n",
    "# ---- Caching / persistence helpers ----\n",
    "_CACHE_ROOT_DEFAULT = Path(\"saved_runs\")\n",
    "\n",
    "def _to_hashable(x):\n",
    "    \"\"\"Convert nested objects to a deterministic, hashable (and mostly JSON-friendly) form.\"\"\"\n",
    "    import numpy as _np\n",
    "    import torch as _torch\n",
    "    from pathlib import Path as _Path\n",
    "\n",
    "    if x is None or isinstance(x, (bool, int, str)):\n",
    "        return x\n",
    "    if isinstance(x, float):\n",
    "        return float(x)\n",
    "    if isinstance(x, _Path):\n",
    "        return str(x)\n",
    "    if isinstance(x, (list, tuple)):\n",
    "        return [_to_hashable(v) for v in x]\n",
    "    if isinstance(x, dict):\n",
    "        return {str(k): _to_hashable(x[k]) for k in sorted(x.keys(), key=lambda z: str(z))}\n",
    "    if isinstance(x, _np.ndarray):\n",
    "        h = hashlib.sha256(x.tobytes(order=\"C\")).hexdigest()\n",
    "        return {\"__ndarray__\": True, \"dtype\": str(x.dtype), \"shape\": list(x.shape), \"sha256\": h}\n",
    "    if isinstance(x, _torch.Tensor):\n",
    "        t = x.detach().cpu()\n",
    "        h = hashlib.sha256(t.numpy().tobytes(order=\"C\")).hexdigest()\n",
    "        return {\"__tensor__\": True, \"dtype\": str(t.dtype), \"shape\": list(t.shape), \"sha256\": h}\n",
    "    return {\"__repr__\": repr(x)}\n",
    "\n",
    "def _run_signature(dataset_type, dataset_params, model_type, model_params, train_sig):\n",
    "    return {\n",
    "        \"dataset_type\": str(dataset_type).lower(),\n",
    "        \"dataset_params\": _to_hashable(dict(dataset_params)),\n",
    "        \"model_type\": str(model_type),\n",
    "        \"model_params\": _to_hashable(dict(model_params)),\n",
    "        \"train_params\": _to_hashable(dict(train_sig)),\n",
    "    }\n",
    "\n",
    "def _run_id_from_signature(sig) -> str:\n",
    "    blob = json.dumps(sig, sort_keys=True, separators=(\",\", \":\"), ensure_ascii=True).encode(\"utf-8\")\n",
    "    return hashlib.sha256(blob).hexdigest()[:16]\n",
    "\n",
    "def _get_run_dir(cache_root: Path, dataset_type, model_type, run_id: str) -> Path:\n",
    "    return Path(cache_root) / str(dataset_type).lower() / str(model_type) / run_id\n",
    "\n",
    "def _cpuify(obj):\n",
    "    import torch as _torch\n",
    "    if isinstance(obj, _torch.Tensor):\n",
    "        return obj.detach().cpu()\n",
    "    if isinstance(obj, dict):\n",
    "        return {k: _cpuify(v) for k, v in obj.items()}\n",
    "    if isinstance(obj, (list, tuple)):\n",
    "        return [_cpuify(v) for v in obj]\n",
    "    return obj\n",
    "\n",
    "def _set_full_determinism(seed: int):\n",
    "    \"\"\"CPU-only determinism: seed controls Python/NumPy/Torch RNGs.\n",
    "    (CUDA is intentionally not used in these notebooks.)\n",
    "    \"\"\"\n",
    "    import os, random\n",
    "    import numpy as np\n",
    "    import torch\n",
    "    seed = int(seed)\n",
    "\n",
    "    os.environ[\"PYTHONHASHSEED\"] = str(seed)\n",
    "\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "\n",
    "    # Determinism flags (will error if a non-deterministic op is used)\n",
    "    try:\n",
    "        torch.use_deterministic_algorithms(True)\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "def _seed_worker(worker_id: int):\n",
    "    import random\n",
    "    import numpy as np\n",
    "    import torch\n",
    "    worker_seed = torch.initial_seed() % 2**32\n",
    "    np.random.seed(worker_seed)\n",
    "    random.seed(worker_seed)\n",
    "\n",
    "def _try_load_cached_run(run_dir: Path):\n",
    "    artifact_path = Path(run_dir) / \"artifact.pt\"\n",
    "    if not artifact_path.exists():\n",
    "        return None\n",
    "    try:\n",
    "        return torch.load(str(artifact_path), map_location=\"cpu\")\n",
    "    except Exception:\n",
    "        return None\n",
    "\n",
    "def _build_model_from_params(model_type, model_params):\n",
    "    mt = str(model_type)\n",
    "    mp = dict(model_params)\n",
    "    if mt == \"DFN\":\n",
    "        model = DFN(**mp)\n",
    "    else:\n",
    "        mp.pop(\"alpha\", None)\n",
    "        mp.pop(\"beta\", None)\n",
    "        if mt == \"MLP\":\n",
    "            model = MLP(**mp)\n",
    "        elif mt == \"MaxAffine\":\n",
    "            model = MaxAffine(**mp)\n",
    "        elif mt == \"LSET\":\n",
    "            model = LSET(**mp)\n",
    "        else:\n",
    "            raise ValueError(\"model_type must be: DFN | MLP | MaxAffine | LSET\")\n",
    "    return model\n",
    "\n",
    "def _save_run(run_dir: Path, signature: dict, model: nn.Module, data: dict, history: dict, spec: dict):\n",
    "    run_dir = Path(run_dir)\n",
    "    run_dir.mkdir(parents=True, exist_ok=True)\n",
    "    artifact_path = run_dir / \"artifact.pt\"\n",
    "    if artifact_path.exists():\n",
    "        return\n",
    "    state_dict = {k: v.detach().cpu() for k, v in model.state_dict().items()}\n",
    "    artifact = {\n",
    "        \"signature\": signature,\n",
    "        \"state_dict\": state_dict,\n",
    "        \"data\": _cpuify(data),\n",
    "        \"history\": history,\n",
    "        \"spec\": spec,\n",
    "    }\n",
    "    torch.save(artifact, str(artifact_path))\n",
    "    try:\n",
    "        with open(run_dir / \"signature.json\", \"w\", encoding=\"utf-8\") as f:\n",
    "            json.dump(signature, f, indent=2, sort_keys=True)\n",
    "    except Exception:\n",
    "        pass\n",
    "\n",
    "def generate_and_train_simple(dataset_type, dataset_params, model_type, model_params, train_params=None):\n",
    "    \n",
    "    tp = train_params or {}\n",
    "\n",
    "    epochs     = int(tp.get(\"epochs\", 200))\n",
    "    batch_sz   = int(tp.get(\"batch_size\", 32))\n",
    "    lr         = float(tp.get(\"lr\", 1e-3))\n",
    "    wd         = float(tp.get(\"weight_decay\", 0.0))\n",
    "    val_frac   = float(tp.get(\"val_frac\", 0.15))\n",
    "    test_frac  = float(tp.get(\"test_frac\", 0.15))\n",
    "    eps        = float(tp.get(\"eps\", 1e-8))\n",
    "    seed       = int(tp.get(\"seed\", 0))\n",
    "    device     = tp.get(\"device\", \"cpu\")\n",
    "    plot_every = int(tp.get(\"plot_every\", 0) or 0)\n",
    "    plot_points= int(tp.get(\"plot_points\", 2048))\n",
    "    plot_chunk = int(tp.get(\"plot_chunk\", 4096))\n",
    "    print_stats= bool(tp.get(\"print_stats\", True))\n",
    "\n",
    "\n",
    "    # ---- determinism (seed controls data, model init, dataloader order, etc.) ----\n",
    "    _set_full_determinism(seed)\n",
    "    # dataset seed: caller may set it; otherwise default to the training seed\n",
    "    dataset_params = dict(dataset_params)\n",
    "    dataset_params.setdefault(\"seed\", int(seed))\n",
    "\n",
    "\n",
    "    # ---- cache check (skip training if identical run already saved) ----\n",
    "    train_sig = {\n",
    "        \"epochs\": int(epochs),\n",
    "        \"batch_size\": int(batch_sz),\n",
    "        \"lr\": float(lr),\n",
    "        \"weight_decay\": float(wd),\n",
    "        \"val_frac\": float(val_frac),\n",
    "        \"test_frac\": float(test_frac),\n",
    "        \"eps\": float(eps),\n",
    "        \"seed\": int(seed),\n",
    "        \"deterministic\": True,\n",
    "    }\n",
    "    cache_root = Path(tp.get(\"cache_root\", _CACHE_ROOT_DEFAULT))\n",
    "    signature = _run_signature(dataset_type, dataset_params, model_type, model_params, train_sig)\n",
    "    run_id = _run_id_from_signature(signature)\n",
    "    run_dir = _get_run_dir(cache_root, dataset_type, model_type, run_id)\n",
    "\n",
    "    cached = _try_load_cached_run(run_dir)\n",
    "    if cached is not None and isinstance(cached, dict) and \"state_dict\" in cached and \"data\" in cached and \"history\" in cached and \"spec\" in cached:\n",
    "        model = _build_model_from_params(model_type, model_params)\n",
    "        model.load_state_dict(cached[\"state_dict\"])\n",
    "        model = model.to(device)\n",
    "        return model, cached[\"data\"], cached[\"history\"], cached[\"spec\"]\n",
    "\n",
    "    # ---- data ----\n",
    "    dt = str(dataset_type).lower()\n",
    "    if dt == \"mdvsp\":\n",
    "        X, y, gt = make_mdvsp_dataset(**dataset_params)\n",
    "    elif dt == \"assignment\":\n",
    "        X, y, gt = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "    elif dt == \"quadratic\":\n",
    "        X, y, gt = generate_convex_quadratic_dataset(**dataset_params)\n",
    "    else:\n",
    "        raise ValueError(\"dataset_type must be: mdvsp | assignment | quadratic\")\n",
    "\n",
    "    X = torch.as_tensor(X, dtype=torch.float32)\n",
    "    y = torch.as_tensor(y, dtype=torch.float32).view(-1)\n",
    "\n",
    "    # ---- print a quick dataset stats ----\n",
    "    if print_stats:\n",
    "        with torch.no_grad():\n",
    "            xmn = X.mean(0)\n",
    "            xsd = X.std(0, unbiased=False)\n",
    "            print(\n",
    "                f\"\\n--- Dataset stats ({dataset_type}) ---\\n\"\n",
    "                f\"  X: shape={tuple(X.shape)}  mean(mean)={xmn.mean():.3g}  std(mean)={xsd.mean():.3g}  \"\n",
    "                f\"min={float(X.min()):.3g}  max={float(X.max()):.3g}\\n\"\n",
    "                f\"  y: shape={tuple(y.shape)}  mean={float(y.mean()):.3g}  std={float(y.std(unbiased=False)):.3g}  \"\n",
    "                f\"min={float(y.min()):.3g}  max={float(y.max()):.3g}\\n\"\n",
    "            )\n",
    "\n",
    "    (Xtr, ytr), (Xva, yva), (Xte, yte) = _split_train_val_test(X, y, val_frac=val_frac, test_frac=test_frac, seed=seed)\n",
    "\n",
    "    scaler = _fit_standardizer(Xtr, ytr, eps=eps)\n",
    "    XtrN, ytrN = _apply_standardizer(Xtr, ytr, scaler)\n",
    "    XvaN, yvaN = _apply_standardizer(Xva, yva, scaler)\n",
    "    XteN, yteN = _apply_standardizer(Xte, yte, scaler)\n",
    "\n",
    "    g_dl = torch.Generator()\n",
    "    g_dl.manual_seed(seed)\n",
    "    train_loader = DataLoader(\n",
    "        TensorDataset(XtrN, ytrN),\n",
    "        batch_size=batch_sz,\n",
    "        shuffle=True,\n",
    "        generator=g_dl,\n",
    "        worker_init_fn=_seed_worker,\n",
    "    )\n",
    "    val_loader   = DataLoader(TensorDataset(XvaN, yvaN), batch_size=batch_sz, shuffle=False)\n",
    "\n",
    "    # subset for plotting\n",
    "    Nv = int(XvaN.shape[0])\n",
    "    if plot_points <= 0 or plot_points >= Nv:\n",
    "        plot_idx = torch.arange(Nv)\n",
    "    else:\n",
    "        g_plot = torch.Generator().manual_seed(seed + 12345)\n",
    "        plot_idx = torch.randperm(Nv, generator=g_plot)[:plot_points]\n",
    "\n",
    "    # ---- model ----\n",
    "    mt = str(model_type)\n",
    "    mp = dict(model_params)\n",
    "\n",
    "    if mt == \"DFN\":\n",
    "        model = DFN(**mp)\n",
    "        extra = f\"layers={mp.get('layer_sizes')} p_list={mp.get('p_list')} alpha={getattr(model,'alpha',None)} beta={getattr(model,'beta',None)}\"\n",
    "    else:\n",
    "        mp.pop(\"alpha\", None)\n",
    "        mp.pop(\"beta\", None)\n",
    "        if mt == \"MLP\":\n",
    "            model = MLP(**mp)\n",
    "            extra = f\"hidden={mp.get('hidden_dims')}\"\n",
    "        elif mt == \"MaxAffine\":\n",
    "            model = MaxAffine(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')}\"\n",
    "        elif mt == \"LSET\":\n",
    "            model = LSET(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')} T={mp.get('T')}\"\n",
    "        else:\n",
    "            raise ValueError(\"model_type must be: DFN | MLP | MaxAffine | LSET\")\n",
    "\n",
    "    model = model.to(device)\n",
    "    opt = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=wd)\n",
    "\n",
    "    n_params = sum(p.numel() for p in model.parameters())\n",
    "    n_trainable = sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "    print(\n",
    "        f\"\\n=== Run: {dataset_type} | {model_type} ===\\n\"\n",
    "        f\"  data: N={len(X)}  train/val/test={len(Xtr)}/{len(Xva)}/{len(Xte)}  dim={X.shape[1]}\\n\"\n",
    "        f\"  model: params={n_params:,} {extra}\\n\"\n",
    "        f\"  train: device={device}  epochs={epochs}  batch={batch_sz}  lr={lr:g}  wd={wd:g}  seed={seed}\\n\"\n",
    "    )\n",
    "\n",
    "    history = {\"train_mse_norm\": [], \"val_mse_norm\": []}\n",
    "    best_val, best_ep, best_state = float(\"inf\"), 0, None\n",
    "\n",
    "    live = display(None, display_id=True) if plot_every > 0 else None\n",
    "\n",
    "    for ep in range(1, epochs + 1):\n",
    "        model.train()\n",
    "        for xb, yb in train_loader:\n",
    "            xb, yb = xb.to(device), yb.to(device)\n",
    "            loss = F.mse_loss(model(xb).squeeze(-1), yb)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "        tr_mse = _mse_norm(model, train_loader, device)\n",
    "        va_mse = _mse_norm(model, val_loader, device)\n",
    "        history[\"train_mse_norm\"].append(tr_mse)\n",
    "        history[\"val_mse_norm\"].append(va_mse)\n",
    "\n",
    "        if va_mse < best_val:\n",
    "            best_val, best_ep = va_mse, ep\n",
    "            best_state = {k: v.detach().cpu().clone() for k, v in model.state_dict().items()}\n",
    "\n",
    "        if plot_every > 0 and (ep == 1 or ep % plot_every == 0 or ep == epochs):\n",
    "            model.eval()\n",
    "            x_plot = XvaN[plot_idx].to(device)\n",
    "            y_true = yvaN[plot_idx].to(device)\n",
    "            y_pred = _predict_in_chunks(model, x_plot, chunk=plot_chunk)\n",
    "\n",
    "            fig, ax = plt.subplots(1, 2, figsize=(10, 4))\n",
    "            ax[0].plot(history[\"train_mse_norm\"], label=\"train\")\n",
    "            ax[0].plot(history[\"val_mse_norm\"], label=\"val\")\n",
    "            ax[0].set_yscale(\"log\")\n",
    "            ax[0].set_title(f\"Epoch {ep}/{epochs} | val MSE={va_mse:.3e} (norm)\")\n",
    "            ax[0].legend()\n",
    "\n",
    "            yt = y_true.detach().cpu().numpy()\n",
    "            yp = y_pred.detach().cpu().numpy()\n",
    "            ax[1].scatter(yt, yp, s=10)\n",
    "            lo = float(min(yt.min(), yp.min()))\n",
    "            hi = float(max(yt.max(), yp.max()))\n",
    "            ax[1].plot([lo, hi], [lo, hi])\n",
    "            ax[1].set_xlabel(\"y_true (norm)\")\n",
    "            ax[1].set_ylabel(\"y_pred (norm)\")\n",
    "            ax[1].set_title(f\"Val scatter (n={len(yt)})\")\n",
    "\n",
    "            plt.tight_layout()\n",
    "            live.update(fig)\n",
    "            plt.close(fig)\n",
    "\n",
    "    if best_state is not None:\n",
    "        model.load_state_dict(best_state)\n",
    "\n",
    "    if print_stats:\n",
    "        print(f\"[DONE] best val MSE (norm) = {best_val:.3e} @ epoch {best_ep}\\n\")\n",
    "\n",
    "    data = {\n",
    "        \"raw\":  {\"Xtr\": Xtr,  \"ytr\": ytr,  \"Xva\": Xva,  \"yva\": yva,  \"Xte\": Xte,  \"yte\": yte},\n",
    "        \"norm\": {\"Xtr\": XtrN, \"ytr\": ytrN, \"Xva\": XvaN, \"yva\": yvaN, \"Xte\": XteN, \"yte\": yteN},\n",
    "        \"scaler\": scaler,\n",
    "        \"best_val_mse_norm\": float(best_val),\n",
    "        \"best_epoch\": int(best_ep),\n",
    "        \"stats\": {\"n_params\": int(n_params), \"n_trainable\": int(n_trainable)},\n",
    "        \"true\": gt,\n",
    "        \"device\": device,\n",
    "    }\n",
    "\n",
    "    spec = {\n",
    "        \"model\": model_type,\n",
    "        \"extra\": extra,\n",
    "        \"n_params\": int(n_params),\n",
    "        \"n_trainable\": int(n_trainable),\n",
    "        \"model_params\": dict(model_params),\n",
    "        \"train_params\": {\n",
    "            \"epochs\": int(epochs),\n",
    "            \"batch_size\": int(batch_sz),\n",
    "            \"lr\": float(lr),\n",
    "            \"weight_decay\": float(wd),\n",
    "            \"seed\": int(seed),\n",
    "            \"device\": str(device),\n",
    "            \"val_frac\": float(val_frac),\n",
    "            \"test_frac\": float(test_frac),\n",
    "        },\n",
    "    }\n",
    "\n",
    "\n",
    "    # ---- save artifacts for this run ----\n",
    "\n",
    "    _save_run(run_dir, signature, model, data, history, spec)\n",
    "\n",
    "\n",
    "    return model, data, history, spec\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ace7f63f",
   "metadata": {},
   "source": [
    "## Optimization Helpers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "38416530",
   "metadata": {
    "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, seed=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",
    "    # Make the IP solve reproducible across runs\n",
    "    try:\n",
    "        M.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            M.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=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",
    "    # Make the IP solve reproducible across runs\n",
    "    try:\n",
    "        M.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            M.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=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",
    "    # Make the IP solve reproducible across runs\n",
    "    try:\n",
    "        M.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            M.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=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",
    "    # Make the IP solve reproducible across runs\n",
    "    try:\n",
    "        M.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            M.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=None):\n",
    "    if model_type == \"DFN\":\n",
    "        return solve_dfn_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\n",
    "    if model_type == \"MLP\":\n",
    "        return solve_mlp_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\n",
    "    if model_type == \"MaxAffine\":\n",
    "        return solve_maxaffine_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\n",
    "    if model_type == \"LSET\":\n",
    "        return solve_lset_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\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, seed=None):\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",
    "    # Make the (ground-truth) solve reproducible across runs\n",
    "    try:\n",
    "        m.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            m.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=None):\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",
    "    # Make the (ground-truth) solve reproducible across runs\n",
    "    try:\n",
    "        m.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            m.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=None):\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",
    "    # Make the (ground-truth) solve reproducible across runs\n",
    "    try:\n",
    "        m.Params.Threads = 1\n",
    "    except Exception:\n",
    "        pass\n",
    "    if seed is not None:\n",
    "        try:\n",
    "            m.Params.Seed = int(seed)\n",
    "        except Exception:\n",
    "            pass\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, seed=None):\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, seed=seed)\n",
    "    if t == \"assignment\":\n",
    "        return solve_true_opt_assignment(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\n",
    "    if t == \"mdvsp\":\n",
    "        return solve_true_opt_mdvsp(gt, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose, seed=seed)\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",
    "        # Per-seed starting point + constraint (so the run seed controls x0 / sum_eq too)\n",
    "        x0_seed = x0\n",
    "        if isinstance(x0, (list, tuple, np.ndarray)) and np.asarray(x0).ndim == 2:\n",
    "            x0_seed = np.asarray(x0)[int(seed)]\n",
    "        x0_seed = np.asarray(x0_seed, int).ravel()\n",
    "\n",
    "        sum_eq_seed = sum_eq\n",
    "        if isinstance(sum_eq, (list, tuple, np.ndarray)) and np.asarray(sum_eq).ndim > 0:\n",
    "            sum_eq_seed = int(np.asarray(sum_eq)[int(seed)])\n",
    "        sum_eq_seed = int(sum_eq_seed)\n",
    "\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_seed, time_limit=time_limit, verbose=False, seed=seed)\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_seed, xmin, xmax,\n",
    "                    delta=delta, sum_eq=sum_eq_seed, 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_seed,\n",
    "                    time_limit=time_limit, verbose=True, seed=seed\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=12 from Xtmp shape=(2048, 12)\n",
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2048, 12)  mean(mean)=9.97  std(mean)=6.07  min=0  max=20\n",
      "  y: shape=(2048,)  mean=1.21e+06  std=2.09e+05  min=4.92e+05  max=1.88e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=2048  train/val/test=1434/307/307  dim=12\n",
      "  model: params=17,203 layers=[32, 64, 32] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=500  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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nTp15OWXXzafXX311U77WL58uVnX0RdffCGdOnWS2rVrS/Pmzc3fOH/+fKnHkZeXJ7/++qtJbG327Nlj9qtdu3v16iVXXXWVdOjQQXJzc522XbJkibRr105q1aolzZo1k+nTpzt9rsv02IcOHSoREREyfPhw+7/jyy+/lNatW5t933///XLy5EmZP3++2aZ+/foyevRouXDhgn1f1atXl7vuuksWLVpUZlwBf0LiDQAAAPxPDzzwgEkOMzIy7MuOHDliksrHHnuszG2Tk5Nl/PjxJnEtKioyD11mM3nyZJN4b926VYYNG1au49HW4IcffljGjBkj27dvl7lz55pE95VXXil1m+zsbGnVqpXUq1evxGeTJk2Sp556SvLz8806Q4YMsSfxmzdvlgcffFBSUlLMMWq3ee0Obrt4YPP6669L+/btzfr6uTp16pTMnDlTFi9eLKtWrZJ169ZJUlKSrFy50jw++ugj0/39888/d9pXly5dZMOGDeWKBeAPalT2AQAAAABVXVhYmDz00EMyb948k4SrhQsXSmxsrPTs2fOy29atW1dq1KghTZo0KfG57re8CbeNJth6H3RaWpp5ry3eL730kjzzzDMmkXdHW7ejo6PdfqZJt60lXFvO9SKBto63adNGZsyYIX369LEn05qYa7Kviba2cNv07t3b7Mdm48aNpuv87NmzpUWLFmaZtnhrsn3o0CETk7Zt25qW9qysLKeLETExMbJv3z5zn3e1arQlwv9RSgEAAAAP0O7Ta9askQMHDpj3moRr4unaBbyiOnfuXOFttFV56tSpJnm1PfT4tDVdW5ndOX36tOmW7k5CQoL9dVRUlHk+fPiwed6xY0eJwdj0/c6dO526iLv7d2j3clvSrSIjI00Xcz1ex2W2v+V4sUKTbteu/YC/osUbAAAA8ICbbrrJ3P+s93v379/fdLvW+6z/L72325G28FqWVeaga5qUasu0dtt2VVpy3bBhQ3PM7oSGhtpf2y4k2EYV12Nxvbjgenzu/h2u+7Xt290y1xHM//zzT5O0awIOVAUk3gAAAICH6Ijgb775pmn17tu3rzRt2rRc29WsWdOpdbgsjRo1khMnTphByGzJrN577ahjx45SWFho5uSuyIUD7fbtLpEui3YH127jjnJyckyXcx0IzRsKCgrMvxGoKuhqDgAAAHhIamqqSbrT09MrdF+2dq/evXu3SaB1ULayulB37drVtPZOnDjR3Gf9ySeflBjI7IUXXjAt7zrQ2bZt20x38E8//VSee+65Uver91JrMq/rV4QODPfNN9+Ye8h/+eUXMyL5O++843Q/t6fpwGr9+vXz2v4BTyPxBgAAADxERwTXKcT0HuXBgweXezvdZsCAASb51RbtsqbKatCggXz88cdm1O/4+HizribYjrSru46onpmZKYmJidKtWzczCFpcXFyp+9Xp0LRrug4KVxHa8vzZZ5+Zkcl11HJN+vX+cseB1TxJL2xoi/rlRosH/EmI5e4GDAAAAABX5I477pAbbrjBTJNV1eg93tpFXlvSw8PDxR89/fTTUlxcbKYZA6oKWrwBAAAAD9ABv7TVd+3atTJy5MgqGVNtQX/ttdfM1GL+qnHjxqZbO1CV0OINAAAAeIDep33s2DEzn7Xr/c067/XevXvdbjd37lxzbziAwEXiDQAAAHiZJt2uU345zlPtr926AXgGiTcAAAAAAF7EPd4AAAAAAHgRiTcAAAAAAF5E4g0AAAAAgBeReAMAAAAA4EUk3gAAAAAAeBGJNwAAAAAAXkTiDQAAAACAF5F4AwAAAAAg3vMvEM/RDHxRKu8AAAAASUVORK5CYII=",
      "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.181e-03 @ epoch 288\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",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 129 rows, 10252 columns and 20673 nonzeros\n",
      "Model fingerprint: 0xe90ea143\n",
      "Variable types: 10240 continuous, 12 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-08, 1e+00]\n",
      "  Objective range  [4e+00, 1e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [3e-01, 7e+01]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Found heuristic solution: objective 2.130400e+11\n",
      "Presolve removed 0 rows and 776 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 129 rows, 9476 columns, 19117 nonzeros\n",
      "Variable types: 9464 continuous, 12 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 7.197305e+05, 202 iterations, 0.01 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 719730.547    0    5 2.1304e+11 719730.547   100%     -    0s\n",
      "H    0     0                    719755.22252 719730.547  0.00%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  MIR: 3\n",
      "\n",
      "Explored 1 nodes (202 simplex iterations) in 0.11 seconds (0.06 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 2: 719755 2.1304e+11 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 7.197552225230e+05, best bound 7.197369128220e+05, gap 0.0025%\n",
      "[CHECK DFN] obj(x_ip)=719755  ip_y=719755  rel_err=3.818e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2048, 12)  mean(mean)=9.97  std(mean)=6.07  min=0  max=20\n",
      "  y: shape=(2048,)  mean=1.21e+06  std=2.09e+05  min=4.92e+05  max=1.88e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | DFN ===\n",
      "  data: N=2048  train/val/test=1434/307/307  dim=12\n",
      "  model: params=13,324 layers=[6, 256, 7] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=500  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA9bNJREFUeJzsnQWYG+X2xt+Jru926+60VKgDxeFixSlS9OIu5cLF7Q+Xi16gSHG7wAWKuxVrKaVQL3V3b7frG53/c0aSbyaTZLKb3c3unt/zpN1MJsmXyWRm3u+c8x5JlmUZDMMwDMMwDMMwDMOkHUf6X5JhGIZhGIZhGIZhGBbdDMMwDMMwDMMwDFOPcKSbYRiGYRiGYRiGYeoJFt0MwzAMwzAMwzAMU0+w6GYYhmEYhmEYhmGYeoJFN8MwDMMwDMMwDMPUEyy6GYZhGIZhGIZhGKaeYNHNMAzDMAzDMAzDMPUEi26GYRiGYRiGYRiGqSdYdNcTb7zxBiRJinv75Zdf0JisXbtWGcd//vOfOj3f6vbee+/FrL969WqMHTsWRUVFyMvLw1FHHYU5c+ZYvjY9f+jQocjKykKnTp1www03oKKiwnLdUCiEdu3a4cknn1TuX3jhhZZj6t+/v+Xzn3nmGeUxr9eLnj174r777kMgEIhZb/v27cprt2nTBjk5ORg9ejR+/PHHlLZVY3znNOYePXrYWo/GmJ+fb7mt161bB4fDoazzf//3f4bHlixZgvPPPx+9evVSvjPaRsOHD8e1116LsrKymPeId0sHd911F0444QR07txZeU16T7uUl5fjlltuwdFHH422bdtaflYR2n+PPPJIZX+m/Zr2b9rPRSorK3HWWWehX79+yrbNzc3FwIED8cADDyiP1Qd29umPP/4YZ599Nvr06YPs7GxlHzn33HOxYsWKlN7rb3/7G6688ko0VQ455BDl+MIwTGZz6qmnKseqPXv2xF2HjmFutxvbtm2z/brJjvONxYMPPohPP/00ZvnixYuV8dJ1RUPz5ptvKudGOlc2FBs3blSO0YceeqhynqXvi66vzdC1xr///W8cdthh6NChg3JeHjx4MB555BHU1NTErL9y5UrluqVbt27KftW7d2/ceOON2LVrl2E9WueUU06p18/ItBxYdNczr7/+On7//feYG4mS5sB1110X89lIUIvs2LEDBx98MJYvX47XXnsN77//vnIQpIPjsmXLDOv+73//U8TAqFGj8M033+Dee+9VDrAkaKyYOnWq8vri43QANY9p0qRJMc+lA/T48eOV53733Xe4+uqrlRPdNddcY1jP5/Mp4oJE9lNPPYXPPvsM7du3x7HHHospU6aguUAXK8Fg0HJb0X5MotHM3LlzMWLECOVC4J577sG3336LF154Accff7yyTXfv3m1Y3+q70W/pgCZf6KR50kknwePxpPRcet5LL72kfN/JTrJLly5V9l+/36/sz7Rf0/5N+zntjzokdmVZVk7mH330kbLvnHbaabj//vtx8sknI93Y3afpQqSqqgp33nmn8p3RJAB9l3RcWrRoka33os/y22+/4e6770ZT5V//+heee+65mOMQwzCZxSWXXKJcN7zzzjuWj5eWluKTTz5RJl3p/NzUSSS6aSK1oUU3nS/uuOMO3HrrrZbXAvUFiWO6LqTz+XHHHRd3vfXr12PChAnKOYzO459//jlOP/10ZYKC9gk6D+vQOXr//fdXzl90Dvj666+Vc+TLL7+sTKSHw+HIuvT8r776Cj/99FO9f1amBSAz9cLrr79Ov3B55syZGbmF16xZo4zvscceq/fn33zzzbLb7ZbXrl0bWVZaWiq3adNGPvPMMyPLgsGg3LFjR/noo482PP9///uf8l5ff/11zGtfffXV8siRIyP3L7jgAjk3NzfpmHbu3ClnZWXJl19+uWH5v//9b1mSJHnRokWRZRMnTlTef/r06ZFlgUBAHjBggLzvvvva3lY///yz3NDQ9ujevbut9Wi7nXXWWfIBBxxgeCwcDiuvcdlllymf495774089ve//115XllZmeXr0nPN71GfhEKhyN/0XvSedqGx6uPdsWNHzGcVOeOMM5T9l/ZjHdq/aT+/5ZZbkr4XrUOvv2rVKjldpLJPb9u2Leb5mzZtUsZ/ySWX2Ho/2vdpf2kMKisr0/ZagwYNUvZthmEyF7o+6NSpkzxixAjLx59//nnlmPrFF1+k9LqJjvONSbzz1wcffFAv1xPJjqnPPfeccn4pKSmRGxLxnE7X0/TZ6fraTEVFhXIzQ9eo9Jxff/01suzll19Wlv3www+GdR988EFl+Zw5cwzLTzjhBPmoo45K0ydiWjIc6c4AKF2GUnFffPFF7LXXXkpa6IABAyzTtBcuXKhEyFq1aqWk8lIa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svO8QJ0joGKcYwbvvBT+P19F9RB0l+O1114zWrRoYcTFxRk9evSgXb5hGN98843+R83zNnbsWOeSOmrJHbV0mNVqNX7/+9/r4NvV6dOnjXHjxhnp6elGQkKCPqnNzs42Ipm3MVM3tdyKA2NX1g033OD8f7BBgwbGoEGDnAE3Y1azoJv3m3cjR47UFwrVRdeMjAxj2LBhxoYNGxi3MKb+nfX1bzCqR33mextPdY6AyuEcMzjnpfD/+Sqqx6T+U5NMOQAAAAAA8I5JTQAAAAAABAhBNwAAAAAAAULQDQAAAABAgBB0AwAAAAAQIATdAAAAAAAECEE3AAAAAAABQtANAAAAAECAEHQDAAAAABAgBN0AAABAlCgoKJC2bdvK999/L6Gqd+/eMnfu3No+DMBvCLoBAACAAHviiSekW7dutT7OM2fOlBYtWsh5550noeqxxx6TBx98UOx2e20fCuAXBN0AAABAiCgsLAzo67/yyity0003STAy6tV16aWXyvHjx2XhwoV+PSagthB0AwAAABV45513pF69epKfn++2/aqrrpI//elP5X7v22+/LZMmTZI1a9aIyWTSN7VNUfffeOMNGTp0qCQlJcnkyZP1c2lpaW6v8fHHH+t9XX366afSs2dPiY+Pl9atW+ufUVRU5PM4Vq5cKVu3btVBrcOOHTv066py7gEDBkhiYqJ07dpVfvjhB7fv/eijj+Sss84Sq9UqLVu2lBdffNHtebVNHft1110nqampcvPNNzt/j//85z/Svn17/drDhw+XU6dOyaxZs/T31K1bV/785z+LzWZzvpbFYpFLLrlEPvjgg3LHFQgXBN0AAABABUaMGKEDw/nz5zu3HTp0SAeU119/fbnfO3LkSLn33nt10Lp37159U9scJk6cqIPudevWyQ033FCpv4XKAl977bVy5513SlZWlsyYMUMHuU8//bTP71myZIm0a9dO6tSpU+a5Rx55RO677z5ZvXq13mf06NHOAP7nn3+Wq6++WkaNGqWPUZXKqxJwx4UDh+eff146deqk91fPK7m5ufLXv/5VZs+eLV988YV8++23MmzYMFmwYIG+/fOf/9Ql7//+97/dXuvss8+WpUuXVmosgFAXU9sHAAAAAIS6hIQEueaaa+Stt97SAbjy3nvvSWZmpvTv37/C701OTpaYmBhp3LhxmefV61Y22HZQwbWa9zx27Fj9WGW6n3rqKXnggQd0EO+NympnZGR4fU4F3I4MuMqYqwsEKiveoUMHmTp1qgwaNMgZSKugXAX6KshWmW2HgQMH6tdx+O9//6vL5adPny5t2rTR21SmWwXa+/fv12PSsWNHnWH/5ptv3C5ENG3aVLKzs/W8brOZPCHCG+9gAAAAoBJUyfSXX34pu3fv1o9VAK6CTs+y76rq1atXlb9HZZOffPJJHbg6bur4VBZdZZe9OX36tC5F96ZLly7O+02aNNFfDxw4oL9u3LixTOM19XjLli1uZeHefg9VUu4IuJVGjRrpsnJ1vK7bHD/L9UKFCrg9y/mBcESmGwAAAKiE7t276/nOan734MGDdam1mlddU2outyuV2TUMo9wGayogVRlpVartyVdgXb9+fX3M3sTGxjrvOy4iOLqHq2PxvLDgeXzefg/P13W8trdtnp3Kjxw5ogN2FXwD4Y6gGwAAAKgk1fl72rRpOtt9wQUXSLNmzSr1fXFxcW5Z4fI0aNBATpw4oRuOOQJZNdfaVY8ePWTz5s16ze2qXDRQpd7egujyqBJwVSruatmyZbrMXDU9C4T169fr3xGIBJSXAwAAAJU0ZswYHXD/7W9/q9I8bFVSvX37dh08qwZs5ZVNn3POOTrL+/DDD+t51e+//36ZpmWPP/64zrirpmYbNmzQJeBz5syRRx991OfrqrnTKpBX+1eFagL39ddf6znjv/zyi+48/uqrr7rN3/Y31UTtoosuCtjrA8FE0A0AAABUkur8rZYJU3OSr7jiikqPm/qeIUOG6MBXZbLLWw4rPT1d3n33Xd3du3PnznpfFVy7UuXtqnP6okWLpHfv3nLuuefqhmctWrTw+bpqyTNVjq4awFWFyjj/61//0h3IVXdyFfCr+eSuTdT8SV3UUJn0irrCA+HCZHibkAEAAADAqwsvvFDOPPNMvRRWuFFzulVZvMqgp6SkSCi6//775fjx43opMSASkOkGAAAAKkE191LZ3sWLF8sdd9wRlmOmMufPPfecXj4sVDVs2FCXsgORgkw3AAAAUMl52UePHtXrVXvOZ1brWu/cudPr982YMUPPBQcQnQi6AQAAgBpSAbfnsl6u61CHaik3gMAj6AYAAAAAIECY0w0AAAAAQIAQdAMAAAAAECAE3QAAAAAABAhBNwAAAAAAAULQDQAAAABAgBB0AwAAAAAQIATdAAAAAAAECEE3AAAAAAASGP8PxGg1UhYxqMoAAAAASUVORK5CYII=",
      "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.208e-05 @ epoch 437\n",
      "\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 270 rows, 6752 columns and 13516 nonzeros\n",
      "Model fingerprint: 0x531f6f7d\n",
      "Variable types: 6740 continuous, 12 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [2e-01, 1e+00]\n",
      "  Objective range  [1e+00, 1e+09]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [1e+00, 7e+01]\n",
      "Warning: Model contains large objective coefficients\n",
      "         Consider reformulating model or setting NumericFocus parameter\n",
      "         to avoid numerical issues.\n",
      "Found heuristic solution: objective 1.086612e+11\n",
      "Presolve removed 0 rows and 3250 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 270 rows, 3502 columns, 7015 nonzeros\n",
      "Found heuristic solution: objective 1.044451e+11\n",
      "Variable types: 3490 continuous, 12 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 7.307342e+05, 129 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    730734.19862 730734.199  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (129 simplex iterations) in 0.01 seconds (0.01 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 730734 1.04445e+11 1.08661e+11 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 7.307341986197e+05, best bound 7.307341986197e+05, gap 0.0000%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=730734  ip_y=730734  rel_err=1.007e-07\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2048, 12)  mean(mean)=9.97  std(mean)=6.07  min=0  max=20\n",
      "  y: shape=(2048,)  mean=1.21e+06  std=2.09e+05  min=4.92e+05  max=1.88e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MLP ===\n",
      "  data: N=2048  train/val/test=1434/307/307  dim=12\n",
      "  model: params=18,305 hidden=[128, 128]\n",
      "  train: device=cpu  epochs=500  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQABAABJREFUeJzsnQWcG2X6x3+xtdrWvaVCC6WlFFq0+CGFw93d3Y/DDv7HoYfc4Yced7jr4bRAkbbUoFSpu65vbOb/ed5kkndm3plMstnd7O7z/XzSJpPJ5J1JNjO/9/eIT9d1HQzDMAzDMAzDMAzD5B1//jfJMAzDMAzDMAzDMAyLboZhGIZhGIZhGIZpRNjpZhiGYRiGYRiGYZhGgkU3wzAMwzAMwzAMwzQSLLoZhmEYhmEYhmEYppFg0c0wDMMwDMMwDMMwjQSLboZhGIZhGIZhGIZpJFh0MwzDMAzDMAzDMEwjwaKbYRiGYRiGYRiGYRoJFt2NxPPPPw+fz+d4+/rrr9GcLFmyRIzj/vvvb9DrVbdXXnnFtv7vv/+Oo48+GuXl5Wjfvj0OOOAA/Pzzz8pt0+t32GEHlJSUoE+fPrjyyitRXV2tXDcej6NHjx548MEHxeMzzzxTOaZtttlG+fp//vOf4rni4mIMGjQIt99+O6LRqG29devWiW1369YNZWVl2G233fDFF19kdaya4zOnMW+11Vae1qMxdujQQXmsly5dCr/fL9b5y1/+Ynrut99+w2mnnYbBgweLz4yO0Y477ohLL70UlZWVtvdwuuWDm2++GX/84x/Rt29fsU16T6/MmDEDhx56KAYMGIDS0lJ06dJFfM7/+c9/bOu67Yf8Xcv0O3D33Xcj33j9TluPG41n5MiRWb3X/vvvjwsvvBAtlb322kv8vjAMU9gcddRR4nd5y5YtjuuccsopCIVCWLt2reftqs5phcDf/vY3vPPOO7blc+bMEeOl64qm5t///je6d++OqqqqJnvPFStWiN/ovffeW1w/0udF51UrdK1x5513Yp999kGvXr3EdeaoUaNwzz33oL6+3rb+woULxXWLcb4fMmQIrr76amzcuNG0Hq1z5JFHNuo+Mm2HYHMPoLXz3HPPKQXfiBEj0Bq47LLLcPLJJ5uWbb311qbH69evx5577onOnTvj2WefFcLsrrvuEj+OU6ZMwfDhw1Pr/ve//8Wpp56Kc889Vwjp+fPn44YbbhAnmk8//dT2/pMmTRLbJ0FvQD+gX375pWk9WmaFfqBvueUW/OlPf8KBBx4oxkLiY+XKlXjqqadS64XDYSEu6GT/8MMPC5H/6KOP4uCDD8bnn38uTgatAbpYicViePXVV3HOOefYvsckyGURTUyfPh177LEHtt12W9x6661C4G/YsAEzZ84UkyfXXnstOnbs6PrZ5BP6zmy//fY4/PDDxXctG+jz7d+/P0466SQh2mtqasT3kU66dIFD3w2D77//3vb6H3/8UVwc0MWhAYl41bp0rD777DPTuvnA63faOtlAk289e/bM6r3effddfPfdd+JCrKXyf//3f2IC8KKLLjL9DjEMU1jQOYlE6EsvvYSLL77Y9nxFRQXefvttMema7W9ZIUKi+9hjj7UJProWoolUun7yMqGeL2pra/HnP/9ZXI/RtUBTQeKYzsNkxBxyyCF4+eWXlestW7YMDz30kDhfk3gm0f3NN9+ICQo619LNmNyna8Zdd91VXJvQOYCEN13L3Hbbbfjqq68wbdo0YTIQ9Hq6hqfrlv3226/J9ptppehMo/Dcc8/pdHinTJlSkEd48eLFYnz33Xdfo7/+uuuu00OhkL5kyZLUsoqKCr1bt2768ccfn1oWi8X03r176wceeKDp9f/973/Fe3300Ue2bV988cX62LFjU4/POOMMvV27dhnHtGHDBr2kpEQ///zzTcvvvPNO3efz6b/++mtq2aOPPiref/Lkyall0WhUHzFihL7zzjt7PlZfffWV3tTQ8Rg4cKCn9ei4nXjiifruu+9uek7TNLGN8847T+zHbbfdlnru9NNPF6+rrKxUbpdea32PxiQej6fu03vRezaUXXbZRe/fv3/G9c4880zx3VmwYIHretXV1Xr79u318ePH6/kkm++0/D3eYYcd9Msvv1zfe++99e22287z+9F3n74vzUFNTU3etjVy5Ejx3WYYpnCh64M+ffroO+20k/L5xx9/XJyf3n///ay2az2nFQpO56/XX3+9Ua4nMv2mPvbYY+L8snnzZr0pkc/pdD1N+07X16rzKt2s0DUqveabb75JLfvXv/4lln3++eemdf/2t7+J5T///LNp+R//+Ef9gAMOyNMeMW0ZDi8vAGj2jUJxn3zySQwbNkyEhZITrgrT/uWXX3DEEUcI15gcY5r9e+GF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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.358e-05 @ epoch 495\n",
      "\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 1282 rows, 781 columns and 20365 nonzeros\n",
      "Model fingerprint: 0x2f96ba4d\n",
      "Variable types: 513 continuous, 268 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [5e-06, 3e+02]\n",
      "  Objective range  [2e+05, 2e+05]\n",
      "  Bounds range     [6e-01, 3e+02]\n",
      "  RHS range        [3e-04, 3e+02]\n",
      "Presolve removed 300 rows and 32 columns\n",
      "Presolve time: 0.05s\n",
      "Presolved: 982 rows, 749 columns, 19206 nonzeros\n",
      "Variable types: 494 continuous, 255 integer (243 binary)\n",
      "\n",
      "Root relaxation: objective 4.881833e+05, 395 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 488183.312    0  111          - 488183.312      -     -    0s\n",
      "H    0     0                    736281.33241 488337.182  33.7%     -    0s\n",
      "     0     0 577611.726    0  149 736281.332 577611.726  21.6%     -    0s\n",
      "     0     0 621139.836    0  144 736281.332 621139.836  15.6%     -    0s\n",
      "     0     0 621179.299    0  145 736281.332 621179.299  15.6%     -    0s\n",
      "     0     0 621181.825    0  145 736281.332 621181.825  15.6%     -    0s\n",
      "     0     0 669306.728    0  132 736281.332 669306.728  9.10%     -    0s\n",
      "     0     0 670136.089    0  131 736281.332 670136.089  8.98%     -    0s\n",
      "H    0     0                    734132.95582 670600.945  8.65%     -    0s\n",
      "     0     0 680369.626    0   86 734132.956 680369.626  7.32%     -    0s\n",
      "     0     0 686113.411    0  111 734132.956 686113.411  6.54%     -    0s\n",
      "     0     0 686306.970    0  108 734132.956 686306.970  6.51%     -    0s\n",
      "     0     0 686315.454    0  109 734132.956 686315.454  6.51%     -    0s\n",
      "     0     0 697927.857    0  116 734132.956 697927.857  4.93%     -    0s\n",
      "     0     0 701361.263    0  118 734132.956 701361.263  4.46%     -    0s\n",
      "     0     0 701567.639    0  121 734132.956 701567.639  4.44%     -    0s\n",
      "     0     0 701610.430    0  117 734132.956 701610.430  4.43%     -    0s\n",
      "     0     0 704731.275    0  121 734132.956 704731.275  4.00%     -    0s\n",
      "     0     0 705309.059    0  123 734132.956 705309.059  3.93%     -    0s\n",
      "     0     0 705439.398    0  123 734132.956 705439.398  3.91%     -    0s\n",
      "     0     0 705585.972    0  123 734132.956 705585.972  3.89%     -    0s\n",
      "     0     0 705596.572    0  123 734132.956 705596.572  3.89%     -    0s\n",
      "     0     0 706525.660    0  121 734132.956 706525.660  3.76%     -    1s\n",
      "     0     0 706785.888    0  123 734132.956 706785.888  3.73%     -    1s\n",
      "     0     0 706872.335    0  123 734132.956 706872.335  3.71%     -    1s\n",
      "     0     0 708788.374    0  117 734132.956 708788.374  3.45%     -    1s\n",
      "     0     0 709613.459    0  121 734132.956 709613.459  3.34%     -    1s\n",
      "     0     0 709771.687    0  118 734132.956 709771.687  3.32%     -    1s\n",
      "     0     0 709911.707    0  119 734132.956 709911.707  3.30%     -    1s\n",
      "     0     0 709957.942    0  116 734132.956 709957.942  3.29%     -    1s\n",
      "     0     0 711614.754    0  118 734132.956 711614.754  3.07%     -    1s\n",
      "H    0     0                    733878.60171 711981.143  2.98%     -    1s\n",
      "H    0     0                    733872.48576 711981.143  2.98%     -    1s\n",
      "     0     0 711981.143    0  117 733872.486 711981.143  2.98%     -    1s\n",
      "     0     0 712158.140    0  117 733872.486 712158.140  2.96%     -    1s\n",
      "     0     0 712181.843    0  118 733872.486 712181.843  2.96%     -    1s\n",
      "     0     0 712863.483    0  119 733872.486 712863.483  2.86%     -    1s\n",
      "H    0     0                    733849.14495 712863.483  2.86%     -    1s\n",
      "H    0     0                    733616.70102 712863.483  2.83%     -    1s\n",
      "     0     0 714724.647    0  112 733616.701 714724.647  2.58%     -    1s\n",
      "     0     0 714724.647    0   70 733616.701 714724.647  2.58%     -    1s\n",
      "     0     0 718901.100    0  102 733616.701 718901.100  2.01%     -    2s\n",
      "     0     0 721922.247    0  101 733616.701 721922.247  1.59%     -    2s\n",
      "     0     0 722012.430    0   98 733616.701 722012.430  1.58%     -    2s\n",
      "     0     0 722185.449    0   90 733616.701 722185.449  1.56%     -    2s\n",
      "     0     0 722208.665    0   95 733616.701 722208.665  1.56%     -    2s\n",
      "     0     0 722219.561    0   95 733616.701 722219.561  1.55%     -    2s\n",
      "     0     0 722238.170    0   97 733616.701 722238.170  1.55%     -    2s\n",
      "     0     0 722258.055    0   97 733616.701 722258.055  1.55%     -    2s\n",
      "     0     0 723697.275    0  104 733616.701 723697.275  1.35%     -    2s\n",
      "     0     0 724227.310    0  108 733616.701 724227.310  1.28%     -    2s\n",
      "     0     0 724354.332    0  104 733616.701 724354.332  1.26%     -    2s\n",
      "     0     0 724381.437    0  105 733616.701 724381.437  1.26%     -    2s\n",
      "     0     0 724385.950    0  108 733616.701 724385.950  1.26%     -    2s\n",
      "     0     0 724809.808    0  109 733616.701 724809.808  1.20%     -    2s\n",
      "     0     0 724894.796    0  106 733616.701 724894.796  1.19%     -    2s\n",
      "     0     0 724929.628    0  109 733616.701 724929.628  1.18%     -    2s\n",
      "     0     0 724959.376    0  109 733616.701 724959.376  1.18%     -    2s\n",
      "     0     0 725560.245    0  109 733616.701 725560.245  1.10%     -    2s\n",
      "     0     2 726932.088    0  109 733616.701 726932.088  0.91%     -    2s\n",
      "H   34     6                    733579.01875 728692.001  0.67%  39.6    2s\n",
      "*  521   296              53    733200.47019 729847.379  0.46%  14.8    3s\n",
      "*  840   426              68    732986.88749 729847.379  0.43%  13.4    3s\n",
      "H 1173   460                    732821.29193 731359.522  0.20%  14.6    3s\n",
      "\n",
      "Cutting planes:\n",
      "  Learned: 17\n",
      "  Gomory: 47\n",
      "  Cover: 10\n",
      "  Implied bound: 63\n",
      "  Clique: 1\n",
      "  MIR: 311\n",
      "  Flow cover: 3\n",
      "  Inf proof: 6\n",
      "  RLT: 136\n",
      "  Relax-and-lift: 41\n",
      "  PSD: 1\n",
      "\n",
      "Explored 2817 nodes (45188 simplex iterations) in 3.55 seconds (6.17 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 732821 732987 733200 ... 736281\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 7.328212919259e+05, best bound 7.328212919259e+05, gap 0.0000%\n",
      "[CHECK MLP] obj(x_ip)=732821  ip_y=732821  rel_err=5.721e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2048, 12)  mean(mean)=9.97  std(mean)=6.07  min=0  max=20\n",
      "  y: shape=(2048,)  mean=1.21e+06  std=2.09e+05  min=4.92e+05  max=1.88e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | MaxAffine ===\n",
      "  data: N=2048  train/val/test=1434/307/307  dim=12\n",
      "  model: params=13,000 n_pieces=1000\n",
      "  train: device=cpu  epochs=500  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAvYZJREFUeJzs3Qd4U2UXB/B/k07a0gJl7733UPaSqShT3KKIH4IKooh74AAXQ2W4cQKyVARkKXuVUVbZFFpGGQUK3Svfc9407U2adJE0bfr/PU9oxm1yexNy77nnvOd1MxgMBhARERERERGR3ens/5RERERERERExKCbiIiIiIiIyIGY6SYiIiIiIiJyEAbdRERERERERA7CoJuIiIiIiIjIQRh0ExERERERETkIg24iIiIiIiIiB2HQTUREREREROQgDLqJiIiIiIiIHIRBt4PMmzcPbm5uNi8bNmyAM505c0atx6effnpbv2/tsmDBgizLnz59GoMHD0ZgYCD8/PzQq1cv7N271+pzy++3aNEC3t7eqFSpEsaPH4+YmBiry6ampqJcuXKYPn26uj1ixAir69SgQQOrv//FF1+ox7y8vFCzZk28++67SE5OzrLc5cuX1XMHBQWhRIkSaN++PdavX5+nbeWM91zWuUaNGrlaTtbR39/f6rY+e/YsdDqdWuadd94xe+zIkSN49NFHUatWLfWeyTZq1aoVnn32Wdy8eTPLa9i62Nu6desynvvq1as5Lv/vv//iySefVJ8HX19fVK5cGffddx/27NljdXn5nEybNg1NmzaFj4+P+mx36NAB27Zts7r95Lnl8yyfNXnuQYMGwRFy+5kWf/75J7p27YqSJUuqv7lx48b4+uuvc/1aPXv2xOjRo1FUdenSRX2/EFHhJt+X8j1748YNm8s8/PDD8PDwwKVLl3L9vNb2aYXBhx9+iD/++CPL/aGhoWp95biioP30008oW7Ysbt26VWCvee7cOfUdLfsp2cfK+yXH15bkWOODDz5At27dUKFCBXWcKfvmjz76CAkJCVmWP3nypDpuqVatmvpc1a5dGxMmTEBUVJTZcrLMwIEDHfo3UvHh7uwVcHU//PCD1YCvUaNGcAXPPfccHnroIbP76tata3b7ypUr6Ny5M0qVKoXvv/9eBWZTpkxRX47BwcGoX79+xrK//vorHnnkETz11FMqkD5+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RMcno2nlAPz9fCc82K5akWmWViyC7oIa023iodfhsd534ofUvup26pq3gNTkAnltIiIiIiIiVxAScQN3f74ZC3dHQOLrMd1qY8kzHVC7rB9chcsE3QU5pttkQPNKWFP6QUQZ/KG/dhLY+2OBvTYREREREVFRlZpmwJf/nsCQOdtwJioOlQK8MX/UnXi5bwM1nNeVuNZfU8Ckk/kzfVphRsoQdTtN5u1OuOns1SIiIjupUaMGZsyYwe1JRERkR+eux+HBr3fg0zXHVfB9d7OKWDWuC+6sVcYltzOD7tsk3fQOVxiEU2kVoYu/CmzlwRkREREREZE1f4acR7+Zm7HrzDX4eurx2bDm+PLBlggo4eGyG4xB922Sgf0v9G2MqSkPqttp22YB0eft8d4QERERERG5hJsJyXhhYQjGLQjBrYQUtKwWiJXjOmNI6you0SytWATdBd1ITatTnSDE1eyNnWkNoEtNAP59r8DXgYiIzH311VeoXLky0tLSzO6/99578fjjj+PUqVO47777UL58efj5+an9x7p167gZiYiI7Gz3mWvoP3Mzlu07D50bMK5nXSz6X3tUL+NbLLa1ywTdzmikZiJnZl6/uzE+THlY3TbsXwBEHizw9SAiKhAGA5AU65yLvHYuDRs2DFevXsV///2Xcd/169exevVqPPzww4iJiUH//v1VoL1v3z706dMHAwYMQHh4uIM2HBERUfGSkpqGaWuP4/6vtuPc9XhUKeWDRaPb44Ve9eCud5lQNEfuzl4BV9GoUknUb9UVy/ffiQH6HTCsewdujyxx9moREdlfchzwYSXnbNnXLgCeuTsrXrp0afTt2xe//fYbevbsqe5btGiRul9u6/V6NG/ePGP5999/H8uWLcNff/2FZ5991mF/AhERUXFwNioW4xeGYF/4DXV7cMvKePe+xvD3dt2x27YUn9MLBeDF3vXxpduDSDLo4XZyHXAqM7tCREQFTzLaS5YsQWJiorr966+/4oEHHlABd2xsLF5++WU1NCkwMFCVmB89epSZbiIiottgMBiweM85VU4uAbe/tztmPtAC04a3KJYBt2Cm247Kl/TG3V074tf/7sIT7quRtuYt6P63EdDx3AYRuRCPEsaMs7NeOw+kXFzGdK9YsUKN2d68eTOmTZumHps4caIqNf/0009Rp04d+Pj4YOjQoUhKSnLQyhMR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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.276e-06 @ epoch 326\n",
      "\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  500\n",
      "\n",
      "Optimize a model with 1001 rows, 13 columns and 13012 nonzeros\n",
      "Model fingerprint: 0xfb736624\n",
      "Variable types: 1 continuous, 12 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [6e-04, 1e+00]\n",
      "  Objective range  [2e+05, 2e+05]\n",
      "  Bounds range     [2e+01, 2e+01]\n",
      "  RHS range        [5e+00, 7e+01]\n",
      "Found heuristic solution: objective 742743.11171\n",
      "Presolve time: 0.00s\n",
      "Presolved: 1001 rows, 13 columns, 13012 nonzeros\n",
      "Variable types: 1 continuous, 12 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 7.322284e+05, 9 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 732228.374    0    4 742743.112 732228.374  1.42%     -    0s\n",
      "H    0     0                    732335.06700 732228.374  0.01%     -    0s\n",
      "H    0     0                    732248.09998 732228.374  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (9 simplex iterations) in 0.02 seconds (0.04 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 3: 732248 732335 742743 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 7.322480999809e+05, best bound 7.322283737939e+05, gap 0.0027%\n",
      "[CHECK MaxAffine] obj(x_ip)=732248  ip_y=732248  rel_err=5.119e-08\n",
      "\n",
      "--- Dataset stats (mdvsp) ---\n",
      "  X: shape=(2048, 12)  mean(mean)=9.97  std(mean)=6.07  min=0  max=20\n",
      "  y: shape=(2048,)  mean=1.21e+06  std=2.09e+05  min=4.92e+05  max=1.88e+06\n",
      "\n",
      "\n",
      "=== Run: mdvsp | LSET ===\n",
      "  data: N=2048  train/val/test=1434/307/307  dim=12\n",
      "  model: params=13,000 n_pieces=1000 T=0.05\n",
      "  train: device=cpu  epochs=500  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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929CCCGxev+OOdEtgrtz586N3QxCCCGk1uzYsQOdOnVqlj3H+zchhJBYvX/HnOgWC7e241IOhhBCCIl2ioqK1ICxdg9rjvD+TQghJFbv3zEjuqdNm6Ymt9utPovgpugmhBDSlGjOYVHavvP+TQghJNbu3zETODZx4kSsWbMGCxcubOymEEIIIYQQQgghsSW6CSGEEEIIIYSQaIOimxBCCCGEEEIIqSdiJqabEEJI/Zd0cjqd7OZDID4+Hg6Hg31HCCGENEMougkhhNSIiO2tW7cq4U0OjaysLLRr165ZJ0sjhBBCmiNRKbrPO+88/Pzzzxg7diw+/vjjxm4OIYQ0a7xeL3Jzc5WlVspi2O2MTKpt/5WVlSEvL099bt++fT0dKUIIIYREI1Epum+77Tb8+c9/xr/+9a/GbgohhDR7qqqqlGjs0KEDUlJSmn1/HArJycnqVYR3mzZt6GpOCCGENCOi0lwxZsyYGguME0IIaRjcbrd6TUhIYJcfBtqAhcvlYj8SQgghzYg6F91z5szBWWedpSwiErf22Wefhazz0ksvoXv37khKSsKwYcMwd+7cum4GIYSQOoaxyOw/QgghpCmzNOcAZizZqV6btOguLS3F4MGD8eKLL1ounz59OiZNmoQHHngAS5cuxahRo3DGGWcgJycH0RyPRwghhBBCCCGkafLEN2tx3ku/YvKHy9WrfG6yolsE9N///necf/75lsunTp2Ka665Btdeey369u2L559/XiXmefnllw9pe5WVlSgqKjJMdcXqdevw3tTJmPHivXX2nYQQQpom3bp1U/csQgghhDQtluYcwCuztxjmyeeGsnjbG7rkzOLFi3HaaacZ5svnX3/99ZC+c8qUKcjMzAxMIuDrirSijbi06E2cWDAdFU7G4BFCSFNj9OjRyruqLli4cCGuv/76OvkuQgghhDQcq3YVWs7fWlAae6K7oKBAJeRp27atYb583rNnT+DzuHHjMH78eHz99dfo1KmTetAJx3333YfCwsLAtGPHjjprb5ehp6EEKWhtO4g1C3+ss+8lhBASPeFDkp09Elq3bs3s7YQQQkgT49fNBXj++42Wy7pnp8Zu9nJzMh556NHPmzlzJvLz81WJmp07d2LEiBFhvysxMREZGRn497//jWOOOUbV9q6zdsYlYnPmsep96YrP6+x7CSGE1D9XXXUVZs+e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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.972e-06 @ epoch 305\n",
      "\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 500\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  500\n",
      "FeasibilityTol  1e-09\n",
      "IntFeasTol  1e-09\n",
      "OptimalityTol  1e-09\n",
      "NumericFocus  3\n",
      "\n",
      "Optimize a model with 3004 rows, 3017 columns and 19018 nonzeros\n",
      "Model fingerprint: 0x94859666\n",
      "Model has 1001 function constraints treated as nonlinear\n",
      "  1000 EXP, 1 LOG\n",
      "Variable types: 3005 continuous, 12 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [3e-02, 2e+05]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-12, 2e+06]\n",
      "  RHS range        [7e+01, 1e+06]\n",
      "Warning: x < 1e-10 in domain of log(x).\n",
      "         Setting lower bound to 1e-10.\n",
      "Presolve removed 2002 rows and 1002 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 6007 rows, 2016 columns, 25023 nonzeros\n",
      "Presolved model has 1001 nonlinear constraint(s)\n",
      "\n",
      "Solving non-convex MINLP\n",
      "\n",
      "Variable types: 2004 continuous, 12 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 4.891348e+05, 1078 iterations, 0.01 seconds (0.05 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 489134.818    0  897          - 489134.818      -     -    0s\n",
      "     0     2 489134.980    0  897          - 489134.980      -     -    0s\n",
      "  3438  2897 717769.854   36    5          - 489233.599      -  19.8    5s\n",
      "  6563  3180 732130.006   25  903          - 519967.303      -  16.6   10s\n",
      "*11068  1489              19    732785.18045 653024.832  10.9%  14.5   12s\n",
      "*11310   928              54    708097.40648 653024.832  7.78%  14.4   12s\n",
      "*11392   928              39    707878.90709 653024.832  7.75%  14.3   12s\n",
      "*11499   601              42    707862.91029 653081.591  7.74%  14.2   12s\n",
      "*11737   601              38    707845.32128 665549.286  5.98%  13.9   12s\n",
      "*11964  1279              45    707826.10497 686219.012  3.05%  13.6   12s\n",
      "*11968  1279              46    707817.62899 686219.012  3.05%  13.6   12s\n",
      "*12000  1279              46    707359.06425 686219.012  2.99%  13.6   12s\n",
      "*12297  1279              55    707345.13019 686219.012  2.99%  13.3   12s\n",
      "*12310  1279              43    707173.13641 686219.012  2.96%  13.3   12s\n",
      "*12483  1279              49    700892.61854 686238.477  2.09%  13.1   12s\n",
      "*13024   488              47    699361.26877 686238.477  1.88%  12.6   12s\n",
      "*13453   488              57    697915.27299 686238.477  1.67%  12.2   12s\n",
      "*13454   488              56    697880.13610 686238.477  1.67%  12.2   12s\n",
      "\n",
      "Explored 14746 nodes (165238 simplex iterations) in 13.03 seconds (48.96 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 697880 697915 699361 ... 707845\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 6.978801360970e+05, best bound 6.978801360970e+05, gap 0.0000%\n",
      "[CHECK LSET] obj(x_ip)=737013  ip_y=697880  rel_err=5.310e-02\n",
      "\n",
      "=== MODEL SPECS (from seed 0 run) ===\n",
      "    model  n_params                                                 details    lr  batch_size  epochs\n",
      "      DFN     17203 layers=[32, 64, 32] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8     500\n",
      "DFN_AfixI     13324  layers=[6, 256, 7] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8     500\n",
      "     LSET     13000                                    n_pieces=1000 T=0.05 0.001           8     500\n",
      "      MLP     18305                                       hidden=[128, 128] 0.001           8     500\n",
      "MaxAffine     13000                                           n_pieces=1000 0.001           8     500\n",
      "\n",
      "=== LEARNING SUMMARY (mean ± SE over seeds) ===\n",
      "    model  train_time        best_val            test\n",
      "      DFN 2986.67 ± 0  0.00118061 ± 0  0.00111334 ± 0\n",
      "DFN_AfixI 1135.79 ± 0 2.20799e-05 ± 0 1.94325e-05 ± 0\n",
      "     LSET 87.4882 ± 0 1.97166e-06 ± 0   4.741e-06 ± 0\n",
      "      MLP 72.7934 ± 0 1.35833e-05 ± 0 1.27355e-05 ± 0\n",
      "MaxAffine 73.4469 ± 0 2.27611e-06 ± 0 8.37672e-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  [5, 0, 20, 0, 5, 0, 20, 0, 0, 9, 13, 1] 719751 ± 0 735450 ± 0   3.98551 ± 0  [6, 0, 20, 0, 5, 0, 20, 0, 0, 9, 13, 0] 719755 ± 0 735490 ± 0  0.259319 ± 0 [4, 2, 8, 0, 13, 7, 6, 6, 1, 14, 7, 5] 733610 ± 0 503.69 ± 0 -0.000604028 ± 0    0.256267 ± 0\n",
      "DFN_AfixI [0, 0, 0, 0, 20, 13, 20, 0, 0, 20, 0, 0] 730734 ± 0 734406 ± 0   2.18533 ± 0 [0, 0, 0, 0, 20, 13, 20, 0, 0, 20, 0, 0] 730734 ± 0 734406 ± 0 0.0583755 ± 0 [4, 2, 8, 0, 13, 7, 6, 6, 1, 14, 7, 5] 733610 ± 0 503.69 ± 0 -1.00748e-05 ± 0    0.108505 ± 0\n",
      "     LSET  [0, 0, 0, 3, 14, 12, 8, 4, 0, 8, 7, 17] 732577 ± 0 733620 ± 0 0.0732396 ± 0 [0, 3, 0, 2, 16, 16, 20, 0, 0, 11, 0, 5] 697880 ± 0 734106 ± 0   13.1067 ± 0 [4, 2, 8, 0, 13, 7, 6, 6, 1, 14, 7, 5] 733610 ± 0 503.69 ± 0      4.97177 ± 0   0.0676109 ± 0\n",
      "      MLP [0, 0, 0, 0, 20, 0, 20, 0, 0, 20, 0, 13] 732843 ± 0 734380 ± 0  0.064556 ± 0 [20, 0, 0, 0, 0, 0, 20, 0, 13, 0, 0, 20] 732821 ± 0 735486 ± 0   3.62022 ± 0 [4, 2, 8, 0, 13, 7, 6, 6, 1, 14, 7, 5] 733610 ± 0 503.69 ± 0   0.00302196 ± 0    0.255722 ± 0\n",
      "MaxAffine  [0, 0, 0, 0, 19, 0, 20, 0, 0, 20, 6, 8] 732238 ± 0 734150 ± 0 0.0708719 ± 0  [0, 0, 0, 1, 19, 0, 20, 0, 0, 20, 6, 7] 732248 ± 0 734130 ± 0 0.0730225 ± 0 [4, 2, 8, 0, 13, 7, 6, 6, 1, 14, 7, 5] 733610 ± 0 503.69 ± 0  -0.00143906 ± 0   0.0708823 ± 0\n",
      "\n",
      "=== FAILURES / WARNINGS (if any) ===\n",
      " seed model    stage                          error\n",
      "    0  LSET IP_CHECK rel_err=5.310e-02 (tol=0.0001)\n"
     ]
    }
   ],
   "source": [
    "# ===================== MDVSP DATASET =====================\n",
    "N_SEEDS = 1\n",
    "VARY_DATASET_SEED = True\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "SILENCE_LOCAL_SEARCH = True\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "dataset_type = \"mdvsp\"\n",
    "dataset_params = dict(\n",
    "    K=2048,\n",
    "    filename=\"RN-12-3000-05.dat\",\n",
    "    x_min=0,\n",
    "    x_max=20,\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=500,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=\"cpu\",\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=10,\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=[32, 64, 32], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=-2.0\n",
    ")\n",
    "\n",
    "# ---- DFN (fixed A = I) ----\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=[6, 256, 7],\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=1000)\n",
    "lset_params = dict(in_dim=in_dim, n_pieces=1000, T=0.05)\n",
    "\n",
    "lr_map = dict(DFN=1e-1, MLP=1e-3, MaxAffine=1e-3, LSET=1e-3)\n",
    "time_limit = 500\n",
    "\n",
    "# x0 + sum_eq are generated per seed so the run seed controls them too\n",
    "x0_list = []\n",
    "sum_eq_list = []\n",
    "for seed in range(int(N_SEEDS)):\n",
    "    rng = np.random.default_rng(int(seed))\n",
    "    x0_s = rng.integers(0, 15, size=in_dim, dtype=int)\n",
    "    x0_list.append(x0_s)\n",
    "    sum_eq_list.append(int(x0_s.sum()))\n",
    "x0 = x0_list[0] if int(N_SEEDS) == 1 else np.stack(x0_list, axis=0)\n",
    "sum_eq = sum_eq_list[0] if int(N_SEEDS) == 1 else sum_eq_list\n",
    "delta = 2\n",
    "\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
}