{
 "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": 1,
   "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",
    "import pandas as pd\n",
    "import copy\n",
    "\n",
    "_TOL = 1e-9"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3cd5a10c-7768-4318-8244-beaf6c4c84d1",
   "metadata": {},
   "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": {},
   "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",
    "    gt = dict(type=\"mdvsp\", N=int(N), SS=int(SS), TT=int(TT),\n",
    "              src=src, dst=dst, cost=cost, cap0=cap0, idxSS=idxSS, idxTT=idxTT)\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "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": {},
   "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",
    "    gt = {\"type\":\"assignment\", \"C\":C.astype(np.float32)}\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "58630247-ccd6-4f88-9bad-06c40e05e81d",
   "metadata": {},
   "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": [
    "def generate_convex_quadratic_dataset(K, dim, eigen_min, eigen_max, x_min, x_max,\n",
    "                                      noise_std=0.0, seed=0, x_star_zero=True):\n",
    "    rng = np.random.default_rng(seed)\n",
    "    U, R = np.linalg.qr(rng.standard_normal((dim, dim)))\n",
    "    U *= np.sign(np.diag(R) + 1e-12)\n",
    "    Q = U @ np.diag(rng.uniform(eigen_min, eigen_max, dim)) @ U.T\n",
    "\n",
    "    x_star = np.zeros(dim, dtype=np.int64) if x_star_zero else rng.integers(x_min, x_max + 1, size=dim)\n",
    "\n",
    "    X = rng.integers(x_min, x_max + 1, size=(K, dim)).astype(np.float32)\n",
    "    d = X - x_star\n",
    "    y = np.einsum(\"bi,ij,bj->b\", d, Q, d) + noise_std * rng.normal(size=K)\n",
    "\n",
    "    gt = {\"type\":\"quadratic\", \"Q\":Q.astype(np.float32), \"x_star\":x_star.astype(np.int64)}\n",
    "    return X.astype(np.float32), y.astype(np.float32), gt\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "666e79e4-8daa-483c-995d-6a3b92367b88",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 10) (50,) [1676.3578 1047.4658 1189.3267  936.0379  602.4306]\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": 11,
   "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": {},
   "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": {},
   "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": {},
   "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": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "71fb35a6-da1c-4761-92f9-b9f5177ccc9f",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def generate_and_train_simple(dataset_type, dataset_params, model_type, model_params, train_params=None):\n",
    "    import numpy as np\n",
    "    import torch\n",
    "    import torch.nn.functional as F\n",
    "    import matplotlib.pyplot as plt\n",
    "    from torch.utils.data import DataLoader, TensorDataset\n",
    "    from IPython.display import display\n",
    "\n",
    "    tp = train_params or {}\n",
    "    epochs     = int(tp.get(\"epochs\", 200))\n",
    "    batch_sz   = int(tp.get(\"batch_size\", 32))\n",
    "    lr         = float(tp.get(\"lr\", 1e-3))\n",
    "    wd         = float(tp.get(\"weight_decay\", 0.0))\n",
    "    val_frac   = float(tp.get(\"val_frac\", 0.15))\n",
    "    test_frac  = float(tp.get(\"test_frac\", 0.15))\n",
    "    eps        = float(tp.get(\"eps\", 1e-8))\n",
    "    seed       = int(tp.get(\"seed\", 0))\n",
    "    device     = tp.get(\"device\", \"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "    plot_every = int(tp.get(\"plot_every\", 0))\n",
    "    plot_points= int(tp.get(\"plot_points\", 2048))\n",
    "    plot_chunk = int(tp.get(\"plot_chunk\", 4096))\n",
    "    print_stats= bool(tp.get(\"print_stats\", True))\n",
    "\n",
    "    # ---- data ----\n",
    "    dt = dataset_type.lower()\n",
    "    if dt == \"mdvsp\":\n",
    "        X, y, gt = make_mdvsp_dataset(**dataset_params)\n",
    "    elif dt == \"assignment\":\n",
    "        X, y, gt = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "    elif dt == \"quadratic\":\n",
    "        X, y, gt = generate_convex_quadratic_dataset(**dataset_params)\n",
    "    else:\n",
    "        raise ValueError(\"dataset_type must be: mdvsp | assignment | quadratic\")\n",
    "\n",
    "    X = torch.as_tensor(X, dtype=torch.float32)\n",
    "    y = torch.as_tensor(y, dtype=torch.float32).view(-1)\n",
    "\n",
    "    # ---- quick dataset stats (RAW) ----\n",
    "    with torch.no_grad():\n",
    "        xmn = X.mean(0); xsd = X.std(0, unbiased=False)\n",
    "        print(\n",
    "            f\"\\n--- Dataset stats ({dataset_type}) ---\\n\"\n",
    "            f\"  X: shape={tuple(X.shape)}  mean(mean)={xmn.mean():.3g}  std(mean)={xsd.mean():.3g}  \"\n",
    "            f\"min={float(X.min()):.3g}  max={float(X.max()):.3g}\\n\"\n",
    "            f\"  y: shape={tuple(y.shape)}  mean={float(y.mean()):.3g}  std={float(y.std(unbiased=False)):.3g}  \"\n",
    "            f\"min={float(y.min()):.3g}  max={float(y.max()):.3g}\\n\"\n",
    "        )\n",
    "\n",
    "    # ---- 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_tr = perm[:n_train]\n",
    "    i_va = perm[n_train:n_train+n_val]\n",
    "    i_te = perm[n_train+n_val:]\n",
    "\n",
    "    Xtr, ytr = X[i_tr], y[i_tr]\n",
    "    Xva, yva = X[i_va], y[i_va]\n",
    "    Xte, yte = X[i_te], y[i_te]\n",
    "\n",
    "    # ---- normalize (train stats only) ----\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",
    "    XtrN = (Xtr - x_mean) / x_std\n",
    "    XvaN = (Xva - x_mean) / x_std\n",
    "    XteN = (Xte - x_mean) / x_std\n",
    "    ytrN = (ytr - y_mean) / y_std\n",
    "    yvaN = (yva - y_mean) / y_std\n",
    "    yteN = (yte - y_mean) / y_std\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",
    "    # ---- plotting subset of val ----\n",
    "    Nv = XvaN.shape[0]\n",
    "    if plot_points <= 0 or plot_points >= Nv:\n",
    "        plot_idx = torch.arange(Nv)\n",
    "    else:\n",
    "        g_plot = torch.Generator().manual_seed(seed + 12345)\n",
    "        plot_idx = torch.randperm(Nv, generator=g_plot)[:plot_points]\n",
    "\n",
    "    # ---- model ----\n",
    "    mt = model_type\n",
    "    mp = dict(model_params)\n",
    "\n",
    "    if mt == \"DFN\":\n",
    "        model = DFN(**mp)\n",
    "        extra = f\"layers={mp.get('layer_sizes')} p_list={mp.get('p_list')} alpha={getattr(model,'alpha',None)} beta={getattr(model,'beta',None)}\"\n",
    "    else:\n",
    "        mp.pop(\"alpha\", None); mp.pop(\"beta\", None)\n",
    "        if mt == \"MLP\":\n",
    "            model = MLP(**mp)\n",
    "            extra = f\"hidden={mp.get('hidden_dims')}\"\n",
    "        elif mt == \"MaxAffine\":\n",
    "            model = MaxAffine(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')}\"\n",
    "        elif mt == \"LSET\":\n",
    "            model = LSET(**mp)\n",
    "            extra = f\"n_pieces={mp.get('n_pieces')} T={mp.get('T')}\"\n",
    "        else:\n",
    "            raise ValueError(\"model_type must be: DFN | MLP | MaxAffine | LSET\")\n",
    "\n",
    "    model = model.to(device)\n",
    "    opt = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=wd)\n",
    "\n",
    "    # ---- header like original ----\n",
    "    n_params = sum(p.numel() for p in model.parameters())\n",
    "    n_trainable = sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "    print(\n",
    "        f\"\\n=== Run: {dataset_type} | {model_type} ===\\n\"\n",
    "        f\"  data: N={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}\\n\"\n",
    "        f\"  train: device={device}  epochs={epochs}  batch={batch_sz}  lr={lr:g}  wd={wd:g}  seed={seed}\\n\"\n",
    "    )\n",
    "\n",
    "    # ---- metrics + live plotting ----\n",
    "    history = {\"train_mse_norm\": [], \"val_mse_norm\": []}\n",
    "    best_val = float(\"inf\")\n",
    "    best_ep = 0\n",
    "    best_state = None\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def mse_norm(loader):\n",
    "        model.eval()\n",
    "        tot, n = 0.0, 0\n",
    "        for xb, yb in loader:\n",
    "            xb, yb = xb.to(device), yb.to(device)\n",
    "            pred = model(xb).squeeze(-1)\n",
    "            tot += F.mse_loss(pred, yb, reduction=\"sum\").item()\n",
    "            n += yb.numel()\n",
    "        return tot / max(n, 1)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def predict_chunks(x_dev):\n",
    "        outs = []\n",
    "        for i in range(0, x_dev.shape[0], plot_chunk):\n",
    "            outs.append(model(x_dev[i:i+plot_chunk]).squeeze(-1))\n",
    "        return torch.cat(outs, 0)\n",
    "\n",
    "    live = display(None, display_id=True) if plot_every > 0 else None\n",
    "\n",
    "    for ep in range(1, epochs + 1):\n",
    "        model.train()\n",
    "        for xb, yb in train_loader:\n",
    "            xb, yb = xb.to(device), yb.to(device)\n",
    "            loss = F.mse_loss(model(xb).squeeze(-1), yb)\n",
    "            opt.zero_grad(set_to_none=True)\n",
    "            loss.backward()\n",
    "            opt.step()\n",
    "\n",
    "        tr_mse = mse_norm(train_loader)\n",
    "        va_mse = mse_norm(val_loader)\n",
    "        history[\"train_mse_norm\"].append(tr_mse)\n",
    "        history[\"val_mse_norm\"].append(va_mse)\n",
    "\n",
    "        if va_mse < best_val:\n",
    "            best_val = va_mse\n",
    "            best_ep = ep\n",
    "            best_state = {k: v.detach().cpu().clone() for k, v in model.state_dict().items()}\n",
    "\n",
    "        if plot_every > 0 and (ep == 1 or ep % plot_every == 0 or ep == epochs):\n",
    "            model.eval()\n",
    "            x_plot = XvaN[plot_idx].to(device)\n",
    "            y_true = yvaN[plot_idx].to(device)\n",
    "            y_pred = predict_chunks(x_plot)\n",
    "\n",
    "            fig, ax = plt.subplots(1, 2, figsize=(10, 4))\n",
    "            ax[0].plot(history[\"train_mse_norm\"], label=\"train\")\n",
    "            ax[0].plot(history[\"val_mse_norm\"], label=\"val\")\n",
    "            ax[0].set_yscale(\"log\")\n",
    "            ax[0].set_title(f\"Epoch {ep}/{epochs} | val MSE={va_mse:.3e} (norm)\")\n",
    "            ax[0].legend()\n",
    "\n",
    "            yt = y_true.detach().cpu().numpy()\n",
    "            yp = y_pred.detach().cpu().numpy()\n",
    "            ax[1].scatter(yt, yp, s=10)\n",
    "            lo = float(min(yt.min(), yp.min()))\n",
    "            hi = float(max(yt.max(), yp.max()))\n",
    "            ax[1].plot([lo, hi], [lo, hi])\n",
    "            ax[1].set_xlabel(\"y_true (norm)\")\n",
    "            ax[1].set_ylabel(\"y_pred (norm)\")\n",
    "            ax[1].set_title(f\"Val scatter (n={len(yt)})\")\n",
    "\n",
    "            plt.tight_layout()\n",
    "            live.update(fig)\n",
    "            plt.close(fig)\n",
    "\n",
    "    if best_state is not None:\n",
    "        model.load_state_dict(best_state)\n",
    "\n",
    "    if print_stats:\n",
    "        print(f\"[DONE] best val MSE (norm) = {best_val:.3e} @ epoch {best_ep}\\n\")\n",
    "\n",
    "    scaler = {\"x_mean\": x_mean, \"x_std\": x_std, \"y_mean\": y_mean, \"y_std\": y_std}\n",
    "    data = {\n",
    "        \"raw\":  {\"Xtr\": Xtr,  \"ytr\": ytr,  \"Xva\": Xva,  \"yva\": yva,  \"Xte\": Xte,  \"yte\": yte},\n",
    "        \"norm\": {\"Xtr\": XtrN, \"ytr\": ytrN, \"Xva\": XvaN, \"yva\": yvaN, \"Xte\": XteN, \"yte\": yteN},\n",
    "        \"scaler\": scaler,\n",
    "        \"best_val_mse_norm\": float(best_val),\n",
    "        \"best_epoch\": int(best_ep),\n",
    "        \"stats\": {\"n_params\": int(n_params), \"n_trainable\": int(n_trainable)},\n",
    "        \"device\": device,\n",
    "    \"true\": gt,\n",
    "    }\n",
    "\n",
    "    spec = {\n",
    "        \"model\": model_type,\n",
    "        \"extra\": extra,\n",
    "        \"n_params\": int(n_params),\n",
    "        \"n_trainable\": int(n_trainable),\n",
    "        \"model_params\": dict(model_params),\n",
    "        \"train_params\": {\n",
    "            \"epochs\": int(epochs),\n",
    "            \"batch_size\": int(batch_sz),\n",
    "            \"lr\": float(lr),\n",
    "            \"weight_decay\": float(wd),\n",
    "            \"seed\": int(seed),\n",
    "            \"device\": str(device),\n",
    "            \"val_frac\": float(val_frac),\n",
    "            \"test_frac\": float(test_frac),\n",
    "        },\n",
    "    }\n",
    "\n",
    "    return model, data, history, spec"
   ]
  },
  {
   "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": 16,
   "id": "1462641f-61ba-4762-b716-a000da6db685",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "def local_search_l1_int(f, x0, x_min, x_max, delta, sum_eq=None, max_iters=10_000, print_every=1):\n",
    "    x  = np.asarray(x0,    int).ravel()\n",
    "    lo = np.asarray(x_min, int).ravel()\n",
    "    hi = np.asarray(x_max, int).ravel()\n",
    "    n = x.size\n",
    "    delta = int(delta)\n",
    "\n",
    "    assert lo.size == n and hi.size == n\n",
    "    assert np.all(x >= lo) and np.all(x <= hi)\n",
    "    if sum_eq is not None:\n",
    "        sum_eq = int(sum_eq)\n",
    "        assert int(x.sum()) == sum_eq\n",
    "\n",
    "    def eval_batch(X):\n",
    "        y = f(X)  # expects X: (B,n) or (n,)\n",
    "        y = np.asarray(y, float)\n",
    "        return y.reshape(-1)\n",
    "\n",
    "    def ok(z):\n",
    "        if np.any(z < lo) or np.any(z > hi): return False\n",
    "        if sum_eq is not None and int(z.sum()) != sum_eq: return False\n",
    "        return True\n",
    "\n",
    "    # integer deltas with exact L1=k\n",
    "    def deltas_exact(k):\n",
    "        d = np.zeros(n, int)\n",
    "        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",
    "    y = float(eval_batch(x[None, :])[0])\n",
    "    hist = [{\"iter\": 0, \"t\": 0.0, \"best_y\": y, \"x\": x.copy()}]\n",
    "    print(f\"iter=0  t=0.00s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    for it in range(1, max_iters + 1):\n",
    "        cand = []\n",
    "        for k in range(1, delta + 1):\n",
    "            for dlt in deltas_exact(k):\n",
    "                z = x + dlt\n",
    "                if ok(z): cand.append(z)\n",
    "\n",
    "        if not cand:\n",
    "            print(f\"STOP: no feasible neighbors. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        Y = eval_batch(np.stack(cand, 0))\n",
    "        j = int(np.argmin(Y))\n",
    "        if float(Y[j]) >= y:\n",
    "            print(f\"STOP: local minimum. best_y={y:.6g} x={x.tolist()}\")\n",
    "            break\n",
    "\n",
    "        x, y = cand[j], float(Y[j])\n",
    "        hist.append({\"iter\": it, \"t\": time.perf_counter() - t0, \"best_y\": y, \"x\": x.copy()})\n",
    "        if it % max(1, print_every) == 0:\n",
    "            print(f\"iter={it}  t={hist[-1]['t']:.2f}s  best_y={y:.6g}  x={x.tolist()}\")\n",
    "\n",
    "    return x, y, hist\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e8ad3cb-514b-47a6-91f9-6378c4b80993",
   "metadata": {},
   "source": [
    "### DFN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "e2987272-f934-4bcd-8fbd-ebf382b07e05",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_dfn_ip_gurobi(dfn, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import numpy as np\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "    import torch\n",
    "    import torch.nn.functional as F\n",
    "\n",
    "    # --- raw bounds + sum constraint live on x ---\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = x_min.size\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    # --- scaler (train stats) ---\n",
    "    x_mean = scaler[\"x_mean\"].detach().cpu().numpy().reshape(-1)\n",
    "    x_std  = scaler[\"x_std\"].detach().cpu().numpy().reshape(-1)\n",
    "    y_mean = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    y_std  = float(scaler[\"y_std\"].detach().cpu())\n",
    "\n",
    "    # --- DFN params (match forward STE rounding) ---\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(),\n",
    "                 dfn.cost_fixed.detach().cpu().numpy()]\n",
    "    cap  = np.r_[torch.round(F.softplus(dfn.cap_raw.detach())).cpu().numpy(),\n",
    "                 dfn.cap_fixed.detach().cpu().numpy()]\n",
    "\n",
    "    A = dfn.A.detach().cpu().numpy()\n",
    "    if isinstance(dfn.A, torch.nn.Parameter):\n",
    "        A = np.round(A)\n",
    "    b = np.round(dfn.b_raw.detach().cpu().numpy())\n",
    "\n",
    "    boundary = dfn.boundary.detach().cpu().numpy().astype(int)\n",
    "    fix = int(dfn.fix_node)\n",
    "    n = int(dfn.n)\n",
    "    m = int(src.size)\n",
    "    alpha = float(dfn.alpha)\n",
    "    beta  = float(dfn.beta)\n",
    "\n",
    "    # --- build edge incidence lists for flow balance ---\n",
    "    out = [[] for _ in range(n)]\n",
    "    inn = [[] for _ in range(n)]\n",
    "    for e in range(m):\n",
    "        out[src[e]].append(e)\n",
    "        inn[dst[e]].append(e)\n",
    "\n",
    "    # --- gurobi model ---\n",
    "    M = gp.Model(\"DFN_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    f = M.addVars(m, lb=0.0, ub=cap.tolist(), vtype=GRB.CONTINUOUS, name=\"f\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq)\n",
    "\n",
    "    # supplies: s[boundary] = A*((x-x_mean)/x_std) + b, and s[fix] = -sum(s[boundary])\n",
    "    xm_over_xs = x_mean / x_std\n",
    "    s = [0] * n\n",
    "    s_boundary = []\n",
    "    for r, v in enumerate(boundary):\n",
    "        const = float(b[r] - (A[r] * xm_over_xs).sum())\n",
    "        expr = const + gp.quicksum((A[r, j] / x_std[j]) * x[j] for j in range(d) if A[r, j] != 0)\n",
    "        s[v] = expr\n",
    "        s_boundary.append(expr)\n",
    "    s[fix] = -gp.quicksum(s_boundary)\n",
    "\n",
    "    # flow conservation\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",
    "    # objective: raw y = (alpha * flow_cost + beta) * y_std + y_mean\n",
    "    flow_cost = gp.quicksum(cost[e] * f[e] for e in range(m))\n",
    "    M.setObjective((alpha * flow_cost + beta) * y_std + y_mean, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No solution (Gurobi status {M.Status})\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None)}\n",
    "    return x_star, float(M.ObjVal), info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9d602f3a-7b8a-4f97-9f11-a35d85bbb338",
   "metadata": {},
   "source": [
    "### MLP"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "befab4b0-814e-4a86-b46d-9b84569bc236",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_mlp_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import numpy as np\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "    import torch\n",
    "\n",
    "    # --- raw bounds + sum constraint on x ---\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = x_min.size\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    # --- scaler (train stats) ---\n",
    "    xm = scaler[\"x_mean\"].detach().cpu().numpy().reshape(-1)   # (d,)\n",
    "    xs = scaler[\"x_std\"].detach().cpu().numpy().reshape(-1)    # (d,)\n",
    "    ym = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    ys = float(scaler[\"y_std\"].detach().cpu())\n",
    "\n",
    "    # --- unwrap optional affine wrapper (if you ever use one) ---\n",
    "    base = model\n",
    "    a_out, b_out = 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base = model.base\n",
    "        a_out, b_out = float(model.a), float(model.b)\n",
    "\n",
    "    # --- grab Linear layers from MLP.net (Sequential) ---\n",
    "    if not hasattr(base, \"net\"):\n",
    "        raise ValueError(\"Expected an MLP with attribute .net (nn.Sequential).\")\n",
    "    linears = [L for L in base.net if isinstance(L, torch.nn.Linear)]\n",
    "    if not linears:\n",
    "        raise ValueError(\"No Linear layers found in base.net\")\n",
    "\n",
    "    W = [L.weight.detach().cpu().numpy().astype(float) for L in linears]\n",
    "    b = [L.bias.detach().cpu().numpy().astype(float)   for L in linears]\n",
    "\n",
    "    # --- absorb input normalization x_norm = (x-xm)/xs into first layer ---\n",
    "    W[0] = W[0] / xs[None, :]\n",
    "    b[0] = b[0] - W[0] @ xm\n",
    "\n",
    "    # --- absorb optional output affine: y_norm = a_out*y_base + b_out ---\n",
    "    W[-1] *= a_out\n",
    "    b[-1] = a_out * b[-1] + b_out\n",
    "\n",
    "    # --- safe bounds for pre-activations (big-M) ---\n",
    "    u = np.maximum(np.abs(x_min), np.abs(x_max))  # bound on |x|\n",
    "    preLU = []\n",
    "    for k in range(len(W) - 1):                   # hidden layers only\n",
    "        U = np.abs(W[k]) @ u + np.abs(b[k])       # bound on |a|\n",
    "        L = -U\n",
    "        preLU.append((L, U))\n",
    "        u = np.maximum(0.0, U)                    # z = relu(a) in [0, U]\n",
    "\n",
    "    # --- build gurobi model ---\n",
    "    M = gp.Model(\"MLP_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    prev = [x[i] for i in range(d)]\n",
    "\n",
    "    # --- hidden ReLU layers ---\n",
    "    for k in range(len(W) - 1):\n",
    "        Lk, Uk = preLU[k]\n",
    "        h = W[k].shape[0]\n",
    "\n",
    "        a = [M.addVar(lb=float(Lk[j]), ub=float(Uk[j]), name=f\"a{k}_{j}\") for j in range(h)]\n",
    "        z = [M.addVar(lb=0.0, ub=float(max(0.0, Uk[j])), name=f\"z{k}_{j}\") for j in range(h)]\n",
    "\n",
    "        for j in range(h):\n",
    "            M.addConstr(a[j] == b[k][j] + gp.quicksum(W[k][j, i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "            Lj, Uj = float(Lk[j]), float(Uk[j])\n",
    "            if Uj <= 0.0:\n",
    "                M.addConstr(z[j] == 0.0)\n",
    "            elif Lj >= 0.0:\n",
    "                M.addConstr(z[j] == a[j])\n",
    "            else:\n",
    "                s = M.addVar(vtype=GRB.BINARY, name=f\"s{k}_{j}\")\n",
    "                M.addConstr(z[j] >= a[j])\n",
    "                M.addConstr(z[j] >= 0.0)\n",
    "                M.addConstr(z[j] <= Uj * s)\n",
    "                M.addConstr(z[j] <= a[j] - Lj * (1 - s))\n",
    "\n",
    "        prev = z\n",
    "\n",
    "    # --- output layer (assume scalar) gives y_norm ---\n",
    "    if W[-1].shape[0] != 1:\n",
    "        raise ValueError(f\"Expected scalar output, got out_dim={W[-1].shape[0]}\")\n",
    "    y_norm = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == b[-1][0] + gp.quicksum(W[-1][0,i] * prev[i] for i in range(len(prev))))\n",
    "\n",
    "    # raw objective: y_raw = y_norm * y_std + y_mean\n",
    "    M.setObjective(ys * y_norm + ym, GRB.MINIMIZE)\n",
    "\n",
    "    M.optimize()\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "edf28c5b-e3fa-4e42-9c75-f4c32a2a0ad6",
   "metadata": {},
   "source": [
    "### Max Affine"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "0d62429d-5b20-488b-bc74-e9025a597dae",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_maxaffine_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import numpy as np\n",
    "    import 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",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm = scaler[\"x_mean\"].detach().cpu().numpy().reshape(-1)\n",
    "    xs = scaler[\"x_std\"].detach().cpu().numpy().reshape(-1)\n",
    "    ym = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    ys = float(scaler[\"y_std\"].detach().cpu())\n",
    "\n",
    "    # optional output affine wrapper (if you ever use it)\n",
    "    base = model\n",
    "    a_out, b_out = 1.0, 0.0\n",
    "    if hasattr(model, \"base\") and hasattr(model, \"a\") and hasattr(model, \"b\"):\n",
    "        base = model.base\n",
    "        a_out, b_out = float(model.a), float(model.b)\n",
    "\n",
    "    W = base.W.detach().cpu().numpy().astype(float)   # (K,d)\n",
    "    b = base.b.detach().cpu().numpy().astype(float)   # (K,)\n",
    "    K = W.shape[0]\n",
    "\n",
    "    # absorb x normalization: x_norm = (x-xm)/xs\n",
    "    Weff = W / xs[None, :]\n",
    "    beff = b - (Weff @ xm)\n",
    "\n",
    "    # absorb output affine: y_norm = a_out*t + b_out\n",
    "    Weff *= a_out\n",
    "    beff  = a_out * beff + b_out\n",
    "\n",
    "    M = gp.Model(\"MaxAffine_IP\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    # t = max_k (Weff[k]^T x + beff[k]) encoded as t >= each affine piece\n",
    "    t = M.addVar(lb=-GRB.INFINITY, vtype=GRB.CONTINUOUS, name=\"t_norm\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(t >= beff[k] + gp.quicksum(Weff[k, j] * x[j] for j in range(d) if Weff[k, j] != 0.0))\n",
    "\n",
    "    # raw objective: y_raw = t_norm * y_std + y_mean\n",
    "    M.setObjective(ys * t + ym, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], float)\n",
    "    info = {\"status\": M.Status, \"runtime\": M.Runtime, \"gap\": getattr(M, \"MIPGap\", None), \"sol_count\": M.SolCount}\n",
    "    return x_star, float(M.ObjVal), info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "90b14a64-82a4-4d77-b9d6-08490ab87733",
   "metadata": {},
   "source": [
    "### LSET"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "ec65d59d-1bb1-4d73-82aa-4bec67488bf0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_lset_ip_gurobi(model, scaler, x_min, x_max, sum_eq, *, integer_x=True, verbose=False, time_limit=None):\n",
    "    import numpy as np\n",
    "    import gurobipy as gp\n",
    "    from gurobipy import GRB\n",
    "\n",
    "    x_min = np.asarray(x_min, float).ravel()\n",
    "    x_max = np.asarray(x_max, float).ravel()\n",
    "    d = int(x_min.size)\n",
    "    sum_eq = float(sum_eq)\n",
    "\n",
    "    xm = np.asarray(scaler[\"x_mean\"].detach().cpu(), dtype=float).reshape(-1)\n",
    "    xs = np.asarray(scaler[\"x_std\"].detach().cpu(),  dtype=float).reshape(-1)\n",
    "    ym = float(scaler[\"y_mean\"].detach().cpu())\n",
    "    ys = float(scaler[\"y_std\"].detach().cpu())\n",
    "\n",
    "    A = model.A.detach().cpu().numpy().astype(float)   # (K,d)\n",
    "    b = model.b.detach().cpu().numpy().astype(float)   # (K,)\n",
    "    T = float(model.T)\n",
    "    K = int(A.shape[0])\n",
    "    assert T != 0.0\n",
    "\n",
    "    # absorb x_norm = (x_raw - xm)/xs  =>  (A/xs) x_raw + (b - (A/xs)xm)\n",
    "    Aeff = A / xs[None, :]\n",
    "    beff = b - (Aeff @ xm)\n",
    "\n",
    "    # ---------- safe linear bounds for z_k ----------\n",
    "    # lin_k(x) = beff[k] + sum_j Aeff[k,j] * x_j, x_j in [x_min, x_max]\n",
    "    lin_lo = np.empty(K, dtype=float)\n",
    "    lin_hi = np.empty(K, dtype=float)\n",
    "    for k in range(K):\n",
    "        a = Aeff[k]\n",
    "        lo = beff[k]\n",
    "        hi = beff[k]\n",
    "        pos = a >= 0\n",
    "        lo += (a[pos] * x_min[pos]).sum() + (a[~pos] * x_max[~pos]).sum()\n",
    "        hi += (a[pos] * x_max[pos]).sum() + (a[~pos] * x_min[~pos]).sum()\n",
    "        lin_lo[k], lin_hi[k] = lo, hi\n",
    "\n",
    "    z_lo = lin_lo / T\n",
    "    z_hi = lin_hi / T\n",
    "    m_lo = float(np.max(z_lo))\n",
    "    m_hi = float(np.max(z_hi))\n",
    "\n",
    "    # w_k = z_k - m, with m >= z_k => w_k <= 0\n",
    "    w_lo = float(np.min(z_lo - m_hi))  # smallest possible (most negative)\n",
    "    # u_k = exp(w_k) in [exp(w_lo), 1]\n",
    "    u_lo = float(np.exp(max(-700.0, w_lo)))  # avoid underflow to 0\n",
    "    s_lo = max(1e-12, K * u_lo)\n",
    "    s_hi = float(K * 1.0)\n",
    "    v_lo = float(np.log(s_lo))\n",
    "    v_hi = float(np.log(s_hi))\n",
    "\n",
    "    # y_norm = T*(m + v)\n",
    "    yN_lo = float(T * (m_lo + v_lo))\n",
    "    yN_hi = float(T * (m_hi + v_hi))\n",
    "    y_lo  = float(ys * yN_lo + ym)\n",
    "    y_hi  = float(ys * yN_hi + ym)\n",
    "\n",
    "    # ---------- model ----------\n",
    "    M = gp.Model(\"lset_ip_stable_bounded\")\n",
    "    M.Params.OutputFlag = 1 if verbose else 0\n",
    "    if time_limit is not None:\n",
    "        M.Params.TimeLimit = float(time_limit)\n",
    "\n",
    "    # exp/log general constraints\n",
    "    M.Params.FuncNonlinear = 1\n",
    "\n",
    "    # tighter numerics\n",
    "    M.Params.FeasibilityTol = 1e-9\n",
    "    M.Params.OptimalityTol  = 1e-9\n",
    "    M.Params.IntFeasTol     = 1e-9\n",
    "    M.Params.NumericFocus   = 3\n",
    "\n",
    "    xt = GRB.INTEGER if integer_x else GRB.CONTINUOUS\n",
    "    x = M.addVars(d, lb=x_min.tolist(), ub=x_max.tolist(), vtype=xt, name=\"x\")\n",
    "    M.addConstr(gp.quicksum(x[i] for i in range(d)) == sum_eq, name=\"sum_eq\")\n",
    "\n",
    "    z = M.addVars(K, lb=z_lo.tolist(), ub=z_hi.tolist(), vtype=GRB.CONTINUOUS, name=\"z\")\n",
    "    for k in range(K):\n",
    "        lin = beff[k] + gp.quicksum(Aeff[k, j] * x[j] for j in range(d) if Aeff[k, j] != 0.0)\n",
    "        M.addConstr(z[k] == lin / T, name=f\"zdef_{k}\")\n",
    "\n",
    "    m = M.addVar(lb=m_lo, ub=m_hi, vtype=GRB.CONTINUOUS, name=\"m\")\n",
    "    w = M.addVars(K, lb=w_lo, ub=0.0, vtype=GRB.CONTINUOUS, name=\"w\")\n",
    "    for k in range(K):\n",
    "        M.addConstr(m >= z[k], name=f\"m_ge_z_{k}\")\n",
    "        M.addConstr(w[k] == z[k] - m, name=f\"wdef_{k}\")\n",
    "\n",
    "    u = M.addVars(K, lb=0.0, ub=1.0, vtype=GRB.CONTINUOUS, name=\"u\")\n",
    "    for k in range(K):\n",
    "        M.addGenConstrExp(w[k], u[k], name=f\"exp_{k}\")\n",
    "\n",
    "    s = M.addVar(lb=s_lo, ub=s_hi, vtype=GRB.CONTINUOUS, name=\"s\")\n",
    "    M.addConstr(s == gp.quicksum(u[k] for k in range(K)), name=\"sumexp_shifted\")\n",
    "\n",
    "    v = M.addVar(lb=v_lo, ub=v_hi, vtype=GRB.CONTINUOUS, name=\"v\")\n",
    "    M.addGenConstrLog(s, v, name=\"log_shifted\")\n",
    "\n",
    "    y_norm = M.addVar(lb=yN_lo, ub=yN_hi, vtype=GRB.CONTINUOUS, name=\"y_norm\")\n",
    "    M.addConstr(y_norm == T * (m + v), name=\"y_norm_def\")\n",
    "\n",
    "    y_raw = M.addVar(lb=y_lo, ub=y_hi, vtype=GRB.CONTINUOUS, name=\"y_raw\")\n",
    "    M.addConstr(y_raw == ys * y_norm + ym, name=\"y_raw_def\")\n",
    "\n",
    "    M.setObjective(y_raw, GRB.MINIMIZE)\n",
    "    M.optimize()\n",
    "\n",
    "    if M.SolCount == 0:\n",
    "        raise RuntimeError(f\"No feasible solution found. Gurobi status {M.Status}\")\n",
    "\n",
    "    x_star = np.array([x[i].X for i in range(d)], dtype=float)\n",
    "    y_star = float(y_raw.X)\n",
    "\n",
    "    info = {\n",
    "        \"status\": M.Status,\n",
    "        \"runtime\": M.Runtime,\n",
    "        \"gap\": getattr(M, \"MIPGap\", None),\n",
    "        \"sol_count\": M.SolCount,\n",
    "        \"obj_gurobi\": float(M.ObjVal),\n",
    "        \"obj_bound\": float(getattr(M, \"ObjBound\", float(\"nan\"))),\n",
    "    }\n",
    "    return x_star, y_star, info\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73b65b06-6612-4032-ad56-7ee64051ba21",
   "metadata": {},
   "source": [
    "# Tests and Results"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a603db2e-924b-4fba-8973-74f86bb16562",
   "metadata": {},
   "source": [
    "### Assignment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c5a3acd7-51df-4afd-8a6d-dd8ca389f210",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ASSIGNMENT] inferred in_dim=10 from Xtmp shape=(1000, 10)\n",
      "\n",
      "\n",
      "===================== SEED 0 =====================\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.553  std(mean)=0.497  min=0  max=1\n",
      "  y: shape=(1000,)  mean=12.3  std=7.3  min=0.739  max=24.2\n",
      "\n",
      "\n",
      "=== Run: assignment | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=16,725 (trainable=16,725)  layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 3.138e-04 @ epoch 403\n",
      "\n",
      "iter=0  t=0.00s  best_y=6.51248e+06  x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "STOP: no feasible neighbors. best_y=6.51248e+06 x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "Set parameter Username\n",
      "Set parameter LicenseID to value 2685751\n",
      "Academic license - for non-commercial use only - expires 2026-07-09\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 161 rows, 8714 columns and 17459 nonzeros\n",
      "Model fingerprint: 0x37ae3ddf\n",
      "Variable types: 8704 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 8e+00]\n",
      "  Objective range  [2e-05, 4e+04]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [5e-02, 5e+01]\n",
      "Presolve removed 0 rows and 578 columns\n",
      "Presolve time: 0.00s\n",
      "Presolved: 161 rows, 8136 columns, 16302 nonzeros\n",
      "Variable types: 8126 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 6231040.1069\n",
      "Found heuristic solution: objective 6223672.0793\n",
      "Found heuristic solution: objective 6204994.0104\n",
      "\n",
      "Root relaxation: objective 6.191797e+06, 308 iterations, 0.00 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "*    0     0               0    6191796.6293 6191796.63  0.00%     -    0s\n",
      "\n",
      "Explored 1 nodes (308 simplex iterations) in 0.02 seconds (0.04 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 4: 6.1918e+06 6.20499e+06 6.22367e+06 6.23104e+06 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 6.191796629298e+06, best bound 6.191796629298e+06, gap 0.0000%\n",
      "[CHECK DFN] obj(x_ip)=6.1918e+06  ip_y=6.1918e+06  rel_err=2.088e-08\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.553  std(mean)=0.497  min=0  max=1\n",
      "  y: shape=(1000,)  mean=12.3  std=7.3  min=0.739  max=24.2\n",
      "\n",
      "\n",
      "=== Run: assignment | DFN ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,610 (trainable=17,610)  layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=-2.0\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.1  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA94AAAGGCAYAAACNL1mYAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA3x1JREFUeJzsnQeYE9XXxt8km+2w9N6l9ypFKaKCgKiAFMVeKQqC/bNXbH8EFBALdhGQYgEFRem9LL33vrRl+6bN95y7m+wkmSSTbPqe3/PMbqbfzExm5r2naSRJksAwDMMwDMMwDMMwTEDQBmazDMMwDMMwDMMwDMOw8GYYhmEYhmEYhmGYAMMWb4ZhGIZhGIZhGIYJICy8GYZhGIZhGIZhGCaAsPBmGIZhGIZhGIZhmADCwpthGIZhGIZhGIZhAggLb4ZhGIZhGIZhGIYJICy8GYZhGIZhGIZhGCaAsPBmGIZhGIZhGIZhmADCwtsN33zzDTQajcth+fLlCCXHjh0T7fjoo4983sbLL7+MW2+9FdWrVxfbeuCBB1wue+TIEQwcOBBlypRBcnIybr75ZmzdulVx2Z9//hmtW7dGfHw8qlWrhqeeegpZWVlOy9E0mkfL0LK0Dq3rit9++w0xMTG4cOGCGJ80aZJoU926dUX7e/To4XLdtLQ08f0qVKiAxMREdO7cGcuWLVNc9p9//hHzaTlantaj9R0xGo144403UKdOHcTFxaFx48b45JNPoBZa7/XXX0eorm26htQs5+p6lyQJ9evXVzz2ly5dwosvvoimTZsiKSkJKSkp4vjce++92LFjR9B+Z2fPnhXXOZ1POpelS5dGu3bt8Pnnn8NsNqvezvHjx/HQQw+Ja5XONf1mBgwY4LTcf//9J34blSpVEr+Tli1bYsqUKYr7ys7OxquvvoqGDRuKbZYvXx433HADDh48CH+j5presmULRo8ejRYtWqBUqVKoXLkybrrpJvz7779e7evNN98U591isSASeeWVV9C2bduIbT/DRDt0701ISEB6errLZYYPHw69Xo/z58+r3i49c0LxTPbEu+++i4ULFzpN37Nnj2ivp2d5IPjuu+9QsWJFZGZmBm2fp06dEu+M3bt3F++idL7oHUIJeidReqe45ZZbfH6Xo/eXO+64IyDfjSkZsPBWwddff41169Y5DfRiFul8/PHHQiDddtttiI2NdbkcCd2uXbviwIEDmDlzJubMmYO8vDxxY9u/f7/dsj/++CPuuusudOjQAX/++Sdee+01cWMkgewITfv222/FMrQsrUPr/vTTT4rtmDdvHrp16yZu9sRnn30mBFHPnj1t05TIz8/HjTfeKIT25MmT8euvvwpRQTfgFStW2C1L43369BHzaTlankQLrU/bkTNq1ChMmDBBiJUlS5aIl4GxY8eKh2Q0QSLsq6++cppOx+rw4cNivmOHSqdOncR5f+SRR0SHCV0Xjz32GI4ePYrU1NSg/c5ITNILAp0/+k/XED20R44ciUcffVTVNnbt2iXEOv2njq6///4bEydORNmyZe2Wo+uEhKrJZMIXX3whXpToN0LXxPjx452OEc2j4/rkk09i6dKl4hh07NgROTk58Cdqr+lZs2Zh48aNooOBlvvyyy/FS4j12KnhzJkz+OCDD4T41moj8xHzzDPPiOuU7k0Mw4QfDz/8sHgHcfWucPXqVSxYsEAYFui+F+m4E94kGIMtvOkZ9X//9394/vnnnZ7/geTQoUPiXYLeV/v27etx+Xr16jm9U5DBxhG173LUybFo0SKvO6MZxobEuOTrr7+W6BBt2rQpLI/S0aNHRfs+/PBDn7dhNpttn5OSkqT7779fcblnn31W0uv10rFjx2zTrl69KlWoUEEaMmSIbZrJZJKqVq0q9erVy279H3/8UbR18eLFtmmLFi0S03766Se7ZW+++WapWrVqYltyDAaDVKZMGenTTz9VbH+zZs2k7t27K7Z/6tSpYl9r1661TTMajVLTpk2la6+91m7ZDh06iOk038qaNWvE+tOmTbNN27Vrl6TRaKR3333Xbv1HH31USkhIkC5duiR5onbt2tJrr70mherapmtIzXKPPPKI+E50zuXcc889UufOnZ2O/cyZM8V6//77r+J25ect0L+zy5cvi2vHkdGjR4v9njhxwu36FotFat26tRjy8vLcLjt8+HApLi5OysrKsptOv4fSpUvbTRs7dqz4zR0+fFgKNGqv6fPnzzutS7/Dli1bStdcc42qfT333HNS9erV7c5xsMjOzvbbtp544gmpYcOG4vwzDBNe0H2J3hPatWunOH/69Oni/vb77797tV1aJxTPZE+4ej+bO3euaPN///0X1HspPTfi4+OlK1euSMFE/lyhdwb67vQOoQS9k9C7iSe8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e22rVatW2Llzp5qT25sTB5L2rRdIuyPp4JI2bmvdunUq5VwKofnDzz//rF4jUbBiqjkRERERUQmNHj1aBd2vvvqqV+OyJb167969KoCWomzuUqjbt2+vensffPBBNc767bffdipk9sgjj6iedyl09ssvv6h08CVLluChhx5y+bwyllqCeVnfG1IY7quvvlJjyHft2qUqkr/88st247l9TQqr9enTx2/PT+RvDLyJiIiIiEpIKoLLFGIyRnnIkCEeP04e069fPxX8So+2u6myypUrh4ULF6qq302bNlXrSoBtS1LdpaL6F198gbZt26JDhw6qCFp2drbL55Xp0CQ1XYrCeUN6nt99911VmVyqlkvQL+PLbQur+ZKc2JAe9eKqxRMFMoOmNyCDiIiIiIg8cvnll6Nhw4ZqmqxgI2O8JUVeetKTk5MRiO677z6cPn1aTTNGFKzY401EREREVAJS8Et6fb/++mtMnDgxKNtQetCfeeYZNbVYoMrMzFRp7UTBjD3eREREREQlIOO0T548qeazdhzfLPNe79+/X/dx8+bNU2PDiSh8MPAmIiIiIvIxCbodp/yynac6UNO6icg/GHgTERERERER+RHHeBMRERERERH5EQNvIiIiIiIiIj9i4E1ERERERETkRwy8iYiIiIiIiPyIgTcRERERERGRHzHwJiIiIiIiIvIjBt5EREREREREfsTAm4iIiIiIiAj+8/8TauwrbnNdzwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 2.344e-03 @ epoch 885\n",
      "\n",
      "iter=0  t=0.00s  best_y=170.406  x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "STOP: no feasible neighbors. best_y=170.406 x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 412 rows, 8870 columns and 17750 nonzeros\n",
      "Model fingerprint: 0x44977308\n",
      "Variable types: 8860 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 2e+00]\n",
      "  Objective range  [1e-04, 4e+04]\n",
      "  Bounds range     [1e+00, 1e+06]\n",
      "  RHS range        [1e-01, 5e+01]\n",
      "Presolve removed 1 rows and 3915 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 411 rows, 4955 columns, 9919 nonzeros\n",
      "Variable types: 4945 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 176.7359565\n",
      "Found heuristic solution: objective 174.3025991\n",
      "Found heuristic solution: objective 148.9345075\n",
      "\n",
      "Root relaxation: objective 1.234267e+02, 458 iterations, 0.01 seconds (0.01 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0  123.42671    0    2  148.93451  123.42671  17.1%     -    0s\n",
      "H    0     0                     123.4719285  123.42671  0.04%     -    0s\n",
      "*    0     0               0     123.4342681  123.43427  0.00%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  MIR: 2\n",
      "\n",
      "Explored 1 nodes (468 simplex iterations) in 0.10 seconds (0.05 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 4: 123.434 148.935 174.303 176.736 \n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.234342680842e+02, best bound 1.234342680842e+02, gap 0.0000%\n",
      "[CHECK DFN_AfixI] obj(x_ip)=123.434  ip_y=123.434  rel_err=2.388e-08\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.553  std(mean)=0.497  min=0  max=1\n",
      "  y: shape=(1000,)  mean=12.3  std=7.3  min=0.739  max=24.2\n",
      "\n",
      "\n",
      "=== Run: assignment | MLP ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=18,049 (trainable=18,049)  hidden=[128, 128]\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.001  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA4ddJREFUeJzsnQWYFdX7x9/tpbsbkU4BEQxCpUxAAcXC+qkoKnbHXwULQcHAQkxUwAIEpAWku7s7dqnt+3/ec3d2z8ydvHdu7X4/z3Nh78yZmXNn5s493/NWjMfj8RAAAAAAAAAAAABcJ9b9XQIAAAAAAAAAAACiGwAAAAAAAAAACCKwdAMAAAAAAAAAAEECohsAAAAAAAAAAAgSEN0AAAAAAAAAAECQgOgGAAAAAAAAAACCBEQ3AAAAAAAAAAAQJCC6AQAAAAAAAACAIAHRDQAAAAAAAAAABAmIbhPGjh1LMTExhq85c+ZQONm1a5fox3vvvef3Pl588UW69tprqVq1amJfd911l2HbHTt2UO/eval06dJUvHhxuvrqq2nFihW6bX/66Sdq2bIlJScnU9WqVemxxx6jM2fO+LTjZbyO23Bb3oa3NeKPP/6g+Ph4Onr0qHg/YsQI0ac6deqI/nfq1Mlw2yNHjojPV758eSpatCi1b9+eZs6cqdv2n3/+Eeu5Hbfn7Xh7LZmZmfTaa69R7dq1KSkpiRo2bEgfffQR2YW3e/XVVylc9zbfQ3baGd3vHo+H6tWrp3vujx8/Ts899xw1btyYihUrRqVKlRLn5/bbb6c1a9aE9HuWmppKL7zwAtWvX19cU77fb775Zlq/fr3ltmfPnqX+/ftTgwYNqESJEuKzNGnShN544w2xTsu0adPo0ksvpSJFiojPfN111+ke56+//qI77riDmjVrRgkJCeKzBhO797R2G+U6HDt2zPaxXn/9dXHdc3JyKBp56aWX6KKLLora/gNQ0OnVq5d4xp46dcqwzYABA8Sz9fDhw7b3y8+6cPwmW/HWW2/Rb7/95rN8w4YNor9Wv+XBYNy4cVShQgU6ffp0yI65b98+MWbs2LGjGIvy9eIxhB48JtEbU3Tv3t3vsRyPX2688cagfDZQ8IHotsHXX39NixYt8nnxoCza+eCDD4Q4uv766ykxMdGwHYvcyy+/nLZs2UJfffUV/fzzz5SWliYeaps3b1a1/f777+mWW26htm3b0tSpU+mVV14RD0UWx1p42TfffCPacFvehrf94YcfdPsxYcIEuuKKK8SDnvn0009p9+7d1KVLl7xleqSnp9OVV14pRPbIkSPp999/p0qVKomH79y5c1Vt+X2PHj3Eem7H7Vl88Pa8H5mHHnqIhg4dSoMGDRJiiwcCjz76qPiBLEiw2Pzyyy99lvO52r59u1ivnUy55JJLxHW/9957xWQJ3xf3338/7dy5k1atWhXS7xkLX56gue+++2jy5Mk0bNgw0QcWoXz/mME/xjy5MGTIEHH/8T3Rp08fISxvuOEGVVtex/dOxYoVRVu+P7du3Sq+O3yeZCZNmkT//fefEKctWrSgYOLknpavIZ8vnhBzwoEDB+idd94R5yc2Njp/Yp588klxn/KzCQAQedxzzz1iDGI0VkhJSRHPWDYq8HMv2jET3SwWQy26z507R88//zw988wzPr//wWTbtm1iLMHj1Z49e1q2r1u3rs+YgscCWuyO5XiCg8cQs2bNcvVzgUKCBxjy9ddfe/gULV26NCLP0s6dO0X/3n33Xb/3kZ2dnfd3sWLFPHfeeaduu6eeesqTkJDg2bVrV96ylJQUT/ny5T19+/bNW5aVleWpUqWKp2vXrqrtv//+e9HXKVOm5C2bPHmyWPbDDz+o2l599dWeqlWrin3JZGRkeEqXLu0ZNWqUbv+bNGni6dixo27/R48eLY61cOHCvGWZmZmexo0bey6++GJV27Zt24rlvF5hwYIFYvuPP/44b9m6des8MTExnrfeeku1/X333ecpUqSI5/jx4x4ratWq5XnllVc84bq3+R6y0+7ee+8Vn4mvucxtt93mad++vc+5/+qrr8R2s2bN0t2vfN2C/T3bunWr2P+LL76oWs73Ai8fPny4X/t9+umnxfbbt2/PW9agQQNP8+bNPTk5OXnL+DuTmJjoufXWWw3PwaBBg8S+goXde1qG+9SqVStx3rjd0aNHbZ+XatWqqT5fqDh79qxr+3r44Yc99evXV11LAEBkwOMDHie0bt1ad/0nn3winlt//vmno/3yNuH4TbbCaHz2yy+/iD7Pnj07pM9S/t1ITk72nDx50hNK5N8VHjPwZ+cxhB48JuGxiRVOx3LXXnutGKcC4JToNENEIOyy8vDDD9Nnn30mXFjZPYUtWHqu0uvWrRMWsjJlyuS5VOtZVNht6oknnhAzdbw/tp7xzN6mTZt82g4fPly4WLPbN1vv2IJmB7uWKJ4xZmtyrVq18paVLFlSWKr//PNPysrKEsv4uAcPHqSBAweqtmdXXu4b70feJy/jdTK8LVvLFi9erFrOVmqeveYZSH/6z+7BfG4U2E39tttuoyVLltD+/fvFMv5/6dKlwoWI1yt06NBBXFe5/zzrzL/R2s/K78+fP09///03uQHPyvL9xTO8WniWmWd8FdffGTNmiHurevXq4t5i1+///e9/jlyD9WDvA+bHH3/MW8bXgq25d999t0979p5gqlSporu/UFpA2b2QYVdvGXZNY/g8+YPiWaHcJ/yZ2euDLcqyqzh/Z5o2bSrul+zsbL/OwaFDh8R15OvK15u/62zdUL53Zji5pxXmz59PY8aMoS+++ILi4uJs9zMjI0N4RNx6662qzyeHwth5VrFnhOIKz1YUDmVhC4XW4sD75BCXm266STxPL7jgArGOXQTZwsUu/K1atRJuqI0aNRLvGfbA4PccKnDxxRfTsmXLfPrA54s9e2bPnm378wMAQgM/l+68805avnw5rV27Vtdzin9/+HnMnnpsyeQxGT93eCzF4xl+zvnLJ598IjyUeH/8jGJ3ZLb8ap+97N1Vo0YN8dxmryF+Vinu7myp5zEejwH596ls2bLiucfeSDL8nONQJh4nKi7S7GXIzzFl/NS5c+e8dbK7teLRxOM1fp5y6JM2rM7sWWr2+dmDTPkd1Y6Fv/32W/GM5WPyeVKevYESjLGD07Ec/zbwedV6rwFgBUS3DXigzINb+SUPnuWB4ocffijcKn/99Vcx2Gaxwn8r8KCcB7sc48ltJ06cKH4IOL6SXTIVOEbmsssuEyKev/gsbNlVlQfJLGplRo8eLcQWizN2u+GHM4tzFkVuwA8dfrg0b97cZx0v4/Uc761MKCjLtcKHf5SU9UpbfijLQkDeVm7LsMDjHySn7q7Kvoz6zygxt0b9V5Zp+8/Cq3Llyrb67y88McA/2Nq4Jb4Hv/vuO/HDxzG6DF8nPkf8gzh9+nR6+eWXxeQF30vsJu0v/IPNP8YcWqDAApx/APv16+fTXpnc4Jhl/kFTRHig3zO9NnovORaXv4c8EcGhFCyg2G2aJ64GDx5MNWvWFPHaduAfZd43x4fzj/D7778vvt+8D0VwMjxBpoWXsTuePz/SLLhZGLLLG19PDsNg10p2hWP3byuc3NMMf595/xw359S1n+81vtY8ANTDzrOK3UX5evE9x/cYi/iTJ0+KQea///7rs0+e+OPJpV9++UU8IxVWr14tcgrwxBQ/Z3lQy205lIUnE9htkPvAx2aBzp9bpnXr1mJAza6EAIDIgyd8WeTJv0uKyzVPprMoZ3F+4sQJsZy/+/x9ZkHOxgx+pviTM4SNKSziOa6YJy35N+7xxx9X5fhgwc3hcryeQ5P4uc3PPX4O8fOM4dAe7huHs/A++HnHv9X8nOJ4aQWecOSJQ35WKi7SH3/8MV1zzTV57s/8bFXW8XKGxwddu3YVz1IW7BwWyMK+W7duuvlsjJ6lenHVPNFh9Jznczxq1CgxFuZxGx+TjSXKOFH+PbXzCgT+zeXj8ziTJxI4t4v2We90LMf3Dfd/ypQpAfUNFEIc28YLEYrbq94rLi5O1ZaXsRvKoUOHVO5PDRs29NSrVy9vWf/+/T1JSUmePXv2qLbv0aOHp2jRop5Tp06J96+//rrY54wZMyzdy5s1a6ZyxV6yZIlY/uOPP7rivrR//36xv6FDh/qsY9dw2W37zTffFO8PHjzo05ZdztldU+HCCy/0dOvWzafdgQMHxD5kVx/+fOzK/v777xv238y9nF3j//e///ksV1yMFRd3xQ1+0aJFPm3vv/9+4SaswO5F7E6sB7fj9m65l/fu3dtTvXp1lWsVu+qbuc+xWyy7E+/evVu0+/333/12L2c3LnZf47/ZFUtxWb7rrrsMzz3fw3welO9MnTp1PA888IBn9erVfn/P+BhGbeWX9j7m0AR2FZPbsBu41eeX4e+TvP3AgQNV7tp8bcqWLeu58sorVdux+12JEiV8whtkzNzL+b4tXry4uI4y7733nthm/fr1pv12ck8zTzzxhKdu3bqec+fOifd8f9p1L3/77bdFW/k56ORZxeeQXUa5nXyvnz592lOxYkVPhw4d8pYp/Xr55Zd1v1f8PN63b1/eslWrVon2HP4iu07+9ttvYvkff/zhs59LL73U065dO8vPDQAID/ybwGMDfsbLzzD+Tm/ZskV3G34G8bObn9W9evVy7F7OoScc6mbG3XffLcYdGzZssP1ZlH7dc889IrQnEPdyfsbx79F1112nWs7P1RYtWqjC6syepXqMHz9etP/vv/981vHySpUqeVJTU/OW8e9BbGysagypjCfsvIx+p63cy1944QXhBs9hbhzOyNctPj7ec8UVV6h+X/wZy3EIVb9+/SzOFABq1CZGoAvPOLJFVkYv0zC78MgJO3iGla2A7AbKM4PsGsrJF7gduxvJsKWbZ0J5lpKTe/HfbNW+6qqrLK8Kz2rKLqDK7JxVgiinmGVX1q4zamu3nXYdJ4JiF2m9ZGzR0P9AYW8HttaxSxPPXDM8W88zs+w+p8DZqNkayjPN7KIvW3w3btwoEub5C8/q80wxWxX4fmWXZbb2mmWAZtc6ng1mC+jChQvF7DlbGfk7pbisO/meseeHnUypiuVf4cEHHxQWB7Z2s/WWrcfvvvuucDFk67ccNmEEWwf4M/Px+Xv69ttvC6su75ct/vziJCz/93//J17sDs5WcbYYs5XbX9c4dstjiwJ7eMiz/nzd2ULC3w32lmEvAO+Yx4vSJyf3NFuH2BrDlny2rDiF7znen/b8231WsScQ74PPmdx3tjhz8jq+/nwu2WVRgZfrwS6bnKVeQbm32Eohb68s13teshsqX3MAQGTCXjnsUcWehvws4GckW3g5eeWFF16Y145/ezhkhq3gcvJI9sBzCnsesSWXf8PYU4pdtrXPPB7D8XNb+5umha3K/MxlzxzZUu5v2JMC/96yFZ2t/VprMY8x2bOSj8chNlbPUi38jFaej3rw55aTq/G4mNvKz1j2JLL7bPXHu5HhCiMy7CnAoUf8u8ku/HKootOxHH8eJSwRALtAdNuAH5pt2rSxbKd1TZGX8eCcRTf/rxfnqjxUFDdcjkFS3FatKFeunOq94t6qdaHxF47v4YeOnouw4rbF7jtyX7itNmMot1XaKW3t7JNhF31+SPMD0x/sHkvuv15bbf/1snDzDxm7GsttA4UFFt83LLRZdLN7Gg8yOLumImJYYPM6/kFkwculqPgHlZdzJvFA7we+B1j8c1gEx6LxpBAPbMzge4C3UWKl5s2bJz4L91sruu18z9j1TRaWRsiCjQUkuyjz4IZd5BX4XCkl2/i82vkeKP3jQQVPQPCAS/7x5gkPdl/nH3v+WxGa/Pl5skEWgXbh+D8OL1Fi07Uo8fo8mSdn4ufBFockOLmn2V2TJ7b4cyqlePhaMzyBwM8Ws0y1fI9xP43iwK2eVWa5APgZyfcy3/uyaDbKG6D9/inVGYyWK59Thge+bj1HAQDuw8/0Rx55RDzDWTTyJC8/M3lSVIHzSHDs9AMPPCAmRFkg8zOKfyd5MtopHNPLQvbzzz8Xx+TnEruS83Of808oYzge85nBE+l9+/YVcdlPPfWUGC+yGzSHh2ld5p2ixI3Lv3l6z39ZdBs9S7Uoz0SjiQHtc1551svPUp5I5YlRO2hDEAMN12PRzblElN9tf8Zy+G0A/gDR7SJsPTNapjyE+H9tTLY8c6jMlnJ8CVvHIwG2eLHY0UtWwst4PcdHMSz0lOVsfVPgHyiOo5WFFrflGCZeJz9UleNw8imGf9DYmsgxuP7CxzLqv3ws5X9eri1HwcuU9co+ObaLr7E84aLdpxvwAIF/6FnwshjiuFeerZcTf3DcEc+Ws9BiwaWgl4DNX9jCzWKSrQZvvvmm4+253BuLXY5fY6u80Uy5EVphaYQiOBnlx5QHRTKcAIbva39j79nawXCyLQW+j3mAx7FsXHKKv888kGErOScPsxqE6cH7YIuw0flWJuy0XgDKs8TJPc25DfjFExRaeJKBE+LoDU7kY/IgRWtBsYvynDR6RvJkCk9+yASzvjkPSo2s9gCA8MPjDx5XsADm5waLVZ4YlBO0suWbPVxYzMoEUl9amUzmZx1PJnO8OOeG4N8D9pyyM4bjfvHvwvjx41XPMaMyjk5Qnltca5on3fXQGkbsPkuVffPz0a5Q18K/40Yx4Vr4t9Rfg4udiXl/xnL82d3uEyj4IJGai3BiCmV2kWF3T36Y8mBVGWyzaGAXc0Vky661bL1RHo5sDeSHd6TUAuQZQe7L3r17VT9YPFPLLsuKaG7Xrp14CGuTfrGlmi2Asns475OXcaINGU74wUKC96W4SfHD0K7rk1H/WfTLGdEVNzQ+jiJc2BLJYoqXy0m8eFaUXV/l/nOyJ/6R0mae58/OAwF24XIT/oFnaxxPVPAxOFmZ7Bqn/GBqE3mxGHMLPj88I8/J22Rhr4W/B7JruwKfU65bzfe6NuupHfizsEua1Yut1wrKtdVmyWarKn/H/BHCjJLVmoW7Fp7F5x9y/i5wRlh+NrB13x94IMcTA/wcYQu09qV8Ps7OLy9XBgRO7mn+TNqXcp15ooSt9WYo96O/WV35M3B/eVJJ9mjgga2SSFG2cgcbTvwjTx4CACLTxZyfbRwyxJZu9kCSnxP826j9XVyzZo1PRQR/4MlFHq9xgi6ecFSSsvIyfn7yM9YI7hd72shil8c62uzlepZieTmjXccu7/wby+70er8b/FK8fJwS6HNedi+38/LXvVwPZbwmT0Q4Hcvx2JHHwvhtAE6BpdsGPODVy6DIg2ClbJAy+8cxouyyxA9izi7JQk8uG8azoUqMJlsM2W2FM+hyDC7H2ChljTimkQU7PwyeffZZMWjmhyrPDvIg3O4MoRW8P3aDYvhHi2NulGzrHMOrfD52x+ESEOwqy1Y8ftAPGzZMiEBZ4LBFlj8HW2U5ppVnoFlkPf3008LtSn548Y8SL+N4W3ZdZfHCgpLdgVkgKC6q3B+eaWR3Zi1c6ofLETG8Dx6oK/1ny6YSq8tus5zdk2e/ud9sYeXrwz+IHCctw25p3C9uyxlK2SLL14D7IFuWmzRpIn7s+ZpyX/l4nDGc48bYzcxN93Llh45FB2et5gc+H0e7nu9J7iufBz4+uyVztmg34fNnBd8rLJC5dBSfF76vedafRRsPSvje1/7g2/mesShzCotKPh7fZ9wHjulmiwgP0Dg+WBbD/H3giTFur7iH8+fg0jJsoedcDCwA+T1bELgSAX9HFTgTLg8S2DLN14BjpPl+4vuey6jI8HdNiWlTBi/KvcuCWXFl5+8bX0M+Fnt78Dng7x3f9zzAZK8Dq4kDu/c0W4O0KNl99eIWtSjbs6DXy5Zux/rAz48BAwaI5xw/Q9jqw9eKPTzs3HtuwZMy/Oxi11UAQOTCz0p+3nBsND93+XdZhp8l7FbOv9U8ruHffX6uspXZn+zYXDWCxRg/E3lilYUy/y7z75ziUcX757hu9u7iUmI8CcvPMB7fcDZz/r3mfrHhgp/J7AbOv+vcT94nP3tkeHt+FvNvOq9naz7/FihWWB4P8DJ2e+bPxV5D/BvFk6ZsleX987iHx3vsEcf/ay3/dmFDBX9+fs77myeG+2onbFMP5XdSyYbO40Ce6Jbd6fk3mr3D2ODCnpj8m8nXg88Tj9PZcODvWI4nbHjs4NY4HBQiNInVgM2syvz6/PPP89rye85AzJkSL7jgApG1kjOXc+ZgLWvXrhUZJUuVKiUyI3ImSb3si5z1+NFHH/XUrFlT7I+z915zzTWeTZs2qTICv/vuuz7b2snAaZUNWpsNc9u2bZ4bb7zRU7JkSZFpnTN/Ll++XHe/nA2cs0Pz56tcubJn8ODBIgOxFl7G67gNt+VttFnXa9SoYfhZOJunUf+155QzaN5xxx0io2dycrLnkksuMcwOP336dLGe23F73u7w4cM+7ThjKveNrxH3n7Ozf/jhhx672M1erjBmzJi8TPkpKSk+6zlTKmfi5GzZZcqU8dx8880iU772fvAne7kZ2uzl3A/OINumTRtPhQoVRMZQ7g+3+fbbb/3+nvkLZ9PnzKVcSYCvKWfI5u+SNqO3klFVPlcLFizwXHvttWIbvsZ87/N39v/+7/9UWbCVtpztmr8jXKWgadOmIsu4nFnXzufWZqnlzOH8PeEM8Pws4HuydevWIjvrmTNnbJ0Du/e0FifZy5nLL7/c07NnT9Uyp88qzijO55H7yll7+VnD59Zuv/h7xddX71j8nLbTty+//FKca20mdgBA5DFy5EjxPW7cuLHPuvT0dM+TTz4pMk7zM+Wiiy4Szxh+zvKzwunY6ZtvvvF07txZZOnm3wT+bejbt69nzZo1qnZ79+4VWcx5fMPPEqWd/NwdNmyYp3bt2uL3olGjRuL3Tnm2yXD1Ba6mwL8/vE7+vR0xYoT4beBqH9qxz9y5c8WzkJ/53Ac+B/yes577+4xnbr/9dt1zrfeMZfg862Vf9wez8YLC1q1bxe8Qf14+t3zduSoGV9hJS0sLaCz30ksviYz5evsBwIwY/ifcwr8gwK4pnLmYM1oC92BLIc+q8syiEi9ekGCLJsdJy94CAEQz7AbOVRvYku9P4rhIgZMEcjJL9kQCAACQD1uX2SLM1m4lFLAwwB6h7JXJXnz+5LUBhRvEdIOIht3qeV6oIApuAAoi7M7PgzF2t4xWODESu/6zqycAAAA17BrOmdcL2zOSQx85FxHntgHAKRDdAAAAXPX64UzCSomvaITjuTm5pVKVAQAAgJr3339fTLAGkgU+2uDfNPZ+8icRLABwLwcgjMC9HAAAAAAAgIINRDcAAAAAAAAAABAk4F4OAAAAAAAAAAAECYhuAAAAAAAAAAAgSMRTAUxycODAASpRooRI6AMAAABEAlyJgZMOcZK52FjMeTsFv+8AAACi9be9wIluFtw1atQIdzcAAAAAXfbu3UvVq1fH2XEIft8BAABE6297gRPdbOFWPnjJkiXD3R0AAABAkJqaKiaFld8p4Az8vgMAAIjW3/YCJ7oVl3IW3BDdAAAAIg2EPgV23vD7DgAAINp+2xFUBgAAAAAAAAAABAmIbgAAAAAAAAAAIEhAdAMAAAAAAAAAAEGiwMV0AwAA8J/s7GzKzMzEKfSDhIQEiouLw7kDAAAAgAqIbgAAAKLO5KFDh+jUqVM4GwFQunRpqly5MpKlAQAAAKDgie7Ro0eLF1tpAAAAOEMR3BUrVqSiRYtCNPoxaXHu3Dk6cuSIeF+lShXcggAAAAAoWKJ70KBB4sW10kqVKhXu7gAAQNTAk5WK4C5Xrly4uxO1FClSRPzPwpvPJVzNAQAAAMAgkRoAABRylBhutnCDwFDOIeLiAQAAAKAA0Q0AAEAQExODMxEgOIcAAAAA0ALRDQAAAAAAAACgUJCWmU1Z2TkhPSZEtxkLRxGN6Uy05POQXRAAAADhoXbt2jRixAicfgAAAKCAsvXwabpx9AIaNXtbSI9bYBKpBYWUfUQHVhDV7RjungAAANChU6dO1LJlS1fE8tKlS6lYsWI4zwAAAEABrDLyw5I99H9/baC0zBw6cTaD7r28LhVPCo0chug2IybXEcDjCcnFAAAA4P6PLGdnj4+3/rmrUKECTj8AAABQAFi55yT9tGQPLdl5go6dTaez6dmUkyvpiiXG0SV1ywqrd6uaZULSH7iXm6EkFfKE1ucfAACANXfddRfNnTuXRo4cKRKY8Wvs2LHi/2nTplGbNm0oKSmJ5s+fT9u3b6cbbriBKlWqRMWLF6e2bdvSP//8Y+pezvv54osvqFevXiIr+YUXXkh//PEHLg0AAAAQwQybupF6fbyQxi/bRzuPn6PTafmCmzmbkU1/rD4o2nDbUADRbUZeJl9YugEAhc9CfC4jK+QvPq5dWGy3b9+e7rvvPjp48KB41ahRQ6x7+umnaejQobRx40Zq3rw5nTlzhnr27CmE9sqVK6lbt2503XXX0Z49e0yP8dprr1Hfvn1pzZo1YvsBAwbQiRMnAj6/AAAAAAiOhfvTuTtst+e2vE2wKTDu5aNHjxYvdiN0DbiXAwAKKeczs6nxy9NCftwNr3ejoon2fppKlSpFiYmJwgpduXJlsWzTpk3i/9dff52uvvrqvLblypWjFi1a5L1/4403aNKkScJy/fDDD5ta02+55Rbx91tvvUUfffQRLVmyhLp37+73ZwQAAABAcNh57Kxf2wTbzbzAWLoHDRpEGzZsEIlw3GL1vhTx/8YDp1zbJwAAgODDruUyZ8+eFdbvxo0bU+nSpYWLOQt0K0s3W8kVOMlaiRIl6MiRI0HrNwAAAAD858Cp8463qVM++ElUC4ylOxikpntjuc+mZ4a7KwAAEFKKJMQJq3M4jusG2izkTz31lIjzfu+996hevXpUpEgRuummmygjI8N0PwkJCar3HOedk1O483zMmzeP3n33XVq+fLlw6WePgRtvvNGw/Zw5c6hz584+y9n1v2HDhkHuLQAAgMLAuYwsevWP9fTzsn2OtnuwY92QJFOD6DYhhpREaojpBgAULlhc2nXzDifsXm4nrIiTqbGrOCdFYzjGe9euXSHoYcGDvQbYVX/gwIHUp08f29tt3ryZSpYsmfce2eIBAAC4wbr9KTT4x5W049hZkZJrUKd61LF+efp1+T6RvfzEuQzKyMxhcSfGNpVKJlGzaqWo/8U1Q5a9PPJHVGHEg+zlAAAQ0XDG8cWLFwsBzS7jRlZotm5PnDhRJE/jCYWXXnqp0Fus/aVHjx7i5ZSKFSsK134AAADADXJyPPTVgp30zt+bKSM7hyqXTKbh/VpQhwvKi/Vt65SjSKHAxHQHhRivm2MMspcDAEBE8uSTT1JcXJyI1WbLqVGM9gcffEBlypShDh06COHN2csvuuiikPe3MNOqVSuqUqUKXXnllTR79mzL9unp6ZSamqp6AQAAAMzR0+k0cOxSemPyRiG4r25ciaY+enme4I40YOk2I8+7HO7lAAAQidSvX58WLVqkWsZu5HoW8VmzZvkk4JTRupvrPftPnUJiTaew0B4zZgy1bt1aCOlvv/1WCG+O9b7iiisMt+OSb1yyDQAAAJCZu+UoPfHzajp2Jp2S4mPpxWsb023tagpPtkgFotuGI0AMFe6kOQAAAIC/NGjQQLwUuLb63r17RVI7M9H93HPP0ZAhQ/Les6VbqcMOAACg8JGelU3v/r2Zvvh3p3jfoFIJ+vCWVtSgcgmKdCC6zUBMNwAAAOA6l1xyCX333XembZKSksQLAAAA2HH0DA3+aSWt2+8NNbqjfS16vmcjSnap6kmwgeg2IyY35B3u5QAAAIBrrFy5UridAwAAAGZwqBdnIX/lj/V0LiObShdNoHf6NKeuTSpH1YmD6LZh6Y6B6AYAAADyyq1t27Yt72zs3LmTVq1aRWXLlqWaNWsKt/D9+/fTuHHjxPoRI0aImPomTZqIuuhs4Z4wYYJ4AQAAAEakpmXSC5PW0Z+rD4j3lUok0T2X14k6wc1AdJvitXR7kL0cAAAAECxbtow6d+6cdzaUuOs777yTxo4dSwcPHlRlkWehzVnmWYgXKVJEiO/JkydTz549cUYBAADosnz3SXr0p5W07+T5vGWHT6fTW1M20ZS1B+m3QZdRNAHRbcO9PMaDRGoAAAAA06lTJ9OqHiy8ZZ5++mnxAgAAAKzIzvHQx7O30YiZW8XfZYsm0Ilzmao2q/am0Pile6hf25oULRSYOt2jR48WdVrbtm3r3k7z0s6jZBgAAAAAAAAABIuDKefp1s//o/dnbBGC+/oWValLw4q6bVfvja4SngVGdHO91Q0bNtDSpUuDYOmG6AYAAAAAAACAYDBt/SHqMXI+Ld55goomxtF7N7egkf1bUts6ZXXbt6hROqouBNzLTcivrw73cgAAAAAAAABwk7TMbPq/vzbQ94u9uUCaVSslam/XKV9MvGcX8h+X7BEu5QqtapSKKtdyBqLbBE9Mbt03WLoBAKBAwlm1H3vsMfECAAAAQOjYdCiVBv+4krYcPiPe/++KuvRE1waUGK92xuakaRzDzS7lbOGONsHNQHTbsHQjkRoAAAAAAAAABI7H46Fv/9tNb0zeSBlZOVShRBIN79uCLr+wguE2LLSjUWwrQHSb4KFcSzcSqQEAAAAAAABAQJw4m0FP/7qG/tl4WLzv3KACvXtzCypfPKlAn9kCk0gtGMQopm6UDAMAgIjjs88+o2rVqlFOjjrvxvXXXy9qRm/fvp1uuOEGqlSpEhUvXlxUt/jnn3/C1l8AAACgMLNw2zHqMXKeENyJcbH08rWN6au72hZ4wc3A0m0ne3mILgYAAEQMnMsi81zoj5tQVM5iacrNN99MgwcPptmzZ9OVV14plp08eZKmTZtGf/75J505c4Z69uxJb7zxBiUnJ9M333xD1113HW3evJlq1oxeFzUAAAAgmsjMzqEPZmyhT+ZuF8OLuhWK0Ue3tKImVUtRYQGi2wxYugEAhRUW3G9VDf1xnz9AlOjNWGpF2bJlqXv37vTDDz/kie5ffvlFLOf3cXFx1KJFi7z2LL4nTZpEf/zxBz388MNB+wgAAAAAIFq55yT9vmo/TVyxn1LTssQpaVK1JL14TaNCJbgZuJfbsHQjphsAACKTAQMG0IQJEyg9PV28//7776l///5CcJ89e5aefvppaty4MZUuXVq4mG/atIn27PGWJQEAAABAcBg2dSP1+nghjV24O09wM+sPpNItny8W6wsTsHTbsHTHuJFILf0M0eF1RNUvJorFXAcAIMJhN2+2OofjuA5gd3GO6Z48ebKI2Z4/fz4NHz5crHvqqaeEq/l7771H9erVoyJFitBNN91EGRkZQeo8AAAAADh2+9O5O0xPxKdzd1C3JpWpVc0yheKEQXSbEKPEdLuRSG3c9UT7lxP1fI/o4vsC3x8AAAR70tGmm3c4YSHdu3dvYeHetm0b1a9fn1q3bi3WsQC/6667qFevXuI9x3jv2rUrzD0GAAAACi5r9p2iwT+ttNV257GzEN1Ajul2wdLNgptZ9T1ENwAAuOxizhbv9evX02233Za3nK3bEydOFOu4GsVLL73kk+kcAAAAAIGTk+Ohz+fvoHenbaasHHvaqU75yJ/cdwv4OdvKXo5BGgAARCpdunQRydM4K/mtt96at/yDDz6gMmXKUIcOHYTw7tatG1100UVh7SsAAABQ0DiSmkZ3fr2Ehk7dJAR3z2aVaWCHWqbbPNixbqGxcjNwL7dVp9vj5l5d3BcAAABOmnbggG/8ee3atWnWrFmqZYMGDVK9h7s5AAAA4D+zNh2mJ39ZQyfOZlByQiy9el0T6te2htBR17esRnM2HxHJ01LPZ1LJIgkie3mnBhULleAuUKJ79OjR4pWdnR0ES7ebohsAAAAAAAAAope0zGwaNnUTjV3ozZXSqEpJ+uiWllSvYom8NiysC5u4LvCim60X/EpNTaVSpUpFsKUbAAAAAAAAAKKTbUdO0yM/rqKNB1PF+4GX1qZnujek5IS4cHctYikwojs4BCGmWxHyAAAAAAAAABAleDwe+mnpXnrtz/WUlplDZYsl0ns3N6cuDSuFu2sRD0S3GainDQAAAAAAACjkpJzLpOcmraEpaw+J95fVK0/D+7agiiWTw921qACi24ZV2pU63fk7dXFfAAAAAAAAABAcVu45STM3HhYW7mNnMig+Noae6taA7ru8LsXGQtfYBaLbjBhvXAJKhgEACgOoYY1zCAAAADDjl+6h0bO30Z4T5/NOSMki8fTdPe2oefXSOEkOgeg2AeHXAIDCQGJiIsXGxoqyWxUqVBDv8xJJAttxbhkZGXT06FFxLvkcAgAAANHIjaP/pVV7U3yWp57PouwcJJj2B4huE2KUkmGuupcDAEBkwSKxTp06dPDgQd1618A+RYsWpZo1a4pzCgAAAESjhVtPcCvsPHYWZcD8AKLbjuh2s043rEcAgAiELbMsFrOysig7Ozvc3YlK4uLiKD4+Hl4CAAAAopJzGVk0Zt4O0zZ1yhcLWX8KEhDdJnjyEqk5EN3ZmURpKUTFygd8cQAAIJSwS3lCQoJ4AQAAAKDwsP5ACg3+cSVtP3rWsE3vVlVh5fYT+L+ZEJObSI2cWLo/60j07gVEx7cb7dXB5QEAAAAAAACA4OUk+fLfndRr9EIhuCuVTKILKhTTFdzD+7XCZfATWLrNyNXHjrKXH1nv/X/jH0SXPe7vdQEAAAAAAACAoHHsTDo99ctqmr35qHh/VaNK9M5NzalssUQR282lwsoUTaT+F9eEhTtAILptWLoduZfnbQwnAgAAAAAAAEDkMX/rUXp8/GohvBPjY+mlaxrRbZfUystL0q9tTfEC7gDRbYJy0/mXSA1u5AAAAAAAAIDwsXLPSZqz+Yj4u1ODitSkail6f/pm+iw3YVr9SsXpw1taUcPKJXGZgghEty1rdY5rWcozsj2E6q0AAAAAAACAYDJs6kb6dG5+NvKRM7dRhRJJdPR0unh/2yU16cVrGlNygpLHCgQLiG4zcuus+mezzt0qZT9RtvfGZvacOEf1/NofAAAAAAAAANizcMuCW4EFd/GkeHq/bwvq1qQyTmWIgOi2417uyfHfSv5BYx9LNwAAAAAAAAAEi53HjEt/Dbn6QgjuEINsXybE5LmX+5NILYYoxw+xDgAAAAAAAAABJkozolgS7K6hBqLbjFxLd6y/idQ82X5eFgAAACAymTdvHl133XVUtWpV4RH222+/WW4zd+5cat26NSUnJ1PdunXp008/DUlfAQCgMLJs1wmatPKA4fpnJqwV8d4gdEB0mxCTF9Ptp3t5DkQ3AACAgsXZs2epRYsWNGrUKFvtd+7cST179qTLL7+cVq5cSc8//zwNHjyYJkyYEPS+AgBAYeNQSho99P0Ky3Yc781x3yA0FBjfgtGjR4tXdna2++7lfhm69S3dHpQSAwAAEMX06NFDvOzCVu2aNWvSiBEjxPtGjRrRsmXL6L333qM+ffoEsacAAFC4mL7+ED09YQ2dOpdpO+67Vc0yQe8XKECW7kGDBtGGDRto6dKlLu41EEs3x3TD0g0AAKBws2jRIuratatqWbdu3YTwzsw0Hhimp6dTamqq6gUAAMCXtMxseum3dXT/t8uF4K5WOtnWaapTvhhOZ4goMKI7uO7lNk3dHqkdW8kR0w0AAKCQc+jQIapUqZJqGb/PysqiY8eOGW43dOhQKlWqVN6rRo0aIegtAABEF5sPnaYbRi2gb//bLd7fd3kdmv1kZ2pZo5Tpdg92rAsrdwgpMO7lQS0ZZld0qyzbyF4OAAAAyL+nCp7cSWrtcpnnnnuOhgwZkveeLd0Q3gAAkP8c/W7xHnrjrw2UnpVD5YsnidrbHetXEOt/G3QZjV+6h2ZuPExliiZS/4tr5rmUs4UbbuWhBaLbjNyY7hjZgm2GbNk2iOkGAAAAChOVK1cW1m6ZI0eOUHx8PJUrV85wu6SkJPECAACg5uTZDHpmwhqavuGweM9C+72bW1CFEt5nJidIY3Fdv1IJ6tfWK7YVILbDA0S3jURq9i3dWdLGyF4OAAAAtG/fnv7880/ViZg+fTq1adOGEhIScIIAAECDIpr1LNKLth+nx8evokOpaZQQF0PPdG9Id19ah2JjvZ5DXAqMM5MrPNCxLj3boxHOcZiB6A6mezmylwMAAChgnDlzhrZt26YqCbZq1SoqW7asyFLObuH79++ncePGifUPPPCAKC/GruL33XefSKz25Zdf0o8//hjGTwEAAJGJVjR3blCBBl95ITWtVopG/LOFPp6zXaSRqluhGH3Yv5VYLot1eVuG33drUhkW7jAD0e1Gne4TO4nOHScqd4G0MbKXAwAAKHhw1vHOnTvnvVfiru+8804aO3YsHTx4kPbs2ZO3vk6dOjRlyhR6/PHHRWnPqlWr0ocffohyYQAAoEFPNM/efFS8KpVIosOn08Wyfm1q0CvXN6aiiWopx9ZxPVAaLPxAdJth1738w5be/++dKW8MSzcAAIACR6dOnfISoenBwltLx44dacWKFUHuGQAARDdGoplhwV00MY7euak5Xdu8qqMSYCgNFn5QMszNkmGH1qrf5/hR3xsAAAAAAABQ6LASx0Ourm8ouBmO/+YYbhmUBosMYOm2E9Pt8SORmicH2csBAAAAAAAAtlBEs9bFXKF1LXVSNT04aRrHcKM0WGQB0W1GXKL4L5Ey7Z1NFtry36rEagAAAAAAAACgT06Oh8oWS6S4mBjKtmv0MxDvKA0WWUB0m5CTWEL8X5TOcwV6b3K0AC3dHotdAAAAAAAAAAoXR06n0RM/r6b5W48ZtkFCtOgFMd0meJJKi//jOHt5xhnrs6kV3bqWbqhuAAAAAAAAgJfZm45QjxHzheBOTogVcdh6ICFa9AJLt+nZSaIMTxwlxmQTpaUQJXkt34bIIhsx3QAAAAAAAAAD0rOy6e2pm+mrBTvF+4aVS9BHt7SiCyuVEGmc5dhuJESLbiC6TYiJjaFUKkblKZUoLZUov/a8DdHt8b40eGDpBgAAAAAAoFCz7cgZGvzjStpwMFW8v6tDbXq2R0NKTogT75EQrWAB0W1CbEwMnfYUofIxLLpTXHIvBwAAAAAAABRGPB4P/bxsL736xwY6n5ktEqe9e1NzurJRJZ+2SIhWcIDothDdZ6iI9036aeuzKSVOy8rOonidRGoAAAAAAACAwkfK+Ux6fuJamrz2oHh/ab1yNLxvS6pUMjncXQNBBqLbhLjYGMpUTpFsxTZCarN670lqXdWG6N4xl+jEdqI2d9u4XAAAAAAAAIBoYOWek3n1srNzPPToT6to/6nzFB8bQ090bUD/u6IuxcYiyXJhAKLbhMS4WMpWErw7FN2ZWdn6JcO0C8Zd7/2/YhOimu3sXDMAAAAAAABABIvsaesPqRKhxeTqgFrlitLI/q2oZQ1vlSRQOIDoNjs5cTGUTXHmoltOlpaTk/dnLDmM6U7ZS0QQ3QAAAAAAAEQbw6ZuVIlsLawYOtavQKNubUUlkhNC2jcQflCn20p0e7ynyGMkoGXRnZ2R92ccf7U4mZoPcCEBAAAAAACgIFm4zQS3wg0tq0JwF1Igum26l+dkZxq0yhfdHkl0x8Z4kL0cAAAAAACAAg67lNuB3c5B4QSi24T4uFjKynUvz8k2snTnW7OPncrPcB4rLN3IXg4AAAAAAEBBxo6Y7tKwgigBBgonEN0mcGZBxdKdbWTpltzLszPT8/6Oi/GQx07yNQAAAAAAAEDUwknRmlcradrmkS4Xhqw/IPKA6DYhQbiXey3d2ZyN3MLSHZuTqbJ0e6TEannNEdMNAAAAAABAgeD4mXS655tltGZ/qmGbBzvWhZW7kAPRbVGnOydXJNuJ6Y5Rie4c8mTD0g0AAAAAAEBB5N+tx6jHyPk0a9MRSoyPpfsur6PbrmuTyiHvG4gsCozoHj16NDVu3Jjatm3r6n5zYrxV1bKNBLRk6ZZFd4ywdOvV6Ub2cgAAAAAAAKKVjKwcGjp1I93+1WI6cjqd6lUsTr8PupQaVSkZUKI1UHApMHW6Bw0aJF6pqalUqlQp93Yck5u9PMu6TndMjrpkmMftRGpHtxBtn0XU5m6i+ER39w0AAAAAAAAwZdexszT4p5W0Zl+KeH9ru5r00jWNqUhiHKVl6o/9kbUcFBjRHSxyYnKzl0tWbENLd7BLho3OteJnnSe67HF39w0AAAAAAAAwZOKKffTSb+vobEY2lSqSQG/3aUbdm1bJW8/ZyR/oWFdVsxvx3ICB6LbAw6Jb6GcjAe3RF93koRy3RbfCvmXB2S8AAAAAAABAsHLPSeEaXqlkEv2ybB/9tuqAWH5xnbI0ol9Lqlq6iM+ZerZHI+rWpLLYji3cKBMGGIhu26LbhqVbk0jN0tItuaYDAAAAAAAAIkNsfzRrK83adNQnyfKjV15IgzrXE38bwUIbYhvIQHRb4ImNJ69+zrYUznLJMBbjeonU1Nv6lhQDAAAAAAAAhIdhUzeq3MNl3rihCd3SrlbI+wSinwKTvTxYeHITqemW/1o4imhMR11Lt8djI3u5lehmQb9gpDd5mkwMMqADAAAAAADgtoXbSHAzSQneXE8AOAWWbivY0i3qdOtYrae/oG4qZS8XgjpQS/fWGUQzXvb+/ao3QyIAAAAAAADAfaxKe2Vmw0sV+Acs3XZiuoU+NojplohTtdG3dKt3bvHFPbHdYAUs3QAAAAAAALgFl/uaseGwaZuEOEgn4B+4c2yKbjLMXp5PXHa6u5ZuKRu6Ice2EqXsp5BybBvRxr8oYsnKIFrzM9HpQ+HuSeTCoQs5mK0FAAAAANh6+DTdOHoBTV1nPnZEvW3gLxDdlmco19LtsRbdsZ58kRzDidR0RLWjmG4r0X3mKNGoNkQfNCZbsMg6ujnwrOmjWhONH+Abax4pzH+faOJ9RGM6h7snkcu464k+voRIL1cBAAAAAEAhgHMwffffbrr2o39p06HTVL54Io0d2JYmPdSBujSsoGqLetsgEBDTbdfSnWMtTuJkYS6yl1tsYym6DbZXEqkd30qOmP4i0X+jia54mqjLC8bH5ORxsTbmY/YtJ7qgC0UcmyZ7/z/traUIdNg5z/v/4XVEVVviFAEAAACgUHHqXAY9M2ENTVvvdSm/on4Fev/mFlShRJJ4/9VdF+fV6Ua9bRAoEN0WeGK8pyg+/ZQr7rsqG7Pflu4Y/2K7WXAz897RF91ci/yji4iKlCX631yKWlCKzeL8yHchasUDAAAAoHDx347j9Pj4VXQwJY0S4mLome4N6e5L61CspvY26m0Dt4DotiLX4ltt/1RvHHOja73LLeO1s220kQQPu2o3u8mZe7lcOoz35aSUWFoKUXIp9bJjW4hO7fG+nO4vkoDoNke+LwMNNQAAhJW9e/fSrl276Ny5c1ShQgVq0qQJJSV5rTQAAADUZGXn0MiZW2nU7G1iCFS3fDH68JZW1LSaZkwMgMsgptuCnFxLt+CPR2wL4picbOs4cFkcrvreVwBZurRLothK4GsZVpMoK92kb3bEWIQKNohuB+cnQq8hAMCQ3bt303PPPUe1a9cWr44dO1KPHj2oTZs2VKpUKbr66qvpl19+oRwkSwQAgDz2njhHfT9bRB/N8grum1tXpz8fuQyCG4QEiG4LYpSYbiYrzb7oNrR0myRS02bbdmLpthFz7oNZdm8bieMilkjqO98D6yaEPsO8GarcA+HsCADAKY8++ig1a9aMtm7dSq+//jqtX7+eUlJSKCMjgw4dOkRTpkyhyy67jF566SVq3rw5LV26NGgn+eOPP6Y6depQcnIytW7dmubPn2/Yds6cORQTE+Pz2rRpU9D6BwAofHAM9sQV+8T/8vuPZm6lnh/OpxV7TlGJpHhh3X735hZULAlOvyA04E6zICc3e7kg87xvIioDYjxZzut0/3w70b3/WItuRWxzwrNAhKaZRTiarcWR1PelXxJNfYoovgjRiy6UMEs/TRQbT5RQxP99wNINQNSSmJhI27dvF67kWipWrEhdunQRr1deeUUIcLaKt23b1vV+jB8/nh577DEhvC+99FL67LPPhLV9w4YNVLNmTcPtNm/eTCVLlsx7r/c5AADAH4ZN3Uifzt2R975m2SK054Q0dieii2qWppH9W1GNskVxkkFIgeh2Yulms+CpvURpp4jG32a+HVuedUW3x1gc7tNYJFZ+Z7T3wN3LrXB7f6Ekkvq+LXcSJUv90PcLnvQZWp0ooSjRCwf934983yGmG4Co4t1337XdtmfPnkHrx/Dhw+mee+6he++9V7wfMWIETZs2jT755BMaOnSo4XY8MVC6dOmg9QsAUDhhi7YsuBmt4Gae79kIghuEBbiXW5Adm6BeMKIp0aeXWZ5Y4V6uY31WpSbTiu5al5Lf+ONebuZbbMdaHKmCLVL7FSjHt3n/zzwX2GdUTUqE+VydPky0fhLqhUc6i0YTfXIp0dlj4e4JiADYlX358uXUtWtX1XJ+v3DhQtNtW7VqRVWqVKErr7ySZs+ebdo2PT2dUlNTVS8AANCDy3rZYc+JcziBICxAdFuQGV/MrxMbk5Op614eY2bpVsV7m4ihPPdyMt7X7w8TfdXdXMyYHSOSXLSjOaY7Eq35kWTp5gmsX+4i+u/j8PYDmDPteW9N9/nDcaYiiOPHj9OgQYOocePGVL58eSpbtqzqFSyOHTtG2dnZVKlSJdVyfs9x5Xqw0B4zZgxNmDCBJk6cSA0aNBDCe94841AttphzYjjlVaNGDdc/CwCgYMB1tN1sB4DbwL3cgow4f0W3kaXbRHSrElzZsTSbiLCV33r/3/ufNza8fH1n1nG3hOvyb4jiEoha3kohI6ImDNwUtTGa6xMf/THdZ494/988lejSweHtC7BGTiYJws5tt90m4rvZzZsFLycmCyXa43k8HsM+sMjml0L79u1FubP33nuPrrjiCt1tOEP7kCFD8t6zpRvCGwCgB9fT7tmsMk1Za5w/58GOdUU7AMIBRLcFmfHF/TqxsR79mG5T0S2LYK0g1iv9Im9vJKA5pvjfD9RJ1wy3sWlpt8vZ40R/5gqppn2I4kNUOzbc1ttg4ZOtPskFS3eETFAUBu+EgkCIRR0w599//xWvFi1ahPRUsVU9Li7Ox6p95MgRH+u3GZdccgl9951R7hIS9cZRcxwAYEV6Vja9+/dmU8H9dp9m1K+tcZJHAIIN3MstyPBTdBslUmuVuZJo3zLvG5+63FJ77bYqcRTju4zjfBXOHM3/e+sMne11RDf3Zf1E4+PrYiFu01PDk9yswAo4lxLnqe4zf3IBFPDkd8AEiO5IomHDhnT+vAtJGv3IoM4lwmbMyP19yYXfd+jQwfZ+Vq5cKdzOAQDAX7YfPUO9P15IX/y7U7y/s30tuvey2j4WbghuEG5g6Q5WTDdbuo2siF9cSfRqirl7uVYMyW0Va5PcflQboucPEGVnEr1XT/oAJgMyOd6bLeLz3nU3kZo/FtVzJ4gOrSGqfQVRrJ9zQnrH2jmfaOs0oi4vhc7iHkwCEcsqD4kIEbsFdqKkgBENlu70M0RJ/k2WRhtcruvZZ5+ll19+mZo2bUoJCerEn3JpLrdht+/bb7+d2rRpI1zFOV57z5499MADD+S5hu/fv5/GjRuXl928du3a1KRJE5GIjS3cHN/NLwAAcAqHs/yybB+98sd6Op+ZTWWKJtA7N7Wgqxt7vW2uaV5VJFfjGG64lINIAKLbgqx4d2O6Ve7iPu7lcky31tKtsy/t9gfXOIvBlIXbgZXm+/YHWZTbFVWfXk6Uuo/oho+JWg3w77h6QvKba73/Fy1PdNljFDKC5eoeyPVxW3TzPuR69v7uA0QBES66t88i+rYX0WWPE131KhV0uPRWSkqKqMutF1vNyc6CRb9+/UQit9dff50OHjwoRD/XBa9Vq5ZYz8tYhCuw0H7yySeFEC9SpIgQ35MnTw5qWTMAQHQxfukeWr33FLWoUdrUMp1yPpOen7SWJq/xlk/tcEE5Gt63JVUulZzXhoU2xDaIJCC6LchK8DemO9NcSGScMRfd2hhuK/dysTjWmzRNxszSHexEairLvc39seBmNvzuv+g2E7ontlPUYieG39Z+TCZ3nDLpAaIdc4gGLSFKDsCqFimx5SC6mfqs93/OY1EIRPeAAQOEq/cPP/wQlkRqDz30kHjpMXbsWNX7p59+WrwAAECPG0f/S6v2poi/f1iyl35csod+G+Rbonf57hM0+MdVtP/UeYqLjaEnutan/11xgfhbr3Y3rN0gUoDotiAuLp4uT/+A5ic97ujEijrdZkKT452dJFKT2679majP5777Z9Gt3c5UdGfKGxsfzwi2orNlqWYHooT82UXdfTi2+AZgITYVkhFuqWP+eZUoK4Oo+1uBT2IEU7wzq3/0/r9uAlGbgf7vR+/z8D0TDe7MhQm9hIyRRKAeF1HGunXrRFy0nBUcAACi0cKtCG4Ffv/utE10QYXiwkW8efXSNHr2Nho5cytl53ioRtki9GH/VobW7GFTN9Knc3fkvX+gY116tkejoH8WAIyA6LYgNjaG9noqklPistMp20z8zXqTaOMf9i2QWlFyfLu+pduJGDMTXHb2s2CE99W8H1HvMeb7d2pRDcQt22zCINJFXMY5r5WOufRRohKVrMXyqb1Eparb/2yyF4Vrbt0ButFr74+sdKIxnYiqXsTT34HtG7hHpH9/YgqX6OZ4ai67BdENAIhm2KVcj9Gz870Tq5RKpoMp3pDJG1tWpf+7sSmVSFbnsZAt3LLgZvh9tyaV4XIOwkaEmy3CT7xwV4mhzJhER9sVP7+fihzVibFWWP2D18XcblZprTjavdBXmHLiMe12ZpYpM8HlxN13zXj95ZzUTXss2yIvABFnegw/RMOuf4mObPSzMw4/h8qanWkslpV2y74mGtGUaOoz4bF05+3Tk1+XfdlXgV2z04eIJt5PdGQD0SrjckIhoaCWn/Mbg+/P0c1EJ3dR2In0SQGXeeSRR+jRRx8VrtzLly+nNWvWqF4AABANcAy3FSy4kxNiaXjfFjSifytDwc2wS7mT5QCEAli6LYjLHcRlxSZRgjZe2oLEM7nxyXYxKxmmFWB/PEx068+aHcT4iqjsdOPjyaLYSmzsWUw09WmiHu+QbbSW7jU/E/35GFG/b4nqXRkdlu4TO4jGXuP9mzPOBxuzvuu5l//zivf/JZ8R9XwnvHW6M87m12Vv0ouoiL7Ll+Vn++RSonPHKOz88xrR6p+I7p+j9jgozOh9f86fIhp9cei+I2YUMvdyTmbG3H333XnLOK47FInUAADALeyK4X5tqlPvi6pbtmN3dCfLAQgFEN0WxOWWrWJLd5FgXw2zmF09gaxXcszHQm7mQi6t046llZh0FnW1LiX68Rav1farrtafQ6/PvK+J93n//v5moldOWGwcJNHt1NJ9bKv//RB9cfg5VNc9xnjd8W1EvwwkSvND5JiVprMDx5vHaz0/PF6X8Lw2JpM9eshW/EgQ3My/w73/L/yQqNub4e5N5JJ6QH0d/S31Fwnu5Yc3EC3/mujyJ6NiomXnTm9dWgAAiFb0XMGN+GbRHiqSGG8Zm81x3hzDLe+Xa3UjmzkIJxDdFsTljh+zY4zdWFzDrGSY1tIt2mgTseU4E1Gm2ctziNb+QrTwI+/LH+Q+hzI7tZuW7lBn1VYdTyPY5Xvi94f9F6dOSoaxh8PsN4m6DyOq1JhoxstEi0YT/W++933ePj3mEwaWfXJgkeNs6bPfIrpuJFHFECRFiYTM6v99SlS6BlHDXK+LSEVcx9jotXR/0sH7veOcGbdPpEgmMzOTOnfuTH/99Rc1bix9FwEAIIpw6vJtNzabhTm3Q/ZyECkgptumpft0vANXWX+RRaqPpVtHIGvbWGVMdyK6zx33DjwDQe6zU+ESUCyt2bYBiO5QxPeqJl5kcZzjtW4rnNfxFDiyyfkx+B7YMo1owYf6n489G3bOJfrB68ZKC0Z6t2EhrkUOv3BqQXdy3467gWjvYqKPLyHa9g8V+LjuQ+uI/n6G6KdbKezoTlp5IqfeesDZ1XM/y6HIj4dOSEig9PT0kJcJAwAAN/HH5XvO5iO22rEwZ3d0WLhBJADRbdPSPaniwz7rduRUdvdqnD9JtHMeUWaajpu4HUs3i26TOG0tZsKI45jnOYjf1t2/1Jf009IKGyJG/mxc9mzm60Tjbyf6uD3R2eP+98logLriW6IPW/m6k+vFP88ZRvRdH/OYeH9RlY2TBMyfjxD9+ah+vxQ+bkd0ao/1MVSfKZvoh75EM14i2r3AeJvU/er3cQm+wlQlum2cm/QzgdcL5+sQdMIsuvm5oOeGHxZizCclwu0V4Fb28kgvjSYlUnv77bcpK8ulhIgAABBiWBBf27wKzjso8MC93Kale3tyE591C3KaUt3YQ+5ekW+uI4pNIOr6hvOYbhZsTpK9BUM0Gu1/7tvqfqelEiWXtLef+e97Xwrz3iXqMSzw/m38y1tf+voPvYnpmL+fJbptgrqv8udh99U5Q73vN00manJj8LKXy8deaTOL9/7lRKVrWhxD6tNfj+vH5lqJEL5H1TtVX289zwwtU560mUnfQb1ubpt2ylkSNzv7dAOeLOLJjVa3E9Vqb3+7BCmbROY5oqTiFFJkoW9l6fZ38sQtXIsnjw7r8eLFi2nmzJk0ffp0atasGRUrprYYTZwY2S7yAIDCTWZ2Dg2fsYUmrz0o3lcskURNq5akWZuPmm7XqYHzUr4AhBuIbgvicsde2ToD79hgWcDYSiiLVGZMR512GmHDA15OcmX7OFnBHWTK1s4DK9Xr/niEqO83JhtL5/agxtUzoERb0uccP8D7f5laJsnpcjSfJ1ltgXcbWXzyhMDF9xMVsS6lYTiRwkI6sbh6gsNIGJmJS63YWvszUbv/BWbpXj/Juk/MmSNEpw8SVW1pvU/OsL9kDNGAX4kuvJrcwZNfD71EFaI4Px+b7CLOeRJWfe8sy7fsVcAZ4kMtulXXxuI5EfXu5cp+okN0ly5dmvr0CYW3BwAAuMvu42dp8E+r8mp033JxTXr52sZUJDFOJFdTYrHHLdpFk1bmGwWQEA1EKxDdFsTl+pdnZ4fYxZQH93pxuzLaDNFskTIrERbqAbKZtdPMldnHZVXTT7aSO0Hel95g+vTh/L8TNbFFWku30Tq3kK8Jx03vmEs0cLL97Q+uJmreN1+sDm/kFSKvnLTRb4ex8BxbLSOLbjteFNqYdSPer+/9/77ZRNUuMt8nC25m5mvuiW6+fzh5G3/eOh2J7vxDvx0LYu39I3PUZsy92T2RwS75Ic6qLR8/Jsrdy7m82e+DiFr0J2p0ndmOKBr4+uuvw90FAABwzG8r99OLv62jM+lZVDI5nt7u05x6NKuicjnn17CpG1WCu1erqvSMReZyACKV6Ahci4A63XqW7tFZGtGRyweZLlgejqy3bqMV2E4t3Q7rjjvGzNrJAkWLUTyydnKA48M3TyXa9a/NflhZ6qRrm6ARTbIY1Etc5zbafe62+RkVFo1Su5obxf4HaunOE4B5G2tKxNkR3Q7dkjmhm238FE3rJhJNf0lzLjxESz437wOHPLxVlWjz3+5PcsnbqXIjhAhLj5gQJVKz4+Zvlb2cQ0M2/UU0/rYCYelWOHr0KP3777+0YMEC8TcAAEQiLLKHjF9Fj41fJf6+uHZZmvrYFSrBbVZKjAU4LwcgGoHotiA+Nld052gGfAN+pQNUXnebrZ5qFBKWf6MT0+3A0u20lrJddi3w1rtli5IRHJuqRc7OLA+wtW70LM5/7O9N9iYnmTIi3YFlPLGo+r18Phd/SrTnP2dWvYDqdPsJu5RzSTHOeq3bJ5cs3apNNe7ldmK6nZQuU46hh56V3F/R9OtAb11uzuhudVyZWbk5GORkd8yMV4hGX+K9T49s8K9P8v2vN1kVbOQJEb3zapRx303+eZXog6ZEZ44G5l6uzVvA947eOY2SRGpnz56lu+++m6pUqUJXXHEFXX755VS1alW655576Nw5nWcsAACECXYjv+bD+TRx5X7iofXjV9WnH+5rR9VKS3lLbJQSc1piDIBIITpGFmEkNld0Z7Hovv4jonIXEj2ywtR1da2nDqUlOIjD9RdtWRse/DoR0nrCN1D2LSMa25Poy67q5XaEy6G18gbGA3mO71Vg92szTu7yxo+biQb5nGndg+V1898j+qqbcb+cwC7ybFXN0FwDp6W29Jj0P6KV3xLN1iTjs+q3laXbymXcaUy3Nou6vzjJ2G+Xs3I5kgBCSxaMIDq6kWjCvf7vQyW6Ze8CnURtwbA0W3mKuHUdzfj3A6LUfUT/jQ4we7nmWn57o9dDIfWgdkcUDQwZMoTmzp1Lf/75J506dUq8fv/9d7HsiSeeCHf3AACAcnI89Mmc7dTnk4W0+/g5IbLH/689PXrVhRSvlAhyUErMnxJjAEQCEN02Ld380KCL7iB6ZBlRuQtMt8nxxFJmrJRwK1TwgNeJy3hWmrxxYMdmAcls+M37f4YNN1izCQIzS7c8sLeyYo9s4XUnNRtMyy67CVpLt4mgsyW6Dc4rizC2qsoZvN0SLYfXm5/Ps0bWQjPRHWsxSaPNXp5JlLLfwuLtklsy3/Oijvl2e6LJzgSQyvXdpD3HzS/8SN7Qfa8S+f7XuwZcYpAtwe/W9Y2zdwOriSCjMnduTuQpWE38WGUv115LJVxg/cRo1Nw0YcIE+vLLL6lHjx5UsmRJ8erZsyd9/vnn9Ouvv4a7ewCAQs7h1DS6/avF9Pbfm4Tx6ppmVWjK4Mupbe2ylttyTPcDHeuqliGJGohmkEjNtqXbvlUzm2Ip1hOGuqmBWLoDHSyzgKzRzpn7K4v++KTABJkbLvLy5IN2UG7mrh9IzeStue7LnMn6xo/d2Wceei7AWflZsCfcYz2JwMnllubGMSsW1nMm9dH5GsnnisUMWxHrXaUuwWZIAJM+LMRmPku05DNr9/L1v3knOm76mqjO5TYPYNK3H28h2r/MWqDHJdo8lt7hs82/C7P+Lz+Wf9d8ch2V+3i28/WB8sWV0rGy7Fu6uV/aGG/DiTLt/RIdqptdyCtV8k2sV7FiRbiXAwDCysyNh+mpX9fQibMZVCQhjl69vjH1bVODYhyEfz3boxF1a1I5L5M5C3EAopWIE92nT5+mLl26UGZmJmVnZ9PgwYPpvvvuiwBLNzkT3W64CTslx6Glmy1k8raBwqIszUEpJCur1aQHvINks3PpNBmcnihQuUVrjmWWmM5KYLCll7Ne22H/CqINvxPV1SkN5xTdz5ipLj2lu50kGJd95U0OJvNtL/NQh5JV898vyp1I2PaP957gfTspfeYEvn6y4BYY/Kj/cqf3/+/6EL0ku5CboBXSbE1u0puoYiO14PY2dia6j23zJsvjPAU1LiGqrwnL0H43+W9+GK3+gah6W6IKDdSl14xIP+OdXCqmn4fCFPk7oSdardY7gcvwfXM9Ud1ORF1eMD+WHnIsNt/zPqLb4PpoY7ijJKa7ffv29Morr9C4ceMoOdnrXXX+/Hl67bXXxDoAAAglnORsy+HTNG/LUZq89pBY1rhKSfrwllZUr6J/5S6VTOYARDsRJ7qLFi0q4tH4f57Fb9q0KfXu3ZvKlSsXlv7E+WHpzhGWbvtxpntyKlDNWBcyznr8sHRzwrMytd2JJWbBYVTO64z34atC6evSL4nK55aFUuDEU3sW5ZdPM0L7eSc9aN7Fld95ywbdMErf0q09D2aiXk9gsEiPT8y3/tvh7DGizzt7/5YTtfmL3r1qK+5ZEiSp+/Xj443g+tN1O0u7koTisJre/188YuLZEAD+ZOHX82Aw/I5rhBpPpNidTFEwmtkf1Vr9Xq9+t8p9O8tbI11JUsjt7Qjdt/k7nkn0zG7nkx/Stdx34gxVN1kfsKfGmp+J9i3xvvwR3bLIFve8JszH6Fxpr0+UZC8fOXIkde/enapXr04tWrQQFqRVq1YJAT5tmpQMEAAAggyX99JmG7/70jr0TI8GtOFAKk1csQ/WalCoiTjRHRcXJwQ3k5aWJqzdHqcZoINSMsz+NmeoiCP38ky3LoPWxdcKjnXe+AdRpWZE9bq40wcnlm52hWVL3eQh5mLabCJBu44tgGawm/San4hqX6q/D215pnnvGO+LLWl8byoDdI6l/vxKog6PEF0+hGjvYnX7aS8QdXvTdz/vXmCQTC6X3QvJEVYuwIbbSTd5vB85Cc4cNhc3SgI8Lr91ic7kCCfFMxXQHvseE/6IJnliQpUczMGX3zDDegCTWlrRzYJUdcwc+5+NJ0dqtidKLkn0zXVE7R7QvxYG986uoxrRvWex18U+ry8BesxYTRr6TIrlfgeViS7ZvVzvvjC8rtHpXs6T0lu3bqXvvvuONm3aJH4r+/fvTwMGDKAiRfQzAgMAgNus2H3CR3Az17WoQh/M2KJax3Ha7DYOQGHDsdqbN28evfvuu7R8+XI6ePAgTZo0iW688UZVm48//li04fVNmjShESNGiFImduEMrB07dhSDCd5P+fJ+uES6RFycUjLMvgUnnRIpThocZnliKT7Gu/15SqYilObjjp5Hx2eJ5g7zr7N8TCd1upUB6OG17rg18yD3hO9D1zTLtpmbqZ2MzfIkg+wub4Wc0dzI0s0CxYx/XvH2rcuL+WWjss57hXqCjmjluFs90W3l1vp1D3KE3vmycuUXSCLEyeSNwtbp1l4A3/fxulJrJySYcddbH0OvRJyuUI8h2rvEm2iP48rtIJ8jWTxyJnjLrNh5G+b/KT8zbJ1/m6LbJ7GgxaSA3A8lcV+Dnl7Phb+ftSG6848XSxpR/ZXGHT6Ydbq1++fPxRZ8vt/bPUjUQ/Pc1D3nBgkao9TSzbC4DmcIFgCgcHPqXAa98od+Scw5m4/4iHF+z3HacBkHhY1Yf+qCshvbqFGSe67E+PHj6bHHHqMXXniBVq5cKcQ2Z1bds2dPXpvWrVuLGXrt68ABbw3V0qVL0+rVq2nnzp30ww8/0OHDkgUtXJZuG5r7SGwFuivjKZ/B6VHKd+f8vthtuu7oGfElvG/YShpQ9nI/E4sd2UiuJDw6d4xcQU7yZmb9ZCHHsdOLxxCdPuDnsYzcy20MvDnuWZkgiJXmsE7u9q8vVtmX/cVpCS9/EtQp4QBGTHveK7iZfUvJL6bnTnDI6N0f/L398mpv7PZ/n1oLU14ve2loJ9n8seDK51zPXd/2fqRjs1eI9tqYWbrZ++Lr7vpZ1xWUibqUfUSjLvZ+lwyO3+HYr17rNp8vPYFtdJ74O8Kx8AtGGvfVuwPz1fL3kydglAmmxZ/o1H63sHTL59FHZEeP6N6yZQuNGTOG3njjDXr99ddVLwAACCaLdxynHiPn09r9+l6Oh1L0jSGotQ0KI44t3Syg+WXE8OHD6Z577qF77/XWpWUrN8eWffLJJzR06FCxjK3kduCsrM2bNxfW9Ztvvlm3TXp6ungppKZalJDyM5GakaV7d05FqhXrHcAOLP01rT/ge/z7MobQRwkf0dtZt1DnIgd1hpkx9FfXOdS7eUWipOJE8UW8FlOncB+dWLplts+kkND2XqKlX7hXQ/zkTqIPGnv/3mjfm0LF+RP2rF9GsFgpfyFRQhGDcmwSXEJLm9xJxrZF1SFrxhO1f9g8pvr4Dm+t52Ll1J4GbrFthtp93egcmcE5CLToWTTl6/j3M0R7FhL1HWe831/vVpeN8nfyStUv6bt4bIu9beRwBQWtuD2w0r7o/ra3fj4F+fx80p7okeVEs94kOraZaOpTRO3uz1+fdsrXut3gGv1QCKO+rBiXHwvfYTDRnGHeXBItJdd0LZOfJOr8vHG/9Y4li37tZMy+5UTbZxmsj4nKRGpcGuzBBx8U3mCVK1dWZQXmv19++eWw9g8AUDDJys6hD2dto1GzthJX1C1fPJGOnbE//kStbVAYcXVkkZGRIQR1165ql0N+v3ChvbhUtmorwpn/Z8HdoEEDw/Ys5EuVKpX3qlGjBgWjZFg2P1V0uDvzKTrjSaZPs64zbLPOU5c6Z3xAf+dcTJVyfK32Rz2lKCcu2RtnGciAf/WPXnERyVRoaK+d3RjYzVPy//a3XJIqe3m2NxncuRNEGTaFv1L3Wo6DNoptZwEzxsSV38yVPhBmvu4tFWYWc//faG+tZ7ZGcqx/MPFHcBvdF3qWbq01mDPDm00kaOs0OwlVkJEt6v64lOt5GGg/s3xfspeHmejWE9ziONLnO77N2HXfKLxh82SilD06fc0mSj3g6ylw+pB6AoJDaH57QD1JyHXW5bwAXLJu6tPq/XASRAXtc5KPLV9jbY34H/sZn2ufc+ghWvWjpvZ75MHW7TfffJMOHTokEqixd5nyWrFiRbi7BwAogOw7eY76j/mPPpzpFdx9LqpOH/Zvpdt2/LJ9PstQaxsUVlwV3ceOHROJz7R1Q/k9DwrssG/fPrriiiuEC/tll11GDz/8sLB2G/Hcc89RSkpK3mvv3r0UHEu3vqDe7qlGzdO/oGFZt1CONODOitEvEbQt/kLV+xU59eiFrLvVjfwtu3MgCgZZVmWrwg27pL5Tl+idOvZd5Vl0c0kmWViw9VuPfcuIDq52NxO3XTb+STS6nXW7GRFsHdNzadYV3TqiWSu6uaa8kdu5P54miteEElpgJLpL1TCf+LAS3bIXyPc3OUv0lreP8zYT8Dl8FvEk2PBG+dnV9SaT5Gu4boL3GGeOEn10EdH899XbHVyjfr9jdr61WjtB8XkX9SSc1r1cFuxa0a49xzwxwJMC3KcI5uTJk4ZeYAAA4DZ/rTkg3MmX7T5JJZLiaWT/lvR+3xbUoV55kSDNirf7NKNnkEQNFFKC4kOnLXzPGVW1y4zgeG+eseeY7jVr1gjXOTOSkpKoZMmSqlcwLN1ZBqJbicnWCvMJTT+mlFIN6eZ0tYCZknxN/pui5ah3xuu016OepKD6XsvSvqKN6Jusq/MWr8mpE+CnIaJLHyNqFsZBmlG94kiBB+bKYP3IJnvbnNhJ9NkVRFun+Wbq1nJ4HYUVo35FAyKOWM/SrSNu9SzVWiHOkyu/PaR/LH8t3czI5uYTKGbJxtgjwVJ0S4L5yAbfSTo7Ilx7LrhPqnjo3L8zTpMjlNru2ioCPCml93lY2HKCQXZr10Xns3AVAL3ze3CV+r3P+dfs6+gW9STZboOcBP6G7IQAFtzTp0sJDAEAIAicy8iiZ35dQw//sJJOp2VRq5qlacqjl9MNLavlteGM5JMe6kDD+7agR6+sp7ufhLjoCN0BIOJLhnFcGZf80lq1jxw54mP9jhYUS3eOiehWkJvsL9mC5nSeSEt/Ug8Es2LyLb1yKTRVWbQbPxau4jf+XobiKYvujPfGwt6e8RytTpZiLf1gQkZburL9HVTaKjN3IMQmGCfuinTRLYtSznxt9XmYVd8TndC4oZ47rt921v+50cvCiRCGOoL15zt9l+kl1dNad1l4sjjslZuES7UuwJh2dm02Et3ct6+vIer0jPH2nPyNQxE6Pesr0rVu1VrRzaLWyqNEK7rZei6L4fQUosQSRJunUsBsmUa0+1+pf5rv0oyXiO6VYq2tJhCUvARWyf607uVafpAmH1n480sPzvJeoT5FIvXq1aOXXnqJ/vvvP2rWrBklJKiv++DBg8PWNwBAdDJ+6R6aufEwlSmaSP0vrimE8uCfVtKOo2dFypFBnerRo1ddqCugOSM5v1buOUkjZ+aGLkkglhsUZlwV3YmJicJSPWPGDOrVq1fecn5/ww03UDQSG2Nt6VaQ3ct5sGhpcDJyIy9alqj9IDr2+2SKoRxh4W5eoyylbvfWLw+EN+efphl7t9KnFESufp1o2nP668wSeUUCsou4El9a70qiLX8bb2M3SZaWC7uqy2wBc9hF+ayOy3/m2cDiyGe/pbPPQEV3unlMN4vQb/41WLfQm/yNadrHOr+B9jnCx7US3VpLPseJy/H+HN+9aHS+5dpfOCb6h77qZXpi2TCPhc5DlBPJsTu6VSjG2p+9CQ6L5FaP8McN38n9FQY4a3nx4sVp7ty54iXD3mUQ3QAAJ9w4+l9atTdFFZPNticeAlcqmUQf9GtJHS6wLuPLwpvdzeVyYYjlBoUdx6L7zJkztG1b/uwVl/Vid/CyZctSzZo1aciQIXT77bdTmzZtqH379mJQwOXCHnjgAYpG4nPrdKsEtQFyG35AWW5jI3bbQ7F0Q8b/0c57riHP8zpWp4vu8GYGlhOVHTV2iz5BJWjerrNEOmWkXUNJCKdHkrvu/65zViqldDpXdFdrYy66/aFKS6LuwwqQ6ObviZ+ixi4LPwxs+y81NaUV5r7tvuhmYelvfL6cuIwnfqzKlWmt8ool2Uz0a0UuW7o5c70C/x2o4GaUEnFGruZWteiNnqHv1SOq2MT82EvGeF/N+xHV7UR+YzehYhjg318AAHDLwi0Lbnk8e3GdsvTZba2pTDH73orsbs71uLk8GFu4UZcbFHYci+5ly5ZR586d896zyGbuvPNOGjt2LPXr14+OHz8uaoQePHhQ1N+eMmUK1apVi6KROCeWbklDe8iOpdu4gcr1nGPGjeo3X/8RUfW2RH/k1vcuUka32V0ZT9PWHI69iaE0CrKLt5mwNhPkuvsq5XV1DQfKcYtXJLp2BNFfj7m3by4vlpRbm92Nkmvd3863joaD0jX0BVYk4SQzvL/Z1fO2T7dXG92O54XdTP6ySJw9lGixA38WIbpzs/AzX15FrrDu18Cug9nE5JH19svl8ctfglE+DwAAIozVezXJJiVKJcfRruNnHYlu2d0cAOBHIrVOnToJQah9seBWeOihh2jXrl2ifjaXEONs5MFm9OjR1LhxY2rbtq2r+42zyF4uI7fxOLR0a1s68oRka7dCcq4rpYbNOTVoP1VQJX7zoUQVcoXkUuaCvLJxNnofGvQguvkbR4c/FWNyfCN48sKIEpWJ2gz0WszcgjNnaycnrhtpPmHB9ds7PUdUuRlR6VpEd02WVjq0MvO+KjUl12h7HxUo7NaJN4vz/8GF+0WU37KwdGsZ3pBo8SfO7gkW3IHGseux8jvfZfuX29/+5M7ovxdcZtiwYXTunL0+LV68mCZPlp8TAACgT5NqxuOPGRuPUq+PF9KwqRtx+gDwkwKTRnDQoEG0YcMGWrp0aVBEN2drPJ1mbrnKVlmnTYRz2QvEfzn18jOTj/xnK6Vn5Q+u7biz66LELzJF8+Nusu1c6jv/9O+YVzxNdN9se9ZsFuR3/G5/32XrEF3QxVF3bi/5FTkmsZjxuuK5SQCrtKCAY91lMZWQTNTvO29IQM32RM37G3oq5MX6FytP9MC/RINXEdW+LH+d0/uFhfuDC/I/m0JvyYre6Xmiu226v7e525t1//InvZ8l2tk5L7DtOWGebDn2F46zdmrp9ocT+XF3QccoYVmkku4wg3uQ4d85DuXiyh5Tp06lo0fz77OsrCxR9ePjjz+mDh06UP/+/V2v6AEAiFw4gdnEFfvE/05LgX0yx/p3gGO0ne4bAFDARHewUEQ388Zf5jN8coZz1kDsYm4obq9+nTJ7DM9btP/Uefp8Xv4Dz8iwftpTxLzDtS/3ijIWTD3fyd+fnUvNSYfYVd0pbI0uJ5WHMLPW8joWj3dNIbryFet9t3+YKNZZFESmQY10vwfWbOlmLtLJkq2l6xvq9/fO1K/PrNQAb3Qd0aDFRHf/7RXhnLneCFmQ+4QbeLzX3IwrpfJ1yvXSeiVUb5P/d/2u+uf+2g/U7xOKESUVJ7r1J6IrXyK6fhRRw2uJ6rnkomyXC64kuv03ouf2E0kTWlGDdgKE2fiHfsy522yT7lO38HfiMNL43aCsXJgYN24czZo1i3JycmjAgAFUuXJlkcS0RIkSooRmq1at6KuvvqK77rqLNm3aRJdffnm4uwwACAFshWZr9JCfV9u2SrOn6l1fLxGlwPad9Ho7lS9mnoiTY7QBAM6B6HYguhds18mcLCFbp1lwG3qkl6pGdOmjlKMRPBsOplpauntnvEbrirQlqnoR0UApsRoL7WveJ2pxi9eKyeWIJJGXLRJdGcD9eHBRfqyxU2LjvNbtR1YQPbqaKF7K0lano7ptfK4grn0p0cX3qQVlx2fVbW+b4BVzvH8H8Kl7JONh+xv8b76vhZkTnSkU87rli7406Gm+rw6PqC358jWWz4sRsvVai5kVnD+0WQmqZ3YTlaia/75WB+//icWNPSXYhb2ktE1em7Lq9/2kRH5M+XpE/b8nqiOFlbBrPp+7jkGMO69xMdEFnb3X6bZfiTrn1nOOFoqWcy8zvlM2/eX+Pv1NJBeJ6GXNDyPNmzenzz77TORPWbFiBf3yyy/0+eef07Rp0+jw4cMi98r9998vRDgAoODD1mc5U7gdq3RqWibd/uUSmrNZ7ZV17Gwmvd2nmWGtbZT9AsA/ILodiO7E+FhHMd2WId2a9ZqKY7ps9VSnD6sMI7p/NnlqtqdHflxJb/+9ySu0OcmWbAGVxJHWvfy56pJQqtmBqFLj/Fhfp8TkiuJyFxCVqa2uxV3rUqLH1hFd9rjXAiojH6vf914hLlOhkXr/NuEJjz9zHLg4V2nuFYTd3vJas9naf/skokfXED2+Xi362X3aCMUSXrqmvtDmCQe28JesTtT/B3t9K1VTLYIN8eSXIdODxXTlpvlW7mY3ef9mgapqV4bo6v/zJmZjjwTFyi8juzs/u9fYoi0L+t5jiG75kahGO/22fN8EyqWaRHcdnybq+iZFDyYTYxHA8pwLaWTDb+1vMO5GKjA4iUMPIVwWrEWLFqIkJ7uSX3XVVVS+vHU5H7dgN/Y6depQcnKyKBc6f/580/Zc1ozbcfu6devSp58GtXglAIUGI+uz0fIVe05Sz5Hz6d9t+hOKXIP78asbiLJfMij7BYD/QHRbEC+J2HhJgOshW7bZZccqLlu7Xn5rJ6Z77f4U+nM1x+Fs129QvIKhe/mP2+J12wkXZxkWX1wr2AytBTdO2jdn6ObM1le9SnTR7cbtREy1dH7vneX1CGD0LN33q2vS+hJDpzxSnPZNFnHeXNe4/SCi6z8kuvcfr+AsU4uoVHV1u+qtiYZsJHpmF9H9c9RJ6DjDuXYyQfYcYDdsnlgYsp6o4TXGfeHPzvHdfJwH5nnFK088dB9qvI1yv9w81vtZ+fz0+sx7Tvt86V3HEzPsjfDAgvx+JUoZ1Hkdc+lgoktyS/xx9v66+dUKBHJiL7P4fcUroGJj337KNL6R6I4/vH3XwoL+Ohulwvjcau9dpsPDxq7mZp4DBR07oRIS87Ob0l0Zz9Cx5LpELQfY22jPQgoIh5NtrsDhLHr44wFUwBk/fjw99thj9MILL9DKlSuFG3uPHj1EiVCj8mY9e/YU7bj9888/L+qIT5gwIeR9B6CgYWR91i5n49CoWVvp5k8XCXdyrr1tth2X/Zr0UAca3reF+P+ZHrnGEACAYyC6bZYME38ble0ytHSbC2efjOXSEnt1waVt9donl6IZFzxPL2XeRWeoqM/qozf8QNT4BnVsdYtb8/9miydbz9ntu2orr6u4NmZZsXDLyJZuK2HDLsCcfZ2TlEnnWohbBXm5AotiBU2iNeVUzMxp5f2jfH21Wzi7jrd7kKjHO0S3/kyOYZdr/lx8ThT4PCr3R3ySWsy3uccrHo2svFr4s/f+LP84bG1/bq9FuTVP/uQFT5JUbUnUoj/RC4fyrdrKtZLFqZxATnsdZTd/+b6wqhutULIK0VM71En2tGW0OL9B32+8ExxNeqnXcTw5H7v1nfoW8TjpPJuV59IT40Yx1Fp3+1BiVh7LTfh68OSSfB44CR5XPjAQnV9m96TTyjNEeKzEqL0/lBAMp6Kav4Pyc0MOXeB72Iqe75Gr8PON8yzw944nq9i7hPMEyKESQDB8+HC655576N5776VGjRrRiBEjqEaNGvTJJ5w53xe2anMCOG7H7Xm7u+++m957z+VrCEAhhMtyWVmlD6acpwFf/EfvTd8ixqvXt6hKM4Z0tNyO/+59UXWU/gIg1HW6CxtxcbLoJgcx3dYFe7RjbLWl23g7RYPKlvfMbA8lxvuK03WVe9G367fq7ietVmeiVhqLa/1uXispCzCljnSF+vlW3YxzlDLtLSoVcy6/1JZWFDsR3ewCrFCmDtlGTtbWbSjRx/mCVjl1r2TeRX2uvYGo8fVeazy7VZ8/SXTPjPzYcreQE47xhICIXY7xxnRfm58wzy/kOGstHKd9+gBR/e7OBKdC3Y5Eay0mHtjTgF3TV+e+d5JNu5gmTjk70zw+XIEneHrpuJ7KQvvBhUSjWuvvV8Yolv7Cq4mObsp/n1DU6wL/zXXG+3pii7cc2MzXyHVCkaWcqdjIN4lgv2+95zCxqG528VMeaTKCJ5fY8quU0mJxPN8P4cSTN5z1nidSal7i9RDh79EbFbzngvMAWLl182TXlCfzQzFS/KgVz0n/+B7hySp+liklCvm+lyesQB4ZGRmiHOizz6rzcHTt2pUWLtT3cFi0aJFYL9OtWzf68ssvKTMzkxISfJM3cdlRfimkpubnPQEAqGGrdLcmlYVLeWZ2Dh04dZ4+mLGZOjWoSEdOp9MzE9bQqXOZVDQxjl6/oSn1uaiaCFGRt2MLN+pqAxAcCozo5jrd/MrOdljT1kVLtzYmW85mrtteI8vld2ZWcmVVvDQhwA9Yq5hzW/DnNbEwLdp7np7JeJPmJT1uLJRlAerEhZfdye+eZl7nmy3Utdp7hShb7M6dIKrYkKjzi0Sz3xCJ5Dw7vCdIWPfb3Zy/rUgW53FfcDMxmnPf2SKTuFs8spzo3HGvC78/sAWbbyhOQmYGezxwWSmOGee2fz+fn4zNCbJFmgU3eyFoy89tneaNeZfjzTlee8FIb0b+cTfoWNw99kQ3u7DvnE9U7SJvvfiFUn12znrOM2HVWuuLPZ7oKVHJ2xeelPr5DgqYAb8SfX+Tuehma+up3eQKPPGkdZXmMnTskcEvxfJ95rDX6jv9RbEohYoZ165uYBIqofBqCtHQmkTpKerlfEye6JPh68Dl1qxqdJetS1S8Yv77yx7zXtfV43PrlNuEJ1v6fJ7/3mHixsLIsWPHxG9tpUpqbxF+f+jQId1teLleey5zxvurUqWKzzZDhw6l114LwgQXAAUUFszT1h9SJVUbOXNb3t/NqpWiD29p5eN2zttBbAMQXAqMe3mw63QzxRLjHNTpNslebiORmtW22nhzFt3BrujDEwG3fP4fZXgkUa0n9li4szhjUcODYCewxUtriVPEISc4YyHA1i2G931hbhKvy58gum+WsLwbfiwW27Lrt5uEa6DOlkl/BTfD9xDH2ldoYN6Ozxtnx2eBxBMpT+8gunW88+MpNbzZYv3EJt8JkC4vEP1vnm+CN84JwMeUs+ErnhhWKPHzLJrZhZ09D1rd5lubnc8F5xng+0gP9pBQ2hklfrtrMlHL23zj4JnqmokNzgHA1na9WPmS1YheOEz02FqiwSuJ6nbSz0ivda/m6gUMW4k7DFav4xwBfG4VeIKLEx1yrXgZ9iDghH+S90SKnB9Bi8VkpGmYiJF3Bt/TfL7Yes3XnCdLtAn7mt6Uf64YXs8hH1y2zgkZZ5y1B3mwlUz7G6FdZtVeb7nCc889RykpKXmvvXv34uwD4DCLucINLavShAc7IPs4AGGiwFi6gwVbj+uWL0Y7jp2lMkXzBYKeFdsnptti376J1JzFdMsTAhkGottsnGtYR9yofW7zMyRZypQBrxYlVtruQNuKXhaWKx74s4WSCWV5YBZx6yd53WQLE/56C3CcOos/FsBOJkD4PlLi+DlRHLtE65Uz04PFI2ejlxO6MWytvuIponnv5rsUm8EeFQpG3hhc8o1f30seFgpcIYCtyqn7ie75x/ccypZ7nmQQ4rOmfiwKW5fZ24PL7nEM8vu5kyZXv+79TLzdQilum8NAtOeLJ7gGTvHtJ/eRX0c35y1K1eaEaNKbaP1EaQKsDdH+ZeTIG8QK/vyDV3hjv/n7zd4H2/7Jn2TjigiKt0daSn6mfbZca7luJNGsN73nalluYkGF86comujdu7ftthMnTgxKHzhDelxcnI9V+8iRIz7WbAWuJ67XPj4+nsqV0ymXx/NkSUkoewaAA8xqaHesX8Edj0gAgF9AdNvgvivq0nMT11J6Vv7AN8vKddzj8SORGtkS3YqOlffPMd3BRjkCu233Tn+V+lx8AQ1QXFKNOlnQuelrohs+9lqcgT3simUjrLLp692LmmR7eXR50fty6tLNlm72uihanui33EzvMhmS+zUL7DXjvccxi8/PSjcWqJxocOc8dS10BRabbAnmXArsbq24XF/8P6Ldi7w5DThZoVPY9b/R9WL/WfM0PxWciK3RtUQXdsufZFv7C9Hfz+Rbyz/pELg3iPx8qZRb8o658uX8v9ldXnaZ13v2sPdBqzu84p0nKma/RbTxD+86FuxRRKlS+RM+/BswadIksaxNmzZiGcdanzp1ypE4d0piYqIo/TVjxgzq1Ss/ASK/5/JlerRv357+/PNP1bLp06eLfuvFcwMAnPPrcmNvENTXBiC8QHTbIDE3g5psTbayRPNa5yXD1JZyK+QmmdKEQDDdyxVWeOrT5cUvpEgklIZuMcCH4C54sAV4xbdeDwYWzIpbvEyHR7z/75jtbaNYXpmytYl2/+v9u0Zb78uIZn29yex4++kv6AvHTs95Y9PZKi/WawSsNvM7wy76t/1KfsN94ARrzLzJ6m6xa788+cEJ87jMHMf5Fy3nzc/ArvGfXUHUemC+h8J3NxFlS5MLTuDzxIkQ2UJvBXsurPzW25YzssvlCTl8hT/Xq7niVV4XBXz99dd5fz/zzDPUt29fkRmcLc8Mx1o/9NBDVLKkWbWDwBkyZAjdfvvtQjSzoB4zZowoF/bAAw/kuYbv37+fxo0bJ97z8lGjRont7rvvPpFYjZOo/fjjj0HtJwCFhXGLdtHC7ScM14/4Zwt9c7fNKioAANeJrtFGmFDccTKysunI6TQ6nZZFlUqaZ4X2lgyz2LE2plv620ywK6vkJv7EdFtxPiOb7vx6CV3ZsCL9r+MFtuLMIwErDwNQgGA3682TvTkE3ITrs3d+Lr9uuRnsus3Z6jmxl8JVr3ut1a00ten1uPFj7zHYkquIbrkkF8Px52wpV0Q313uPRKo0z/+bXdy5ZJwS881lt57bR7RzLtGEe72f2wm8n0setNe2yY3el5Uwn/VGbgm06OSrr76if//9N09wM/w3C9sOHTrQu+/m3i9BoF+/fnT8+HF6/fXX6eDBg9S0aVOaMmUK1apVS6znZXLN7jp16oj1jz/+uEh6WrVqVfrwww+pTx+HnisAABU8/mNB/fHs7aZnZu6WYyLmGwnTAAgPEN02SFAs3Vk5dPGbM8Xf0x83r9tqJ5FajoNEavpC0mMd060dvDvgxyV7aMnOE+LFottpDDgAQYdj/Tf+lZ8sLRxwbLq2xjlbflmM23WhrtxMvcwoUdvgVd4yZ9qkYpGKNskax7Fz8rhndoU/BMWOMI9wOPP3xo0bqUEDdSJEXpaTE/y672xR55ceY8eO9VnWsWNHWrFiRdD7BUBhYc/xczT4p5W0au8p2zHfEN0AhAeIbhsk5Vq65bjpDQfM64WKkmEe/0uGaRO16e1KbenOf5Oalkmv/rGebmhpkORM53h6pGVlm2dbp8gkUvsFggAnNGs1oOCcWs5+fnK3cdb/snW8r2gn3IK7gDBw4EC6++67adu2bXTJJV63+//++4+GDRsm1gEACi6/r9pPL0xaR2fSs6hEcjwN692c1u4/ZZi9nEFcNwDhA6LbkXt5vuWA3cwDFX72rNlK2/x10zccpjcnb6Cb29TQdS//aOZWmrhiv3g9fpWmDrLN4wVqJQ8n8C4HUYuS/RwAG7z33nsiK/gHH3wg3LkZrnf99NNP0xNPPIFzCEABhEX2y7+vE2M8pk2tMjSif0uqXqYoXdO8CnVrUpnmbD5Cv63cT7tPnM/b7sGOdWHlBiCMFBjRzTFi/OIkMm4Tn1uaK1Ny13tryibTbVjQ6pUV07axnWRNs/7z+TvpptaS6JYmBA6l+pmoqICIWbjBW3P0dLqYqKlaWsr6DACIKmJjY4XA5ldqqtf7KtgJ1AAA4WPNvlM0+MeVtOv4OeKh6SNdLqRHutSj+NwwSIbdx/n1+NUNRAw3u5SzhRtu5QCElwIjugcNGiRePPCQS6q4gVIPO8tBWS47dbo9jmK6dbY3iOlWsq1b9tFWK/3jRTLRMjkQTtq+6a13vPqVrlSqCMr1ABDNcd1z5syh7du306233iqWHThwQIjv4sWLh7t7AAA/0IplNuJ8Pn8HvTttsyhZW7VUMo3o34ourlPWdD+KAAcAhJ8CI7qDSWyu6E7XxDgHHNOtWS23126rty95kez6rrjDG21ndHzFbYkt+8kJcT5hl9GTvZwiBvZmWLMvhepVLE7FkiLv67b7+FlqXt2kdjQAEtEZcFJw2b17N3Xv3l1kCU9PT6err76aSpQoQe+88w6lpaWJUmIAgOhi2NSNqrjs2y+pKSzb87ceE+97NK0s4rdLFcWEOQDRhD2TaCEnLld9pmXazwY7ftleS5Hqk0jN46zslVEiNSXxm9V+tOvSMrOp6SvTqOXr0221jyh1G6H8ueYg3TB6Ad04eoEr+1u7L4W2HTlNbhGMUnMAgNDw6KOPijrZJ0+epCJF8kNFevXqRTNneittAACiy8KtTYT27X97hOBOToilob2b0ccDLoLgBiAKiTzTWwQS54elmzmfkWW63seFXBLh2nW6lm6pvSyeZEu3mSz2aAT1sKmbVJMLWqsWJLZzfl/pTXSy9cgZCpSTZzPoulH/ir93DXOnRJY8WQOAFbhbIguu0b1gwQJKTExULeda2fv3e589AIDogV3K9ahaOpnG3X0x1atYIuR9AgC4A0S3I9HtzCqYcj7TdL3WcqyO6XZWMkwW4HJMd46DjOhjF+5S9U3rXh4thm07XgLRyMEU84z5/pwfWLoBiF64Frde8tB9+/YJN3MAQHTFcBv9Jn/QtyUENwBRDkS3A9HtVMulnndm6eZ46q/+3Undm1YmKVG699g628v92XzojEFMt8nxpWNsPqR2WdbdrmBq2ajEOyniX4StfN84SQ4IAGK6IwuO4R4xYgSNGTNGvOdnwpkzZ+iVV16hnj17hrt7AAA/Yri1tKxRitrVLYdzCUCUg5huOyfJT3FjZenWqtj1B1Lp9b82UNcP5tlLpCZt/+nc7Xm1wxMkS3eWScyuvM8YPVGnWeoTg07WLNx2jP7bcZxCSUGVkfJtGIgxX95UznoPAIguhg8fTnPnzqXGjRuLxGmcvbx27drCtfztt98Od/cAAH7EcGtZtTdFtAMARDewdDuwdDvF2r1cfzlbvLNznLmXM7uOnaOKJZJVlm4nyd+sLN12ypjJpKZl0q1fLBZ/b3mjh6pfwaSAeper8LjkXg5LNwDRS7Vq1WjVqlX0008/0fLly4W7+T333EMDBgxQJVYDAERXDLdeO5T+AiC6gei2c5L8FN0sOrWcOJtB5zOyqUhinKnrN2cSt4pT9hhYQmVxe16zH0NLt095ML2YbmdSL+Vc/ufXTiIEk2ipJ+4U+Xrw9Ynz09lXPjtZ2jgGAEzvQTiYRwqZmZnUoEED+uuvv2jgwIHiBQCIHtgTccnOE7bacr1uAEB0A/dyOyfJX9GtY+ned/I8tX3zH0txmGXL0q3fRu6tueh2NpiOFilbKCzdgbiXG9R3B8D63ikEX64oISEhQdTmxkQIAJEBu4BPXLHPliv4/lPn6ZbP/6Oflu7VjeGWebBjXVi5ASgAFBhL9+jRo8VLL5OrW3W67cLNeWxq5NrN7uOMmZFRm8FSP6bbemCcbuJebjaA1j2ew/E2xufuIsfYm2Wlt0Ke7NFO7gAAoodHHnlExG5/8cUXFB9fYH7OAYj6ZGgPdKxLz/ZopNt2ytqD9OyENZSalkXFk+LpzV5NqWbZosKFnC3a7EauZDNX3gMAop8C8ys9aNAg8UpNTaVSpdSzhIES69AfIDk+TliYrZJUmVq6NVmlrbKXM8rcgLzYvGSYSd88vtZvp27b6rrjoXQvjxw8Ee42b5ZoDwAQ2SxevJhmzpxJ06dPp2bNmlGxYmoX1IkTJ4atbwAU5mRo/L5bk8oqwXwuI4te/3NDnnW7RY3S9FH/VlSzXFHxXm7Lf0NsA1CwKDCiO5g4tXQnJ8SaunUrmOlQbaytflv9HeRIatosltpjEdNt83ARJ4QLg4U9IEu37F6OkmG24MoAD3y7nG5tV4tual2dCitwZY4sSpcuTX369Al3NwAo1BglQ5OTn204kEqP/LiCth89K8ZbD3a8gB6/ur6q2gwAoGAD0R2E7OXJCXHsIG7Zzkw3ZWot3TbcvZVe2rV0y2t8y4P5lhHzyV5uIaXlQ4fS0l1Qka+RW6dTG8YA9Bk2dROt2HNKvAqz6AaRxddffx3uLgBQ6DFKcsbLeez29YJd4jeEvR8rlkiiEf1aUod65Qv9eQOgsAHRHTTRbQ4/iM1Eq0/JMJ02g39cqbutvKmZpVu2iPv0L8def0U9bwNPALl1aDW3/YOZ9T+S4DwA87cedd3SDfdye5xO8+ZhACASOXLkCG3evFk8y+rXr08VK1YMd5cAKDSwNZtjuGUXc05+VqNsUbp77FKavdn7231Vo4r0zk0tqGyxxDD2FgAQLiC6wyS6We+axVTbSaR2ICXNug6zmehWZS83LxnGbbVdmL/1GP28bB+906c5dW5Y0bQfocx6bPdQI//ZSt8t3k2/D7qUqpaO7Jq2/MMtlxYJqE63tLXWoyLU7Dh6hmZuPEK3t69l63sDAMiHc5hwLhOu060kEY2Li6N+/fqJxKJu5zcBAOjDSdM4hptdynn8tuPoWbp6+Fw6eS5TlHF98ZpGdPsltaJikh8AEBwQTGLnJPkR020FW6DNhKidkmG23LrtxnRr12mWsQjX7mnNvhQ6ejqdBo5dqr9/gz75y+m0TCGUtx89Iyy0e0+cszyuGR/8s0X0/4MZWyjS0dbydKtkWLjrdHd5fy69OWUjfTRra1j7AQoG/H0e8vMqWr7bumRPQeDee+8VydS4VvepU6coJSVF/L1s2TK67777wt09AAqdxXvu5iP0zIS19Nm8HUJwF0uMo3f6NKM72teG4AagkANLdzAs3fFxtkS3maVb6/ZrR2PlZy+XEqnZjOnWorWsC9HtUOm5HdP9xl8bafyyvTRy5ha6on4FmrP5KH19V1sfK3thqCUcyGcMn9u/MUt3RrZIipTzBMx5ftJamrHhME1csZ92DbumwJ+uyZMn07Rp0+iyyy7LW9atWzf6/PPPqXv37mHtGwCFjfu+WUozNh5RLTubkU2PjV9Nmw6dNiwhBgAoHMDSHaTs5Vbc/uViU+Gkdfs1s1hrkZuabScLYe1H1JYMY4Ooc+EhuZfb3GLzodP06dztlKaT/X3pLq+1lz8SC25m3KJdJkctuARm6Y68M2Q2OQQiG76f7v1mKT35y+qIzSJcUClXrpyuCzkvK1MGtX0BCNUzcPj0zT6CW4bjvbm0GACg8ALRbeckxcb4iFIzkmxYupftPkkbD502XB+I2+8ZKemT7ZhubfZyXUu3s37Ixnq7lu5uI+aJLJ+faWpeiv3p7CO+kJbbCCiRmsHf4cQs4R+IbLgEzj8bj9Cvy/eFuys+YTIFnRdffJGGDBlCBw8ezFt26NAheuqpp+ill14Ka98AKAxw2Ntj41fRh7O2WbYtbJOCAAA1cC93YO3Osil07Fi6razQPpZum8c+m55Fo2ZvC7hOt3Yrb0y38b7OZ2RTkcQ4wz7L3edM3I/8sIJ6NKtCfdvU0N3fmn2n8v7ed/Ic3fL5f7T3xHmfdok6orswGE0L2keM/JJykd6/8CE/Y6KlGkBB4ZNPPqFt27ZRrVq1qGbNmmLZnj17KCkpiY4ePUqfffZZXtsVK1aEsacAFDxW7DlJj/60UoxNOArRau7YqLQYAKBwANHtwNpt+UTNxW4WZtNEahrRff+45Tb2GEObDqWqlpjW6Tb5OHayl8s0evlv2vR/3VWf3Uh0fzF/hyihwS8j0S0zdOomXcHNJMTFuO4+/d+O43QuI4u6NKxEkYpbJcMiRevqTQ7xpBTfgxBxkY32OaHzlQxLXwoDN954Y7i7AEChg3+vOAxu+Iwt4u/qZYrQyP6taMaGQ6qyYTJcQowTrQEACi8FRnRzeRR+KWVTwhnXbVt0m6zL1riXbz582t4+NTs1rdNtorh4sxifOt3mcImMxlVL5u/DwL381LlMckJGlrGrfYIL7uXaS9t/zH/i/yUvXEkVSyRTRBJYzTDpz8hQ3dr7lGP6u34wj5pVL0Wjb70obP0CTidxtHUPQos2TMYpnFPih8W7aVCXepH73Zd45ZVXbLX78ccf6ezZs1SsGCxtAATCoZQ0enz8Klq047h4f23zKvRW72ZUMjmBWtcqk1c2TLFqK39DcAMACozo5lql/OK6pcGoTeokg3mSTfdyMytjpksxrma7kY+vtSaKwbO0zKrEmf6xnSdS8+fzcemwGmWLunIs+TOeOJuhO/DmhG67j5+jm1pXp3ARyO2hEtqRobl9JoBmbzpCe06cE6/Rt1LYiRSPgEgn3KcpUEs355Rgdhw7S9/e044KCv/73/+oXbt2VLdu3XB3BYCIgxOc2RHHXBnh6V9Xi1JgRRPj6NXrm9DNraurxk+8vbwPiG0AQIET3cHGSdWwhFh7ovv1vzbYLhlmh93Hz1JNSXwGYukWq6T1wr3cYX/k/TvJvq7bFwMmrNjnfT3YnlrXKmvZPpBjKdz86SLxf90KxeiiMLmLBWKhdlNAHkw5T4dT06lljdIB7Ud7n4ZbvIHCPTmx4YA6TCfaicSKBQBEAsOmblS5hD/Qsa5PaS/2vHprykYat2i3eN+0Wkn6sH8rqluheMj7CwCIXgpn6mc/cJIl2w2XZ20iNTsM+Xm1j1gxF93G++IxmrxeuJcHYOkONhNW7HdlP6oyahauqnuOn6NwEdDEgsHf/tB+6Cy6cfQCn1wCTtHei9AI0Um4wxUQ/w8AcGLh1sZga0t7bTl8mm4YtSBPcN93eR2a8GAHCG4AgGNg6bZJrAO/xXgXMgn5WzLMSUy3Knu5Zp23RJjG0m0xntaeIlW98IBUlPW2smdAIFadaKlcFVgiNfc/5Mo9p6hh5fx4fqegZFjBENoFZbKksCVkA6AwYlTC65M52+iBjhfQtPWH6csFO0Vi2/LFk+j9vi2oY/0KIe8nAKBgANFtEyfGa70yVuESIXq1rRXMjuDREc2egEoJUVCRs707PZRs0VZZumO8Sdx6fbyAGlQuQcP7tqRIwTVLt0sXhkvGueteHlnqLbJ6Ez6iXYweOZ1G94xdRrdcXJNubectsaVPlH9QAIAlRiW8pm84Il4yPZtVguAGAAQE3MuDkL3cDUu3P+7lzITl+1TvzWKptQJTu07e0ptIzfzYevvQ+zsYuJV4TttNzlC6/kAqTXTJfd0t3Dqdbu2H8xO8MGmt39tr74+CYjEtaFhdl3BfN6sn73vTNtPa/Sn0fAD3KgCgYMBJzjiG2w7jFu1RuZ0DAIBTILptEudASDuJ/zYi049Easz4ZXtV77NsxnRrP502hpv/tLI+agfcqlJCQbaWySXWAhn4a8VfKOPSw5FIzc1P9/3iPX5vC/fy6EV9P4U7ptt8/dkAPTKilVq1alFCQoJr+zt58iTdfvvtolIIv/jvU6dOmW5z1113iZh7+XXJJZe41icA/IGTpj16Zb2A3NEBAMAOEN02ibeZkZxJcJLq3GXRrSXHbky3T8kwX0u1U/2pdi/35P1/Lt3ZwNfOcWXPAL2B/w+L91CfTxbSybMZDhKpRS7KqeXru3rvKdNa5lrk8+PPpMLszUeo07uzafnuE+QWPpZuiiyQ/dmeqA33HJVbE3rR4kbPQnbePG+ZMzPWrVtHNWrUcO24t956K61atYr+/vtv8eK/WXhb0b17dzp48GDea8qUKa71CQB/2XgwNSB3dAAAsANium3CJSNCaenOyApBTLfJIbSJ01gUWQk0M/dy5c/7xi2jfzaqY6WssHMm1InUfNcr7qQfztpKr1zXJOoTqSkicPTsbfT+jC10TbMqNHrARTY3lvfj/NgDv14q/h/wxWJyC5+Y7nCrN2Ab+Xsfbs8Qq4oDUaKlbXP69Gnq2rWrENQDBw6kO++8k6pVqxbUY27cuFEI7f/++0/U/mY+//xzat++PW3evJkaNGhguG1SUhJVrlw5qP0DwAkfztziE78NAADBAJbuIMRYJziM6dazqrhl6bZbp1vbB7aGypueSc9yLNDk9udy3TqdCm67yG70Zt08nZbls0z+7E7EXjitYcrHHTPPW+5k8tqDtrd1SxalZbpzjzrJsu8mk1buo9f+XB9QDflQcTY9SzWxFKmE+0y6Zumm6GDChAm0f/9+evjhh+mXX36h2rVrU48ePejXX3+lzMzMoBxz0aJFwqVcEdwMu4nzsoULF5puO2fOHKpYsSLVr1+f7rvvPjpyBGIHhO+Z+uQvq2n4jK22t4F7OQAgECC6/YgZdrtOd7yOO3ooRLesZXxKhuWo3ZCvH7WAHhu/ypGVST72DaMX0Klz5q7dxv20HsqrzpeZBd9CYEWB/srF47c60HowRAJWNeODwePjV9PXC3bRrE2BD/z53p6y9iClZ2UHZXB46duz6JoP/6WIj+kOt3u51Xqbqjxa3MuZcuXK0aOPPkorV66kJUuWUL169YSrd9WqVenxxx+nrVvtiwo7HDp0SAhnLbyM1xnBkwHff/89zZo1i95//31aunQpdenShdLT0w234XWpqamqFwCBsnZfCl370b/06/J95CQaEO7lAIBAgOi2iVlCMjsi2rx9bPBEt8ko2ExwseDWrt525IzpsbSx1Nr9/7RUneQtWCXD/D0fegI/0LF3sKy0erej3bjuQOoqB8sq7OteLh0zyErupI3JIKse3PblYnro+xX0/vQt5DabDp2mU+cyafPh00KARzSRMYdjSBRpacdwjPT06dPFKy4ujnr27Enr16+nxo0b0wcffGC5/auvvuqT6Ez7WrZsmeHkBT/rzCY1+vXrR9dccw01bdqUrrvuOpo6dSpt2bKFJk+ebLjN0KFD85K18cvNuHRQ+ODfr8/n7aDenywQVusqpZLpx/su8clg/mDHurrLONs5AAD4C2K6gzBYS4h3NpcRpyPSl+5ypzSFmV5RrdNLpOZQYCn7O5KaJsryaIXUsKmbHO0vb78OS4aZZVC2ypItr/Y4HFSGEr3rWv/FqTSyf0u6oaV5TGcggvb+b5dTMPBNpCYne9O/jst2naDm1UtTkcQ4Ve6FLYdPU7NqpWxfq1gXrum6/V4L3G8r99PzPRuRmyRJzxMeKDatVopCiZOJo3BnL3fLRG0VGx4psAv5H3/8QV9//bUQ282bNxfW7QEDBlCJEiVEm59++okefPBBsdwMdlHv37+/aRt2X1+zZg0dPnzYZ93Ro0epUqVKtvtepUoVkVXdzBL/3HPP0ZAhQ/Les6Ubwhv4w5HTafTEz6tp/tZj4n33JpVpWJ9mVLpoIrWrW466Naksnq9szVbEtd4yAADwF4hum4y69SKRBCzdhjUxwUGmcyPRHQrkAbKPe7mmTret/eVu0GPkfDp+NoN6NgtdwhyrRGp21nnXG1uBWfy5UILdFZSro+3Ooz+tshbdBn/b4Z+NvoNtNzAT/3rrPpmzjd6bvoU6NahAYwdenLf8jq+W0JKdJ+jNXk1pQLtato7t8OtqSjAcAeRnzr6T58MguguOe7nt/UTI99yOcM3JyaFbbrlFuJa3bNnSp023bt2odOnSlvsqX768eFnBCdNSUlLE8S6+2PvdW7x4sVjWoUMH230/fvw47d27V3wGs8Rr/AIgELjixlO/rKZjZzIoOSGWXrq2Md16cU3VxCyLaq2w1lsGAABU2N3LR48eLdzo2rZtG5T9X1G/Aq1/rZvP8kGdL/BZFu9QmTl1R3cLc6uucyuo0p4FNzN701EKFbbdy3VUkTr7svy3Jyy1pNftT6FVe81r3jpIMWBKpGQJN3Mv1+vit//tFv/P2ay+x1hwM9//Z79muB1Lt/3T5P75lMMG/L0H2ctk0A8rAr7eVhZgu3v/a80BGvj1Er/zPES7WHYLdhs/cOCA+P3TE9xMmTJlaOfOna4ds1GjRqL0FydC4wzm/OK/r732WlXm8oYNG9KkSZPE32fOnKEnn3xSJGHbtWuXSKjGLuYs8nv16uVa3wBYueckTVyxj8Yv3UM/L91Dj/ywQlTcYMHdsHIJ+vPhy8SEbKR4rQEACg8FxtI9aNAg8WL3M479CgZ6pcCeuLoBnU3PprELd/mdSC1clm51SS/1cPndaZtp78lzjvandUkvmhhH5x2UWguELEmFegKI6dbWJjdaFyw4lp8TvDDrXutGxZPizS3dfgwczKz54UKrJc1c4GdtOkyHU42TL4UTq/PJ349Yh993OTmbv/fgp3O3i//vvayOY8uNkyPaFfUP/7BS/P/BjC302g1NKXSJ1NzZT6RgpzZ2MOCEaIMHDxblypjrr7+eRo0apWrD5cPY+s1wjPnatWtp3LhxdOrUKWHd7ty5M40fPz7PDR6AQBk2dSN9Otdb0UPLXR1q07M9GlJyQn44EgAAhJICI7rDQa9W1XQH0E5LhjkV6W6x4UB+JljtWPnfbd64JyewEFSs3NpYVKeoy3g5LBlmWpvcvujmP2VRGwrRLbsSp5zPNBbdAXQlErOXa5F7pe3j3WO9yZzMcDIX4UZMt4LH4vvWb8wieuyq+nTPZXX8snQHerXsJttz8p1RJeZzuG+RPTg2hl7o2Uh3UtMpblmvYAUzp2zZsvTdd9/Zvm+KFClC06ZNc+XaAGBk4TYS3MwNLatCcAMAwkqBcS8PB8r4TjvO08tGHomW7u8X73HVzZh1b2pafm3Y0wFkWla5F9ton2lTmFi555q5NXOseqTUSnZLKwdTc+86dpZWW7jJ2yHYXv223Mtt7stsEuO5iWtEnfj/+2uD3xMx4QgHsDpiIDHdZzOyRdk2Ft8hsXS7chQAQKTxxmTz5ypqbAMAwg1EtwvxjdryXonx0RHT7bawYUEgx1azwAgVquRgJp/FKvRbZenWyI3dx8+J8k2RgNJPfwx7aks3BY1O780R9dkPnDrvaLtjZ9Lp73WHAhKaTs6Lm6F9pkn8/NynLLrD4ZngLJGab+NDKWl0WpqM0yNSwwUAAJHP4+NX0vLd5hO8qLENAAg3EN0OuaBCMVM3bX8s3U5jPIOBG0N5FnBybLVb2BFddrWIfhk02YVcaqvTNFLcsQPphdodOPifx6mF4ZoP56uypAdjYkC+p9z89pmHNvi3T5V7eRhuP6t7xMy9nMv0XDJ0JjV7dXpIJj6QGwmAwgWXjpy08oBpG9TYBgBEAhDdDhl3TzufAd6BU2lRmb2cef3PDfTfjuOuuK1qLd2hxK54tBLNZsnlQpHB3O51CET8h7rEk9HdrfUQMbJ6+vNZrbJsy5fRKH53/6nzNHvTEYd1qs2O6d/JVidSo4DwhLhk2Jq93kRaVrj1CIyW+toAgMDhZ/TTv64xbfN2n2b0TI9GON0AgLAD0e2QaqWL+Cw7lKoW3UnxzrJjOhXpbvLVgp3Uf8x/ruzLo0loFkqLlV09Yx3TLWcvD72l2+PQahoTxGP4A5c6W7HnpK22703fbKtdMM65fB8YCb5Lh82igWOX0syNDoS3ptn5jGwxMHTP0h0ZnhZ2QzLsfo9d8/aJcSdBGizmAEQ2U9cepB4j5tEOC0+qcCWqBQAALXgauQCXopBJSnCaSM24fd3yvu7swcANYcOu224lGnPaHU+A+33593X07rRNPvGpWpET7Dxqdj/3mfQsem/aZjp5zjxW1gq3Dfc3jl5AvT9eSOcypHh+A50zbqG31rYV/tyaVqJJvt+tEqkt3H7c7+/RFe/OFuJ925EzrsR0+3Mu3BTqeqfKbj6FUGSQd2v6EqIbgMiEJzKfm7iWHvx+BaWmZVGL6qXolotrGLZHLDcAIFKA6HZhgPdcz4aq5U5LZZm5l4cqs7kb43I3Ld2Oj23zA+jV6T5xNp3GLdpNo2dvpxNSyTNuqW3udHLCE6TP8cZfG2jU7G0O9+57DCXb/G8r91P/MYvo+Bl3ElqdsZFEz66wsTrn24+e8d235v3bf2+ivp8tyrMay/u06oeTuHdty6OnvefTqZu6kaVbVUc+xyOSzgU7nMBqe7NKA3avcZxrpb4s1tvdD9zUAYg4OH/OdaP+pR+X7BHf9Qc6XkC/PNCBhvZuTpMe6kBdGlZQtUcsNwAgkkCdbhcGeOxO3qZWGVq22+tWm+jQnSkuEkS3C/tgQRAM93InQkHrPs4i+v5xy0wFnByHvvnwaZWo0bbXT8TmHnY/69YjZ/w/hvT3nM1HhcVcEfDvTd9CQ3s383vfescwwu6dbXXKr3x/Lu0ado1pm0/mbBf//73+EF3foqrGvdy8J07uP6O2LNz9zXyvqkEvLb//22X0z8Yj9MsD7alt7bLGffLrqPL29kMytBMLdsVryCzLCPkGIOrg58o3C3fRW1M3iUnIiiWS6IN+LenSeuXz2rSqWYa+uutiUa+bk3eyhZuXAQBApADRHQTsxg3mXQQTYR2qeCQ33Mt5F+GqY83H5rrQ14/6V7X8gxlb8iZDjERzprRsx9H8+DBeqm2uZyl3c4yvTuRGQUG7X9liLtdZd+sYRsLL7vfEr4kOg30r96ecZN/S0u0okZp+200H/S81J+9Tvj9YcDNf/bvTVHQH+t1WXcsguZc7fWYa7sclVc3d2XH0DFUtXYSSE5zl6AAAuAd7X3GytJmbvM+7KxtWpHduak7liifptmehDbENAIhEILojYIAXV1Dcy0XJMPeVoh33XhYWbM3kGC8ZbX1gPdGcKbnvZkiTBrxPH0t3kL3nQ+Oc7/wobBl2ci+aXTPOxv37qgMiLt3Wvlw8Kcq+5PvASvA5ObxRX3cdd1Y2zWif/tx/avdv5zvwBHJ9bLuXO+mRyeFc2s/u4+eoy/tzqWHlEvT3Y1e4s1MAgCP+3XqMhvy8io6cTqfE+Fh6oWcjuqN9Ldcm6QAAIJRAdAeAW899MzGTEMbM5n65l4etZBhR0SRri5SeIV6uLZ4t99/ja+UMpXt5qCzdVizffYJu+2IJPa/JXWCG7L6t/Z58OHOriJ+3S7CzlzNfL9hJk9ccpK8HtqUSyQmqdWaHZ1dHzthup62/qO5BnQNYlvQKcCrHytKvdi9Xr7P79HIre7nbY3F/QwIAAP7D5STfn76FPpu3XTxT6lUsTh/d0ooaVSmJ0woAiFqQSM0lAhnWRkYiNY9LMd3O3cvnbTlKb03ZaFi32Q7c/VJFEnyX+7TTsXRLQlu21POfWo0d7ERx6pJl7hyLY9w4rn13rrXV6V4H/7iKzmdm00u/r7e9jTz5or2DZ2866uj4/tXptr9PPuev/blBhCF8+e9OXdFq1AXOossJ2uS2buOmpfvZCWvpqV9Wu9MxnT6ZXSuzZ0yo3Mv11ocrJAYA4MuUtQepy/tz6NO5XsF9y8U16c+HL4PgBgBEPbB0RwBmmiLepJyYm+S4lb3cD0v3HV8tEf9XL+NbA51rPp84ax1nzAP6khoLJcNuzFbIEwXamsNaERHsAbrH1VhcD73+1wb6esEu8X7fyfM05dHLHVlj+fMqdaadIE9OBCqogjHPIVu65d3z5IIWs/M1YcU+W20DOQfy5/dnckzeZM+Jc+L1bI+GhjGRPttbrtc/l9rPzf0wOg1Wc4uzNx8Rrqbcb7M8F05P8+PjV9HMjYdp7lOdqUyxRGcbAwACRkl8xpPuHCK26/i5vHVdG1dyJbEnAABEAhDdAWA2wLv3sjr0hY7VTA8zcRUfIvdyjmEMFI+flm69JGbMwu3H6NbPF9s7NhGVSPbvds5yYOmWk64FA7XoD4ylu07mCW6GxZZ3v/b3/PyktX4dO5D7QIs/QtNJnW6r0+HkkitNf162l/6QJnwC+RarE6mZr7f7fHH0maxVt9TWY9qPWIMzYZVBfuDXS8X/tcsXo9svqUX+oj3MpJX7xf8TV+6ney6r4/d+AQDOGTZ1I306d4fh+ukbDgtRjsRoAICCANzLXUI72JRLWVjFZWuNw+/f3MKW67mbaC124Uikli4lNGOmrz/s4OD+WxPl5GnZGqu3NoY7EEs3W+usUIfvBia7U877kYlcc8ifl/l3X6jcywO8hYMxzyHPCVhPQggHc1v7Va4ZZ9v9d9uxQLoo7TMw7we9LRxdEweTEh4/r6PdOt37Tzr3urBDFKXOAKBAwGLaTHArsBUcAAAKAhDdftCsWinxf5+Lqhu2kQfHXHbGDK24alC5RMjdy92AB9WBJFLTxnSn6bj6GuGxKUj0hLncZ1WCLWHp1opu/z+fYq0zQz6e22JTuc+ClaDNbukzp4cPSiI1+TxbzKM4OXwwJggCnXwJeHurOt1kL5Ga2X7sTgIEI2bezURuAAB7bD96xlY7rrcNAAAFgehRdBHEhAc70L/PdKY2prVx8/8ec3sbalK1JN3YsqpBW/VAUq4LGxdFJhj+HIEkQ/t1udqqqhdfayYs/BUXsvVa7r63ZJixVTwYZUuCmb3c42KJJyvk5HSBij43E6nxvrj+slFMtx6HUtNozb4UCheBxvkHOhGgrrluvt7sbC7bddJwnZV7uY3dB/SdtH18AEDAHE5No3GLdlu2a1OrNFzLAQAFhgIjukePHk2NGzemtm3bBv1YXC+yepmipm0aVSmhslxPHnw5jejfSpS+0KK1tMmxydE0GOTBt7YUUyA4tXT7q/flOG2thdYskVogYnLhtmPUfcQ84WLnqtg0uV2U3ZlaC126fPJ94Jbo45rrh1LSbG/30PfLqffHC1R94SzlXH/54znbpP2b+0fP2XyUTkv137t+MJf+WG2doC8UXgO2CLJng7x7H0u3dD8O+GIxHT+TrrsPuw49Vh8lxs/10fScBSCa+WfDYfHbxxOZVuFzL1zTOGT9AgCAYFNgEqkNGjRIvFJTU6lUKa/7dyjRDgZZlE999HIqXVSdUTspPtZSXJUpmp9F90yaH3G5YYLLfvVrW8O1/Z3PtK+i9QSyXWQhrU6k5ms9dxqzbtT61i+8CeJu/3IJrXutm+qYsoXVaV1SO9IhFO7lciI1tyzdrV6fYfv8s8VzytpD4u91+/Ot1GfSveJ54or9+f1z2J8th8/Q4B9X0vUt9D1X9PtDrpUMO3k2g27/anFAdbqdfFc8AST/05boOpyarps13a7otbqXzHaz69hZ+kXjTZN/fFuHBwAEMIk+dMpG+ibXwt24Skn66NZWlHo+U8Rt/75qP83dkp8H48GOdWHlBgAUKAqM6I5E9AST3qBQO45kS7pCqmRh69G0Mk1d5xUSkQhnxw4k5lnmn41HqG3tMrbbe2sp24jptnCFlhOpeePEjdu6IV4VEai3T44B3zXsGkf7C4bLe7gt3cr2/ibps9rOjRr1gdaPduJe/snc7bRuf6rt7XUznjv4yJbnx0FIhJGXhd371mr/Znu5/9tlhusQ0w1A8Nh6+DQ98uNK2nTotHjPlQKe7t6AkuK9oXScnbz3RdXzyodxHDcylgMAChoQ3SFGz6JjZnWSM1BbJWSLBNwsFcUlr5xZuv07jhyHror1FTHd6p3O2HAoqEmdAk0axv3njOssIrRiSemv3UNsO2Iv0Y0e8uSL9jM5Fbl+ZeyWtrEKeQiF5T+QWHnt+TqfoQ67sOq+3vl2y9LN+z4oufxrvxPax53RYe3eE5bu5Sbifdcx47KIcC8HwH34e/3Dkj30+p8bRHWS8sUT6b2bW1CnBhV127PQhtgGABRUILpDjN6Q0GwAXFZyNY+LAh9IreXWCresjF6rtMdl0e0r5FfsOZX3tz/zC+waXKZY/jXVXlKPTt8S4pylXvhzzQG6oWU1w/V2JwuuGj6X/EXrpq/w0cytedaOYN4j8nWzmggKheYOBJV7uR8zS3pb+FunW7sZx8iPXZhfC97FObc85PAA7gvH9rM3kGIls4v2vpfvqyh4tAIQVZw6l0HPTlhLf6/3TlRffmF5er9vC6pYIjncXQMAgLBQYBKphRvbukDX0p3/9xd3tBH/fz2wLfVqVY0e7HRBVInurYedWUddszIGYOlWCzS1W7SZ4PPncK3+b4ZK5GuvqfZwXO/ZKfO3HhPxcafOZYbeoqvnpi8d9/0ZWwy3MRKU/lxXeZPtR83rvMr946Rpo2dvc9/lPIDdyV1Zd8A3izpnY+/zyUKavUm/DrzeZJQT8W42SSMLbr222ieWsaU7P7/Coz+tpO8X52c2vvajf/P+/mrBTmr26nS65K2Zuvtx8oSUT4HZs9XN5JAAFETYLXziin15iUH/23GceoycLwR3QlwMvdCzEX0z8GIIbgBAoQaW7hCjN7aTB/gVS3qTDHVuUFG8lu8+kbfOKtNnJODUJdmtGsxcyuv//toQ8H5kMSJKhpkMuP0VZnImbK07rHafk1bupw/6tXRcek1bfk19DAo68uSFXct6708W0m+DLvVZ7pd1V/qQL/22zvY9uPnwaXp32mZqWs06GePC7flJf6xItZEQkfeXGBfrU4pQ7t+09YfpmmZVVOu9kwpnaeBYgxwAAcZ0O4rZ1qzXNtdLTqgsZ/5ac5B+X3VAvAa0q2V4nJOaCSUFJykNZA8IM7d0niSLi3VmVQegsDBs6kb6dO6OvPcNKhenLYfOiO9+lVLJomRqs+qhT24LAACRBizdLvFAxwvykp05dy83aS8NBqPB0p2eZb/MVyDJsUIjFs2vjb/iNU66phlZOSoLZTDPhrJvT6gTqdl0OV61N991X8afW8SJdVKv5aGU85bbjVtoXWdWwcql/mx6liipddOni2izpq22f7tPmFvu7bmXe5cu2HaMth+1P1HmNI+BTzy/wbVRmtmZnDAnxvakmNwPs0drpD2jAIgU2LItC25mc67gZjjfw+S1oSuvCAAAkQxEt0t0b1qZFjzbhUbdepFpOz2Lijww1WY5lt/ZtXS/cWNTChdOXTFlV+tQ4LEYkFslUlPvy7/BuHafbKE0WucmLPCH/LzKwmXeI2JoJ600tpTbQc7yHuhn4v5aCSjtemcxy/71T4lVdAMW3Uo3lkneLXrnLzMr8ER0vGzDgVQh9K983zx235FR3GP1nr9Txsfw51LI31n58Wp1D8hiWp4I82kX4mcUANHChzO3WrZhUa64nQMAQGEGottFqpUuYmmN1lttNjiUs+rGxeZfrqKJxu6OLWuUpisb6mcHDTZOjUKyOAsFPOhnUck1xa0G8B/M2EJvTN5osi//+mAq5IN8Org+NWeRNYJrW3MM7ePjV7sW062cUn/cxJXtrSZztKsDjckOpMSXP2RKHyBTe3089ieq9KzWeqeCF63XiQ/XO28eJ+7lms7qWbr17n9/r9eR1DS66P9m0Kt/rBfv5avmmzVfvW229Owxdy+HpRsALSykZ28+auvEcBkwAAAo7EB0hxi9wbyZGJHHgnYt3bxNuIaJTq2aobYicfdYVH4+f6fu+myp/7uOnzPfl599kI+h179g46/4dYK6nrnHtpvusKmbfJb9vGwvDf5ppel2WlHu5D7UbetiiS877cfM3W4o8jw6+QuM0LNae4y8BzTL9p44R+3emkmfzNmu2d6Bq75FTLe3IoCO6LZ9BHlfHvp8/g5RVlFJ6CY/LxfvUHsM+Os2jkRqAPgyf6s9wc1w3W0AACjsQHSHmOd6NvRZ1v6CcoYDXLWlW45XND4Gb+N69mWbnNPUEHZi4QsFVmJsh0Wmayf7MsJss2C6l4cyRlUV0+2x/9k+lcSnwh+rDwgLvBnafftbEkshEDu3U5E2Y8Nh+mbRbkNRrf1sHCYQ6CQL3wNzNVaqt//eREdOp4v/jS3dFm7+FgtEckI9y3vufp0kQuP9mJ3qNyZvcHCdPBETAgNAJMPPky/m76APZ26z1f7BjnVRexsAAJC9PPS0qllG9f7laxtT37Y1fErv6BEfJ4luk0FiOC3dTvFxpQ0ybopaf3flVJQ940fZMDeP71ad7mCK/UAs3bqi24n60+D0c2pLmmlFnrZ/ZpZuo5ACLb8u20eT1x5ULcsycKN2FtNtfh34OpklUnOCNxO6sSdRqSIJptvL59nskiGRGgBejp5Opyd/WU1zt3gn7GqXK6ryCGOB3bVJZZqz2ZsctFODihDcAACQC0qGhREe1999WR1TESSP/e1mL5et45FOyBOpuaj7PH4ez0wQ6q0bv2wvRds5V8d0e4Iu9tll/8/VB/y6zkZZ0/3ui4PPyYNYZYBqKLo12zi1dH/wj29t9GkbfD0H7ExUWLXQcydXHSNHPymeP3cG9zdNUy1BSnshcmzYrlTgsXcvA1BYYaH9xM+r6NiZDEqKj6WXrm1MA9rVFM9PjtlmF3LFqKA1LgAAAIDoDiuKNDbT0rKAjrftXh6a2GA3ePVPbwKk6LR0G+/r73WHaNTsrSLe1KcPJmP4UFy3UFu6lc8UzOP+smyfqk67k2N9+59v6a9Apq2cWEa7vD9HVbddL6Y7UPdyu3hs3OfjFu2mS+uVF4Pu/afOO47pzjKxdK/dl0K7LfIoqPaV7aEfFu9RLeM65wpVSieb90Vl6Q5vngUAIrkM6Lt/b6Yv/vXmQWlQqQR9dGsrql+pRJ7AhsgGAABrYOmOAGRXVp+SYSpLd/6A0nwcGBM17uULth0P6fHc1H1mg/EHvlvuXyI1ooIR061TMownIoKFLLjlY4YDJ4JfK7h1RbXH/eunm9HcYLfa5f/7drnf7uWjZm2jUbe28tnuwKnz9PykteSEk+cyfI/vIOu47KZv7n3iqFsAFBh2HD0jkliu258q3t/RvhY937MRJScYV08BAACgDxKphRE7caNGlm7tQHxwl3rSNoGXTCqouGlt9fccO3Uvd5usELjLqmO6vf87FVWBEOhp9ITx/FolUnMD/V3qH+duqY685X4tjrNk1wlaqePOv/XIadvHMD2+x75HgFaUs0VPj3BO4EQqb775JnXo0IGKFi1KpUuXtv28fPXVV6lq1apUpEgR6tSpE61fH1pPJ2Bc/mviin159bT5WnHVCK70wYK7TNEE+vyONvT6DU0huAEAwE9g6Q4jMQ7bqLKXa4a3yVLdbrOY7seuupAqlEiiFyato8KIm5MR/u4pVcflPG+fIRjfGyXMcvUYkvA8cTadxi9VuwEHm0CFUiDbBzqxw8kF+T7l3fB3PlSazyir+NYjvrW/jfBxL9fp/Bkd674/n9Go/rjd3AVa9/Ixc3fotoPo9iUjI4Nuvvlmat++PX355Ze2rtc777xDw4cPp7Fjx1L9+vXpjTfeoKuvvpo2b95MJUp4XZVB6Bk2dSN9Kt371zSrLAwCf63xJlpsX7ccfdCvJVUupQ7XAAAA4AxYusOInjauXb6oX3W6k+Lj1NnLDQax7BbW56Lqtvtotza4XZ64uj6FEzddRf1NwNXr44WG60LhoRAK93L5GG9N2UTPTAidldsVoeQJ36QGi8X+Y/6jbiPmCWHopE62XXSTmeksO52eFdB+PTY9AfxNpGZ2fCvRLYeAcJfmGdQdhqHbl9dee40ef/xxatasma1rxddlxIgR9MILL1Dv3r2padOm9M0339C5c+fohx9+sLUP4D48GSoLbmby2kNCcPOE31PdGtB397aD4AYAABeA6A4jcvz22le70vIXr6ISyQmGLuhmdboT42NVlm5OdKRHXEyMo1q4djOm2yXcidXdtFr9vio/W3agnE7LpKW7ToQkflS28AXvGOF1yQ30PIbT0p2elUOLd56gbUfO0JbDZ4JyT+jtUu84p85mBrRfvdOYoXNv+DPZpDd55CSmm7MwKxxKTaM9J86FLfFgQWfnzp106NAh6tq1a96ypKQk6tixIy1caDwJCYJr4TabDH2rV1Ma1Lme62MAAAAorMC9PELQim2FGMM63Wpkkc3CtkZZtcVcITaWpb79H1HOBswiwC0CqX/sBpE6fr7l8/9E7Fy/NjUKRiK1MJ/oQD0GAtn6w5lbAzp2WmZ+bPGcLUeCYmm1cs02S1bmZL96kxfsPm+nP37dY3JMt4PJpXenbTZcB/fywGHBzVSqVEm1nN/v3u1bPUAhPT1dvBRSU70JvUBgcOy21sKtJUGqBAAAACBw8FQNJzb0pxyfrcpe7vGoSo2pRXdMXjkP3/2ZlyjTkmBgMfeXcNcQj9QEc0p2WLdrcusxZp75YKtgiO7wbT9x5f6Ajn1eEt3v/L2Z/t2m7/YcCFqXdf5e+LiGezz0oEkWflv71Wmj5/ZtlNH/fIZ+cjMjb4oTZzMMxb3/iQ+pUMBJzvi3w+y1bNkyVydd+ZqYTcQOHTqUSpUqlfeqUSP4k5KFAa6rbQXX3QYAAOAesHRHeiI1g5huHgf+eN8l9MiPK+mNG5uqBpTcrE/rarrZotlVzInwhXu5NVyLu1QRfU+FSORgSlqByJBuRqDWyWDEUdvlfKb63KVp3gcDPl3aU8YJ1A44vVdsJFLT87TQE9DvT9+sW+deYe1+dU6Fw6lptGjHcdsx3dE+Uec2Dz/8MPXv39+0Te3atf3ad+XKlfMs3lWqVMlbfuTIER/rt8xzzz1HQ4YMUVm6IbwDp6pFUrTeraqi9jYAALgMRHeEE2sS031J3XK05PkrhaVg9qYjqm04sdrjV9WnD/7Zotqf12Jh//gJLsdzhTs8zG2r1YwNh+m+cctEybYhXRu4u/MoJvpjuilspJlYd52y2iDZn54buHaiwarklu5+LY5jtF+9ZR/N2mZ6LG086tzNao8Aq5huuxQWS3f58uXFKxjUqVNHCO8ZM2ZQq1at8jKgz507l95++23D7Tjum1/APTYdSqWXfl9vKriH9/NeIwAAAO4B9/IwUrqoM+uobOkuXzxR/K+45qncy6VSTfqJ1GKC7l5ev1JxMUnQqqa6hquTePJg4HZ8puJN8KGFQAgGTrLQh5pQxI2bkRPo8cNo3ZTdywPl9i8X6y7Xfjo+XdqP7E8kiE/JMB2PAT0viHQXrNLa77aTmG4n+wVEe/bsoVWrVon/s7Ozxd/8OnMmv7xcw4YNadKkSeJv/s157LHH6K233hLL1q1bR3fddZeo833rrbfilIYA9tj4ZuEuun7UAuHFwqVDX7muMfVrU50url1G/D/poQ4Q3AAAECRg6Q4DYwe2FbGa79zU3LKtPPDlJGg/3X8JDZu6SbiUG2UvV0S1nJ1XwSg3ysj+Lalq6SL06ZztNFOymmtLht3ZvhZNWrmfUnVq7cr8PugyEac56PsVhp8nHLg9fpYtdOze+sgPK2nAJTUpFLx4TSOasGIfRSJhF91hTKRmhw5DZ9IL1zTWXeePhdkIo++prqVbK7r9mCDTnne9KAM9C7SRRd4J2mRobrmXQ3T78vLLL4uSXwqK9Xr27NnUqVMn8TfX305JSclr8/TTT9P58+fpoYceopMnT1K7du1o+vTpqNEdAjjXwdO/rqZ/Nnp/2zs3qEDv3dyCyhWHFwEAAIQKiO4w0KlBRfFy6l7OAviiuuXot0GX+rRTi27v/8fO+Fq6jazc7I7etnZZ+jx2h2kG0/YXlKNb2tWk7iPmm/a7SGKcbkx4uLOXu53gKz0r3yr59tRNtGTXCfEKBXI2+0gjO+wx3QFuH+RJA46VHvSDekLKbQutORpx7PH4iEspb6Ofe7WfSM0NjktJ1NwMcYCh25exY8eKl/l58/g8+zlZG79A6Fi47Rg9/vMqOpyaLqqRPNujIQ28tHbYf4sBAKCwAffyCEf+XTRLaqat0820q1PWp12RhDjT42h/h/WEnZNEbNq24Y/pdj4Q79G0su5EhzbJVWqas5rGgRLJ9VPDH9PtiVpLvV5JLbfResEI93IX9suJz17+fZ0oSWSYSC1E94bWY8Dfo8LSDaIRntx6++9NNODLxUJwX1ChGE0a1IHuvqwOBDcAAISBAmPpHj16tHhxfFlBQm3pNp4jkdcpWuyhzvWoYslk6tywIm09fFpk9uW/naBXq9OJ1tNuHv6SYc63iY+LpZY1SguRa2YpN7s+hU10h7tkWKC3WTj7H2h884Jtx+itKRtpWG/r8BW1e7kn4HPw5uQNYoA/btFu2jXsGt3vW7As3XbLkDmlsCRSA9HH+KV7RGhGixqlqV/b/LCm3cfP0uCfVuWFbdxycQ166drGVDSxwAz5AAAg6igwT+BBgwaJF5cU4XqeBQVZO5hauiV1q8RiJifE0W2X1BJ/VytdxJZLuzaOs0SyNtlbYCXHwl1+xx+rlZLBnZPQZZvYy0Lt7s39iVTCHdMdqGh2S7D5Q6Ax3QO+8CZPu/PrJba38eToxHn70Q0W3Kr96nxfQuM+rw4ROJOe5bebOCzdINJgT5JHf1pJe06cF+9/WLKXvpi/g2YM6US/rdxPL/62TtzzJZPjaVif5tSzWX6ZNgAAAOGhwIjuAotBnW4z9/JADqPVcck6+3UiurVxY+EWY/4cX5k4sPrYZtcnGMDSbUyg91mwY7pDlTzJLt6SYfmwhezx8asC7oO+pTs053bHsbPU77NFNKJ/S2o/dJbf+wn3RCEAMsOmbqRP56pzrzBbj5yldm/+Q4dPp+fV4n71+ibUtYm3RjoAAIDwgpjuKK3TrUUuGeaPlc4oqYqvwPY4s3RHmOj2B8WCbSVy2Q09lERyIpxQuRAbEahOisb7NBC0idRuGL1AiNbA9+u7LCuE98binSfo+Ynqet5OCXNOQABUFm49wa2gCG4lWeP93y4XIh0AAED4geiOcGRZxSXDjChTLJH6tqkuajeXLZbo93G0Ok4vTFnbpmhupnI9tELVnwF329plKJwon8FqsiEhgrOJF7aY7sLef6fo1el2Az338lBPyBzVqeLgBLiXg0hhpx8TYSzSlcSGAAAAwgdEdzRZui1E3zs3taD3+7YI6HjamG6tNZXremrF//j72xvvL8Z/19LSRRPov+eupG/vaUfhREmQZuU9fj6jYCXxC4TMKBethc3SzS7UwfjEOWF0L887XlaAoQaF61YAEUyd8sVCJtYBAAC4C0R3FBGOZNVa626bWmV8+mE2F6CdKHBiQVz+4tVUuVQyucE1DhPJVC9TxNfSbXEBflt1wM/eFTzCXac7UAqjpTs4pm7ffc7dcpRCSaCJ2x74bjnN3xraPgOgR6uaZeiBjnVDJtYBAAC4B0R3hCO7NlqJvkAwEs58yB/ubUfXtahKy168Sli+9dysH+h4gS338kwLMdawcgl696bmNP/pzrYTmDElksxzAg7r04z8RUmQFsnZwiONcNfpDpTsQhnT7e4+P5+3IyKsxG5Y+cKdowAAJi0zm9Iynd2LD3asK8Q6AACA8ILs5RGOnBQtJDWutTHdMTHUoV558cprotOmR9PK9Onc7b670yZSsxBjb/VuRhdpBghal3c9rMb2Ts+d3Dxf/EN02+VwahpFM1/+u5MKE97s5e4q5DenbAx7Pga3KJ6kLZ0IQGjZduQ0PfzDStp06LR4X754Ih0741uhoH7FYtQj17OLy4RCcAMAQGQA0R3hFJcsuGYJywLFSE/G2BCw/NaoRvWFFYs7siAmx/t+RvlwV9SvQPN03FPNyvrcfWmdgCYs8izd8AuxzclzmX6fbxB6+OtzNt39nAQbDqRSQaBEMn4qQXjg37aflu6l1/5cL6zc5Yol0ns3t6DODSvS+KV7aObGw3TibCaVLZZAVzaqRP3a1sSlAgCACAQjiQinaGI8/TboUuHmnZwQRNGdK6+10lTPuqsV/9zEyPX69va16PW/Nth200xKMK8LfnPr6rqi24yXrm1E6VnOXPJk63pcXiI1WLpBwYQTxwUj2dK5zIKRXBCiG4SDlHOZ9OzENTR13SHx/vILy9P7N7egiiW9uU5YYENkAwBAdADbXRTQskZpal69dEiOpRXZckIxeSLg64Ft896zhcxIkCbExVLPZpVtW7oTdczJqrJpBsfxWHwmqxrbZhhZ8d2ma+NKlm16X1QtJH0B7qN3b0cKO4+dCcp+g5GbLRyUgHs5CDFLdp6gHiPnCcHN5Sif79mQvhl4cZ7gBgAAEF1E7igQhJQiOq7rt1xcwzBBWucGFalIruW9bvlippnVh/VpblguiAcTn9/RRnqvI7qlfRsdx2pwH4iVWhHsgSTXshMa0MYi/rVptZJ+H78wUK10EWpVMzSTU/6gV/Ne5s1eTSlc3D12WdiOHQ0Uh3s5CBFZ2Tk0fMYW6j9mER1ISaPa5YrShAc70P1XXBDUZKoAAACCC9zLCzlcC/vKhpWoXZ2y4r38kz60d75Y1mPxC1fS2fQsKlMskU6c803oolAyOcGwlNTMIZ2odLEEU/EvW9/1tLN2HMIW4+kbDpu2sUI+TnyAopvF1E2tq1ODF//2a2KgZtmiYh/s7fDaH+splHRvUpn+Xu91bYwGF+AhV9en279cEtTj1CpXlHYfP+d4O6uEgBVLwIIVqQTiKQOAESv3nBRhHRx2xRPOxZLi6PN5O2nZ7pNifZ+LqtNrNzRR5XYBAAAQneBJXsh5sOMF9D/Jmu3EIMxiWhHUdi3JHDsql/mqWa6o+PuZ7g3FsUsVSXDk/j7w0trUt00N6vXxgrxlY+5oQ7WfnWy6nRVNq5XKE1aK6Jb77gTePkknQZwWoz6ye/vlF1agSLTORloG7gsqqBP3BQN/vSasdFtivPnJrlwymQ5FeVZ4AICXYVM30qdzd+iejqT4WHrnpuZ0Q0uEEwEAQEEhiobUIBi4lRysaul8K12yTjI0tkCWKZpAT3ZtIG2THy/+YKcLDF3Zzfr7ynVNqFGVksIa7JSHOukf79J65Whgh9p57+NyXd5zwlR0WE5SF+oeBCN5nJW49BcOMahSKjno8dgxQTiXnRtUoPqVzCcMhgZQax4AEFkWbiPBzXDiz68XFK6yhQAAUNCB6C7kaHWAv4KCLbkbXu8mEqz9+0wXn/WDr7yQlr94NdUuXyx/Gx1x7q+18LPb29BVjSrRpIc62N6XYsHWnocHO9ZTWaaVdmxJDQTunxkxBp9Pdm01K40WLaJ7/tOd8/7+fdClru3Xk+stcMvF7pfM4dwDCv6eErPtvh54saULMwv/G1pW9e/gAICIwU6lgFV7U0RJMAAAAAUDiO5CTpva3lhuf92wtVnNOcFa+eJJuuuVJDAj+7cUyde41qhTjLpXp3wx+uLONtSqpnkyMr3+aOuD82L5OIqV0+jcNK9eyrzPuVMZowe0Mm8n6p3rJZJzz9J9bfMq4lzZxS3NLVu35RCCkhbhBE5QJkWualSR3EYWxP5+R4ySICmLjcru5R3XoE2xxDj6/t52fvUJABB6MrLsldJbvfdU0PsCAAAgNEB0F1IWPNuFxt9/iShHJjOos9fl+rZL3LcWKnCc2qwnO1H9SiVcT0blBFnAyFZ3FlWyhTchVzDqHZnrpk566FJbQs+qZFSMQRs3K02xeHSSE8pKCNrFaC9u5qdSnACCkfRKzqpvtnuzYxt5DSjbWPY7Rl+4r3+9O11ar7z5tsAwKR4AoeTYmXQau3C3rbYtNL/PAAAAoheI7kJcXqld3XI+y+tVLEGb3+hOb9wYmfGjbno7x0kuw5y4RiVMpW9GotIuxrgGuNkEgiKm7FhI9WqCy2It0I/P+wpHJmZ12bcY3cz2bqFXdi5Q5OtiNvEzZfDlhuuMTrtyPqzuD24nh0RYwSX/IoUKJZJEpYRIo1gicomC0DFvy1HqPmI+bTp02rJtqxqlqF/b4E1+AwAACC0Q3cAHO5m2w0UgMcZ/PXKZmGzQs+Im59Yc9x5DfRxFxOkdWdFARm7S7Hp+TfMqtvrHoktPMMp9eaJrAypXLJEev6q+aTI4c0u3/XOYka0u8eYvslBlV/OxA9uK+uxcbs4tFC+BYEwqxEuzMGanz0zvG4lq5Xpo+33PZXXU25u4qOuhqc6nizzZFEw4n4GcRDFSSMu05+YLQCBkZOXQW1M20h1fLRGWbk6aeHPr6rptq5RMorf7NKNJgy7DSQcAgAIEpvlBVMEChXWHP4nEuQzYiP4t6eZPF/mIHFl8eN3LyVd064gmRTDpxbHPfrKT4/hpPffyA6fO5/1do2xRWvbiVXl9ebp7Q9pz4hz9teagrWPwZ3EiSnmwKFOpZBIdTk0np2hPXacGzuOu77+iLo2ZZ5zxNyE+xifpmVu8fkMTuuebZZYW6TiTGmtGpz3PvVza7ws9G9GR0+ryYCy4nbj720n8xxMgnCk52HC3B7SrSS/+to4iiSDkCQTAJ2na4B9X0tr9KXmhWy9e01hM9N7aribN2XyEDqWkUeVSyeK56CQvCQAAgOgBohtEFd4kZzH5AbwWaN1xtW7kRpZuWVjli27f/SuLyhXPt9i+06c5dW9W2bHrdIyBe/mR02qRqxV9ThJ78UdxIrq1tcn/GdKRmr06nZzihrbhuu52rNGBJAPUwpMgy1+6ikpI11J7+i6sWJy2HjmT2wfnMd3KJqrkffGxPlZtkUjNwbUzOg1sdf5n4+G874O1o2vgaL9TCjxZxZY/5qVrG9P//bWBQonswQCAm3CliV+X76NX/lhP5zKyRXjF232aU7cmlfPasMCGyAYAgMIBRhwgqriwUgl688am4u9Hr7zQsn3RRLWrfDnJIi0LmIolklXLZYtiYq4FVU/DKM3KF0tSWVz9iVVOSojTFW1WNcidSEz+XE7cyzMl9/KFz3ZRiU8nuCGErUrMJZrUU5/wYHvV+/Y6+Qz08JDH5zNrP8rYuy8OKJGaMuEjb8t/aq3a/NbJtTO6b2RnCqv4dyWxYqAYxcGXLZZ/bu/qUJtCjRN3fQDskpqWSYN/WkVP/bpGCO5L6palqY9erhLcAAAAChcQ3SAqWPrCVTTnyU4iIVP/i2vS8hevosev9sY168Huuczwvi1Vyzmm+/9uaELD+7ZQyYBWNUtrXNj1LN2+A3RlWbUy+bHi5zOcu+uyG/r1LarSU90a5mVFV/j5f2rB6NsH+8fRus5bkZWdL2Cr5sbDs0uk3L9Akc99INnfFffyTKnPCq1rqUvjvdW7mSi1ZYWeQ4VW+CZIJ9RMdBtdpxLJXgu+LLJZDGZrJg+8SfvINnd0qC2ErPa48jXVelZULKEOkxjQrha5gdFnl8+vHSv+6le60oqXria30JugASAQVuw5ST1Hzqc/Vx8Q9/RT3RrQ9/deQlVK5f9GAAAAKHzAvRxEBSy2+aVnsdbjvivq0oBLaora4Vpub++1qH2zcJeu8GOBIIsEO4nUyhZLpMFd6tH3i/f4JUj/fOQyYfHs3rSymGAoXzyRBv2wQljgOdbPjBiXspd3alCB5mw+mveeY6Nval2dFu04rmr3Vi9vZvvaz04W/7N1ftYTneiKd2cbHlcrIGU4oVqbN/6x5QlgR5SbHUuBz4CdWGa9uGgz936zCRAjK3XxXEu6NsP74dS0gBKpFUuMp1evb0K7j5+l2dJ1zZTOT1qm+hzwcX+4tx3d+sViurh2Wapice/ZxeizO5W8XOOdrYhucR6J1ICfrNxzUsRrK3k7Zm06TMt2n6TFO06InCPVyxShkf1bUetaiNEGAAAA0Q0KMHqCW+a0NHiXS36xJVAWN2YuuLKYGNK1gbC+O3Gl/v7edkIkFpfilZXJhY8HtLa1D6cx3XXLF6elu06qlnO8YfNqpVSimxPBVS6ZTAu3H6e2tY0Hjhx/XLNcUVrzalcqmhBH9V6Y6iipl5yErl2dslS7XDEav2yvrUzb61/rRk1emaa6TnUrWCevy/Z4qFhSPKWcz8xzN9dOLnj77butVvfajbM2ukwlcy3d8nXkXWoFIa+Xww84vKKlSR1fpV8d61dQie4sKWRAO0HB16lDvfK0a9g1FKq4V6e4VTv+uR4N6fP5O13ZFyhcDJu6kT6da5zUsV7FYjTxoUuDUhIRAABAdAL3clBoUQQXw2W4FE6dz1QJK8WCKo/1b2hZVfz/v44XBBS7fGm98nRF/QoUKngy4fmejahfmxo0/v5LVAmltJMLvCw+Lpbe79tCuPQboWzHA0xub5Q5nkm2iMvm+Gk9gc5ik8W9FhbOef3IXc9u8H8+fJlpOTWeWOGyZbxPLunGSbzs0rBySdV7leb2OLf2Ku7l2vvodFqWz3FkwcnZwDs3tM4Cf9sltejDW1rlvZc9J7Qls4LlbW3HvdwuVnHtPFFkBXuj8He3aml3LPmgcFm4zQQ3s+3IWdqem1wRAAAAYCC6QaHl1LlMTbysdzDfqEoJdUx3bqyw7Mg9ol9LYdk1szRa0aOpO0l12OVWb/JAD/5cpTiL7k3NqZ2UTIxFrSJanVpwtWL4q7va+LT56JZWdMvFNeiPh81rz5YsEq/rTs99kevHc4KvKYMvF3/3uchb7/ZBaQKkWfVSNPjKC0UCoye71tdNEMdZg7e80YNG33qR5WSAEk+8+PkrVcm/tBMtZhrS6HTKXg4KLK61btScjEz2wLA7wcMTIZwvQBalEx7sQNMfv0KVKI/JtlPc2w9Ons3QXW52vozccq0Sji96rotlIjieiGA+7J8/GQGAHbjEl5vtAAAAFA4Q0w0KLbKlm+EETWfSs0Qc9REpnlax5MrCjAVPIK6DLAaeuLoBuQG7GW86lEq9L6pObWuXFbHqY6V4dbu1orWZ022Lbo11u0vDSj5t2Po8tHdzw3080qUe/bhkDz3ZtYGYRDiYkibK7Shw32T3ck7wpSR2e+/m5vTq9Y19soxzjPxP95snobObxZvhfskTHAqy9jVzoze2dOvvU2vp1mYvd5p4+7GrLqRJK/fTPZfVycuJwN4Mmdn51u5AanZ/0K8FPT5+te46ri/v1L3c6FxaWbrlyYgLKhT3Wc8JGWvnxuHy/3JoAXsEcE1lAAAAAAA3gaUbFFq0mZtZUHF2cyXmVyvIRt16kYi35szngdK9SRXXyhWVKZYoxGXfNjVEUh9OnjXvqc7C4vz1/7d3J/AxnesfwB9CIghBiJBIRCVBiBBLULvYS6kbagvlX6619q22Nl1Ve7tZevu3XJS2lquopYjlotYogmiFqBtSqRCiCXHu53mZcWbmzGRmMiNnZn7fz+fIzJkzY857zplznvO+7/PGNaJB0YH59oflAPulp03m81tWQ1PDzMFcQU2MCRUJ5DiQ5ibjC/pEUISsFQHX1sqDrVKy/vocZJkzlFktv2fNwmvLHjP5tvhuRLRFAbr8e5lqLm2sOJWG9uLP5O2pP2Z6ERM3Rfo20l1e3/j2IbRvchudJIT6rRT0m5vrk3dJ0Kd/E6px9fJ0cGobkWCQM95bWtNtdF81o4Z/drfa1LGOL3WX1fBraAJupd+B/IbnA9fGN4nMTb7XOjT/rh8AAOA6UNMNLmt651r0++0HouZPn86wSk+DG25KfnRGuwKNOc3B8O+Z2aL5sz1xYjOeGPf7XXn4qnhsLNDnwINr+Dl5WpsFCWJekXxuyX34Sj0RcBurxbSUqXLlDOfZuc9qfj3NGO5LaaxuzjbMAbf+/yUP5GpWKi2SsV3+4z41q2E4nveQZtXpk58uicdv9QzXqXHm2lnuT/7bH/do/LpEs2polWpjeTu93jKY6lQpQ3HLjol5vP7yj9Bfh/d616Pb2bm049xNMpf+DYT8+nQHK3xXpfee4aR67sXEjQFOMGj8Pbr/Ifetf2tLkrZ5Oa+iJukfB+/MnMNvaIvqYtLHGfn1yW9eKPWvB9B0kZiy/hfalZT/8TWyVbDovgIAAKCBKwxwWRwsGutjLL/4ltcGFiTg1g+GC4OxwE9zY0HefLp4Pp1nOTA0J+CW17Rbi2tNd59/drGrlFQtPxwE1qmifLNDvqocPK56rQl9e/yatu+vHPeJ5+zeOY/yRD9zrv3i4JxrwKqU9ST/ciXphUql8y37qMBydD3zAUUEGH6nEsWeJLGT15Y9yM0zyHCuT6+Ldr6UMsKbYupmhzyANqflgVLLAL4BJg+6p3UOo+rTt4nnmqRxBTkG5XkBNOTdKhB0myc+Pp62bt1KiYmJ5O7uTpmZmfm+Jy4ujlasWKEzr0mTJnTkyBFSu0O/3aI31iXSzbs5ojvN1M5hVD+gLF3NyBZ5EfjmleYvtzZCwA0AAPoQdAMo8C7pLppnu7u5mdXfV+04W/mPZ9Oon14Wck2Nbvd6VbTjjU/tFCZqBK2pTdbXJrQize8RTrYQaMebFRVLe4hxylm5ksWpSBF30RzbnACOg0Ae+k3z2NhNAXmsOO+lOiKg53hPHkSObvMCnbl+h9oqZCXnbgS8fUz1ubd0CC5Lb17wzQBjuFbeEm/1qKOYBXrPxFaUlHaXOtT2NTtJXUHWl/u1ayjlaeBM56ArNzeX+vTpQ9HR0fT111+bXTydOnWiZcuWPdse7qYTPxY2DqQ/+SmZvkz4Tdwg4t9LTr6nGY2hYWD5wv6KAADgIBB0AxihlBDMUXG28viXww2G9Pr29Wj6+fKfFFPn2bqONDHUlqVsOQLVC5W8RDNzc4aEshQHd8uHNC7Q++U4IN48urm4aO+96LBBTXdJdzfFoHlSR8Om2Dy02W9/3KcG1crRXVnyP6VWC6YSuSnhxHWj1pw0ucyEDiG0cFeyqHU2NiQc4xr+7eNfJG/P/AOpCP+yNDA6SDHo5ibsSs3YrRleTF/dp8GSnJusybm85p+buvN26hLuV/D/2MnMmzdP/F2+fLlF7/Pw8KDKlW0zaoO9pWZk09i1pyjxWqY2Z8Ls7rxP4LIJAAAs5/hVeABgFqWAyae0hxin2l61+bYIlOS49tPe/eFtpZ6/t05NmLw/vXx88fxwE3NN3gF5c36loFs/SVh+eNtz7Z0pnFn+yPR2NEJvTHq5/2sZrB3DXGnIN/nQceFVy9A/ng7VZclNAm62K/8ca3CCPn3Na/go3jxxdysiWoZwdwKwjYSEBKpUqRKFhITQ8OHDKT1dncNq/TvxOnX59IAIuLnLAQ8ryDkTEHADAIC1cMsWAOymIDH3+HY1acjyY9SrQVVyZHHNgsQQblM6hlL/f/4s5nENqjWCfUqJTODcr1SpqTTXSnPt+ksR5pfZ1jEv0ltbk2jNz6k0o0uYwesciBoLpEN8S9PqYU1FVn9zcDZxeUZxc2JuHhs9OzdPp2k9f8YY2dBe7cIq0e4LpgM43o+UvmdsowCxPfTHBa+h0C8frNe5c2fRJD0wMJBSUlLozTffpLZt29KJEydEDbiSnJwcMWncvXvXrpuAh4yc8+9ztP7kk+EKeZ/4R9/6ohUHAABAQSDoBgC7Cbewn68cJ846Pqs9VZAFW46Ih3Cb3DFUp+myJTXd+gHwOy/XNfo6JzB7u6fx15Vw333+TO7LrzQOuTHta/nSPwdHUUFwV4Y5m89Rt3rGm3D7mtGdwJzcaq1CnvTZ18fN/HtGPrtJsWN8S0q+mUXNZDXgrmDu3LnaZuPGHDt2jKKirNvmsbGx2sfh4eHiczgA54RsvXr1UnzPu+++m+93KqhTqbcp4WI63bz7F+1LvkVpd/4SuRZGt60pMuab6lIBAABgLgTdAGBzP457UQytM/zFJ82OrcXN350BB9l5sjG1SqmwX6glATfLe2xhqnQjme0587u86bi5uNlv1l9PhpHzNFGeCZNa0+nfM+klhTG7lYRW9hKTqxk9ejT17dvX5DJBQUE2+//8/PxE0H3p0pPh95RMnz6dJkyYoFPTHRBgejx6c607lkqLEn6jKxnZOvNLe7jR/8c1FiMmAAAA2Ir6rvwAwOHV8isjJniGa8+8SxanzOyH+fajdgSP8hvU28ya+5q+1gW4QRVKiUzvbHrnMEq+kUWDmgUq9nO3tK+7K/Lx8RHT85KRkUHXrl0Twbcx3OzcWNPzguj5xUFKvPZk39F3LydPcTx3AACAgkC7KQCA54ADTE5IljS/I5UoXvDh2AqbvOa+MHzaL5Iiq3nTPwdFURVvT9rxRkvq36TgY8JD/lJTU8UY3fw3Ly9PPObp3r172mXCwsJo48aN4jHPnzRpEh0+fJiuXLkiEqp1795dBPkvv/zycy1yruE2FnBrpNy6/9y+DwAAuAbV1nRnZ2dTrVq1ROKVBQsWFPbXAQAoMGcItjWsaRJu6/9/49+bF+p3cFWzZ8+mFStWaJ9HRj7JJr93715q3bq1eHzx4kW6c+dJcOvm5kZnzpyhlStXUmZmpqjdbtOmDa1bt468vJ5vU/7TT4cAU/O+DQAAzke1QXd8fDw1adKksL8GAADIrB8ZTRtOXqcpHQ0znYNr4PG58xujW5Klpvf09KQdO3aQGkQEeNOao9eMvj6yVTBFVtPNZA8AAOCUQTcnVrlw4YJofnb27NnC/joAAPAUjz0uH38cwJHENqpG3xw1bGLeMNCbZnWtjYAbAADU0ad7//79IhiuUqWK6KO4adMmg2W+/PJLql69OpUoUYIaNmxIBw4csOj/4L5fPFQIAAAAgC1tGtWC3u9dl2JqV6LYKH/a+PdmtH5kcwTcAACgnpru+/fvU0REBA0ZMoR69+5t8Dr30Ro/frwIvJs3b05Lliyhzp07U1JSElWrVk0sw4F4Tk6OwXt37twpxgENCQkR06FDh6xdLwAAAACjNd48AQAAqDLo5gCaJ2MWLlxIr732Gg0bNkw8/+STT0RfrkWLFmlrr0+cOGH0/UeOHKG1a9fSd999JzKePnz4kMqUKSMStyjh4F0ewPM4ngAAAAAAAABON2RYbm6uCKhjYmJ05vNzc2utOTDnsTt5WBHOWj58+HCjAbdm+bJly2qngICAAq8HAAAAAAAAgOqC7lu3bokxO319fXXm8/MbN26QPUyfPl0MS6KZOGAHAAAAAAAAcNrs5ZxgTX/oEP155oiLi8t3GQ8PDzEBAAAAAAAAOHVNt4+PD7m5uRnUaqenpxvUfgMAAAAAAAA4O5sG3e7u7iIz+a5du3Tm8/NmzZrZ8r8CAAAAAAAAcL7m5ZxR/Ndff9U+T0lJocTERCpfvrwYEmzChAk0cOBAioqKoujoaFq6dCmlpqbSiBEjbP3dAQAAAAAAAJwr6D5+/Di1adNG+5yDbDZ48GBavnw5xcbGUkZGBs2fP5/S0tIoPDyctm3bRoGBgbb95gAAAAAAAAAqV0TiLGdO4IsvvhATZ09PTk4Wmcx5fG8AAAA1uHv3rhjaEucnlB8AALjWud1pgm4NXmFvb28xdBiCbgAAUNOJOSAggDIzM8UJGiyD8zsAADjqud0uQ4YVpqysLPGXVx4AAECN5ykE3daVG8P5HQAAHO3c7nQ13Y8fP6b//ve/5OXlZdXY4Ep3LlBrjnKzN+xrKLPnAftZ4ZYZn275pFylShUqWtSmg4e4BFue301xtePE1daXYZ2xnZ0R9usyhVLu5p7bna6mm1fW39/fpp/JJyFXORHZEsoNZYb9TJ1wbBZemaGGW13nd1Nc7ThxtfVlWGfX4Grb2dXWVw3rbM65HbfaAQAAAAAAAOwEQTcAAAAAAACAnSDoNsHDw4PmzJkj/oL5UG6WQ5mhzJ4H7GcoM8Bxgt8F1/wtxDo7P2xjdXO6RGoAAAAAAAAAaoGabgAAAAAAAAA7QdANAAAAAAAAYCcIugEAAAAAAADsBEG3CV9++SVVr16dSpQoQQ0bNqQDBw6QK3r33XepUaNG5OXlRZUqVaKePXvSxYsXdZbh1ABz584VA8N7enpS69at6dy5czrL5OTk0JgxY8jHx4dKlSpFL730Ev3+++/kKmVYpEgRGj9+vHYeyszQ9evXacCAAVShQgUqWbIk1a9fn06cOIEyM+LRo0c0a9Ys8TvFx11wcDDNnz+fHj9+jDJ7av/+/dS9e3fx28TH4KZNm3TK0FbH4e3bt2ngwIFirE6e+HFmZqYVvxbwvMXHx1OzZs3Eb463t7dZ74mLixP7k3xq2rQpOfM6m3OsqJk1x6ijbWdLr1v37dsnluPl+fyxePFiciSWrG9CQoLBtuTpwoUL5CznM2fbxvstXF+1b2ME3UasW7dOBEgzZ86kU6dO0YsvvkidO3em1NRUcjV8wI4aNYqOHDlCu3btEhf6MTExdP/+fe0yH3zwAS1cuJA+//xzOnbsGFWuXJk6dOhAWVlZ2mW4PDdu3Ehr166lgwcP0r1796hbt26Ul5dHzozLY+nSpVSvXj2d+Sgzwwui5s2bU/HixenHH3+kpKQk+uijj3QuCFFmut5//31xAuXj7vz586J8PvzwQ/rss89QZk/x71RERIQoIyW22qdeffVVSkxMpO3bt4uJH/NFPahfbm4u9enTh0aOHGnR+zp16kRpaWnaadu2beTM62zOsaJm1h6jjrKdLb1uTUlJoS5duojlePkZM2bQ2LFjaf369eTM1+lcaSTfnjVr1iRnOZ852za+b+H6qn4bc/ZyMNS4cWNpxIgROvPCwsKkadOmuXxxpaenc8Z7ad++faIsHj9+LFWuXFl67733tGXz119/SWXLlpUWL14snmdmZkrFixeX1q5dq13m+vXrUtGiRaXt27c7bZlmZWVJNWvWlHbt2iW1atVKGjdunJiPMjM0depUqUWLFkbLEmVmqGvXrtLQoUN15vXq1UsaMGAAykwB/25t3LjR5vtUUlKS+OwjR45olzl8+LCYd+HCBaP7NKjLsmXLxLY3x+DBg6UePXpIrrLO5hwrambtMepI29nS69YpU6aI1+Vef/11qWnTppIzru/evXvF9r59+7bkjOczZ9zGlq6v2rcxarqN3AHmJq1cmyvHzw8dOkSu7s6dO+Jv+fLltXfSbty4oVNePFZgq1attOXF5fnw4UOdZbi5SHh4uFOXKbcQ6Nq1K7Vv315nPsrM0ObNmykqKkrUvnA3hsjISPrqq69QZia0aNGCdu/eTcnJyeL56dOnRU0s39nGfpY/Wx2Hhw8fFs1VmzRpol2Gm6DyPGf+fXN13JSRf6tCQkJo+PDhlJ6eTq58rKhZQY5RR9jO1ly3cpnoL9+xY0c6fvy4+M1z1ut0vrbw8/Ojdu3a0d69e8mZOfI2Lgi1bmME3Qpu3bolmg36+vrqzOfnfNJxZXyzacKECeJiny86maZMTJUX/3V3d6dy5coZXcbZcFPUkydPiv7c+lBmhi5fvkyLFi0SzYB27NhBI0aMEM2gVq5ciTIzYurUqdSvXz8KCwsTzfL5RMPN7Xge9rP82eo45L98Ua6P5znr75ur42asq1evpj179ohuMNzcum3btqL/v6seK2pm7THqKNvZmutWnq+0PHch5M9TM2vWl4Mw7urHTas3bNhAoaGhIijjfsPOypG3sTXUvo2LFfYXUDPufK8fcOrPczWjR4+mX375RdSm2aK8nLVMr127RuPGjaOdO3eK5BXGoMye4eRfXNP9zjvviOccQHKSHg7EBw0ahDIz0qdt1apVtGbNGqpTp47oo8hBN9fEDh48GGVmJlsch0rLO+vvmyPghF/z5s0zuQwHUPybY43Y2FjtY74BzZ8TGBhIW7dupV69epEzrrMar4vMXWdrj1E1bmdbbh+l5ZXmq5Ul68sBGE8a0dHR4lptwYIF1LJlS3JWjr6NLaH2bYygWwFnqHVzczO4W8ZNivTvGLkSzt7LTYD5jpG/v792PidTYVxefJdJqbx4GW4OxMmy5DVGvAxnUHU23OyJ140zRmrwXVkuO04Iocn+jjJ7hved2rVr65RjrVq1tAk/sJ8Zmjx5Mk2bNo369u0rntetW5euXr0qWldw0I0yM81W5cPL3Lx50+Dz//jjD5c+ZxT2DWLNcWFMUFCQzf4/3n84GLt06RI54zqbc6yoeZ25ssAWx6gatrOtrlt5myotX6xYMTGCiCtcp3MXA75x7awceRvbipq2MZqXK+CmhBwscaZuOX7ujAFifviuGJ/YuKkGN7Hi4Rnk+Dkf2PLy4otUznquKS8uT27+Kl+GMwqePXvWKcuUm7OcOXNG1DxqJr5D3r9/f/GYh21AmenizOX6Q9FxX2W+wGHYzwxlZ2dT0aK6P+N8IaIZMgxlZpqtyofvpnOui6NHj2qX+fnnn8U8Z/x9cwR8Uc7dLkxNplohWSojI0PUqMgDUmdaZ3OOFTWvs62OUTVsZ1tdt3KZ6C/PrfP4WoV/81zhOp0zeqttW9qSI29jW1HVNi7sTG5qxZlqOWPt119/LbJejh8/XipVqpR05coVydWMHDlSZChNSEiQ0tLStFN2drZ2Gc5oysts2LBBOnPmjNSvXz/Jz89Punv3rnYZzjLp7+8v/fTTT9LJkyeltm3bShEREdKjR48kVyDPXs5QZrqOHj0qFStWTIqPj5cuXbokrV69WipZsqS0atUqlJmJzLpVq1aVtmzZIqWkpIjjz8fHR2QsxX72bASBU6dOiYlPeQsXLhSPr169atPjsFOnTlK9evVERmSe6tatK3Xr1s1Gvx5gT7wv8D4xb948qXTp0tr9hfcdjdDQULGPMJ4/ceJE6dChQ+K444y50dHR4liU7zfOtM7mHitqZs4x6sjbOb/rVs7qPXDgQO3yly9fFufYN954QyzP7+P3f//995IjsHR9P/74Y5H9Ojk5WTp79qx4nc8J69evl5zlfOZs2zjLwvVV+zZG0G3CF198IQUGBkru7u5SgwYNtENkuRreYZUmHmpEPpzInDlzxJAiHh4eUsuWLcVJWe7BgwfS6NGjpfLly0uenp7iZJeamiq5Cv2gG2Vm6IcffpDCw8PFPsTDXCxdulTndZSZLr7w432qWrVqUokSJaTg4GBp5syZUk5ODspMbwgR/YlvWNhyn8rIyJD69+8veXl5iYkfq3XYEtDF+4LSPsL7job8nMc3nGNiYqSKFSuKC1g+/vgzHOl8Zuk6m3usqJk5x6ijb2dT16383fk6RI4rUyIjI8XyQUFB0qJFiyRHYsn6vv/++1KNGjXEubJcuXJiiNKtW7dKznQ+c7ZtvNfC9VX7Ni7C/xR2bTsAAAAAAACAM0KfbgAAAAAAAAA7QdANAAAAAAAAYCcIugEAAAAAAADsBEE3AAAAAAAAgJ0g6AYAAAAAAACwEwTdAAAAAAAAAHaCoBsAAAAAAADAThB0AwAAAAAAANgJgm4AAAAAABeVm5tLL7zwAv3nP/8htWrUqBFt2LChsL8GgNUQdAMAAAAAPGdz586l+vXrF3q5L126lAIDA6l58+akVm+++SZNmzaNHj9+XNhfBcAqCLoBAAAAAFTq4cOHdv38zz77jIYNG0bPo0bdWl27dqU7d+7Qjh07bPqdAJ4XBN0AAAAAABZauXIlVahQgXJycnTm9+7dmwYNGmTyvcuXL6d58+bR6dOnqUiRImLieYwfL168mHr06EGlSpWit99+W7zm7e2t8xmbNm0Sy8r98MMP1LBhQypRogQFBweL/+PRo0dGv8fJkyfp119/FUGtxpUrV8TncnPuNm3aUMmSJSkiIoIOHz6s897169dTnTp1yMPDg4KCguijjz7SeZ3n8XePi4ujsmXL0vDhw7XrsWXLFgoNDRWf/corr9D9+/dpxYoV4j3lypWjMWPGUF5envaz3NzcqEuXLvTNN9+YLFcAtULQDQAAAABgoT59+ojAcPPmzdp5t27dEgHlkCFDTL43NjaWJk6cKILWtLQ0MfE8jTlz5oig+8yZMzR06FCzvg/XAg8YMIDGjh1LSUlJtGTJEhHkxsfHG33P/v37KSQkhMqUKWPw2syZM2nSpEmUmJgolunXr582gD9x4gT97W9/o759+4rvyE3luQm45saBxocffkjh4eFieX6dZWdn06effkpr166l7du3U0JCAvXq1Yu2bdsmpn/961+iyfv333+v81mNGzemAwcOmFUWAGpTrLC/AAAAAACAo/H09KRXX32Vli1bJgJwtnr1avL396fWrVvn+97SpUtTsWLFqHLlygav8+eaG2xrcHDN/Z4HDx4snnNN91tvvUVTpkwRQbwSrtWuUqWK4msccGtqwLnGnG8QcK14WFgYLVy4kNq1a6cNpDko50Cfg2yu2dZo27at+ByNgwcPiubyixYtoho1aoh5XNPNgfbNmzdFmdSuXVvUsO/du1fnRkTVqlUpNTVV9OsuWhT1huBYsMcCAAAAAFiBm0zv3LmTrl+/Lp5zAM5Bp36zb0tFRUVZ/B6uTZ4/f74IXDUTfz+uRefaZSUPHjwQTdGV1KtXT/vYz89P/E1PTxd/z58/b5B4jZ9funRJp1m40npwk3JNwM18fX1Fs3L+vvJ5mv9LfqOCA2795vwAjgA13QAAAAAAVoiMjBT9nbl/d8eOHUVTa+5XXVDcl1uOa3YlSTKZYI0DUq6R5qba+owF1j4+PuI7KylevLj2seYmgiZ7OH8X/RsL+t9PaT30P1fz2Urz9DOV//nnnyJg5+AbwNEg6AYAAAAAsBJn/v74449FbXf79u0pICDArPe5u7vr1AqbUrFiRcrKyhIJxzSBLPe1lmvQoAFdvHhRjLltyU0DbuqtFESbwk3Auam43KFDh0Qzc056Zg9nz54V6wjgiNC8HAAAAADASv379xcB91dffWVRP2xuUp2SkiKCZ07AZqrZdJMmTUQt74wZM0S/6jVr1hgkLZs9e7aoceekZufOnRNNwNetW0ezZs0y+rncd5oDeV7eEpwEbvfu3aLPeHJyssg8/vnnn+v037Y1TqIWExNjt88HsCcE3QAAAAAAVuLM3zxMGPdJ7tmzp9nv4/d06tRJBL5ck21qOKzy5cvTqlWrRHbvunXrimU5uJbj5u2cOX3Xrl3UqFEjatq0qUh4FhgYaPRzecgzbo7OCeAswTXO3377rchAztnJOeDn/uTyJGq2xDc1uCY9v6zwAGpVRFLqgAEAAAAAAGbp0KED1apVSwyF5Wi4Tzc3i+cadC8vL1KjyZMn0507d8RQYgCOCDXdAAAAAABW4OReXNu7Z88eGjVqlEOWIdecf/DBB2L4MLWqVKmSaMoO4KhQ0w0AAAAAYAXul3379m0xXrV+f2Ye1/rq1auK71uyZInoCw4ArgFBNwAAAACAjXHArT+sl3wcarU25QYA20PQDQAAAAAAAGAn6NMNAAAAAAAAYCcIugEAAAAAAADsBEE3AAAAAAAAgJ0g6AYAAAAAAACwEwTdAAAAAAAAAHaCoBsAAAAAAADAThB0AwAAAAAAANgJgm4AAAAAAAAAso//ARkpJCmV5AQSAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 7.268e-04 @ epoch 740\n",
      "\n",
      "iter=0  t=0.00s  best_y=121.525  x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "STOP: no feasible neighbors. best_y=121.525 x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 1282 rows, 779 columns and 20107 nonzeros\n",
      "Model fingerprint: 0xde5ccf4e\n",
      "Variable types: 513 continuous, 266 integer (256 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [7e-06, 6e+02]\n",
      "  Objective range  [7e+00, 7e+00]\n",
      "  Bounds range     [1e+00, 6e+02]\n",
      "  RHS range        [3e-04, 6e+02]\n",
      "Presolve removed 293 rows and 28 columns\n",
      "Presolve time: 0.04s\n",
      "Presolved: 989 rows, 751 columns, 18617 nonzeros\n",
      "Variable types: 495 continuous, 256 integer (246 binary)\n",
      "\n",
      "Root relaxation: objective -6.959775e+01, 407 iterations, 0.01 seconds (0.02 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0  -69.59775    0  107          -  -69.59775      -     -    0s\n",
      "     0     0  -26.37179    0  124          -  -26.37179      -     -    0s\n",
      "     0     0  -17.96338    0  137          -  -17.96338      -     -    0s\n",
      "     0     0  -17.82545    0  140          -  -17.82545      -     -    0s\n",
      "     0     0  -17.82432    0  140          -  -17.82432      -     -    0s\n",
      "H    0     0                      94.6269816  -17.82432   119%     -    0s\n",
      "H    0     0                      85.5829098  -10.48498   112%     -    0s\n",
      "     0     0  -10.48498    0  143   85.58291  -10.48498   112%     -    0s\n",
      "     0     0  -10.12641    0  145   85.58291  -10.12641   112%     -    0s\n",
      "     0     0  -10.05507    0  146   85.58291  -10.05507   112%     -    0s\n",
      "     0     0  -10.04149    0  145   85.58291  -10.04149   112%     -    0s\n",
      "     0     0   -4.11645    0  153   85.58291   -4.11645   105%     -    0s\n",
      "     0     0   -3.40346    0  155   85.58291   -3.40346   104%     -    0s\n",
      "     0     0   -3.27872    0  152   85.58291   -3.27872   104%     -    0s\n",
      "     0     0   -3.17901    0  153   85.58291   -3.17901   104%     -    0s\n",
      "     0     0   -3.13230    0  152   85.58291   -3.13230   104%     -    0s\n",
      "     0     0   -3.12314    0  152   85.58291   -3.12314   104%     -    0s\n",
      "     0     0   -1.36762    0  158   85.58291   -1.36762   102%     -    1s\n",
      "     0     0    3.08185    0  152   85.58291    3.08185  96.4%     -    1s\n",
      "     0     0    9.99783    0  153   85.58291    9.99783  88.3%     -    1s\n",
      "     0     0    9.99783    0  153   85.58291    9.99783  88.3%     -    1s\n",
      "     0     0   11.26974    0  155   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  157   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  158   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  156   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  158   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  157   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.26974    0  159   85.58291   11.26974  86.8%     -    1s\n",
      "     0     0   11.73095    0  157   85.58291   11.73095  86.3%     -    1s\n",
      "     0     0   13.58149    0  154   85.58291   13.58149  84.1%     -    2s\n",
      "     0     2   13.58149    0  154   85.58291   13.58149  84.1%     -    2s\n",
      "H   42    44                      85.0256729   33.95235  60.1%   175    2s\n",
      "H   47    44                      83.1912875   34.02786  59.1%   161    2s\n",
      "H 1086   725                      79.7099053   36.51918  54.2%  51.2    3s\n",
      "  2578  1661   51.50902   22  106   79.70991   39.20595  50.8%  37.9    5s\n",
      "H 2624  1624                      79.1955130   44.47924  43.8%  41.3    9s\n",
      "H 2633  1541                      78.6673673   44.47924  43.5%  41.2    9s\n",
      "  3654  1875   64.00192   35  107   78.66737   44.47924  43.5%  44.6   10s\n",
      "H 3767  1799                      72.7936517   44.47924  38.9%  44.2   10s\n",
      "* 5203  1591              95      71.4639469   51.86098  27.4%  43.9   10s\n",
      "* 8321  1792              77      70.2982508   60.21921  14.3%  46.5   12s\n",
      " 16337    18     cutoff   43        70.29825   68.63494  2.37%  45.0   15s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 45\n",
      "  Implied bound: 1\n",
      "  MIR: 437\n",
      "  Flow cover: 139\n",
      "  Inf proof: 5\n",
      "  RLT: 518\n",
      "  Relax-and-lift: 51\n",
      "\n",
      "Explored 16989 nodes (756765 simplex iterations) in 15.16 seconds (38.07 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 10: 70.2983 71.4639 72.7937 ... 94.627\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 7.029825076253e+01, best bound 7.029825076253e+01, gap 0.0000%\n",
      "[CHECK MLP] obj(x_ip)=70.2983  ip_y=70.2983  rel_err=7.337e-08\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.553  std(mean)=0.497  min=0  max=1\n",
      "  y: shape=(1000,)  mean=12.3  std=7.3  min=0.739  max=24.2\n",
      "\n",
      "\n",
      "=== Run: assignment | MaxAffine ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,600 (trainable=17,600)  n_pieces=1600\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.01  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAx7pJREFUeJzs3QeYE2XXBuAnZStl6b1L7wiIIFLkU4qioiL2XhAUFSu/7dNPxS4i2HvHAlhQAZGOhSrCAgLS21J32Zb+X+fNJjvpZZMt2ee+rsBmMklmk+xkzpzznlfncDgcICIiIiIiIqKY08f+IYmIiIiIiIiIQTcRERERERFRHDHTTURERERERBQnDLqJiIiIiIiI4oRBNxEREREREVGcMOgmIiIiIiIiihMG3URERERERERxwqCbiIiIiIiIKE4YdBMRERERERHFCYPuID744APodLqAl0WLFqEs7dy5U23HCy+8EPVjPPzwwzjvvPPQuHFj9VjXXXddwHX//fdfXHTRRahRowaqVq2Ks88+G2vWrPG77hdffIHu3bsjNTUVjRo1wl133YXc3Fyf9WSZ3CbryLpyH7lvIN999x2MRiMOHz6srk+ZMkVtU8uWLdX2Dxo0KOB9s7Ky1O9Xp04dpKeno2/fvliwYIHfdX/55Rd1u6wn68v95P7eLBYLHn/8cbRo0QIpKSlo3749Xn31VYRL7vff//4XZfXZls9QOOsF+rw7HA60bt3a72t/9OhRTJo0CR07dkSVKlWQkZGhXp+rr74a69evL9W/s48++giXXXYZ2rVrB71er173SBw8eBC33347WrVqhbS0NDRv3hw33ngjdu/e7bHe3r171ed54MCB6u9Etl9+P285OTl46qmn1GvWoEED9ffUpUsXPPvssygsLEQ8hPOZ3rNnD0aNGqV+T9d71qNHD0ybNg1WqzXs53riiSfU+26321ERPfLIIzj11FMr7PYTJTrZT8m++MSJEwHXufLKK5GUlIRDhw6F/biyzy6L7+RQnn76acyePdtneWZmptreUN/l8SDfq3Xr1sXJkydL7TnD/Y4V8v3q75hi2LBhUR/LyfHLhRdeGJffjRIfg+4wvP/++/jtt998LnJQVtG9/PLLKjg6//zzkZycHHA9CXLPPPNM/PPPP3jvvffw5ZdfquBAdmpbtmzxWPfTTz/F5Zdfjt69e+Onn37CY489pnaKEhx7k2UffvihWkfWlfvIfT/77DO/2/HNN99gwIABakcv3njjDezatQtnnXWWe5k/JpMJQ4YMUUH2K6+8gm+//Rb169dXO9/Fixd7rCvXhw8frm6X9WR9CVjk/vI4WuPGjcPkyZMxfvx4zJ07Vx0I3HnnneoLMpFUq1YN7777rs9yea22b9+ubvc+mXL66aer9/2mm25SJ0vkc3HLLbdgx44dWLduXan+nX388cfYuHEjTjvtNJxyyikR3Vfec/nMzZgxA/fee6/6nP7f//0f5syZg379+nkccGzbtk39nvK3NGLEiICPKcG6nDCS3+2tt95Sr88ll1yiDp7kJJiczIilcD/TeXl5qF69ugo6ZZvkBFj//v1xxx13YOzYsWE91/79+/Hcc8+pwFtOcFRE8j7L51T2TURU/shJTzkGCXSskJ2djVmzZqn9qez3KrpgQbcEi6UddOfn56vvwQceeMDn+z+ewv2OdZETyN7HFPLd6y3cYzn5jpbv/l9//TWmvxdVEg4K6P3335cjX8fKlSvL5au0Y8cOtX3PP/981I9hs9ncP1epUsVx7bXX+l3vvvvucyQlJTl27tzpXpadne2oU6eO49JLL3Uvs1qtjoYNGzrOOeccj/t/+umnalt//PFH97I5c+aoZZ999pnHumeffbajUaNG6rG0zGazo0aNGo5p06b53f5OnTo5Bg4c6Hf7p0+frp5rxYoV7mUWi8XRsWNHx2mnneaxbu/evdVyud1l+fLl6v6vvfaae9mGDRscOp3O8fTTT3vc/+abb3akpaU5jh496gilefPmjscee8xRVp9t+QyFs95NN92kfid5z7WuuuoqR9++fX1e+/fee0/d79dff/X7uNr3rTT+zrTPd+6556rXPVzz589X2/fOO+94LJfPrSyfOXOm3+eR30dul9/PW25urrp4k79luc/SpUsdsRTuZzoQ+Rs3Go2OwsLCkOvef//9jsaNG3u8FqUlLy8vZo91++23O9q2beuw2+0xe0wiig05PpDjhJ49e/q9/fXXX1f7t++//z6ix5X7lMV3ciiBjs+++uortc0LFy4s1X2pfG+kpqY6jh8/7ihN4X7HCjkmkWOTUCI9ljvvvPPUcSpRpCpmGqIckpIVKT9988030bZtW1WeIuWV/kqlN2zYgAsuuAA1a9Z0l1T7y6hI2dQ9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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.320e-03 @ epoch 740\n",
      "\n",
      "iter=0  t=0.00s  best_y=200.625  x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "STOP: no feasible neighbors. best_y=200.625 x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "\n",
      "Optimize a model with 1601 rows, 11 columns and 17610 nonzeros\n",
      "Model fingerprint: 0xb2154825\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [4e-05, 2e+00]\n",
      "  Objective range  [7e+00, 7e+00]\n",
      "  Bounds range     [1e+00, 1e+01]\n",
      "  RHS range        [2e+00, 5e+01]\n",
      "Presolve time: 0.00s\n",
      "Presolved: 1601 rows, 11 columns, 17610 nonzeros\n",
      "Variable types: 1 continuous, 10 integer (0 binary)\n",
      "Found heuristic solution: objective 255.8258532\n",
      "Found heuristic solution: objective 176.5676859\n",
      "\n",
      "Root relaxation: objective 1.603161e+02, 16 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  160.31606    0    4  176.56769  160.31606  9.20%     -    0s\n",
      "H    0     0                     161.6312048  160.31606  0.81%     -    0s\n",
      "H    0     0                     160.9156458  160.31606  0.37%     -    0s\n",
      "H    0     0                     160.7346793  160.54193  0.12%     -    0s\n",
      "     0     0  160.55095    0    5  160.73468  160.55095  0.11%     -    0s\n",
      "     0     0  160.66720    0    5  160.73468  160.66720  0.04%     -    0s\n",
      "\n",
      "Cutting planes:\n",
      "  Gomory: 3\n",
      "  MIR: 1\n",
      "  StrongCG: 1\n",
      "\n",
      "Explored 1 nodes (19 simplex iterations) in 0.06 seconds (0.09 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 5: 160.735 160.916 161.631 ... 255.826\n",
      "\n",
      "Optimal solution found (tolerance 1.00e-04)\n",
      "Best objective 1.607346792908e+02, best bound 1.607346792908e+02, gap 0.0000%\n",
      "[CHECK MaxAffine] obj(x_ip)=160.735  ip_y=160.735  rel_err=5.506e-09\n",
      "\n",
      "--- Dataset stats (assignment) ---\n",
      "  X: shape=(1000, 10)  mean(mean)=0.553  std(mean)=0.497  min=0  max=1\n",
      "  y: shape=(1000,)  mean=12.3  std=7.3  min=0.739  max=24.2\n",
      "\n",
      "\n",
      "=== Run: assignment | LSET ===\n",
      "  data: N=1000  train/val/test=700/150/150  dim=10\n",
      "  model: params=17,600 (trainable=17,600)  n_pieces=1600 T=0.05\n",
      "  train: device=cpu  epochs=1000  batch=8  lr=0.01  wd=0  seed=0\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAGGCAYAAABmGOKbAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA0WBJREFUeJzsnQd4E+Ufx78ZXUApe2/ZQ0BABEFAVIaiggO3KA4ERcW9FedfFBEFce+BCjhRQEW2CMiQPWTv2UJn1v/5XXrpJbkklzRp0/b7eZ40zc03d5e79/v+lsnlcrlACCGEEEIIIYSQqGOO/iYJIYQQQgghhBBC0U0IIYQQQgghhMQQWroJIYQQQgghhJAYQdFNCCGEEEIIIYTECIpuQgghhBBCCCEkRlB0E0IIIYQQQgghMYKimxBCCCGEEEIIiREU3YQQQgghhBBCSIyg6CaEEEIIIYQQQmIERXcQPvroI5hMpoCvP//8E8XJjh07lHa88sorEW/j8ccfx0UXXYS6desq2xo2bFjAZf/77z8MGTIElSpVQoUKFXD++efjn3/+0V32q6++QocOHZCcnIw6dergnnvuwalTp/yWk2kyT5aRZWUdWTcQP/zwA6xWKw4fPqx8njBhgtKmxo0bK+3v3bt3wHUPHTqkfL9q1aqhXLly6NatG37//XfdZX/77Tdlviwny8t6sr4vNpsNzzzzDBo1aoSkpCS0bNkSb7zxBowi6z399NMormtbriEjywW63l0uF5o2bap77I8ePYpHHnkErVu3Rvny5ZGWlqYcn+uvvx5r1qwpst/Z/v37letczqecy4oVK6JTp05455134HA4DG9Hzqu0X86zXG9y3uX86/H999+jV69eyr7ku7dp00bZn5a8vDw8+eSTyrYSExPRsGFD5XhlZ2cjFhi5pnfv3o3BgwejSZMmnnPWsWNHvPnmm7Db7Yb3NXbsWOW8O51OlESeeOIJnHHGGSW2/YSUduQ+lZKSghMnTgRc5tprr0VCQgIOHjxoeLvyzCmOZ3IoXnjhBXz33Xd+09evX6+0N9SzPBZ88sknqF69Ok6ePFlk+9yzZ4/SZ5Tnq/RF5XxJH0IP6ZPo9Sn69+8fcV9O+i+XXnppTL4bKQO4SEA+/PBDlxwieV+yZInfKz09vViP3vbt25X2jRs3LuJtlCtXznXWWWe5RowY4UpMTHTdeOONussdOnTIVadOHVebNm1c06ZNc/3888+uHj16uFJTU10bN270Wvazzz5T2nXLLbe4/vjjD9eUKVNcaWlprvPPP99vuzKtUqVKyjKyrKwj637++ee67bjhhhtcffr08Xxu0aKF64wzznDdfPPNrurVq7t69eqlu15OTo6rbdu2rnr16intmz17tuuSSy5xWa1W159//um1rHyW6TJflpPl69atq6wv29Ei7U1KSnK9/PLLrrlz57oefvhhl8lkcj3//PMuIzRs2ND11FNPuYrr2pZryMhycp6vu+46v/nyndX52mN/8uRJV9OmTV21atVyvfrqq67ffvvN9eOPPyr/n3322a6PP/64yH5nst/69eu7HnvsMeW6lXN67733usxms+umm24ytI3nnntOOa+PPPKI8p3lfMvv5dZbb/Vb9sUXX1S2PXLkSNcvv/yifPc333zT9cYbb3gtN2TIEFdycrLrhRdecM2ZM8c1duxYZZuDBg1yRRuj1/SGDRuU39gHH3ygtHvmzJmuO++8Uzk/w4cPN7SvvXv3usqXL+/65ptvXCWVEydOKPclOQ6EkPhD7utyX5o0aVLA33BKSorr0ksvDWu7ss3ieCaHQu6pev0zuc9Km+W5VJRkZmYqz5DC9D8jQb5ntWrVXOedd57r6quv9vQd9JA+SZMmTfz6FPKc88VoX27r1q3Ks/T333+P2XckpReK7iCoYmDZsmWueCQaotvhcIS8qQsPPPCAKyEhwbVjxw7PNBFDcvO78sorPdPsdrurdu3argsuuMBrfRHR0lbpxKuIAJJpX3zxhZ8QF4Ev29KSl5endIRFwOi1XwYEAolueTDLvhYvXuyZZrPZXK1bt3adeeaZXst26dJFmS7zVRYtWqSsP3nyZM+0tWvXKjdlEU1aRIjJw/7o0aOu0iK65YEk38lXAIsQ79atm9+xF7Ei68lAih7a8xbr39mxY8eUa8eXUaNGKfvdtWtX0PWPHDmiiOPbbrvNa7o8jOX8r1u3zjNt+fLliuD+3//+F3Sb8uCXfcsghBa5lmS6CONoYvSaDoT8xqWj4TvopMeDDz6odMa057goO4LRQgYbmjdv7nI6nVHbJiEkOkj/QPoJnTp10p3/1ltvKfc3EefhQNFt7F4qzw15Lh4/ftxVlGifK9JnCCW6pW8SinD7chdddJGuEYmQUNC9PEqI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",
      "text/plain": [
       "<Figure size 1000x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[DONE] best val MSE (norm) = 8.787e-04 @ epoch 310\n",
      "\n",
      "iter=0  t=0.00s  best_y=240.339  x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "STOP: no feasible neighbors. best_y=240.339 x=[5, 5, 5, 5, 5, 5, 5, 5, 5, 5]\n",
      "Set parameter OutputFlag to value 1\n",
      "Set parameter TimeLimit to value 300\n",
      "Set parameter FuncNonlinear to value 1\n",
      "Set parameter FeasibilityTol to value 1e-09\n",
      "Set parameter OptimalityTol to value 1e-09\n",
      "Set parameter IntFeasTol to value 1e-09\n",
      "Set parameter NumericFocus to value 3\n",
      "Gurobi Optimizer version 12.0.3 build v12.0.3rc0 (mac64[arm] - Darwin 25.2.0 25C56)\n",
      "\n",
      "CPU model: Apple M4 Max\n",
      "Thread count: 14 physical cores, 14 logical processors, using up to 14 threads\n",
      "\n",
      "Non-default parameters:\n",
      "TimeLimit  300\n",
      "FeasibilityTol  1e-09\n",
      "IntFeasTol  1e-09\n",
      "OptimalityTol  1e-09\n",
      "NumericFocus  3\n",
      "\n",
      "Optimize a model with 4804 rows, 4815 columns and 27216 nonzeros\n",
      "Model fingerprint: 0x2f427a1f\n",
      "Model has 1601 function constraints treated as nonlinear\n",
      "  1600 EXP, 1 LOG\n",
      "Variable types: 4805 continuous, 10 integer (0 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [4e-04, 4e+01]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e-12, 2e+03]\n",
      "  RHS range        [1e+01, 1e+02]\n",
      "Warning: x < 1e-10 in domain of log(x).\n",
      "         Setting lower bound to 1e-10.\n",
      "Presolve removed 3202 rows and 1602 columns\n",
      "Presolve time: 0.01s\n",
      "Presolved: 9607 rows, 3214 columns, 36821 nonzeros\n",
      "Presolved model has 1601 nonlinear constraint(s)\n",
      "\n",
      "Solving non-convex MINLP\n",
      "\n",
      "Variable types: 3204 continuous, 10 integer (0 binary)\n",
      "\n",
      "Root relaxation: objective 1.866901e+02, 1625 iterations, 0.02 seconds (0.09 work units)\n",
      "\n",
      "    Nodes    |    Current Node    |     Objective Bounds      |     Work\n",
      " Expl Unexpl |  Obj  Depth IntInf | Incumbent    BestBd   Gap | It/Node Time\n",
      "\n",
      "     0     0  186.69014    0   15          -  186.69014      -     -    0s\n",
      "\n",
      "Explored 1 nodes (1625 simplex iterations) in 0.05 seconds (0.14 work units)\n",
      "Thread count was 14 (of 14 available processors)\n",
      "\n",
      "Solution count 0\n",
      "\n",
      "Model is infeasible\n",
      "Best objective -, best bound -, gap -\n",
      "\n",
      "=== MODEL SPECS (from seed 0 run) ===\n",
      "    model  n_params  n_trainable                                                    extra    lr  batch_size  epochs  weight_decay\n",
      "      DFN     16725        16725 layers=[16, 128, 16] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000           0.0\n",
      "DFN_AfixI     17610        17610   layers=[5, 400, 6] p_list=[1, 1] alpha=0.005 beta=-2.0 0.100           8    1000           0.0\n",
      "     LSET     17600        17600                                     n_pieces=1600 T=0.05 0.010           8    1000           0.0\n",
      "      MLP     18049        18049                                        hidden=[128, 128] 0.001           8    1000           0.0\n",
      "MaxAffine     17600        17600                                            n_pieces=1600 0.010           8    1000           0.0\n",
      "\n",
      "=== LEARNING SUMMARY (mean ± SE over seeds) ===\n",
      "    model  n  train_time  train_time_n        best_val  best_val_n      train_raw  train_raw_n       val_raw  val_raw_n      test_raw  test_raw_n  n_eval_err\n",
      "      DFN  1 1054.16 ± 0             1 0.000313839 ± 0           1  0.0132882 ± 0            1 0.0169147 ± 0          1 0.0167272 ± 0           1           0\n",
      "DFN_AfixI  1 1636.36 ± 0             1  0.00234355 ± 0           1   0.133106 ± 0            1  0.126309 ± 0          1  0.111723 ± 0           1           0\n",
      "     LSET  1 173.195 ± 0             1 0.000878741 ± 0           1  0.0432333 ± 0            1 0.0473608 ± 0          1 0.0559065 ± 0           1           0\n",
      "      MLP  1 184.769 ± 0             1 0.000726755 ± 0           1 0.00662253 ± 0            1 0.0391693 ± 0          1  0.046866 ± 0           1           0\n",
      "MaxAffine  1 167.565 ± 0             1   0.0013205 ± 0           1  0.0865491 ± 0            1 0.0711696 ± 0          1 0.0820673 ± 0           1           0\n",
      "\n",
      "=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\n",
      "    model  n_seeds            LS_y  LS_y_n         LS_time  LS_time_n  LS_fails           IP_y  IP_y_n      IP_time  IP_time_n  IP_fails  LS_vs_IP_%  LS_vs_IP_%_n  IP_obj_rel_err  IP_obj_rel_err_n\n",
      "      DFN        1 6.51248e+06 ± 0       1  0.00114783 ± 0          1         0 6.1918e+06 ± 0       1 0.104931 ± 0          1         0 5.17915 ± 0             1 2.08821e-08 ± 0                 1\n",
      "DFN_AfixI        1     170.406 ± 0       1  0.00269633 ± 0          1         0    123.434 ± 0       1 0.246001 ± 0          1         0 38.0537 ± 0             1 2.38791e-08 ± 0                 1\n",
      "     LSET        1     240.339 ± 0       1  0.00064725 ± 0          1         0            nan       0 0.158462 ± 0          1         1         nan             0             nan                 0\n",
      "      MLP        1     121.525 ± 0       1 0.000241666 ± 0          1         0    70.2983 ± 0       1  15.2321 ± 0          1         0 72.8699 ± 0             1 7.33714e-08 ± 0                 1\n",
      "MaxAffine        1     200.625 ± 0       1 0.000252916 ± 0          1         0    160.735 ± 0       1 0.124478 ± 0          1         0 24.8178 ± 0             1   5.506e-09 ± 0                 1\n",
      "\n",
      "=== FAILURES / WARNINGS (if any) ===\n",
      " seed model stage                                                       error\n",
      "    0  LSET    IP RuntimeError('No feasible solution found. Gurobi status 3')\n"
     ]
    }
   ],
   "source": [
    "import time, io, contextlib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "# ---------- 0) CONFIG ----------\n",
    "N_SEEDS = 1\n",
    "SEEDS = list(range(N_SEEDS))\n",
    "\n",
    "# If True: dataset_params[\"seed\"] is set to the run seed (dataset changes each seed)\n",
    "VARY_DATASET_SEED = False\n",
    "\n",
    "# If True: model_params[\"seed\"] is set to the run seed (init changes each seed) when that key exists\n",
    "VARY_MODEL_INIT_SEED = True\n",
    "\n",
    "# If True: raise when IP objective doesn't match obj(x_ip)\n",
    "STRICT_IP_CHECK = False\n",
    "IP_CHECK_TOL = 1e-4\n",
    "\n",
    "# Silence local search prints\n",
    "SILENCE_LOCAL_SEARCH = False\n",
    "\n",
    "# Multi-seed + plot_every=1 will spam your notebook badly.\n",
    "# Set this to True if you REALLY want plots for every seed/model.\n",
    "ALLOW_PLOTS_MULTI_SEED = True\n",
    "\n",
    "# ===================== ASSIGNMENT DATASET CONFIG =====================\n",
    "dataset_type = \"assignment\"\n",
    "dataset_params = dict(\n",
    "    K=1000,            # number of samples\n",
    "    num_nodes=10,    # bipartite side size (depends on your generator)\n",
    "    c_min=1,         # min cost / feature value\n",
    "    c_max=10,        # max cost / feature value\n",
    "    noise_std=0.1,\n",
    "    seed=0,\n",
    ")\n",
    "\n",
    "# infer dimension from assignment generator (exactly like your mdvsp inference)\n",
    "Xtmp, _, _ = generate_bipartite_subset_matching_dataset(**dataset_params)\n",
    "in_dim = int(np.asarray(Xtmp).shape[1])\n",
    "print(f\"[ASSIGNMENT] inferred in_dim={in_dim} from Xtmp shape={np.asarray(Xtmp).shape}\")\n",
    "\n",
    "# ===================== TRAIN CONFIG =====================\n",
    "train_base = dict(\n",
    "    epochs=1000,\n",
    "    batch_size=8,\n",
    "    val_frac=0.15,\n",
    "    test_frac=0.15,\n",
    "    seed=0,\n",
    "    device=(\"cuda\" if torch.cuda.is_available() else \"cpu\"),\n",
    "    eps=1e-8,\n",
    "    weight_decay=0.0,\n",
    "    plot_every=1,\n",
    "    plot_points=2048,\n",
    "    plot_chunk=4096,\n",
    ")\n",
    "\n",
    "# ---- DFN (learnable A) ----\n",
    "dfn_params = dict(\n",
    "    input_dim=in_dim, layer_sizes=[16, 128, 16], p_list=[1, 1],\n",
    "    seed=0, alpha=5e-3, beta=-2.0\n",
    ")\n",
    "\n",
    "# ---- DFN (fixed A = I) ----\n",
    "# Need |L1| + |LK| = dim + 1\n",
    "dfnA_layer_sizes = [5, 400, 6]\n",
    "assert dfnA_layer_sizes[-1] > 0, f\"in_dim too small for DFN_AfixI with L1=5 (got in_dim={in_dim})\"\n",
    "assert dfnA_layer_sizes[0] + dfnA_layer_sizes[-1] == in_dim + 1, \"Need |L1|+|LK| = dim+1 for A_fixed=I\"\n",
    "\n",
    "dfn_Afix_params = dict(\n",
    "    input_dim=in_dim,\n",
    "    layer_sizes=dfnA_layer_sizes,\n",
    "    p_list=[1, 1],\n",
    "    seed=0,\n",
    "    alpha=5e-3,\n",
    "    beta=-2.0,\n",
    "    A_fixed=np.eye(in_dim, dtype=np.float32),\n",
    ")\n",
    "\n",
    "# ---- other models ----\n",
    "mlp_params  = dict(in_dim=in_dim, hidden_dims=[128, 128], out_dim=1)\n",
    "maff_params = dict(in_dim=in_dim, n_pieces=1600)\n",
    "lset_params = dict(in_dim=in_dim, n_pieces=1600, T=0.05)\n",
    "\n",
    "lr_map = dict(DFN=1e-1, MLP=1e-3, MaxAffine=1e-2, LSET=1e-2)\n",
    "\n",
    "time_limit = 300\n",
    "\n",
    "# ===================== FEASIBLE INTEGER BOX + FEASIBLE x0 / sum_eq =====================\n",
    "xmin  = np.full(in_dim, int(dataset_params[\"c_min\"]), dtype=int)\n",
    "xmax  = np.full(in_dim, int(dataset_params[\"c_max\"]), dtype=int)\n",
    "\n",
    "# choose feasible x0 inside [xmin,xmax]\n",
    "x0_val = int((xmin[0] + xmax[0]) // 2)\n",
    "x0 = np.full(in_dim, x0_val, dtype=int)\n",
    "\n",
    "delta = 1\n",
    "sum_eq = int(x0.sum())  # guaranteed feasible by construction\n",
    "\n",
    "# (display_name, model_type_for_training_and_IP, model_params)\n",
    "runs = [\n",
    "    (\"DFN\",        \"DFN\", dfn_params),\n",
    "    (\"DFN_AfixI\",  \"DFN\", dfn_Afix_params),\n",
    "    (\"MLP\",        \"MLP\", mlp_params),\n",
    "    (\"MaxAffine\",  \"MaxAffine\", maff_params),\n",
    "    (\"LSET\",       \"LSET\", lset_params),\n",
    "]\n",
    "\n",
    "# ---------- 2) IP DISPATCH ----------\n",
    "def solve_ip(model_type, model, scaler, xmin, xmax, sum_eq, *, time_limit=None, verbose=False):\n",
    "    if model_type == \"DFN\":\n",
    "        return solve_dfn_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MLP\":\n",
    "        return solve_mlp_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"MaxAffine\":\n",
    "        return solve_maxaffine_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    if model_type == \"LSET\":\n",
    "        return solve_lset_ip_gurobi(model, scaler, xmin, xmax, sum_eq, time_limit=time_limit, verbose=verbose)\n",
    "    raise ValueError(model_type)\n",
    "\n",
    "# ---------- 3) HELPERS ----------\n",
    "def suppress_stdout(fn, *args, **kwargs):\n",
    "    if not SILENCE_LOCAL_SEARCH:\n",
    "        return fn(*args, **kwargs), \"\"\n",
    "    buf = io.StringIO()\n",
    "    with contextlib.redirect_stdout(buf):\n",
    "        out = fn(*args, **kwargs)\n",
    "    return out, buf.getvalue()\n",
    "\n",
    "def make_obj(model, scaler, device, chunk=4096):\n",
    "    \"\"\"\n",
    "    Robust objective wrapper:\n",
    "    - Always returns a numpy array shape (B,) even for B=1\n",
    "    - Never raises if model forward fails: returns +inf for those points\n",
    "    - Tracks error count in obj._err_count / obj._err_first\n",
    "    \"\"\"\n",
    "    xm = scaler[\"x_mean\"].to(device)\n",
    "    xs = scaler[\"x_std\"].to(device)\n",
    "    ym = scaler[\"y_mean\"].to(device)\n",
    "    ys = scaler[\"y_std\"].to(device)\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def obj(Xraw):\n",
    "        Xraw = torch.as_tensor(Xraw, dtype=torch.float32, device=device)\n",
    "        if Xraw.dim() == 1:\n",
    "            Xraw = Xraw.unsqueeze(0)\n",
    "\n",
    "        outs = []\n",
    "        B = int(Xraw.shape[0])\n",
    "        for i in range(0, B, int(chunk)):\n",
    "            Xb = Xraw[i:i+chunk]\n",
    "            try:\n",
    "                Xn = (Xb - xm) / xs\n",
    "                yn = model(Xn)\n",
    "                yn = torch.as_tensor(yn).reshape(-1)\n",
    "                y  = (yn * ys + ym).reshape(-1).detach().cpu()\n",
    "                if y.numel() != Xb.shape[0]:\n",
    "                    y = y.expand(Xb.shape[0]).contiguous()\n",
    "                outs.append(y)\n",
    "            except Exception as e:\n",
    "                obj._err_count += int(Xb.shape[0])\n",
    "                if obj._err_first is None:\n",
    "                    obj._err_first = repr(e)\n",
    "                outs.append(torch.full((int(Xb.shape[0]),), float(\"inf\"), device=\"cpu\"))\n",
    "\n",
    "        return torch.cat(outs, 0).numpy()\n",
    "\n",
    "    obj._err_count = 0\n",
    "    obj._err_first = None\n",
    "    return obj\n",
    "\n",
    "def safe_raw_mse(obj, Xraw, yraw):\n",
    "    yp = np.asarray(obj(Xraw), dtype=float).reshape(-1)\n",
    "    yt = yraw.detach().cpu().numpy().reshape(-1) if torch.is_tensor(yraw) else np.asarray(yraw, float).reshape(-1)\n",
    "    if yp.shape[0] != yt.shape[0]:\n",
    "        return np.nan, f\"shape mismatch: pred {yp.shape} vs true {yt.shape}\"\n",
    "    mask = np.isfinite(yp)\n",
    "    if mask.sum() == 0:\n",
    "        return np.nan, \"all predictions were non-finite (inf/nan)\"\n",
    "    return float(np.mean((yp[mask] - yt[mask])**2)), None\n",
    "\n",
    "def t_to_best(hist, y_best):\n",
    "    best_t = float(\"nan\")\n",
    "    for r in hist:\n",
    "        if abs(float(r.get(\"best_y\", np.inf)) - float(y_best)) < 1e-12:\n",
    "            best_t = float(r.get(\"t\", float(\"nan\")))\n",
    "            break\n",
    "    return best_t\n",
    "\n",
    "def check_ip_matches_obj(name, obj, x_ip, y_ip, tol=1e-4):\n",
    "    y_obj = np.asarray(obj(np.asarray(x_ip)), dtype=float).reshape(-1)[0]\n",
    "    y_ip  = float(y_ip)\n",
    "    rel = abs(float(y_obj) - y_ip) / (abs(float(y_obj)) + 1e-12)\n",
    "    print(f\"[CHECK {name}] obj(x_ip)={float(y_obj):.6g}  ip_y={y_ip:.6g}  rel_err={rel:.3e}\")\n",
    "    if STRICT_IP_CHECK and rel > tol:\n",
    "        raise RuntimeError(f\"{name}: IP objective != obj() (rel_err={rel:.3e})\")\n",
    "    return rel\n",
    "\n",
    "def mean_se(x):\n",
    "    x = pd.to_numeric(pd.Series(x), errors=\"coerce\").to_numpy()\n",
    "    x = x[np.isfinite(x)]\n",
    "    n = int(x.shape[0])\n",
    "    if n == 0:\n",
    "        return np.nan, np.nan, 0\n",
    "    m = float(x.mean())\n",
    "    se = float(x.std(ddof=1) / np.sqrt(n)) if n > 1 else 0.0\n",
    "    return m, se, n\n",
    "\n",
    "def fmt_mean_se(m, se):\n",
    "    if not np.isfinite(m):\n",
    "        return \"nan\"\n",
    "    if not np.isfinite(se):\n",
    "        return f\"{m:.6g}\"\n",
    "    return f\"{m:.6g} ± {se:.3g}\"\n",
    "\n",
    "\n",
    "def eval_true_obj(gt, x):\n",
    "    \"\"\"Evaluate ground-truth objective at decision x (RAW space).\"\"\"\n",
    "    if not isinstance(gt, dict):\n",
    "        return np.nan\n",
    "    x = np.asarray(x).reshape(-1)\n",
    "    t = gt.get(\"type\", None)\n",
    "\n",
    "    if t == \"quadratic\":\n",
    "        Q = np.asarray(gt[\"Q\"], float)\n",
    "        xs = np.asarray(gt[\"x_star\"], float).reshape(-1)\n",
    "        d = x.astype(float) - xs\n",
    "        return float(d @ Q @ d)\n",
    "\n",
    "    if t == \"assignment\":\n",
    "        C = np.asarray(gt[\"C\"], float)\n",
    "        idx = np.flatnonzero(x > 0.5)\n",
    "        if idx.size == 0:\n",
    "            return 0.0\n",
    "        r, c = linear_sum_assignment(C[idx, :])\n",
    "        return float(C[idx, :][r, c].sum())\n",
    "\n",
    "    if t == \"mdvsp\":\n",
    "        N, SS, TT = int(gt[\"N\"]), int(gt[\"SS\"]), int(gt[\"TT\"])\n",
    "        src = np.asarray(gt[\"src\"], np.int64); dst = np.asarray(gt[\"dst\"], np.int64)\n",
    "        cost = np.asarray(gt[\"cost\"], float);   cap0 = np.asarray(gt[\"cap0\"], float)\n",
    "        idxSS = np.asarray(gt[\"idxSS\"], np.int64); idxTT = np.asarray(gt[\"idxTT\"], np.int64)\n",
    "\n",
    "        cap = cap0.copy()\n",
    "        cap[idxSS] = x.astype(float)\n",
    "        cap[idxTT] = x.astype(float)\n",
    "\n",
    "        F = lemon_mcf.max_flow(N, src, dst, cap, SS, TT)[\"value\"]\n",
    "        supply = np.zeros(N, float); supply[SS] = F; supply[TT] = -F\n",
    "        return float(lemon_mcf.solve_mcf(N, src, dst, cost, cap, supply)[\"total_cost\"])\n",
    "\n",
    "    return np.nan\n",
    "\n",
    "# ---------- 4) RUN MULTI-SEED ----------\n",
    "learn_rows, opt_rows, spec_rows, fail_rows = [], [], [], []\n",
    "\n",
    "for seed in SEEDS:\n",
    "    print(f\"\\n\\n===================== SEED {seed} =====================\")\n",
    "\n",
    "    for name, model_type, model_params_base in runs:\n",
    "        # ---- per-run params ----\n",
    "        dp = dict(dataset_params)\n",
    "        if VARY_DATASET_SEED and \"seed\" in dp:\n",
    "            dp[\"seed\"] = int(seed)\n",
    "\n",
    "        mp = dict(model_params_base)\n",
    "        if VARY_MODEL_INIT_SEED and \"seed\" in mp:\n",
    "            mp[\"seed\"] = int(seed)\n",
    "\n",
    "        tp = dict(train_base)\n",
    "        tp[\"seed\"] = int(seed)\n",
    "        tp[\"lr\"] = float(lr_map[model_type])\n",
    "\n",
    "        if (N_SEEDS > 1) and (tp.get(\"plot_every\", 0) not in (0, None)) and (not ALLOW_PLOTS_MULTI_SEED):\n",
    "            tp[\"plot_every\"] = 0\n",
    "\n",
    "        # ---- TRAIN ----\n",
    "        t0 = time.perf_counter()\n",
    "        try:\n",
    "            out = generate_and_train_simple(dataset_type, dp, model_type, mp, tp)\n",
    "        except Exception as e:\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=repr(e)))\n",
    "            learn_rows.append(dict(seed=seed, model=name, train_time=np.nan, best_epoch=np.nan,\n",
    "                                   best_val=np.nan, train_raw=np.nan, val_raw=np.nan, test_raw=np.nan,\n",
    "                                   train_err=repr(e)))\n",
    "            continue\n",
    "\n",
    "        train_time = time.perf_counter() - t0\n",
    "\n",
    "        # support both (model,data,hist,spec) and (model,data,hist)\n",
    "        if isinstance(out, tuple) and len(out) == 4:\n",
    "            model, data, hist, spec = out\n",
    "        elif isinstance(out, tuple) and len(out) == 3:\n",
    "            model, data, hist = out\n",
    "            n_params = sum(p.numel() for p in model.parameters())\n",
    "            n_trainable = sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "            spec = dict(n_params=int(n_params), n_trainable=int(n_trainable), extra=\"\", train_params=tp)\n",
    "        else:\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"TRAIN\", error=f\"Unexpected return: {type(out)}\"))\n",
    "            continue\n",
    "\n",
    "        if seed == SEEDS[0]:\n",
    "            spec_rows.append(dict(\n",
    "                model=name,\n",
    "                n_params=int(spec.get(\"n_params\", np.nan)),\n",
    "                n_trainable=int(spec.get(\"n_trainable\", np.nan)),\n",
    "                extra=str(spec.get(\"extra\", \"\")),\n",
    "                lr=float(spec.get(\"train_params\", {}).get(\"lr\", tp[\"lr\"])),\n",
    "                batch_size=int(spec.get(\"train_params\", {}).get(\"batch_size\", tp[\"batch_size\"])),\n",
    "                epochs=int(spec.get(\"train_params\", {}).get(\"epochs\", tp[\"epochs\"])),\n",
    "                weight_decay=float(spec.get(\"train_params\", {}).get(\"weight_decay\", tp.get(\"weight_decay\", 0.0))),\n",
    "            ))\n",
    "\n",
    "        device = data[\"device\"]\n",
    "        scaler = data[\"scaler\"]\n",
    "        obj = make_obj(model, scaler, device, chunk=int(tp.get(\"plot_chunk\", 4096)))\n",
    "        gt = data.get(\"true\", None)\n",
    "\n",
    "        # ---- LEARNING METRICS (RAW MSE) ----\n",
    "        train_raw, err_tr = safe_raw_mse(obj, data[\"raw\"][\"Xtr\"], data[\"raw\"][\"ytr\"])\n",
    "        val_raw,   err_va = safe_raw_mse(obj, data[\"raw\"][\"Xva\"], data[\"raw\"][\"yva\"])\n",
    "        test_raw,  err_te = safe_raw_mse(obj, data[\"raw\"][\"Xte\"], data[\"raw\"][\"yte\"])\n",
    "\n",
    "        if obj._err_count > 0:\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"OBJ\",\n",
    "                                  error=f\"obj() had {obj._err_count} forward failures; first={obj._err_first}\"))\n",
    "\n",
    "        val_curve = np.asarray(hist.get(\"val_mse_norm\", []), dtype=float)\n",
    "        best_ep = int(np.argmin(val_curve) + 1) if val_curve.size else np.nan\n",
    "        best_val = float(np.min(val_curve)) if val_curve.size else np.nan\n",
    "\n",
    "        learn_rows.append(dict(\n",
    "            seed=seed, model=name,\n",
    "            train_time=float(train_time),\n",
    "            best_epoch=best_ep,\n",
    "            best_val=best_val,\n",
    "            train_raw=float(train_raw) if np.isfinite(train_raw) else np.nan,\n",
    "            val_raw=float(val_raw) if np.isfinite(val_raw) else np.nan,\n",
    "            test_raw=float(test_raw) if np.isfinite(test_raw) else np.nan,\n",
    "            train_err=(err_tr or err_va or err_te)\n",
    "        ))\n",
    "        if err_tr or err_va or err_te:\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"EVAL_MSE\", error=(err_tr or err_va or err_te)))\n",
    "\n",
    "        # ---- LOCAL SEARCH ----\n",
    "        t0 = time.perf_counter()\n",
    "        try:\n",
    "            (ls_out, _ls_log) = suppress_stdout(\n",
    "                local_search_l1_int, obj, x0, xmin, xmax,\n",
    "                delta=delta, sum_eq=sum_eq, print_every=0\n",
    "            )\n",
    "            x_best, y_best, ls_hist = ls_out\n",
    "            ls_time = time.perf_counter() - t0\n",
    "            opt_rows.append(dict(\n",
    "                seed=seed, model=name, method=\"LS\",\n",
    "                y=float(y_best), runtime=float(ls_time),\n",
    "                t_best=float(t_to_best(ls_hist, y_best)),\n",
    "                iters=int(len(ls_hist)-1),\n",
    "                status=None, gap=None,\n",
    "                x=str(np.asarray(x_best, int).tolist()),\n",
    "                true_y=float(eval_true_obj(gt, x_best)),\n",
    "                err=None\n",
    "            ))\n",
    "        except Exception as e:\n",
    "            ls_time = time.perf_counter() - t0\n",
    "            opt_rows.append(dict(\n",
    "                seed=seed, model=name, method=\"LS\",\n",
    "                y=np.nan, runtime=float(ls_time),\n",
    "                t_best=np.nan, iters=np.nan,\n",
    "                status=None, gap=None,\n",
    "                x=None,\n",
    "                true_y=np.nan,\n",
    "                err=repr(e)\n",
    "            ))\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"LS\", error=repr(e)))\n",
    "\n",
    "        # ---- IP SOLVE ----\n",
    "        t0 = time.perf_counter()\n",
    "        try:\n",
    "            x_ip, y_ip, info = solve_ip(\n",
    "                model_type, model, scaler, xmin, xmax, sum_eq,\n",
    "                time_limit=time_limit, verbose=True\n",
    "            )\n",
    "            ip_time = time.perf_counter() - t0\n",
    "\n",
    "            rel_err = check_ip_matches_obj(name, obj, x_ip, y_ip, tol=IP_CHECK_TOL)\n",
    "            if rel_err > IP_CHECK_TOL:\n",
    "                fail_rows.append(dict(seed=seed, model=name, stage=\"IP_CHECK\",\n",
    "                                      error=f\"rel_err={rel_err:.3e} (tol={IP_CHECK_TOL})\"))\n",
    "\n",
    "            opt_rows.append(dict(\n",
    "                seed=seed, model=name, method=\"IP\",\n",
    "                y=float(y_ip), runtime=float(ip_time),\n",
    "                t_best=np.nan, iters=np.nan,\n",
    "                status=(info.get(\"status\") if isinstance(info, dict) else None),\n",
    "                gap=(info.get(\"gap\") if isinstance(info, dict) else None),\n",
    "                x=str(np.asarray(x_ip, int).tolist()),\n",
    "                true_y=float(eval_true_obj(gt, x_ip)),\n",
    "                err=None,\n",
    "                ip_rel_err=float(rel_err),\n",
    "            ))\n",
    "        except Exception as e:\n",
    "            ip_time = time.perf_counter() - t0\n",
    "            opt_rows.append(dict(\n",
    "                seed=seed, model=name, method=\"IP\",\n",
    "                y=np.nan, runtime=float(ip_time),\n",
    "                t_best=np.nan, iters=np.nan,\n",
    "                status=None, gap=None,\n",
    "                x=None,\n",
    "                true_y=np.nan,\n",
    "                err=repr(e),\n",
    "                ip_rel_err=np.nan\n",
    "            ))\n",
    "            fail_rows.append(dict(seed=seed, model=name, stage=\"IP\", error=repr(e)))\n",
    "\n",
    "# ---------- 5) TABLES ----------\n",
    "spec_df  = pd.DataFrame(spec_rows).drop_duplicates(\"model\").sort_values(\"model\").reset_index(drop=True)\n",
    "learn_df = pd.DataFrame(learn_rows).sort_values([\"model\",\"seed\"]).reset_index(drop=True)\n",
    "opt_df   = pd.DataFrame(opt_rows).sort_values([\"model\",\"seed\",\"method\"]).reset_index(drop=True)\n",
    "\n",
    "fail_df = pd.DataFrame(fail_rows)\n",
    "if fail_df.empty:\n",
    "    fail_df = pd.DataFrame(columns=[\"seed\",\"model\",\"stage\",\"error\"])\n",
    "else:\n",
    "    for c in [\"stage\",\"model\",\"seed\"]:\n",
    "        if c not in fail_df.columns:\n",
    "            fail_df[c] = np.nan\n",
    "    fail_df = fail_df.sort_values([\"stage\",\"model\",\"seed\"]).reset_index(drop=True)\n",
    "\n",
    "# Per-seed per-model LS vs IP % gap (minimization): (LS - IP)/|IP|\n",
    "gap_seed_df = pd.DataFrame(columns=[\"seed\",\"model\",\"ls_vs_ip_pct\"])\n",
    "if not opt_df.empty:\n",
    "    pivot = opt_df.pivot_table(index=[\"seed\",\"model\"], columns=\"method\", values=\"y\", aggfunc=\"first\")\n",
    "    if (\"LS\" in pivot.columns) and (\"IP\" in pivot.columns):\n",
    "        pivot[\"ls_vs_ip_pct\"] = 100.0 * (pivot[\"LS\"] - pivot[\"IP\"]) / (np.abs(pivot[\"IP\"]) + 1e-12)\n",
    "        gap_seed_df = pivot.reset_index()[[\"seed\",\"model\",\"ls_vs_ip_pct\"]]\n",
    "        opt_df = opt_df.merge(gap_seed_df, on=[\"seed\",\"model\"], how=\"left\")\n",
    "    else:\n",
    "        opt_df[\"ls_vs_ip_pct\"] = np.nan\n",
    "\n",
    "# Aggregate (mean ± SE across seeds)\n",
    "learn_agg = []\n",
    "for model in sorted(learn_df[\"model\"].unique()):\n",
    "    sub = learn_df[learn_df[\"model\"] == model]\n",
    "    row = {\"model\": model, \"n\": int(sub[\"seed\"].nunique())}\n",
    "    for col in [\"train_time\",\"best_val\",\"train_raw\",\"val_raw\",\"test_raw\"]:\n",
    "        m, se, n = mean_se(sub[col])\n",
    "        row[col] = fmt_mean_se(m, se)\n",
    "        row[col+\"_n\"] = n\n",
    "    row[\"n_eval_err\"] = int(sub[\"train_err\"].notna().sum())\n",
    "    learn_agg.append(row)\n",
    "learn_agg_df = pd.DataFrame(learn_agg).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "opt_agg = []\n",
    "for model in sorted(opt_df[\"model\"].unique()):\n",
    "    sub = opt_df[opt_df[\"model\"] == model]\n",
    "    row = {\"model\": model, \"n_seeds\": int(sub[\"seed\"].nunique())}\n",
    "\n",
    "    for method in [\"LS\",\"IP\"]:\n",
    "        s = sub[sub[\"method\"] == method]\n",
    "        m, se, n = mean_se(s[\"y\"])\n",
    "        row[f\"{method}_y\"] = fmt_mean_se(m, se)\n",
    "        row[f\"{method}_y_n\"] = n\n",
    "\n",
    "        # True objective at the returned x (new)\n",
    "        if \"true_y\" in s.columns:\n",
    "            m, se, n = mean_se(s[\"true_y\"])\n",
    "            row[f\"{method}_true_y\"] = fmt_mean_se(m, se)\n",
    "            row[f\"{method}_true_y_n\"] = n\n",
    "        else:\n",
    "            row[f\"{method}_true_y\"] = \"nan\"\n",
    "            row[f\"{method}_true_y_n\"] = 0\n",
    "\n",
    "        m, se, n = mean_se(s[\"runtime\"])\n",
    "        row[f\"{method}_time\"] = fmt_mean_se(m, se)\n",
    "        row[f\"{method}_time_n\"] = n\n",
    "\n",
    "        row[f\"{method}_fails\"] = int(s[\"y\"].isna().sum())\n",
    "\n",
    "    g = gap_seed_df[gap_seed_df[\"model\"] == model][\"ls_vs_ip_pct\"] if not gap_seed_df.empty else []\n",
    "    m, se, n = mean_se(g)\n",
    "    row[\"LS_vs_IP_%\"] = fmt_mean_se(m, se)\n",
    "    row[\"LS_vs_IP_%_n\"] = n\n",
    "\n",
    "    ip_rel = sub[sub[\"method\"]==\"IP\"][\"ip_rel_err\"] if \"ip_rel_err\" in sub.columns else pd.Series([], dtype=float)\n",
    "    m, se, n = mean_se(ip_rel)\n",
    "    row[\"IP_obj_rel_err\"] = fmt_mean_se(m, se)\n",
    "    row[\"IP_obj_rel_err_n\"] = n\n",
    "\n",
    "    opt_agg.append(row)\n",
    "opt_agg_df = pd.DataFrame(opt_agg).sort_values(\"model\").reset_index(drop=True)\n",
    "\n",
    "print(\"\\n=== MODEL SPECS (from seed 0 run) ===\")\n",
    "print(spec_df.to_string(index=False))\n",
    "\n",
    "print(\"\\n=== LEARNING SUMMARY (mean ± SE over seeds) ===\")\n",
    "print(learn_agg_df.to_string(index=False))\n",
    "\n",
    "print(\"\\n=== OPTIMIZATION SUMMARY (mean ± SE over seeds) ===\")\n",
    "print(opt_agg_df.to_string(index=False))\n",
    "\n",
    "print(\"\\n=== FAILURES / WARNINGS (if any) ===\")\n",
    "if fail_df.shape[0] == 0:\n",
    "    print(\"None\")\n",
    "else:\n",
    "    print(fail_df.to_string(index=False))\n",
    "\n",
    "# display(learn_df)\n",
    "# display(opt_df)\n",
    "# display(fail_df)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "83438b38-642d-4603-822d-26c02ebd4818",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:dfn]",
   "language": "python",
   "name": "conda-env-dfn-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
