{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "96398989-280e-41b3-bc11-99b4b51e9439",
   "metadata": {},
   "source": [
    "# General Helpers"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "767d34c9-66bd-4986-a324-4daeec80aee1",
   "metadata": {},
   "source": [
    "### Imports"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "bef302bd-4ca0-4269-9ba1-ac6d05ef5819",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "from pathlib import Path\n",
    "import numpy as np\n",
    "import cppimport\n",
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import math\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from IPython.display import clear_output, display\n",
    "import ipywidgets as widgets\n",
    "import time\n",
    "\n",
    "_TOL = 1e-9"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3cd5a10c-7768-4318-8244-beaf6c4c84d1",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### Python Implementation of LEMON "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b4658685-aab5-4c45-aa6d-36e862bbdc9a",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "repo = Path().resolve().parent\n",
    "sys.path.insert(0, str(repo))\n",
    "lemon_mcf = cppimport.imp(\"lemon_mcf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1ff805be-adf0-44c9-a12c-d4d2fb077251",
   "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": [
    "# ----- Example of Usage 1 ------ #\n",
    "\n",
    "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",
    "# ----- Example of Usage 2 ------ #\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": "b2d023ed-4551-4a12-895b-5499538ccfe3",
   "metadata": {},
   "source": [
    "# Generating Datasets"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4689d09-9931-4210-9834-9cfa0e9ef08c",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### Multiple-Depot Vehicle Scheduling"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f137ed20-30ef-41a6-97f5-088d39d7f81e",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def make_mdvsp_dataset(K, filename, x_min, x_max, noise_std=0.0, seed=0, max_trips=None, max_succ=None):\n",
    "    rng = np.random.default_rng(seed)\n",
    "\n",
    "    with open(filename) as f:\n",
    "        m, n, l = map(int, f.readline().split()); f.readline()\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; ntr = len(trips)\n",
    "    SS=0; depS=1+np.arange(m); depT=1+m+np.arange(m)\n",
    "    trS=1+2*m+np.arange(ntr); trT=1+2*m+ntr+np.arange(ntr)\n",
    "    TT=1+2*m+2*ntr; N=TT+1\n",
    "\n",
    "    src, dst, cost, cap = [], [], [], []\n",
    "    for d in range(m):\n",
    "        src += [SS, int(depT[d])]; dst += [int(depS[d]), TT]; cost += [0.,0.]; cap += [0.,0.]\n",
    "    idxSS, idxTT = np.arange(0,2*m,2), np.arange(1,2*m,2)\n",
    "\n",
    "    src += trS.tolist(); dst += trT.tolist(); cost += [0.]*ntr; cap += [1.]*ntr\n",
    "    for d in range(m):\n",
    "        src += [int(depS[d])]*ntr; dst += trS.tolist()\n",
    "        cost += (5000+10*D[d,p]).astype(float).tolist(); cap += [1.]*ntr\n",
    "        src += trT.tolist(); dst += [int(depT[d])]*ntr\n",
    "        cost += (5000+10*D[q,d]).astype(float).tolist(); cap += [1.]*ntr\n",
    "\n",
    "    order=np.argsort(s); p2,s2=p[order],s[order]\n",
    "    for i in range(ntr):\n",
    "        t=D[q[i],p2]; feas=np.flatnonzero(s2>=e[i]+t)[:(max_succ or ntr)]\n",
    "        j=order[feas]\n",
    "        if j.size:\n",
    "            src += [int(trT[i])]*j.size; dst += trS[j].tolist()\n",
    "            cost += (8*t[feas]+2*(s[j]-e[i])).astype(float).tolist()\n",
    "            cap  += [1.]*j.size\n",
    "\n",
    "    src=np.array(src,np.int64); dst=np.array(dst,np.int64)\n",
    "    cost=np.array(cost,np.float64); cap0=np.array(cap,np.float64)\n",
    "\n",
    "    X = rng.integers(x_min, np.asarray(x_max)+1, size=(K,m)).astype(np.float64)\n",
    "    y = np.empty(K, np.float64)\n",
    "\n",
    "    for k in range(K):\n",
    "        cap = cap0.copy(); cap[idxSS]=X[k]; cap[idxTT]=X[k]\n",
    "        F = lemon_mcf.max_flow(N, src, dst, cap, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N); supply[SS]=F; supply[TT]=-F\n",
    "        y[k] = lemon_mcf.solve_mcf(N, src, dst, cost, cap, supply)[\"total_cost\"] + noise_std*rng.normal()\n",
    "\n",
    "    return X.astype(np.float32), y.astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "37a7e0ec-627f-4e79-835e-450d614ae196",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 8) (50,) [295001.12 202700.17 263610.56 203118.94 212801.83]\n"
     ]
    }
   ],
   "source": [
    "X, y = make_mdvsp_dataset(K=50, filename=\"RN-8-3000-03.dat\", x_min=0, x_max=6, noise_std=1.0, seed=1, max_trips=200, max_succ=5)\n",
    "print(X.shape, y.shape, y[:5])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "49d46a1c-d77b-4e87-984a-1b7cff5cf0db",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### Assignement"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "80f63803-1393-451b-95fb-c3147a6968f3",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def generate_bipartite_subset_matching_dataset(K, num_nodes, c_min, c_max, noise_std=0.0, seed=0):\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",
    "        s = int(rng.integers(1, num_nodes + 1))\n",
    "        idx = rng.choice(num_nodes, size=s, replace=False)\n",
    "        X[k, idx] = 1.0\n",
    "\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        y[k] = C[idx, :][r, c].sum() + noise_std * rng.normal()\n",
    "\n",
    "    return X.astype(np.float32), y.astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "58630247-ccd6-4f88-9bad-06c40e05e81d",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 20) (50,) [27.28291   21.602198   3.5180728 27.081621  16.3313   ]\n"
     ]
    }
   ],
   "source": [
    "X, y = generate_bipartite_subset_matching_dataset(K=50, num_nodes=20, c_min=1, c_max=10, noise_std=0.5, seed=0)\n",
    "print(X.shape, y.shape, y[:5])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9c19ed1a-276c-4f7b-930b-15ee5dd1a087",
   "metadata": {},
   "source": [
    "### Quadratic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "edd30065-8973-4a0f-8315-99a96ac42355",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def generate_convex_quadratic_dataset(K, dim, eigen_min, eigen_max, x_min, x_max, noise_std=0.0, seed=0):\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 = rng.integers(x_min, x_max + 1, size=dim)\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",
    "    return X.astype(np.float32), y.astype(np.float32)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "666e79e4-8daa-483c-995d-6a3b92367b88",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 10) (50,) [4715.296  2633.573  2447.379  1586.9839 3246.9062]\n"
     ]
    }
   ],
   "source": [
    "X, y = generate_convex_quadratic_dataset(K=50, dim=10, eigen_min=1.0, eigen_max=5.0, x_min=-10, x_max=10, noise_std=0.5, seed=0)\n",
    "print(X.shape, y.shape, y[:5])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e1cdd06e-81d1-4f27-a39b-81d540a21241",
   "metadata": {},
   "source": [
    "# Models Definition"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "290dba75-9ccf-40ed-8d18-80430a30e824",
   "metadata": {},
   "source": [
    "### DFN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "27f37d1b-613f-4faa-ad04-df8dfd436170",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class _MCFValue(torch.autograd.Function):\n",
    "    @staticmethod\n",
    "    def forward(ctx, n_nodes, src, dst, cost, cap, supply):\n",
    "        n = int(n_nodes)\n",
    "        src = src.long(); dst = dst.long()\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\")\n",
    "        if torch.abs(supply.double().sum()) > _TOL:\n",
    "            raise ValueError(\"require sum(supply)=0\")\n",
    "\n",
    "        src_np = src.detach().cpu().contiguous().view(-1).numpy().astype(np.int64,  copy=False)\n",
    "        dst_np = dst.detach().cpu().contiguous().view(-1).numpy().astype(np.int64,  copy=False)\n",
    "        c_np   = cost.detach().cpu().contiguous().view(-1).numpy().astype(np.float64, copy=False)\n",
    "        u_np   = cap.detach().cpu().contiguous().view(-1).numpy().astype(np.float64, copy=False)\n",
    "        b_np   = supply.detach().cpu().contiguous().view(-1).numpy().astype(np.float64, copy=False)\n",
    "\n",
    "        out = lemon_mcf.solve_mcf(n, src_np, dst_np, c_np, u_np, b_np, tol=_TOL)\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 - u_np) <= _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  # gauge-fix\n",
    "\n",
    "        return None, None, None, grad_cost*g, grad_cap*g, grad_sup*g"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "0853f854-e747-4afe-bce5-c78e8198a41d",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class DFN(nn.Module):\n",
    "    def __init__(self, input_dim, layer_sizes, p_list, big_cost=1e6, big_cap=1e6,\n",
    "                 seed=0, A_fixed=None, alpha=1e-6, beta=-0.0):\n",
    "        super().__init__()\n",
    "        self.alpha = float(alpha)\n",
    "        self.beta  = float(beta)\n",
    "\n",
    "        layer_sizes = list(map(int, layer_sizes))\n",
    "        K = len(layer_sizes)\n",
    "        if K < 2 or len(p_list) != K-1: raise ValueError(\"need K>=2 and len(p_list)=K-1\")\n",
    "        self.n = sum(layer_sizes)\n",
    "        if self.n <= 0: raise ValueError(\"sum(layer_sizes) must be > 0\")\n",
    "\n",
    "        layers, off = [], 0\n",
    "        for s in layer_sizes:\n",
    "            layers.append(torch.arange(off, off+s, dtype=torch.long)); off += s\n",
    "        L1, LK = layers[0], layers[-1]\n",
    "        if L1.numel()==0 or LK.numel()==0: raise ValueError(\"first/last layer must be non-empty\")\n",
    "        self.fix_node = int(LK[-1].item())\n",
    "\n",
    "        gen = torch.Generator().manual_seed(int(seed))\n",
    "        def bipartite(U, V):\n",
    "            su, sv = int(U.numel()), int(V.numel())\n",
    "            return U.repeat_interleave(sv), V.repeat(su)\n",
    "\n",
    "        # learnable arcs (forward/backward sampled independently)\n",
    "        sf, tf, sb, tb = [], [], [], []\n",
    "        for i, p in enumerate(map(float, p_list)):\n",
    "            if not (0.0 <= p <= 1.0): raise ValueError(\"p_list entries must be in [0,1]\")\n",
    "\n",
    "            s, t = bipartite(layers[i], layers[i+1])  # forward\n",
    "            if p < 1.0:\n",
    "                keep = (torch.rand(s.numel(), generator=gen) < p)\n",
    "                s, t = s[keep], t[keep]\n",
    "            sf.append(s); tf.append(t)\n",
    "\n",
    "            s, t = bipartite(layers[i+1], layers[i])  # backward\n",
    "            if p < 1.0:\n",
    "                keep = (torch.rand(s.numel(), generator=gen) < p)\n",
    "                s, t = s[keep], t[keep]\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: raise ValueError(\"no learnable arcs (increase p_list / layer sizes)\")\n",
    "\n",
    "        # fixed big arcs L1 <-> LK\n",
    "        s1, t1 = bipartite(L1, LK); 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",
    "        boundary = torch.cat([L1, LK[:-1]], 0)\n",
    "        self.register_buffer(\"boundary\", boundary)\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",
    "        ste = lambda z: z + (torch.round(z) - z).detach()\n",
    "\n",
    "        capP  = ste(F.softplus(self.cap_raw))\n",
    "        costP = self.cost_raw\n",
    "        b     = ste(self.b_raw)\n",
    "        A     = ste(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):\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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72c356e0-d483-442b-a32b-49f0d7eab840",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d547b665-8251-45cb-8d9a-ffef58911114",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "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)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e74105b4-7d14-4b4d-9261-160fc4b44827",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### Max-Affine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "0fbc2d7a-4792-47a8-ab0c-6ff991f5492a",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class MaxAffine(nn.Module):\n",
    "    \"\"\"f(x) = max_k (w_k^T x + b_k), returns shape (batch,)\"\"\"\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",
    "        y = x @ self.W.T + self.b\n",
    "        return y.max(dim=1).values"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4b30023b-4802-4f90-b074-026359cf9623",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "### LogSumExp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "4d2e2022-711d-4a9e-bdf7-4ef803bac1f2",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class LSET(nn.Module):\n",
    "    def __init__(self, in_dim: int, n_pieces: int, T: float = 0.01):\n",
    "        super().__init__()\n",
    "        T = float(T)\n",
    "        assert T != 0.0, \"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",
    "        self.T = T\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)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e8a3d912-fa0a-4acc-a12f-10a089f213de",
   "metadata": {
    "jp-MarkdownHeadingCollapsed": true
   },
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "88981c27-e1db-47dc-b051-3bb6fc7ddb63",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def _set_seed(seed: int = 0):\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "def _to_tensor(x, dtype=torch.float32):\n",
    "    if isinstance(x, torch.Tensor): return x.to(dtype)\n",
    "    return torch.as_tensor(x, dtype=dtype)\n",
    "\n",
    "class NormalizedRegressor(nn.Module):\n",
    "    \"\"\"\n",
    "    Wraps a base model trained on normalized (x,y).\n",
    "    Returned model accepts RAW x and outputs RAW y without changing base weights.\n",
    "    \"\"\"\n",
    "    def __init__(self, base: nn.Module, x_mean, x_std, y_mean, y_std, eps=1e-8):\n",
    "        super().__init__()\n",
    "        self.base = base\n",
    "        self.register_buffer(\"x_mean\", _to_tensor(x_mean).view(1, -1))\n",
    "        self.register_buffer(\"x_std\",  _to_tensor(x_std).view(1, -1).clamp_min(eps))\n",
    "        self.register_buffer(\"y_mean\", _to_tensor(y_mean).view(()))\n",
    "        self.register_buffer(\"y_std\",  _to_tensor(y_std).view(()).clamp_min(eps))\n",
    "\n",
    "    def forward(self, x_raw: torch.Tensor) -> torch.Tensor:\n",
    "        x = (x_raw - self.x_mean) / self.x_std\n",
    "        y_norm = self.base(x)\n",
    "        y_norm = y_norm.squeeze(-1)  # supports (B,1) or (B,)\n",
    "        return y_norm * self.y_std + self.y_mean\n",
    "\n",
    "@torch.no_grad()\n",
    "def _mse(model, loader, device):\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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "71fb35a6-da1c-4761-92f9-b9f5177ccc9f",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def generate_and_train(\n",
    "    dataset_type: str,\n",
    "    dataset_params: dict,\n",
    "    model_type: str,\n",
    "    model_params: dict,\n",
    "    train_params: dict | None = None,\n",
    "    lr = 1e-3,\n",
    "    alpha: float = 1.0,\n",
    "    beta: float = 0.0,\n",
    "):\n",
    "    train_params = train_params or {}\n",
    "    seed        = int(train_params.get(\"seed\", 0))\n",
    "    epochs      = int(train_params.get(\"epochs\", 200))\n",
    "    batch_sz    = int(train_params.get(\"batch_size\", 8))\n",
    "    wd          = float(train_params.get(\"weight_decay\", 0.0))\n",
    "    val_frac    = float(train_params.get(\"val_frac\", 0.15))\n",
    "    test_frac   = float(train_params.get(\"test_frac\", 0.15))\n",
    "    plot_every  = int(train_params.get(\"plot_every\", 10))\n",
    "    device      = train_params.get(\"device\", \"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "    eps         = float(train_params.get(\"eps\", 1e-8))\n",
    "    plot_points = train_params.get(\"plot_points\", 2048)\n",
    "    plot_chunk  = int(train_params.get(\"plot_chunk\", 4096))\n",
    "    print_stats = bool(train_params.get(\"print_stats\", True))\n",
    "\n",
    "    # allow overriding via train_params\n",
    "    alpha = float(train_params.get(\"alpha\", alpha))\n",
    "    beta  = float(train_params.get(\"beta\",  beta))\n",
    "\n",
    "    _set_seed(seed)\n",
    "\n",
    "    # ---- generate dataset ----\n",
    "    dt = dataset_type.lower()\n",
    "    if dt == \"mdvsp\":\n",
    "        X, y = make_mdvsp_dataset(**dataset_params)\n",
    "    elif dt == \"assignment\":\n",
    "        X, y = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "    elif dt == \"quadratic\":\n",
    "        X, y = generate_convex_quadratic_dataset(**dataset_params)\n",
    "    else:\n",
    "        raise ValueError(\"dataset_type must be: 'mdvsp' | 'assignment' | 'quadratic'\")\n",
    "\n",
    "    X = _to_tensor(X, torch.float32)\n",
    "    y = _to_tensor(y, torch.float32).view(-1)\n",
    "\n",
    "    # ---- split ----\n",
    "    N = 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(seed)\n",
    "    perm = torch.randperm(N, generator=g)\n",
    "    i_train = perm[:n_train]\n",
    "    i_val   = perm[n_train:n_train+n_val]\n",
    "    i_test  = perm[n_train+n_val:]\n",
    "\n",
    "    Xtr, ytr = X[i_train], y[i_train]\n",
    "    Xva, yva = X[i_val],   y[i_val]\n",
    "    Xte, yte = X[i_test],  y[i_test]\n",
    "\n",
    "    # ---- normalize ----\n",
    "    x_mean = Xtr.mean(0, keepdim=True)\n",
    "    x_std  = Xtr.std(0, unbiased=False, keepdim=True).clamp_min(eps)\n",
    "    y_mean = ytr.mean()\n",
    "    y_std  = ytr.std(unbiased=False).clamp_min(eps)\n",
    "\n",
    "    def norm_x(x): return (x - x_mean) / x_std\n",
    "    def norm_y(t): return (t - y_mean) / y_std\n",
    "\n",
    "    XtrN, ytrN = norm_x(Xtr), norm_y(ytr)\n",
    "    XvaN, yvaN = norm_x(Xva), norm_y(yva)\n",
    "    XteN, yteN = norm_x(Xte), norm_y(yte)\n",
    "\n",
    "    train_loader = DataLoader(TensorDataset(XtrN, ytrN), batch_size=batch_sz, shuffle=True)\n",
    "    val_loader   = DataLoader(TensorDataset(XvaN, yvaN), batch_size=batch_sz, shuffle=False)\n",
    "\n",
    "    Nv = XvaN.shape[0]\n",
    "    if plot_points is None or int(plot_points) <= 0 or int(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)[:int(plot_points)]\n",
    "\n",
    "    # ---- build model ----\n",
    "    mt = model_type\n",
    "\n",
    "    class AffineOut(nn.Module):\n",
    "        def __init__(self, base, a, b):\n",
    "            super().__init__()\n",
    "            self.base = base\n",
    "            self.a = float(a); self.b = float(b)\n",
    "        def forward(self, x):\n",
    "            return self.a * self.base(x) + self.b\n",
    "\n",
    "    if mt == \"DFN\":\n",
    "        base = DFN(**model_params, alpha=alpha, beta=beta)\n",
    "    elif mt == \"MLP\":\n",
    "        base = MLP(**model_params)\n",
    "        if alpha != 1.0 or beta != 0.0: base = AffineOut(base, alpha, beta)\n",
    "    elif mt == \"MaxAffine\":\n",
    "        base = MaxAffine(**model_params)\n",
    "        if alpha != 1.0 or beta != 0.0: base = AffineOut(base, alpha, beta)\n",
    "    elif mt == \"LSET\":\n",
    "        base = LSET(**model_params)\n",
    "        if alpha != 1.0 or beta != 0.0: base = AffineOut(base, alpha, beta)\n",
    "    else:\n",
    "        raise ValueError(\"model_type must be: 'DFN' | 'MLP' | 'MaxAffine' | 'LSET'\")\n",
    "\n",
    "    # ---- print model ----\n",
    "    n_params = sum(p.numel() for p in base.parameters())\n",
    "    n_trainable = sum(p.numel() for p in base.parameters() if p.requires_grad)\n",
    "\n",
    "    extra = \"\"\n",
    "    if mt == \"MLP\":\n",
    "        extra = f\"hidden={model_params.get('hidden_dims')}\"\n",
    "    elif mt in [\"MaxAffine\", \"LSET\"]:\n",
    "        extra = f\"n_pieces={model_params.get('n_pieces')}\"\n",
    "    elif mt == \"DFN\":\n",
    "        extra = f\"layers={model_params.get('layer_sizes')} p_list={model_params.get('p_list')}\"\n",
    "\n",
    "    print(\n",
    "        f\"\\n=== Run: {dataset_type} | {model_type} ===\\n\"\n",
    "        f\"  data: N={N}  train/val/test={len(Xtr)}/{len(Xva)}/{len(Xte)}  dim={X.shape[1]}\\n\"\n",
    "        f\"  model: params={n_params:,} (trainable={n_trainable:,})  {extra}  alpha={alpha:g} beta={beta:g}\\n\"\n",
    "        f\"  train: device={device}  epochs={epochs}  batch={batch_sz}  lr={lr:g}  wd={wd:g}  seed={seed}\\n\"\n",
    "    )\n",
    "\n",
    "    base = base.to(device)\n",
    "    opt = torch.optim.Adam(base.parameters(), lr=lr, weight_decay=wd)\n",
    "    history = {\"train_mse\": [], \"val_mse\": []}\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def predict_chunks(x_dev: torch.Tensor) -> torch.Tensor:\n",
    "        outs = []\n",
    "        for i in range(0, x_dev.shape[0], plot_chunk):\n",
    "            outs.append(base(x_dev[i:i+plot_chunk]).squeeze(-1))\n",
    "        return torch.cat(outs, dim=0)\n",
    "\n",
    "    live = display(None, display_id=True)\n",
    "\n",
    "    best_val = float(\"inf\")\n",
    "    best_ep = 0\n",
    "    best_state = None\n",
    "\n",
    "    for ep in range(1, epochs + 1):\n",
    "        base.train()\n",
    "        for xb, yb in train_loader:\n",
    "            xb, yb = xb.to(device), yb.to(device)\n",
    "            pred = base(xb).squeeze(-1)\n",
    "            loss = F.mse_loss(pred, yb)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "        tr_mse = _mse(base, train_loader, device)\n",
    "        va_mse = _mse(base, val_loader, device)\n",
    "        history[\"train_mse\"].append(tr_mse)\n",
    "        history[\"val_mse\"].append(va_mse)\n",
    "\n",
    "        if va_mse < best_val:\n",
    "            best_val = va_mse\n",
    "            best_ep = ep\n",
    "            best_state = {k: v.detach().cpu().clone() for k, v in base.state_dict().items()}\n",
    "\n",
    "        if (ep == 1) or (ep % plot_every == 0) or (ep == epochs):\n",
    "            base.eval()\n",
    "            x_plot = XvaN[plot_idx].to(device)\n",
    "            y_true = yvaN[plot_idx].to(device)\n",
    "            y_pred = predict_chunks(x_plot)\n",
    "\n",
    "            fig, ax = plt.subplots(1, 2, figsize=(10, 4))\n",
    "            ax[0].plot(history[\"train_mse\"], label=\"train\")\n",
    "            ax[0].plot(history[\"val_mse\"], 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",
    "        base.load_state_dict(best_state)\n",
    "\n",
    "    best_model_raw = NormalizedRegressor(base, x_mean, x_std, y_mean, y_std).to(device).eval()\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def mse_raw(Xraw, yraw):\n",
    "        pred = best_model_raw(Xraw.to(device))\n",
    "        return F.mse_loss(pred, yraw.to(device)).item()\n",
    "\n",
    "    train_mse_raw = mse_raw(Xtr, ytr)\n",
    "    val_mse_raw   = mse_raw(Xva, yva)\n",
    "    test_mse_raw  = mse_raw(Xte, yte)\n",
    "\n",
    "    if print_stats:\n",
    "        print(\n",
    "            f\"[DONE] best val MSE (norm) = {best_val:.3e} @ epoch {best_ep}\\n\"\n",
    "            f\"       RAW MSE train/val/test = {train_mse_raw:.3e} / {val_mse_raw:.3e} / {test_mse_raw:.3e}\\n\"\n",
    "        )\n",
    "\n",
    "    data = {\n",
    "        \"raw\":  {\"X_train\": Xtr,  \"y_train\": ytr,  \"X_val\": Xva,  \"y_val\": yva,  \"X_test\": Xte,  \"y_test\": yte},\n",
    "        \"norm\": {\"X_train\": XtrN, \"y_train\": ytrN, \"X_val\": XvaN, \"y_val\": yvaN, \"X_test\": XteN, \"y_test\": yteN},\n",
    "        \"scaler\": {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std},\n",
    "        \"device\": device,\n",
    "        \"stats\": {\n",
    "            \"n_params\": int(n_params),\n",
    "            \"n_trainable\": int(n_trainable),\n",
    "            \"best_epoch\": int(best_ep),\n",
    "            \"best_val_mse_norm\": float(best_val),\n",
    "            \"train_mse_raw\": float(train_mse_raw),\n",
    "            \"val_mse_raw\": float(val_mse_raw),\n",
    "            \"test_mse_raw\": float(test_mse_raw),\n",
    "            \"lr\": float(lr),\n",
    "            \"weight_decay\": float(wd),\n",
    "            \"batch_size\": int(batch_sz),\n",
    "            \"epochs\": int(epochs),\n",
    "            \"seed\": int(seed),\n",
    "            \"alpha\": float(alpha),\n",
    "            \"beta\": float(beta),\n",
    "        },\n",
    "    }\n",
    "    return best_model_raw, data, history\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3ea2fa64-618b-4813-83f8-8929026fa377",
   "metadata": {},
   "source": [
    "# Optimization"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fcdce4e5-80aa-4af4-b49e-a7c1a82fd17b",
   "metadata": {},
   "source": [
    "### Local Search"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "1462641f-61ba-4762-b716-a000da6db685",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def local_search_l1(model, x0, x_min, x_max, delta, step=1, sum_eq=None, max_iters=10_000, live=True):\n",
    "    x0    = np.asarray(x0, float).ravel()\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    assert np.all(x0 >= x_min) and np.all(x0 <= x_max)\n",
    "    if sum_eq is not None: assert np.isclose(x0.sum(), sum_eq)\n",
    "\n",
    "    du = delta / step\n",
    "    assert abs(du - round(du)) < 1e-9\n",
    "    du = int(round(du))\n",
    "    n = x0.size\n",
    "\n",
    "    # model eval (batch): supports torch nn.Module, .predict, or callable\n",
    "    def f(X):\n",
    "        # sklearn style\n",
    "        if hasattr(model, \"predict\"):\n",
    "            return np.asarray(model.predict(X)).reshape(-1)\n",
    "    \n",
    "        # torch style\n",
    "        import torch\n",
    "        import torch.nn as nn\n",
    "    \n",
    "        if isinstance(model, nn.Module):\n",
    "            model.eval()\n",
    "    \n",
    "            # choose device safely (works even if model has no parameters)\n",
    "            dev = None\n",
    "            for t in list(model.parameters()) + list(model.buffers()):\n",
    "                dev = t.device\n",
    "                break\n",
    "            if dev is None:\n",
    "                dev = torch.device(\"cpu\")\n",
    "    \n",
    "            Xt = torch.as_tensor(X, dtype=torch.float32, device=dev)\n",
    "            with torch.no_grad():\n",
    "                y = model(Xt)\n",
    "            return y.detach().cpu().numpy().reshape(-1)\n",
    "    \n",
    "        # fallback: python callable\n",
    "        return np.array([float(model(x)) for x in X], dtype=float)\n",
    "\n",
    "\n",
    "    def ok(x):\n",
    "        if np.any(x < x_min) or np.any(x > x_max): return False\n",
    "        if sum_eq is not None and not np.isclose(x.sum(), sum_eq): return False\n",
    "        return True\n",
    "\n",
    "    # all integer deltas with exact L1 = k\n",
    "    def deltas_exact_L1(k):\n",
    "        d = np.zeros(n, int)\n",
    "        def rec(i, rem):\n",
    "            if i == n:\n",
    "                if rem == 0: yield d.copy()\n",
    "                return\n",
    "            for t in range(rem + 1):\n",
    "                if t == 0:\n",
    "                    d[i] = 0; yield from rec(i+1, rem)\n",
    "                else:\n",
    "                    d[i] = +t; yield from rec(i+1, rem-t)\n",
    "                    d[i] = -t; yield from rec(i+1, rem-t)\n",
    "            d[i] = 0\n",
    "        yield from rec(0, k)\n",
    "\n",
    "    t0 = time.perf_counter()\n",
    "    x = x0.copy()\n",
    "    y = float(f(x[None, :])[0])\n",
    "    best_x, best_y = x.copy(), y\n",
    "    hist = [{\"iter\": 0, \"t\": 0.0, \"best_y\": best_y}]\n",
    "\n",
    "    for it in range(1, max_iters + 1):\n",
    "        cand = []\n",
    "        for k in range(1, du + 1):\n",
    "            for d in deltas_exact_L1(k):\n",
    "                x2 = x + step * d\n",
    "                if ok(x2): cand.append(x2)\n",
    "        if not cand: break\n",
    "\n",
    "        Y = f(np.stack(cand))\n",
    "        j = int(np.argmin(Y))\n",
    "        if Y[j] >= y: break  # no improvement\n",
    "\n",
    "        x, y = cand[j], float(Y[j])\n",
    "        if y < best_y: best_x, best_y = x.copy(), y\n",
    "\n",
    "        hist.append({\"iter\": it, \"t\": time.perf_counter() - t0, \"best_y\": best_y})\n",
    "        if live: print(f\"iter={it}  t={hist[-1]['t']:.2f}s  best_y={best_y:.6g}\")\n",
    "\n",
    "    return best_x, best_y, hist\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e8ad3cb-514b-47a6-91f9-6378c4b80993",
   "metadata": {},
   "source": [
    "### DFN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "e2987272-f934-4bcd-8fbd-ebf382b07e05",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def solve_dfn_ip_gurobi(model, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import numpy as np, gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "    import torch.nn.functional as F\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = x_min.size\n",
    "\n",
    "    # unwrap NormalizedRegressor (raw->norm->base->raw)\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"x_mean\"):\n",
    "        dfn = model.base\n",
    "        x_mean = model.x_mean.detach().cpu().numpy().ravel()\n",
    "        x_std  = model.x_std.detach().cpu().numpy().ravel()\n",
    "        y_mean = float(model.y_mean.detach().cpu().numpy())\n",
    "        y_std  = float(model.y_std.detach().cpu().numpy())\n",
    "    else:\n",
    "        dfn = model\n",
    "        x_mean = np.zeros(d); x_std = np.ones(d)\n",
    "        y_mean = 0.0; y_std = 1.0\n",
    "\n",
    "    # DFN constants (match DFN.forward STE: round(softplus(cap_raw)), round(A,b) if learnable)\n",
    "    src = dfn.src.detach().cpu().numpy().astype(int)\n",
    "    dst = dfn.dst.detach().cpu().numpy().astype(int)\n",
    "    cost = np.r_[dfn.cost_raw.detach().cpu().numpy(), dfn.cost_fixed.detach().cpu().numpy()]\n",
    "    cap  = np.r_[np.round(F.softplus(dfn.cap_raw.detach()).cpu().numpy()), dfn.cap_fixed.detach().cpu().numpy()]\n",
    "    A = dfn.A.detach().cpu().numpy()\n",
    "    if hasattr(dfn, \"A\") and hasattr(dfn, \"A\") and str(type(dfn.A)).endswith(\"Parameter'>\"):\n",
    "        A = np.round(A)\n",
    "    b = np.round(dfn.b_raw.detach().cpu().numpy())\n",
    "\n",
    "    boundary = dfn.boundary.detach().cpu().numpy().astype(int)\n",
    "    fix = int(dfn.fix_node)\n",
    "    alpha, beta = float(dfn.alpha), float(dfn.beta)\n",
    "    n, m = int(dfn.n), len(src)\n",
    "\n",
    "    out = [[] for _ in range(n)]; inn = [[] for _ in range(n)]\n",
    "    for e in range(m): out[src[e]].append(e); inn[dst[e]].append(e)\n",
    "\n",
    "    M = gp.Model(\"dfn_min\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None: 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)) == float(sum_eq))\n",
    "\n",
    "    # supply(boundary) = A @ ((x - mean)/std) + b  => linear in raw x\n",
    "    s = [0]*n; bexpr = []\n",
    "    for r, v in enumerate(boundary):\n",
    "        const = b[r] - float((A[r] * (x_mean / x_std)).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; bexpr.append(expr)\n",
    "    s[fix] = -gp.quicksum(bexpr)\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",
    "    M.optimize()\n",
    "\n",
    "    if M.Status not in (GRB.OPTIMAL, GRB.SUBOPTIMAL):\n",
    "        raise RuntimeError(f\"Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    return x_star, float(M.ObjVal), {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None)}\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d602f3a-7b8a-4f97-9f11-a35d85bbb338",
   "metadata": {},
   "source": [
    "### MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "befab4b0-814e-4a86-b46d-9b84569bc236",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def solve_mlp_ip_gurobi(model, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    \"\"\"\n",
    "    Exact MILP for the notebook MLP (Linear/ReLU/.../Linear), minimizing model(x_raw)\n",
    "    s.t. x_min<=x<=x_max and sum(x)=sum_eq. Works with NormalizedRegressor too.\n",
    "    Returns (x_star, y_star, info).\n",
    "    \"\"\"\n",
    "    import numpy as np, gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "    import torch\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = x_min.size\n",
    "\n",
    "    # unwrap NormalizedRegressor\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"x_mean\"):\n",
    "        base = model.base\n",
    "        xm = model.x_mean.detach().cpu().numpy().ravel()\n",
    "        xs = model.x_std.detach().cpu().numpy().ravel()\n",
    "        ym = float(model.y_mean.detach().cpu().numpy())\n",
    "        ys = float(model.y_std.detach().cpu().numpy())\n",
    "    else:\n",
    "        base = model\n",
    "        xm = np.zeros(d); xs = np.ones(d)\n",
    "        ym = 0.0; ys = 1.0\n",
    "\n",
    "    net = base.net  # notebook MLP has .net = nn.Sequential(...)\n",
    "    linears = [L for L in net if isinstance(L, torch.nn.Linear)]\n",
    "    if not linears:\n",
    "        raise ValueError(\"Could not find Linear layers. Expected the notebook MLP with net=nn.Sequential(...).\")\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",
    "    # absorb input normalization: a1 = W1*((x-xm)/xs) + b1  => (W1/xs)*x + (b1 - (W1/xs)@xm)\n",
    "    W[0] = W[0] / xs[None, :]\n",
    "    b[0] = b[0] - W[0] @ xm\n",
    "\n",
    "    def affine_bounds(Wl, bl, lo, hi):\n",
    "        Wp, Wn = np.maximum(Wl, 0.0), np.minimum(Wl, 0.0)\n",
    "        L = Wp @ lo + Wn @ hi + bl\n",
    "        U = Wp @ hi + Wn @ lo + bl\n",
    "        return L, U\n",
    "\n",
    "    # interval bounds for each ReLU pre-activation (for tight big-M)\n",
    "    lo, hi = x_min, x_max\n",
    "    preLU = []\n",
    "    for k in range(len(W) - 1):\n",
    "        L, U = affine_bounds(W[k], b[k], lo, hi)\n",
    "        preLU.append((L, U))\n",
    "        lo, hi = np.maximum(0.0, L), np.maximum(0.0, U)\n",
    "\n",
    "    M = gp.Model(\"mlp_min\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == float(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    prev = [x[i] for i in range(d)]\n",
    "\n",
    "    # hidden layers (ReLU)\n",
    "    for k in range(len(W) - 1):\n",
    "        L, U = preLU[k]\n",
    "        h = W[k].shape[0]\n",
    "        a = [M.addVar(lb=float(L[j]), ub=float(U[j]), name=f\"a{k}_{j}\") for j in range(h)]\n",
    "        z = [M.addVar(lb=0.0, ub=float(max(0.0, U[j])), name=f\"z{k}_{j}\") for j in range(h)]\n",
    "\n",
    "        for j in range(h):\n",
    "            M.addConstr(\n",
    "                a[j] == b[k][j] + gp.quicksum(W[k][j,i] * prev[i] for i in range(len(prev)) if W[k][j,i] != 0.0)\n",
    "            )\n",
    "            Lj, Uj = float(L[j]), float(U[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",
    "    # output layer (assume scalar)\n",
    "    out_dim = W[-1].shape[0]\n",
    "    if out_dim != 1:\n",
    "        raise ValueError(f\"Expected scalar output, got out_dim={out_dim}.\")\n",
    "    y = M.addVar(name=\"y\")\n",
    "    M.addConstr(\n",
    "        y == b[-1][0] + gp.quicksum(W[-1][0,i] * prev[i] for i in range(len(prev)) if W[-1][0,i] != 0.0)\n",
    "    )\n",
    "\n",
    "    M.setObjective(ys * y + ym, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.Status not in (GRB.OPTIMAL, GRB.SUBOPTIMAL):\n",
    "        raise RuntimeError(f\"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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edf28c5b-e3fa-4e42-9c75-f4c32a2a0ad6",
   "metadata": {},
   "source": [
    "### Max Affine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d62429d-5b20-488b-bc74-e9025a597dae",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "90b14a64-82a4-4d77-b9d6-08490ab87733",
   "metadata": {},
   "source": [
    "### LSET"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec65d59d-1bb1-4d73-82aa-4bec67488bf0",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def solve_lset_ip_gurobi(model, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    \"\"\"\n",
    "    Minimizes LSET (or NormalizedRegressor(LSET)) over x with bounds + sum(x)=sum_eq.\n",
    "    Returns: (x_star, y_star, info)\n",
    "\n",
    "    Note: with integer_x=True this is a mixed-integer convex nonlinear model (exp/log constraints).\n",
    "    \"\"\"\n",
    "    import numpy as np, 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 = x_min.size\n",
    "\n",
    "    # unwrap NormalizedRegressor if needed\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"x_mean\"):\n",
    "        base = model.base\n",
    "        xm = model.x_mean.detach().cpu().numpy().ravel()\n",
    "        xs = model.x_std.detach().cpu().numpy().ravel()\n",
    "        ym = float(model.y_mean.detach().cpu().numpy())\n",
    "        ys = float(model.y_std.detach().cpu().numpy())\n",
    "    else:\n",
    "        base = model\n",
    "        xm = np.zeros(d); xs = np.ones(d)\n",
    "        ym = 0.0; ys = 1.0\n",
    "\n",
    "    # LSET params (trained constants)\n",
    "    A = base.A.detach().cpu().numpy().astype(float)   # (K,d)\n",
    "    b = base.b.detach().cpu().numpy().astype(float)   # (K,)\n",
    "    T = float(base.T)\n",
    "    K = A.shape[0]\n",
    "\n",
    "    # incorporate input normalization: x_norm=(x-xm)/xs  =>  Aeff x + beff\n",
    "    Aeff = A / xs[None, :]\n",
    "    beff = b - (Aeff @ xm)\n",
    "\n",
    "    M = gp.Model(\"lset_min\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    # handle exp/log as nonlinear (not static PWL)\n",
    "    M.Params.FuncNonlinear = 1  # :contentReference[oaicite:1]{index=1}\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)) == float(sum_eq), name=\"sum_eq\")\n",
    "\n",
    "    # t_k = (Aeff_k x + beff_k)/T\n",
    "    t = M.addVars(K, vtype=GRB.CONTINUOUS, name=\"t\")\n",
    "    u = M.addVars(K, lb=0.0, vtype=GRB.CONTINUOUS, name=\"u\")  # u_k = exp(t_k)\n",
    "    for k in range(K):\n",
    "        M.addConstr(\n",
    "            t[k] == (beff[k] + gp.quicksum(Aeff[k, j] * x[j] for j in range(d) if Aeff[k, j] != 0.0)) / T\n",
    "        )\n",
    "        M.addGenConstrExp(t[k], u[k], name=f\"exp_{k}\")\n",
    "\n",
    "    s = M.addVar(lb=1e-9, vtype=GRB.CONTINUOUS, name=\"s\")  # sum exp must be >0 for log\n",
    "    M.addConstr(s == gp.quicksum(u[k] for k in range(K)), name=\"sumexp\")\n",
    "\n",
    "    v = M.addVar(vtype=GRB.CONTINUOUS, name=\"v\")           # v = log(s)\n",
    "    M.addGenConstrLog(s, v, name=\"log\")\n",
    "\n",
    "    y_norm = M.addVar(vtype=GRB.CONTINUOUS, name=\"y_norm\") # y_norm = T*v\n",
    "    M.addConstr(y_norm == T * v, name=\"scaleT\")\n",
    "\n",
    "    y_raw = ys * y_norm + ym\n",
    "    M.setObjective(y_raw, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.Status not in (GRB.OPTIMAL, GRB.SUBOPTIMAL):\n",
    "        raise RuntimeError(f\"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"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73b65b06-6612-4032-ad56-7ee64051ba21",
   "metadata": {},
   "source": [
    "# Tests and Results"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d348d132-8176-46a9-9103-4879375a7904",
   "metadata": {},
   "source": [
    "### Common Training Params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "6bc3aae5-b6a1-4538-8c6e-63653574846b",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "train_params = dict(\n",
    "    epochs=10,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    plot_every=1,\n",
    "    seed=0,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a603db2e-924b-4fba-8973-74f86bb16562",
   "metadata": {},
   "source": [
    "### Multiple-Depot Vehicle Scheduling"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dbf50ea2-c68a-469d-9de8-3477c86423b2",
   "metadata": {},
   "source": [
    "### Assignment"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6a9543e7-a6e6-4ebb-8ee2-085bcf91acaf",
   "metadata": {},
   "source": [
    "### Quadratic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "id": "199885dd-5fbf-4b88-837e-0a535e1118eb",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "=== Run: quadratic | MLP ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=4,929 (trainable=4,929)  hidden=[64, 64]  alpha=1 beta=0\n",
      "  train: device=cpu  epochs=50  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA94AAAGGCAYAAACNL1mYAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAqqhJREFUeJzs3Qd4U2UXB/B/96C0BUoLpS17j7IKspeyBGUKggqKg6UoDnDvD7coMpwgKopMUZAlyN4byp6FUspsgdLd7zlvmpqmSZq2SZMm/9/z3Ca5WTc36b333Pe853XJysrKAhERERERERFZhat1XpaIiIiIiIiIGHgTERERERERWRlbvImIiIiIiIisiIE3ERERERERkRUx8CYiIiIiIiKyIgbeRERERERERFbEwJuIiIiIiIjIihh4ExEREREREVkRA28iIiIiIiIiK2LgbWOzZs2Ci4uL0enff/+16fKdOXNGLccnn3xSpOcbmn777bc8jz916hT69euHwMBA+Pn54Z577sHu3buNvv748eMRGRmprsu6MvZeW7duzfNced27775bvY+8n7yvvH9BvjdbqFKlCoYPH27W42QZO3bsaPD+2bNnG/2drVixAl27dkVoaCi8vLzUpbzOBx98YPA9DE3G3rcgzp8/j2effRYdOnRQ35G8rqz7wnrooYfUa/Tq1SvPfYmJiXj11VdRq1Yt+Pr6olKlShg4cCAOHTqU63EF/Z0V1a1bt9Q6kO/A29sbjRs3zvO/k5GRgc8++wzdu3dHWFiYWv66deti4sSJuHHjhtnvJY8NCgoy+L9ZEly/fl39ThYvXmzrRSEiC+rbty98fHxMbs+GDh0KDw8PXLp0yezXle32W2+9BXvzv//9z+B2LDo6Wi2vHFsVNzlmKF++PG7evFls71mQYwA55jC0X5b9or60tDS8/fbb6hhGjnHq1KmDKVOm5Hncww8/jD59+ljls5Fzcrf1ApDGzJkz1T++vnr16jnEKnr66acxZMiQXPNq1qyZ6/bly5fRrl07lClTBj/88IMKMiZNmqQ2pjt27EDt2rXzvO7ChQvx2GOP5dlhderUKde8Bg0a5Lp95MgR9boSxPz+++9ITk7GG2+8od5/7969aufiCEqXLo3169fj5MmTqF69eq77ZB37+/urgFPXjBkzMGrUKPTv3x9fffUVypYti5iYGGze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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.485e-02 @ epoch 50\n",
      "       RAW MSE train/val/test = 9.669e+02 / 1.477e+04 / 1.281e+04\n",
      "\n",
      "quadratic+MLP yhat: tensor([2971.6199, 1703.8828, 2000.8853, 2891.2866])\n",
      "iter=1  t=0.00s  best_y=1245.72\n",
      "iter=2  t=0.00s  best_y=1107.83\n",
      "iter=3  t=0.01s  best_y=976.79\n",
      "iter=4  t=0.01s  best_y=852.844\n",
      "iter=5  t=0.01s  best_y=754.672\n",
      "iter=6  t=0.01s  best_y=677.093\n",
      "iter=7  t=0.02s  best_y=600.745\n",
      "iter=8  t=0.02s  best_y=533.81\n",
      "iter=9  t=0.02s  best_y=464.965\n",
      "iter=10  t=0.02s  best_y=402.733\n",
      "iter=11  t=0.03s  best_y=343.971\n",
      "iter=12  t=0.03s  best_y=286.641\n",
      "iter=13  t=0.03s  best_y=232.03\n",
      "iter=14  t=0.03s  best_y=181.402\n",
      "iter=15  t=0.04s  best_y=131.036\n",
      "iter=16  t=0.04s  best_y=76.7839\n",
      "iter=17  t=0.04s  best_y=37.394\n",
      "iter=18  t=0.04s  best_y=-1.80249\n",
      "iter=19  t=0.05s  best_y=-41.6326\n",
      "iter=20  t=0.06s  best_y=-77.5999\n",
      "iter=21  t=0.07s  best_y=-115.552\n",
      "iter=22  t=0.07s  best_y=-147.993\n",
      "iter=23  t=0.10s  best_y=-173.683\n",
      "iter=24  t=0.10s  best_y=-209.63\n",
      "iter=25  t=0.10s  best_y=-231.892\n",
      "iter=26  t=0.11s  best_y=-249.541\n",
      "iter=27  t=0.11s  best_y=-266.74\n",
      "iter=28  t=0.11s  best_y=-283.918\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 60\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  60\n",
      "\n",
      "Optimize a model with 642 rows, 395 columns and 5963 nonzeros\n",
      "Model fingerprint: 0x56e90387\n",
      "Variable types: 257 continuous, 138 integer (128 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e-05, 1e+01]\n",
      "  Objective range  [1e+03, 1e+03]\n",
      "  Bounds range     [1e+00, 1e+01]\n",
      "  RHS range        [7e-04, 2e+01]\n",
      "Presolve removed 128 rows and 0 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 514 rows, 395 columns, 5782 nonzeros\n",
      "Variable types: 257 continuous, 138 integer (128 binary)\n",
      "\n",
      "Root relaxation: objective 2.820376e+03, 201 iterations, 0.00 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0 2820.37598    0    7          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    7          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    7          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    9          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    8          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    5          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    9          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    6          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    6          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    7          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    8          - 2820.37598      -     -    0s\n",
      "     0     0 2820.37598    0    9          - 2820.37598      -     -    0s\n",
      "H    0     0                    3068.7146135 2820.37598  8.09%     -    0s\n",
      "     0     0 2820.37598    0    9 3068.71461 2820.37598  8.09%     -    0s\n",
      "H    0     2                    3031.9817160 2820.37598  6.98%     -    0s\n",
      "     0     2 2820.37598    0    9 3031.98172 2820.37598  6.98%     -    0s\n",
      "H 1123  1602                    3002.1618116 2820.37598  6.06%  41.0    0s\n",
      "H 1199  1602                    2934.4924136 2820.37598  3.89%  40.4    0s\n",
      "H 2504  1948                    2914.2510117 2820.37598  3.22%  37.7    0s\n",
      "H 2620  1857                    2899.0434140 2820.37598  2.71%  37.4    0s\n",
      "H 2625  1766                    2828.9790647 2820.37598  0.30%  37.3    0s\n",
      "H 2630  1682                    2826.6258000 2820.37598  0.22%  37.3    0s\n",
      "H 4785  2951                    2826.0793058 2820.37598  0.20%  36.0    1s\n",
      "H 6608  2767                    2824.0028315 2820.37598  0.13%  35.9    1s\n",
      "H 8849  3860                    2820.7683622 2820.37598  0.01%  37.1    1s\n",
      "H15067  7002                    2820.7075792 2820.37598  0.01%  37.7    2s\n",
      "H28016 13138                    2820.6355133 2820.37598  0.01%  39.1    4s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 1\n",
      "  MIR: 2\n",
      "  Flow cover: 2\n",
      "  RLT: 3\n",
      "\n",
      "Explored 28090 nodes (1101991 simplex iterations) in 4.81 seconds (14.41 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 2820.64 2820.71 2820.77 ... 2934.49\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 2.820635513268e+03, best bound 2.820375976562e+03, gap 0.0092%\n",
      "\n",
      "=== Run: quadratic | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=8,533 (trainable=8,533)  layers=[16, 64, 16] p_list=[1, 1]  alpha=1e-06 beta=-5\n",
      "  train: device=cpu  epochs=50  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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5Rwh5xa5bjEOvIW8r9Q3+f3339VxMbFx1dLQYe54LftYho7JdaSc6+U9ZQy+4fnCmufsxMg5TN5fzqPSkCBDyeTcZdxYK0P+ZKiZIe3cJ88bku+NbP/KlStTtW3kouzd1U72o6Upm7pJCqQheUxSaa5fvx4vheuFF17QFSlSJO6x9u3b6/z8/BKkT0qqcbp06XT3799X90ePHq3WuXbt2iTTy8uUKaPeyzi1e/78+cn6vImllycnJevAgQPq+X379sU9tn//ft2AAQN0S5cu1W3ZskX3888/60qUKKH246pVq+KW2759u9ltl/Qlee7q1atWSS8/dOiQWm769OnxHn/xxRfNpt0J2deSTisp1BUqVEhxermW+i1pXG3atFG///333ypVS/62pvazpJ6XLl067nso37kGDRroJk2apNJ8jd/D3Pf3f//7X9xyWuq/JTfZLnNkn9StW1eXKVMmi9KD58yZo/viiy9UavSGDRt0X375pS5Lliy6HDlyqDRxQ3/99ZdK1T58+HC8bTZOLy9evLhK28uYMaP6vshyX3/9tdpPL730ki42NlYtJ9vn7e2t69evX7zXP3z4UJczZ8546d/yGvlshjfZt5988kmCxw3T7GX7xo4dm+Bzz5s3Tz23Y8cOk/sluenlu3btUutbsGBBgudkPbI/Lly4EPfYkydP1H5+5513kn1c0va7qSEO8r2X5xYvXhz3mOyTbNmyqcflGKCRlEP5vz948OAE6xkxYoTO09NT9+jRI4v3AREln5x7ZLiL4bnj/fffV/9fT548mej5T847rVu3TnZ6ed++fXVBQUGJLtO9e3d1vD969KjFnyWx83Jy08slPVyOkc2bN0+Qnl2uXDl1jWA8TOrTTz+1aDsXLlyolt+5c2eC5+RxOf89ePAg7jG5ppTjoeG5xBrn7KTSy+U4LGnwcm6W6xL5u8k5U479hmnqkiou511TfH19db169UrweJ48eXTt2rVLYk+RO2IhNVKtppLqY8hUdWxJQzIsOiKtxO3atVOFOqR1U9JupYCELCcpU4ak10dac6WlVapDyu/Sq20qxdiYtMzKexm3MNqrirG0zkpaq6SzaqQAm9w00psorbfSyzls2DDVemwoserj1qpMLu9dqVIl1XIvBajEsWPHVCu/tHwbktZraWmXXkPDFvmkKm1b2uMg7y+p4zNnzlQt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7uVODmnYqFu3rtr3MrTm1q1bCbJaHJlcT0rROvkpmW/anO7SQ6h9fxyBM18LJ3U+cFTOfF390UcfqSnlJFNGpuKUekbScLBq1Srrv5nV66GTXU2ePFlNYeLr66urWLGi05brtyX52pu6yTQYZB6nDDPvzz//1JUuXVrn5+enpiaZPn06v0pGHjx4oKacy58/v87f319XqFAh3YgRI3QRERFuva82btxo8njUtWvXuGnDRo4cqaYOk+9X7dq1dYcPH7b3ZpNOp9u3b5+uatWqavok+U4XL15c/a3Cw8Odbv+cO3fOaaYMO3TokK5evXq6LFmyqP8TBQoUUFNEXb58WefI5BrD3PWHM5Bjkqltl2OYo3HWa+GkzgeOypmvq7t37x73XcmWLZuuQYMGujVr1tjkvTzkH+uH8kRERERERETE6uVERERERERENsKgm4iIiIiIiMhGGHQTERERERER2QiDbiIiIiIiIiIbYdBNREREREREZCMMuomIiIiIiIhshEE3ERERERERkY0w6CYiIiIiIiKyEQbdRERERESUQGRkJIoUKYLt27c77N6pUqUKlixZYu/NIEoUg24iIiIiIgcyatQolC9f3t6bgenTpyMkJAQvvfQSHNUnn3yCDz/8ELGxsfbeFCKzGHQTERERETmhqKgom65/4sSJ6NmzJ9KiRz2lmjVrhrCwMKxevdqq20RkTQy6iYiIiIisaM6cOciaNSsiIiLiPf7666+jS5cuib72l19+wWeffYaDBw/Cw8ND3eQxIb9PnToVLVu2RPr06fH555+r54KCguKtY9myZWpZQ3/++ScqVaoEf39/FCpUSL1HdHS02e3Yv38/Tp8+rYJazfnz59V6JZ27Xr16SJcuHcqVK4d///033msXL16MUqVKwc/PDwUKFMB3330X73l5TLa9W7duCAwMxNtvvx33Of766y8UL15crbtNmzYIDw/H7Nmz1WsyZ86Mfv36ISYmJm5dXl5eaNq0KebPn5/ofiWyJwbdRERERERW1LZtWxUYrlixIu6x27dvq4DyrbfeSvS17dq1w/vvv6+C1mvXrqmbPKYZOXKkCroPHz6M7t27W7Q90gvcuXNn9O/fH0ePHsW0adNUkPvFF1+Yfc2WLVtQrFgxZMqUKcFzI0aMwJAhQ3DgwAG1TIcOHeIC+H379uGNN95A+/bt1TZKqrykgGsNB5pvvvkGpUuXVsvL8+Lx48f44YcfsGDBAqxatQqbNm3Ca6+9hpUrV6rbr7/+qlLe//jjj3jrevHFF7F161aL9gWRPXjb5V2JiIiIiFxUQEAAOnbsiFmzZqkAXPz222/Imzcv6tatm+RrM2TIAG9vb+TMmTPB87JeS4NtjQTXMu65a9eu6r70dP/vf//DsGHDVBBvivRq586d2+RzEnBrPeDSYy4NBNIr/sILL2DcuHFo0KBBXCAtQbkE+hJkS8+2pn79+mo9mm3btql0+R9//BGFCxdWj0lPtwTaN27cUPukZMmSqod948aN8Roi8uTJg4sXL6px3Z6e7FMkx8NvJRERERGRlUnK9Jo1a3DlyhV1XwJwCTqN076Tq3Llysl+jfQmjx49WgWu2k22T3rRpXfZlCdPnqhUdFPKli0b93uuXLnUz5s3b6qfx44dS1B4Te6fOnUqXlq4qc8hKeVawC1y5Mih0splew0f097LsKFCAm7jdH4iR8GebiIiIiIiK6tQoYIa7yzjuxs1aqRSrWVcdWrJWG5D0rOr0+kSLbAmAan0SEuqtjFzgXVwcLDaZlN8fHziftcaEbTq4bItxg0Lxttn6nMYr1dbt6nHjCuV3717VwXsEnwTOSIG3URERERENiCVv8ePH696u19++WXky5fPotf5+vrG6xVOTLZs2fDw4UNVcEwLZGWstaGKFSvixIkTas7t5DQaSKq3qSA6MZICLqnihnbs2KHSzKXomS38999/6jMSOSqmlxMRERER2UCnTp1UwD1jxoxkjcOWlOpz586p4FkKsCWWNl21alXVy/vRRx+pcdXz5s1LULTs008/VT3uUtTsyJEjKgV84cKF+Pjjj82uV8ZOSyAvyyeHFIFbv369GjN+8uRJVXl80qRJ8cZvW5sUUWvYsKHN1k+UWgy6iYiIiIhsQCp/yzRhMia5VatWFr9OXtO4cWMV+EpPdmLTYWXJkgVz585V1b3LlCmjlpXg2pCkt0vl9LVr16JKlSqoVq2aKngWEhJidr0y5Zmko0sBuOSQHudFixapCuRSnVwCfhlPblhEzZqkUUN60pOqCk9kTx46U4MsiIiIiIgo1V555RWUKFFCTYXlbGRMt6TFSw96xowZ4YiGDh2KsLAwNZUYkaNiTzcRERERkZVJcS/p7d2wYQP69OnjlPtXes6//vprNX2Yo8qePbtKZSdyZOzpJiIiIiKyMhmXfe/ePTVftfF4ZpnX+sKFCyZfN23aNDUWnIhcB4NuIiIiIqI0JAG38bRehvNQO2oqNxGlDINuIiIiIiIiIhvhmG4iIiIiIiIiG2HQTURERERERGQjDLqJiIiIiIiIbIRBNxEREREREZGNMOgmIiIiIiIishEG3UREREREREQ2wqCbiIiIiIiIyEYYdBMRERERERHBNv4Pfq5hyqy+28MAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[107]\u001b[39m\u001b[32m, line 34\u001b[39m\n\u001b[32m     27\u001b[39m x_best_MLP_IP, y_best_MLP_IP, hist_DFN_IP = solve_mlp_ip_gurobi(\n\u001b[32m     28\u001b[39m     m_MLP, xmin, xmax,\n\u001b[32m     29\u001b[39m     sum_eq=sum_eq,\n\u001b[32m     30\u001b[39m     verbose=\u001b[38;5;28;01mTrue\u001b[39;00m, time_limit=\u001b[32m60\u001b[39m\n\u001b[32m     31\u001b[39m )\n\u001b[32m     33\u001b[39m \u001b[38;5;66;03m# DFN (requires lemon_mcf working)\u001b[39;00m\n\u001b[32m---> \u001b[39m\u001b[32m34\u001b[39m m_DFN, data_DFN, hist_DFN = \u001b[43mgenerate_and_train\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m     35\u001b[39m \u001b[43m    \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mquadratic\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mquadratic_params\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m     36\u001b[39m \u001b[43m    \u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mDFN\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mdict\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43minput_dim\u001b[49m\u001b[43m=\u001b[49m\u001b[43min_dim\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlayer_sizes\u001b[49m\u001b[43m=\u001b[49m\u001b[43m[\u001b[49m\u001b[32;43m16\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m64\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m16\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mp_list\u001b[49m\u001b[43m=\u001b[49m\u001b[43m[\u001b[49m\u001b[32;43m1\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mseed\u001b[49m\u001b[43m=\u001b[49m\u001b[32;43m0\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m     37\u001b[39m \u001b[43m    \u001b[49m\u001b[43mtrain_params\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m     38\u001b[39m \u001b[43m    \u001b[49m\u001b[43mlr\u001b[49m\u001b[43m \u001b[49m\u001b[43m=\u001b[49m\u001b[43m \u001b[49m\u001b[32;43m1e-1\u001b[39;49m\u001b[43m,\u001b[49m\n\u001b[32m     39\u001b[39m \u001b[43m    \u001b[49m\u001b[43malpha\u001b[49m\u001b[43m=\u001b[49m\u001b[32;43m1e-6\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbeta\u001b[49m\u001b[43m=\u001b[49m\u001b[43m-\u001b[49m\u001b[32;43m5.0\u001b[39;49m\n\u001b[32m     40\u001b[39m \u001b[43m)\u001b[49m\n\u001b[32m     41\u001b[39m \u001b[38;5;28;01mwith\u001b[39;00m torch.no_grad(): \u001b[38;5;28mprint\u001b[39m(\u001b[33m\"\u001b[39m\u001b[33mquadratic+DFN yhat:\u001b[39m\u001b[33m\"\u001b[39m, m_DFN(data_DFN[\u001b[33m\"\u001b[39m\u001b[33mraw\u001b[39m\u001b[33m\"\u001b[39m][\u001b[33m\"\u001b[39m\u001b[33mX_test\u001b[39m\u001b[33m\"\u001b[39m][:\u001b[32m4\u001b[39m].to(data_DFN[\u001b[33m\"\u001b[39m\u001b[33mdevice\u001b[39m\u001b[33m\"\u001b[39m])))\n\u001b[32m     43\u001b[39m x_best_DFN, y_best_DFN, hist_DFN_ls = local_search_l1(\n\u001b[32m     44\u001b[39m     m_DFN, x0, xmin, xmax,\n\u001b[32m     45\u001b[39m     delta=delta, step=step,\n\u001b[32m     46\u001b[39m     sum_eq=sum_eq,\n\u001b[32m     47\u001b[39m     live=\u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[32m     48\u001b[39m )\n",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[16]\u001b[39m\u001b[32m, line 191\u001b[39m, in \u001b[36mgenerate_and_train\u001b[39m\u001b[34m(dataset_type, dataset_params, model_type, model_params, train_params, lr, alpha, beta)\u001b[39m\n\u001b[32m    188\u001b[39m         ax[\u001b[32m1\u001b[39m].set_title(\u001b[33mf\u001b[39m\u001b[33m\"\u001b[39m\u001b[33mVal scatter (n=\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mlen\u001b[39m(yt)\u001b[38;5;132;01m}\u001b[39;00m\u001b[33m)\u001b[39m\u001b[33m\"\u001b[39m)\n\u001b[32m    190\u001b[39m         plt.tight_layout()\n\u001b[32m--> \u001b[39m\u001b[32m191\u001b[39m         \u001b[43mlive\u001b[49m\u001b[43m.\u001b[49m\u001b[43mupdate\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfig\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    192\u001b[39m         plt.close(fig)\n\u001b[32m    194\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m best_state \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/display_functions.py:354\u001b[39m, in \u001b[36mDisplayHandle.update\u001b[39m\u001b[34m(self, obj, **kwargs)\u001b[39m\n\u001b[32m    344\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34mupdate\u001b[39m(\u001b[38;5;28mself\u001b[39m, obj, **kwargs):\n\u001b[32m    345\u001b[39m \u001b[38;5;250m    \u001b[39m\u001b[33;03m\"\"\"Update existing displays with my id\u001b[39;00m\n\u001b[32m    346\u001b[39m \n\u001b[32m    347\u001b[39m \u001b[33;03m    Parameters\u001b[39;00m\n\u001b[32m   (...)\u001b[39m\u001b[32m    352\u001b[39m \u001b[33;03m        additional keyword arguments passed to update_display\u001b[39;00m\n\u001b[32m    353\u001b[39m \u001b[33;03m    \"\"\"\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m354\u001b[39m     \u001b[43mupdate_display\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdisplay_id\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mdisplay_id\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/display_functions.py:306\u001b[39m, in \u001b[36mupdate_display\u001b[39m\u001b[34m(obj, display_id, **kwargs)\u001b[39m\n\u001b[32m    292\u001b[39m \u001b[38;5;250m\u001b[39m\u001b[33;03m\"\"\"Update an existing display by id\u001b[39;00m\n\u001b[32m    293\u001b[39m \n\u001b[32m    294\u001b[39m \u001b[33;03mParameters\u001b[39;00m\n\u001b[32m   (...)\u001b[39m\u001b[32m    303\u001b[39m \u001b[33;03m:func:`display`\u001b[39;00m\n\u001b[32m    304\u001b[39m \u001b[33;03m\"\"\"\u001b[39;00m\n\u001b[32m    305\u001b[39m kwargs[\u001b[33m'\u001b[39m\u001b[33mupdate\u001b[39m\u001b[33m'\u001b[39m] = \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m306\u001b[39m \u001b[43mdisplay\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdisplay_id\u001b[49m\u001b[43m=\u001b[49m\u001b[43mdisplay_id\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/display_functions.py:278\u001b[39m, in \u001b[36mdisplay\u001b[39m\u001b[34m(include, exclude, metadata, transient, display_id, raw, clear, *objs, **kwargs)\u001b[39m\n\u001b[32m    276\u001b[39m     publish_display_data(data=obj, metadata=metadata, **kwargs)\n\u001b[32m    277\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m278\u001b[39m     format_dict, md_dict = \u001b[38;5;28;43mformat\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minclude\u001b[49m\u001b[43m=\u001b[49m\u001b[43minclude\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mexclude\u001b[49m\u001b[43m=\u001b[49m\u001b[43mexclude\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    279\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m format_dict:\n\u001b[32m    280\u001b[39m         \u001b[38;5;66;03m# nothing to display (e.g. _ipython_display_ took over)\u001b[39;00m\n\u001b[32m    281\u001b[39m         \u001b[38;5;28;01mcontinue\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/formatters.py:238\u001b[39m, in \u001b[36mDisplayFormatter.format\u001b[39m\u001b[34m(self, obj, include, exclude)\u001b[39m\n\u001b[32m    236\u001b[39m md = \u001b[38;5;28;01mNone\u001b[39;00m\n\u001b[32m    237\u001b[39m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m238\u001b[39m     data = \u001b[43mformatter\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    239\u001b[39m \u001b[38;5;28;01mexcept\u001b[39;00m:\n\u001b[32m    240\u001b[39m     \u001b[38;5;66;03m# FIXME: log the exception\u001b[39;00m\n\u001b[32m    241\u001b[39m     \u001b[38;5;28;01mraise\u001b[39;00m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/decorator.py:235\u001b[39m, in \u001b[36mdecorate.<locals>.fun\u001b[39m\u001b[34m(*args, **kw)\u001b[39m\n\u001b[32m    233\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m kwsyntax:\n\u001b[32m    234\u001b[39m     args, kw = fix(args, kw, sig)\n\u001b[32m--> \u001b[39m\u001b[32m235\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mcaller\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m(\u001b[49m\u001b[43mextras\u001b[49m\u001b[43m \u001b[49m\u001b[43m+\u001b[49m\u001b[43m \u001b[49m\u001b[43margs\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkw\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/formatters.py:282\u001b[39m, in \u001b[36mcatch_format_error\u001b[39m\u001b[34m(method, self, *args, **kwargs)\u001b[39m\n\u001b[32m    280\u001b[39m \u001b[38;5;250m\u001b[39m\u001b[33;03m\"\"\"show traceback on failed format call\"\"\"\u001b[39;00m\n\u001b[32m    281\u001b[39m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m282\u001b[39m     r = \u001b[43mmethod\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    283\u001b[39m \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mNotImplementedError\u001b[39;00m:\n\u001b[32m    284\u001b[39m     \u001b[38;5;66;03m# don't warn on NotImplementedErrors\u001b[39;00m\n\u001b[32m    285\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m._check_return(\u001b[38;5;28;01mNone\u001b[39;00m, args[\u001b[32m0\u001b[39m])\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/formatters.py:402\u001b[39m, in \u001b[36mBaseFormatter.__call__\u001b[39m\u001b[34m(self, obj)\u001b[39m\n\u001b[32m    400\u001b[39m     \u001b[38;5;28;01mpass\u001b[39;00m\n\u001b[32m    401\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m402\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mprinter\u001b[49m\u001b[43m(\u001b[49m\u001b[43mobj\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    403\u001b[39m \u001b[38;5;66;03m# Finally look for special method names\u001b[39;00m\n\u001b[32m    404\u001b[39m method = get_real_method(obj, \u001b[38;5;28mself\u001b[39m.print_method)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/IPython/core/pylabtools.py:170\u001b[39m, in \u001b[36mprint_figure\u001b[39m\u001b[34m(fig, fmt, bbox_inches, base64, **kwargs)\u001b[39m\n\u001b[32m    167\u001b[39m     \u001b[38;5;28;01mfrom\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34;01mmatplotlib\u001b[39;00m\u001b[34;01m.\u001b[39;00m\u001b[34;01mbackend_bases\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mimport\u001b[39;00m FigureCanvasBase\n\u001b[32m    168\u001b[39m     FigureCanvasBase(fig)\n\u001b[32m--> \u001b[39m\u001b[32m170\u001b[39m \u001b[43mfig\u001b[49m\u001b[43m.\u001b[49m\u001b[43mcanvas\u001b[49m\u001b[43m.\u001b[49m\u001b[43mprint_figure\u001b[49m\u001b[43m(\u001b[49m\u001b[43mbytes_io\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkw\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    171\u001b[39m data = bytes_io.getvalue()\n\u001b[32m    172\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m fmt == \u001b[33m'\u001b[39m\u001b[33msvg\u001b[39m\u001b[33m'\u001b[39m:\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/backend_bases.py:2160\u001b[39m, in \u001b[36mFigureCanvasBase.print_figure\u001b[39m\u001b[34m(self, filename, dpi, facecolor, edgecolor, orientation, format, bbox_inches, pad_inches, bbox_extra_artists, backend, **kwargs)\u001b[39m\n\u001b[32m   2158\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m bbox_inches:\n\u001b[32m   2159\u001b[39m     \u001b[38;5;28;01mif\u001b[39;00m bbox_inches == \u001b[33m\"\u001b[39m\u001b[33mtight\u001b[39m\u001b[33m\"\u001b[39m:\n\u001b[32m-> \u001b[39m\u001b[32m2160\u001b[39m         bbox_inches = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mfigure\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_tightbbox\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m   2161\u001b[39m \u001b[43m            \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbbox_extra_artists\u001b[49m\u001b[43m=\u001b[49m\u001b[43mbbox_extra_artists\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   2162\u001b[39m         \u001b[38;5;28;01mif\u001b[39;00m (\u001b[38;5;28misinstance\u001b[39m(layout_engine, ConstrainedLayoutEngine) \u001b[38;5;129;01mand\u001b[39;00m\n\u001b[32m   2163\u001b[39m                 pad_inches == \u001b[33m\"\u001b[39m\u001b[33mlayout\u001b[39m\u001b[33m\"\u001b[39m):\n\u001b[32m   2164\u001b[39m             h_pad = layout_engine.get()[\u001b[33m\"\u001b[39m\u001b[33mh_pad\u001b[39m\u001b[33m\"\u001b[39m]\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/figure.py:1848\u001b[39m, in \u001b[36mFigureBase.get_tightbbox\u001b[39m\u001b[34m(self, renderer, bbox_extra_artists)\u001b[39m\n\u001b[32m   1844\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m ax.get_visible():\n\u001b[32m   1845\u001b[39m     \u001b[38;5;66;03m# some Axes don't take the bbox_extra_artists kwarg so we\u001b[39;00m\n\u001b[32m   1846\u001b[39m     \u001b[38;5;66;03m# need this conditional....\u001b[39;00m\n\u001b[32m   1847\u001b[39m     \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[32m-> \u001b[39m\u001b[32m1848\u001b[39m         bbox = \u001b[43max\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_tightbbox\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m   1849\u001b[39m \u001b[43m            \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mbbox_extra_artists\u001b[49m\u001b[43m=\u001b[49m\u001b[43mbbox_extra_artists\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1850\u001b[39m     \u001b[38;5;28;01mexcept\u001b[39;00m \u001b[38;5;167;01mTypeError\u001b[39;00m:\n\u001b[32m   1851\u001b[39m         bbox = ax.get_tightbbox(renderer)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/axes/_base.py:4567\u001b[39m, in \u001b[36m_AxesBase.get_tightbbox\u001b[39m\u001b[34m(self, renderer, call_axes_locator, bbox_extra_artists, for_layout_only)\u001b[39m\n\u001b[32m   4565\u001b[39m         \u001b[38;5;28;01mif\u001b[39;00m ba:\n\u001b[32m   4566\u001b[39m             bb.append(ba)\n\u001b[32m-> \u001b[39m\u001b[32m4567\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_update_title_position\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   4568\u001b[39m axbbox = \u001b[38;5;28mself\u001b[39m.get_window_extent(renderer)\n\u001b[32m   4569\u001b[39m bb.append(axbbox)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/axes/_base.py:3134\u001b[39m, in \u001b[36m_AxesBase._update_title_position\u001b[39m\u001b[34m(self, renderer)\u001b[39m\n\u001b[32m   3132\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m title.get_text():\n\u001b[32m   3133\u001b[39m     \u001b[38;5;28;01mfor\u001b[39;00m ax \u001b[38;5;129;01min\u001b[39;00m axs:\n\u001b[32m-> \u001b[39m\u001b[32m3134\u001b[39m         \u001b[43max\u001b[49m\u001b[43m.\u001b[49m\u001b[43myaxis\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_tightbbox\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# update offsetText\u001b[39;00m\n\u001b[32m   3135\u001b[39m         \u001b[38;5;28;01mif\u001b[39;00m ax.yaxis.offsetText.get_text():\n\u001b[32m   3136\u001b[39m             bb = ax.yaxis.offsetText.get_tightbbox(renderer)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/axis.py:1356\u001b[39m, in \u001b[36mAxis.get_tightbbox\u001b[39m\u001b[34m(self, renderer, for_layout_only)\u001b[39m\n\u001b[32m   1353\u001b[39m \u001b[38;5;28mself\u001b[39m._update_label_position(renderer)\n\u001b[32m   1355\u001b[39m \u001b[38;5;66;03m# go back to just this axis's tick labels\u001b[39;00m\n\u001b[32m-> \u001b[39m\u001b[32m1356\u001b[39m tlb1, tlb2 = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_get_ticklabel_bboxes\u001b[49m\u001b[43m(\u001b[49m\u001b[43mticks_to_draw\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1358\u001b[39m \u001b[38;5;28mself\u001b[39m._update_offset_text_position(tlb1, tlb2)\n\u001b[32m   1359\u001b[39m \u001b[38;5;28mself\u001b[39m.offsetText.set_text(\u001b[38;5;28mself\u001b[39m.major.formatter.get_offset())\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/axis.py:1332\u001b[39m, in \u001b[36mAxis._get_ticklabel_bboxes\u001b[39m\u001b[34m(self, ticks, renderer)\u001b[39m\n\u001b[32m   1330\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m renderer \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[32m   1331\u001b[39m     renderer = \u001b[38;5;28mself\u001b[39m.get_figure(root=\u001b[38;5;28;01mTrue\u001b[39;00m)._get_renderer()\n\u001b[32m-> \u001b[39m\u001b[32m1332\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m (\u001b[43m[\u001b[49m\u001b[43mtick\u001b[49m\u001b[43m.\u001b[49m\u001b[43mlabel1\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_window_extent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1333\u001b[39m \u001b[43m         \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mtick\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mticks\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43;01mif\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mtick\u001b[49m\u001b[43m.\u001b[49m\u001b[43mlabel1\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_visible\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m]\u001b[49m,\n\u001b[32m   1334\u001b[39m         [tick.label2.get_window_extent(renderer)\n\u001b[32m   1335\u001b[39m          \u001b[38;5;28;01mfor\u001b[39;00m tick \u001b[38;5;129;01min\u001b[39;00m ticks \u001b[38;5;28;01mif\u001b[39;00m tick.label2.get_visible()])\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/axis.py:1332\u001b[39m, in \u001b[36m<listcomp>\u001b[39m\u001b[34m(.0)\u001b[39m\n\u001b[32m   1330\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m renderer \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[32m   1331\u001b[39m     renderer = \u001b[38;5;28mself\u001b[39m.get_figure(root=\u001b[38;5;28;01mTrue\u001b[39;00m)._get_renderer()\n\u001b[32m-> \u001b[39m\u001b[32m1332\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m ([\u001b[43mtick\u001b[49m\u001b[43m.\u001b[49m\u001b[43mlabel1\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget_window_extent\u001b[49m\u001b[43m(\u001b[49m\u001b[43mrenderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1333\u001b[39m          \u001b[38;5;28;01mfor\u001b[39;00m tick \u001b[38;5;129;01min\u001b[39;00m ticks \u001b[38;5;28;01mif\u001b[39;00m tick.label1.get_visible()],\n\u001b[32m   1334\u001b[39m         [tick.label2.get_window_extent(renderer)\n\u001b[32m   1335\u001b[39m          \u001b[38;5;28;01mfor\u001b[39;00m tick \u001b[38;5;129;01min\u001b[39;00m ticks \u001b[38;5;28;01mif\u001b[39;00m tick.label2.get_visible()])\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/text.py:969\u001b[39m, in \u001b[36mText.get_window_extent\u001b[39m\u001b[34m(self, renderer, dpi)\u001b[39m\n\u001b[32m    964\u001b[39m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[32m    965\u001b[39m         \u001b[33m\"\u001b[39m\u001b[33mCannot get window extent of text w/o renderer. You likely \u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m    966\u001b[39m         \u001b[33m\"\u001b[39m\u001b[33mwant to call \u001b[39m\u001b[33m'\u001b[39m\u001b[33mfigure.draw_without_rendering()\u001b[39m\u001b[33m'\u001b[39m\u001b[33m first.\u001b[39m\u001b[33m\"\u001b[39m)\n\u001b[32m    968\u001b[39m \u001b[38;5;28;01mwith\u001b[39;00m cbook._setattr_cm(fig, dpi=dpi):\n\u001b[32m--> \u001b[39m\u001b[32m969\u001b[39m     bbox, info, descent = \u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_get_layout\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43m_renderer\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    970\u001b[39m     x, y = \u001b[38;5;28mself\u001b[39m.get_unitless_position()\n\u001b[32m    971\u001b[39m     x, y = \u001b[38;5;28mself\u001b[39m.get_transform().transform((x, y))\n",
      "\u001b[36mFile \u001b[39m\u001b[32m/opt/anaconda3/envs/dfn/lib/python3.11/site-packages/matplotlib/text.py:437\u001b[39m, in \u001b[36mText._get_layout\u001b[39m\u001b[34m(self, renderer)\u001b[39m\n\u001b[32m    433\u001b[39m     offset_layout = [(x + width - w, y)\n\u001b[32m    434\u001b[39m                      \u001b[38;5;28;01mfor\u001b[39;00m x, y, w \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mzip\u001b[39m(xs, ys, ws)]\n\u001b[32m    436\u001b[39m \u001b[38;5;66;03m# the corners of the unrotated bounding box\u001b[39;00m\n\u001b[32m--> \u001b[39m\u001b[32m437\u001b[39m corners_horiz = np.array(\n\u001b[32m    438\u001b[39m     [(xmin, ymin), (xmin, ymax), (xmax, ymax), (xmax, ymin)])\n\u001b[32m    440\u001b[39m \u001b[38;5;66;03m# now rotate the bbox\u001b[39;00m\n\u001b[32m    441\u001b[39m corners_rotated = M.transform(corners_horiz)\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "quadratic_params = dict(K=1000, dim=10, eigen_min=1.0, eigen_max=5.0, x_min=-10, x_max=10, noise_std=0.1, seed=0)\n",
    "Xtmp, _ = generate_convex_quadratic_dataset(**quadratic_params)\n",
    "in_dim = int(Xtmp.shape[1])\n",
    "x0 = np.array([5,-5,5,-5,5,5,-5,5,5,5])\n",
    "xmin = np.full(in_dim, -10)\n",
    "xmax = np.full(in_dim, 10)\n",
    "delta = 2\n",
    "step = 1\n",
    "sum_eq = 20\n",
    "\n",
    "# MLP\n",
    "m_MLP, data, hist = generate_and_train(\n",
    "    \"quadratic\", quadratic_params,\n",
    "    \"MLP\", dict(in_dim=in_dim, hidden_dims=[64,64], out_dim=1),\n",
    "    train_params,\n",
    "    lr = 1e-3,\n",
    ")\n",
    "with torch.no_grad(): print(\"quadratic+MLP yhat:\", m_MLP(data[\"raw\"][\"X_test\"][:4].to(data[\"device\"])))\n",
    "\n",
    "x_best_MLP, y_best_MLP, hist_MLP = local_search_l1(\n",
    "    m_MLP, x0, xmin, xmax,\n",
    "    delta=delta, step=step,\n",
    "    sum_eq=sum_eq,\n",
    "    live=True\n",
    ")\n",
    "\n",
    "x_best_MLP_IP, y_best_MLP_IP, hist_DFN_IP = solve_mlp_ip_gurobi(\n",
    "    m_MLP, xmin, xmax,\n",
    "    sum_eq=sum_eq,\n",
    "    verbose=True, time_limit=60\n",
    ")\n",
    "\n",
    "# DFN (requires lemon_mcf working)\n",
    "m_DFN, data_DFN, hist_DFN = generate_and_train(\n",
    "    \"quadratic\", quadratic_params,\n",
    "    \"DFN\", dict(input_dim=in_dim, layer_sizes=[16, 64, 16], p_list=[1, 1], seed=0),\n",
    "    train_params,\n",
    "    lr = 1e-1,\n",
    "    alpha=1e-6, beta=-5.0\n",
    ")\n",
    "with torch.no_grad(): print(\"quadratic+DFN yhat:\", m_DFN(data_DFN[\"raw\"][\"X_test\"][:4].to(data_DFN[\"device\"])))\n",
    "\n",
    "x_best_DFN, y_best_DFN, hist_DFN_ls = local_search_l1(\n",
    "    m_DFN, x0, xmin, xmax,\n",
    "    delta=delta, step=step,\n",
    "    sum_eq=sum_eq,\n",
    "    live=True\n",
    ")\n",
    "x_best_DFN_IP, y_best_DFN_IP, hist_DFN_IP = solve_dfn_ip_gurobi(\n",
    "    m_DFN, xmin, xmax,\n",
    "    sum_eq=sum_eq,\n",
    "    verbose=True, time_limit=60\n",
    ")\n",
    "\n",
    "# MaxAffine\n",
    "m_MAFF, data, hist = generate_and_train(\n",
    "    \"quadratic\", quadratic_params,\n",
    "    \"MaxAffine\", dict(in_dim=in_dim, n_pieces=400),\n",
    "    train_params,\n",
    "    lr = 1e-2,\n",
    ")\n",
    "with torch.no_grad(): print(\"quadratic+MaxAffine yhat:\", m_MAFF(data[\"raw\"][\"X_test\"][:4].to(data[\"device\"])))\n",
    "\n",
    "x_best_MAFF, y_best_MAFF, hist_MAFF = local_search_l1(\n",
    "    m_MAFF, x0, xmin, xmax,\n",
    "    delta=delta, step=step,\n",
    "    sum_eq=sum_eq,\n",
    "    live=True\n",
    ")\n",
    "x_best_MAFF_IP, y_best_MAFF_IP, hist_MAFF_IP = solve_maxaffine_ip_gurobi(\n",
    "    m_MAFF, xmin, xmax,\n",
    "    sum_eq=sum_eq,\n",
    "    verbose=True, time_limit=60\n",
    ")\n",
    "\n",
    "\n",
    "# LSET\n",
    "m_LSET, data, hist = generate_and_train(\n",
    "    \"quadratic\", quadratic_params,\n",
    "    \"LSET\", dict(in_dim=in_dim, n_pieces=400, T=0.05),\n",
    "    train_params,\n",
    "    lr = 1e-2,\n",
    ")\n",
    "with torch.no_grad(): print(\"quadratic+LSET yhat:\", m_LSET(data[\"raw\"][\"X_test\"][:4].to(data[\"device\"])))\n",
    "\n",
    "x_best_LSET, y_best_LSET, hist_LSET = local_search_l1(\n",
    "    m_LSET, x0, xmin, xmax,\n",
    "    delta=delta, step=step,\n",
    "    sum_eq=sum_eq,\n",
    "    live=True\n",
    ")\n",
    "\n",
    "x_best_LSET_IP, y_best_LSET_IP, hist_LSET_IP = solve_lset_ip_gurobi(\n",
    "    m_LSET, xmin, xmax,\n",
    "    sum_eq=sum_eq,\n",
    "    verbose=True, time_limit=60\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ae2dad03-2df2-4815-8618-1bcbfa848ddb",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "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
}
