{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import gurobipy as gp\n",
    "from gurobipy import GRB\n",
    "\n",
    "import numpy as np \n",
    "import scipy.optimize as opt\n",
    "import scipy as sc\n",
    "import torch \n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "import matplotlib.pyplot as plt \n",
    "\n",
    "from baselines import nominal_portfolio, sample_robust\n",
    "from maximal import solve_maximal\n",
    "\n",
    "import torch \n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from torch.distributions.normal import Normal\n",
    "# from torch.distributions.multivariate_normal import MultivariateNormal\n",
    "\n",
    "# n = 10\n",
    "# vec = torch.ones(n)\n",
    "# vec[-1] = 10\n",
    "# generator = MultivariateNormal(torch.arange(1, n+1, 1).float(), torch.diag(vec).float())\n",
    "# # generator = MultivariateNormal(torch.arange(1, n, 1).float(), torch.diag(torch.tensor([i * i * i for i in range(1, n)]).float()))\n",
    "\n",
    "# normal = Normal(torch.tensor([0.0]), torch.tensor([1.0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "QUANTILE = 0.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[*********************100%%**********************]  8 of 8 completed\n",
      "                  AAPL        AMZN       GOOG         JPM         MCD  \\\n",
      "Date                                                                    \n",
      "2021-01-04  127.331696  159.331497  86.412003  116.437096  197.740234   \n",
      "2021-01-05  128.905975  160.925507  87.045998  117.070679  198.925446   \n",
      "2021-01-06  124.566826  156.919006  86.764503  122.567833  198.473923   \n",
      "2021-01-07  128.817429  158.108002  89.362503  126.592834  199.395752   \n",
      "2021-01-08  129.929306  159.134995  90.360497  126.732620  203.054810   \n",
      "\n",
      "                  META        TSLA          ZM  \n",
      "Date                                            \n",
      "2021-01-04  268.940002  243.256668  359.980011  \n",
      "2021-01-05  270.970001  245.036667  360.829987  \n",
      "2021-01-06  263.309998  251.993332  344.410004  \n",
      "2021-01-07  268.739990  272.013336  342.500000  \n",
      "2021-01-08  267.570007  293.339996  349.609985  \n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "tickers_list = ['JPM', 'AMZN', 'TSLA', 'AAPL', 'GOOG', 'ZM', 'META', 'MCD']\n",
    "\n",
    "# Fetch the data\n",
    "import yfinance as yf\n",
    "data = yf.download(tickers_list,'2021-1-2')['Adj Close']\n",
    "\n",
    "# Print first 5 rows of the data\n",
    "print(data.head())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 8\n",
    "s = int(len(data) * 0.8)\n",
    "\n",
    "np.random.seed(42)\n",
    "\n",
    "# train_data = data.iloc[:s].values / np.mean(data.iloc[:s].values, axis = 0)\n",
    "# test_data = data.iloc[s:].values / np.mean(data.iloc[:s].values, axis = 0)\n",
    "keep = np.random.choice(len(data), s, replace=False)\n",
    "train_data = data.iloc[keep].values\n",
    "test_data = data.iloc[1 - keep].values \n",
    "\n",
    "# train_data = data.iloc[keep].values / np.mean(data.iloc[keep].values, axis = 0) #** 2\n",
    "# test_data = data.iloc[1 - keep].values / np.mean(data.iloc[keep].values, axis = 0)# ** 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 18.74891702  28.57814932  17.40693414  14.90261346  25.64454971\n",
      "  78.34593338  58.42388022 118.39553128]\n",
      "[152.04834317 138.70420621 118.6613247  136.32549798 245.9942902\n",
      " 247.28518674 249.19806601 174.45281723]\n"
     ]
    }
   ],
   "source": [
    "print(np.std(train_data, axis=0))\n",
    "print(np.mean(train_data, axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "alpha = [1]               # linear terms of the piecewise utility function\n",
    "beta = [0]             # constant terms of the piecewise utility function\n",
    "\n",
    "mu = np.mean(train_data, axis=0)         # the expected values of stock returns\n",
    "sigma = np.std(train_data, axis=0)             # variance of stock returns\n",
    "Sigma = np.cov(train_data)       # covariance matrix of stock returns\n",
    "d_ub = np.max(train_data, axis=0)        # upper bounds of stock returns\n",
    "d_lb = np.min(train_data, axis=0)      # lower bounds of stock returns\n",
    "\n",
    "J = len(mu)                     # number of stocks\n",
    "K = len(alpha)                  # number of pieces of the utility function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from rsome import dro                        # import the dro module\n",
    "# from rsome import E                          # import the notion of expectation\n",
    "# from rsome import square                     # import the square function\n",
    "# from rsome import grb_solver as grb          # import the interface for Gurobi\n",
    "\n",
    "# model = dro.Model()                          # create an RSOME DRO model\n",
    "\n",
    "# d = model.rvar(J)                            # J random variables as an array d\n",
    "# u = model.rvar(J+1)                          # J+1 random variables as an array u\n",
    "# fset = model.ambiguity()                     # create an ambiguity set\n",
    "# fset.suppset(d >= d_lb, d <= d_ub,\n",
    "#              square(d-mu) <= u[:-1],\n",
    "#              square((d-mu).sum()) <= u[-1])  # support of random variables\n",
    "# fset.exptset(E(d) == mu,\n",
    "#              E(u[:-1]) <= sigma**2,\n",
    "#              E(u[-1]) <= Sigma.sum())        # uncertainty set of expectations\n",
    "\n",
    "# x = model.dvar(J)                            # J decision variables as an array x\n",
    "# y = model.dvar()                             # 1 decision variable as y\n",
    "# y.adapt(d)                                   # y affinely adapts to d\n",
    "# y.adapt(u)                                   # y affinely adapts to u\n",
    "\n",
    "# model.maxinf(E(y), fset)                     # worst-case expectation over fset\n",
    "# model.st(y <= a*(d@x) + b\n",
    "#          for a, b in zip(alpha, beta))       # piecewise linear constraints\n",
    "# model.st(x.sum() == 1, x >= 0)               # constraints of x\n",
    "\n",
    "# model.solve(grb)                             # solve the model by Gurobi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "QUANTILE = 0.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "from timer import Benchmark\n",
    "timer = Benchmark()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "from rsome import ro\n",
    "import rsome as rso\n",
    "from rsome import msk_solver as msk\n",
    "\n",
    "\n",
    "def fd_robust(epsilon, timeit = False):\n",
    "    timer.__enter__()\n",
    "\n",
    "    model = ro.Model()\n",
    "    s = len(train_data)\n",
    "    y = train_data\n",
    "    x_lb = np.zeros(n)  # lower bounds of investment decisions\n",
    "    x_ub = np.ones(n)   # upper bounds of investment decisions\n",
    "\n",
    "    pi = model.rvar(s)\n",
    "    uset = (pi.sum() == 1, pi >= 0,\n",
    "            rso.norm(pi - 1/s, 1) <= epsilon)    # uncertainty set of pi\n",
    "\n",
    "    x = model.dvar(n)\n",
    "    u = model.dvar(s)\n",
    "\n",
    "    model.maxmin(pi @ (y @ x), uset)\n",
    "    model.st(x >= x_lb, x <= x_ub, x.sum() == 1)\n",
    "\n",
    "    model.solve(msk)\n",
    "    runtime = timer.__exit__()\n",
    "    if timeit: return x.get(), runtime\n",
    "    return x.get()\n",
    "\n",
    "def kld_robust(epsilon, timeit = False):\n",
    "    timer.__enter__()\n",
    "    \n",
    "    model = ro.Model()\n",
    "    s = len(train_data)\n",
    "    y = train_data\n",
    "    x_lb = np.zeros(n)  # lower bounds of investment decisions\n",
    "    x_ub = np.ones(n)   # upper bounds of investment decisions\n",
    "\n",
    "    pi = model.rvar(s)\n",
    "    uset = (pi.sum() == 1, pi >= 0,\n",
    "            rso.kldiv(pi, 1/s, epsilon))    # uncertainty set of pi\n",
    "\n",
    "    x = model.dvar(n)\n",
    "    u = model.dvar(s)\n",
    "\n",
    "    model.maxmin(pi @ (y @ x), uset)\n",
    "    model.st(x >= x_lb, x <= x_ub, x.sum() == 1)\n",
    "\n",
    "    model.solve(msk)\n",
    "\n",
    "    runtime = timer.__exit__()\n",
    "    if timeit: return x.get(), runtime\n",
    "    return x.get()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0248s\n",
      "Elapsed Time: 0.3855019000475295\n",
      "119.17199783325195\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0338s\n",
      "Elapsed Time: 0.41292040003463626\n",
      "119.17199774477962\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0289s\n",
      "Elapsed Time: 0.3910884000360966\n",
      "119.17199771924183\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0328s\n",
      "Elapsed Time: 0.4120276000467129\n",
      "196.48134080786068\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0246s\n",
      "Elapsed Time: 0.3979962000157684\n",
      "203.82499282923987\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0267s\n",
      "Elapsed Time: 0.39449959999183193\n",
      "205.7897581484867\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0273s\n",
      "Elapsed Time: 0.38914130005287006\n",
      "206.56665930916805\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0248s\n",
      "Elapsed Time: 0.3885825999896042\n",
      "207.6918755093782\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0241s\n",
      "Elapsed Time: 0.39176560001214966\n",
      "208.34308000187917\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0256s\n",
      "Elapsed Time: 0.3775488000246696\n",
      "209.0236081045542\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0237s\n",
      "Elapsed Time: 0.38874580000992864\n",
      "208.8959857639597\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0283s\n",
      "Elapsed Time: 0.39427099999738857\n",
      "208.50065531401486\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0251s\n",
      "Elapsed Time: 0.4013604000210762\n",
      "208.49032948787797\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0254s\n",
      "Elapsed Time: 0.42337719997158274\n",
      "208.49032948931028\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0281s\n",
      "Elapsed Time: 0.39456479996442795\n",
      "208.49032948561683\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0271s\n",
      "Elapsed Time: 0.39099779998650774\n",
      "208.49032948456593\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0253s\n",
      "Elapsed Time: 0.39185799995902926\n",
      "208.4903294845659\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0279s\n",
      "Elapsed Time: 0.39571949996752664\n",
      "208.4903294845659\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0258s\n",
      "Elapsed Time: 0.40201050002360716\n",
      "208.57088042311426\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0249s\n",
      "Elapsed Time: 0.39081450004596263\n",
      "208.98684828679103\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0258s\n",
      "Elapsed Time: 0.3911852999590337\n",
      "209.9374090408456\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0243s\n",
      "Elapsed Time: 0.38950430002296343\n",
      "210.35287522866372\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0316s\n",
      "Elapsed Time: 0.4002108999993652\n",
      "210.21230756967594\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0258s\n",
      "Elapsed Time: 0.3978266000049189\n",
      "210.09478426050103\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0270s\n",
      "Elapsed Time: 0.37589659995865077\n",
      "210.02904360757756\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0265s\n",
      "Elapsed Time: 0.40428329998394474\n",
      "209.98198440199658\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0247s\n",
      "Elapsed Time: 0.39053119998425245\n",
      "209.9819835654911\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0258s\n",
      "Elapsed Time: 0.4058494999771938\n",
      "209.98198356660436\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0276s\n",
      "Elapsed Time: 0.39457629999378696\n",
      "209.98198356694658\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0299s\n",
      "Elapsed Time: 0.40929860004689544\n",
      "209.9819835669258\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0314s\n",
      "Elapsed Time: 0.40459190000547096\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0289s\n",
      "Elapsed Time: 0.4005620999960229\n",
      "209.98198356722764\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0283s\n",
      "Elapsed Time: 0.40518890001112595\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0250s\n",
      "Elapsed Time: 0.37246039998717606\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0240s\n",
      "Elapsed Time: 0.3918810000177473\n",
      "209.9819835669349\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0261s\n",
      "Elapsed Time: 0.39125360001344234\n",
      "209.93474754516032\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0268s\n",
      "Elapsed Time: 0.4064702999894507\n",
      "209.9422384476939\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0319s\n",
      "Elapsed Time: 0.3987362000043504\n",
      "209.938127698207\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0310s\n",
      "Elapsed Time: 0.3892627999885008\n",
      "209.91958791163864\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0264s\n",
      "Elapsed Time: 0.4005526000401005\n",
      "209.9589949321931\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0318s\n",
      "Elapsed Time: 0.3995373999932781\n",
      "209.9760883537883\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0362s\n",
      "Elapsed Time: 0.4112641999963671\n",
      "209.98198356689318\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0343s\n",
      "Elapsed Time: 0.40399650001199916\n",
      "209.98198356692572\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0294s\n",
      "Elapsed Time: 0.3995267999707721\n",
      "209.9819835624479\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0251s\n",
      "Elapsed Time: 0.400924599962309\n",
      "209.98198356269074\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0289s\n",
      "Elapsed Time: 0.4885764000355266\n",
      "209.98198356692845\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0249s\n",
      "Elapsed Time: 0.3847191000240855\n",
      "209.98198355366614\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0303s\n",
      "Elapsed Time: 0.4112763000302948\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0386s\n",
      "Elapsed Time: 0.4301566999638453\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0255s\n",
      "Elapsed Time: 0.39408880000701174\n",
      "209.9819835662677\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0249s\n",
      "Elapsed Time: 0.39068650000263005\n",
      "209.98198353041943\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0282s\n",
      "Elapsed Time: 0.4097104999818839\n",
      "209.9819835669349\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0308s\n",
      "Elapsed Time: 0.42269899998791516\n",
      "209.98198356651375\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0389s\n",
      "Elapsed Time: 0.4282907999586314\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0313s\n",
      "Elapsed Time: 0.39814889995614067\n",
      "209.98198356580832\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0292s\n",
      "Elapsed Time: 0.38759949995437637\n",
      "209.98198348392808\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0280s\n",
      "Elapsed Time: 0.4021649999776855\n",
      "209.98198356693496\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0324s\n",
      "Elapsed Time: 0.4229588999878615\n",
      "209.9819835657444\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0332s\n",
      "Elapsed Time: 0.4200509999645874\n",
      "209.98198356693496\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0286s\n",
      "Elapsed Time: 0.3855176999932155\n",
      "209.98198356690784\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0399s\n",
      "Elapsed Time: 0.4047275999910198\n",
      "209.98198356693496\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0453s\n",
      "Elapsed Time: 0.42886649997672066\n",
      "209.98198356689784\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0360s\n",
      "Elapsed Time: 0.3958621999481693\n",
      "209.9819835669349\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0434s\n",
      "Elapsed Time: 0.43097450002096593\n",
      "209.98198356693496\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0361s\n",
      "Elapsed Time: 0.4161141000222415\n",
      "209.9819835667191\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0337s\n",
      "Elapsed Time: 0.40358710003783926\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0407s\n",
      "Elapsed Time: 0.42769060004502535\n",
      "209.98198356693493\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0333s\n",
      "Elapsed Time: 0.3969414999592118\n",
      "209.98198356560047\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0295s\n",
      "Elapsed Time: 0.4025420999969356\n",
      "209.98198356704341\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0343s\n",
      "Elapsed Time: 0.40795969997998327\n",
      "209.98198356693496\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0428s\n",
      "Elapsed Time: 0.4156411999720149\n",
      "209.98198356193154\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0478s\n",
      "Elapsed Time: 0.45508119999431074\n",
      "209.98198356693499\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0275s\n",
      "Elapsed Time: 0.40397349995328113\n",
      "209.98198356562654\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0432s\n",
      "Elapsed Time: 0.4198253999929875\n",
      "209.98198351077923\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0315s\n",
      "Elapsed Time: 0.4061630999785848\n",
      "209.9819835671567\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0396s\n",
      "Elapsed Time: 0.44188040000153705\n",
      "209.98198353576586\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0475s\n",
      "Elapsed Time: 0.4441540000261739\n",
      "210.22678251463145\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0301s\n",
      "Elapsed Time: 0.40320649999193847\n",
      "210.41733433863246\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0263s\n",
      "Elapsed Time: 0.4012786999810487\n",
      "210.76834332509625\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0508s\n",
      "Elapsed Time: 0.4435669000376947\n",
      "210.73177512445662\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0336s\n",
      "Elapsed Time: 0.4506299999775365\n",
      "210.53414344821434\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0326s\n",
      "Elapsed Time: 0.446479799982626\n",
      "210.4701598987814\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0322s\n",
      "Elapsed Time: 0.4621725999750197\n",
      "210.47015989895385\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0451s\n",
      "Elapsed Time: 0.46342589997220784\n",
      "210.47015989878136\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0400s\n",
      "Elapsed Time: 0.45793010003399104\n",
      "210.4701598987845\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0352s\n",
      "Elapsed Time: 0.4424447000492364\n",
      "210.47015989878227\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0274s\n",
      "Elapsed Time: 0.42661779996706173\n",
      "210.47015989871386\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0360s\n",
      "Elapsed Time: 0.4461066999938339\n",
      "210.47015989881297\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0311s\n",
      "Elapsed Time: 0.4733554000267759\n",
      "210.47015989777194\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0269s\n",
      "Elapsed Time: 0.44357309996848926\n",
      "210.47015989574402\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0264s\n",
      "Elapsed Time: 0.4320282000117004\n",
      "210.47015989877912\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0320s\n",
      "Elapsed Time: 0.41088069998659194\n",
      "210.47015989870377\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0376s\n",
      "Elapsed Time: 0.45201220002491027\n",
      "210.47015989873324\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0334s\n",
      "Elapsed Time: 0.41769139998359606\n",
      "210.4701598987831\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0362s\n",
      "Elapsed Time: 0.42545800004154444\n",
      "210.47015989877585\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0262s\n",
      "Elapsed Time: 0.39722909999545664\n",
      "210.4701598987814\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0323s\n",
      "Elapsed Time: 0.4253474000142887\n",
      "210.47015989878142\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0338s\n",
      "Elapsed Time: 0.432637199992314\n",
      "210.47015989900257\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0338s\n",
      "Elapsed Time: 0.4459396999445744\n",
      "210.4701598987814\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0251s\n",
      "Elapsed Time: 0.42560159997083247\n",
      "210.47015989878136\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0292s\n",
      "Elapsed Time: 0.4106829999946058\n",
      "210.47015989867836\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0394s\n",
      "Elapsed Time: 0.4321844999794848\n",
      "210.47015989878577\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0329s\n",
      "Elapsed Time: 0.4151300999801606\n",
      "210.47015989878133\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0324s\n",
      "Elapsed Time: 0.42082969995681196\n",
      "210.47015989878147\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0400s\n",
      "Elapsed Time: 0.42847729998175055\n",
      "210.47015989878142\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0279s\n",
      "Elapsed Time: 0.4116185000166297\n",
      "210.4701598987814\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0287s\n",
      "Elapsed Time: 0.42141449998598546\n",
      "210.4701599200285\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0378s\n",
      "Elapsed Time: 0.41624590003630146\n",
      "210.51820030978158\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0383s\n",
      "Elapsed Time: 0.4217555999639444\n",
      "210.54094552496994\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0326s\n",
      "Elapsed Time: 0.41376510000554845\n",
      "210.55847240592593\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0437s\n",
      "Elapsed Time: 0.43424799997592345\n",
      "210.56064590080072\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0277s\n",
      "Elapsed Time: 0.4034465999575332\n",
      "210.56355627918546\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0281s\n",
      "Elapsed Time: 0.40612070000497624\n",
      "210.607849253063\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0313s\n",
      "Elapsed Time: 0.40968299994710833\n",
      "210.64369140926274\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0431s\n",
      "Elapsed Time: 0.4279892000486143\n",
      "210.70747827827142\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0285s\n",
      "Elapsed Time: 0.43527180003002286\n",
      "210.7480811191291\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0352s\n",
      "Elapsed Time: 0.44404229999054223\n",
      "210.7393634112008\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0436s\n",
      "Elapsed Time: 0.42572940001264215\n",
      "210.73337250798792\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0312s\n",
      "Elapsed Time: 0.4189811000251211\n",
      "210.7120364542372\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0295s\n",
      "Elapsed Time: 0.41968079999787733\n",
      "210.604527460166\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0315s\n",
      "Elapsed Time: 0.4249067999771796\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0260s\n",
      "Elapsed Time: 0.3989125000080094\n",
      "210.60725838583969\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0372s\n",
      "Elapsed Time: 0.43043850001413375\n",
      "210.60725838758685\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0296s\n",
      "Elapsed Time: 0.4124071000260301\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0386s\n",
      "Elapsed Time: 0.4256230000173673\n",
      "210.6072583875869\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0261s\n",
      "Elapsed Time: 0.4725103999953717\n",
      "210.60725838775295\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0307s\n",
      "Elapsed Time: 0.4113814000156708\n",
      "210.60725838758685\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0299s\n",
      "Elapsed Time: 0.41815219999989495\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0465s\n",
      "Elapsed Time: 0.43776910001179203\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0314s\n",
      "Elapsed Time: 0.4361930000013672\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0375s\n",
      "Elapsed Time: 0.4249277000199072\n",
      "210.60725838842782\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0353s\n",
      "Elapsed Time: 0.42217239999445155\n",
      "210.60725840403074\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0381s\n",
      "Elapsed Time: 0.4363191000302322\n",
      "210.60725853398236\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0445s\n",
      "Elapsed Time: 0.4417347999988124\n",
      "210.62324435169467\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0360s\n",
      "Elapsed Time: 0.4141679999884218\n",
      "210.66693332408934\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0360s\n",
      "Elapsed Time: 0.41966499999398366\n",
      "210.68313945195746\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0325s\n",
      "Elapsed Time: 0.41793840000173077\n",
      "210.66090116506962\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0381s\n",
      "Elapsed Time: 0.4227264000219293\n",
      "210.65158651639504\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0290s\n",
      "Elapsed Time: 0.42891290003899485\n",
      "210.67798291142506\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0300s\n",
      "Elapsed Time: 0.42348980001406744\n",
      "210.70377853924646\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0326s\n",
      "Elapsed Time: 0.41255700000328943\n",
      "210.70909190280472\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0373s\n",
      "Elapsed Time: 0.40749750001123175\n",
      "210.70551238896903\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0388s\n",
      "Elapsed Time: 0.4207159000216052\n",
      "210.70332326078073\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0420s\n",
      "Elapsed Time: 0.4211520000244491\n",
      "210.7010235820521\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0327s\n",
      "Elapsed Time: 0.41140460001770407\n",
      "210.69464457680428\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0384s\n",
      "Elapsed Time: 0.4282731999992393\n",
      "210.72237969110304\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0313s\n",
      "Elapsed Time: 0.4118540000054054\n",
      "210.7279845741986\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0348s\n",
      "Elapsed Time: 0.4242456000065431\n",
      "210.73219168856957\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0276s\n",
      "Elapsed Time: 0.4143500999780372\n",
      "210.70164976241918\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0393s\n",
      "Elapsed Time: 0.43012829998042434\n",
      "210.67946929184734\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0388s\n",
      "Elapsed Time: 0.4200049000210129\n",
      "210.68291569535324\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0301s\n",
      "Elapsed Time: 0.4118665999849327\n",
      "210.6614539436263\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0378s\n",
      "Elapsed Time: 0.4292805000441149\n",
      "210.6882603052964\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0379s\n",
      "Elapsed Time: 0.45424829999683425\n",
      "210.69530520960717\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0339s\n",
      "Elapsed Time: 0.42988060001516715\n",
      "210.7099099031782\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0321s\n",
      "Elapsed Time: 0.4206403999705799\n",
      "210.73410683857412\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0544s\n",
      "Elapsed Time: 0.44339820003369823\n",
      "210.74350223429244\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0321s\n",
      "Elapsed Time: 0.4281135000055656\n",
      "210.7368914122752\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0301s\n",
      "Elapsed Time: 0.4324046999681741\n",
      "210.73193313856595\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0473s\n",
      "Elapsed Time: 0.4653180000022985\n",
      "210.74629767594303\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0375s\n",
      "Elapsed Time: 0.4289651000290178\n",
      "210.75419858943087\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0296s\n",
      "Elapsed Time: 0.4116337000159547\n",
      "210.77247309456246\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0446s\n",
      "Elapsed Time: 0.43614160001743585\n",
      "210.76519212901437\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0420s\n",
      "Elapsed Time: 0.43466550001176074\n",
      "210.76707137449463\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0393s\n",
      "Elapsed Time: 0.41758670000126585\n",
      "210.7772888085874\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0310s\n",
      "Elapsed Time: 0.41240380000090227\n",
      "210.72375110594908\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0368s\n",
      "Elapsed Time: 0.4408873000065796\n",
      "210.75223641648273\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0307s\n",
      "Elapsed Time: 0.41425839997828007\n",
      "210.7303601868762\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0392s\n",
      "Elapsed Time: 0.41726189997280017\n",
      "210.70287096694707\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0273s\n",
      "Elapsed Time: 0.4137789999949746\n",
      "210.7028709674164\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0441s\n",
      "Elapsed Time: 0.42499149998184294\n",
      "210.7028709691984\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0298s\n",
      "Elapsed Time: 0.40732989995740354\n",
      "210.70287100209694\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0433s\n",
      "Elapsed Time: 0.4193849000148475\n",
      "210.71283916365573\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0579s\n",
      "Elapsed Time: 0.45009210001444444\n",
      "210.75046386825423\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0309s\n",
      "Elapsed Time: 0.4257505999994464\n",
      "210.7566159375333\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0374s\n",
      "Elapsed Time: 0.4267486999742687\n",
      "210.77289051627346\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0328s\n",
      "Elapsed Time: 0.42137060000095516\n",
      "210.77769935665827\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0584s\n",
      "Elapsed Time: 0.4486571999732405\n",
      "210.74767075899192\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0300s\n",
      "Elapsed Time: 0.4073851999710314\n",
      "210.72804673770935\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0307s\n",
      "Elapsed Time: 0.4051636999938637\n",
      "210.75180351326057\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0317s\n",
      "Elapsed Time: 0.4223212000215426\n",
      "210.73204055765265\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0397s\n",
      "Elapsed Time: 0.42953109997324646\n",
      "210.7098806605326\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0303s\n",
      "Elapsed Time: 0.3963803999940865\n",
      "210.69292717601616\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0316s\n",
      "Elapsed Time: 0.40630039997631684\n",
      "210.64196656173428\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0584s\n",
      "Elapsed Time: 0.4457622999907471\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0306s\n",
      "Elapsed Time: 0.410255899943877\n",
      "210.62497055567937\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0477s\n",
      "Elapsed Time: 0.42193650000263005\n",
      "210.60725840681744\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0331s\n",
      "Elapsed Time: 0.40755550004541874\n",
      "210.6072583883676\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0397s\n",
      "Elapsed Time: 0.4252359999809414\n",
      "210.60725838758685\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0399s\n",
      "Elapsed Time: 0.4232833000132814\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0349s\n",
      "Elapsed Time: 0.42853149998700246\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0350s\n",
      "Elapsed Time: 0.4047551000257954\n",
      "210.60725838651683\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0415s\n",
      "Elapsed Time: 0.42872139997780323\n",
      "210.6072583875869\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0422s\n",
      "Elapsed Time: 0.4243119999882765\n",
      "210.60725838758682\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0363s\n",
      "Elapsed Time: 0.4162450999720022\n",
      "210.60725838758685\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0387s\n",
      "Elapsed Time: 0.4103184000123292\n",
      "210.60725838758688\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0476s\n",
      "Elapsed Time: 0.4306827000109479\n",
      "210.6072583875869\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0460s\n",
      "Elapsed Time: 0.42353849997743964\n",
      "210.60725838758694\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0541s\n",
      "Elapsed Time: 0.432176599977538\n",
      "210.6072583875869\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0515s\n",
      "Elapsed Time: 0.43412430002354085\n",
      "210.607258387587\n"
     ]
    }
   ],
   "source": [
    "qs_phi = []\n",
    "epsilons = np.arange(0, 2, 1e-2)\n",
    "phi_decisions = []\n",
    "vd_times = []\n",
    "# epsilons = [1e-2, 1e-1]\n",
    "for epsilon in epsilons:\n",
    "    x, vd_time = fd_robust(epsilon, timeit = True)\n",
    "    vd_times.append(vd_time)\n",
    "    phi_decisions.append(x)\n",
    "    qs_phi.append(np.quantile(test_data @ x, QUANTILE))\n",
    "    print(qs_phi[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0563s\n",
      "Elapsed Time: 3.346181600005366\n",
      "209.36335832173697\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0495s\n",
      "Elapsed Time: 3.2361536999815144\n",
      "209.26720245641297\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0458s\n",
      "Elapsed Time: 3.267583399952855\n",
      "209.2983232133963\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0506s\n",
      "Elapsed Time: 3.2378968999837525\n",
      "209.36216139271113\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0377s\n",
      "Elapsed Time: 3.245451900002081\n",
      "209.43778883303293\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0430s\n",
      "Elapsed Time: 3.196519899996929\n",
      "209.51792620798844\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0492s\n",
      "Elapsed Time: 3.131996000010986\n",
      "209.5993386739029\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0401s\n",
      "Elapsed Time: 3.26777169998968\n",
      "209.68220736077797\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0402s\n",
      "Elapsed Time: 3.240433499973733\n",
      "209.77260503874774\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0327s\n",
      "Elapsed Time: 3.27173129998846\n",
      "209.86074613655174\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0357s\n",
      "Elapsed Time: 3.1609285000013188\n",
      "209.94657355967507\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0343s\n",
      "Elapsed Time: 3.199678100005258\n",
      "210.03025617363866\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0445s\n",
      "Elapsed Time: 3.2572215999825858\n",
      "210.11778808622992\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0450s\n",
      "Elapsed Time: 3.1811877000145614\n",
      "211.12644335448942\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0376s\n",
      "Elapsed Time: 3.296331099991221\n",
      "211.9295199835476\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0351s\n",
      "Elapsed Time: 3.114376200013794\n",
      "212.56624797687482\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0321s\n",
      "Elapsed Time: 3.036508400051389\n",
      "213.08646191346904\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0314s\n",
      "Elapsed Time: 2.9839151999913156\n",
      "213.521550830968\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0346s\n",
      "Elapsed Time: 2.9022813999908976\n",
      "213.89199777459658\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0312s\n",
      "Elapsed Time: 3.029304600029718\n",
      "214.21254709607805\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0366s\n",
      "Elapsed Time: 2.9524102000286803\n",
      "214.49343758593233\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0339s\n",
      "Elapsed Time: 2.9998462999938056\n",
      "214.72835557446038\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0361s\n",
      "Elapsed Time: 3.0083063000347465\n",
      "214.80443451739728\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0380s\n",
      "Elapsed Time: 3.0195889999740757\n",
      "214.8228061426372\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0391s\n",
      "Elapsed Time: 3.107317799993325\n",
      "214.72351099791953\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0357s\n",
      "Elapsed Time: 2.939485000038985\n",
      "214.63143390845525\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0412s\n",
      "Elapsed Time: 3.015837199985981\n",
      "214.5454680769421\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0398s\n",
      "Elapsed Time: 2.963536600000225\n",
      "214.44254524123693\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0366s\n",
      "Elapsed Time: 3.0788156000198796\n",
      "214.34119006039617\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0336s\n",
      "Elapsed Time: 2.9903583000414073\n",
      "214.24600071034683\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0413s\n",
      "Elapsed Time: 2.9396025000023656\n",
      "214.15628830128276\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0339s\n",
      "Elapsed Time: 3.039727800001856\n",
      "214.15912368369\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0317s\n",
      "Elapsed Time: 2.895400800043717\n",
      "214.21217055207322\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0357s\n",
      "Elapsed Time: 2.9842902999953367\n",
      "214.23312381253342\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0359s\n",
      "Elapsed Time: 2.9352943999692798\n",
      "214.23474346729637\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0402s\n",
      "Elapsed Time: 2.920562200015411\n",
      "214.23422863851354\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0434s\n",
      "Elapsed Time: 3.027437100012321\n",
      "214.22528479284713\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0339s\n",
      "Elapsed Time: 2.938167300017085\n",
      "214.1734533997136\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0310s\n",
      "Elapsed Time: 2.9788546000490896\n",
      "214.18471453183722\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0347s\n",
      "Elapsed Time: 2.9348274000221863\n",
      "214.19657261652304\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0334s\n",
      "Elapsed Time: 2.9140495999599807\n",
      "214.20902470778665\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0325s\n",
      "Elapsed Time: 3.008537699992303\n",
      "214.20833191091634\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0318s\n",
      "Elapsed Time: 2.9371326999971643\n",
      "214.14686396304532\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0318s\n",
      "Elapsed Time: 3.023762400029227\n",
      "214.0880287581345\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0318s\n",
      "Elapsed Time: 2.9062846999731846\n",
      "214.0316326302687\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0391s\n",
      "Elapsed Time: 3.0306455999962054\n",
      "213.97766925800167\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0621s\n",
      "Elapsed Time: 3.0498418000061065\n",
      "213.92588149844454\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0366s\n",
      "Elapsed Time: 3.1267233000253327\n",
      "213.87619254185705\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0462s\n",
      "Elapsed Time: 3.260805200028699\n",
      "213.82849537837117\n"
     ]
    }
   ],
   "source": [
    "qs_kl = []\n",
    "epsilons = np.arange(5e-2, 2.5, 5e-2)\n",
    "kl_decisions = []\n",
    "kl_times = []\n",
    "# epsilons = [1e-2, 1e-1]\n",
    "for epsilon in epsilons:\n",
    "    x, tim = kld_robust(epsilon, timeit = True)\n",
    "    kl_decisions.append(x)\n",
    "    kl_times.append(tim)\n",
    "    qs_kl.append(np.quantile(test_data @ x, QUANTILE))\n",
    "    print(qs_kl[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1bbb4246eb0>]"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(epsilons[1:], qs_kl[1:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "214.8228061426372"
      ]
     },
     "execution_count": 48,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max(qs_kl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {},
   "outputs": [],
   "source": [
    "QUANTILE = 0.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0013s\n",
      "Elapsed Time: 0.23611309996340424\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0011s\n",
      "Elapsed Time: 0.23289420001674443\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.24635659996420145\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2307899000006728\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23543850000714883\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0017s\n",
      "Elapsed Time: 0.2468501000548713\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.24462140002287924\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23388149996753782\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23288949998095632\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23076060001039878\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2330288999946788\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0011s\n",
      "Elapsed Time: 0.2320307000190951\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23076469998341054\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0009s\n",
      "Elapsed Time: 0.24681969999801368\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0007s\n",
      "Elapsed Time: 0.24533010000595823\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0009s\n",
      "Elapsed Time: 0.23197259998414665\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.22915979998651892\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23230239999247715\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23235960002057254\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.234089000034146\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0017s\n",
      "Elapsed Time: 0.2510661999695003\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2417482000309974\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23149450001074\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23356219998095185\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23065570002654567\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0011s\n",
      "Elapsed Time: 0.24738869996508583\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23339130001841113\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23259679996408522\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23345930001232773\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23525700002210215\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2327738999738358\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2321387999691069\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0011s\n",
      "Elapsed Time: 0.23275900003500283\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.24677039997186512\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2337853999924846\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23453470005188137\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2352820000378415\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2327013000031002\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23196610005106777\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23303679999662563\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0010s\n",
      "Elapsed Time: 0.23467500001424924\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.24625610001385212\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23460640001576394\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.24789930001134053\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23410549998516217\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0011s\n",
      "Elapsed Time: 0.2336492000031285\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23077180003747344\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0015s\n",
      "Elapsed Time: 0.23347859998466447\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.23060150002129376\n",
      "Being solved by Gurobi...\n",
      "Solution status: 2\n",
      "Running time: 0.0000s\n",
      "Elapsed Time: 0.2318803000380285\n"
     ]
    }
   ],
   "source": [
    "from baselines import robust\n",
    "\n",
    "Ls = np.arange(0, 0.5, 0.01)\n",
    "robust_decisions = [] \n",
    "all_robust_vals = []\n",
    "robust_times = []\n",
    "for L in Ls:\n",
    "    L /= np.std(train_data)\n",
    "    # solver, obj, robust_sol = robust(np.arange(1, n, 1), np.arange(1, n, 1), L)\n",
    "    solver, obj, robust_sol, tim = robust(np.mean(train_data, axis=0),  np.std(train_data, axis=0) ** 2, L, timeit=True)\n",
    "\n",
    "    robust_decisions.append(robust_sol)\n",
    "    robust_times.append(tim)\n",
    "\n",
    "    robust_vals = np.dot(test_data, robust_sol)\n",
    "    all_robust_vals.append(robust_vals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x1bbb663d790>]"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(Ls, [np.quantile(robust_vals, QUANTILE) for robust_vals in all_robust_vals])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1.06212444e-08, 9.54033132e-09, 9.61381698e-09, 9.49599900e-09,\n",
       "       9.23746985e-01, 1.40324835e-02, 6.22204775e-02, 1.45906225e-08])"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "robust_sol"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "208.83008909110205\n"
     ]
    }
   ],
   "source": [
    "print(np.max([np.quantile(robust_vals, QUANTILE) for robust_vals in all_robust_vals]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0079s\n",
      "Elapsed Time: 0.22448350000195205\n",
      "84.9969985961914\n",
      "1\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0130s\n",
      "Elapsed Time: 0.31278620002558455\n",
      "119.28491096520246\n",
      "2\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0175s\n",
      "Elapsed Time: 0.23809619998792186\n",
      "3\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.253204700013157\n",
      "4\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0230s\n",
      "Elapsed Time: 0.24588890001177788\n",
      "5\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0092s\n",
      "Elapsed Time: 0.23623760003829375\n",
      "6\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.31310080003459007\n",
      "7\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0298s\n",
      "Elapsed Time: 0.254348199989181\n",
      "8\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0223s\n",
      "Elapsed Time: 0.24015359999611974\n",
      "9\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0223s\n",
      "Elapsed Time: 0.24608099996112287\n",
      "10\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0253s\n",
      "Elapsed Time: 0.2539460999541916\n",
      "11\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0100s\n",
      "Elapsed Time: 0.30862189998151734\n",
      "12\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0289s\n",
      "Elapsed Time: 0.2553298000129871\n",
      "13\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0131s\n",
      "Elapsed Time: 0.24314539995975792\n",
      "14\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0213s\n",
      "Elapsed Time: 0.24184229999082163\n",
      "15\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0098s\n",
      "Elapsed Time: 0.29925809998530895\n",
      "16\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.23590700002387166\n",
      "17\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.2466114000417292\n",
      "18\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0120s\n",
      "Elapsed Time: 0.232831500004977\n",
      "19\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.23002469999482855\n",
      "20\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0176s\n",
      "Elapsed Time: 0.3202000000164844\n",
      "21\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0242s\n",
      "Elapsed Time: 0.25350049999542534\n",
      "22\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0178s\n",
      "Elapsed Time: 0.25428829999873415\n",
      "23\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0178s\n",
      "Elapsed Time: 0.2484106000047177\n",
      "24\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.23872239998308942\n",
      "25\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0134s\n",
      "Elapsed Time: 0.3127972000511363\n",
      "26\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0297s\n",
      "Elapsed Time: 0.25099929998395965\n",
      "27\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0267s\n",
      "Elapsed Time: 0.2622832999913953\n",
      "28\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.24333450000267476\n",
      "29\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0130s\n",
      "Elapsed Time: 0.31600520003121346\n",
      "30\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.24457439995603636\n",
      "31\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0224s\n",
      "Elapsed Time: 0.24441829998977482\n",
      "32\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0200s\n",
      "Elapsed Time: 0.24728579999646172\n",
      "33\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0172s\n",
      "Elapsed Time: 0.24570839997613803\n",
      "34\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0129s\n",
      "Elapsed Time: 0.3072352000162937\n",
      "35\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0185s\n",
      "Elapsed Time: 0.23777639999752864\n",
      "36\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0094s\n",
      "Elapsed Time: 0.23892009997507557\n",
      "37\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0170s\n",
      "Elapsed Time: 0.2543440000154078\n",
      "38\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0146s\n",
      "Elapsed Time: 0.2932526000076905\n",
      "39\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0216s\n",
      "Elapsed Time: 0.2567879999987781\n",
      "40\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0207s\n",
      "Elapsed Time: 0.26075260003563017\n",
      "41\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0207s\n",
      "Elapsed Time: 0.24625969998305663\n",
      "42\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0217s\n",
      "Elapsed Time: 0.24807610001880676\n",
      "43\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0203s\n",
      "Elapsed Time: 0.3381643000175245\n",
      "44\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0218s\n",
      "Elapsed Time: 0.25109159998828545\n",
      "45\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0150s\n",
      "Elapsed Time: 0.2419655999983661\n",
      "46\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0224s\n",
      "Elapsed Time: 0.2596744999755174\n",
      "47\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.29603149998001754\n",
      "48\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0220s\n",
      "Elapsed Time: 0.24526090000290424\n",
      "49\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0206s\n",
      "Elapsed Time: 0.2449493000167422\n",
      "50\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0240s\n",
      "Elapsed Time: 0.2514593999949284\n",
      "51\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0129s\n",
      "Elapsed Time: 0.25288439996074885\n",
      "52\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0211s\n",
      "Elapsed Time: 0.30293850001180544\n",
      "53\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0118s\n",
      "Elapsed Time: 0.23887709999689832\n",
      "54\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0176s\n",
      "Elapsed Time: 0.23818550002761185\n",
      "55\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0132s\n",
      "Elapsed Time: 0.24449299997650087\n",
      "56\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0232s\n",
      "Elapsed Time: 0.24298480001743883\n",
      "57\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0228s\n",
      "Elapsed Time: 0.3114631999633275\n",
      "58\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0111s\n",
      "Elapsed Time: 0.23705120000522584\n",
      "59\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0192s\n",
      "Elapsed Time: 0.25407510000513867\n",
      "60\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0213s\n",
      "Elapsed Time: 0.25079860002733767\n",
      "61\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0132s\n",
      "Elapsed Time: 0.2384623999823816\n",
      "62\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.29165199998533353\n",
      "63\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.23548109998228028\n",
      "64\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.2318173999665305\n",
      "65\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0140s\n",
      "Elapsed Time: 0.239170600019861\n",
      "66\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0151s\n",
      "Elapsed Time: 0.23535090003861114\n",
      "67\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.28912899998249486\n",
      "68\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.23427049996098503\n",
      "69\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0169s\n",
      "Elapsed Time: 0.23898190003819764\n",
      "70\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0145s\n",
      "Elapsed Time: 0.23205029999371618\n",
      "71\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22745440003927797\n",
      "72\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0131s\n",
      "Elapsed Time: 0.31396949995541945\n",
      "73\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22951120004290715\n",
      "74\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0177s\n",
      "Elapsed Time: 0.2399862000020221\n",
      "75\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.2239809999591671\n",
      "76\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.23416619998170063\n",
      "77\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.29641810001339763\n",
      "78\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.22899639996467158\n",
      "79\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0123s\n",
      "Elapsed Time: 0.23512909997953102\n",
      "80\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0094s\n",
      "Elapsed Time: 0.2278482000110671\n",
      "81\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.23647279996657744\n",
      "82\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0128s\n",
      "Elapsed Time: 0.2949115000083111\n",
      "83\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0127s\n",
      "Elapsed Time: 0.2338206999702379\n",
      "84\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22845090000191703\n",
      "85\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0142s\n",
      "Elapsed Time: 0.2371248999843374\n",
      "86\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0103s\n",
      "Elapsed Time: 0.23168069997336715\n",
      "87\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0118s\n",
      "Elapsed Time: 0.2951270999619737\n",
      "88\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.2297819000086747\n",
      "89\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0127s\n",
      "Elapsed Time: 0.2346858999808319\n",
      "90\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.23122730001341552\n",
      "91\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.23540239996509627\n",
      "92\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0153s\n",
      "Elapsed Time: 0.2998202000162564\n",
      "93\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.23051850002957508\n",
      "94\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0132s\n",
      "Elapsed Time: 0.2360130000161007\n",
      "95\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22773350001079962\n",
      "96\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.2338298999820836\n",
      "97\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.29426819999935105\n",
      "98\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.2325696999905631\n",
      "99\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.23339629999827594\n",
      "100\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0086s\n",
      "Elapsed Time: 0.2326488000107929\n",
      "101\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.23366339999483898\n",
      "102\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0131s\n",
      "Elapsed Time: 0.2997202000115067\n",
      "103\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.23128880001604557\n",
      "104\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.2336224999744445\n",
      "105\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0121s\n",
      "Elapsed Time: 0.23520779999671504\n",
      "106\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.2314321000012569\n",
      "107\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.29354739998234436\n",
      "108\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.231937000004109\n",
      "109\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.2345410999841988\n",
      "110\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0119s\n",
      "Elapsed Time: 0.23508529999526218\n",
      "111\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0158s\n",
      "Elapsed Time: 0.23625769995851442\n",
      "112\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.28606190002756193\n",
      "113\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0098s\n",
      "Elapsed Time: 0.2345365000073798\n",
      "114\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0123s\n",
      "Elapsed Time: 0.2361638000002131\n",
      "115\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.23175869998522103\n",
      "116\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0163s\n",
      "Elapsed Time: 0.2403514999896288\n",
      "117\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0163s\n",
      "Elapsed Time: 0.2930645999731496\n",
      "118\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0128s\n",
      "Elapsed Time: 0.2281516999937594\n",
      "119\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0124s\n",
      "Elapsed Time: 0.23451450001448393\n",
      "119.63289560437659\n",
      "120\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.23328570002922788\n",
      "120.63917745825783\n",
      "121\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0118s\n",
      "Elapsed Time: 0.23034670000197366\n",
      "121.64493909414335\n",
      "122\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0120s\n",
      "Elapsed Time: 0.29767210001591593\n",
      "122.64322703084265\n",
      "123\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.2290244000032544\n",
      "123.64151496754191\n",
      "124\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0125s\n",
      "Elapsed Time: 0.23817170003894717\n",
      "124.63980290424124\n",
      "125\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.22808510001050308\n",
      "125.63809084094056\n",
      "126\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.23850440001115203\n",
      "126.6363787776398\n",
      "127\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.29184050002368167\n",
      "127.6213919314339\n",
      "128\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0129s\n",
      "Elapsed Time: 0.23374699999112636\n",
      "128.60223727662478\n",
      "129\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0091s\n",
      "Elapsed Time: 0.22647489997325465\n",
      "129.61469745166917\n",
      "130\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0127s\n",
      "Elapsed Time: 0.23675720003666356\n",
      "130.62648510949086\n",
      "131\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22774740000022575\n",
      "131.62998783886943\n",
      "132\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.29625119996489957\n",
      "132.63349056824356\n",
      "133\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.23412029998144135\n",
      "133.63699329761758\n",
      "134\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.23386009997921064\n",
      "134.6346259519304\n",
      "135\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0130s\n",
      "Elapsed Time: 0.235869099968113\n",
      "135.64395002373922\n",
      "136\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.22929730004398152\n",
      "136.661003593563\n",
      "137\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0117s\n",
      "Elapsed Time: 0.2965641000191681\n",
      "137.67805716338677\n",
      "138\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0163s\n",
      "Elapsed Time: 0.23788899998180568\n",
      "138.69511073321027\n",
      "139\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0142s\n",
      "Elapsed Time: 0.23180819995468482\n",
      "139.7037244307467\n",
      "140\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0131s\n",
      "Elapsed Time: 0.23100259999046102\n",
      "140.69872748799375\n",
      "141\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.22878619999391958\n",
      "141.6937305452403\n",
      "142\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.29421810002531856\n",
      "142.68814982431215\n",
      "143\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0102s\n",
      "Elapsed Time: 0.2371485999901779\n",
      "144.4305632025251\n",
      "144\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.23156620003283024\n",
      "145.41208327131395\n",
      "145\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.23332460003439337\n",
      "147.10452244642946\n",
      "146\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0158s\n",
      "Elapsed Time: 0.23738360003335401\n",
      "148.0596120883026\n",
      "147\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.287767999980133\n",
      "149.0147017301758\n",
      "148\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.23361490003298968\n",
      "149.96747540567677\n",
      "149\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0085s\n",
      "Elapsed Time: 0.231143000011798\n",
      "150.90924833035015\n",
      "150\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0122s\n",
      "Elapsed Time: 0.23567639995599166\n",
      "151.26322011740547\n",
      "151\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0094s\n",
      "Elapsed Time: 0.22760759998345748\n",
      "152.25385532572236\n",
      "152\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.2944246000261046\n",
      "153.2383757288555\n",
      "153\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0132s\n",
      "Elapsed Time: 0.23648079996928573\n",
      "154.22200763593784\n",
      "154\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0160s\n",
      "Elapsed Time: 0.2386306999833323\n",
      "155.40661890873378\n",
      "155\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.2251842999830842\n",
      "156.40198465493728\n",
      "156\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0165s\n",
      "Elapsed Time: 0.2393325000302866\n",
      "157.39735040114078\n",
      "157\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.29114669997943565\n",
      "158.38673633864425\n",
      "158\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0091s\n",
      "Elapsed Time: 0.23552739998558536\n",
      "159.36574854532137\n",
      "159\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0120s\n",
      "Elapsed Time: 0.23551319999387488\n",
      "160.34397705296476\n",
      "160\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.23058540001511574\n",
      "161.31021510634608\n",
      "161\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.23301089997403324\n",
      "162.71207862450964\n",
      "162\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0106s\n",
      "Elapsed Time: 0.29477600002428517\n",
      "163.69563659105162\n",
      "163\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.2338286000303924\n",
      "164.67919455759366\n",
      "164\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0188s\n",
      "Elapsed Time: 0.24195580004015937\n",
      "165.66275252413556\n",
      "165\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0080s\n",
      "Elapsed Time: 0.23841500002890825\n",
      "166.64631049067756\n",
      "166\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.23303000000305474\n",
      "167.62986845721952\n",
      "167\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0133s\n",
      "Elapsed Time: 0.2993985000066459\n",
      "168.61342642376138\n",
      "168\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.23271710000699386\n",
      "169.59698439030345\n",
      "169\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0086s\n",
      "Elapsed Time: 0.22708749998128042\n",
      "170.58054235684546\n",
      "170\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0173s\n",
      "Elapsed Time: 0.23736680002184585\n",
      "171.56410032338738\n",
      "171\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0121s\n",
      "Elapsed Time: 0.22827250004047528\n",
      "172.54765828992947\n",
      "172\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0170s\n",
      "Elapsed Time: 0.2985814000130631\n",
      "173.5182358130561\n",
      "173\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.24020529998233542\n",
      "174.48487399564033\n",
      "174\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0171s\n",
      "Elapsed Time: 0.24169609998352826\n",
      "175.4515121782248\n",
      "175\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0116s\n",
      "Elapsed Time: 0.24095919996034354\n",
      "176.41815036081104\n",
      "176\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0166s\n",
      "Elapsed Time: 0.23938829998951405\n",
      "177.38478854339377\n",
      "177\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0121s\n",
      "Elapsed Time: 0.29332500003511086\n",
      "178.35142672597382\n",
      "178\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0173s\n",
      "Elapsed Time: 0.23599690000992268\n",
      "179.31806490855777\n",
      "179\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.22437549999449402\n",
      "180.28470309114144\n",
      "180\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0152s\n",
      "Elapsed Time: 0.241715399955865\n",
      "181.25134127372502\n",
      "181\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0162s\n",
      "Elapsed Time: 0.24806660000467673\n",
      "182.21797945630814\n",
      "182\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.28570260002743453\n",
      "182.96299654210011\n",
      "183\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0138s\n",
      "Elapsed Time: 0.23746769997524098\n",
      "183.9655928713376\n",
      "184\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.2303665000363253\n",
      "185.46172206107792\n",
      "185\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0147s\n",
      "Elapsed Time: 0.23555010004201904\n",
      "186.7984583101231\n",
      "186\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.22715639998205006\n",
      "187.02154154306706\n",
      "187\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0098s\n",
      "Elapsed Time: 0.2983750000130385\n",
      "188.0401911003081\n",
      "188\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0147s\n",
      "Elapsed Time: 0.2382476999773644\n",
      "189.05884065754915\n",
      "189\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0087s\n",
      "Elapsed Time: 0.22521290002623573\n",
      "190.07749021478946\n",
      "190\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0086s\n",
      "Elapsed Time: 0.2325363999698311\n",
      "191.95559795539265\n",
      "191\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0183s\n",
      "Elapsed Time: 0.2425725000211969\n",
      "192.94432477660672\n",
      "192\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0146s\n",
      "Elapsed Time: 0.2930950000300072\n",
      "193.8971410093041\n",
      "193\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0127s\n",
      "Elapsed Time: 0.2303360000369139\n",
      "194.84995724200266\n",
      "194\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.22997729998314753\n",
      "195.80277347470124\n",
      "195\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0133s\n",
      "Elapsed Time: 0.23279330000514165\n",
      "196.03925310986162\n",
      "196\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.23039240000071004\n",
      "196.90009316074008\n",
      "197\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.2920814999961294\n",
      "197.87110538776264\n",
      "198\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.23212950001470745\n",
      "199.04628528202468\n",
      "199\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0089s\n",
      "Elapsed Time: 0.2333187999902293\n",
      "199.4122067198723\n",
      "200\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.23395560000790283\n",
      "200.5477380928808\n",
      "201\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0102s\n",
      "Elapsed Time: 0.23241539997979999\n",
      "201.68326946589195\n",
      "202\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0175s\n",
      "Elapsed Time: 0.30214029998751357\n",
      "202.77339503680165\n",
      "203\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.22508790000574663\n",
      "203.8393342759737\n",
      "204\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.2327429000288248\n",
      "204.84848451447283\n",
      "205\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0131s\n",
      "Elapsed Time: 0.23580779996700585\n",
      "205.63389783563065\n",
      "206\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.22924180002883077\n",
      "206.82128356239915\n",
      "207\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.2946574999950826\n",
      "207.8497550052795\n",
      "208\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0088s\n",
      "Elapsed Time: 0.2341006000060588\n",
      "208.5099675868191\n",
      "209\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.23339310003211722\n",
      "209.7689842184377\n",
      "210\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.23364489997038618\n",
      "210.87874160681926\n",
      "211\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0090s\n",
      "Elapsed Time: 0.23319890000857413\n",
      "212.1414001244101\n",
      "212\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0101s\n",
      "Elapsed Time: 0.2975252000032924\n",
      "213\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0095s\n",
      "Elapsed Time: 0.2331766999559477\n",
      "212.913665876125\n",
      "214\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0152s\n",
      "Elapsed Time: 0.23602229997050017\n",
      "213.60013911057464\n",
      "215\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0129s\n",
      "Elapsed Time: 0.23210790002485737\n",
      "214.23729348535244\n",
      "216\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0126s\n",
      "Elapsed Time: 0.22961239999858662\n",
      "214.87505852216674\n",
      "217\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0184s\n",
      "Elapsed Time: 0.3020968000055291\n",
      "218\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.2422295999713242\n",
      "219\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0154s\n",
      "Elapsed Time: 0.2388352999696508\n",
      "215.2294945554841\n",
      "220\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0155s\n",
      "Elapsed Time: 0.23429649998433888\n",
      "221\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.23249699996085837\n",
      "215.28868529547213\n",
      "222\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0096s\n",
      "Elapsed Time: 0.29469449998578057\n",
      "223\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.23372090002521873\n",
      "224\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0183s\n",
      "Elapsed Time: 0.23731890000635758\n",
      "225\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0186s\n",
      "Elapsed Time: 0.24813630001153797\n",
      "226\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.24085010000271723\n",
      "227\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0106s\n",
      "Elapsed Time: 0.29398740001488477\n",
      "228\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0166s\n",
      "Elapsed Time: 0.24022249999688938\n",
      "229\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0097s\n",
      "Elapsed Time: 0.2286591999582015\n",
      "230\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0167s\n",
      "Elapsed Time: 0.23766300000716\n",
      "231\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0166s\n",
      "Elapsed Time: 0.23472580005181953\n",
      "232\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0187s\n",
      "Elapsed Time: 0.3001490999595262\n",
      "233\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0166s\n",
      "Elapsed Time: 0.24729109997861087\n",
      "234\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.24132029997417703\n",
      "235\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0109s\n",
      "Elapsed Time: 0.2315080999978818\n",
      "236\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0143s\n",
      "Elapsed Time: 0.2355673999991268\n",
      "237\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0106s\n",
      "Elapsed Time: 0.2959719999926165\n",
      "238\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0118s\n",
      "Elapsed Time: 0.23371709999628365\n",
      "239\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0110s\n",
      "Elapsed Time: 0.23074820003239438\n",
      "240\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0148s\n",
      "Elapsed Time: 0.23870859999442473\n",
      "241\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0115s\n",
      "Elapsed Time: 0.2289714000071399\n",
      "242\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0105s\n",
      "Elapsed Time: 0.2947128000087105\n",
      "243\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0112s\n",
      "Elapsed Time: 0.23459929996170104\n",
      "244\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0107s\n",
      "Elapsed Time: 0.23259869997855276\n",
      "245\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0110s\n",
      "Elapsed Time: 0.23178119998192415\n",
      "246\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0114s\n",
      "Elapsed Time: 0.23248000000603497\n",
      "247\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0104s\n",
      "Elapsed Time: 0.2955847000121139\n",
      "248\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0098s\n",
      "Elapsed Time: 0.2319932000245899\n",
      "249\n",
      "Being solved by Mosek...\n",
      "Solution status: optimal\n",
      "Running time: 0.0108s\n",
      "Elapsed Time: 0.23429789999499917\n"
     ]
    }
   ],
   "source": [
    "from maximum_robust import robust_portfolio, robust_portfolio_exact, robust_portfolio_relax\n",
    "\n",
    "QUANTILE = 0.01\n",
    "\n",
    "ts = np.arange(0,250,1)\n",
    "qs_train = []\n",
    "qs_test = []\n",
    "qs_exact_train = [] \n",
    "best = 0\n",
    "best_decision = -1\n",
    "\n",
    "maximal_decisions = [] \n",
    "maximal_times = []\n",
    "\n",
    "for t in ts:\n",
    "    print(t)\n",
    "\n",
    "    ans, tim = robust_portfolio_relax(train_data, t, timeit = True)\n",
    "\n",
    "    maximal_times.append(tim)\n",
    "\n",
    "    vals = np.dot(train_data, ans)\n",
    "    vals_test = np.dot(test_data, ans)\n",
    "\n",
    "    qs_train.append(np.quantile(vals, QUANTILE))\n",
    "    qs_test.append(np.quantile(vals_test, QUANTILE))\n",
    "\n",
    "    maximal_decisions.append(ans)\n",
    "\n",
    "    if qs_test[-1] > best: \n",
    "        best = qs_test[-1] \n",
    "        # print(ans)\n",
    "        best_decision = ans\n",
    "        print(best)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1bbb6d93af0>"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(ts, qs_train, label = 'train')\n",
    "plt.plot(ts, qs_test, label = 'test')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "215.28868529547213\n",
      "215.26092755149315\n"
     ]
    }
   ],
   "source": [
    "print(np.max(qs_test))\n",
    "print(np.max(qs_train))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.        , 0.        , 0.        , 0.        , 0.73783077,\n",
       "       0.01884922, 0.17999362, 0.06332639])"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "best_decision"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1bbb66401c0>"
      ]
     },
     "execution_count": 62,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEbCAYAAADAsRPLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABjcElEQVR4nO3dd3hURdvA4d+Tzab3SgiQ0HtHmiDYQBAUFFERBPRVsSLiZ8P+vvbeFSwUC1UBFVAEQZCidGkRQk8CpPey2Z3vj7MJSUhCAkk2IXNf117Z0+bM2d3ss1POjCil0DRN07SSnBydAU3TNK120gFC0zRNK5UOEJqmaVqpdIDQNE3TSqUDhKZpmlYqHSA0TdO0UukAUQuJyAQRUUUeeSISLSIvi4ibo/NXF4nICBF5xNH5OB8i8ryI6P7opRCRh0XkhlLWn/Wa2f+Xnq+xzF0EdICo3W4C+gDXAr8ATwJvODRHddcIoE4GCOBzjM+BdraHgbMCBPo1qxLOjs6AVq4dSqmD9ucrRaQlcKeITFZK2RyZMe3CiIirUiq3IvsqpU4AJ6o5SxcV/ZpVDV2CqFu2Ae5AUMEKEfEQkddE5LC9KuqwiEwTESf79jARyReRB0smJiKPi4hFRIKLrLtBRDaJSJaIpIjIAhFpUuK4IyLytYjcIiL7RCRTRLaISL8S+60RkTWlnPeIiMwssa6piHwjIvEikisiO0Rk5LleEBEJFpHPRORfe56Pi8i3IhJeZJ+ZwHggvEi13ZEy0nMVkSQReauUbTfbj+1iX75ERBaKyAkRyRaRKHs1oHspr8N6ERkuIttFJBe4T0T+EZEfSjnPQPt5BtuXy6ou+Z+IPGR/z9NFZK2ItC+xn8m+X5z99VktIm0qWt0iIleKyDYRybFXc94jIjOLvn5F8juwxLEFVaWRRdbdYs9DvIhk2F+P8aWc95zXZ89DBHBbkfd1ZlmvWRnX11lElopIsv09/FNE+pfY5xIRWSkiifbX8JCIfHyutC8GugRRt0QCqUAigIg4Y1Q9tQP+C/wD9AaeAQKAqUqpOBH5DRgHfFAivbHACqVUvD29ScAnwFfAi4A38DywVkQ6KaXSixzbH2htP1eO/fw/iUikUiqlMhclIo2BzcBpYAoQD9wMLBKREUqppeUcHmA//5P24xoCU4E/RaSNUqogb8HAJcB19uNK/fWulMoVkfnAGBF5TCllLbJ5LLBbKbXDvtwE2AHMBNKB9sCzQDPglhJJtwLet+flEJBkz8N7ItJQKRVbZN97gMPAr+Vcd0F+ooDJgAtG9eMS+3Xn2/d5AXjKvu03oBtQ3utZSETaAsuALfbrccX4PHgB1rKPLFczYCHwKmADLgM+FxF3pdSnlby+kfb87bTnC4zPQIWISDdgHbAduAvIAiYBv4lIX6XUVhHxwvgf+wuYgPE+RwJ9K3XVdZVSSj9q2QPjg6gwvoCdAX/gDiAfeKDIfuPs+11W4vhpQB4QYl++rSC9Ivt0sa8bbV/2wgg+X5ZIK9Ke1sNF1h0BkgH/Iut62NMbU2TdGmBNKdd3BJhZZPkLjH/swBL7rcSoZqvMa2cCGtvzMrLI+pnAiQqmcan9+MFF1gUDFuCxMo4R+3s1FuOLL7DItjX2dV1KHOMNpAHPFFkXhBE4niiy7nnjX7XYsQo4AJiLrBtlX9/XvuwPZAAflzj2Eft+z5/jdfgGSAA8i6xrbP88HCmybqA9vYFlfI4jy0jfyf6azQB2Vvb6inyWvi4l7bJes+eLLK8C9gEuJT4/+4DFJT7Xnc73/7kuP3QVU+22H+NLKQnjS/QzpdSHRbZfAxwFNoiIc8ED45enGaM0AfADxhfFuCLHjsMICAW/JvsAPsA3JdI6Yc/HZSXytlEplVxk+R/73yZU3jUYvwRTS5z7F6CziPiUd7CI3CsiO0UkAyOIHrNvan0eeUEp9ScQTfHX6xaML7RvipzXR4zqvWiML3ULMAcjWLQskewRdabkUXCedOBr4D9irxIEJtqP/6oCWV2plLIUWS75HnQEPIEFJY5bWIG0wfhMLFNKZRbJ83HgzwoefxYRaSki34lIDMbrZQH+Q+nv1bmu77zZqwEHYLw2tiKfOcEoaRV83g8AKcBnIjLWXtqtN3SAqN1GYlSLDMX40N4nIrcX2R6CUQdrKfH4y749EEAplQUswqirFRExAbcCC5RRBVOQFvbzlEyvY0FaRSQVXVBnGlzPpxtuCHB7Kect6LFV8tyFxGhb+die7xuAnpwJjBfSJfhrYIS9igGMYLFaKRVTZJ+vMKok3geuxniv7i/j3HFlnOdjjC+8oSIiwN3AD0qpUxXIY1KJ5ZLvQZj97+kS+1Uk7YLjS9u3oscXY38tVwKdgScwqikvAb7EqL4q6VzXdyECMEoLz3D25+4BwF9EnJRSqcDlQCzGe3VMRHaLyI1VkIdaT7dB1G67lb0Xk4isBnYBb4jIIvuvukSMuurRZRx/pMjzORgNtf0wGrrD7OsKJNr/TgD2lJJWeinrziUHo1RSUkCJ5USMuuDXykgntoz1YPyyX6WUmlqwQkSaViaTZZgDPAeMFJHNGF9khY2pYtyPcj1GlcV7RdZ3LCO9UhtMlVK7RWQdRrtDDtDC/rwqFASlEIq/p6GVOL60fUuuK/iR4VJifcnA3gfjB01/pdT6gpX2X+41LQWj2u8jYHZpOyh7T0F7ye9Gez57YLR3zReRzkqp3TWSWwfRAaKOUEbj6f8BS4D7MH5drwBuBDKUUvvPkcTvGNVF4zACxBGML+UCGzCCQAul1KwqyvZRjH8sF6VUHoCIXIZR917UCowvjz1KqexKnsMDox6/qIml7JeLcd0VopSKFpGNGK9XKyAT+L7ILq4Yv0AtJQ6dUNFzFPExRonFH/hXKbX6PNIozT8Y+b4J4/0vcFMFj9+IUbLxLKhmslexXErxoH3U/rcDxRvWh5ZIz8P+t/A1ExF/jEB7vir1vhZQSmXaA3NnYJuqQLdxZTSMbxKRZzA6O7QFdIDQagel1FIR+Rt4VEQ+xKgPnwisEqNb5k6MX3HNMT7AI+zVSyilbCLyDcavUzPwjrK3wtm3p9kD0EdidHtdjtFGEY5RV7tGKfVtJbM8F6PK5Et798OmGA2kqSX2exajWuwP+3Udwfiy7AA0U0rdUc45VgCPi8hT9jSuwGjMLGkvECAi92L0yslRSv1Tyn5Fzcb4hdkRo9ono2CDUipVRDYBU0UkDqMx9w6M16uyFgHvYnzxTi1/14pTSiWLyLvAUyKSzpleTHfadznXl+L/MILJryLyBsZn6wVKVDEpo6fcWuBJEUnAqNIai/E5LGoDRjD/SESew2gfeRrjtfM9r4s03tf+IjIMOAkkKKWOVPDYR4A/gF9E5AuMElMQxmtkUko9YU/3bmAxRmndE3gI48fUxvPMc93h6FZy/Tj7wZneHy1K2TbIvm2KfdkNo8fGfoxfU0nA3/Z1ziWObW8/tliPphL7DMX4tZkGZAMHMeqI2xXZ5wil9xw5q2cMRkA6YE9rA9CdEr2Y7Ps1wrj7NQajl0wcRn312HO8Vu4YXXPjMf5pf8IIRCV7rHgC32H0vlIU6YVTTtr+9tdUAYNK2R6JEUjTMb4UP8S4671Yjx6MXkzrz3GuzzCqagJL2fY8pffI+V8p+VHAhCLrTMBLGF+e2fa89LXvN7kCr8FVGN1AczG6596D0SPsSIn9GgE/YlTdnARexmh8LtaLCSOAb7fnJRrjy/ZCrq8NRkk4y75t5jles5Kfz7YYP2RO26/xBEbHjaH27a2BeRjBIcf+OVsG9Krp7wVHPMT+Imia5iD2uu2DwDql1Lhz7V8F57sJmI/RPXrdufYv5fiZGAEwsoqzptUyuopJ0xzE3n23AzAG4/6Cs+7eroJz9MIo1WzG+AXcHaMH0SZgfTmHapoOEJrmQN0wqvNOY1T37KiGc2Rg9Om/H6NH2WmM0sOTSlcfaOegq5g0TdO0Uukb5TRN07RSXTRVTEFBQSoyMtLR2dA0TatTtm7dmqCUCi5t20UTICIjI9myZYujs6FpmlaniMjRsrbpKiZN0zStVDpAaJqmaaXSAULTNE0rlQ4QmqZpWql0gNA0TdNKpQOEpmmaViodIDRN07RS1fsAYU1L49Trb5C+ejXWlBRHZ0fTNK3WuGhulDtfuQcPkjhnDklffgmAa8sWuHfvjkf3Hnj06I45LOwcKWiapl2c6n2A8OjWjS0fLOBGjzSyt21l57I1BHy/BLe58wCQsDC8OnZE3FwRkzOYnBCTM2IygcmEmEyI2RkxuyCuroiLC+LqglPBcxdXXJs3w7VFCwdfqaZpWuXU+wABcPulEWAy49nzEg61G8Qn/8SSvncfrU9H0yHxMG237CLM04yy5pOVbUFsVkzKhpPNithsYLGgLCWnJi7OtWULfIYOxWfIEFz0mFGaptUBF81w3z169FDnPRbTxo9h1YsQ2g5CO0CDjliC2rFfNWHryXxEhPF9IwHo/fIqTqblFB7qJDC6R2NeGdkBZbHw4KzNuFgteJvAx2TDW6x0STlK6NZ1ZG/dCoBbu3b4DB2C9zVDcGl0PlMYa5qmVQ0R2aqU6lHaNl2CAGjYFXrcASd3wb6lsG0WZoyZ6jv6RUCf+4F7wGbjzxHZnPJqy1GLH8eTsziRnE2TAA/EyQlxdSVemUnNgYzcfNJybGTkWvlPv/5Me+Qeso7HsOS9ObSN2kzOm29x+s23cO/cGZ9rr8Xn2qE4BwY6+IXQNE07Q5cgSlIK0mLh1G44+Y/xt9lA6D4B0k/CW61h6JvQ8y5IOACL7gTvMDC7g7O78bfIw2ZyI7fJZbg36khUbDI3ffIHaRZnGmYlclNGFH2PbMMn9giYTLj27kPugKvxufoq/AJ88HAxISIXfk2apmll0CWIyhAB33Dj0Wpw8W3uAXDXavCxVwtZLeAZbASU/BywZBd5ZAEKJ8D9hhnQqCOt86PYZbqdvYNnszyrF3H78okK/5d+jYfjdTiN02t2YfpzPadee4kfwjrwR5PuHI5ox5d39qFjI192HE/h9/2naeDrRgMfN0J93Aj3c8fXw1zTr5KmafWALkFUF6XAmgd5mWdKFMlHYNd86HKbEYB2LUD9/AiSm1Z4SHa8C0nHfMg45oLKA5u7Gbdu3fHt0ZM/JZDno2wku3oXO9XqqQNoFuzFydQc3F1M+LrrgKFpWsWUV4LQAaI2yE6BlKOQfBRSjkHKUWzxh8nYeYj0vSnk2JqTd+xE4e4SFER+89bkNAgiNjSSIeNvwhwYyOMLd7Fg63E6hPvSp3kgfZsHcUmkPx4uuqCoaVrpdICoy2w2EMGamUnu8s/J3vQbOaZ25OzZS96haLC/fS4Ng8jucAn7ApvxuzmM3zJcybMJzYI8Wf3oQAAOxWfQOMADs6ne30CvaZqdDhAXKVv0RnJWLyBr/S9kH88iO9EVa67RqO3k60t2y3ZktWhDp8t74dKmLX2m7yTHYqV3s0D6tgiiX4sgWoV66YZwTavHdIC42NlscHgNauss8v5aQfZpISs7nOwkd/JiEgt3y/cL4FRoBLvcQ9lqDuGgXzijrr2E/7umLTkWK8t3x9G+oS/Ngjxx1qUMTasXdICoTzITYddc2DYb4vdjHfA/cr16k/PPDnJ2/0POwaPkRkeD1QqAcjLh7OuDxdObqEwh3cWdLFdPzP5+eAUF0HngJbQacjkmLy8HX5imadVBB4j6SCk4/hcENAWvENj+NSy5H+7/G5t3E3L37CTn4BEscXFYU1PJT0klIz6J7MQkrKmpOGem45abbaRlMpHXqh1/+jbDqVdvIvr0oHNkIGG+brp6StPqOB0gNEg6DFHLofe9xr0eSx6A6NXQ5lpofwM07gVOxauVrLm5ZO/YSdaGDcStWovzwSicUGQ4u7EruAXRjdpw7w098fP35lQuWMwuNAr1x9XLA3Fzw8nTU5c8NK2W0wFCO9ueH2DXAoheZdzk5xMO7UZAhxsgvLsRRErIT04mdcNG4lb9Qf7mjbgmnj7naZy8vTGHh5MfFIKENcSzSWO8IhpjDm+IS0QkJi/Parg4TdMqSgcIrWy56UbJYvf3cPA3sFnArwm0HwmdbjEGMCyFUor8kyexpqWjcnOIO5XMoROJxJ1O5VR8KomJqXjk5XBXaw8ssbEc2n0Qr5R4PPJzC9OwOpnwvXwgvtcOxXPgQEweHjV00ZqmFXD4UBsi0hiYDTQAbMB0pdR7IvIGMBzIA6KBiUqpFPsxTwJ3AlbgIaXULzWR13rH1Rs6jTYe2Smw/2fY8z1s/AiczEaAyM81xqVq2K2wGkpEMIeFFU6o1Mz+KCo334qrswmAU0eSOJyQSVp8IjnHT2CLiyMi7iBt/tlExqpV5JpdiW7VHaerBtPh+qtpEean2zc0zcFqpAQhImFAmFJqm4h4A1uBEUAjYLVSKl9EXgNQSj0uIu2A74CeQEPgN6CVUspa1jkupARxKOUQCdkJ9AzreV7HX5SykkDZwDMI/v0Vvr0JblsELa8yhg9xdgMn0wWfRlmtpP/1N2s++ZqGOzbimZdFqosH2yK7ETliKINHXYnVw4v1B+Np5O9BuJ87nq76znBNqyoOL0EopeKAOPvzdBHZB4QrpX4tstsmYJT9+fXAXKVULnBYRA5iBIuN1ZG/Hw7+QL4tn55hPVFKsfrYanqG9cTbxfvcB1+sPALOPG/cE0Z+Bk37G8vr3oZts4wG7nYjILI/mM7voyQmEz59enNdn96ovDyOrFhN8qIl9Nu2EfPr6/n3dZCIpuxSwcwPaMJ+/wjSQhsRHujFw1e15Mq2oZxKy2HRthMEeLjg7+mCv4cLAZ5mGvl74Ga+8CCmafVVjbdBiEgk8AfQQSmVVmT9j8A8pdTXIvIhsEkp9bV92xfAcqXUwhJp3Q3cDdCkSZPuR48ePa88WawWsvKz8HX15VDKIa5fcj3Tek3jlja3kGvNJT0vnSD3oPNK+6J0cJXRbfbfX8CSCR6B0PY6o90i4tLzDhZF2bKyyN65k+wdO8jYvoOsHTuRtFQA8lzdiWnQlAatm9MoMowTVjMfb0sgzdWTNBcP0l08SXXx5PUJlzK0U0N2x6Qye+MRIgI9iQz0JCLQg4hAD7zd9KCGmlZrGqlFxAtYC7yklPq+yPppQA/gBqWUEpGPgI0lAsQypdSistKuqkZqm7KxK34XET4R+Lv5s+rYKh5Z8whzhsyhU3CnC07/omLJNhq29/wAUSuMYOEZbASLTqOhSe8qO5VSCsvRo0bQ2LmT7J27sJw6hTUlBfLzSz1GfHxwa9GC+IAwlia7sNclkOPeIcS7+6HEicX3X0qXxn5Ex2cQl5JDx3BfPXS6Vu84vIrJngkzsAj4pkRwGA8MA65UZ6LVCaBxkcMbAbE1kU8ncaJLSJfC5db+rbm38720CzR68yw5uISjaUe5v8v9mKqgDr5OM7tD2+HGIy8LDq40gsXO74yhzpv0NoYB2foVtLza6B11nkQEl8hIXCIj8b3++sL1SilsGRlYU1KwJicbf1NSyE9MIu/IEfKio/HduoExycmFx9hc3cgMDsPn6QWc8PPjQJqNvxIsLDF74OLnQ2CDIMKbN2HYqMvx9NX3cWj1V001UgswC0hSSj1cZP01wNvAAKVUfJH17YFvOdNIvQpoWV2N1JXx6l+vsidhD3OGzgEgKimKZr7NMJv0L89CeZmQmwHeoXB6H3zcG0Z8Cl1uNYY03/8TRPSFBp2qpKG7IvKTk8mLjiY3+hB5h6LJO3IUa2oq1rQ08lNTsaamIfmW4geZTLi1bk1iRCvMHTvSemAfXJtG6t5V2kXF4VVMItIPWAf8g9HNFeAp4H3AFSgYUW6TUmqS/ZhpwB1APvCwUmp5eeeoyfsgLFYLZpOZXGsuVy64kiGRQ5jWexoAK46soHNQZ8K8wmokL7WeUsZcF+7+4OYLO76DxZOMbU7O4BFkVEt5Fvy1P+8yBrwbGPNjJPxrNIQ7uxrTvmYlgsnFuLnPpWrunVBKoXJysKalYU1NJfXwMWTfbrJ37iRxyw7cLTkA5Lp7QfsOhF7SFa/27XBt0xZzeEMdNLQ6y+EBoiY44kY5q83Kn7F/4uPiQ5eQLiRmJzJw/kAe7fEo49uPJ8uSxQfbP2BEixG0Dmhdo3mr1VJj4OgGOL0XMuONL/zMePsjAfIy4N6Nxj0Yf82AZY/C/0UbgWPVi7DuLXtCAoHNIbQDNOgAoR2Nvz7hpd4Jfr6S07PZ8PsWDq/djNq7m5YJR2iScRqx/+9Y3D3Jj2yOZ7u2BHXpgEe7tri1bIm4uFRZHjStuugAUUOsNiuHUg/h5+pHsEcwUUlRjFs+jtf6v8blTS4nKimKR9c+youXvkjXkK5k5GWQlJNEuFe4bs8oKi/LKC04mSDjtDFVa8OuYDLD6f2QEGXcvJcYDad2GzfxpRTpweYRCI/sM9JQqkqDRY7FyoboBPycbLTNiSduyy4WLVhNs9RYmqbG4W7NA0A5m3Fv3xb3jp1w79wJ944dMUdE6JKGVuvoAOFAVpsVGzbMTmaikqL4ZOcnTOk+hQifCFYeXckjax5h4fCFtA5ozfqY9czYNYPXLnuNBp4N+Df5X7ac3MKIFiPwMHuQnJNMWl4ajbwa6YBSUk4anNpjBIy0WLjqOWP9vLFGiWLIa9V3aouVg6cz+DculZi9B8nYvYdrnJMIOHaQzN27kRyjekp8fPDo1An3Th1xbdHCaHSPiMDJU49HpTlOrejFVF+ZnEyYML7MWwe05t3L3y3c1jGoIy/2fZFwr/DCdc5OzriZ3AD4K+4vXvv7NYY0HYKH2YOl0Ut5c8ubbLh1A94u3nyz7xvmRc1j1jWz8Hfzr9HrqnXcfCCij/EooBT4RRjtGgDWfFj/DnS8EQJKDgxyAac2m+gQ7kuHcF/o0QS4onDbr7ti+HzOKgKOH6BV8nG67DtMgz83IMpWuI81IAhbeCOkUROcmkTgERlBaLNGmENCcA4KQsy6A4TmGLoEUYtZbVZSclPwd/PHSZw4nHqY3Qm7ubbZtTiJE2uOr+H347/zfJ/nERE+3fkpCdkJTOs1TVdllObEFvjiamMIkcj+0G8KNL+iSqugSqOUYv/JdFbtO8Wq/afZf/g02+5si+XoMX78eSMJ+w8SnpFAeEY8fnmZZx1v8/HFNTQEF3vAcA5rgGvz5rg2b45L06Y4ubtXa/61i5uuYqon3t76NqezTvNq/1cBmLFrBi39WzKw8UDHZqw2SYs17tP4+0tIOwGNe8PlT0LTAdUeKApk5ObjZR9PKiYlm9NpOeTm28ixWMlLTsV8KpYe3jby4+P5etlWck/FE5CbRkNrJkG56XikJyM2ewlEBHOjRrg2a4ZLi+a4Nm+Be5cuuDZrWiPXotV9OkDUQ/m2fIb/MJyBjQfyeM/HUUrx0uaXuCriKnqHVd0dznVWfi5snwN/vAXpsdCkL1z+1JnxpmqJtBwLO46lsO1YMtuPpbD9WDK9m/jwQf8gcqMP8cFXvxKYEEvTzNM0TDuNs824q9ytY0d8R1yPz9ChOPvX8+pHrVw6QNRTNmUjJz8HD7MHSTlJ3Lj0RiZ1msTNbW4mPS+d5zc8z4T2E+gY3NHRWXUcS44xf/f6tyE9DrqMhREfOTpXZbLZFOm5+fi6G+0Sc/86RmxqDvHpOcSnZJEfc4Lrsw7Tee+f5EZFYTWZsFxyKRFjR+M/4DLdnqGdRTdS11NO4oSH2biRLMAtgNU3rSZfGb8wYzNi+SfhH7LzjXmno5KieH/7+0ztMZVmvlXXgFvrmd2g193Q7XbYOhN87Dc45udBWowxp3ct4uQkhcEB4JaeZQ1f8n/s/WMLy9+YQb9tWzm16Q8Oe/iQN+AqWo+5Ef/uXZASU8xqWkm6BFHPKaUQETbEbuCVza/w+aDPCfUM5dcjvzIvah7vXP4OPi4+xGXEkW5Jp4VfC5ykHnyxrHsb1r4G928G/0hH5+a85VisbIg6yb7Fv+C19le6ntiNWVkxBQfhOWAgPlddiWefPji5ujo6q5qD6BKEVqaC3k59G/blx5E/Fq63YSM7PxtPZ6OP/oJ/F/Dl7i/ZMnYLTuLEwn8Xsv30dl7q9xIAf8b8SUxGDKNbjwaMSZiy87NpH9S+hq+oinS+1ZgUqSA4ZCaCZ6BDs3Q+3MwmrugQzhUd7sD61ER27D1Kk0O7yFj9O4lLfyJt4UKsrm549bsUv6uuwmvgAN1moRXSAUIr1TWR13BN5DWFyyNajKBjUEecnYyPTGpuKsfSjhVuX3FkBRtjNxYGiBn/zGD76e2suHEFAC9sfIG4jDg+vfpTAH6M/pE8ax43trqxpi6pcnzCoM99xvP4KJg+EHreDQOfMEaxrYNMTkL3DpHQIRK/667jzz8Psm7hr0Ts30KfDVvIXrUKAPHwwMnNDSc3N8TdHSdXV+OvmxtOnp7GVLONGmFuFI5Lo0aYw8Nx0vOJX5R0FZNWJSw2Czn5OYWz8B1KOURqXipdQ7oC8M2+b0jMTuShbg8BcM/Ke8i35fPF4C8Ao4tuQ8+G3NLmFsdcQHmyk+HXp41JkgKawfD3a11vp/OllOLvI8l8u+kIUeu3MNYpjqvC3bBmZ3PgWAKBzja8xQq5udhysrGlZ2CJjUXZ7w4vYAoMNAJGkwjcWrfCtXVrXFu1xjkkWN+TU8vpXkxaraOUIjs/u7AR/c5f7qSZb7PCUXEn/TaJQRGDuKHlDQBkWbIK93WYQ2vgx8nG2FBdboOBT4Jf43MdVWckZ+aRm2+jga8b+0+mcc276wBwcXaiY7gv3Zr4cVOPxrQM8cKamIjlxAnyTsRgOXECS8wJ8k6cIO/IUfLj4grTNPn54dqmjRE0WrU2Rr51cUHMZsTZ2fhb5GEKCEBMehiZmqTbILRaR0SKfeF/MfgLCn6s5OQbv07z7X36syxZ9PmuD490f4Tx7cdjsVn44/gfdA3tSoBbwNmJV5dmA41RZte+Cps+gX8WwCX/gf5TjZFm6zh/zzOjz7Zp4MPmp65k29Fkth1LZtuxFGZtOEq/lsG0CvXmiM2NPQRz5dUd8HUt/jViTU0l999/yYn6l9yoKHKiokievwCVnX3OPJj8/fEaOBCvKy7Hq29fPU6Vg+kShFbrpeelMy9qHr3DetMhqAP/Jv/LjUtv5JX+rzCs2TASshNYfHAxw5oNo4Fng5rJVMpxI1Ds+BbMHnDDDGgztGbO7SC5+VacRDCbnHh75b+8v+oALs5ODGgVzNCODbiybSg+ZczzraxW8o4dIz8+HvLzURbLWQ9bTg7ZO3aSsXYttrQ0xMUFjz698b78CrwuH4g5NLRmL7ie0FVM2kUlz5rH/qT9NPFugp+bH3+c+IP7V93Pd9d+R4egDuyK38WCfxfwQJcHCPWs5i+V+H+NQHH1i+DbyJjrwiOgzjZkV5TNpth6LJmfd8WxYvdJTqbl4O9h5u9pV+FsciIxI5cAT5fzan9QFgtZ27aTsXo16atXYzl+HAC39u3xHzcW3+HDdTVUFdIBQrvopeam4mn2xNnJmeWHl/PqX6+ydMRSfF19mR81n7lRc5l5zUx8XHxIzknG1eRaPW0as66D7CS4Z12Nje3kaDabYvvxFI4mZnJDt0YAXP32WlKyLfRrEcSlLYK4tEUgYb6VD5pKKfKio0lf/TtpP/9MblQUri1bEDx5Ml5XXqkbwKuADhBavVNwAyDAqqOrWH5kOW9c9gYiwmt/vcYPB39g460bERHWnVhHhiWDIU2HXPiJj6w3ZsVrPwJsNmP4Dt/wcx52MVFKsWDLCdYfTODPgwkkZhqTKN3ZrynPDGuHUop9cem0DPXCbKr4TZdKKdJ/+ZX4994j7/Bh3Dp3ImTKI3j27lVdl1Iv6AChaUVsP72dgykHuanVTQA8uOpBYjJj+P667wF4ZfMrKBRP9XoKgB8O/ICLyYVrm10LwN7EvYR4hBDkfo6G6b+/gF+fgSufMe6hqIeTPNlsiqhT6fx5MIFWod5c1iqYo4mZDHhjDa7OTrRr6EPnRn50DPelf8sgQnzczpmmys8ndfFi4j/8iPyTJ/G89FKCp0zBvUMdvSnTwXSA0LRyWGwWknOSCfEIAeCtLW+Ra80tDBC3/XwbPq4+fHLVJwCMWjoKbxdvvrrmq/ITTjkOP02BgyshvAdc94Exz3Y9l5Zj4ff9p9l1IpV/TqSyOzaVrDwrn9zWjSEdw9gbm8Z3fx2jfUMf2jf0pVUDL1ydzw6uttxckr/9jsTPPsOakoL31VfjM+QaPHr3xjmgBnu31XE6QGjaBVBKYbFZcDEZ3UB3nN6Bq8mVtoFtybJk8dDqh7in8z1c0uCS0g6G3Ytg+WOQkwr9HoHLHjXmy9YAsNoUh+IzaODrhrebmWX/xPHYwl1k5BrdnJ2dhBYhXnw6tjuRQZ7YbAonpzNtD9aMDJK+mknSnDnY0tIAcG3bFs/evfHs2weP7t31nd7l0AFC06pJdEo0j6x5hOf7Pk/XkK6k5KSQZ8srLI0UykyEX56EXfMgqJUx1lOjHtDokou+x9P5sNkUx5Ky2BObxp7YVPbEpvHxbd3wdHXmrV+j+HXPKS5rFcRlrYK5JDIAN7MJlZ9Pzt69ZG7YSObGjWRv24ayWMBsxqNzZ9y7d8c51D4rX1AwzsFBOAcG1vvgoQOEplWjgv8hEeHD7R8ye+9sNo/ZjIgwP2o+W05u4fUBrwPw++Z3ObRrDjfGHcLPZjNuvAttB8c2Q/x++yCBLuWdrt5bsiOG+VuO8/fhZPKsNlydnbiqbSgf3dYNgK1HkwDwxorHv3uQ7VvI27yJnH37jI4DJTh5eGAKDsKjW3dCH38Mk59fTV6Ow+k7qTWtGhXtanl98+txdnIuXJdhySApJ6lw+1prCgfD2zL2lp/g5B4Ibm1s2PM97PgOuo4zln+ZBnE7wTvMGDjQu+gjFNwDwNW73nSlLer6LuFc3yWcrLx8Nh9KYu2/8cW2/9/CXRyKLzq3d1uuGD6AL+Z1xZqczOdLtuCbk0ZDWyZBeZl4ZachCfGk/vQTmRs20PC1V/HsrWddBF2C0LQaZ1M2nMSJnPwcTqSfoIV/C6OtIj0OfBoaO/3+ijH2U3qc8bDmnZ2QXxN4+B/j+crnQFlh0P+MZWs+mOrn77/dMakkZuaRlm0hNdtCWo6FcD93ru8SjlKK/q//zonk4sN+jOsdwVMthdhH/4+8w4cJuOMOgh+ejJPLxV+a0yUITatFCiZcenPLm/x86GeW3bAMfzf/M8EB4PInjQcYwSM7GdJiIf0kZJyErCQwFRnWIi8D7GNXYbPCx72MnlPdJ0CT3vWqpNEh3LfMbSLC+sevIDM3n2NJWRxNzORIYhatQr1wbxNKwDdzSX/nTZK+/JLMjRsJf+N1XFu0qMHc1y66BKFpDnI66zSb4zYzvPnwqk04Jw1WvQC75kNuGgS3NQJF55vBXU8GVBalFLd9vpmULAvTW2ST9dIL2DIzCXns//AfM+aivWu7vBJEPZg7UtNqpxCPkMLgsDdxL9/u+7ZqEnbzgWvfgqn7jXsvzO6w4nF4qw38cC8c22SUSrRiRIS7L2vG4YRMbttrxnXWd3j07Mmp//6P45MmYTl12tFZrHG6BKFptcALG1/gz5g/+f667/Fy8ar6E8TthC1fGUOU52VAYAsY/5PRAK4Vs/VoMnfM/BtXZydm3XEJoat+4vTrr4NS+I64noAJE3Bt3tzR2awyupurptVyVpuVhOwEQj1DSc9LJ8+aR6B7NcyBnZsBe5fAod+NIcpFYMuX4BkCbYdV/fnqqH9PpTPui80EeLry84P9yD9xnMQvvyT1h8Wo3Fy8Bg4k4I6JeFxySZ2vetIBQtPqkJm7Z/Le9vdYccOK6h+uXCn4tD8Et4JRXxrrspKMIcvrueNJWeRZbTQPPlOiy09KIvnb70j+9lusSUm4dehA4B0T8R40CHGum31+HN4GISKNReR3EdknIntEZLJ9/U32ZZuI9Ciyf6SIZIvIDvvj05rIp6bVBgMbD+SR7o8UBocvd3/JN/u+qZ6TicA9a2Hom8Zy7A54u53RbTYnrXrOWUc0DvCgebAXSimeXbKb6X9Ek+flQ/AD99Ni9SoavPACtowMYh6ZSvSgwWSs/9PRWa5yNdVInQ9MVUq1BXoD94tIO2A3cAPwRynHRCulutgfk2oon5rmcJG+kYxrN65wedupbeyM31m4fCj1UNWe0Ml0psTgFWIMVf7nu/B+V6P6yZpfteerY3LzbRxPyuLlZfu59NXVvPfbAVKtTvjfPJpmy36m0ccf4eTpwfF77yX1558dnd0q5ZAqJhFZAnyolFppX14DPKqU2mJfjgR+Ukp1qGiauopJu5hZrBbMJjOnMk8xeNFgnuj5BLe0uaX6Thizzbib+9gGo5vs4P9Bi6uq73x1wJYjSXy6Nprf9p3Gw8XER2O6cXkbY8wta1oax++7j+yt2wh95mkCxoxxcG4rzuFVTCUyEwl0BTafY9emIrJdRNaKSP8y0rpbRLaIyJb4+PjSdtG0i4LZflOcr6sv93W5j6sijC/r1NxU8m3V8As/vBtMXAaj50B+Dnx9I3w9Ck7vr/pz1RE9IgP4fPwl/PLwZQztGEbHRsYNebtjUjmc40STzz/Ha+BATr34X+I/+oiLoX23RksQIuIFrAVeUkp9X2T9GoqXIFwBL6VUooh0BxYD7ZVSZVaK6hKEVh89tPohknOSmTVkVuEd2lUuPxf+mgFrX4e8dKP3U8dR1XOuOmjMjE1sPJTIfQOb88jAZpx69llSlyzBf+xYQp96EnGq3beb1YqhNkTEDCwCvikaHEqjlMoFcu3Pt4pINNAK0BFA04q4rvl1pOSmFAaHLEtW1c+17ewKfR8wRpr9811oepmxPm4nmFwhpE3Vnq+O+eDWrry2Yj8f/R7NkYQs3nzxv5j8/EiaNQtrSgoNX3kZMZvPnVAtVCMBQoyOwl8A+5RSb1dg/2AgSSllFZFmQEugilvmNK3uK6hqAtgct5mpa6cyf9h8Gno1LOeo8+QZCIP+e2Z55bOQeAgm76iX06kWCPRy5bUbO9EixItXlu8nJiWbLx+cQnBAAPHvvIM1LZVG772Hk3vdm/ejpso+lwLjgCuKdF0dKiIjReQE0Af4WUR+se9/GbBLRHYCC4FJSqmk0pPWNA0g2D2Y9oHtC2+wm7VnFqN/HE2uNRcwShdVWqV845dw01dGcMjPhaUPwfG/jef1jDFMR3M+ua07/h5mvNzMBN1zNw1eeIHMdes5dsed2DIzz51QLaNvlNO0i9SyQ8tYH7Oel/u/DMBzG55j26lt/DjyRwA+2P4BSTlJPNfnOQBm75lNYk4iU7pPqfzJYrbC7BHG4IBiMobyCGkDIe0gpK3x179pvRiCXCmFiJCcmce+k2l0OLCFmCmP4HfLzYQ995yjs3eWWtEGoWlazRrabChDmw0tXL4s/DJa+J0Zujrflo/Failc3pu0t1gJY/LqyTTxacLUHlOBM198pQrvbsxNEb0KTu8zHif/gb1LAXuaJlcYMw+aXw6ZCZCXacxpUceHqiip4DV6/Zco5m85zn+v78CV48eTNHMmPoMH16nJiHQJQtO0Ur206SXCvcKZ0GECSimGfj+UW9rcwvj24wFYH7OeVv6tzp5/u6i8LEj41x409kDfh4yb8TZ+BL88BVP/NWbIi9kGVovRvdZUNxt0S8rIzefBb7fxe1Q8k3o1ZNSnT4LFQtOlSzF5eTo6e4Vq1X0QmqbVDdN6T2NChwkA5FpzGdB4AKEexvAf6Xnp3Pvbvfx8yLhzOMuSxT0r7+H7AyU6KLp4QMMu0OVWY7Y7L3swaT0Erv/ICA4A69+BLwfB223tjd/RNXCF1cvL1ZkZt/dgQt9IPt0cy6ab7sMSF0f82285OmsVpksQmqZVmsVmYU/CHkI9QgnzCiMuI46H1zzMc32eo11gu/Kro0qTcRqObTQmOYpabkyfGtnfmOio7XCjq20dpZRi8twd7DyRwrd5m0ibM5smM7+qNVVNejRXTdNq1Pvb3ifTksnjPR+v/A186SdhxzewdRakHAX3AOMejB53QFDdnP4zIzcfq03hTT6HR4xE5efTbOkSnDwdX9Wkq5g0TasxSilyrDnkWHPO7+5u7wbQfyo8tAPGLTZuzPtrujGHhXGCqsxujfBydcbX3YzF7MKusQ9hiY3l9FvnvCXM4XQvJk3TqpSI8Nglj2FTNgBOpJ9g0YFFTOo8CVdTJaqKnJyMHk/NL4eMeGPqVIBts2D/Mrjxc2N61Trklz2nmLJHMf2K6+Dbb/EeNAjP3r0cna0y6RKEpmnVoqD0sPbEWubun0tS9gXc6+oVDK5Fp2JV4OptPE0/df7p1rDhncIY2rEBD3v2xtawEXFPP12rb6DTAULTtGp1W9vb+HHkj4R5GfNfT149ma92f3X+CXafALctMO6fyEww5q349majq2wtJyK8emMngoJ8ea3TTVhiYmp1VZMOEJqmVbsg9yDAuDnPbDLj7GTUblttVl7Y+AL/xP9zfgk7u0L/KXBsE8y4HBb9B1JPVFW2q4WPm5mPxnRjk2djdvQcTPK335K5+S9HZ6tUuheTpmkOcyT1CGOXj+WZ3s8wOHIwWZYsjqQdoV1gu8ollJMKf74PGz8EBPo9bNyU51LFI9tWoSU7Ymjr74LT3WPBaqPZzz/h5Frz3Xl1LyZN02qlSN9I1oxewxVNrgDgh4M/cPNPN3Mg+UDlEnLzhSufgfv/glaDYc0r8OEl8M/CWtvr6fou4bSKCKbBs89iOXGClIULHZ2ls+gAoWmaQzk7OWN2MobXuK75dbzc72Va+rcE4Jt93zB3/9yKJ+YfAaNnwYRlxjzbi+6Elc9UR7arzEdpAfwb2pyE6TOw5daukXArFSBEpK2IPCMiH9mX24hIp+rJmqZp9Y23izfDmw8vXN4Qu4HNcWdmJ07LK3NSyeIiL4W718B1H0CX24x1cTuNO7UtOVWY4wt3SdMAvmxxFdZTp2pdKaLCAUJEbsKYLjQcY24HAC+g9jbBa5pWp3105UeFw5UnZCdw1YKrzh7vqSxOJuh2uzHcOMA/C4w5Kwpu3tvzA+z4DlKOVUPOK25AqxDimrbnROPWJNayUkRlShAvAoOUUpMAq33dTqBzledK0zTNzt3ZuEHOSZy4pc0tdAvpBsDh1MMsjV5KnjWvYgld9QLc+yc4uxjLW76ExZPg3Y7wTkf4/WWHtFeYnISR3RrxScTl5NeyUkRlAkQIRkCAwgHeUUWea5qmVZsAtwAe6f4Ikb6RAPx06Cde3PgimRbjRrNz9sh0MkFg8zPL45bApD9hyOsQ3BrWvga/Pu2QIHFDt0ZsC2xOWsv2taoUUZkAsZUzVUsFbgFqZwdeTdMuag90eYB5w+bh7+YPwNS1U3ntr9cqnoCTEzToAL3uMW6863m30U12bSXSqCKtG3jz/phuRE6dXKtKEZUZi+kh4FcRuRPwtM8f3QoYVC050zRNK4eI0NzPKBHYlI1Qj1CCPYIBozTx06GfuLzx5Xi5eJWXTEFicM1rxix3a14BFy/o+0B1Zv8s13VuiFJhZPfoTuL0GfiNGuWQ+yKKqnAJQim1H2gDfAQ8DXwFdFRKVbLDsqZpWtVyEice7/k4d3S4A4B9Sft4av1TLD+yHKhA9RMYJYrh70O76+HXafDvr9WZ5VIt2HKCHVfcVGtKEZUazVUplQXMr6a8aJqmVYm2AW35dui3hSWMX478wnf7v+ONAW+UP0WqyRlu+NyYY7vZwJrJbBEr951ie4wHC7rXjlJEZbq5rhORP0p7VGcGNU3TKktE6BjcEQ+zMdSGycmEq8mVALcAgMKhyEvl7AKXTjb+ZiZA9O81kWUAbuzWiITMPGKvH1srShGVaaT+HPiiyONnoAHwWzXkS9M0rcpcHXE10wdNx9nJmTxrHjf/dDM/HPjh3Af+8hQsGG+M9VQDrmgTgr+HmW8twbjb2yIc2aOpMm0Qs0o8XgOGAldXX/Y0TdOqVqYlk3Cv8MKqJqvNWnYbxTWvwm2LjLGebNbS96lCLs5OXNe5ISv3ncbjP5McXoq40LGYYgA91IamaXWGv5s/717+LpeGXwrA1/u+5q5f7yLLknX2zh4B0PgS4/n6t2HWdXCiekeNvrF7I9o39CGlTSeHlyIq0wZxR4nHAxjVTJuqL3uapmnVy8fFh2CP4ML2ijJ5BMGpPfD5lfDtLXByd7Xkp1MjP36471JaNfAh+IEHHFqKqPB8ECJSsqUmE9gBvKOUSqzifFWang9C07QLlZSTxJ8xfxYbMLCY3AzY/An8+QHkpkKHG2HgUxDUosrzkpplwWqzkTbpTvKOHKX5zz9h8vWt8vNUyXwQSqnLSzyGKaWerg3BQdM0rSrM3DOTFze+yMnMk6Xv4OoFl/0fPLwT+j0CUcvho56w+H5jbKfsZGO/xGjYuxTy7eNEpZ6o1CiyaTkWer3yG19tOELok09iTU7m9JtvXuDVVV5lh/v2FZGeInJF0Ud1ZU7TNK0mPdT1IWYOmUkDzwZAOTfYufvDVc/B5J3GEB3/zIefpkBGvLH93xUwfxzkZxvLmz+F15vB3Ntgx7eQWf7vah83M5dEBvD9thhc27YjcOIEUhYsJHPT5nKPq2qVqWKagHEXdQZQtDVHKaWaVX3WKkdXMWmaVpXWHF/D3Ki5vHnZm+ceriMvE3LTwSMQTGYjAKTHQkg7Y5DA2B2wbbZR4kiPNYYcb9wLWg+B1teWWkW1ZEcMk+fu4Nu7etE73ItD110PQLMli3Fyd6+y66yqKUdfAkYppUKVUk2LPBweHDRN06paWl4aGXkZOEkFviZdPMG7gREcADwDoUFHIzgANOwCw96GR/bC3WuNaqq8DFj5LHzYHT65FI4XH/d0ULsGeLk68/22GJzc3Ah78UUsx46R8NFHVXuh5ahMgHAGzmtwEhFpLCK/i8g+EdkjIpPt62+yL9tEpEeJY54UkYMiEiUig8/nvJqmaefruubXMeuaWXiYPbBYLRxPP37hiYoYweLyp2DSenh4Nwx5A3LSjAmNinB3MXFtxzCW/xNHjsWKZ+9e+N00isSvZpK9Z8+F56Ui2a1EFdMjgDfwX6XKu0+91GPDgDCl1DYR8cYYOnwExlwSNuAz4FGl1Bb7/u2A74CeQEOMu7VbKaXKvFNFVzFpmlZdXvvrNdbHrGfB8AW4ObtV/Qly0sDJGVw8jOooZ1cIacuxxCzybTaaBRtVXNa0NKKvvRbnoGCazp+HmM0XfOqqqmKagjGKa7qIHCv6ONeBSqk4pdQ2+/N0YB8QrpTap5SKKuWQ64G5SqlcpdRh4CBGsNA0TatxAxsP5Pb2t+NqqqaB89x8jOAAsOIJmDcWbFaaBHoUBgcAk48PDZ55htx9+0icObN68lJEZUZzHVsVJxSRSKArUF5zfDjFb8A7YV+naZpW43qF9aJXWK+aOdnoOUZDtpMJ8nPZf+Agn+7M438jO+Ll6ozPoEGkXX01CR9+hM/VV+MSGVltWalwgFBKrb3Qk4mIF7AIeFgplVberqVloZT07gbuBmjSpMmFZk/TNK1cG2M3Mn3XdD6+6uPCubKrnFew8QD44w1abPyEptmDOObVnXbNI8EjkND7biVz40binnmGJrNmIU4XOmpS6SocIETEFXgWuBUIVEr5isggjLaBDytwvBkjOHyjlPr+HLufABoXWW4ExJbcSSk1HZgORhtEhS5E0zTtPDk7OZOWl0ZCdgKNvRuf+4AL1XUccmwzk498D1u+B3szqxkIaevByb8zSJnUCf/p1TPsR2UaqT/GqOZ5FViulPITkXDgV6VU+3McK8AsIEkp9XAp29dQvJG6PfAtZxqpVwEtdSO1pmmOZlO2inV9rUL/+fwPMpJPMXdsK8hKhKwkVGYix17+jpzjSTRb8Rvm0HImQipHVTVSjwTGKKU2YvQ8QikVQ8XaBi4FxgFXiMgO+2OoiIwUkRNAH+Bn+zzXKKX2YMxctxdYAdxfXnDQNE2rKU7iRJ41jy93f1n6CLDVoFerRmxK9CDOoxU0vwI6jkJ630PY+zNRNidOvfRStZy3Mo3UeSX3F5Fg4JxjMSml1lN6uwJAqbN2KKVewrg5T9M0rVbZm7iXd7e+S4hHCMOaDav28/VvFUTzvz05mZpDmO+Ztg+XyEgavPA8rs2rfrBAqFwV05tAC4zurluB9sC7wEGl1LRqyV0l6ComTdNqUnRKdOGc13VZVVUxPQUcAf4B/IADGA3HL1xg/jRN0+qcguAQkxFTY1VN+VZb2QMIVoPKDPedp5R6WCnlBYQC3kqpKUqpvOrLnqZpWu2VnJPMqKWj+GD7B9V+rg3RCXT970r2xJZ3h0DVqsyMcovtYye5KqXiVU2GMU3TtFrI382fqT2mMq7duGo/V/NgL9Jz8ll/MKHaz1WgMlVMa4H/A06LyCwRGSxSw329NE3TaplRrUbR0KshSiliM866XavKhPq40SrUi/UHamGAUEq9o5TqCfQADmE0UMeKyPvVlDdN07Q64/N/PmfU0lHVGiT6twzmryNJ5Fhqptd/pUsASqkDSqkXgFuAXcD9VZ4rTdO0OmZYs2FM7DCRMM+wajtHv5ZB5OXb+OtwUrWdo6jKTjnaXESeFpE9GHNDHAAGVEvONE3T6pAwrzDu6nQXIkJCdgJxGXFVfo5eTQOYNKA54f7VNA5UCZUZi+lvoBWwFHgUY4gNfXezpmlaEUopHlr9EBabhXnD5lXpsBweLs48MaRNlaV3LpW5k/pNYKlSKru6MqNpmlbXiQiPXfIYQLWM2ZSbb2Xr0WTah/ni63HhEwaVpzKN1PMADxEZJyKPAYhIQxFpVG250zRNq4O6hHShS0gXADbEbqjSG+miTqYzZsZm1vx7usrSLEtl7oMYAEQBtwHP2Fe3BD6phnxpmqbVeSczT/LAqgf4eMfHVZZm+4a++HmYWVcD3V0rU8X0LnCzUmqViCTb121GTwWqaZpWqgaeDfjwig8LSxNVweQkXNo8iHUH4lFKYcymUD0qU0EWqZRaZX9ecBf1WSO8apqmaWf0De+Lh9mjStPs1zKIU2m5HDydUaXpllSZALFXRAaXWHcVxuB9mqZpWhn2Ju5l1NJRHEo5VCXp9WsRBFDtw25U5tf/Y8ASEfkZcBeRz4DhwPXVkjNN07SLRIhHCK4mV9LyqmagvcYBHiy5/1LaN/SpkvTKUqH5IETEBGQAzYGxQARwHPhaKXWiWnNYQeXNB5GWlsbp06exWCw1nCutvjCbzYSEhODjU73/sJpW1cqbD6JCJQillFVE/rU/f70qM1fd0tLSOHXqFOHh4bi7u1drg45WPymlyM7OJiYmBkAHCa1MFquFpJwkQj1DLzit+PRcPl5zkBFdwunc2O/CM1eKylQxfQP8JCLvASc401CNUmp1VWesqpw+fZrw8HA8PKq2kUjTCogIHh4ehIeHExsbqwOEVqZxy8fh6+rLZ1d/dsFpuZqdmL3xKB4uploRIO61/32+xHoFNKuS3FQDi8WCu3vNjFui1W/u7u66GlMr18QOE/E0e1ZJWj5uZro09mP9gQT+r2T3oSpS4QChlGpaPVmofrpaSasJ+nOmncvgyKr9Ju/fMoj3Vh0gJSsPPw+XKk0bzmO4b03TNO38JeUk8e2+b7HaLnys0/4tg1AKNkQnVkHOzqYDxEVq5syZ9OvXr3DZy8uLQ4eqpg+2pmnnb+uprbzy1yvsjN95wWl1buRHZKAHadnVU7WpA4SDRUZG8ttvvxUuz507F39/f9auXcuRI0cQEfLz8y/4PBkZGTRrVmubijSt3hjYaCA/XPcD3UK7XXBaziYnfn90ILf0bFIFOTubDhC1yKxZs7j//vv5+eefGTCg9s/DVBWBS9PqG7PJTAv/FlWWXm0Zi0mrRtOnT2fq1Kn88ssv9O3bt9LHJyYmct111+Hj40PPnj2Jjo4utl1EOHjwIJs2baJBgwZYrWfqP3/44Qc6deoEgM1m49VXX6V58+YEBgYyevRokpKM6Q0LSjRffPEFTZo04YorrsBqtTJ16lSCgoJo2rQpH374YbFST2pqKnfeeSdhYWGEh4fz9NNPF567oBrs0Ucfxd/fn6ZNm7J8+fLCfCUlJTFx4kQaNmyIv78/I0aMKNz2008/0aVLF/z8/Ojbty+7du2q9GumaY6Sb8vnlc2vMG//PEdnpVz1cqC9mz/beNa6YZ3CGNcnkuw8KxO++uus7aO6N+KmHo1Jyszj3q+3nrV9bO8IhnduSGxKNg39Ktet9pNPPmH9+vWsWrWKzp07V+rYAvfffz9ubm7ExcVx+PBhBg8eTNOmZ3c86927N56enqxevZqrr74agG+//ZYxY8YA8P7777N48WLWrl1LcHAwDz30EPfffz/fffddYRpr165l3759ODk5MWPGDJYvX86OHTvw9PTkpptuKna+8ePHExoaysGDB8nMzGTYsGE0btyYe+65B4DNmzczfvx4EhISmD59OnfeeScxMTGICOPGjcPLy4s9e/bg5eXFhg0bANi2bRt33HEHP/74Iz169ODrr7/muuuuIyoqCldX1/N6/TStJjk7OROdGo2bs5ujs1IuXYKoBVauXEnv3r3p2LHjeR1vtVpZtGgRL774Ip6ennTo0IHx48eXuf+tt95a+IWfnp7OsmXLuPXWWwH47LPPeOmll2jUqBGurq48//zzLFy4sFh10vPPP4+npyfu7u7Mnz+fyZMn06hRI/z9/XniiScK9zt16hTLly/n3XffxdPTk5CQEKZMmcLcuXML94mIiOCuu+7CZDIxfvx44uLiOHXqFHFxcSxfvpxPP/0Uf39/zGZzYbXbjBkzuOeee+jVq1fhca6urmzatOm8Xj9Nc4TpV09nSvcpjs5GueplCWLePX3K3ObuYip3e4CnS7nbK1t6APj000/573//y3/+8x+++OKLStcpxsfHk5+fT+PGjQvXRURElLn/mDFj6Nu3L5988gnff/893bp1K9z/6NGjjBw5EienM78dTCYTp06dKlwuep7Y2Nhiy0WfHz16FIvFQlhYWOE6m81WbJ8GDRoUPi+42z0jI4OkpCQCAgLw9/c/K/9Hjx5l1qxZfPDBB4Xr8vLyiI2NLfOaNa22KZiONNOSWWU3z1U1XYKoBUJCQli1ahXr1q3jvvvuq/TxwcHBODs7c/z48cJ1x44dK3P/du3aERERwfLly4tVL4HxBb98+XJSUlIKHzk5OYSHhxfuUzSAhYWFceLEmfEai+ahcePGuLq6kpCQUJhWWloae/bsOec1NW7cmKSkJFJSUkrdNm3atGJ5zMrKKiwFaVpdMXf/XK6Yf0WVjfJa1XSAqCUaNmzI6tWrWbFiBVOmFC925ubmkpOTU/iw2WzFtptMJm644Qaef/55srKy2Lt3L7NmzSr3fGPGjOH999/njz/+KNZuMGnSJKZNm8bRo0cBo3SyZMmSMtMZPXo07733HjExMaSkpPDaa68VbgsLC2PQoEFMnTqVtLQ0bDYb0dHRrF279pyvR1hYGEOGDOG+++4jOTkZi8XCH3/8AcBdd93Fp59+yubNm1FKkZmZyc8//0x6evo509W02qRrSFfGtB1z1v90baEDRC3SuHFjVq9ezcKFC3nyyScL13t5eeHu7l74WL367LERP/zwQzIyMmjQoAETJkxg4sSJ5Z7r1ltvZc2aNVxxxRUEBQUVrp88eTLXXXcdgwYNwtvbm969e7N58+Yy07nrrrsYNGgQnTp1omvXrgwdOhRnZ2dMJhMAs2fPJi8vj3bt2uHv78+oUaOIi4ur0OsxZ84czGYzbdq0ISQkhHfffReAHj16MGPGDB544AH8/f1p0aIFM2fOrFCamlabtA5ozeRuk/Fz83N0VkpVofkgLvgkIo2B2UADwAZMV0q9JyIBwDwgEjgCjFZKJYtIJLAPiLInsUkpNam8c5Q1H8S+ffto27ZtFV2Jdi7Lly9n0qRJhSWQ+kZ/3rTKstgsRCVF0di7Mb6uvjV+/vLmg6ipEkQ+MFUp1RboDdwvIu2AJ4BVSqmWwCr7coFopVQX+6Pc4KA5TnZ2NsuWLSM/P5+YmBheeOEFRo4c6ehsaVqdEZ0Sza0/38q6mHWOzspZaiRAKKXilFLb7M/TMUoH4RjTlRZUls8CRtREfrSqo5Tiueeew9/fn65du9K2bVtefPFFR2dL0+qMln4teWPAG/RtWPkbZKtbjXdztVcfdQU2A6FKqTgwgoiIhBTZtamIbAfSgKeVUmeFVxG5G7gboEmT6hmLRCufh4cHf//9t6OzoWl1lsnJxDWR1zg6G6Wq0UZqEfECFgEPK6XK69cVBzRRSnUFHgG+FZGzpulSSk1XSvVQSvUIDg6unkxrmqZVs+ScZH469BMZeRmOzkoxNRYgRMSMERy+UUp9b199SkTC7NvDgNMASqlcpVSi/flWIBpoVVN51TRNq0n/Jv/Lk+ueZEf8DkdnpZgaCRBi3Fn1BbBPKfV2kU1LgYIxIcYDS+z7B4uIyf68GdAS0JMZaJp2Ueoc3JkFwxfQJ6zsURocoabaIC4FxgH/iMgO+7qngFeB+SJyJ3AMKLhj6zLgRRHJB6zAJKVUUg3lVdM0rUa5ObvRJqCNo7NxlhoJEEqp9UBZAwxdWcr+izCqozRN0+qFQymHWH5kOXd3vBuzyezo7AD6Tup6Yc2aNTRq1KhwuX379qxZs8ZxGdI07SwHUg4wfdd0DqcddnRWCukA4UCDBw/m2WefPWv9kiVLaNCgAfn5+UyYMAEXFxe8vb3x9vamQ4cOPPnkk6Smpp73effs2cPAgQMvIOeaplW1AY0GsOHWDbTyrz39cXSAcKAJEyYwZ84cSg53MmfOHG677TacnY0awMcee4z09HTi4+P56quv2LRpE5deeimZmZmOyHap9PSjmnZh3Jzdat2w3zpAONCIESNISkpi3boz9wAmJyfz008/cfvtt5+1v5ubG5dccglLly4lMTGRr776qtR0s7OzmTBhAv7+/rRr1+6sG9kiIyP57bffiI2Nxd3dvXBKUYDt27cTFBSExWIB4Msvv6Rt27b4+/szePDgYmMsiQgfffQRLVu2pGXLlgC8/vrrhIWF0bBhQz7//PPCqU7BGJX20UcfpUmTJoSGhjJp0iSys7OBM9Vgb731FiEhIYSFhRW7vuzsbKZOnUpERAS+vr7069ev8NhNmzbRt29f/Pz86Ny5s64+0+qsDbEbeG7Dc2f9aHSUejlhEF9de+59Wg2GSx86s3+XMdD1NshMhPlnf3kXM/HnCmXD3d2d0aNHM3v2bC677DIA5s+fT5s2bcqdetTb25urr76adevW8cADD5y1/YUXXiA6Opro6GgyMzMZMmRIqek0bNiQPn36sGjRIu666y7AmH501KhRmM1mFi9ezMsvv8yPP/5Iy5YtefXVV7n11lsLp/4EWLx4MZs3b8bd3Z0VK1bw9ttvs2rVKpo2bVo4rWiBxx9/nEOHDrFjxw7MZjNjxozhxRdf5JVXXgHg5MmTpKamEhMTw8qVKxk1ahQjRozA39+fRx99lD179rBhwwYaNGjA5s2bcXJyIiYmhmuvvZY5c+ZwzTXXsGrVKm688Ub279+PvnlSq2tOpJ9gQ+wGknOTCXALcHR2dAnC0caPH8+CBQsKfw3Pnj273OlCCzRs2LDYL/+i5s+fz7Rp0wgICKBx48Y89NBDZaYzZsyYwulHlVLMnTu3cAKhzz77jCeffJK2bdvi7OzMU089xY4dO4qVIp588kkCAgIKpx+dOHEi7du3x8PDg+eee65wP6UUM2bM4J133iEgIABvb2+eeuqpYtOPms1mnn32WcxmM0OHDsXLy4uoqChsNhtffvkl7733HuHh4ZhMJvr27Yurqytff/01Q4cOZejQoTg5OXH11VfTo0cPli1bds7XUNNqmxtb3sjKUStrRXCA+lqCqOAv/FL39wys/PHl6NevH8HBwSxZsoSePXvy999/8/3335/zuJiYGAICSv8QlZwGtLzpR0eNGsWDDz5IbGwsBw4cQETo378/YEztOXnyZKZOnVq4v1KKmJiYwjRLTj/ao8eZUYOLbouPjycrK4vu3bsXS8tqtRYuBwYGFra7gDHOU0ZGBgkJCeTk5NC8efOz8n/06FEWLFjAjz/+WLjOYrFw+eWXl3nNmlZbmZxMjs5CMfUzQNQyt99+O7NnzyYqKopBgwYRGhpa7v4ZGRn89ttvTJs2rdTtYWFhHD9+nPbt2wPlTz/q5+fHoEGDmD9/Pvv27ePWW28tnFK0YGrP2267rczjKzr9aFBQEO7u7uzZs6fY9KUVERQUhJubG9HR0WdVvTVu3Jhx48YxY8aMSqWpabXV/Kj5bIzdyDuXv+PorOgqptrg9ttv57fffmPGjBnlVi/l5uaydevWwnr5smaNGz16NK+88grJycmcOHGCDz74oNzzjxkzhtmzZ7No0aJi81NPmjSJV155pXAO6dTUVBYsWFBmOqNHj+arr75i3759ZGVlFRv228nJibvuuospU6Zw+vRpwCgF/fLLL+XmreDYO+64g0ceeYTY2FisVisbN24kNzeXsWPH8uOPP/LLL79gtVrJyclhzZo1xQKVptUledY8Mi2ZWGwWR2fFKOZfDI/u3bur0uzdu7fU9bXNgAEDlJ+fn8rJySm2fvz48cpsNisvLy/l4eGh2rVrpx577DGVnJxcZlqZmZlq3LhxytfXV7Vt21a9/vrrKjw8vHB7RESEWrlyZeFyVlaW8vLyUu3atTsrrdmzZ6sOHToob29v1ahRIzVx4sTCbYA6cOBAsf1ffvllFRoaqsLCwtTHH3+sAHXs2DGllFLZ2dnqySefVE2bNlXe3t6qTZs26r333lNKKfX7778Xy2PJfGZlZanJkyerhg0bKh8fH9W/f3+VlZWllFJq06ZN6rLLLlP+/v4qKChIDR06VB09erTM16c61ZXPm6YVALaoMr5Xa2TK0Zqgpxytffbt20eHDh3Izc0t1rZwMdOfN62uqQ1Tjmr1xA8//EBeXh7Jyck8/vjjDB8+vN4EB02rKq/99RqTfnP8TMs6QGhV6rPPPiM4OJjmzZtjMpn45JNPHJ0lTatzwr3CaebbzNHZ0L2YtKq1YsUKR2dB0+q8se3GOjoLgC5BaJqm1Vo5+TkOPb8OEJqmabXQnb/cyf+t/T+H5kFXMWmaptVCgyMHY3Zy7MRBOkBomqbVQqNbj3Z0FnQVk6ZpWm2VZckiPiveYefXAeIiMnDgQD7//HNHZ0PTtCqglGLYD8N4b9t7DsuDDhAOFhkZibu7O15eXvj7+3PttdcWG+TOEWbOnEm/fv0cmgdNq+9EhEd6PMINLW9wWB50gKgFfvzxRzIyMoiLiyM0NJQHH3zQ0VnSNK0WGNZsGN1Cuzns/DpA1CJubm6MGjWKvXv3AmdXGZX8Zb9y5UratGmDr68vDzzwQLFpCq1WK1OnTiUoKIimTZvy4YcfIiKFc0enpqZy5513EhYWRnh4OE8//TRWq5V9+/YxadIkNm7ciJeXF35+fjVz8ZqmncWmbEQlRXE8zTG1CvUyQExcMZHFBxcDYLFZmLhiIj9GGxPOZOdnM3HFRFYcNu4ITs9LZ+KKifx29DcAknOSmbhiImuOrwEgITuBiSsmsj5mPQAnM0+ed76ysrKYN28evXv3Pue+CQkJ3Hjjjfzvf/8jISGB5s2b8+effxZunzFjBsuXL2fHjh1s27aNxYsXFzt+/PjxODs7c/DgQbZv386vv/7K559/Ttu2bfn000/p06cPGRkZpKSknPf1aJp2YfJt+Yz5eQxzo+aee+dqoLu51gIjRozA2dmZjIwMQkJCKjRHwrJly2jXrh2jRo0C4OGHH+att94q3D5//nwmT55Mo0aNAHjiiSdYtWoVAKdOnWL58uWkpKTg7u6Op6cnU6ZMYfr06WfNI61pmuO4mFx4/4r3ae539myKNaFeBoivrvmq8LnZyVxs2d3Zvdiyt4t3sWV/N/9iy0HuQcWWG3g2qHR+Fi9ezFVXXYXVamXJkiUMGDCgsJqpLCWnFRWRs6b/LLpc9PnRo0exWCyEhYUVrrPZbMX20TStdrg0/FKHnbteVjHVViaTiRtuuAGTycT69evx9PQkKyurcPvJk2eqrwqmFS2glCq2XN70n40bN8bV1ZWEhARSUlJISUkhLS2tcOa4otOIaprmWFablV+O/MK2U9tq/Nw6QNQiSimWLFlCcnIybdu2pUuXLnz//fdkZWVx8OBBvvjii8J9r732Wvbs2cP3339Pfn4+77//frEAMnr0aN577z1iYmJISUnhtddeK9wWFhbGoEGDmDp1KmlpadhsNqKjo1m7di0AoaGhnDhxgry8vJq7eE3TSuUkTrz+1+ss/HdhzZ+7xs+onWX48OF4eXnh4+PDtGnTmDVrFu3bt2fKlCm4uLgQGhrK+PHjue222wqPCQoKYsGCBTzxxBMEBgZy4MABLr30TFH0rrvuYtCgQXTq1ImuXbsydOhQnJ2dMZlMAMyePZu8vDzatWuHv78/o0aNIi4uDoArrriC9u3b06BBA4KCgmr2xdA0rRgRYeY1M3nx0hfPvXNVn1tPOVo/LF++nEmTJnH06FFHZ+Wipj9vWl2jpxyth7Kzs1m2bBn5+fnExMTwwgsvMHLkSEdnS9O08zRrzyy+3vt1jZ6zRgKEiDQWkd9FZJ+I7BGRyfb1ASKyUkQO2P/6FznmSRE5KCJRIjK4JvJ5MVFK8dxzz+Hv70/Xrl1p27YtL75Y80VUTdOqxpaTW9h2umYbqmuqm2s+MFUptU1EvIGtIrISmACsUkq9KiJPAE8Aj4tIO+AWoD3QEPhNRFoppaw1lN86z8PDg7///tvR2dA0rYq8ffnbNT4/RI2UIJRScUqpbfbn6cA+IBy4Hphl320WMML+/HpgrlIqVyl1GDgI9KyJvGqaptVGjpg8qMbbIEQkEugKbAZClVJxYAQRIMS+WzhQdPCRE/Z1JdO6W0S2iMiW+HjHjZmuaZpWEz7Z+QkPrX6oxs5XowFCRLyARcDDSqm08nYtZd1Z3a2UUtOVUj2UUj2Cg4OrKpuapmm1koezB94u3tiUrUbOV2NDbYiIGSM4fKOU+t6++pSIhCml4kQkDDhtX38CKDruQyMgtqbyqmmaVhuNbz++Rs9XU72YBPgC2KeUervIpqVAwRWPB5YUWX+LiLiKSFOgJfBXTeRV0zSttsuyZJ17pypQU1VMlwLjgCtEZIf9MRR4FbhaRA4AV9uXUUrtAeYDe4EVwP31vQfTpEmT+O9//1vl+9Ym69ato3Xr1hXad8KECTz99NPnfS4vLy8OHTp03sdrmqPM2DWDqxZchcVqqfZz1UgVk1JqPaW3KwBcWcYxLwEvVVumaonIyEhiY2OJjY0tNqxFly5d2LlzJ4cPHyYyMpJPP/20wmlWZt+aEhMTQ0REBFFRUTRvXnzo4pEjR9K8eXPefPNNoqKiqvzcAwcOZOzYsfznP/8pXJeRkVHl59G0mtA9tDtWZSXPlofZVL09m/Sd1LVA06ZN+e677wqX//nnH7Kzsx2Yo6oXHh7OlVdeyZw5c4qtT0pKYtmyZYwfX7N1q5pWV3UL7cakzpPwNHtW+7l0gKgFxo0bx+zZswuXZ82axe23315sn6JVKmvWrKFRo0a89dZbhISEEBYWxldffVXuvq+//nrhvosXL2bZsmW0atWKgIAAXn755VKPLXp8gcjISN544w06deqEp6cnd955J6dOnWLIkCF4e3tz1VVXkZycXOp1jh8//qwAMXfuXNq3b0/Hjh3POte+ffsYOHAgfn5+tG/fnqVLl5aabnJyMsOGDSM4OBh/f3+GDRtWONT5tGnTWLduHQ888ABeXl488MADgDEA2sGDBwFj+tXbb7+d4OBgIiIi+N///ofNZvQSKZjm9dFHH8Xf35+mTZuyfPnyUvOhaTXFarOyM34n1T2WXr2bMOjkyy+Tu29/tZ7DtW0bGjz1VIX37927N3PmzGHfvn20atWKefPmsX79+nLr2E+ePElqaioxMTGsXLmSUaNGMWLECPz9/UvdNycnh5iYGGbOnMldd93F1VdfzdatWzl27Bjdu3fnlltuoVmzZhXK76JFi1i5ciX5+fl07dqV7du388UXX9CuXTuGDBnC+++/z3PPPXfWcSNHjuTee+9l/fr1hXNrz5kz56xgCGCxWBg+fDh33HEHv/76K+vXr+f6669ny5YtZ7VT2Gw2Jk6cyPz587Fardxxxx088MADLF68mJdeeok///zzrCqmoh588EFSU1M5dOgQiYmJDBo0iLCwMO68804ANm/ezPjx40lISGD69OnceeedxMTE6HkzNIdZfHAxz298nh+u+4EW/i2q7Ty6BFFLFJQiVq5cSZs2bQgPP+u+wGLMZjPPPvssZrOZoUOH4uXlVWb9vdlsZtq0aZjNZm655RYSEhKYPHky3t7etG/fnvbt27Nr164K5/XBBx8kNDSU8PBw+vfvT69evejatSuurq6MHDmS7du3l3qcu7s7N910U2Fp6cCBA2zdupUxY8acte+mTZvIyMjgiSeewMXFhSuuuIJhw4YVq4orEBgYyI033oiHhwfe3t5MmzatcG6Lc7FarcybN49XXnkFb29vIiMjmTp1arGSTkREBHfddRcmk4nx48cTFxfHqVOnKpS+plWHAY0H8MaAN2jo1bBaz1PvShCV+WVfk8aNG8dll13G4cOHS/1FXVJgYCDOzmfePg8PjzIbXgMDAwvngXB3dweMSYEKuLu7V6rRtuSxlUlr/PjxDB8+nPfff585c+ZwzTXXEBISctZ+BVOmOjmd+Q0TERFBTEzMWftmZWUxZcoUVqxYUVi9lZ6ejtVqLbzusiQkJJCXl0dERESZ52nQ4Mw0sh4eHoBu5NYcK8g9iGsir6n28+gSRC0RERFB06ZNWbZsGTfccIPD8lHeNKdVoX///gQGBrJkyRK+/vrrMoNhw4YNOX78eGFbAMCxY8dKLVm99dZbREVFsXnzZtLS0vjjjz8ACutny6sKCgoKwmw2F5sno6zzaFptkpqbyg8HfiAlJ6XazqEDRC3yxRdfsHr1ajw9q793Qlm6dOnCsmXLSEpK4uTJk7z77rtVfo7bb7+dxx9/nJSUFIYPH17qPr169cLT05PXX38di8XCmjVr+PHHH7nlllvO2jc9PR13d3f8/PxISkrihRdeKLY9NDS0zHseTCYTo0ePZtq0aaSnp3P06FHefvttxo4de+EXqmnV6ET6CZ7d8CwbYjdU2zl0gKhFmjdvTo8epU7sVGPGjRtH586diYyMZNCgQdx8881Vfo7bb7+dY8eOcfPNN+Pq6lrqPi4uLixdupTly5cTFBTEfffdx+zZs2nTps1Z+z788MNkZ2cTFBRE7969ueaa4kXvyZMns3DhQvz9/XnoobMHOvvggw/w9PSkWbNm9OvXjzFjxnDHHXdUzcVqWjVpG9iWhcMXMqTpkGo7h55yVNOqkP68aXWNnnJU0zTtIpSam8o7W99hZ/zOaklfBwhN07Q6ysXkwryoeexJ2FMt6de7bq6apmkXC3dnd9aMXoObs1u1pF8vShAXSzuLVrvpz5nmCNUVHKAeBAiz2XzRDXyn1U7Z2dmYzTU/b7CmVZeLPkCEhIQQExNDVlaW/oWnVQulFFlZWcTExJR6V7im1VUXfRuEj48PYAzdYLFU/wQbWv1kNpsJDQ0t/Lxp2sXgog8QYAQJ/Y+raZpWORd9FZOmaZp2fnSA0DRN00qlA4SmaZpWKh0gNE3TtFJdNIP1iUg8cLScXYKAhBrKTm1SX68b6u+16+uufy7k2iOUUsGlbbhoAsS5iMiWskYsvJjV1+uG+nvt+rrrn+q6dl3FpGmappVKBwhN0zStVPUpQEx3dAYcpL5eN9Tfa9fXXf9Uy7XXmzYITdM0rXLqUwlC0zRNqwQdIDRN07RS1fkAISLXiEiUiBwUkSdK2e4vIj+IyC4R+UtEOlT02NrufK9dRBqLyO8isk9E9ojI5JrP/fm7kPfcvt0kIttF5Keay/WFu8DPup+ILBSR/fb3vU/N5v7CXOC1T7F/zneLyHciUn0z7FQxEflSRE6LyO4ytouIvG9/XXaJSLci2y78+00pVWcfgAmIBpoBLsBOoF2Jfd4AnrM/bwOsquixtflxgdceBnSzP/cG/q0r134h111k+yPAt8BPjr6emrpuYBbwH/tzF8DP0ddUE9cOhAOHAXf78nxggqOvqRLXfhnQDdhdxvahwHJAgN7A5oq+ZhV51PUSRE/goFLqkFIqD5gLXF9in3bAKgCl1H4gUkRCK3hsbXbe166UilNKbbOvTwf2Yfwj1QUX8p4jIo2Aa4HPay7LVeK8r1tEfDC+aL6wb8tTSqXUWM4v3AW95xjTGriLiDPgAcTWTLYvnFLqDyCpnF2uB2YrwybAT0TCqKLvt7oeIMKB40WWT3D2F91O4AYAEekJRACNKnhsbXYh115IRCKBrsDm6spoFbvQ634XeAywVWsuq96FXHczIB74yl619rmIeFZ/lqvMeV+7UioGeBM4BsQBqUqpX6s9xzWnrNemSr7f6nqAkFLWley3+yrgLyI7gAeB7UB+BY+tzS7k2o0ERLyARcDDSqm0aspnVTvv6xaRYcBppdTW6s1itbiQ99sZo5riE6VUVyATqEttbhfynvtj/HJuCjQEPEVkbDXmtaaV9dpUyfdbXZ9R7gTQuMhyI0oUH+1ffBPBaNDBqI88jFHULPfYWu5Crh0RMWMEh2+UUt/XRIaryIVc9y3AdSIyFHADfETka6VUXfjCuNDP+gmlVEEpcSF1K0BcyLUPBg4rpeLt274H+gJfV3+2a0RZr41LGesrx9GNMBfYgOMMHML4dVDQENO+xD5+gIv9+V0Y9XUVOrY2Py7w2gWYDbzr6Ouoyesusc9A6lYj9QVdN7AOaG1//jzwhqOvqSauHegF7MEIkoLRWP+go6+pktcfSdmN1NdSvJH6r4q+ZhU6t6MvvgpevKEYvXCigWn2dZOASfbnfYADwH7ge8C/vGPr0uN8rx3oh1Hc3AXssD+GOvp6auI9L5JGnQoQF3rdQBdgi/09X1zaa1KbHxd47S/Y1+8G5gCujr6eSlz3dxhtJxaM0sKdJa5bgI/sr8s/QI/yXrPKPvRQG5qmaVqp6nojtaZpmlZNdIDQNE3TSqUDhKZpmlYqHSA0TdO0UukAoWmappVKBwhNq2VEZLmIjLc/nyAi6x2dJ61+qut3UmtanSYizwMtVJG7uZVSQxyXI007Q5cgNE3TtFLpAKFpdiLSVUS2iUi6iMwTkbki8r/SqnlERIlIC/vza+2jpKaJyHF7qaBgv0j7vuNF5JiIJIjINPu2a4CngJtFJENEdtrXrxGR/5SRxzYislJEkuyTwYyuppdD03SA0DQAEXHBGIJiDhAALABurODhmcDtGOMBXQvcKyIjSuzTD2gNXAk8KyJtlVIrgJeBeUopL6VU53Pk0RNYiTHZUQhwK/CxiLSvYD41rVJ0gNA0Q2/AjDGAoUUptRD4uyIHKqXWKKX+UUrZlFK7MMbPGVBitxeUUtlKqZ0YA6eVGwzKMAw4opT6SimVr4xJnxYBo84jLU07J91IrWmGhkCMKj442dGKHCgivTDmI+iAMXKmK0YJpKiTRZ5nAV7nkccIoJeIpBRZ54xR6tG0KqdLEJpmiAPC7XMJFGhi/5uJMVw0ACLSoMSx3wJLgcZKKV/gU0qfsKU0lRkt8ziwVinlV+ThpZS6txJpaFqF6QChaYaNGLOvPSQiziJyA8a8vmAfS19EuoiIG8Z8CkV5A0lKqRz7dJdjKnHeUxjzJ1fkf/EnoJWIjBMRs/1xiYi0rcT5NK3CdIDQNEAZE7vfAEwAkoGbMeYVQCn1L/Ai8BvGnAMlb1y7D3hRRNKBZ4H5lTh1QVVUoohsO0ce04FBGDPjxWJUW72GUaWlaVVOzwehaWUQkZkYU3U+7ei8aJoj6BKEpmmaViodIDRN07RS6SomTdM0rVS6BKFpmqaVSgcITdM0rVQ6QGiapmml0gFC0zRNK5UOEJqmaVqp/h/1Ve2jISH9GAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "quantiles = np.arange(0.,0.1, 0.0025)\n",
    "\n",
    "maximal_scores = np.array([np.max([ np.quantile(test_data @ decision, q) for decision in maximal_decisions ]) for q in quantiles])\n",
    "kl_scores = np.array([np.max([ np.quantile(test_data @ decision, q) for decision in kl_decisions ]) for q in quantiles])\n",
    "vd_scores = np.array([np.max([ np.quantile(test_data @ decision, q) for decision in phi_decisions ]) for q in quantiles])\n",
    "robust_scores = np.array([np.max([ np.quantile(test_data @ decision, q) for decision in robust_decisions ]) for q in quantiles])\n",
    "\n",
    "plt.plot(1-quantiles, kl_scores, label = 'KL divergence', linestyle='--')\n",
    "plt.plot(1-quantiles, vd_scores, label = 'VD divergence', linestyle='-.')\n",
    "plt.plot(1-quantiles, robust_scores, label = 'Budget', linestyle=':')\n",
    "plt.plot(1-quantiles, maximal_scores, label = 'Minimum Violation' )\n",
    "plt.xlabel('quantile', fontsize=\"12\")\n",
    "plt.ylabel('revenue', fontsize=\"12\")\n",
    "plt.title('Revenue at varying quantiles', fontsize=\"16\")\n",
    "plt.legend(fontsize=\"12\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "violation_d mean: 245.8596748343472\n",
      "divergence  mean: 247.6070645175763\n",
      "kl          mean: 246.00277570498574\n",
      "robust      mean: 247.60706450681528\n"
     ]
    }
   ],
   "source": [
    "print('violation_d mean:', np.max([ np.mean(test_data @ decision) for decision in maximal_decisions ]))\n",
    "print('divergence  mean:', np.max([ np.mean(test_data @ decision) for decision in phi_decisions ]))\n",
    "print('kl          mean:', np.max([ np.mean(test_data @ decision) for decision in kl_decisions]))\n",
    "print('robust      mean:', np.max([ np.mean(test_data @ decision) for decision in robust_decisions]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.24956010119919664"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(maximal_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 384,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.23140479699970457"
      ]
     },
     "execution_count": 384,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(robust_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 386,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.943508537499656"
      ]
     },
     "execution_count": 386,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.mean(kl_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x75d5f7d1\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "[0.0, 0.0, 1.0, 0.0]\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe0062650\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xcc2b9a54\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x10185b2e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xec3bf142\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xab4c917e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xddfc19cd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x67848ce6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc166b562\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x43548210\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x13de405f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6f256803\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x51f597c1\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe9852f08\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x93793771\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x995be33a\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x130ac414\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xeeef8941\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf7a98961\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x521f5ee1\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xdde57292\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe91c46f8\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5584e07f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6dedf2ee\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2c9bd3f4\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xee85e87e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x964bd8e3\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x07683079\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x57746720\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xdc24e0d3\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6d155a47\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd73f55b5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa694db6a\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x22c34776\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6871f231\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc6eb2b92\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x739e857c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd1492d9c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf02efe0e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xbbc4d561\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0b6b8d62\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5061f284\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2f26e651\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xac5e9fdc\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa359e99b\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5db0abed\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xba6a94f0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x820122bd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x794c7836\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa787ea02\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2fcb324c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 1e+01]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x3c9c7b88\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4ddaeca6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9c10c632\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc9712b8c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4d5c5e22\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x1fd2b376\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5e93655f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x20666225\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5c4010fd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x646418d5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2ae4bbef\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0cf50d8f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4114748d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.01 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa81dc915\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0a95428b\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x61c1dc64\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xae8e3bdb\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa52b6d18\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x1b7f57fd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x28cc8629\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x8b9a0707\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5b1544db\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9899418d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x41a47771\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x1ac053b7\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9a07ffc5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x67f5aa0f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf0d91ccf\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x35adf60e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9947e35d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9db461ac\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x169e60fd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa238f942\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x77239ff8\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa2242ac3\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x62c715eb\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.01 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd8a5b445\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xad993ba0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x25dc5655\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x13e21357\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6fe22c88\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6dcd9702\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0b40f3b4\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.01 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc218c328\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x80c1578d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x42609237\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xeaa9c129\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x293f8d7b\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf1b171aa\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe2e7f6bd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe2dbf442\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7f60e5a5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x8c83835a\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x39a65909\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x12479f45\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.01 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xfa818af6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xfb52d72e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xff607542\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x67f80a5d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x55dbe399\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xb3d15d64\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x001cecfd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7cceb0bc\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x469b24d0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2185d254\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5ff17a64\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4f857e3b\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xde501fa0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc64a27ea\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7b91b3f0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x87c4c588\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4ec5d9f6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x1e9a51cb\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6f41f5f5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc81fd5e6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x40372394\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x025cf42d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9af50e57\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd5809551\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0f849500\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x31f0fcba\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe83f5718\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4845852f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x0d3125f2\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x62b9dbf6\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7d808b22\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x896adef2\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf37b5224\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xb3a5898f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x3cb05eee\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xdbd8d3dd\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x53165182\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x88c23c1d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x59508dc5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x2971155d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x5256e848\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x494e4aa5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa989df08\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7d88cccb\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.02 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc7e9453c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 9e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xaab8e59c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x012d39cb\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x11df4aa5\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xed9c8344\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x4c7c4be0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf4d65c55\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe77d381c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xae778192\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9e236df4\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x61983c1c\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x38fd8b25\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xb0f2f847\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xdee31926\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xff5c0193\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xcddb4821\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7554f281\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9d54140d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x81b79e30\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x93cbdf41\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x3c042b5d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x1d793691\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf29c2942\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x3a888480\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x07359b2a\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x17d71dac\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd2540d8e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6f0a4679\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x933bfe6f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe76831b1\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf5e6cd71\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x13fbd057\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6947eeb2\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x981ac208\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x843b58e4\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.01 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xe815249f\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x687611a7\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x3b75d988\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd02d557d\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xa4c6732e\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd7d58876\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x6939aa4a\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x08e64778\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xc5086f18\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x7948db47\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x9510ef67\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xd51dcdfc\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0x8867a9e0\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xf4e4c334\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n",
      "Set parameter MIPGap to value 0.05\n",
      "Gurobi Optimizer version 9.5.1 build v9.5.1rc2 (win64)\n",
      "Thread count: 8 physical cores, 16 logical processors, using up to 16 threads\n",
      "Optimize a model with 1001 rows, 1004 columns and 5004 nonzeros\n",
      "Model fingerprint: 0xaef61554\n",
      "Variable types: 4 continuous, 1000 integer (1000 binary)\n",
      "Coefficient statistics:\n",
      "  Matrix range     [1e+00, 4e+02]\n",
      "  Objective range  [1e+00, 1e+00]\n",
      "  Bounds range     [1e+00, 1e+00]\n",
      "  RHS range        [1e+00, 8e+00]\n",
      "Found heuristic solution: objective 1000.0000000\n",
      "\n",
      "Explored 0 nodes (0 simplex iterations) in 0.00 seconds (0.00 work units)\n",
      "Thread count was 1 (of 16 available processors)\n",
      "\n",
      "Solution count 1: 1000 \n",
      "\n",
      "Optimal solution found (tolerance 5.00e-02)\n",
      "Best objective 1.000000000000e+03, best bound 1.000000000000e+03, gap 0.0000%\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x23881ed87c0>"
      ]
     },
     "execution_count": 123,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from maximum_robust import robust_portfolio, robust_portfolio_exact, robust_portfolio_relax\n",
    "\n",
    "ts = np.arange(0,2,0.01)\n",
    "qs_train = []\n",
    "qs_test = []\n",
    "best = 0\n",
    "for t in ts:\n",
    "    solution = robust_portfolio_exact(train_data, t)\n",
    "    ans = solution.X[:n]\n",
    "    vals = np.dot(train_data, ans)\n",
    "    vals_test = np.dot(test_data, ans)\n",
    "    # print(np.dot(train_data, ans), np.dot(test_data, ans))\n",
    "    qs_train.append(np.quantile(vals, QUANTILE))\n",
    "    qs_test.append(np.quantile(vals_test, QUANTILE))\n",
    "    # print(np.quantile(np.dot(train_data, ans), QUANTILE), np.quantile(np.dot(test_data, ans), QUANTILE))\n",
    "    if qs_test[-1] > best: \n",
    "        best = qs_test[-1] \n",
    "        print(ans)\n",
    "plt.plot(ts, qs_train, label = 'train')\n",
    "plt.plot(ts, qs_test, label = 'test')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 223,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x220af0ffd90>"
      ]
     },
     "execution_count": 223,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(qs_train, label = 'train')\n",
    "plt.plot(qs_test, label = 'test')\n",
    "plt.legend()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8006283642180143"
      ]
     },
     "execution_count": 222,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.max(qs_test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "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.9.7"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
