{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "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.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": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "NB_SAMPLE = 100\n",
    "MEAN_DEMAND = 5\n",
    "T_train = 10_000\n",
    "SNAPSHOT_TIMES = [99, 999, 4_999, 9_999]# 19_999, 49_999]\n",
    "T_test = 10_000\n",
    "T = max(T_train, T_test)\n",
    "NB_XP = 10\n",
    "\n",
    "SEED = 1\n",
    "torch.manual_seed(SEED)\n",
    "\n",
    "lifetime = 3\n",
    "leadtime = 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_costs = torch.zeros(NB_XP, NB_SAMPLE, T_train)\n",
    "train_parameters = torch.zeros(NB_XP, NB_SAMPLE, T_train)\n",
    "test_mean_costs = torch.zeros(NB_XP, NB_SAMPLE, len(SNAPSHOT_TIMES))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulate_and_get_plot_input(xp_idx, purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost) :\n",
    "    for sample_idx in range(NB_SAMPLE) : \n",
    "        demands = torch.poisson(MEAN_DEMAND*torch.ones(T_train))\n",
    "        product = LS_FIFOP_Product(lifetime, leadtime, demands, purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost, 10*T_train*demands.numpy().max())\n",
    "        environment = Infinite_Warehouse([product])\n",
    "\n",
    "        algorithms = [\n",
    "            GAPSI_Special(environment, [1], .1, 10, torch.zeros(1), torch.zeros(1), 20*torch.ones(1), [torch.ones(T_train,1)]),\n",
    "        ]\n",
    "        _, _, sample_costs, sample_parameters, _ = Simulator(environment,algorithms, False, False).run(T_train)\n",
    "        train_costs[xp_idx, sample_idx] = sample_costs[0]\n",
    "        train_parameters[xp_idx, sample_idx] = sample_parameters[0].reshape(T_train)\n",
    "        print(\"\\txp {}, sample {}, train cost {}\".format(xp_idx, sample_idx, train_costs[xp_idx, sample_idx].mean()))\n",
    "\n",
    "        for snap_idx, snapshot_time in enumerate(SNAPSHOT_TIMES) :\n",
    "            demands = torch.poisson(MEAN_DEMAND*torch.ones(T_test))\n",
    "            product = LS_FIFOP_Product(lifetime, leadtime, demands, purchase_cost, holding_cost, selling_price, outdating_cost, penalty_cost, 10*T_train*demands.numpy().max())\n",
    "            environment = Infinite_Warehouse([product])\n",
    "            \n",
    "            algorithms = [\n",
    "                Base_Stock(environment, [train_parameters[xp_idx, sample_idx, :snapshot_time].mean()*torch.ones(T_test)])\n",
    "            ]\n",
    "            _, _, sample_costs, _, _ = Simulator(environment,algorithms, False, False).run(T_test)\n",
    "            test_mean_costs[xp_idx, sample_idx, snap_idx] = sample_costs[0].mean()\n",
    "            \n",
    "    print(\"Summary: xp {}:\\n\\t OPT {},\\n\\tmean test cost {}\\n\\tstd test cost {}\".format(\n",
    "        xp_idx,\n",
    "        OPTs[xp_idx],\n",
    "        test_mean_costs[xp_idx].mean(dim=0),\n",
    "        test_mean_costs[xp_idx].std(dim=0)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_simulation_output(mean_cum_losses, std_cum_losses, OPT) :\n",
    "    plt.figure(figsize=(13,4))\n",
    "    plt.loglog(torch.arange(1,T+1), mean_cum_losses-OPT, color=\"k\")\n",
    "    plt.fill_between(torch.arange(1,T+1), mean_cum_losses-std_cum_losses-OPT, mean_cum_losses+std_cum_losses-OPT, color=\"r\", alpha=0.33)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\txp 0, sample 0, train cost 4.185154438018799\n",
      "\txp 0, sample 1, train cost 4.177061557769775\n",
      "\txp 0, sample 2, train cost 4.196484565734863\n",
      "\txp 0, sample 3, train cost 4.224098205566406\n",
      "\txp 0, sample 4, train cost 4.12162446975708\n",
      "\txp 0, sample 5, train cost 4.229732036590576\n",
      "\txp 0, sample 6, train cost 4.225247859954834\n",
      "\txp 0, sample 7, train cost 4.188469409942627\n",
      "\txp 0, sample 8, train cost 4.156618595123291\n",
      "\txp 0, sample 9, train cost 4.300320148468018\n",
      "\txp 0, sample 10, train cost 4.193716526031494\n",
      "\txp 0, sample 11, train cost 4.208651065826416\n",
      "\txp 0, sample 12, train cost 4.223819732666016\n",
      "\txp 0, sample 13, train cost 4.17130184173584\n",
      "\txp 0, sample 14, train cost 4.27250337600708\n",
      "\txp 0, sample 15, train cost 4.203359127044678\n",
      "\txp 0, sample 16, train cost 4.260583400726318\n",
      "\txp 0, sample 17, train cost 4.169365406036377\n",
      "\txp 0, sample 18, train cost 4.196355819702148\n",
      "\txp 0, sample 19, train cost 4.259984493255615\n",
      "\txp 0, sample 20, train cost 4.251291751861572\n",
      "\txp 0, sample 21, train cost 4.226405620574951\n",
      "\txp 0, sample 22, train cost 4.241827964782715\n",
      "\txp 0, sample 23, train cost 4.1900739669799805\n",
      "\txp 0, sample 24, train cost 4.232411861419678\n",
      "\txp 0, sample 25, train cost 4.181175231933594\n",
      "\txp 0, sample 26, train cost 4.25076150894165\n",
      "\txp 0, sample 27, train cost 4.231755256652832\n",
      "\txp 0, sample 28, train cost 4.23599100112915\n",
      "\txp 0, sample 29, train cost 4.254513740539551\n",
      "\txp 0, sample 30, train cost 4.263817310333252\n",
      "\txp 0, sample 31, train cost 4.216963291168213\n",
      "\txp 0, sample 32, train cost 4.129862308502197\n",
      "\txp 0, sample 33, train cost 4.260100364685059\n",
      "\txp 0, sample 34, train cost 4.214289665222168\n",
      "\txp 0, sample 35, train cost 4.251151084899902\n",
      "\txp 0, sample 36, train cost 4.281190395355225\n",
      "\txp 0, sample 37, train cost 4.161253929138184\n",
      "\txp 0, sample 38, train cost 4.254765033721924\n",
      "\txp 0, sample 39, train cost 4.282281875610352\n",
      "\txp 0, sample 40, train cost 4.2039899826049805\n",
      "\txp 0, sample 41, train cost 4.184044361114502\n",
      "\txp 0, sample 42, train cost 4.192239284515381\n",
      "\txp 0, sample 43, train cost 4.219067573547363\n",
      "\txp 0, sample 44, train cost 4.193782806396484\n",
      "\txp 0, sample 45, train cost 4.250159740447998\n",
      "\txp 0, sample 46, train cost 4.2645263671875\n",
      "\txp 0, sample 47, train cost 4.295016765594482\n",
      "\txp 0, sample 48, train cost 4.197083473205566\n",
      "\txp 0, sample 49, train cost 4.22812557220459\n",
      "\txp 0, sample 50, train cost 4.245116233825684\n",
      "\txp 0, sample 51, train cost 4.31958532333374\n",
      "\txp 0, sample 52, train cost 4.195212364196777\n",
      "\txp 0, sample 53, train cost 4.17563533782959\n",
      "\txp 0, sample 54, train cost 4.229371070861816\n",
      "\txp 0, sample 55, train cost 4.219263553619385\n",
      "\txp 0, sample 56, train cost 4.208807468414307\n",
      "\txp 0, sample 57, train cost 4.178397178649902\n",
      "\txp 0, sample 58, train cost 4.19950532913208\n",
      "\txp 0, sample 59, train cost 4.274886131286621\n",
      "\txp 0, sample 60, train cost 4.233095169067383\n",
      "\txp 0, sample 61, train cost 4.207066059112549\n",
      "\txp 0, sample 62, train cost 4.237524509429932\n",
      "\txp 0, sample 63, train cost 4.271721363067627\n",
      "\txp 0, sample 64, train cost 4.236504554748535\n",
      "\txp 0, sample 65, train cost 4.1903157234191895\n",
      "\txp 0, sample 66, train cost 4.203090667724609\n",
      "\txp 0, sample 67, train cost 4.212636470794678\n",
      "\txp 0, sample 68, train cost 4.220707893371582\n",
      "\txp 0, sample 69, train cost 4.297122955322266\n",
      "\txp 0, sample 70, train cost 4.190543174743652\n",
      "\txp 0, sample 71, train cost 4.238032341003418\n",
      "\txp 0, sample 72, train cost 4.221139430999756\n",
      "\txp 0, sample 73, train cost 4.219173908233643\n",
      "\txp 0, sample 74, train cost 4.212245464324951\n",
      "\txp 0, sample 75, train cost 4.26161003112793\n",
      "\txp 0, sample 76, train cost 4.171229839324951\n",
      "\txp 0, sample 77, train cost 4.179389476776123\n",
      "\txp 0, sample 78, train cost 4.228175163269043\n",
      "\txp 0, sample 79, train cost 4.195536136627197\n",
      "\txp 0, sample 80, train cost 4.187975883483887\n",
      "\txp 0, sample 81, train cost 4.1975531578063965\n",
      "\txp 0, sample 82, train cost 4.238100051879883\n",
      "\txp 0, sample 83, train cost 4.164999485015869\n",
      "\txp 0, sample 84, train cost 4.250519752502441\n",
      "\txp 0, sample 85, train cost 4.176726341247559\n",
      "\txp 0, sample 86, train cost 4.272634029388428\n",
      "\txp 0, sample 87, train cost 4.184011459350586\n",
      "\txp 0, sample 88, train cost 4.247365474700928\n",
      "\txp 0, sample 89, train cost 4.245632648468018\n",
      "\txp 0, sample 90, train cost 4.265810966491699\n",
      "\txp 0, sample 91, train cost 4.213125228881836\n",
      "\txp 0, sample 92, train cost 4.2134928703308105\n",
      "\txp 0, sample 93, train cost 4.241298198699951\n",
      "\txp 0, sample 94, train cost 4.192363739013672\n",
      "\txp 0, sample 95, train cost 4.304476261138916\n",
      "\txp 0, sample 96, train cost 4.169914245605469\n",
      "\txp 0, sample 97, train cost 4.209027290344238\n",
      "\txp 0, sample 98, train cost 4.192483425140381\n",
      "\txp 0, sample 99, train cost 4.129064083099365\n",
      "Summary: xp 0:\n",
      "\t OPT 4.16,\n",
      "\tmean test cost tensor([4.3240, 4.2154, 4.2005, 4.1940])\n",
      "\tstd test cost tensor([0.1525, 0.0461, 0.0439, 0.0477])\n",
      "\txp 1, sample 0, train cost 4.339728355407715\n",
      "\txp 1, sample 1, train cost 4.2964348793029785\n",
      "\txp 1, sample 2, train cost 4.305858612060547\n",
      "\txp 1, sample 3, train cost 4.280339241027832\n",
      "\txp 1, sample 4, train cost 4.225360870361328\n",
      "\txp 1, sample 5, train cost 4.343597888946533\n",
      "\txp 1, sample 6, train cost 4.222819805145264\n",
      "\txp 1, sample 7, train cost 4.291452884674072\n",
      "\txp 1, sample 8, train cost 4.2346930503845215\n",
      "\txp 1, sample 9, train cost 4.237915515899658\n",
      "\txp 1, sample 10, train cost 4.25449275970459\n",
      "\txp 1, sample 11, train cost 4.40616512298584\n",
      "\txp 1, sample 12, train cost 4.295870304107666\n",
      "\txp 1, sample 13, train cost 4.34497594833374\n",
      "\txp 1, sample 14, train cost 4.220101356506348\n",
      "\txp 1, sample 15, train cost 4.266730308532715\n",
      "\txp 1, sample 16, train cost 4.27344274520874\n",
      "\txp 1, sample 17, train cost 4.313249111175537\n",
      "\txp 1, sample 18, train cost 4.262745380401611\n",
      "\txp 1, sample 19, train cost 4.2619194984436035\n",
      "\txp 1, sample 20, train cost 4.204111099243164\n",
      "\txp 1, sample 21, train cost 4.285597801208496\n",
      "\txp 1, sample 22, train cost 4.339097499847412\n",
      "\txp 1, sample 23, train cost 4.17019510269165\n",
      "\txp 1, sample 24, train cost 4.302657604217529\n",
      "\txp 1, sample 25, train cost 4.284131050109863\n",
      "\txp 1, sample 26, train cost 4.3247270584106445\n",
      "\txp 1, sample 27, train cost 4.296361923217773\n",
      "\txp 1, sample 28, train cost 4.340085029602051\n",
      "\txp 1, sample 29, train cost 4.241106033325195\n",
      "\txp 1, sample 30, train cost 4.33521032333374\n",
      "\txp 1, sample 31, train cost 4.276695251464844\n",
      "\txp 1, sample 32, train cost 4.2357587814331055\n",
      "\txp 1, sample 33, train cost 4.284537315368652\n",
      "\txp 1, sample 34, train cost 4.276276588439941\n",
      "\txp 1, sample 35, train cost 4.318539142608643\n",
      "\txp 1, sample 36, train cost 4.299199104309082\n",
      "\txp 1, sample 37, train cost 4.269161224365234\n",
      "\txp 1, sample 38, train cost 4.281494617462158\n",
      "\txp 1, sample 39, train cost 4.3197150230407715\n",
      "\txp 1, sample 40, train cost 4.3466901779174805\n",
      "\txp 1, sample 41, train cost 4.3071980476379395\n",
      "\txp 1, sample 42, train cost 4.343523025512695\n",
      "\txp 1, sample 43, train cost 4.323317527770996\n",
      "\txp 1, sample 44, train cost 4.277448654174805\n",
      "\txp 1, sample 45, train cost 4.296341419219971\n",
      "\txp 1, sample 46, train cost 4.3221845626831055\n",
      "\txp 1, sample 47, train cost 4.3744282722473145\n",
      "\txp 1, sample 48, train cost 4.316773414611816\n",
      "\txp 1, sample 49, train cost 4.264962673187256\n",
      "\txp 1, sample 50, train cost 4.224849700927734\n",
      "\txp 1, sample 51, train cost 4.287158012390137\n",
      "\txp 1, sample 52, train cost 4.244491100311279\n",
      "\txp 1, sample 53, train cost 4.371704578399658\n",
      "\txp 1, sample 54, train cost 4.305944442749023\n",
      "\txp 1, sample 55, train cost 4.366783618927002\n",
      "\txp 1, sample 56, train cost 4.377048492431641\n",
      "\txp 1, sample 57, train cost 4.363879680633545\n",
      "\txp 1, sample 58, train cost 4.277574062347412\n",
      "\txp 1, sample 59, train cost 4.221468448638916\n",
      "\txp 1, sample 60, train cost 4.322087287902832\n",
      "\txp 1, sample 61, train cost 4.2781901359558105\n",
      "\txp 1, sample 62, train cost 4.1605048179626465\n",
      "\txp 1, sample 63, train cost 4.27192497253418\n",
      "\txp 1, sample 64, train cost 4.266299724578857\n",
      "\txp 1, sample 65, train cost 4.3251872062683105\n",
      "\txp 1, sample 66, train cost 4.1957855224609375\n",
      "\txp 1, sample 67, train cost 4.322925567626953\n",
      "\txp 1, sample 68, train cost 4.284460544586182\n",
      "\txp 1, sample 69, train cost 4.286159992218018\n",
      "\txp 1, sample 70, train cost 4.233513832092285\n",
      "\txp 1, sample 71, train cost 4.329035758972168\n",
      "\txp 1, sample 72, train cost 4.259245872497559\n",
      "\txp 1, sample 73, train cost 4.29633903503418\n",
      "\txp 1, sample 74, train cost 4.289884567260742\n",
      "\txp 1, sample 75, train cost 4.28550386428833\n",
      "\txp 1, sample 76, train cost 4.3119025230407715\n",
      "\txp 1, sample 77, train cost 4.3607497215271\n",
      "\txp 1, sample 78, train cost 4.248398303985596\n",
      "\txp 1, sample 79, train cost 4.264355182647705\n",
      "\txp 1, sample 80, train cost 4.270323276519775\n",
      "\txp 1, sample 81, train cost 4.309322357177734\n",
      "\txp 1, sample 82, train cost 4.200014114379883\n",
      "\txp 1, sample 83, train cost 4.282290935516357\n",
      "\txp 1, sample 84, train cost 4.313572406768799\n",
      "\txp 1, sample 85, train cost 4.362096786499023\n",
      "\txp 1, sample 86, train cost 4.256363868713379\n",
      "\txp 1, sample 87, train cost 4.322610378265381\n",
      "\txp 1, sample 88, train cost 4.277563095092773\n",
      "\txp 1, sample 89, train cost 4.279874801635742\n",
      "\txp 1, sample 90, train cost 4.295265197753906\n",
      "\txp 1, sample 91, train cost 4.270896911621094\n",
      "\txp 1, sample 92, train cost 4.309616565704346\n",
      "\txp 1, sample 93, train cost 4.207605361938477\n",
      "\txp 1, sample 94, train cost 4.385814666748047\n",
      "\txp 1, sample 95, train cost 4.227237701416016\n",
      "\txp 1, sample 96, train cost 4.262242794036865\n",
      "\txp 1, sample 97, train cost 4.321956634521484\n",
      "\txp 1, sample 98, train cost 4.360965728759766\n",
      "\txp 1, sample 99, train cost 4.300105094909668\n",
      "Summary: xp 1:\n",
      "\t OPT 4.23,\n",
      "\tmean test cost tensor([4.4127, 4.2652, 4.2667, 4.2586])\n",
      "\tstd test cost tensor([0.1586, 0.0532, 0.0481, 0.0434])\n",
      "\txp 2, sample 0, train cost 4.280608177185059\n",
      "\txp 2, sample 1, train cost 4.394827842712402\n",
      "\txp 2, sample 2, train cost 4.363244533538818\n",
      "\txp 2, sample 3, train cost 4.343850612640381\n",
      "\txp 2, sample 4, train cost 4.323886871337891\n",
      "\txp 2, sample 5, train cost 4.308629512786865\n",
      "\txp 2, sample 6, train cost 4.357309818267822\n",
      "\txp 2, sample 7, train cost 4.363527297973633\n",
      "\txp 2, sample 8, train cost 4.302999496459961\n",
      "\txp 2, sample 9, train cost 4.348042011260986\n",
      "\txp 2, sample 10, train cost 4.305228233337402\n",
      "\txp 2, sample 11, train cost 4.297382831573486\n",
      "\txp 2, sample 12, train cost 4.321855068206787\n",
      "\txp 2, sample 13, train cost 4.296018123626709\n",
      "\txp 2, sample 14, train cost 4.23837423324585\n",
      "\txp 2, sample 15, train cost 4.304239273071289\n",
      "\txp 2, sample 16, train cost 4.299476146697998\n",
      "\txp 2, sample 17, train cost 4.323403358459473\n",
      "\txp 2, sample 18, train cost 4.313261985778809\n",
      "\txp 2, sample 19, train cost 4.281783580780029\n",
      "\txp 2, sample 20, train cost 4.226680755615234\n",
      "\txp 2, sample 21, train cost 4.39165735244751\n",
      "\txp 2, sample 22, train cost 4.442306041717529\n",
      "\txp 2, sample 23, train cost 4.304681777954102\n",
      "\txp 2, sample 24, train cost 4.344536781311035\n",
      "\txp 2, sample 25, train cost 4.371469020843506\n",
      "\txp 2, sample 26, train cost 4.340880393981934\n",
      "\txp 2, sample 27, train cost 4.356484413146973\n",
      "\txp 2, sample 28, train cost 4.320539474487305\n",
      "\txp 2, sample 29, train cost 4.376439094543457\n",
      "\txp 2, sample 30, train cost 4.331924915313721\n",
      "\txp 2, sample 31, train cost 4.337284564971924\n",
      "\txp 2, sample 32, train cost 4.321642875671387\n",
      "\txp 2, sample 33, train cost 4.349090099334717\n",
      "\txp 2, sample 34, train cost 4.269358158111572\n",
      "\txp 2, sample 35, train cost 4.381740093231201\n",
      "\txp 2, sample 36, train cost 4.294400215148926\n",
      "\txp 2, sample 37, train cost 4.3783111572265625\n",
      "\txp 2, sample 38, train cost 4.370935916900635\n",
      "\txp 2, sample 39, train cost 4.337865352630615\n",
      "\txp 2, sample 40, train cost 4.392440319061279\n",
      "\txp 2, sample 41, train cost 4.33412504196167\n",
      "\txp 2, sample 42, train cost 4.329741477966309\n",
      "\txp 2, sample 43, train cost 4.368277072906494\n",
      "\txp 2, sample 44, train cost 4.257598876953125\n",
      "\txp 2, sample 45, train cost 4.3362040519714355\n",
      "\txp 2, sample 46, train cost 4.29745626449585\n",
      "\txp 2, sample 47, train cost 4.383354663848877\n",
      "\txp 2, sample 48, train cost 4.25029993057251\n",
      "\txp 2, sample 49, train cost 4.362882614135742\n",
      "\txp 2, sample 50, train cost 4.337740898132324\n",
      "\txp 2, sample 51, train cost 4.316296100616455\n",
      "\txp 2, sample 52, train cost 4.301220893859863\n",
      "\txp 2, sample 53, train cost 4.314133167266846\n",
      "\txp 2, sample 54, train cost 4.389724254608154\n",
      "\txp 2, sample 55, train cost 4.278070449829102\n",
      "\txp 2, sample 56, train cost 4.329350471496582\n",
      "\txp 2, sample 57, train cost 4.340229511260986\n",
      "\txp 2, sample 58, train cost 4.340691089630127\n",
      "\txp 2, sample 59, train cost 4.3064961433410645\n",
      "\txp 2, sample 60, train cost 4.292282581329346\n",
      "\txp 2, sample 61, train cost 4.358656883239746\n",
      "\txp 2, sample 62, train cost 4.347762584686279\n",
      "\txp 2, sample 63, train cost 4.405642032623291\n",
      "\txp 2, sample 64, train cost 4.2949910163879395\n",
      "\txp 2, sample 65, train cost 4.210266590118408\n",
      "\txp 2, sample 66, train cost 4.34407901763916\n",
      "\txp 2, sample 67, train cost 4.329504013061523\n",
      "\txp 2, sample 68, train cost 4.358456611633301\n",
      "\txp 2, sample 69, train cost 4.346304416656494\n",
      "\txp 2, sample 70, train cost 4.2795634269714355\n",
      "\txp 2, sample 71, train cost 4.386268615722656\n",
      "\txp 2, sample 72, train cost 4.247345924377441\n",
      "\txp 2, sample 73, train cost 4.393039703369141\n",
      "\txp 2, sample 74, train cost 4.348568916320801\n",
      "\txp 2, sample 75, train cost 4.397167205810547\n",
      "\txp 2, sample 76, train cost 4.417594909667969\n",
      "\txp 2, sample 77, train cost 4.312204837799072\n",
      "\txp 2, sample 78, train cost 4.296823978424072\n",
      "\txp 2, sample 79, train cost 4.3336873054504395\n",
      "\txp 2, sample 80, train cost 4.272299766540527\n",
      "\txp 2, sample 81, train cost 4.327682971954346\n",
      "\txp 2, sample 82, train cost 4.415563106536865\n",
      "\txp 2, sample 83, train cost 4.404654026031494\n",
      "\txp 2, sample 84, train cost 4.359560012817383\n",
      "\txp 2, sample 85, train cost 4.383613586425781\n",
      "\txp 2, sample 86, train cost 4.3372111320495605\n",
      "\txp 2, sample 87, train cost 4.261559963226318\n",
      "\txp 2, sample 88, train cost 4.388782978057861\n",
      "\txp 2, sample 89, train cost 4.356179714202881\n",
      "\txp 2, sample 90, train cost 4.2211079597473145\n",
      "\txp 2, sample 91, train cost 4.364985942840576\n",
      "\txp 2, sample 92, train cost 4.35131311416626\n",
      "\txp 2, sample 93, train cost 4.253989219665527\n",
      "\txp 2, sample 94, train cost 4.364120960235596\n",
      "\txp 2, sample 95, train cost 4.331372261047363\n",
      "\txp 2, sample 96, train cost 4.312272548675537\n",
      "\txp 2, sample 97, train cost 4.270925998687744\n",
      "\txp 2, sample 98, train cost 4.28705358505249\n",
      "\txp 2, sample 99, train cost 4.3094635009765625\n",
      "Summary: xp 2:\n",
      "\t OPT 4.28,\n",
      "\tmean test cost tensor([4.4473, 4.3065, 4.3118, 4.3072])\n",
      "\tstd test cost tensor([0.1908, 0.0484, 0.0466, 0.0449])\n",
      "\txp 3, sample 0, train cost 5.638566970825195\n",
      "\txp 3, sample 1, train cost 5.700181484222412\n",
      "\txp 3, sample 2, train cost 5.514346599578857\n",
      "\txp 3, sample 3, train cost 5.643996715545654\n",
      "\txp 3, sample 4, train cost 5.501256465911865\n",
      "\txp 3, sample 5, train cost 5.605041980743408\n",
      "\txp 3, sample 6, train cost 5.690255165100098\n",
      "\txp 3, sample 7, train cost 5.57744026184082\n",
      "\txp 3, sample 8, train cost 5.606632232666016\n",
      "\txp 3, sample 9, train cost 5.6216020584106445\n",
      "\txp 3, sample 10, train cost 5.488445281982422\n",
      "\txp 3, sample 11, train cost 5.478558540344238\n",
      "\txp 3, sample 12, train cost 5.520203113555908\n",
      "\txp 3, sample 13, train cost 5.709604740142822\n",
      "\txp 3, sample 14, train cost 5.562535285949707\n",
      "\txp 3, sample 15, train cost 5.626270294189453\n",
      "\txp 3, sample 16, train cost 5.5793585777282715\n",
      "\txp 3, sample 17, train cost 5.750965595245361\n",
      "\txp 3, sample 18, train cost 5.66172981262207\n",
      "\txp 3, sample 19, train cost 5.77258825302124\n",
      "\txp 3, sample 20, train cost 5.6642608642578125\n",
      "\txp 3, sample 21, train cost 5.445636749267578\n",
      "\txp 3, sample 22, train cost 5.670614242553711\n",
      "\txp 3, sample 23, train cost 5.599282741546631\n",
      "\txp 3, sample 24, train cost 5.604976177215576\n",
      "\txp 3, sample 25, train cost 5.619365692138672\n",
      "\txp 3, sample 26, train cost 5.604532241821289\n",
      "\txp 3, sample 27, train cost 5.624937534332275\n",
      "\txp 3, sample 28, train cost 5.538985729217529\n",
      "\txp 3, sample 29, train cost 5.585844993591309\n",
      "\txp 3, sample 30, train cost 5.688036918640137\n",
      "\txp 3, sample 31, train cost 5.677981853485107\n",
      "\txp 3, sample 32, train cost 5.606308460235596\n",
      "\txp 3, sample 33, train cost 5.607363224029541\n",
      "\txp 3, sample 34, train cost 5.755317211151123\n",
      "\txp 3, sample 35, train cost 5.64374303817749\n",
      "\txp 3, sample 36, train cost 5.587855815887451\n",
      "\txp 3, sample 37, train cost 5.734535217285156\n",
      "\txp 3, sample 38, train cost 5.45070219039917\n",
      "\txp 3, sample 39, train cost 5.524932384490967\n",
      "\txp 3, sample 40, train cost 5.5435919761657715\n",
      "\txp 3, sample 41, train cost 5.668542385101318\n",
      "\txp 3, sample 42, train cost 5.604280948638916\n",
      "\txp 3, sample 43, train cost 5.569847583770752\n",
      "\txp 3, sample 44, train cost 5.606283664703369\n",
      "\txp 3, sample 45, train cost 5.609080791473389\n",
      "\txp 3, sample 46, train cost 5.540331840515137\n",
      "\txp 3, sample 47, train cost 5.579049587249756\n",
      "\txp 3, sample 48, train cost 5.569880485534668\n",
      "\txp 3, sample 49, train cost 5.615312099456787\n",
      "\txp 3, sample 50, train cost 5.542171478271484\n",
      "\txp 3, sample 51, train cost 5.677577972412109\n",
      "\txp 3, sample 52, train cost 5.645633697509766\n",
      "\txp 3, sample 53, train cost 5.658802032470703\n",
      "\txp 3, sample 54, train cost 5.58925199508667\n",
      "\txp 3, sample 55, train cost 5.564591407775879\n",
      "\txp 3, sample 56, train cost 5.606817245483398\n",
      "\txp 3, sample 57, train cost 5.547493934631348\n",
      "\txp 3, sample 58, train cost 5.640688896179199\n",
      "\txp 3, sample 59, train cost 5.654507637023926\n",
      "\txp 3, sample 60, train cost 5.443631172180176\n",
      "\txp 3, sample 61, train cost 5.6489362716674805\n",
      "\txp 3, sample 62, train cost 5.8130106925964355\n",
      "\txp 3, sample 63, train cost 5.53533935546875\n",
      "\txp 3, sample 64, train cost 5.601231575012207\n",
      "\txp 3, sample 65, train cost 5.668645858764648\n",
      "\txp 3, sample 66, train cost 5.733919143676758\n",
      "\txp 3, sample 67, train cost 5.528366565704346\n",
      "\txp 3, sample 68, train cost 5.752312183380127\n",
      "\txp 3, sample 69, train cost 5.572359561920166\n",
      "\txp 3, sample 70, train cost 5.547922611236572\n",
      "\txp 3, sample 71, train cost 5.6166205406188965\n",
      "\txp 3, sample 72, train cost 5.579524517059326\n",
      "\txp 3, sample 73, train cost 5.518768310546875\n",
      "\txp 3, sample 74, train cost 5.680807590484619\n",
      "\txp 3, sample 75, train cost 5.637803077697754\n",
      "\txp 3, sample 76, train cost 5.668955326080322\n",
      "\txp 3, sample 77, train cost 5.573490619659424\n",
      "\txp 3, sample 78, train cost 5.562764644622803\n",
      "\txp 3, sample 79, train cost 5.618613243103027\n",
      "\txp 3, sample 80, train cost 5.7201762199401855\n",
      "\txp 3, sample 81, train cost 5.403215408325195\n",
      "\txp 3, sample 82, train cost 5.577041149139404\n",
      "\txp 3, sample 83, train cost 5.672068119049072\n",
      "\txp 3, sample 84, train cost 5.686420440673828\n",
      "\txp 3, sample 85, train cost 5.7331037521362305\n",
      "\txp 3, sample 86, train cost 5.619699954986572\n",
      "\txp 3, sample 87, train cost 5.5436506271362305\n",
      "\txp 3, sample 88, train cost 5.622668743133545\n",
      "\txp 3, sample 89, train cost 5.711636543273926\n",
      "\txp 3, sample 90, train cost 5.605113983154297\n",
      "\txp 3, sample 91, train cost 5.709296226501465\n",
      "\txp 3, sample 92, train cost 5.651264667510986\n",
      "\txp 3, sample 93, train cost 5.6228156089782715\n",
      "\txp 3, sample 94, train cost 5.51937198638916\n",
      "\txp 3, sample 95, train cost 5.630764961242676\n",
      "\txp 3, sample 96, train cost 5.6288957595825195\n",
      "\txp 3, sample 97, train cost 5.679536819458008\n",
      "\txp 3, sample 98, train cost 5.795845031738281\n",
      "\txp 3, sample 99, train cost 5.4636993408203125\n",
      "Summary: xp 3:\n",
      "\t OPT 5.5,\n",
      "\tmean test cost tensor([6.0121, 5.5844, 5.5769, 5.5690])\n",
      "\tstd test cost tensor([0.4306, 0.0844, 0.0772, 0.0770])\n",
      "\txp 4, sample 0, train cost 6.605599880218506\n",
      "\txp 4, sample 1, train cost 6.63261079788208\n",
      "\txp 4, sample 2, train cost 6.78063440322876\n",
      "\txp 4, sample 3, train cost 6.696158409118652\n",
      "\txp 4, sample 4, train cost 6.647594451904297\n",
      "\txp 4, sample 5, train cost 6.428329944610596\n",
      "\txp 4, sample 6, train cost 6.772439956665039\n",
      "\txp 4, sample 7, train cost 6.811042308807373\n",
      "\txp 4, sample 8, train cost 6.728359222412109\n",
      "\txp 4, sample 9, train cost 6.67077112197876\n",
      "\txp 4, sample 10, train cost 6.793877124786377\n",
      "\txp 4, sample 11, train cost 6.69081974029541\n",
      "\txp 4, sample 12, train cost 6.632083415985107\n",
      "\txp 4, sample 13, train cost 6.662085056304932\n",
      "\txp 4, sample 14, train cost 6.562244415283203\n",
      "\txp 4, sample 15, train cost 6.780107021331787\n",
      "\txp 4, sample 16, train cost 6.538976669311523\n",
      "\txp 4, sample 17, train cost 6.586134433746338\n",
      "\txp 4, sample 18, train cost 6.557544708251953\n",
      "\txp 4, sample 19, train cost 6.619550704956055\n",
      "\txp 4, sample 20, train cost 6.585501670837402\n",
      "\txp 4, sample 21, train cost 6.583285808563232\n",
      "\txp 4, sample 22, train cost 6.625277996063232\n",
      "\txp 4, sample 23, train cost 6.868092060089111\n",
      "\txp 4, sample 24, train cost 6.844485759735107\n",
      "\txp 4, sample 25, train cost 6.815428256988525\n",
      "\txp 4, sample 26, train cost 6.844001770019531\n",
      "\txp 4, sample 27, train cost 6.635706424713135\n",
      "\txp 4, sample 28, train cost 6.751334190368652\n",
      "\txp 4, sample 29, train cost 6.773834228515625\n",
      "\txp 4, sample 30, train cost 6.689503192901611\n",
      "\txp 4, sample 31, train cost 6.781853675842285\n",
      "\txp 4, sample 32, train cost 6.733249187469482\n",
      "\txp 4, sample 33, train cost 6.778007984161377\n",
      "\txp 4, sample 34, train cost 6.742303848266602\n",
      "\txp 4, sample 35, train cost 6.611536026000977\n",
      "\txp 4, sample 36, train cost 6.76486349105835\n",
      "\txp 4, sample 37, train cost 6.721218109130859\n",
      "\txp 4, sample 38, train cost 6.894916534423828\n",
      "\txp 4, sample 39, train cost 6.925051689147949\n",
      "\txp 4, sample 40, train cost 6.79184627532959\n",
      "\txp 4, sample 41, train cost 6.762465000152588\n",
      "\txp 4, sample 42, train cost 6.760764122009277\n",
      "\txp 4, sample 43, train cost 6.73778772354126\n",
      "\txp 4, sample 44, train cost 6.51108455657959\n",
      "\txp 4, sample 45, train cost 6.548005104064941\n",
      "\txp 4, sample 46, train cost 6.6388163566589355\n",
      "\txp 4, sample 47, train cost 6.491621971130371\n",
      "\txp 4, sample 48, train cost 6.680338382720947\n",
      "\txp 4, sample 49, train cost 6.524821758270264\n",
      "\txp 4, sample 50, train cost 6.5983500480651855\n",
      "\txp 4, sample 51, train cost 6.826811790466309\n",
      "\txp 4, sample 52, train cost 6.6728010177612305\n",
      "\txp 4, sample 53, train cost 6.722685813903809\n",
      "\txp 4, sample 54, train cost 6.5905537605285645\n",
      "\txp 4, sample 55, train cost 6.904786109924316\n",
      "\txp 4, sample 56, train cost 6.738917350769043\n",
      "\txp 4, sample 57, train cost 6.5921311378479\n",
      "\txp 4, sample 58, train cost 6.919857978820801\n",
      "\txp 4, sample 59, train cost 6.715808391571045\n",
      "\txp 4, sample 60, train cost 6.583942413330078\n",
      "\txp 4, sample 61, train cost 6.547979831695557\n",
      "\txp 4, sample 62, train cost 6.8489203453063965\n",
      "\txp 4, sample 63, train cost 6.743016242980957\n",
      "\txp 4, sample 64, train cost 6.547650337219238\n",
      "\txp 4, sample 65, train cost 6.688079833984375\n",
      "\txp 4, sample 66, train cost 6.675060749053955\n",
      "\txp 4, sample 67, train cost 6.644862651824951\n",
      "\txp 4, sample 68, train cost 6.625932693481445\n",
      "\txp 4, sample 69, train cost 6.759059429168701\n",
      "\txp 4, sample 70, train cost 6.572079658508301\n",
      "\txp 4, sample 71, train cost 6.712931156158447\n",
      "\txp 4, sample 72, train cost 6.700827121734619\n",
      "\txp 4, sample 73, train cost 6.8111982345581055\n",
      "\txp 4, sample 74, train cost 6.572263240814209\n",
      "\txp 4, sample 75, train cost 6.500882625579834\n",
      "\txp 4, sample 76, train cost 6.537680625915527\n",
      "\txp 4, sample 77, train cost 6.549060821533203\n",
      "\txp 4, sample 78, train cost 6.7571258544921875\n",
      "\txp 4, sample 79, train cost 6.606879711151123\n",
      "\txp 4, sample 80, train cost 6.769249439239502\n",
      "\txp 4, sample 81, train cost 6.661529541015625\n",
      "\txp 4, sample 82, train cost 6.769099235534668\n",
      "\txp 4, sample 83, train cost 6.703324794769287\n",
      "\txp 4, sample 84, train cost 6.553309917449951\n",
      "\txp 4, sample 85, train cost 6.755471706390381\n",
      "\txp 4, sample 86, train cost 6.674362659454346\n",
      "\txp 4, sample 87, train cost 6.574092388153076\n",
      "\txp 4, sample 88, train cost 6.694399356842041\n",
      "\txp 4, sample 89, train cost 6.621988296508789\n",
      "\txp 4, sample 90, train cost 6.783975601196289\n",
      "\txp 4, sample 91, train cost 6.764679908752441\n",
      "\txp 4, sample 92, train cost 6.644789695739746\n",
      "\txp 4, sample 93, train cost 6.9681782722473145\n",
      "\txp 4, sample 94, train cost 6.727925777435303\n",
      "\txp 4, sample 95, train cost 6.8642258644104\n",
      "\txp 4, sample 96, train cost 6.604138374328613\n",
      "\txp 4, sample 97, train cost 6.596665859222412\n",
      "\txp 4, sample 98, train cost 6.916785717010498\n",
      "\txp 4, sample 99, train cost 6.8460187911987305\n",
      "Summary: xp 4:\n",
      "\t OPT 6.56,\n",
      "\tmean test cost tensor([8.1188, 6.6108, 6.6198, 6.6186])\n",
      "\tstd test cost tensor([1.0323, 0.1127, 0.1093, 0.1187])\n",
      "\txp 5, sample 0, train cost 27.992036819458008\n",
      "\txp 5, sample 1, train cost 27.91299057006836\n",
      "\txp 5, sample 2, train cost 27.898303985595703\n",
      "\txp 5, sample 3, train cost 28.176284790039062\n",
      "\txp 5, sample 4, train cost 27.98384666442871\n",
      "\txp 5, sample 5, train cost 28.206228256225586\n",
      "\txp 5, sample 6, train cost 27.90818214416504\n",
      "\txp 5, sample 7, train cost 28.016387939453125\n",
      "\txp 5, sample 8, train cost 27.726890563964844\n",
      "\txp 5, sample 9, train cost 28.108478546142578\n",
      "\txp 5, sample 10, train cost 27.85221290588379\n",
      "\txp 5, sample 11, train cost 28.11635398864746\n",
      "\txp 5, sample 12, train cost 28.052696228027344\n",
      "\txp 5, sample 13, train cost 28.113771438598633\n",
      "\txp 5, sample 14, train cost 27.873178482055664\n",
      "\txp 5, sample 15, train cost 27.930509567260742\n",
      "\txp 5, sample 16, train cost 28.020994186401367\n",
      "\txp 5, sample 17, train cost 28.21982192993164\n",
      "\txp 5, sample 18, train cost 27.926416397094727\n",
      "\txp 5, sample 19, train cost 27.84052848815918\n",
      "\txp 5, sample 20, train cost 28.020877838134766\n",
      "\txp 5, sample 21, train cost 28.046165466308594\n",
      "\txp 5, sample 22, train cost 28.120162963867188\n",
      "\txp 5, sample 23, train cost 27.95711898803711\n",
      "\txp 5, sample 24, train cost 28.226543426513672\n",
      "\txp 5, sample 25, train cost 27.84941291809082\n",
      "\txp 5, sample 26, train cost 28.094205856323242\n",
      "\txp 5, sample 27, train cost 28.008987426757812\n",
      "\txp 5, sample 28, train cost 27.974559783935547\n",
      "\txp 5, sample 29, train cost 28.07171630859375\n",
      "\txp 5, sample 30, train cost 28.281496047973633\n",
      "\txp 5, sample 31, train cost 27.945884704589844\n",
      "\txp 5, sample 32, train cost 27.95380973815918\n",
      "\txp 5, sample 33, train cost 27.861108779907227\n",
      "\txp 5, sample 34, train cost 28.20209312438965\n",
      "\txp 5, sample 35, train cost 28.001605987548828\n",
      "\txp 5, sample 36, train cost 28.055469512939453\n",
      "\txp 5, sample 37, train cost 27.859909057617188\n",
      "\txp 5, sample 38, train cost 28.05391502380371\n",
      "\txp 5, sample 39, train cost 28.013402938842773\n",
      "\txp 5, sample 40, train cost 28.100875854492188\n",
      "\txp 5, sample 41, train cost 27.97823715209961\n",
      "\txp 5, sample 42, train cost 28.092588424682617\n",
      "\txp 5, sample 43, train cost 27.99632453918457\n",
      "\txp 5, sample 44, train cost 27.9433650970459\n",
      "\txp 5, sample 45, train cost 27.926319122314453\n",
      "\txp 5, sample 46, train cost 28.03499984741211\n",
      "\txp 5, sample 47, train cost 27.92597770690918\n",
      "\txp 5, sample 48, train cost 27.97136878967285\n",
      "\txp 5, sample 49, train cost 27.99139976501465\n",
      "\txp 5, sample 50, train cost 28.0374813079834\n",
      "\txp 5, sample 51, train cost 28.204627990722656\n",
      "\txp 5, sample 52, train cost 27.8066349029541\n",
      "\txp 5, sample 53, train cost 28.14824676513672\n",
      "\txp 5, sample 54, train cost 28.011762619018555\n",
      "\txp 5, sample 55, train cost 28.25568389892578\n",
      "\txp 5, sample 56, train cost 27.97810935974121\n",
      "\txp 5, sample 57, train cost 28.02288055419922\n",
      "\txp 5, sample 58, train cost 27.996999740600586\n",
      "\txp 5, sample 59, train cost 28.040985107421875\n",
      "\txp 5, sample 60, train cost 28.030946731567383\n",
      "\txp 5, sample 61, train cost 27.96333122253418\n",
      "\txp 5, sample 62, train cost 28.19881248474121\n",
      "\txp 5, sample 63, train cost 27.956743240356445\n",
      "\txp 5, sample 64, train cost 28.039175033569336\n",
      "\txp 5, sample 65, train cost 27.911291122436523\n",
      "\txp 5, sample 66, train cost 27.95749282836914\n",
      "\txp 5, sample 67, train cost 27.80396270751953\n",
      "\txp 5, sample 68, train cost 28.025962829589844\n",
      "\txp 5, sample 69, train cost 28.113061904907227\n",
      "\txp 5, sample 70, train cost 27.92801856994629\n",
      "\txp 5, sample 71, train cost 27.857955932617188\n",
      "\txp 5, sample 72, train cost 28.184406280517578\n",
      "\txp 5, sample 73, train cost 27.989730834960938\n",
      "\txp 5, sample 74, train cost 27.91870880126953\n",
      "\txp 5, sample 75, train cost 27.974056243896484\n",
      "\txp 5, sample 76, train cost 28.08942413330078\n",
      "\txp 5, sample 77, train cost 27.91483497619629\n",
      "\txp 5, sample 78, train cost 28.222774505615234\n",
      "\txp 5, sample 79, train cost 27.775146484375\n",
      "\txp 5, sample 80, train cost 27.99925994873047\n",
      "\txp 5, sample 81, train cost 28.178462982177734\n",
      "\txp 5, sample 82, train cost 27.908321380615234\n",
      "\txp 5, sample 83, train cost 28.02399444580078\n",
      "\txp 5, sample 84, train cost 28.124340057373047\n",
      "\txp 5, sample 85, train cost 28.024850845336914\n",
      "\txp 5, sample 86, train cost 28.18758773803711\n",
      "\txp 5, sample 87, train cost 28.00628662109375\n",
      "\txp 5, sample 88, train cost 27.931636810302734\n",
      "\txp 5, sample 89, train cost 28.314077377319336\n",
      "\txp 5, sample 90, train cost 27.947725296020508\n",
      "\txp 5, sample 91, train cost 27.9996337890625\n",
      "\txp 5, sample 92, train cost 27.762277603149414\n",
      "\txp 5, sample 93, train cost 27.943584442138672\n",
      "\txp 5, sample 94, train cost 27.886140823364258\n",
      "\txp 5, sample 95, train cost 27.998971939086914\n",
      "\txp 5, sample 96, train cost 28.250965118408203\n",
      "\txp 5, sample 97, train cost 27.919986724853516\n",
      "\txp 5, sample 98, train cost 28.03025245666504\n",
      "\txp 5, sample 99, train cost 27.71029281616211\n",
      "Summary: xp 5:\n",
      "\t OPT 28.01,\n",
      "\tmean test cost tensor([28.1582, 28.0288, 28.0336, 27.9926])\n",
      "\tstd test cost tensor([0.1816, 0.1262, 0.1179, 0.1264])\n",
      "\txp 6, sample 0, train cost 28.127025604248047\n",
      "\txp 6, sample 1, train cost 28.086750030517578\n",
      "\txp 6, sample 2, train cost 28.135297775268555\n",
      "\txp 6, sample 3, train cost 28.177274703979492\n",
      "\txp 6, sample 4, train cost 28.020105361938477\n",
      "\txp 6, sample 5, train cost 28.14811897277832\n",
      "\txp 6, sample 6, train cost 28.134387969970703\n",
      "\txp 6, sample 7, train cost 28.06532859802246\n",
      "\txp 6, sample 8, train cost 28.109193801879883\n",
      "\txp 6, sample 9, train cost 28.088130950927734\n",
      "\txp 6, sample 10, train cost 28.020912170410156\n",
      "\txp 6, sample 11, train cost 28.078250885009766\n",
      "\txp 6, sample 12, train cost 27.974838256835938\n",
      "\txp 6, sample 13, train cost 28.05531883239746\n",
      "\txp 6, sample 14, train cost 27.944656372070312\n",
      "\txp 6, sample 15, train cost 28.136014938354492\n",
      "\txp 6, sample 16, train cost 28.28790283203125\n",
      "\txp 6, sample 17, train cost 28.000532150268555\n",
      "\txp 6, sample 18, train cost 27.892478942871094\n",
      "\txp 6, sample 19, train cost 27.97237205505371\n",
      "\txp 6, sample 20, train cost 27.999305725097656\n",
      "\txp 6, sample 21, train cost 27.886850357055664\n",
      "\txp 6, sample 22, train cost 28.04273796081543\n",
      "\txp 6, sample 23, train cost 28.078140258789062\n",
      "\txp 6, sample 24, train cost 28.119853973388672\n",
      "\txp 6, sample 25, train cost 28.266624450683594\n",
      "\txp 6, sample 26, train cost 27.94875717163086\n",
      "\txp 6, sample 27, train cost 28.20754623413086\n",
      "\txp 6, sample 28, train cost 28.008399963378906\n",
      "\txp 6, sample 29, train cost 27.84184455871582\n",
      "\txp 6, sample 30, train cost 28.067949295043945\n",
      "\txp 6, sample 31, train cost 27.859115600585938\n",
      "\txp 6, sample 32, train cost 28.02662467956543\n",
      "\txp 6, sample 33, train cost 27.9798526763916\n",
      "\txp 6, sample 34, train cost 27.837566375732422\n",
      "\txp 6, sample 35, train cost 28.09609031677246\n",
      "\txp 6, sample 36, train cost 27.99709129333496\n",
      "\txp 6, sample 37, train cost 27.874502182006836\n",
      "\txp 6, sample 38, train cost 28.026878356933594\n",
      "\txp 6, sample 39, train cost 28.016193389892578\n",
      "\txp 6, sample 40, train cost 27.819637298583984\n",
      "\txp 6, sample 41, train cost 28.069602966308594\n",
      "\txp 6, sample 42, train cost 28.118412017822266\n",
      "\txp 6, sample 43, train cost 28.221250534057617\n",
      "\txp 6, sample 44, train cost 28.07417869567871\n",
      "\txp 6, sample 45, train cost 28.06795883178711\n",
      "\txp 6, sample 46, train cost 27.91452407836914\n",
      "\txp 6, sample 47, train cost 28.050899505615234\n",
      "\txp 6, sample 48, train cost 28.056753158569336\n",
      "\txp 6, sample 49, train cost 28.271587371826172\n",
      "\txp 6, sample 50, train cost 27.90159034729004\n",
      "\txp 6, sample 51, train cost 28.05451202392578\n",
      "\txp 6, sample 52, train cost 28.059955596923828\n",
      "\txp 6, sample 53, train cost 27.881084442138672\n",
      "\txp 6, sample 54, train cost 28.032817840576172\n",
      "\txp 6, sample 55, train cost 27.971418380737305\n",
      "\txp 6, sample 56, train cost 28.181732177734375\n",
      "\txp 6, sample 57, train cost 28.123693466186523\n",
      "\txp 6, sample 58, train cost 27.888235092163086\n",
      "\txp 6, sample 59, train cost 28.033775329589844\n",
      "\txp 6, sample 60, train cost 28.074403762817383\n",
      "\txp 6, sample 61, train cost 27.970956802368164\n",
      "\txp 6, sample 62, train cost 27.846893310546875\n",
      "\txp 6, sample 63, train cost 28.07930564880371\n",
      "\txp 6, sample 64, train cost 28.303796768188477\n",
      "\txp 6, sample 65, train cost 28.00191879272461\n",
      "\txp 6, sample 66, train cost 28.1286563873291\n",
      "\txp 6, sample 67, train cost 28.07720375061035\n",
      "\txp 6, sample 68, train cost 28.00105094909668\n",
      "\txp 6, sample 69, train cost 28.046981811523438\n",
      "\txp 6, sample 70, train cost 28.126934051513672\n",
      "\txp 6, sample 71, train cost 28.193824768066406\n",
      "\txp 6, sample 72, train cost 28.068761825561523\n",
      "\txp 6, sample 73, train cost 28.112812042236328\n",
      "\txp 6, sample 74, train cost 28.067359924316406\n",
      "\txp 6, sample 75, train cost 28.058671951293945\n",
      "\txp 6, sample 76, train cost 27.954877853393555\n",
      "\txp 6, sample 77, train cost 28.07689094543457\n",
      "\txp 6, sample 78, train cost 28.058286666870117\n",
      "\txp 6, sample 79, train cost 28.02167510986328\n",
      "\txp 6, sample 80, train cost 28.083269119262695\n",
      "\txp 6, sample 81, train cost 28.042112350463867\n",
      "\txp 6, sample 82, train cost 27.967100143432617\n",
      "\txp 6, sample 83, train cost 27.896650314331055\n",
      "\txp 6, sample 84, train cost 28.05281639099121\n",
      "\txp 6, sample 85, train cost 27.96994400024414\n",
      "\txp 6, sample 86, train cost 28.16451644897461\n",
      "\txp 6, sample 87, train cost 27.795499801635742\n",
      "\txp 6, sample 88, train cost 27.87209129333496\n",
      "\txp 6, sample 89, train cost 28.000709533691406\n",
      "\txp 6, sample 90, train cost 27.77817153930664\n",
      "\txp 6, sample 91, train cost 27.953006744384766\n",
      "\txp 6, sample 92, train cost 27.91258430480957\n",
      "\txp 6, sample 93, train cost 27.907817840576172\n",
      "\txp 6, sample 94, train cost 27.973878860473633\n",
      "\txp 6, sample 95, train cost 27.806869506835938\n",
      "\txp 6, sample 96, train cost 28.06757164001465\n",
      "\txp 6, sample 97, train cost 27.768787384033203\n",
      "\txp 6, sample 98, train cost 28.121299743652344\n",
      "\txp 6, sample 99, train cost 28.161909103393555\n",
      "Summary: xp 6:\n",
      "\t OPT 28.02,\n",
      "\tmean test cost tensor([28.1752, 28.0496, 28.0377, 28.0195])\n",
      "\tstd test cost tensor([0.1860, 0.1192, 0.1206, 0.1342])\n",
      "\txp 7, sample 0, train cost 28.03725242614746\n",
      "\txp 7, sample 1, train cost 28.215322494506836\n",
      "\txp 7, sample 2, train cost 27.982234954833984\n",
      "\txp 7, sample 3, train cost 28.247360229492188\n",
      "\txp 7, sample 4, train cost 28.076677322387695\n",
      "\txp 7, sample 5, train cost 27.917009353637695\n",
      "\txp 7, sample 6, train cost 28.178993225097656\n",
      "\txp 7, sample 7, train cost 28.03508186340332\n",
      "\txp 7, sample 8, train cost 27.819902420043945\n",
      "\txp 7, sample 9, train cost 28.002819061279297\n",
      "\txp 7, sample 10, train cost 28.0248966217041\n",
      "\txp 7, sample 11, train cost 28.058443069458008\n",
      "\txp 7, sample 12, train cost 27.763050079345703\n",
      "\txp 7, sample 13, train cost 28.107616424560547\n",
      "\txp 7, sample 14, train cost 27.95416831970215\n",
      "\txp 7, sample 15, train cost 28.080116271972656\n",
      "\txp 7, sample 16, train cost 28.139307022094727\n",
      "\txp 7, sample 17, train cost 28.06610870361328\n",
      "\txp 7, sample 18, train cost 27.878381729125977\n",
      "\txp 7, sample 19, train cost 28.185409545898438\n",
      "\txp 7, sample 20, train cost 28.011531829833984\n",
      "\txp 7, sample 21, train cost 28.110387802124023\n",
      "\txp 7, sample 22, train cost 28.063940048217773\n",
      "\txp 7, sample 23, train cost 28.216875076293945\n",
      "\txp 7, sample 24, train cost 27.921283721923828\n",
      "\txp 7, sample 25, train cost 28.145462036132812\n",
      "\txp 7, sample 26, train cost 28.0137996673584\n",
      "\txp 7, sample 27, train cost 28.049694061279297\n",
      "\txp 7, sample 28, train cost 28.23967742919922\n",
      "\txp 7, sample 29, train cost 28.22003746032715\n",
      "\txp 7, sample 30, train cost 27.907543182373047\n",
      "\txp 7, sample 31, train cost 28.08702278137207\n",
      "\txp 7, sample 32, train cost 27.945322036743164\n",
      "\txp 7, sample 33, train cost 28.13360023498535\n",
      "\txp 7, sample 34, train cost 27.92583656311035\n",
      "\txp 7, sample 35, train cost 27.93776512145996\n",
      "\txp 7, sample 36, train cost 28.02854347229004\n",
      "\txp 7, sample 37, train cost 27.900522232055664\n",
      "\txp 7, sample 38, train cost 28.105934143066406\n",
      "\txp 7, sample 39, train cost 28.090803146362305\n",
      "\txp 7, sample 40, train cost 28.09564781188965\n",
      "\txp 7, sample 41, train cost 27.884437561035156\n",
      "\txp 7, sample 42, train cost 28.074806213378906\n",
      "\txp 7, sample 43, train cost 27.888887405395508\n",
      "\txp 7, sample 44, train cost 28.0065975189209\n",
      "\txp 7, sample 45, train cost 28.34302520751953\n",
      "\txp 7, sample 46, train cost 28.116296768188477\n",
      "\txp 7, sample 47, train cost 28.56133460998535\n",
      "\txp 7, sample 48, train cost 28.0521183013916\n",
      "\txp 7, sample 49, train cost 27.9373722076416\n",
      "\txp 7, sample 50, train cost 27.92142105102539\n",
      "\txp 7, sample 51, train cost 27.90033721923828\n",
      "\txp 7, sample 52, train cost 28.07876205444336\n",
      "\txp 7, sample 53, train cost 27.897306442260742\n",
      "\txp 7, sample 54, train cost 28.060199737548828\n",
      "\txp 7, sample 55, train cost 28.028963088989258\n",
      "\txp 7, sample 56, train cost 28.212505340576172\n",
      "\txp 7, sample 57, train cost 28.066896438598633\n",
      "\txp 7, sample 58, train cost 28.065143585205078\n",
      "\txp 7, sample 59, train cost 27.857505798339844\n",
      "\txp 7, sample 60, train cost 28.067312240600586\n",
      "\txp 7, sample 61, train cost 28.071849822998047\n",
      "\txp 7, sample 62, train cost 27.95956802368164\n",
      "\txp 7, sample 63, train cost 28.002599716186523\n",
      "\txp 7, sample 64, train cost 28.11518096923828\n",
      "\txp 7, sample 65, train cost 28.09769058227539\n",
      "\txp 7, sample 66, train cost 28.011005401611328\n",
      "\txp 7, sample 67, train cost 28.28485870361328\n",
      "\txp 7, sample 68, train cost 28.093740463256836\n",
      "\txp 7, sample 69, train cost 28.0157470703125\n",
      "\txp 7, sample 70, train cost 28.237306594848633\n",
      "\txp 7, sample 71, train cost 27.93943977355957\n",
      "\txp 7, sample 72, train cost 27.936674118041992\n",
      "\txp 7, sample 73, train cost 28.106060028076172\n",
      "\txp 7, sample 74, train cost 28.211931228637695\n",
      "\txp 7, sample 75, train cost 27.91279411315918\n",
      "\txp 7, sample 76, train cost 28.01935577392578\n",
      "\txp 7, sample 77, train cost 28.237102508544922\n",
      "\txp 7, sample 78, train cost 28.15294075012207\n",
      "\txp 7, sample 79, train cost 28.400741577148438\n",
      "\txp 7, sample 80, train cost 28.000234603881836\n",
      "\txp 7, sample 81, train cost 28.12600326538086\n",
      "\txp 7, sample 82, train cost 28.193744659423828\n",
      "\txp 7, sample 83, train cost 28.138402938842773\n",
      "\txp 7, sample 84, train cost 27.945920944213867\n",
      "\txp 7, sample 85, train cost 28.000581741333008\n",
      "\txp 7, sample 86, train cost 28.034719467163086\n",
      "\txp 7, sample 87, train cost 28.0526180267334\n",
      "\txp 7, sample 88, train cost 27.938077926635742\n",
      "\txp 7, sample 89, train cost 28.21762466430664\n",
      "\txp 7, sample 90, train cost 27.989089965820312\n",
      "\txp 7, sample 91, train cost 27.85578727722168\n",
      "\txp 7, sample 92, train cost 28.107559204101562\n",
      "\txp 7, sample 93, train cost 28.089805603027344\n",
      "\txp 7, sample 94, train cost 28.064353942871094\n",
      "\txp 7, sample 95, train cost 28.199508666992188\n",
      "\txp 7, sample 96, train cost 27.962705612182617\n",
      "\txp 7, sample 97, train cost 27.919837951660156\n",
      "\txp 7, sample 98, train cost 28.105384826660156\n",
      "\txp 7, sample 99, train cost 28.010940551757812\n",
      "Summary: xp 7:\n",
      "\t OPT 28.03,\n",
      "\tmean test cost tensor([28.1608, 28.0426, 28.0226, 28.0392])\n",
      "\tstd test cost tensor([0.1626, 0.1225, 0.1523, 0.1199])\n",
      "\txp 8, sample 0, train cost 30.47480583190918\n",
      "\txp 8, sample 1, train cost 29.937515258789062\n",
      "\txp 8, sample 2, train cost 30.23849105834961\n",
      "\txp 8, sample 3, train cost 30.153518676757812\n",
      "\txp 8, sample 4, train cost 30.476537704467773\n",
      "\txp 8, sample 5, train cost 30.160518646240234\n",
      "\txp 8, sample 6, train cost 30.0350341796875\n",
      "\txp 8, sample 7, train cost 30.2742977142334\n",
      "\txp 8, sample 8, train cost 30.357643127441406\n",
      "\txp 8, sample 9, train cost 30.164386749267578\n",
      "\txp 8, sample 10, train cost 30.383262634277344\n",
      "\txp 8, sample 11, train cost 30.571928024291992\n",
      "\txp 8, sample 12, train cost 30.309175491333008\n",
      "\txp 8, sample 13, train cost 30.488752365112305\n",
      "\txp 8, sample 14, train cost 30.381174087524414\n",
      "\txp 8, sample 15, train cost 30.18654441833496\n",
      "\txp 8, sample 16, train cost 30.178556442260742\n",
      "\txp 8, sample 17, train cost 30.409971237182617\n",
      "\txp 8, sample 18, train cost 30.286975860595703\n",
      "\txp 8, sample 19, train cost 30.120803833007812\n",
      "\txp 8, sample 20, train cost 30.304231643676758\n",
      "\txp 8, sample 21, train cost 30.394432067871094\n",
      "\txp 8, sample 22, train cost 30.441375732421875\n",
      "\txp 8, sample 23, train cost 30.367374420166016\n",
      "\txp 8, sample 24, train cost 30.522109985351562\n",
      "\txp 8, sample 25, train cost 30.180025100708008\n",
      "\txp 8, sample 26, train cost 30.271299362182617\n",
      "\txp 8, sample 27, train cost 30.508440017700195\n",
      "\txp 8, sample 28, train cost 30.174108505249023\n",
      "\txp 8, sample 29, train cost 29.85761260986328\n",
      "\txp 8, sample 30, train cost 30.416318893432617\n",
      "\txp 8, sample 31, train cost 30.479686737060547\n",
      "\txp 8, sample 32, train cost 30.151409149169922\n",
      "\txp 8, sample 33, train cost 30.259016036987305\n",
      "\txp 8, sample 34, train cost 30.434146881103516\n",
      "\txp 8, sample 35, train cost 30.060943603515625\n",
      "\txp 8, sample 36, train cost 30.409059524536133\n",
      "\txp 8, sample 37, train cost 30.24393081665039\n",
      "\txp 8, sample 38, train cost 30.347890853881836\n",
      "\txp 8, sample 39, train cost 30.387290954589844\n",
      "\txp 8, sample 40, train cost 30.283246994018555\n",
      "\txp 8, sample 41, train cost 30.447546005249023\n",
      "\txp 8, sample 42, train cost 30.288650512695312\n",
      "\txp 8, sample 43, train cost 30.382049560546875\n",
      "\txp 8, sample 44, train cost 30.435577392578125\n",
      "\txp 8, sample 45, train cost 30.286380767822266\n",
      "\txp 8, sample 46, train cost 30.388952255249023\n",
      "\txp 8, sample 47, train cost 30.077577590942383\n",
      "\txp 8, sample 48, train cost 29.963878631591797\n",
      "\txp 8, sample 49, train cost 30.226953506469727\n",
      "\txp 8, sample 50, train cost 30.16362762451172\n",
      "\txp 8, sample 51, train cost 30.061349868774414\n",
      "\txp 8, sample 52, train cost 30.45785903930664\n",
      "\txp 8, sample 53, train cost 30.1444034576416\n",
      "\txp 8, sample 54, train cost 30.54085350036621\n",
      "\txp 8, sample 55, train cost 30.331369400024414\n",
      "\txp 8, sample 56, train cost 30.48687171936035\n",
      "\txp 8, sample 57, train cost 30.223125457763672\n",
      "\txp 8, sample 58, train cost 30.30164909362793\n",
      "\txp 8, sample 59, train cost 30.462636947631836\n",
      "\txp 8, sample 60, train cost 30.311172485351562\n",
      "\txp 8, sample 61, train cost 30.32457733154297\n",
      "\txp 8, sample 62, train cost 30.073347091674805\n",
      "\txp 8, sample 63, train cost 30.086849212646484\n",
      "\txp 8, sample 64, train cost 30.358409881591797\n",
      "\txp 8, sample 65, train cost 30.350324630737305\n",
      "\txp 8, sample 66, train cost 30.511150360107422\n",
      "\txp 8, sample 67, train cost 30.112468719482422\n",
      "\txp 8, sample 68, train cost 30.510799407958984\n",
      "\txp 8, sample 69, train cost 30.348154067993164\n",
      "\txp 8, sample 70, train cost 30.548934936523438\n",
      "\txp 8, sample 71, train cost 30.470888137817383\n",
      "\txp 8, sample 72, train cost 30.388818740844727\n",
      "\txp 8, sample 73, train cost 30.368030548095703\n",
      "\txp 8, sample 74, train cost 30.071483612060547\n",
      "\txp 8, sample 75, train cost 30.246749877929688\n",
      "\txp 8, sample 76, train cost 30.186725616455078\n",
      "\txp 8, sample 77, train cost 30.409568786621094\n",
      "\txp 8, sample 78, train cost 30.451156616210938\n",
      "\txp 8, sample 79, train cost 30.492231369018555\n",
      "\txp 8, sample 80, train cost 30.387197494506836\n",
      "\txp 8, sample 81, train cost 30.409290313720703\n",
      "\txp 8, sample 82, train cost 30.262409210205078\n",
      "\txp 8, sample 83, train cost 30.465988159179688\n",
      "\txp 8, sample 84, train cost 30.328903198242188\n",
      "\txp 8, sample 85, train cost 30.334562301635742\n",
      "\txp 8, sample 86, train cost 30.43209457397461\n",
      "\txp 8, sample 87, train cost 30.374753952026367\n",
      "\txp 8, sample 88, train cost 30.16373062133789\n",
      "\txp 8, sample 89, train cost 30.487693786621094\n",
      "\txp 8, sample 90, train cost 30.29444122314453\n",
      "\txp 8, sample 91, train cost 30.18169403076172\n",
      "\txp 8, sample 92, train cost 30.385971069335938\n",
      "\txp 8, sample 93, train cost 30.584056854248047\n",
      "\txp 8, sample 94, train cost 30.231849670410156\n",
      "\txp 8, sample 95, train cost 30.19573974609375\n",
      "\txp 8, sample 96, train cost 30.175312042236328\n",
      "\txp 8, sample 97, train cost 30.25800895690918\n",
      "\txp 8, sample 98, train cost 30.397356033325195\n",
      "\txp 8, sample 99, train cost 30.450105667114258\n",
      "Summary: xp 8:\n",
      "\t OPT 30.26,\n",
      "\tmean test cost tensor([30.7946, 30.2987, 30.3004, 30.2951])\n",
      "\tstd test cost tensor([0.4192, 0.1467, 0.1369, 0.1499])\n",
      "\txp 9, sample 0, train cost 31.764015197753906\n",
      "\txp 9, sample 1, train cost 31.652862548828125\n",
      "\txp 9, sample 2, train cost 31.62887191772461\n",
      "\txp 9, sample 3, train cost 31.752290725708008\n",
      "\txp 9, sample 4, train cost 32.21672058105469\n",
      "\txp 9, sample 5, train cost 31.634868621826172\n",
      "\txp 9, sample 6, train cost 31.389699935913086\n",
      "\txp 9, sample 7, train cost 31.941028594970703\n",
      "\txp 9, sample 8, train cost 31.424449920654297\n",
      "\txp 9, sample 9, train cost 31.254072189331055\n",
      "\txp 9, sample 10, train cost 31.70924949645996\n",
      "\txp 9, sample 11, train cost 31.694211959838867\n",
      "\txp 9, sample 12, train cost 31.810619354248047\n",
      "\txp 9, sample 13, train cost 31.739486694335938\n",
      "\txp 9, sample 14, train cost 31.84296226501465\n",
      "\txp 9, sample 15, train cost 31.962039947509766\n",
      "\txp 9, sample 16, train cost 31.550683975219727\n",
      "\txp 9, sample 17, train cost 31.663911819458008\n",
      "\txp 9, sample 18, train cost 31.530864715576172\n",
      "\txp 9, sample 19, train cost 31.856393814086914\n",
      "\txp 9, sample 20, train cost 31.912593841552734\n",
      "\txp 9, sample 21, train cost 31.731599807739258\n",
      "\txp 9, sample 22, train cost 31.732362747192383\n",
      "\txp 9, sample 23, train cost 31.939266204833984\n",
      "\txp 9, sample 24, train cost 31.650222778320312\n",
      "\txp 9, sample 25, train cost 31.830228805541992\n",
      "\txp 9, sample 26, train cost 31.748355865478516\n",
      "\txp 9, sample 27, train cost 31.397550582885742\n",
      "\txp 9, sample 28, train cost 31.509614944458008\n",
      "\txp 9, sample 29, train cost 31.880809783935547\n",
      "\txp 9, sample 30, train cost 31.807540893554688\n",
      "\txp 9, sample 31, train cost 31.57133674621582\n",
      "\txp 9, sample 32, train cost 31.797475814819336\n",
      "\txp 9, sample 33, train cost 31.98821258544922\n",
      "\txp 9, sample 34, train cost 31.7653751373291\n",
      "\txp 9, sample 35, train cost 31.632591247558594\n",
      "\txp 9, sample 36, train cost 31.893924713134766\n",
      "\txp 9, sample 37, train cost 31.48477554321289\n",
      "\txp 9, sample 38, train cost 31.633939743041992\n",
      "\txp 9, sample 39, train cost 31.640396118164062\n",
      "\txp 9, sample 40, train cost 31.52299690246582\n",
      "\txp 9, sample 41, train cost 31.266878128051758\n",
      "\txp 9, sample 42, train cost 31.46380043029785\n",
      "\txp 9, sample 43, train cost 31.78372573852539\n",
      "\txp 9, sample 44, train cost 31.510303497314453\n",
      "\txp 9, sample 45, train cost 31.685344696044922\n",
      "\txp 9, sample 46, train cost 31.678184509277344\n",
      "\txp 9, sample 47, train cost 31.795162200927734\n",
      "\txp 9, sample 48, train cost 31.677133560180664\n",
      "\txp 9, sample 49, train cost 31.645771026611328\n",
      "\txp 9, sample 50, train cost 31.463781356811523\n",
      "\txp 9, sample 51, train cost 31.8375186920166\n",
      "\txp 9, sample 52, train cost 31.897111892700195\n",
      "\txp 9, sample 53, train cost 31.835927963256836\n",
      "\txp 9, sample 54, train cost 31.53220558166504\n",
      "\txp 9, sample 55, train cost 31.8237247467041\n",
      "\txp 9, sample 56, train cost 31.921306610107422\n",
      "\txp 9, sample 57, train cost 31.69053840637207\n",
      "\txp 9, sample 58, train cost 31.43558120727539\n",
      "\txp 9, sample 59, train cost 31.782302856445312\n",
      "\txp 9, sample 60, train cost 31.641536712646484\n",
      "\txp 9, sample 61, train cost 31.870080947875977\n",
      "\txp 9, sample 62, train cost 31.99696159362793\n",
      "\txp 9, sample 63, train cost 31.42494773864746\n",
      "\txp 9, sample 64, train cost 31.88541603088379\n",
      "\txp 9, sample 65, train cost 31.579784393310547\n",
      "\txp 9, sample 66, train cost 31.8543758392334\n",
      "\txp 9, sample 67, train cost 31.774690628051758\n",
      "\txp 9, sample 68, train cost 31.81679916381836\n",
      "\txp 9, sample 69, train cost 31.71809959411621\n",
      "\txp 9, sample 70, train cost 31.641521453857422\n",
      "\txp 9, sample 71, train cost 31.736621856689453\n",
      "\txp 9, sample 72, train cost 31.898418426513672\n",
      "\txp 9, sample 73, train cost 31.629352569580078\n",
      "\txp 9, sample 74, train cost 31.664384841918945\n",
      "\txp 9, sample 75, train cost 31.721240997314453\n",
      "\txp 9, sample 76, train cost 31.581939697265625\n",
      "\txp 9, sample 77, train cost 31.723644256591797\n",
      "\txp 9, sample 78, train cost 31.967247009277344\n",
      "\txp 9, sample 79, train cost 31.794157028198242\n",
      "\txp 9, sample 80, train cost 32.10710525512695\n",
      "\txp 9, sample 81, train cost 31.609130859375\n",
      "\txp 9, sample 82, train cost 32.02919006347656\n",
      "\txp 9, sample 83, train cost 31.683862686157227\n",
      "\txp 9, sample 84, train cost 31.521915435791016\n",
      "\txp 9, sample 85, train cost 31.761850357055664\n",
      "\txp 9, sample 86, train cost 31.775524139404297\n",
      "\txp 9, sample 87, train cost 31.706830978393555\n",
      "\txp 9, sample 88, train cost 31.61959457397461\n",
      "\txp 9, sample 89, train cost 31.766286849975586\n",
      "\txp 9, sample 90, train cost 31.571781158447266\n",
      "\txp 9, sample 91, train cost 31.494483947753906\n",
      "\txp 9, sample 92, train cost 31.830842971801758\n",
      "\txp 9, sample 93, train cost 31.78603172302246\n",
      "\txp 9, sample 94, train cost 31.834543228149414\n",
      "\txp 9, sample 95, train cost 31.59930992126465\n",
      "\txp 9, sample 96, train cost 32.072017669677734\n",
      "\txp 9, sample 97, train cost 31.687063217163086\n",
      "\txp 9, sample 98, train cost 31.585119247436523\n",
      "\txp 9, sample 99, train cost 31.64580535888672\n",
      "Summary: xp 9:\n",
      "\t OPT 31.57,\n",
      "\tmean test cost tensor([33.1213, 31.6527, 31.6439, 31.6348])\n",
      "\tstd test cost tensor([0.9268, 0.1567, 0.1697, 0.1785])\n"
     ]
    }
   ],
   "source": [
    "OPTs = [4.16, 4.23, 4.28, 5.50, 6.56, 28.01, 28.02, 28.03, 30.26, 31.57]\n",
    "GAP_S = [0.08, 0.06, 0.03, 0.28, 0.48, 0.00, 0.00, 0.00, 0.00, 0.01]\n",
    "\n",
    "purchase_costs = torch.cat([0.0*torch.ones(5,T), 5.0*torch.ones(5,T)])\n",
    "holding_costs = 1.0*torch.ones(NB_XP, T)\n",
    "selling_prices = 0.0*torch.ones(NB_XP, T)\n",
    "outdating_costs = torch.cat([3.0*torch.ones(1,T), 6.0*torch.ones(1,T), 8.0*torch.ones(3,T), 3.0*torch.ones(1,T), 6.0*torch.ones(1,T), 8.0*torch.ones(3,T)])\n",
    "penalty_costs = torch.cat([8.0*torch.ones(3,T), 20.0*torch.ones(1,T), 40.0*torch.ones(1,T), 8.0*torch.ones(3,T), 20.0*torch.ones(1,T), 40.0*torch.ones(1,T)])\n",
    "\n",
    "for xp_idx in range(NB_XP) :\n",
    "    simulate_and_get_plot_input(xp_idx, purchase_costs[xp_idx], holding_costs[xp_idx], selling_prices[xp_idx], outdating_costs[xp_idx], penalty_costs[xp_idx])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Mean costs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 4.3200,  4.2200,  4.2000,  4.1900],\n",
       "        [ 4.4100,  4.2700,  4.2700,  4.2600],\n",
       "        [ 4.4500,  4.3100,  4.3100,  4.3100],\n",
       "        [ 6.0100,  5.5800,  5.5800,  5.5700],\n",
       "        [ 8.1200,  6.6100,  6.6200,  6.6200],\n",
       "        [28.1600, 28.0300, 28.0300, 27.9900],\n",
       "        [28.1800, 28.0500, 28.0400, 28.0200],\n",
       "        [28.1600, 28.0400, 28.0200, 28.0400],\n",
       "        [30.7900, 30.3000, 30.3000, 30.3000],\n",
       "        [33.1200, 31.6500, 31.6400, 31.6300]])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_mean_costs.mean(dim=1).round(decimals=2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Standard deviation of costs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.1500, 0.0500, 0.0400, 0.0500],\n",
       "        [0.1600, 0.0500, 0.0500, 0.0400],\n",
       "        [0.1900, 0.0500, 0.0500, 0.0400],\n",
       "        [0.4300, 0.0800, 0.0800, 0.0800],\n",
       "        [1.0300, 0.1100, 0.1100, 0.1200],\n",
       "        [0.1800, 0.1300, 0.1200, 0.1300],\n",
       "        [0.1900, 0.1200, 0.1200, 0.1300],\n",
       "        [0.1600, 0.1200, 0.1500, 0.1200],\n",
       "        [0.4200, 0.1500, 0.1400, 0.1500],\n",
       "        [0.9300, 0.1600, 0.1700, 0.1800]])"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_mean_costs.std(dim=1).round(decimals=2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Relative optimality gap"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(1.2542)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "100*((test_mean_costs[:,:,-1].mean(dim=1)-torch.tensor(OPTs))/torch.tensor(OPTs)).max()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "inventory_policy_selection",
   "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
}
