{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch.nn.functional import relu\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import os\n",
    "\n",
    "from policy_selection_for_inventories.simulator import Simulator\n",
    "\n",
    "from policy_selection_for_inventories.algorithms.gapsi_special import GAPSI_Special\n",
    "\n",
    "from policy_selection_for_inventories.algorithms.mpc import MPC\n",
    "from policy_selection_for_inventories.algorithms.base_stock import Base_Stock\n",
    "import policy_selection_for_inventories\n",
    "\n",
    "\n",
    "from policy_selection_for_inventories.environments.ls_fifop_product import LS_FIFOP_Product\n",
    "from policy_selection_for_inventories.environments.infinite_warehouse import Infinite_Warehouse\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "lifetime = 2\n",
    "leadtime = 0\n",
    "\n",
    "MPC_horizon = 7"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Product demands"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Loading the demands and initializing the environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.read_csv(\n",
    "    os.path.join(policy_selection_for_inventories.__path__[0], \"..\", \"..\", \"data\", \"m5_processed\", \"demands_product.csv\"),\n",
    "    index_col=[\"item_id\",\"ds\"]\n",
    ")\n",
    "df = df.join(df.assign().groupby(\"item_id\")[\"y\"].mean().rename(\"mean\"), on=\"item_id\", how=\"left\")\n",
    "df[\"normalized_y\"] = df[\"y\"]/df[\"mean\"]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Categories ordered by normalized standard deviation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "item_id\n",
       "FOODS_3_377        0.213820\n",
       "FOODS_3_694        0.224344\n",
       "FOODS_3_226        0.232873\n",
       "FOODS_3_586        0.240471\n",
       "FOODS_3_668        0.243895\n",
       "                     ...   \n",
       "FOODS_3_069        2.693414\n",
       "FOODS_3_563        2.779326\n",
       "FOODS_3_466        2.822436\n",
       "HOUSEHOLD_2_448    2.911242\n",
       "FOODS_3_296        3.382072\n",
       "Name: norm_std, Length: 3049, dtype: float64"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ordered_norm_std = df.assign().groupby(\"item_id\")[\"normalized_y\"].std().rename(\"norm_std\").sort_values()\n",
    "ordered_norm_std"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Median index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median index: FOODS_3_316\n"
     ]
    }
   ],
   "source": [
    "median_index = ordered_norm_std.index.values[(len(ordered_norm_std)-1)//2]\n",
    "print(\"Median index: {}\".format(median_index))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "demands = torch.FloatTensor(df.loc[median_index, \"y\"].values)\n",
    "#demands /= demands.mean()\n",
    "T = len(demands)\n",
    "\n",
    "purchase_cost = 1.0*torch.ones(T)\n",
    "holding_cost = 1.0*torch.ones(T)\n",
    "selling_price = 0.0*torch.ones(T)\n",
    "outdating_cost = 1.0*torch.ones(T)\n",
    "penalty_cost = 10.0*torch.ones(T)\n",
    "\n",
    "product = LS_FIFOP_Product(lifetime, leadtime, demands, purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost, 10*T*demands.numpy().max())\n",
    "environment = Infinite_Warehouse([product])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Computing forecasts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "NB_SAMPLE = 10"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "true_leadtime_demand_forecasts = torch.cat([torch.zeros(7),demands,torch.zeros(leadtime)]).unfold(0,leadtime+1,1).sum(dim=1)[:T]\n",
    "\n",
    "SEED = 1\n",
    "torch.manual_seed(SEED)\n",
    "noise_theoretical_std = demands.std()/2\n",
    "noise = noise_theoretical_std*torch.randn(NB_SAMPLE,T)\n",
    "\n",
    "leadtime_demand_forecasts = []\n",
    "fake_environments = []\n",
    "\n",
    "for sample_idx in range(NB_SAMPLE) :\n",
    "    noisy_demands = relu(demands+noise[sample_idx])\n",
    "    leadtime_demand_forecasts.append(\n",
    "        torch.cat([torch.zeros(7),noisy_demands,torch.zeros(leadtime)]).unfold(0,leadtime+1,1).sum(dim=1)[:T]   \n",
    "    )\n",
    "\n",
    "    fake_product = LS_FIFOP_Product(\n",
    "        lifetime, leadtime, torch.cat([torch.zeros(MPC_horizon), relu(demands+noise[sample_idx])]), purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost, 10*T*demands.numpy().max()\n",
    "    )\n",
    "    fake_environments.append(Infinite_Warehouse([fake_product]))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Computing the best base-stock level $S_T^*$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [01:11<00:00,  1.40it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAh8AAAGdCAYAAACyzRGfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/SrBM8AAAACXBIWXMAAA9hAAAPYQGoP6dpAABKu0lEQVR4nO3de3yU5Z03/s+cM0lmJgfIAZJAOAgioAiCQGupImpdV6u7blsP2NVa3aBFn6e70sPW/vqz4dnaWt269ETVbqVYavHAU6VUBGXLMYKAyEE5BZIQQpKZZCZzvK/nj5n7nplkMpl7ZpIJuT/v1yuvwsxkcufGkg/f63t9L50QQoCIiIhoiOhzfQFERESkLQwfRERENKQYPoiIiGhIMXwQERHRkGL4ICIioiHF8EFERERDiuGDiIiIhhTDBxEREQ0pY64voDdJktDU1ASbzQadTpfryyEiIqIUCCHQ1dWFMWPGQK9PXtsYduGjqakJ1dXVub4MIiIiSkNjYyOqqqqSvmbYhQ+bzQYgfPF2uz3HV0NERESpcLlcqK6uVn6OJzPswoe81GK32xk+iIiILjKptEyw4ZSIiIiGFMMHERERDSmGDyIiIhpSDB9EREQ0pBg+iIiIaEipCh+rVq3CzJkzlZ0o8+fPx1tvvdXndUII3HTTTdDpdHjttdeyda1EREQ0AqgKH1VVVVi5ciUaGhqwZ88eXHvttbj11lvx0Ucfxb3upz/9KaeTEhERUUKq5nzccsstcb9/6qmnsGrVKuzYsQOXXXYZAGDfvn348Y9/jD179qCysjJ7V0pEREQjQtpDxkKhENatWwe324358+cDADweD77yla/g+eefR0VFRUrv4/P54PP5lN+7XK50L4mIiIguAqobTg8cOIDCwkJYLBY89NBDWL9+PaZNmwYAeOyxx7BgwQLceuutKb9ffX09HA6H8sFzXYiIiEY21ZWPKVOmYN++fXA6nfjjH/+IpUuXYuvWrfjkk0+wefNm7N27V9X7rVixAo8//rjye3k2PBEREY1MOiGEyOQNFi9ejIkTJ8JqteK5556LO0Y3FApBr9fjs5/9LLZs2ZLS+7lcLjgcDjidTp7tQkREdJFQ8/M744PlJEmCz+fD97//fTzwwANxz82YMQPPPPNMn0bVXGjt8mLVlk9hMRrwxE1Tc305REREmqUqfKxYsQI33XQTampq0NXVhTVr1mDLli3YuHEjKioqEjaZ1tTUoLa2NmsXnK4ubxAv/M9J2POMDB9EREQ5pCp8tLa24t5770VzczMcDgdmzpyJjRs34vrrrx+s68saoz48dyQoZbTKRERERBlSFT5Wr16t6s0zbCfJKgPDBxER0bCgmbNdTIbwtxpi+CAiIsopzYQPufIRksSwqsgQERFpjWbCh9zzAXDphYiIKJe0Ez4MMfNHGD6IiIhyRjvhI6byEQhJObwSIiIibdNM+DDEhA9WPoiIiHJHM+GDPR9ERETDg2bCh06ni9vxQkRERLmhmfABRJde2PNBRESUO5oKHyZWPoiIiHJOU+GDI9aJiIhyT1PhQ571EQwxfBAREeWKtsKHUvlgzwcREVGuaDJ8sOeDiIgodzQVPgwGebcLwwcREVGuaCp8mPThb5eVDyIiotzRVPgwsOeDiIgo57QZPrjsQkRElDOaCh9GAxtOiYiIck1b4SPS88EhY0RERLmjsfAhVz7Y80FERJQrmgof0YPlWPkgIiLKFU2FD5OBW22JiIhyTVPhgwfLERER5Z6mwodytkuIPR9ERES5oq3wYWDlg4iIKNe0FT44Xp2IiCjnNBU+ortduOxCRESUK5oKH5xwSkRElHvaCh/c7UJERJRzmgofBnm8OoeMERER5YymwofJwPHqREREuaap8MEhY0RERLmnqfDBng8iIqLc01T4YM8HERFR7mkqfLDng4iIKPc0FT7Y80FERJR7mgof0YPlGD6IiIhyRVvhwxDp+WDlg4iIKGe0FT707PkgIiLKNU2FD+VgOVY+iIiIckZT4UNedgmx54OIiChntBU+uNuFiIgo51SFj1WrVmHmzJmw2+2w2+2YP38+3nrrLQBAe3s7HnnkEUyZMgVWqxU1NTV49NFH4XQ6B+XC0xHdasueDyIiolwxqnlxVVUVVq5cicmTJ0MIgZdeegm33nor9u7dCyEEmpqa8PTTT2PatGk4deoUHnroITQ1NeGPf/zjYF2/KtEhY6x8EBER5YpOCJHRT+KSkhL86Ec/wv3339/nuXXr1uHuu++G2+2G0ZhaznG5XHA4HHA6nbDb7ZlcWh9vfNiER3+/F/MnlOL3D16d1fcmIiLSMjU/v1VVPmKFQiGsW7cObrcb8+fPT/ga+QKSBQ+fzwefz6f83uVypXtJAzJy2YWIiCjnVDecHjhwAIWFhbBYLHjooYewfv16TJs2rc/r2tra8IMf/AAPPvhg0verr6+Hw+FQPqqrq9VeUsrYcEpERJR7qsPHlClTsG/fPuzcuRMPP/wwli5dikOHDsW9xuVy4eabb8a0adPw5JNPJn2/FStWwOl0Kh+NjY1qLyllRvZ8EBER5ZzqZRez2YxJkyYBAGbPno3du3fj2WefxS9+8QsAQFdXF2688UbYbDasX78eJpMp6ftZLBZYLJY0Ll09gz6ctQKc80FERJQzGc/5kCRJ6dlwuVxYsmQJzGYz3njjDeTl5WV8gdnE8epERES5p6rysWLFCtx0002oqalBV1cX1qxZgy1btmDjxo1K8PB4PPjd734Hl8ulNI+OHj0aBoNhUL4BNdjzQURElHuqwkdrayvuvfdeNDc3w+FwYObMmdi4cSOuv/56bNmyBTt37gQAZVlGduLECYwfPz5rF50u9nwQERHlnqrwsXr16n6fW7RoETIcGTLo5J6PIHs+iIiIckajZ7uw54OIiChXtBU+uOxCRESUc9oKH5HKB7faEhER5Y7Gwkf422Xlg4iIKHc0FT4M7PkgIiLKOU2FD7nng7tdiIiIckdb4UPeaiuJYb8tmIiIaKTSWPjQKb9m2wcREVFuaCp8GAzR8BEIse+DiIgoFzQVPkz66LfLHS9ERES5oanwYYhZduHhckRERLmhqfAR2/MR5LILERFRTmgqfOj1Osj5g8suREREuaGp8AHEb7clIiKioae58CH3fbDyQURElBuaCx/Rw+XY80FERJQL2gsfBlY+iIiIcklz4cPAng8iIqKc0lz4kJddeLgcERFRbmgvfMgn20rs+SAiIsoF7YUP7nYhIiLKKc2FD4Oy24Xhg4iIKBc0Fz5MhvC3zMoHERFRbmgufMiVD/Z8EBER5Ybmwgd3uxAREeWW9sKHgXM+iIiIcklz4YNnuxAREeWW5sKHUWXPR4fbj59sOorGds9gXhYREZFmaC98yMsuKfZ8/OZ/TuC5d47h1+8fH8zLIiIi0gzthQ+Vyy4NpzoAAG3d/kG7JiIiIi3RXPiIbrUdOHyEJIH9Z5wAAJc3MKjXRUREpBWaCx9qej4+Pd+Nbl8QANDlDQ7qdREREWmF9sKHip6Pfac7lV93sfJBRESUFdoLHyp6PvY2diq/ZuWDiIgoOzQXPpSD5VJYdtnH8EFERJR1mgsfJkOk8jHAsovHH8SRFpfy+55ACIEQz4MhIiLKlObCR6q7XQ6ccUISwKhCi/JYN6sfREREGdNc+DDq5bNdklcx5CWX2eOKYDUZAHC7LRERUTZoMHykVvmQw8cV1cWwW40A2PdBRESUDZoLH4YUez7k8DGrpgi2PBMAVj6IiIiyQXPhI5XKxzmXF81OL/Q6YMZYB2x5rHwQERFliwbDx8A9H3sjw8UuKbehwGJUKh8MH0RERJlTFT5WrVqFmTNnwm63w263Y/78+XjrrbeU571eL+rq6lBaWorCwkLccccdOHfuXNYvOhOpDBmLXXIBEFP54LILERFRplSFj6qqKqxcuRINDQ3Ys2cPrr32Wtx666346KOPAACPPfYY3nzzTaxbtw5bt25FU1MTbr/99kG58HTJPR+BJD0f+xrDJ9leUV0EALBz2YWIiChrjGpefMstt8T9/qmnnsKqVauwY8cOVFVVYfXq1VizZg2uvfZaAMALL7yASy+9FDt27MDVV1+dvavOgCmy7NJf5SMkCRyInGR7RXUxAMQsu7DyQURElKm0ez5CoRDWrl0Lt9uN+fPno6GhAYFAAIsXL1ZeM3XqVNTU1GD79u39vo/P54PL5Yr7GEwDDRk71toFtz+EArMBk8oKAQA2CysfRERE2aI6fBw4cACFhYWwWCx46KGHsH79ekybNg0tLS0wm80oKiqKe315eTlaWlr6fb/6+no4HA7lo7q6WvU3oYZR3mrbT8OpfJLtzKoiJajIPR/caktERJQ51eFjypQp2LdvH3bu3ImHH34YS5cuxaFDh9K+gBUrVsDpdCofjY2Nab9XKpSD5frp+VCGi0WaTQHAbuVuFyIiomxR1fMBAGazGZMmTQIAzJ49G7t378azzz6Lf/qnf4Lf70dnZ2dc9ePcuXOoqKjo9/0sFgssFku/z2fbQD0f0cmmRcpj0SFjDB9ERESZynjOhyRJ8Pl8mD17NkwmE9555x3luSNHjuD06dOYP39+pl8ma5L1fPiDEo6e6wIAXF5VpDzOrbZERETZo6rysWLFCtx0002oqalBV1cX1qxZgy1btmDjxo1wOBy4//778fjjj6OkpAR2ux2PPPII5s+fP2x2ugDRno9gqG/PR48/BDmTlBaalcc54ZSIiCh7VIWP1tZW3HvvvWhubobD4cDMmTOxceNGXH/99QCAZ555Bnq9HnfccQd8Ph9uuOEG/Nd//degXHi6ohNO+1Y+fKEQAECniw4jAwA7t9oSERFljarwsXr16qTP5+Xl4fnnn8fzzz+f0UUNJkOSCaf+YLgaYjboodNFw4dc+fAGJARCEkwGzU2lJyIiyhrN/RRVDpZLsOzik8OHMf62FFqiGY1LL0RERJnRXvgwJG84BQCL0dDrc/TIN4cf49ILERFRZrQXPpJstY2Gj763RRk01sPKBxERUSY0Fz6iQ8b6Lrv4Q4mXXQCe70JERJQtmgsfJkNqDae92ZUR66x8EBERZUJz4WOgIWMAKx9ERESDSXPhQ5nzkeBsl/52uwAcNEZERJQt2gsfyXa7hPpfdolWPhg+iIiIMqG98KEMGUvQcJqk8mHn+S5ERERZobnwkX7PB5ddiIiIskFz4UMejZ6o58MfDJ/tkrTh1MfKBxERUSY0Fz6Sne3iS2HIGCsfREREmdFc+FDOdknS85E4fIQrH64eVj6IiIgyobnwIVc+JAFIvaofyXe7sPJBRESUDZoLH8aYYNG76TT5bpdI5YPhg4iIKCPaCx+RygfQt+8jtSFjXHYhIiLKhObChyEmfAR69X1El10MfT5Prnz4gpJSISEiIiL1NBc+TDHLLqFQ6ssuhZHKB8DqBxERUSY0Fz5iCh+qej4Meh0KzOGKCJtOiYiI0qe58KHT6frdbpssfAA834WIiCgbNBc+gJjD5Xovu0R6PiwJttoCbDolIiLKBm2GD3342+672yU8Xt1iSh4+XAwfREREadNk+DAMtOzSb+WDsz6IiIgypcnwYTIkPtl2oJ4Pu5U9H0RERJnSZPhQKh+h1IeMAez5ICIiygZNho/+ej6Sne0C8HwXIiKibNBm+DCkt9XWrmy1ZeWDiIgoXZoMH/0tuww854OVDyIiokxpMnzIQ8b6W3axMHwQERENGk2GD0Ok5yPQ326XBAfLAYDNwmUXIiKiTGkyfMhbbUOqx6vLQ8ZY+SAiIkqXJsNHop6PkCSUuR/9L7uw8kFERJQpTYaP6MFy0fAhVz0AVj6IiIgGk0bDR/jbVhs+5Amn/qCknANDRERE6mgzfCTo+fCFwmFCp4tWRnortBiVX3PHCxERUXo0GT7kno9AqG/lw2zQQ6dLHD4Mep0SQBg+iIiI0qPJ8JFovPpAO11kPN+FiIgoMxoNHwkaTgcYMCbjoDEiIqLMaDJ8GOSzXULRno/YZZdkuN2WiIgoM5oMH6YE49XVLru4elj5ICIiSocmw4chyVbbgcNHuPLhYuWDiIgoLZoMH4kOlvOF1DacsvJBRESUDm2GD4O81TZmzkdAbjhNfKicjOGDiIgoM6rCR319Pa666irYbDaUlZXhtttuw5EjR+Je09LSgnvuuQcVFRUoKCjAlVdeiVdffTWrF52pRJUPebfLQA2ndjacEhERZURV+Ni6dSvq6uqwY8cObNq0CYFAAEuWLIHb7VZec++99+LIkSN44403cODAAdx+++248847sXfv3qxffLoy6fmws/JBRESUEePAL4l6++23437/4osvoqysDA0NDbjmmmsAAH/729+watUqzJ07FwDwne98B8888wwaGhowa9asLF12ZkzJttqm2HDa5WPlg4iIKB0Z9Xw4nU4AQElJifLYggUL8Morr6C9vR2SJGHt2rXwer1YtGhRwvfw+XxwuVxxH4PNkPBU2/DZLmw4JSIiGlxphw9JkrB8+XIsXLgQ06dPVx7/wx/+gEAggNLSUlgsFnz961/H+vXrMWnSpITvU19fD4fDoXxUV1ene0kpS9bzYUl5yBjDBxERUTrSDh91dXU4ePAg1q5dG/f4d7/7XXR2duKvf/0r9uzZg8cffxx33nknDhw4kPB9VqxYAafTqXw0Njame0kpk3s+Eh4sl/KQMS67EBERpUNVz4ds2bJl2LBhA9577z1UVVUpj3/66af42c9+hoMHD+Kyyy4DAFx++eV4//338fzzz+PnP/95n/eyWCywWCxpXn565K22ISmdng8uuxAREWVCVeVDCIFly5Zh/fr12Lx5M2pra+Oe93g84TfVx7+twWCAFPODPtcSHSznS3Grrbzs4g9J8AZCg3SFREREI5eqykddXR3WrFmD119/HTabDS0tLQAAh8MBq9WKqVOnYtKkSfj617+Op59+GqWlpXjttdewadMmbNiwYVC+gXQoDadpLLsUWqK3rMsbRJ4p+VAyIiIiiqeq8rFq1So4nU4sWrQIlZWVyscrr7wCADCZTPjzn/+M0aNH45ZbbsHMmTPx29/+Fi+99BK+8IUvDMo3kA5TpLoRN149mNqEU4NepwQQDhojIiJST1XlQwgx4GsmT5487Caa9hbdaqu+5wMA8s0GdPuC6OGyCxERkWraPNsl0VZbFeFD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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final cost 21.312725067138672\n"
     ]
    }
   ],
   "source": [
    "levels_1 = policy_selection_for_inventories.utils.find_best_S_policy(\n",
    "    environment=environment,\n",
    "    T=T,\n",
    "    seasonality=[1],\n",
    "    initial_levels=[demands[:T].unfold(0,leadtime+1,1).sum(dim=1).mean().reshape(1)],\n",
    "    nb_iterations=100,\n",
    "    learning_rate=10.0,\n",
    "    show_progress_bar=True\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Running the algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "algorithms = [Base_Stock(environment, [levels_1[0]*torch.ones(T)])]\n",
    "algorithms += [Base_Stock(environment, [leadtime_demand_forecasts[sample_idx]]) for sample_idx in range(NB_SAMPLE)]\n",
    "algorithms += [MPC(fake_environments[sample_idx], MPC_horizon) for sample_idx in range(NB_SAMPLE)]\n",
    "algorithms += [GAPSI_Special(environment, [1], 0.1, 50, torch.zeros(1), torch.zeros(1), torch.ones(1),\n",
    "    [(leadtime+1)*demands.max()*torch.ones(T,1)])\n",
    "]\n",
    "algorithms += [GAPSI_Special(environment, [2], 0.1, 50, torch.zeros(2), torch.zeros(2), torch.ones(2),\n",
    "    [torch.stack([2*leadtime_demand_forecasts[sample_idx], (leadtime+1)*demands.max()*torch.ones(T)], dim=1)])\n",
    "    for sample_idx in range(NB_SAMPLE)\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "11it [00:02,  4.39it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003162 /   0.0006324 (  perturbed bounds)\n",
      "2 /   0.0003162 /   0.0006324 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000712 /    0.000712 (  perturbed bounds)\n",
      "1 /    0.000712 /    0.000712 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008215 /   0.0008215 (  perturbed bounds)\n",
      "1 /   0.0008215 /   0.0008215 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009141 /   0.0009141 (  perturbed bounds)\n",
      "1 /   0.0009141 /   0.0009141 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006068 /    0.001214 (  perturbed bounds)\n",
      "2 /   0.0006068 /    0.001214 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003572 /   0.0003572 (  perturbed bounds)\n",
      "1 /   0.0003572 /   0.0003572 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007667 /   0.0007667 (  perturbed bounds)\n",
      "1 /   0.0007667 /   0.0007667 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006412 /   0.0006412 (  perturbed bounds)\n",
      "1 /   0.0006412 /   0.0006412 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005419 /   0.0005419 (  perturbed bounds)\n",
      "1 /   0.0005419 /   0.0005419 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004073 /   0.0008145 (  perturbed bounds)\n",
      "2 /   0.0004073 /   0.0008145 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002012 /   0.0002012 (  perturbed bounds)\n",
      "1 /   0.0002012 /   0.0002012 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002928 /   0.0002928 (  perturbed bounds)\n",
      "1 /   0.0002928 /   0.0002928 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003728 /   0.0003728 (  perturbed bounds)\n",
      "1 /   0.0003728 /   0.0003728 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "12it [00:36, 10.51s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009832 /    0.001106 (  perturbed bounds)\n",
      "2 /   0.0009832 /    0.001106 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008366 /   0.0008366 (  perturbed bounds)\n",
      "1 /   0.0008366 /   0.0008366 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007019 /   0.0007897 (  perturbed bounds)\n",
      "2 /   0.0007019 /   0.0007897 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006534 /   0.0006534 (  perturbed bounds)\n",
      "1 /   0.0006534 /   0.0006534 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005459 /   0.0005459 (  perturbed bounds)\n",
      "1 /   0.0005459 /   0.0005459 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003342 /   0.0003342 (  perturbed bounds)\n",
      "1 /   0.0003342 /   0.0003342 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000147 /    0.000147 (  perturbed bounds)\n",
      "1 /    0.000147 /    0.000147 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "3 /   0.0009529 /    0.002144 (  perturbed bounds)\n",
      "3 /   0.0009529 /    0.002144 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003854 /   0.0004817 (  perturbed bounds)\n",
      "2 /   0.0003854 /   0.0004817 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000571 /    0.001142 (  perturbed bounds)\n",
      "2 /    0.000571 /    0.001142 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000662 /    0.000662 (  perturbed bounds)\n",
      "1 /    0.000662 /    0.000662 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002142 /   0.0002142 (  perturbed bounds)\n",
      "1 /   0.0002142 /   0.0002142 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005635 /   0.0005635 (  perturbed bounds)\n",
      "1 /   0.0005635 /   0.0005635 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007232 /   0.0007232 (  perturbed bounds)\n",
      "1 /   0.0007232 /   0.0007232 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007897 /    0.001579 (  perturbed bounds)\n",
      "2 /   0.0007897 /    0.001579 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008587 /   0.0008587 (  perturbed bounds)\n",
      "1 /   0.0008587 /   0.0008587 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007695 /    0.001539 (  perturbed bounds)\n",
      "2 /   0.0007695 /    0.001539 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008233 /   0.0008233 (  perturbed bounds)\n",
      "1 /   0.0008233 /   0.0008233 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "13it [01:12, 18.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003465 /   0.0003465 (  perturbed bounds)\n",
      "1 /   0.0003465 /   0.0003465 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008575 /   0.0008575 (  perturbed bounds)\n",
      "1 /   0.0008575 /   0.0008575 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002804 /   0.0002804 (  perturbed bounds)\n",
      "1 /   0.0002804 /   0.0002804 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004983 /   0.0004983 (  perturbed bounds)\n",
      "1 /   0.0004983 /   0.0004983 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002428 /   0.0002428 (  perturbed bounds)\n",
      "1 /   0.0002428 /   0.0002428 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003754 /   0.0003754 (  perturbed bounds)\n",
      "1 /   0.0003754 /   0.0003754 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003898 /   0.0003898 (  perturbed bounds)\n",
      "1 /   0.0003898 /   0.0003898 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009479 /    0.001185 (  perturbed bounds)\n",
      "2 /   0.0009479 /    0.001185 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "3 /   0.0009871 /    0.001357 (  perturbed bounds)\n",
      "3 /   0.0009871 /    0.001357 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002387 /   0.0002387 (  perturbed bounds)\n",
      "1 /   0.0002387 /   0.0002387 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002156 /   0.0002156 (  perturbed bounds)\n",
      "1 /   0.0002156 /   0.0002156 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002385 /   0.0002385 (  perturbed bounds)\n",
      "1 /   0.0002385 /   0.0002385 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001435 /   0.0001435 (  perturbed bounds)\n",
      "1 /   0.0001435 /   0.0001435 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001583 /   0.0001583 (  perturbed bounds)\n",
      "1 /   0.0001583 /   0.0001583 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002952 /   0.0002952 (  perturbed bounds)\n",
      "1 /   0.0002952 /   0.0002952 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0005119 /   0.0006399 (  perturbed bounds)\n",
      "2 /   0.0005119 /   0.0006399 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "14it [01:47, 23.37s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004325 /   0.0004865 (  perturbed bounds)\n",
      "2 /   0.0004325 /   0.0004865 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000922 /    0.001844 (  perturbed bounds)\n",
      "2 /    0.000922 /    0.001844 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002557 /   0.0002557 (  perturbed bounds)\n",
      "1 /   0.0002557 /   0.0002557 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003312 /   0.0003312 (  perturbed bounds)\n",
      "1 /   0.0003312 /   0.0003312 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006795 /   0.0006795 (  perturbed bounds)\n",
      "1 /   0.0006795 /   0.0006795 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000659 /    0.001318 (  perturbed bounds)\n",
      "2 /    0.000659 /    0.001318 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0005299 /   0.0005961 (  perturbed bounds)\n",
      "2 /   0.0005299 /   0.0005961 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002817 /   0.0002817 (  perturbed bounds)\n",
      "1 /   0.0002817 /   0.0002817 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006442 /   0.0006442 (  perturbed bounds)\n",
      "1 /   0.0006442 /   0.0006442 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004383 /   0.0008767 (  perturbed bounds)\n",
      "2 /   0.0004383 /   0.0008767 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007782 /   0.0007782 (  perturbed bounds)\n",
      "1 /   0.0007782 /   0.0007782 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007532 /   0.0007532 (  perturbed bounds)\n",
      "1 /   0.0007532 /   0.0007532 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003009 /   0.0003009 (  perturbed bounds)\n",
      "1 /   0.0003009 /   0.0003009 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001691 /   0.0001691 (  perturbed bounds)\n",
      "1 /   0.0001691 /   0.0001691 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009521 /    0.001071 (  perturbed bounds)\n",
      "2 /   0.0009521 /    0.001071 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007827 /   0.0008805 (  perturbed bounds)\n",
      "2 /   0.0007827 /   0.0008805 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005405 /   0.0005405 (  perturbed bounds)\n",
      "1 /   0.0005405 /   0.0005405 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "3 /   0.0005812 /   0.0007265 (  perturbed bounds)\n",
      "3 /   0.0005812 /   0.0007265 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002349 /   0.0002349 (  perturbed bounds)\n",
      "1 /   0.0002349 /   0.0002349 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003272 /    0.000409 (  perturbed bounds)\n",
      "2 /   0.0003272 /    0.000409 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007798 /   0.0007798 (  perturbed bounds)\n",
      "1 /   0.0007798 /   0.0007798 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003353 /   0.0006706 (  perturbed bounds)\n",
      "2 /   0.0003353 /   0.0006706 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003735 /   0.0003735 (  perturbed bounds)\n",
      "1 /   0.0003735 /   0.0003735 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "15it [02:21, 26.70s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005152 /   0.0005152 (  perturbed bounds)\n",
      "1 /   0.0005152 /   0.0005152 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009185 /    0.001033 (  perturbed bounds)\n",
      "2 /   0.0009185 /    0.001033 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002381 /   0.0002381 (  perturbed bounds)\n",
      "1 /   0.0002381 /   0.0002381 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000936 /     0.00117 (  perturbed bounds)\n",
      "2 /    0.000936 /     0.00117 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000322 /   0.0006439 (  perturbed bounds)\n",
      "2 /    0.000322 /   0.0006439 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002871 /   0.0002871 (  perturbed bounds)\n",
      "1 /   0.0002871 /   0.0002871 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000889 /    0.001778 (  perturbed bounds)\n",
      "2 /    0.000889 /    0.001778 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000449 /    0.000449 (  perturbed bounds)\n",
      "1 /    0.000449 /    0.000449 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002808 /   0.0002808 (  perturbed bounds)\n",
      "1 /   0.0002808 /   0.0002808 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009354 /   0.0009354 (  perturbed bounds)\n",
      "1 /   0.0009354 /   0.0009354 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004531 /   0.0009061 (  perturbed bounds)\n",
      "2 /   0.0004531 /   0.0009061 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009335 /    0.001867 (  perturbed bounds)\n",
      "2 /   0.0009335 /    0.001867 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005395 /   0.0005395 (  perturbed bounds)\n",
      "1 /   0.0005395 /   0.0005395 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006113 /   0.0006113 (  perturbed bounds)\n",
      "1 /   0.0006113 /   0.0006113 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000183 /    0.000183 (  perturbed bounds)\n",
      "1 /    0.000183 /    0.000183 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001528 /   0.0001528 (  perturbed bounds)\n",
      "1 /   0.0001528 /   0.0001528 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004798 /   0.0005997 (  perturbed bounds)\n",
      "2 /   0.0004798 /   0.0005997 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003829 /   0.0003829 (  perturbed bounds)\n",
      "1 /   0.0003829 /   0.0003829 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005699 /   0.0005699 (  perturbed bounds)\n",
      "1 /   0.0005699 /   0.0005699 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005359 /   0.0005359 (  perturbed bounds)\n",
      "1 /   0.0005359 /   0.0005359 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006175 /    0.001235 (  perturbed bounds)\n",
      "2 /   0.0006175 /    0.001235 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007929 /   0.0007929 (  perturbed bounds)\n",
      "1 /   0.0007929 /   0.0007929 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "16it [02:57, 29.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004809 /   0.0004809 (  perturbed bounds)\n",
      "1 /   0.0004809 /   0.0004809 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000979 /    0.000979 (  perturbed bounds)\n",
      "1 /    0.000979 /    0.000979 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0008485 /    0.001697 (  perturbed bounds)\n",
      "2 /   0.0008485 /    0.001697 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006393 /   0.0006393 (  perturbed bounds)\n",
      "1 /   0.0006393 /   0.0006393 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006291 /    0.001258 (  perturbed bounds)\n",
      "2 /   0.0006291 /    0.001258 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004596 /   0.0004596 (  perturbed bounds)\n",
      "1 /   0.0004596 /   0.0004596 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005384 /   0.0005384 (  perturbed bounds)\n",
      "1 /   0.0005384 /   0.0005384 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008108 /   0.0008108 (  perturbed bounds)\n",
      "1 /   0.0008108 /   0.0008108 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001914 /   0.0001914 (  perturbed bounds)\n",
      "1 /   0.0001914 /   0.0001914 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006158 /   0.0006158 (  perturbed bounds)\n",
      "1 /   0.0006158 /   0.0006158 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002132 /   0.0002132 (  perturbed bounds)\n",
      "1 /   0.0002132 /   0.0002132 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007754 /   0.0007754 (  perturbed bounds)\n",
      "1 /   0.0007754 /   0.0007754 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003186 /   0.0003186 (  perturbed bounds)\n",
      "1 /   0.0003186 /   0.0003186 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009164 /    0.001146 (  perturbed bounds)\n",
      "2 /   0.0009164 /    0.001146 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002912 /   0.0002912 (  perturbed bounds)\n",
      "1 /   0.0002912 /   0.0002912 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002002 /   0.0002002 (  perturbed bounds)\n",
      "1 /   0.0002002 /   0.0002002 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002202 /   0.0002202 (  perturbed bounds)\n",
      "1 /   0.0002202 /   0.0002202 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001741 /   0.0001741 (  perturbed bounds)\n",
      "1 /   0.0001741 /   0.0001741 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007444 /   0.0007444 (  perturbed bounds)\n",
      "1 /   0.0007444 /   0.0007444 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006839 /   0.0006839 (  perturbed bounds)\n",
      "1 /   0.0006839 /   0.0006839 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003126 /   0.0003126 (  perturbed bounds)\n",
      "1 /   0.0003126 /   0.0003126 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007428 /   0.0007428 (  perturbed bounds)\n",
      "1 /   0.0007428 /   0.0007428 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "17it [03:31, 30.86s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004707 /   0.0004707 (  perturbed bounds)\n",
      "1 /   0.0004707 /   0.0004707 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001744 /   0.0001744 (  perturbed bounds)\n",
      "1 /   0.0001744 /   0.0001744 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002242 /   0.0002242 (  perturbed bounds)\n",
      "1 /   0.0002242 /   0.0002242 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002908 /   0.0002908 (  perturbed bounds)\n",
      "1 /   0.0002908 /   0.0002908 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004037 /   0.0004037 (  perturbed bounds)\n",
      "1 /   0.0004037 /   0.0004037 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005939 /   0.0005939 (  perturbed bounds)\n",
      "1 /   0.0005939 /   0.0005939 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001641 /   0.0001641 (  perturbed bounds)\n",
      "1 /   0.0001641 /   0.0001641 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004326 /   0.0004326 (  perturbed bounds)\n",
      "1 /   0.0004326 /   0.0004326 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009326 /   0.0009326 (  perturbed bounds)\n",
      "1 /   0.0009326 /   0.0009326 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003198 /   0.0003998 (  perturbed bounds)\n",
      "2 /   0.0003198 /   0.0003998 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008332 /   0.0008332 (  perturbed bounds)\n",
      "1 /   0.0008332 /   0.0008332 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007456 /   0.0007456 (  perturbed bounds)\n",
      "1 /   0.0007456 /   0.0007456 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000288 /    0.000288 (  perturbed bounds)\n",
      "1 /    0.000288 /    0.000288 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007232 /   0.0007232 (  perturbed bounds)\n",
      "1 /   0.0007232 /   0.0007232 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006482 /   0.0006482 (  perturbed bounds)\n",
      "1 /   0.0006482 /   0.0006482 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003193 /   0.0006386 (  perturbed bounds)\n",
      "2 /   0.0003193 /   0.0006386 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005968 /   0.0005968 (  perturbed bounds)\n",
      "1 /   0.0005968 /   0.0005968 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002477 /   0.0002477 (  perturbed bounds)\n",
      "1 /   0.0002477 /   0.0002477 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007699 /   0.0007699 (  perturbed bounds)\n",
      "1 /   0.0007699 /   0.0007699 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002766 /   0.0002766 (  perturbed bounds)\n",
      "1 /   0.0002766 /   0.0002766 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006254 /   0.0006254 (  perturbed bounds)\n",
      "1 /   0.0006254 /   0.0006254 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004629 /   0.0009258 (  perturbed bounds)\n",
      "2 /   0.0004629 /   0.0009258 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006355 /    0.001271 (  perturbed bounds)\n",
      "2 /   0.0006355 /    0.001271 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003271 /   0.0003271 (  perturbed bounds)\n",
      "1 /   0.0003271 /   0.0003271 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009476 /    0.001066 (  perturbed bounds)\n",
      "2 /   0.0009476 /    0.001066 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002462 /   0.0002462 (  perturbed bounds)\n",
      "1 /   0.0002462 /   0.0002462 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007096 /   0.0007096 (  perturbed bounds)\n",
      "1 /   0.0007096 /   0.0007096 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008513 /   0.0008513 (  perturbed bounds)\n",
      "1 /   0.0008513 /   0.0008513 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0008367 /   0.0009413 (  perturbed bounds)\n",
      "2 /   0.0008367 /   0.0009413 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "18it [04:07, 32.29s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000578 /    0.000578 (  perturbed bounds)\n",
      "1 /    0.000578 /    0.000578 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007505 /   0.0009948 (  perturbed bounds)\n",
      "2 /   0.0007505 /   0.0009948 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006569 /   0.0006569 (  perturbed bounds)\n",
      "1 /   0.0006569 /   0.0006569 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008483 /   0.0008483 (  perturbed bounds)\n",
      "1 /   0.0008483 /   0.0008483 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003748 /   0.0003748 (  perturbed bounds)\n",
      "1 /   0.0003748 /   0.0003748 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007074 /   0.0007074 (  perturbed bounds)\n",
      "1 /   0.0007074 /   0.0007074 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008226 /   0.0008226 (  perturbed bounds)\n",
      "1 /   0.0008226 /   0.0008226 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /     0.00041 /     0.00082 (  perturbed bounds)\n",
      "2 /     0.00041 /     0.00082 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003731 /   0.0003731 (  perturbed bounds)\n",
      "1 /   0.0003731 /   0.0003731 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002958 /   0.0002958 (  perturbed bounds)\n",
      "1 /   0.0002958 /   0.0002958 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001704 /   0.0001704 (  perturbed bounds)\n",
      "1 /   0.0001704 /   0.0001704 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002451 /   0.0002451 (  perturbed bounds)\n",
      "1 /   0.0002451 /   0.0002451 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002083 /   0.0002083 (  perturbed bounds)\n",
      "1 /   0.0002083 /   0.0002083 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007481 /   0.0007481 (  perturbed bounds)\n",
      "1 /   0.0007481 /   0.0007481 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0003054 /   0.0003054 (  perturbed bounds)\n",
      "1 /   0.0003054 /   0.0003054 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003176 /   0.0006353 (  perturbed bounds)\n",
      "2 /   0.0003176 /   0.0006353 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0007243 /   0.0007243 (  perturbed bounds)\n",
      "1 /   0.0007243 /   0.0007243 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000898 /    0.000898 (  perturbed bounds)\n",
      "1 /    0.000898 /    0.000898 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002567 /   0.0002567 (  perturbed bounds)\n",
      "1 /   0.0002567 /   0.0002567 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006841 /   0.0006841 (  perturbed bounds)\n",
      "1 /   0.0006841 /   0.0006841 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0005827 /    0.001165 (  perturbed bounds)\n",
      "2 /   0.0005827 /    0.001165 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008526 /   0.0008526 (  perturbed bounds)\n",
      "1 /   0.0008526 /   0.0008526 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002332 /   0.0002332 (  perturbed bounds)\n",
      "1 /   0.0002332 /   0.0002332 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003147 /   0.0003934 (  perturbed bounds)\n",
      "2 /   0.0003147 /   0.0003934 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002513 /   0.0002513 (  perturbed bounds)\n",
      "1 /   0.0002513 /   0.0002513 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "19it [04:41, 32.76s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006397 /   0.0009596 (  perturbed bounds)\n",
      "2 /   0.0006397 /   0.0009596 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001772 /   0.0001772 (  perturbed bounds)\n",
      "1 /   0.0001772 /   0.0001772 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005989 /   0.0005989 (  perturbed bounds)\n",
      "1 /   0.0005989 /   0.0005989 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009637 /   0.0009637 (  perturbed bounds)\n",
      "1 /   0.0009637 /   0.0009637 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004393 /   0.0004393 (  perturbed bounds)\n",
      "1 /   0.0004393 /   0.0004393 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0007414 /    0.000982 (  perturbed bounds)\n",
      "2 /   0.0007414 /    0.000982 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004114 /   0.0008228 (  perturbed bounds)\n",
      "2 /   0.0004114 /   0.0008228 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008551 /   0.0008551 (  perturbed bounds)\n",
      "1 /   0.0008551 /   0.0008551 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006613 /    0.001323 (  perturbed bounds)\n",
      "2 /   0.0006613 /    0.001323 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009188 /   0.0009188 (  perturbed bounds)\n",
      "1 /   0.0009188 /   0.0009188 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002051 /   0.0002051 (  perturbed bounds)\n",
      "1 /   0.0002051 /   0.0002051 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002849 /   0.0002849 (  perturbed bounds)\n",
      "1 /   0.0002849 /   0.0002849 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005245 /   0.0005245 (  perturbed bounds)\n",
      "1 /   0.0005245 /   0.0005245 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005696 /   0.0005696 (  perturbed bounds)\n",
      "1 /   0.0005696 /   0.0005696 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002606 /   0.0002606 (  perturbed bounds)\n",
      "1 /   0.0002606 /   0.0002606 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005152 /   0.0005152 (  perturbed bounds)\n",
      "1 /   0.0005152 /   0.0005152 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009722 /    0.001944 (  perturbed bounds)\n",
      "2 /   0.0009722 /    0.001944 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009284 /   0.0009284 (  perturbed bounds)\n",
      "1 /   0.0009284 /   0.0009284 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000538 /   0.0006725 (  perturbed bounds)\n",
      "2 /    0.000538 /   0.0006725 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004387 /   0.0008773 (  perturbed bounds)\n",
      "2 /   0.0004387 /   0.0008773 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0005347 /   0.0005347 (  perturbed bounds)\n",
      "1 /   0.0005347 /   0.0005347 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002158 /   0.0002158 (  perturbed bounds)\n",
      "1 /   0.0002158 /   0.0002158 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0005959 /   0.0007449 (  perturbed bounds)\n",
      "2 /   0.0005959 /   0.0007449 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008418 /   0.0008418 (  perturbed bounds)\n",
      "1 /   0.0008418 /   0.0008418 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002917 /   0.0002917 (  perturbed bounds)\n",
      "1 /   0.0002917 /   0.0002917 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "20it [05:16, 33.42s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /    0.000318 /    0.000318 (  perturbed bounds)\n",
      "1 /    0.000318 /    0.000318 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008269 /   0.0008269 (  perturbed bounds)\n",
      "1 /   0.0008269 /   0.0008269 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002145 /   0.0002145 (  perturbed bounds)\n",
      "1 /   0.0002145 /   0.0002145 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0008173 /    0.001635 (  perturbed bounds)\n",
      "2 /   0.0008173 /    0.001635 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0001739 /   0.0001739 (  perturbed bounds)\n",
      "1 /   0.0001739 /   0.0001739 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004809 /   0.0009618 (  perturbed bounds)\n",
      "2 /   0.0004809 /   0.0009618 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0009812 /   0.0009812 (  perturbed bounds)\n",
      "1 /   0.0009812 /   0.0009812 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002995 /   0.0002995 (  perturbed bounds)\n",
      "1 /   0.0002995 /   0.0002995 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0003403 /   0.0006807 (  perturbed bounds)\n",
      "2 /   0.0003403 /   0.0006807 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000401 /    0.000802 (  perturbed bounds)\n",
      "2 /    0.000401 /    0.000802 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0006958 /   0.0006958 (  perturbed bounds)\n",
      "1 /   0.0006958 /   0.0006958 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009885 /    0.001236 (  perturbed bounds)\n",
      "2 /   0.0009885 /    0.001236 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0009934 /    0.001987 (  perturbed bounds)\n",
      "2 /   0.0009934 /    0.001987 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0004667 /   0.0004667 (  perturbed bounds)\n",
      "1 /   0.0004667 /   0.0004667 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0008725 /   0.0008725 (  perturbed bounds)\n",
      "1 /   0.0008725 /   0.0008725 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /    0.000472 /     0.00059 (  perturbed bounds)\n",
      "2 /    0.000472 /     0.00059 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "1 /   0.0002637 /   0.0002637 (  perturbed bounds)\n",
      "1 /   0.0002637 /   0.0002637 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0004919 /   0.0006935 (  perturbed bounds)\n",
      "2 /   0.0004919 /   0.0006935 (unperturbed bounds)\n",
      "Solve 1: Forcing phase 2 since near primal feasible with unperturbed costs\n",
      "num / max / sum primal infeasiblitiles\n",
      "2 /   0.0006803 /   0.0007653 (  perturbed bounds)\n",
      "2 /   0.0006803 /   0.0007653 (unperturbed bounds)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "32it [05:57, 11.19s/it]\n"
     ]
    }
   ],
   "source": [
    "states, controls, costs, parameters, computation_times = Simulator(environment,algorithms, True, False).run(T)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Comparing the algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "alg_names = [r\"$S^*_T$\", r\"$\\hat{S}_t$\", \"MPC\", \"GAPSI without forecasts\", \"GAPSI with forecasts\"]\n",
    "alg_mean = []\n",
    "alg_std = []\n",
    "alg_time = []\n",
    "\n",
    "alg_mean.append(costs[0].mean())\n",
    "alg_std.append(0.0)\n",
    "alg_time.append(round(computation_times[0], 2))\n",
    "\n",
    "alg_mean.append(torch.stack(costs)[1:1+NB_SAMPLE].mean(dim=1).mean())\n",
    "alg_std.append(torch.stack(costs)[1:1+NB_SAMPLE].mean(dim=1).std())\n",
    "alg_time.append(round(np.array(computation_times[1:1+NB_SAMPLE]).mean(), 2))\n",
    "\n",
    "alg_mean.append(torch.stack(costs)[1+NB_SAMPLE:1+2*NB_SAMPLE].mean(dim=1).mean())\n",
    "alg_std.append(torch.stack(costs)[1+NB_SAMPLE:1+2*NB_SAMPLE].mean(dim=1).std())\n",
    "alg_time.append(round(np.array(computation_times[1+NB_SAMPLE:1+2*NB_SAMPLE]).mean(), 2))\n",
    "\n",
    "alg_mean.append(costs[1+2*NB_SAMPLE].mean())\n",
    "alg_std.append(0.0)\n",
    "alg_time.append(round(computation_times[1+2*NB_SAMPLE], 2))\n",
    "\n",
    "alg_mean.append(torch.stack(costs)[2+2*NB_SAMPLE:2+3*NB_SAMPLE].mean(dim=1).mean())\n",
    "alg_std.append(torch.stack(costs)[2+2*NB_SAMPLE:2+3*NB_SAMPLE].mean(dim=1).std())\n",
    "alg_time.append(round(np.array(computation_times[2+2*NB_SAMPLE:2+3*NB_SAMPLE]).mean(), 2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ratio of losses\n",
      "\n",
      "Algorithm: $S^*_T$\n",
      "\tMean: 1.0\n",
      "\tStd.: 0.0\n",
      "\tAvg. time: 0.228\n",
      "Algorithm: $\\hat{S}_t$\n",
      "\tMean: 1.028\n",
      "\tStd.: 0.011\n",
      "\tAvg. time: 0.213\n",
      "Algorithm: MPC\n",
      "\tMean: 1.028\n",
      "\tStd.: 0.011\n",
      "\tAvg. time: 34.798\n",
      "Algorithm: GAPSI without forecasts\n",
      "\tMean: 0.735\n",
      "\tStd.: 0.0\n",
      "\tAvg. time: 0.677\n",
      "Algorithm: GAPSI with forecasts\n",
      "\tMean: 0.704\n",
      "\tStd.: 0.005\n",
      "\tAvg. time: 0.679\n"
     ]
    }
   ],
   "source": [
    "ratio_of_losses_mean = [round((alg_mean[i]/alg_mean[0]).item(), 3) for i in range(1,len(alg_mean))]\n",
    "ratio_of_losses_std = [round((alg_std[i]/alg_mean[0]).item(), 3) for i in range(1,len(alg_mean))]\n",
    "\n",
    "print(\"Ratio of losses\\n\")\n",
    "for i in range(len(alg_names)) :\n",
    "    print(\"Algorithm: {}\\n\\tMean: {}\\n\\tStd.: {}\\n\\tAvg. time: {}\".format(\n",
    "        alg_names[i],\n",
    "        1.000 if (i==0) else ratio_of_losses_mean[i-1],\n",
    "        0.000 if (i==0) else ratio_of_losses_std[i-1],\n",
    "        alg_time[i]\n",
    "    ))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "policy_selection_for_inventories",
   "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.11.6"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
