{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "d256db9f-be41-4671-a7a4-ef80951a6b8c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n",
      "DEVICE cuda hi\n",
      "TRAINING 2-STAGE\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "from datetime import datetime as dt\n",
    "import pytz\n",
    "from pandas.tseries.holiday import USFederalHolidayCalendar\n",
    "\n",
    "try: import setGPU\n",
    "except ImportError: pass\n",
    "import warnings\n",
    "import torch\n",
    "\n",
    "import model_classes, nets\n",
    "from constants import *\n",
    "\n",
    "from model_classes import SolvePointQP\n",
    "\n",
    "from data import get_data, get_decision_mask, get_decision_mask_\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "warnings.simplefilter(\"ignore\")\n",
    "\n",
    "DEVICE = \"cpu\"\n",
    "if torch.cuda.is_available(): \n",
    "    DEVICE = \"cuda\"\n",
    "print(\"DEVICE\", DEVICE, \"hi\")\n",
    "\n",
    "X_train, Y_train, X_test, Y_test, X_train_pt, Y_train_pt, X_test_pt, Y_test_pt = get_data(DEVICE) \n",
    "variables = {'X_train_': X_train_pt, 'Y_train_': Y_train_pt, \n",
    "        'X_test_': X_test_pt, 'Y_test_': Y_test_pt}\n",
    "\n",
    "params = {\"n\": 24, \"c_ramp\": 0.4, \"gamma_under\": 50, \"gamma_over\": 0.5}\n",
    "\n",
    "mask = get_decision_mask(Y_train_pt, DEVICE)\n",
    "\n",
    "EPOCHS_rmse = 200\n",
    "\n",
    "print(\"TRAINING 2-STAGE\")\n",
    "model_rmse = model_classes.Net(X_train[:,:-1], Y_train, [200, 200]).to(DEVICE)\n",
    "model_rmse = nets.run_rmse_net(model_rmse, variables, X_train, Y_train, EPOCHS_rmse)\n",
    "model_rmse.eval()\n",
    "\n",
    "EPOCHS_e2e = 200"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "970d628e-52e4-45b0-889a-222e58a7fa9d",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TRAINING END-to-END\n",
      "epoch: 0   6.769690632820129\n",
      "epoch: 40   0.5236739993095398\n",
      "epoch: 80   0.5909971594810486\n",
      "epoch: 120   0.5611312359571456\n",
      "epoch: 160   0.40533834099769595\n",
      "epoch: 200   0.4636148244142532\n",
      "epoch: 240   0.4443850010633469\n",
      "epoch: 280   0.4066182315349579\n",
      "epoch: 320   0.3909959703683853\n",
      "epoch: 360   0.39957232475280763\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "Net(\n",
       "  (lin): Linear(in_features=149, out_features=24, bias=True)\n",
       "  (net): Sequential(\n",
       "    (0): Linear(in_features=149, out_features=200, bias=True)\n",
       "    (1): BatchNorm1d(200, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (2): ReLU()\n",
       "    (3): Dropout(p=0.2, inplace=False)\n",
       "    (4): Linear(in_features=200, out_features=200, bias=True)\n",
       "    (5): BatchNorm1d(200, eps=1e-05, momentum=0.1, affine=True, track_running_stats=True)\n",
       "    (6): ReLU()\n",
       "    (7): Dropout(p=0.2, inplace=False)\n",
       "    (8): Linear(in_features=200, out_features=24, bias=True)\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(\"TRAINING END-to-END\")\n",
    "end_to_end_net = nets.train_end_to_end(X_train[:,:-1], Y_train, variables, params, 400, DEVICE)\n",
    "end_to_end_net.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9ae740c5-8409-45e8-9478-1a1ab5dae7bb",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TRAIN P-MODEL\n",
      "epoch: 0   0.511872410774231\n",
      "epoch: 400   0.32661674737930296\n",
      "epoch: 800   0.30034556701779364\n",
      "epoch: 1200   0.2707848769426346\n",
      "epoch: 1600   0.24867946818470954\n",
      "epoch: 2800   0.1882987316697836\n",
      "epoch: 3200   0.16939189314842223\n",
      "epoch: 3600   0.1628490522503853\n"
     ]
    }
   ],
   "source": [
    "print(\"TRAIN P-MODEL\")\n",
    "p_net = nets.train_pnet(end_to_end_net, X_train_pt, Y_train_pt, params, 4000, DEVICE)\n",
    "p_net.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "2c279f7d-fbb1-4bec-b5bd-15372ca8ba5b",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TRAIN F-MODEL\n",
      "epoch: 0   0.007396284035516705\n",
      "epoch: 20   0.010016845452046255\n",
      "epoch: 40   0.007578555873478763\n",
      "epoch: 60   0.005226198412710801\n",
      "epoch: 80   0.01382506194000598\n",
      "epoch: 100   0.013783356429048581\n",
      "epoch: 120   0.005495912469632458\n",
      "epoch: 140   0.02018836655828636\n",
      "epoch: 160   0.016953749457607047\n",
      "epoch: 180   0.043102673412649894\n",
      "epoch: 200   0.017609268498927123\n",
      "epoch: 220   0.003214236273634015\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[73], line 3\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28mprint\u001b[39m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mTRAIN F-MODEL\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m      2\u001b[0m \u001b[38;5;66;03m# f_net = model_classes.FNet(X_train[:,:-1], Y_train, [200, 200]).to(DEVICE)\u001b[39;00m\n\u001b[0;32m----> 3\u001b[0m f_net \u001b[38;5;241m=\u001b[39m \u001b[43mnets\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtrain_fnet\u001b[49m\u001b[43m(\u001b[49m\u001b[43mf_net\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mp_net\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX_train\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43m:\u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mY_train\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mvariables\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mparams\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m2000\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mDEVICE\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      5\u001b[0m end_to_end_net\u001b[38;5;241m.\u001b[39meval()\n\u001b[1;32m      6\u001b[0m f_net\u001b[38;5;241m.\u001b[39meval()\n",
      "File \u001b[0;32m~/Rares/Endogenous/energy/nets.py:173\u001b[0m, in \u001b[0;36mtrain_fnet\u001b[0;34m(model, p_net, xx, yy, variables, params, EPOCHS, DEVICE)\u001b[0m\n\u001b[1;32m    171\u001b[0m f_pred \u001b[38;5;241m=\u001b[39m model(x, w)\n\u001b[1;32m    172\u001b[0m p_pred \u001b[38;5;241m=\u001b[39m p_net(x, f_pred, m) \n\u001b[0;32m--> 173\u001b[0m p_pred_true \u001b[38;5;241m=\u001b[39m \u001b[43mp_net\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mm\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    175\u001b[0m v1 \u001b[38;5;241m=\u001b[39m f_pred[:,:w]\n\u001b[1;32m    176\u001b[0m v1_true \u001b[38;5;241m=\u001b[39m p_net\u001b[38;5;241m.\u001b[39me_net(x)[:,:w]\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1532\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_compiled_call_impl(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1531\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1532\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1541\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1536\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1537\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1538\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1539\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1540\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1541\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1543\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m   1544\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/Rares/Endogenous/energy/model_classes.py:75\u001b[0m, in \u001b[0;36mPNet.forward\u001b[0;34m(self, x, seq, mask)\u001b[0m\n\u001b[1;32m     73\u001b[0m \u001b[38;5;66;03m# o = self.l1((seq * mask).unsqueeze(2))\u001b[39;00m\n\u001b[1;32m     74\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mno_grad():\n\u001b[0;32m---> 75\u001b[0m     a \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43me_net\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     76\u001b[0m \u001b[38;5;66;03m# o = self.l2(o)\u001b[39;00m\n\u001b[1;32m     77\u001b[0m \u001b[38;5;66;03m# o = self.l3(o)\u001b[39;00m\n\u001b[1;32m     78\u001b[0m \u001b[38;5;66;03m# print(torch.sum(mask, 1))\u001b[39;00m\n\u001b[1;32m     79\u001b[0m \u001b[38;5;66;03m# return o.squeeze(2) + a  \u001b[39;00m\n\u001b[1;32m     80\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m o \u001b[38;5;241m+\u001b[39m a\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1532\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_compiled_call_impl(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1531\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1532\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1541\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1536\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1537\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1538\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1539\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1540\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1541\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1543\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m   1544\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/Rares/Endogenous/energy/model_classes.py:51\u001b[0m, in \u001b[0;36mNet.forward\u001b[0;34m(self, x)\u001b[0m\n\u001b[1;32m     50\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, x):\n\u001b[0;32m---> 51\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mlin(x) \u001b[38;5;241m+\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mnet\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1532\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_compiled_call_impl(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1531\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1532\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1541\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1536\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1537\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1538\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1539\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1540\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1541\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1543\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m   1544\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/container.py:217\u001b[0m, in \u001b[0;36mSequential.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    215\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m):\n\u001b[1;32m    216\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m module \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mself\u001b[39m:\n\u001b[0;32m--> 217\u001b[0m         \u001b[38;5;28minput\u001b[39m \u001b[38;5;241m=\u001b[39m \u001b[43mmodule\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43minput\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m    218\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28minput\u001b[39m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1532\u001b[0m, in \u001b[0;36mModule._wrapped_call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1530\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_compiled_call_impl(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[1;32m   1531\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m-> 1532\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_call_impl\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/module.py:1541\u001b[0m, in \u001b[0;36mModule._call_impl\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1536\u001b[0m \u001b[38;5;66;03m# If we don't have any hooks, we want to skip the rest of the logic in\u001b[39;00m\n\u001b[1;32m   1537\u001b[0m \u001b[38;5;66;03m# this function, and just call forward.\u001b[39;00m\n\u001b[1;32m   1538\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m (\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_forward_pre_hooks\n\u001b[1;32m   1539\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_backward_pre_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_backward_hooks\n\u001b[1;32m   1540\u001b[0m         \u001b[38;5;129;01mor\u001b[39;00m _global_forward_hooks \u001b[38;5;129;01mor\u001b[39;00m _global_forward_pre_hooks):\n\u001b[0;32m-> 1541\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mforward_call\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m   1543\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[1;32m   1544\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mNone\u001b[39;00m\n",
      "File \u001b[0;32m~/my-conda-envs/rares_env/lib/python3.12/site-packages/torch/nn/modules/batchnorm.py:141\u001b[0m, in \u001b[0;36m_BatchNorm.forward\u001b[0;34m(self, input)\u001b[0m\n\u001b[1;32m    136\u001b[0m     factory_kwargs \u001b[38;5;241m=\u001b[39m {\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdevice\u001b[39m\u001b[38;5;124m'\u001b[39m: device, \u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdtype\u001b[39m\u001b[38;5;124m'\u001b[39m: dtype}\n\u001b[1;32m    137\u001b[0m     \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39m\u001b[38;5;21m__init__\u001b[39m(\n\u001b[1;32m    138\u001b[0m         num_features, eps, momentum, affine, track_running_stats, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mfactory_kwargs\n\u001b[1;32m    139\u001b[0m     )\n\u001b[0;32m--> 141\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mforward\u001b[39m(\u001b[38;5;28mself\u001b[39m, \u001b[38;5;28minput\u001b[39m: Tensor) \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m>\u001b[39m Tensor:\n\u001b[1;32m    142\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_check_input_dim(\u001b[38;5;28minput\u001b[39m)\n\u001b[1;32m    144\u001b[0m     \u001b[38;5;66;03m# exponential_average_factor is set to self.momentum\u001b[39;00m\n\u001b[1;32m    145\u001b[0m     \u001b[38;5;66;03m# (when it is available) only so that it gets updated\u001b[39;00m\n\u001b[1;32m    146\u001b[0m     \u001b[38;5;66;03m# in ONNX graph when this node is exported to ONNX.\u001b[39;00m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "print(\"TRAIN F-MODEL\")\n",
    "# f_net = model_classes.FNet(X_train[:,:-1], Y_train, [200, 200]).to(DEVICE)\n",
    "f_net = nets.train_fnet(f_net, p_net, X_train[:,:-1], Y_train, variables, params, 2000, DEVICE)\n",
    "\n",
    "end_to_end_net.eval()\n",
    "f_net.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "1b39b368-3b5e-4f15-83cc-bf4c2b418d89",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 0.37904945503060633\n",
      "10 0.1666721010580659\n",
      "20 0.10774160077795386\n",
      "30 0.08732015214860439\n",
      "40 0.08037764225155115\n",
      "50 0.07287448558956384\n",
      "60 0.058051897641271354\n",
      "70 0.05868791427463293\n",
      "80 0.043537204740569\n",
      "90 0.04002793658524752\n",
      "100 0.03769151662476361\n",
      "110 0.03584921695291996\n",
      "120 0.038328109914436935\n",
      "130 0.029232106702402234\n",
      "140 0.029866836224682627\n",
      "150 0.0275243269931525\n",
      "160 0.024751224191859364\n",
      "170 0.02148118390701711\n",
      "180 0.021840772866271438\n",
      "190 0.019339186213910578\n",
      "200 0.01759004408493638\n",
      "210 0.020227278242819013\n",
      "220 0.01619431809987873\n",
      "230 0.01649337255395949\n",
      "240 0.01693031017202884\n",
      "250 0.018659305232577025\n",
      "260 0.016682366773020475\n",
      "270 0.011060677776113153\n",
      "280 0.013782857262995094\n",
      "290 0.011482022271957248\n",
      "300 0.017989160467404872\n",
      "310 0.012599993664771318\n",
      "320 0.013106906418688596\n",
      "330 0.012264792810892686\n",
      "340 0.010926641456317157\n",
      "350 0.011108917152741924\n",
      "360 0.010666093821637333\n",
      "370 0.0117803892318625\n",
      "380 0.009901738472981378\n",
      "390 0.01126640640082769\n",
      "400 0.010811554404208437\n",
      "410 0.010687316282419488\n",
      "420 0.01157713367487304\n",
      "430 0.009659514164086431\n",
      "440 0.010983671158319339\n",
      "450 0.010371844604378566\n",
      "460 0.009051621407270432\n",
      "470 0.011545063396915793\n",
      "480 0.009172613451373763\n",
      "490 0.010409053037874401\n",
      "500 0.010477139161666855\n",
      "510 0.008318289550370537\n",
      "520 0.008620213705580682\n",
      "530 0.006829872881062329\n",
      "540 0.007449700619326904\n",
      "550 0.010958682501805015\n",
      "560 0.012651490570278838\n",
      "570 0.00893227378721349\n",
      "580 0.008524930292041972\n",
      "590 0.009487388954148628\n",
      "600 0.011291303559555672\n",
      "610 0.015344183698762209\n",
      "620 0.008057784105767496\n",
      "630 0.007775649389950559\n",
      "640 0.005980951440287754\n",
      "650 0.007366534846369177\n",
      "660 0.011282901405356824\n",
      "670 0.007054576843511313\n",
      "680 0.006239277630811557\n",
      "690 0.006062498567043804\n",
      "700 0.00701109190529678\n",
      "710 0.007915349095128477\n",
      "720 0.008394403266429436\n",
      "730 0.006637518625357188\n",
      "740 0.007521141761098988\n",
      "750 0.009214617853576784\n",
      "760 0.006740559456811752\n",
      "770 0.008975166279124097\n",
      "780 0.006080712634138763\n",
      "790 0.009869345328770578\n",
      "800 0.005565209724009037\n",
      "810 0.012365261927479878\n",
      "820 0.007316938219883013\n",
      "830 0.005680048849899322\n",
      "840 0.004495847827056423\n",
      "850 0.011096685459488071\n",
      "860 0.007558160805492662\n",
      "870 0.006996226243791171\n",
      "880 0.005279121352941729\n",
      "890 0.007031364910071716\n",
      "900 0.006177600378869101\n",
      "910 0.006884515632409602\n",
      "920 0.005949919292761479\n",
      "930 0.006113059585914016\n",
      "940 0.004946813175629359\n",
      "950 0.01126353933941573\n",
      "960 0.006447005162481218\n",
      "970 0.006760056859639008\n",
      "980 0.005742333589296322\n",
      "990 0.007308360433089547\n"
     ]
    }
   ],
   "source": [
    "reward_learner = nets.train_reward_learner(p_net, X_train[:,:-1], Y_train, variables, params, 1000, DEVICE)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "2b682c2e-a93c-4f32-a586-855de10140da",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(24, 639)\n",
      "(639,)\n"
     ]
    }
   ],
   "source": [
    "all_rewards = []\n",
    "for w in range(24):\n",
    "    r = reward_learner(X_test_pt, w).cpu().detach()\n",
    "    all_rewards.append(list(r))\n",
    "reward_losses = []\n",
    "# print(reward_actions.shape)\n",
    "all_rewards = np.array(all_rewards)\n",
    "reward_actions = np.argmin(all_rewards, axis=0)\n",
    "print(all_rewards.shape)\n",
    "print(reward_actions.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "8d637937-acbe-4a99-a597-f560534ab436",
   "metadata": {},
   "outputs": [],
   "source": [
    "def task_loss_no_mean(Y_sched, Y_actual, params):\n",
    "    return (params[\"gamma_under\"] * torch.clamp(Y_actual - Y_sched, min=0) + \n",
    "        params[\"gamma_over\"] * torch.clamp(Y_sched - Y_actual, min=0))\n",
    "\n",
    "def pred_obj(x, w): \n",
    "    f_pred = f_net(x, w)\n",
    "    m = get_decision_mask_(f_pred, DEVICE, w)\n",
    "\n",
    "    p_pred = p_net(x, f_pred, m)\n",
    "\n",
    "    v2 = p_pred[:,w:]\n",
    "    v1 = p_net(x, torch.zeros_like(f_pred), torch.zeros_like(f_pred))[:,:w]\n",
    "\n",
    "    v = torch.cat((v1, v2), 1)\n",
    "\n",
    "    loss = nets.task_loss(v, f_pred, params).mean()\n",
    "    return loss.item()\n",
    "\n",
    "\n",
    "def eval_decision(x, y, w):\n",
    "    f_pred = f_net(x, w)\n",
    "    m = get_decision_mask_(y, DEVICE, w)\n",
    "\n",
    "    p_pred = p_net(x, y, m)\n",
    "    \n",
    "    v1 = p_net(x, y, torch.zeros_like(y))[:,:w]\n",
    "    # v1 = f_pred[:,:w]\n",
    "    v2 = p_pred[:,w:]\n",
    "            \n",
    "    v = torch.cat((v1, v2), 1)\n",
    "\n",
    "    loss = nets.task_loss(v, y, params).mean()\n",
    "    return loss.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "d38f9c31-96b8-4d26-8599-aa540cb1b776",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    },
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "end-to-end cost: 0.2939223647117615\n",
      "2-stage    cost: 0.27221572399139404\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19708868861198425\n",
      "RANDOM  true cost:  -1 0.22479579908152422\n",
      "OPTIMAL true cost: 2 0.19170646369457245\n",
      "REWARD  true cost: 17 0.21494679152965546\n",
      "\n",
      "end-to-end cost: 0.2630069851875305\n",
      "2-stage    cost: 0.20238268375396729\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18894803524017334\n",
      "RANDOM  true cost:  -1 0.21338509333630404\n",
      "OPTIMAL true cost: 16 0.18894803524017334\n",
      "REWARD  true cost: 7 0.2043449878692627\n",
      "\n",
      "end-to-end cost: 0.32557618618011475\n",
      "2-stage    cost: 0.375069797039032\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.26440542936325073\n",
      "RANDOM  true cost:  -1 0.26823648003240425\n",
      "OPTIMAL true cost: 16 0.23936347663402557\n",
      "REWARD  true cost: 3 0.25782617926597595\n",
      "\n",
      "end-to-end cost: 0.30497655272483826\n",
      "2-stage    cost: 0.21156638860702515\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19463442265987396\n",
      "RANDOM  true cost:  -1 0.22697151452302933\n",
      "OPTIMAL true cost: 2 0.18904022872447968\n",
      "REWARD  true cost: 15 0.21041059494018555\n",
      "\n",
      "end-to-end cost: 0.36224624514579773\n",
      "2-stage    cost: 1.4179129600524902\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.256717324256897\n",
      "RANDOM  true cost:  -1 0.28713930398225784\n",
      "OPTIMAL true cost: 2 0.25094175338745117\n",
      "REWARD  true cost: 3 0.256717324256897\n",
      "\n",
      "end-to-end cost: 0.44219744205474854\n",
      "2-stage    cost: 0.09946467727422714\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2703694999217987\n",
      "RANDOM  true cost:  -1 0.3260437722007434\n",
      "OPTIMAL true cost: 5 0.26922231912612915\n",
      "REWARD  true cost: 7 0.2721502482891083\n",
      "\n",
      "end-to-end cost: 0.26027539372444153\n",
      "2-stage    cost: 5.701001167297363\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.21762311458587646\n",
      "RANDOM  true cost:  -1 0.19087109062820673\n",
      "OPTIMAL true cost: 2 0.11755874007940292\n",
      "REWARD  true cost: 10 0.14754053950309753\n",
      "\n",
      "end-to-end cost: 0.20565693080425262\n",
      "2-stage    cost: 2.081655502319336\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14680129289627075\n",
      "RANDOM  true cost:  -1 0.16604301209251085\n",
      "OPTIMAL true cost: 2 0.14571382105350494\n",
      "REWARD  true cost: 20 0.18368707597255707\n",
      "\n",
      "end-to-end cost: 0.15251633524894714\n",
      "2-stage    cost: 2.779972553253174\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.10753630101680756\n",
      "RANDOM  true cost:  -1 0.1398779610171914\n",
      "OPTIMAL true cost: 16 0.10753630101680756\n",
      "REWARD  true cost: 7 0.15395492315292358\n",
      "\n",
      "end-to-end cost: 1.0572514533996582\n",
      "2-stage    cost: 2.6985433101654053\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 1.0435290336608887\n",
      "RANDOM  true cost:  -1 0.855662322913607\n",
      "OPTIMAL true cost: 2 0.15939143300056458\n",
      "REWARD  true cost: 17 1.0272325277328491\n",
      "\n",
      "end-to-end cost: 0.16340398788452148\n",
      "2-stage    cost: 1.0651452541351318\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.1313338577747345\n",
      "RANDOM  true cost:  -1 0.1613198115179936\n",
      "OPTIMAL true cost: 16 0.11904387176036835\n",
      "REWARD  true cost: 3 0.1780785322189331\n",
      "\n",
      "end-to-end cost: 0.21757152676582336\n",
      "2-stage    cost: 3.8137662410736084\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17042133212089539\n",
      "RANDOM  true cost:  -1 0.21749698432783285\n",
      "OPTIMAL true cost: 17 0.1681494116783142\n",
      "REWARD  true cost: 3 0.2431524693965912\n",
      "\n",
      "end-to-end cost: 0.2979086935520172\n",
      "2-stage    cost: 0.20886723697185516\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2555551528930664\n",
      "RANDOM  true cost:  -1 0.26070152906080085\n",
      "OPTIMAL true cost: 16 0.22509488463401794\n",
      "REWARD  true cost: 3 0.26414552330970764\n",
      "\n",
      "end-to-end cost: 0.25687330961227417\n",
      "2-stage    cost: 1.305303931236267\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.17081668972969055\n",
      "RANDOM  true cost:  -1 0.18970690915981928\n",
      "OPTIMAL true cost: 2 0.15718244016170502\n",
      "REWARD  true cost: 2 0.15718244016170502\n",
      "\n",
      "end-to-end cost: 0.21582847833633423\n",
      "2-stage    cost: 3.484067916870117\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.14738838374614716\n",
      "RANDOM  true cost:  -1 0.16942037517825762\n",
      "OPTIMAL true cost: 16 0.14349643886089325\n",
      "REWARD  true cost: 7 0.18375042080879211\n",
      "\n",
      "end-to-end cost: 0.1922539323568344\n",
      "2-stage    cost: 2.90151309967041\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.1468665450811386\n",
      "RANDOM  true cost:  -1 0.1693497976909081\n",
      "OPTIMAL true cost: 16 0.13912737369537354\n",
      "REWARD  true cost: 7 0.1763170063495636\n",
      "\n",
      "end-to-end cost: 0.22545954585075378\n",
      "2-stage    cost: 0.20806507766246796\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.17060641944408417\n",
      "RANDOM  true cost:  -1 0.19512071398397288\n",
      "OPTIMAL true cost: 16 0.16236653923988342\n",
      "REWARD  true cost: 3 0.19710054993629456\n",
      "\n",
      "end-to-end cost: 0.23873794078826904\n",
      "2-stage    cost: 0.7843937277793884\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.16860362887382507\n",
      "RANDOM  true cost:  -1 0.1957334168255329\n",
      "OPTIMAL true cost: 16 0.16860362887382507\n",
      "REWARD  true cost: 2 0.17926351726055145\n",
      "\n",
      "end-to-end cost: 0.3589012622833252\n",
      "2-stage    cost: 0.5506320595741272\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.26945385336875916\n",
      "RANDOM  true cost:  -1 0.29303213953971863\n",
      "OPTIMAL true cost: 16 0.2644873261451721\n",
      "REWARD  true cost: 7 0.28098195791244507\n",
      "\n",
      "end-to-end cost: 0.40924203395843506\n",
      "2-stage    cost: 1.3700816631317139\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.26085326075553894\n",
      "RANDOM  true cost:  -1 0.30884668479363125\n",
      "OPTIMAL true cost: 2 0.25807642936706543\n",
      "REWARD  true cost: 5 0.26239222288131714\n",
      "\n",
      "end-to-end cost: 0.315657377243042\n",
      "2-stage    cost: 2.632267713546753\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.2028391808271408\n",
      "RANDOM  true cost:  -1 0.23313191657265028\n",
      "OPTIMAL true cost: 2 0.18493473529815674\n",
      "REWARD  true cost: 10 0.2091529369354248\n",
      "\n",
      "end-to-end cost: 0.2737283408641815\n",
      "2-stage    cost: 1.10769522190094\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.17052143812179565\n",
      "RANDOM  true cost:  -1 0.20374457413951555\n",
      "OPTIMAL true cost: 2 0.16549567878246307\n",
      "REWARD  true cost: 7 0.17618410289287567\n",
      "\n",
      "end-to-end cost: 0.24677102267742157\n",
      "2-stage    cost: 1.49765145778656\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.17618092894554138\n",
      "RANDOM  true cost:  -1 0.18784871449073157\n",
      "OPTIMAL true cost: 2 0.15549442172050476\n",
      "REWARD  true cost: 17 0.18173262476921082\n",
      "\n",
      "end-to-end cost: 0.25162070989608765\n",
      "2-stage    cost: 0.9595252871513367\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.1783110499382019\n",
      "RANDOM  true cost:  -1 0.19368743834396204\n",
      "OPTIMAL true cost: 2 0.16447460651397705\n",
      "REWARD  true cost: 7 0.17622768878936768\n",
      "\n",
      "end-to-end cost: 0.26971113681793213\n",
      "2-stage    cost: 0.7481891512870789\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.19109123945236206\n",
      "RANDOM  true cost:  -1 0.2123045058300098\n",
      "OPTIMAL true cost: 16 0.18725702166557312\n",
      "REWARD  true cost: 3 0.19473853707313538\n",
      "\n",
      "end-to-end cost: 0.35927534103393555\n",
      "2-stage    cost: 1.9724504947662354\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2476646900177002\n",
      "RANDOM  true cost:  -1 0.2836797001461188\n",
      "OPTIMAL true cost: 2 0.2476646900177002\n",
      "REWARD  true cost: 3 0.25345367193222046\n",
      "\n",
      "end-to-end cost: 0.3773537576198578\n",
      "2-stage    cost: 0.776742160320282\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.251064658164978\n",
      "RANDOM  true cost:  -1 0.2895781559248765\n",
      "OPTIMAL true cost: 2 0.2473362684249878\n",
      "REWARD  true cost: 7 0.25588107109069824\n",
      "\n",
      "end-to-end cost: 0.26814937591552734\n",
      "2-stage    cost: 1.6347092390060425\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.155647873878479\n",
      "RANDOM  true cost:  -1 0.19428767822682858\n",
      "OPTIMAL true cost: 2 0.14931702613830566\n",
      "REWARD  true cost: 10 0.17349457740783691\n",
      "\n",
      "end-to-end cost: 0.2073463648557663\n",
      "2-stage    cost: 4.258829116821289\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.14244261384010315\n",
      "RANDOM  true cost:  -1 0.15976310707628727\n",
      "OPTIMAL true cost: 2 0.13349714875221252\n",
      "REWARD  true cost: 7 0.15884363651275635\n",
      "\n",
      "end-to-end cost: 0.21212947368621826\n",
      "2-stage    cost: 0.4971967935562134\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.15841293334960938\n",
      "RANDOM  true cost:  -1 0.18147229651610056\n",
      "OPTIMAL true cost: 16 0.14990369975566864\n",
      "REWARD  true cost: 2 0.17338165640830994\n",
      "\n",
      "end-to-end cost: 0.2294101119041443\n",
      "2-stage    cost: 0.4098895192146301\n",
      "TRUE\n",
      "CHOSEN  true cost: 17 0.1780860424041748\n",
      "RANDOM  true cost:  -1 0.20522167968253294\n",
      "OPTIMAL true cost: 16 0.17488686740398407\n",
      "REWARD  true cost: 22 0.21640077233314514\n",
      "\n",
      "end-to-end cost: 0.20548933744430542\n",
      "2-stage    cost: 4.347096920013428\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.1546238660812378\n",
      "RANDOM  true cost:  -1 0.1704097588857015\n",
      "OPTIMAL true cost: 16 0.14724698662757874\n",
      "REWARD  true cost: 15 0.15037453174591064\n",
      "\n",
      "end-to-end cost: 0.286140501499176\n",
      "2-stage    cost: 0.8879421949386597\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.22593435645103455\n",
      "RANDOM  true cost:  -1 0.25861101659635705\n",
      "OPTIMAL true cost: 16 0.2149888128042221\n",
      "REWARD  true cost: 7 0.27507585287094116\n",
      "\n",
      "end-to-end cost: 0.3502837121486664\n",
      "2-stage    cost: 0.7066375613212585\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2587830722332001\n",
      "RANDOM  true cost:  -1 0.28582286834716797\n",
      "OPTIMAL true cost: 2 0.2587830722332001\n",
      "REWARD  true cost: 7 0.26803672313690186\n",
      "\n",
      "end-to-end cost: 0.23924480378627777\n",
      "2-stage    cost: 4.683984756469727\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.13262604176998138\n",
      "RANDOM  true cost:  -1 0.17168997849027315\n",
      "OPTIMAL true cost: 2 0.12761357426643372\n",
      "REWARD  true cost: 7 0.13799181580543518\n",
      "\n",
      "end-to-end cost: 0.24628424644470215\n",
      "2-stage    cost: 1.2006042003631592\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18928933143615723\n",
      "RANDOM  true cost:  -1 0.21341506764292717\n",
      "OPTIMAL true cost: 7 0.18269318342208862\n",
      "REWARD  true cost: 7 0.18269318342208862\n",
      "\n",
      "end-to-end cost: 0.26028454303741455\n",
      "2-stage    cost: 0.03236699104309082\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.19373485445976257\n",
      "RANDOM  true cost:  -1 0.21906182914972305\n",
      "OPTIMAL true cost: 16 0.1856440305709839\n",
      "REWARD  true cost: 7 0.22011375427246094\n",
      "\n",
      "end-to-end cost: 0.204519122838974\n",
      "2-stage    cost: 7.303099632263184\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.13012145459651947\n",
      "RANDOM  true cost:  -1 0.24093073544402918\n",
      "OPTIMAL true cost: 16 0.13012145459651947\n",
      "REWARD  true cost: 7 0.4003060758113861\n",
      "\n",
      "end-to-end cost: 0.218400239944458\n",
      "2-stage    cost: 0.9031236171722412\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.17952784895896912\n",
      "RANDOM  true cost:  -1 0.20548892517884573\n",
      "OPTIMAL true cost: 16 0.1657899022102356\n",
      "REWARD  true cost: 17 0.168055459856987\n",
      "\n",
      "end-to-end cost: 0.35423359274864197\n",
      "2-stage    cost: 0.04173080250620842\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.28592702746391296\n",
      "RANDOM  true cost:  -1 0.3000246187051137\n",
      "OPTIMAL true cost: 16 0.2673313319683075\n",
      "REWARD  true cost: 18 0.28790023922920227\n",
      "\n",
      "end-to-end cost: 0.42806634306907654\n",
      "2-stage    cost: 0.11930444091558456\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2850414216518402\n",
      "RANDOM  true cost:  -1 0.3283292440076669\n",
      "OPTIMAL true cost: 2 0.28184324502944946\n",
      "REWARD  true cost: 7 0.28994083404541016\n",
      "\n",
      "end-to-end cost: 0.29534852504730225\n",
      "2-stage    cost: 4.603143692016602\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.13618004322052002\n",
      "RANDOM  true cost:  -1 0.19838718697428703\n",
      "OPTIMAL true cost: 2 0.13426366448402405\n",
      "REWARD  true cost: 17 0.21987514197826385\n",
      "\n",
      "end-to-end cost: 0.24968630075454712\n",
      "2-stage    cost: 1.1281079053878784\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.1788535714149475\n",
      "RANDOM  true cost:  -1 0.20107856765389442\n",
      "OPTIMAL true cost: 16 0.17293791472911835\n",
      "REWARD  true cost: 7 0.19392070174217224\n",
      "\n",
      "end-to-end cost: 0.25414156913757324\n",
      "2-stage    cost: 0.5273647308349609\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17639833688735962\n",
      "RANDOM  true cost:  -1 0.20298735238611698\n",
      "OPTIMAL true cost: 16 0.17639833688735962\n",
      "REWARD  true cost: 3 0.18990617990493774\n",
      "\n",
      "end-to-end cost: 0.22508695721626282\n",
      "2-stage    cost: 4.681215763092041\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15389874577522278\n",
      "RANDOM  true cost:  -1 0.16560073072711626\n",
      "OPTIMAL true cost: 2 0.13152983784675598\n",
      "REWARD  true cost: 3 0.13820089399814606\n",
      "\n",
      "end-to-end cost: 0.35950326919555664\n",
      "2-stage    cost: 1.2586058378219604\n",
      "TRUE\n",
      "CHOSEN  true cost: 17 0.310332715511322\n",
      "RANDOM  true cost:  -1 0.31760966839889687\n",
      "OPTIMAL true cost: 2 0.19041070342063904\n",
      "REWARD  true cost: 3 0.20269326865673065\n",
      "\n",
      "end-to-end cost: 0.26808351278305054\n",
      "2-stage    cost: 3.544127941131592\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.231113463640213\n",
      "RANDOM  true cost:  -1 0.23700057218472162\n",
      "OPTIMAL true cost: 16 0.20422904193401337\n",
      "REWARD  true cost: 3 0.23946338891983032\n",
      "\n",
      "end-to-end cost: 0.22043268382549286\n",
      "2-stage    cost: 3.924668073654175\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2141452133655548\n",
      "RANDOM  true cost:  -1 0.20044495786229768\n",
      "OPTIMAL true cost: 16 0.16445431113243103\n",
      "REWARD  true cost: 7 0.21528677642345428\n",
      "\n",
      "end-to-end cost: 0.3034241795539856\n",
      "2-stage    cost: 5.651769638061523\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.273928701877594\n",
      "RANDOM  true cost:  -1 0.2772756926715374\n",
      "OPTIMAL true cost: 2 0.15276861190795898\n",
      "REWARD  true cost: 7 0.2687479257583618\n",
      "\n",
      "end-to-end cost: 0.3629923462867737\n",
      "2-stage    cost: 0.4435266852378845\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.3342210650444031\n",
      "RANDOM  true cost:  -1 0.3150919508188963\n",
      "OPTIMAL true cost: 2 0.18574073910713196\n",
      "REWARD  true cost: 17 0.3188818097114563\n",
      "\n",
      "end-to-end cost: 0.18812784552574158\n",
      "2-stage    cost: 4.258788108825684\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.1497534066438675\n",
      "RANDOM  true cost:  -1 0.167167441919446\n",
      "OPTIMAL true cost: 16 0.14057067036628723\n",
      "REWARD  true cost: 15 0.1497534066438675\n",
      "\n",
      "end-to-end cost: 0.6603189706802368\n",
      "2-stage    cost: 3.364719867706299\n",
      "TRUE\n",
      "CHOSEN  true cost: 17 0.6354992985725403\n",
      "RANDOM  true cost:  -1 0.5605270142356554\n",
      "OPTIMAL true cost: 2 0.1486329436302185\n",
      "REWARD  true cost: 7 0.5330187678337097\n",
      "\n",
      "end-to-end cost: 1.96438729763031\n",
      "2-stage    cost: 1.1899535655975342\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 1.9480645656585693\n",
      "RANDOM  true cost:  -1 1.6346293538808823\n",
      "OPTIMAL true cost: 3 0.3694725036621094\n",
      "REWARD  true cost: 3 0.3694725036621094\n",
      "\n",
      "end-to-end cost: 0.23665806651115417\n",
      "2-stage    cost: 1.0177018642425537\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18939268589019775\n",
      "RANDOM  true cost:  -1 0.23506065644323826\n",
      "OPTIMAL true cost: 17 0.1863836944103241\n",
      "REWARD  true cost: 17 0.1863836944103241\n",
      "\n",
      "end-to-end cost: 0.3252737522125244\n",
      "2-stage    cost: 0.13997286558151245\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2458844631910324\n",
      "RANDOM  true cost:  -1 0.2625562685231368\n",
      "OPTIMAL true cost: 2 0.23873500525951385\n",
      "REWARD  true cost: 17 0.2445002645254135\n",
      "\n",
      "end-to-end cost: 0.20259332656860352\n",
      "2-stage    cost: 4.873364448547363\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20193642377853394\n",
      "RANDOM  true cost:  -1 0.17274145719905695\n",
      "OPTIMAL true cost: 16 0.1366613805294037\n",
      "REWARD  true cost: 7 0.21029984951019287\n",
      "\n",
      "end-to-end cost: 0.5931512713432312\n",
      "2-stage    cost: 1.4059346914291382\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.5626715421676636\n",
      "RANDOM  true cost:  -1 0.5033443303157886\n",
      "OPTIMAL true cost: 2 0.19269657135009766\n",
      "REWARD  true cost: 17 0.5473413467407227\n",
      "\n",
      "end-to-end cost: 0.22191393375396729\n",
      "2-stage    cost: 0.19600461423397064\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.17173850536346436\n",
      "RANDOM  true cost:  -1 0.19911551413436732\n",
      "OPTIMAL true cost: 16 0.16082696616649628\n",
      "REWARD  true cost: 13 0.19668063521385193\n",
      "\n",
      "end-to-end cost: 0.2019956409931183\n",
      "2-stage    cost: 2.39530348777771\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14138831198215485\n",
      "RANDOM  true cost:  -1 0.16871333867311478\n",
      "OPTIMAL true cost: 16 0.14138831198215485\n",
      "REWARD  true cost: 7 0.17005090415477753\n",
      "\n",
      "end-to-end cost: 0.22068290412425995\n",
      "2-stage    cost: 0.5649001598358154\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.18082503974437714\n",
      "RANDOM  true cost:  -1 0.2021311999609073\n",
      "OPTIMAL true cost: 16 0.1682136058807373\n",
      "REWARD  true cost: 3 0.2030702531337738\n",
      "\n",
      "end-to-end cost: 0.2874581813812256\n",
      "2-stage    cost: 0.5875619649887085\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.26963627338409424\n",
      "RANDOM  true cost:  -1 0.2645198938747247\n",
      "OPTIMAL true cost: 16 0.21896497905254364\n",
      "REWARD  true cost: 17 0.21947482228279114\n",
      "\n",
      "end-to-end cost: 0.331923246383667\n",
      "2-stage    cost: 0.5532354116439819\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2532831132411957\n",
      "RANDOM  true cost:  -1 0.27484772106011707\n",
      "OPTIMAL true cost: 16 0.25062936544418335\n",
      "REWARD  true cost: 17 0.25525763630867004\n",
      "\n",
      "end-to-end cost: 0.24946823716163635\n",
      "2-stage    cost: 1.530247449874878\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.15784016251564026\n",
      "RANDOM  true cost:  -1 0.185451061775287\n",
      "OPTIMAL true cost: 2 0.15162774920463562\n",
      "REWARD  true cost: 7 0.1635253131389618\n",
      "\n",
      "end-to-end cost: 0.24553780257701874\n",
      "2-stage    cost: 0.31332457065582275\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.18553945422172546\n",
      "RANDOM  true cost:  -1 0.2075237805644671\n",
      "OPTIMAL true cost: 16 0.17877861857414246\n",
      "REWARD  true cost: 2 0.19356147944927216\n",
      "\n",
      "end-to-end cost: 0.2508043944835663\n",
      "2-stage    cost: 1.8690217733383179\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.1507769525051117\n",
      "RANDOM  true cost:  -1 0.18583985604345798\n",
      "OPTIMAL true cost: 2 0.1507769525051117\n",
      "REWARD  true cost: 3 0.15570667386054993\n",
      "\n",
      "end-to-end cost: 0.19584910571575165\n",
      "2-stage    cost: 4.854524612426758\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.14042969048023224\n",
      "RANDOM  true cost:  -1 0.15357417985796928\n",
      "OPTIMAL true cost: 2 0.12973099946975708\n",
      "REWARD  true cost: 17 0.1428951621055603\n",
      "\n",
      "end-to-end cost: 0.582175612449646\n",
      "2-stage    cost: 1.7712335586547852\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.54246985912323\n",
      "RANDOM  true cost:  -1 0.5090849436819553\n",
      "OPTIMAL true cost: 4 0.2513083815574646\n",
      "REWARD  true cost: 2 0.32882723212242126\n",
      "\n",
      "end-to-end cost: 0.306204617023468\n",
      "2-stage    cost: 0.6603854298591614\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.26243317127227783\n",
      "RANDOM  true cost:  -1 0.2676997035741806\n",
      "OPTIMAL true cost: 16 0.2275879830121994\n",
      "REWARD  true cost: 3 0.2722671926021576\n",
      "\n",
      "end-to-end cost: 0.4215686321258545\n",
      "2-stage    cost: 0.05385437607765198\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2940678596496582\n",
      "RANDOM  true cost:  -1 0.3318155420323213\n",
      "OPTIMAL true cost: 2 0.2940678596496582\n",
      "REWARD  true cost: 17 0.3183465898036957\n",
      "\n",
      "end-to-end cost: 0.37809059023857117\n",
      "2-stage    cost: 0.025516634806990623\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22104065120220184\n",
      "RANDOM  true cost:  -1 0.2730726258208354\n",
      "OPTIMAL true cost: 2 0.21860575675964355\n",
      "REWARD  true cost: 2 0.21860575675964355\n",
      "\n",
      "end-to-end cost: 0.3519286811351776\n",
      "2-stage    cost: 2.5311503410339355\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1938381791114807\n",
      "RANDOM  true cost:  -1 0.24908819360037646\n",
      "OPTIMAL true cost: 2 0.1913342922925949\n",
      "REWARD  true cost: 3 0.1938381791114807\n",
      "\n",
      "end-to-end cost: 0.35419175028800964\n",
      "2-stage    cost: 0.325153112411499\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20452241599559784\n",
      "RANDOM  true cost:  -1 0.25583534004787606\n",
      "OPTIMAL true cost: 2 0.20081613957881927\n",
      "REWARD  true cost: 5 0.20558111369609833\n",
      "\n",
      "end-to-end cost: 0.3420206904411316\n",
      "2-stage    cost: 0.7271921634674072\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.217746764421463\n",
      "RANDOM  true cost:  -1 0.25570594022671383\n",
      "OPTIMAL true cost: 2 0.21222464740276337\n",
      "REWARD  true cost: 3 0.217746764421463\n",
      "\n",
      "end-to-end cost: 0.3688076436519623\n",
      "2-stage    cost: 0.19928085803985596\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2369661033153534\n",
      "RANDOM  true cost:  -1 0.2777950881669919\n",
      "OPTIMAL true cost: 2 0.23252704739570618\n",
      "REWARD  true cost: 17 0.2736331820487976\n",
      "\n",
      "end-to-end cost: 0.43176159262657166\n",
      "2-stage    cost: 1.6847832202911377\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2780114412307739\n",
      "RANDOM  true cost:  -1 0.3277176419893901\n",
      "OPTIMAL true cost: 2 0.2759759724140167\n",
      "REWARD  true cost: 7 0.2826255261898041\n",
      "\n",
      "end-to-end cost: 0.4522486627101898\n",
      "2-stage    cost: 0.9607347249984741\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2748216390609741\n",
      "RANDOM  true cost:  -1 0.3342856938640277\n",
      "OPTIMAL true cost: 5 0.2729755640029907\n",
      "REWARD  true cost: 2 0.2752125859260559\n",
      "\n",
      "end-to-end cost: 0.3948614001274109\n",
      "2-stage    cost: 0.19367548823356628\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2516321539878845\n",
      "RANDOM  true cost:  -1 0.2953627159198125\n",
      "OPTIMAL true cost: 2 0.2464379519224167\n",
      "REWARD  true cost: 7 0.25522738695144653\n",
      "\n",
      "end-to-end cost: 0.36980313062667847\n",
      "2-stage    cost: 2.3795065879821777\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18387553095817566\n",
      "RANDOM  true cost:  -1 0.2530252269158761\n",
      "OPTIMAL true cost: 3 0.18387553095817566\n",
      "REWARD  true cost: 3 0.18387553095817566\n",
      "\n",
      "end-to-end cost: 0.3418084383010864\n",
      "2-stage    cost: 0.3275666832923889\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22636988759040833\n",
      "RANDOM  true cost:  -1 0.26181241994102794\n",
      "OPTIMAL true cost: 2 0.22153788805007935\n",
      "REWARD  true cost: 7 0.23266887664794922\n",
      "\n",
      "end-to-end cost: 0.34351640939712524\n",
      "2-stage    cost: 0.5783545970916748\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22301465272903442\n",
      "RANDOM  true cost:  -1 0.2590233397980531\n",
      "OPTIMAL true cost: 2 0.21936878561973572\n",
      "REWARD  true cost: 5 0.22644570469856262\n",
      "\n",
      "end-to-end cost: 0.35988181829452515\n",
      "2-stage    cost: 1.0490230321884155\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22988836467266083\n",
      "RANDOM  true cost:  -1 0.2731193397194147\n",
      "OPTIMAL true cost: 2 0.2256586253643036\n",
      "REWARD  true cost: 3 0.22988836467266083\n",
      "\n",
      "end-to-end cost: 0.4513833522796631\n",
      "2-stage    cost: 0.43807095289230347\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2824292778968811\n",
      "RANDOM  true cost:  -1 0.33807559311389923\n",
      "OPTIMAL true cost: 2 0.2824292778968811\n",
      "REWARD  true cost: 8 0.2949632704257965\n",
      "\n",
      "end-to-end cost: 0.47103434801101685\n",
      "2-stage    cost: 0.5386412739753723\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2828426957130432\n",
      "RANDOM  true cost:  -1 0.34336793422698975\n",
      "OPTIMAL true cost: 5 0.2814900279045105\n",
      "REWARD  true cost: 5 0.2814900279045105\n",
      "\n",
      "end-to-end cost: 0.3672843873500824\n",
      "2-stage    cost: 1.195763349533081\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21748864650726318\n",
      "RANDOM  true cost:  -1 0.2658909298479557\n",
      "OPTIMAL true cost: 2 0.2118256390094757\n",
      "REWARD  true cost: 7 0.22071242332458496\n",
      "\n",
      "end-to-end cost: 0.3653187155723572\n",
      "2-stage    cost: 0.30064451694488525\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22798065841197968\n",
      "RANDOM  true cost:  -1 0.2715868819504976\n",
      "OPTIMAL true cost: 2 0.22397540509700775\n",
      "REWARD  true cost: 3 0.22798065841197968\n",
      "\n",
      "end-to-end cost: 0.3725828528404236\n",
      "2-stage    cost: 0.220569908618927\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22413775324821472\n",
      "RANDOM  true cost:  -1 0.27542033853630227\n",
      "OPTIMAL true cost: 2 0.22051557898521423\n",
      "REWARD  true cost: 7 0.22958378493785858\n",
      "\n",
      "end-to-end cost: 0.36359381675720215\n",
      "2-stage    cost: 2.008512496948242\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1901736706495285\n",
      "RANDOM  true cost:  -1 0.2526673221339782\n",
      "OPTIMAL true cost: 2 0.18988262116909027\n",
      "REWARD  true cost: 17 0.2703835368156433\n",
      "\n",
      "end-to-end cost: 0.33926254510879517\n",
      "2-stage    cost: 0.599674642086029\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19722335040569305\n",
      "RANDOM  true cost:  -1 0.24659495490292707\n",
      "OPTIMAL true cost: 2 0.19362036883831024\n",
      "REWARD  true cost: 6 0.20625600218772888\n",
      "\n",
      "end-to-end cost: 0.37490659952163696\n",
      "2-stage    cost: 2.6966681480407715\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2665153741836548\n",
      "RANDOM  true cost:  -1 0.2968985053400199\n",
      "OPTIMAL true cost: 2 0.2603793144226074\n",
      "REWARD  true cost: 5 0.2702319324016571\n",
      "\n",
      "end-to-end cost: 0.4461430013179779\n",
      "2-stage    cost: 0.06368058919906616\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.3195975422859192\n",
      "RANDOM  true cost:  -1 0.3536137143770854\n",
      "OPTIMAL true cost: 2 0.31538769602775574\n",
      "REWARD  true cost: 2 0.31538769602775574\n",
      "\n",
      "end-to-end cost: 0.4147528111934662\n",
      "2-stage    cost: 0.023934412747621536\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.23468828201293945\n",
      "RANDOM  true cost:  -1 0.2965534881999095\n",
      "OPTIMAL true cost: 5 0.23294997215270996\n",
      "REWARD  true cost: 2 0.2348816692829132\n",
      "\n",
      "end-to-end cost: 0.39955395460128784\n",
      "2-stage    cost: 0.14514069259166718\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21796362102031708\n",
      "RANDOM  true cost:  -1 0.28186514352758724\n",
      "OPTIMAL true cost: 5 0.21747323870658875\n",
      "REWARD  true cost: 2 0.21940498054027557\n",
      "\n",
      "end-to-end cost: 0.40478384494781494\n",
      "2-stage    cost: 0.5663112998008728\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24685710668563843\n",
      "RANDOM  true cost:  -1 0.29785866911212605\n",
      "OPTIMAL true cost: 2 0.2444862574338913\n",
      "REWARD  true cost: 7 0.2519395053386688\n",
      "\n",
      "end-to-end cost: 0.41919904947280884\n",
      "2-stage    cost: 0.29403671622276306\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2369675487279892\n",
      "RANDOM  true cost:  -1 0.2987321875989437\n",
      "OPTIMAL true cost: 5 0.23687681555747986\n",
      "REWARD  true cost: 10 0.26230448484420776\n",
      "\n",
      "end-to-end cost: 0.47635024785995483\n",
      "2-stage    cost: 0.06478392332792282\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2661668062210083\n",
      "RANDOM  true cost:  -1 0.33805476874113083\n",
      "OPTIMAL true cost: 7 0.26097649335861206\n",
      "REWARD  true cost: 5 0.26348352432250977\n",
      "\n",
      "end-to-end cost: 0.4948028326034546\n",
      "2-stage    cost: 1.3606891632080078\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.27649378776550293\n",
      "RANDOM  true cost:  -1 0.35097214331229526\n",
      "OPTIMAL true cost: 7 0.2737498879432678\n",
      "REWARD  true cost: 6 0.2822032570838928\n",
      "\n",
      "end-to-end cost: 0.5479202270507812\n",
      "2-stage    cost: 0.05398016795516014\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3342358469963074\n",
      "RANDOM  true cost:  -1 0.40369310850898427\n",
      "OPTIMAL true cost: 7 0.3319709300994873\n",
      "REWARD  true cost: 7 0.3319709300994873\n",
      "\n",
      "end-to-end cost: 0.4453551769256592\n",
      "2-stage    cost: 0.6212477684020996\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.22766348719596863\n",
      "RANDOM  true cost:  -1 0.3050699519614379\n",
      "OPTIMAL true cost: 7 0.22177386283874512\n",
      "REWARD  true cost: 6 0.23171263933181763\n",
      "\n",
      "end-to-end cost: 0.4315143823623657\n",
      "2-stage    cost: 0.07046572864055634\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22757014632225037\n",
      "RANDOM  true cost:  -1 0.3007618132978678\n",
      "OPTIMAL true cost: 7 0.22411608695983887\n",
      "REWARD  true cost: 3 0.22757014632225037\n",
      "\n",
      "end-to-end cost: 0.3992954194545746\n",
      "2-stage    cost: 1.5859198570251465\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1912669539451599\n",
      "RANDOM  true cost:  -1 0.2698137474556764\n",
      "OPTIMAL true cost: 7 0.19057583808898926\n",
      "REWARD  true cost: 6 0.19704954326152802\n",
      "\n",
      "end-to-end cost: 0.3906111717224121\n",
      "2-stage    cost: 0.8270546793937683\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19982454180717468\n",
      "RANDOM  true cost:  -1 0.2703603742023309\n",
      "OPTIMAL true cost: 5 0.19803544878959656\n",
      "REWARD  true cost: 10 0.2267540991306305\n",
      "\n",
      "end-to-end cost: 0.40924006700515747\n",
      "2-stage    cost: 0.3467090129852295\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21846920251846313\n",
      "RANDOM  true cost:  -1 0.28893974733849365\n",
      "OPTIMAL true cost: 5 0.2166273593902588\n",
      "REWARD  true cost: 10 0.24745750427246094\n",
      "\n",
      "end-to-end cost: 0.5238510370254517\n",
      "2-stage    cost: 0.08606357872486115\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3048863410949707\n",
      "RANDOM  true cost:  -1 0.3787159038086732\n",
      "OPTIMAL true cost: 7 0.30217379331588745\n",
      "REWARD  true cost: 7 0.30217379331588745\n",
      "\n",
      "end-to-end cost: 0.5413349270820618\n",
      "2-stage    cost: 0.03303273394703865\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.31146615743637085\n",
      "RANDOM  true cost:  -1 0.3903820527096589\n",
      "OPTIMAL true cost: 7 0.30902600288391113\n",
      "REWARD  true cost: 6 0.319388210773468\n",
      "\n",
      "end-to-end cost: 0.42405471205711365\n",
      "2-stage    cost: 1.5376417636871338\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.19433754682540894\n",
      "RANDOM  true cost:  -1 0.2848298139870167\n",
      "OPTIMAL true cost: 7 0.19184021651744843\n",
      "REWARD  true cost: 10 0.2271556854248047\n",
      "\n",
      "end-to-end cost: 0.4259922504425049\n",
      "2-stage    cost: 0.06329166889190674\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24157071113586426\n",
      "RANDOM  true cost:  -1 0.30700765425960225\n",
      "OPTIMAL true cost: 5 0.23841899633407593\n",
      "REWARD  true cost: 3 0.24157071113586426\n",
      "\n",
      "end-to-end cost: 0.4095380902290344\n",
      "2-stage    cost: 0.4296413064002991\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21091078221797943\n",
      "RANDOM  true cost:  -1 0.2818973623216152\n",
      "OPTIMAL true cost: 7 0.2099032700061798\n",
      "REWARD  true cost: 6 0.21582239866256714\n",
      "\n",
      "end-to-end cost: 0.4163152575492859\n",
      "2-stage    cost: 0.057882629334926605\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2194153070449829\n",
      "RANDOM  true cost:  -1 0.2899252139031887\n",
      "OPTIMAL true cost: 5 0.21814368665218353\n",
      "REWARD  true cost: 2 0.2233581840991974\n",
      "\n",
      "end-to-end cost: 0.4193159341812134\n",
      "2-stage    cost: 0.08709189295768738\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23077695071697235\n",
      "RANDOM  true cost:  -1 0.29865190635124844\n",
      "OPTIMAL true cost: 5 0.22979572415351868\n",
      "REWARD  true cost: 5 0.22979572415351868\n",
      "\n",
      "end-to-end cost: 0.5036959648132324\n",
      "2-stage    cost: 0.23163175582885742\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.28618675470352173\n",
      "RANDOM  true cost:  -1 0.3630227881173293\n",
      "OPTIMAL true cost: 7 0.28424057364463806\n",
      "REWARD  true cost: 2 0.29942137002944946\n",
      "\n",
      "end-to-end cost: 0.5363412499427795\n",
      "2-stage    cost: 0.05038486421108246\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3072317838668823\n",
      "RANDOM  true cost:  -1 0.38820382083455723\n",
      "OPTIMAL true cost: 7 0.305269330739975\n",
      "REWARD  true cost: 6 0.31515270471572876\n",
      "\n",
      "end-to-end cost: 0.43393954634666443\n",
      "2-stage    cost: 0.23858290910720825\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2067716121673584\n",
      "RANDOM  true cost:  -1 0.29358734500904876\n",
      "OPTIMAL true cost: 7 0.20097796618938446\n",
      "REWARD  true cost: 7 0.20097796618938446\n",
      "\n",
      "end-to-end cost: 0.4307568669319153\n",
      "2-stage    cost: 0.04041871055960655\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2296028733253479\n",
      "RANDOM  true cost:  -1 0.30325875990092754\n",
      "OPTIMAL true cost: 7 0.22884464263916016\n",
      "REWARD  true cost: 6 0.23595046997070312\n",
      "\n",
      "end-to-end cost: 0.40369081497192383\n",
      "2-stage    cost: 0.16539224982261658\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20940807461738586\n",
      "RANDOM  true cost:  -1 0.2797742486000061\n",
      "OPTIMAL true cost: 7 0.20845314860343933\n",
      "REWARD  true cost: 6 0.21371781826019287\n",
      "\n",
      "end-to-end cost: 0.3761603534221649\n",
      "2-stage    cost: 0.5487546920776367\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20884951949119568\n",
      "RANDOM  true cost:  -1 0.26763636370499927\n",
      "OPTIMAL true cost: 2 0.20791302621364594\n",
      "REWARD  true cost: 6 0.2163301706314087\n",
      "\n",
      "end-to-end cost: 0.4092021882534027\n",
      "2-stage    cost: 0.33947283029556274\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2489665001630783\n",
      "RANDOM  true cost:  -1 0.3012886264671882\n",
      "OPTIMAL true cost: 2 0.24686327576637268\n",
      "REWARD  true cost: 2 0.24686327576637268\n",
      "\n",
      "end-to-end cost: 0.5041279196739197\n",
      "2-stage    cost: 0.26713573932647705\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.3104236423969269\n",
      "RANDOM  true cost:  -1 0.37386444335182506\n",
      "OPTIMAL true cost: 5 0.30884847044944763\n",
      "REWARD  true cost: 17 0.3823840320110321\n",
      "\n",
      "end-to-end cost: 0.5475372076034546\n",
      "2-stage    cost: 0.050735779106616974\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3348773121833801\n",
      "RANDOM  true cost:  -1 0.40266862759987515\n",
      "OPTIMAL true cost: 7 0.3325057029724121\n",
      "REWARD  true cost: 6 0.34053683280944824\n",
      "\n",
      "end-to-end cost: 0.45874881744384766\n",
      "2-stage    cost: 0.047241322696208954\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.23810641467571259\n",
      "RANDOM  true cost:  -1 0.32020325275758904\n",
      "OPTIMAL true cost: 7 0.2315073311328888\n",
      "REWARD  true cost: 10 0.27270883321762085\n",
      "\n",
      "end-to-end cost: 0.4303855895996094\n",
      "2-stage    cost: 1.7325694561004639\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.26374194025993347\n",
      "RANDOM  true cost:  -1 0.3203994147479534\n",
      "OPTIMAL true cost: 5 0.262378454208374\n",
      "REWARD  true cost: 17 0.32990366220474243\n",
      "\n",
      "end-to-end cost: 0.4286673963069916\n",
      "2-stage    cost: 0.014172732830047607\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.23505449295043945\n",
      "RANDOM  true cost:  -1 0.3015203047543764\n",
      "OPTIMAL true cost: 7 0.22890228033065796\n",
      "REWARD  true cost: 6 0.233998104929924\n",
      "\n",
      "end-to-end cost: 0.4232215881347656\n",
      "2-stage    cost: 0.04234166070818901\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23067423701286316\n",
      "RANDOM  true cost:  -1 0.29904987911383313\n",
      "OPTIMAL true cost: 5 0.22878193855285645\n",
      "REWARD  true cost: 2 0.2364203929901123\n",
      "\n",
      "end-to-end cost: 0.4272443652153015\n",
      "2-stage    cost: 0.038874365389347076\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2320260852575302\n",
      "RANDOM  true cost:  -1 0.3016149265070756\n",
      "OPTIMAL true cost: 7 0.23122280836105347\n",
      "REWARD  true cost: 2 0.23592548072338104\n",
      "\n",
      "end-to-end cost: 0.5039334893226624\n",
      "2-stage    cost: 0.07324466109275818\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2988918423652649\n",
      "RANDOM  true cost:  -1 0.3688298898438613\n",
      "OPTIMAL true cost: 7 0.2973131537437439\n",
      "REWARD  true cost: 10 0.3225809633731842\n",
      "\n",
      "end-to-end cost: 0.5146841406822205\n",
      "2-stage    cost: 0.026950467377901077\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2895607352256775\n",
      "RANDOM  true cost:  -1 0.3696835935115814\n",
      "OPTIMAL true cost: 7 0.2875020503997803\n",
      "REWARD  true cost: 10 0.31387460231781006\n",
      "\n",
      "end-to-end cost: 0.3930473327636719\n",
      "2-stage    cost: 1.2354785203933716\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.1963285505771637\n",
      "RANDOM  true cost:  -1 0.26867866702377796\n",
      "OPTIMAL true cost: 7 0.1853470802307129\n",
      "REWARD  true cost: 6 0.19179263710975647\n",
      "\n",
      "end-to-end cost: 0.3497314453125\n",
      "2-stage    cost: 0.16321128606796265\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.19185268878936768\n",
      "RANDOM  true cost:  -1 0.2504320877293746\n",
      "OPTIMAL true cost: 2 0.19008874893188477\n",
      "REWARD  true cost: 7 0.19500908255577087\n",
      "\n",
      "end-to-end cost: 0.3129863739013672\n",
      "2-stage    cost: 2.57444167137146\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.16496968269348145\n",
      "RANDOM  true cost:  -1 0.22484906887014708\n",
      "OPTIMAL true cost: 2 0.16227023303508759\n",
      "REWARD  true cost: 17 0.25935810804367065\n",
      "\n",
      "end-to-end cost: 0.2624932527542114\n",
      "2-stage    cost: 1.5268934965133667\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1516016572713852\n",
      "RANDOM  true cost:  -1 0.19769124997158846\n",
      "OPTIMAL true cost: 2 0.14986051619052887\n",
      "REWARD  true cost: 7 0.1558579057455063\n",
      "\n",
      "end-to-end cost: 0.21710538864135742\n",
      "2-stage    cost: 2.8628172874450684\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.16195034980773926\n",
      "RANDOM  true cost:  -1 0.19211996036271253\n",
      "OPTIMAL true cost: 3 0.12583842873573303\n",
      "REWARD  true cost: 2 0.1292218565940857\n",
      "\n",
      "end-to-end cost: 0.241677388548851\n",
      "2-stage    cost: 2.4259731769561768\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.19831351935863495\n",
      "RANDOM  true cost:  -1 0.20158502645790577\n",
      "OPTIMAL true cost: 2 0.17136065661907196\n",
      "REWARD  true cost: 2 0.17136065661907196\n",
      "\n",
      "end-to-end cost: 0.24185502529144287\n",
      "2-stage    cost: 0.9852855205535889\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.20160333812236786\n",
      "RANDOM  true cost:  -1 0.20778209095199904\n",
      "OPTIMAL true cost: 2 0.1828889548778534\n",
      "REWARD  true cost: 7 0.18780457973480225\n",
      "\n",
      "end-to-end cost: 0.11744025349617004\n",
      "2-stage    cost: 3.7743115425109863\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.10229882597923279\n",
      "RANDOM  true cost:  -1 0.26292967423796654\n",
      "OPTIMAL true cost: 14 0.10229882597923279\n",
      "REWARD  true cost: 5 0.4368426501750946\n",
      "\n",
      "end-to-end cost: 0.23883822560310364\n",
      "2-stage    cost: 0.1646815985441208\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18895328044891357\n",
      "RANDOM  true cost:  -1 0.200692405924201\n",
      "OPTIMAL true cost: 2 0.18460838496685028\n",
      "REWARD  true cost: 3 0.18739764392375946\n",
      "\n",
      "end-to-end cost: 0.4058801531791687\n",
      "2-stage    cost: 0.046400852501392365\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2203555703163147\n",
      "RANDOM  true cost:  -1 0.2872651449094216\n",
      "OPTIMAL true cost: 5 0.2203555703163147\n",
      "REWARD  true cost: 7 0.22359149158000946\n",
      "\n",
      "end-to-end cost: 0.40198665857315063\n",
      "2-stage    cost: 0.43077588081359863\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2127237766981125\n",
      "RANDOM  true cost:  -1 0.2807990815490484\n",
      "OPTIMAL true cost: 5 0.21140389144420624\n",
      "REWARD  true cost: 4 0.2127237766981125\n",
      "\n",
      "end-to-end cost: 0.3715561032295227\n",
      "2-stage    cost: 2.2098586559295654\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18490755558013916\n",
      "RANDOM  true cost:  -1 0.25827552067736786\n",
      "OPTIMAL true cost: 5 0.1827743947505951\n",
      "REWARD  true cost: 14 0.26412901282310486\n",
      "\n",
      "end-to-end cost: 0.395518034696579\n",
      "2-stage    cost: 0.63193678855896\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2538299262523651\n",
      "RANDOM  true cost:  -1 0.30514117951194447\n",
      "OPTIMAL true cost: 2 0.2518101632595062\n",
      "REWARD  true cost: 3 0.2538299262523651\n",
      "\n",
      "end-to-end cost: 0.3698890209197998\n",
      "2-stage    cost: 3.5338027477264404\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22085092961788177\n",
      "RANDOM  true cost:  -1 0.2758175271252791\n",
      "OPTIMAL true cost: 2 0.2189883589744568\n",
      "REWARD  true cost: 7 0.22402004897594452\n",
      "\n",
      "end-to-end cost: 0.20043331384658813\n",
      "2-stage    cost: 2.5086934566497803\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19465228915214539\n",
      "RANDOM  true cost:  -1 0.20485497949024042\n",
      "OPTIMAL true cost: 1 0.1370096206665039\n",
      "REWARD  true cost: 17 0.19654056429862976\n",
      "\n",
      "end-to-end cost: 0.23394916951656342\n",
      "2-stage    cost: 1.3280830383300781\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.19103901088237762\n",
      "RANDOM  true cost:  -1 0.1862706591685613\n",
      "OPTIMAL true cost: 2 0.15283404290676117\n",
      "REWARD  true cost: 7 0.1625867784023285\n",
      "\n",
      "end-to-end cost: 0.3596695065498352\n",
      "2-stage    cost: 0.8799697756767273\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.21486584842205048\n",
      "RANDOM  true cost:  -1 0.2563377848515908\n",
      "OPTIMAL true cost: 2 0.19900113344192505\n",
      "REWARD  true cost: 2 0.19900113344192505\n",
      "\n",
      "end-to-end cost: 0.39093416929244995\n",
      "2-stage    cost: 0.4041227698326111\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21732452511787415\n",
      "RANDOM  true cost:  -1 0.27941867771248025\n",
      "OPTIMAL true cost: 5 0.21524971723556519\n",
      "REWARD  true cost: 2 0.21720871329307556\n",
      "\n",
      "end-to-end cost: 0.4013110101222992\n",
      "2-stage    cost: 0.5171200037002563\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2243441790342331\n",
      "RANDOM  true cost:  -1 0.2872872104247411\n",
      "OPTIMAL true cost: 3 0.2243441790342331\n",
      "REWARD  true cost: 2 0.22491364181041718\n",
      "\n",
      "end-to-end cost: 0.4882461428642273\n",
      "2-stage    cost: 0.17006775736808777\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2975877821445465\n",
      "RANDOM  true cost:  -1 0.36127792795499164\n",
      "OPTIMAL true cost: 5 0.29564985632896423\n",
      "REWARD  true cost: 17 0.37432917952537537\n",
      "\n",
      "end-to-end cost: 0.48093104362487793\n",
      "2-stage    cost: 0.10332457721233368\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.27369457483291626\n",
      "RANDOM  true cost:  -1 0.34809860462943715\n",
      "OPTIMAL true cost: 7 0.2718355059623718\n",
      "REWARD  true cost: 10 0.29651832580566406\n",
      "\n",
      "end-to-end cost: 0.35668015480041504\n",
      "2-stage    cost: 5.087371826171875\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.1852249801158905\n",
      "RANDOM  true cost:  -1 0.2507309690117836\n",
      "OPTIMAL true cost: 5 0.17389385402202606\n",
      "REWARD  true cost: 10 0.1978393793106079\n",
      "\n",
      "end-to-end cost: 0.2191847264766693\n",
      "2-stage    cost: 0.22106260061264038\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.16150659322738647\n",
      "RANDOM  true cost:  -1 0.17674411460757256\n",
      "OPTIMAL true cost: 2 0.14911291003227234\n",
      "REWARD  true cost: 7 0.15811415016651154\n",
      "\n",
      "end-to-end cost: 0.20531801879405975\n",
      "2-stage    cost: 0.09252406656742096\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17448782920837402\n",
      "RANDOM  true cost:  -1 0.17212294042110443\n",
      "OPTIMAL true cost: 2 0.14930057525634766\n",
      "REWARD  true cost: 3 0.15206877887248993\n",
      "\n",
      "end-to-end cost: 0.2014753818511963\n",
      "2-stage    cost: 0.4846782684326172\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17676381766796112\n",
      "RANDOM  true cost:  -1 0.16673474137981734\n",
      "OPTIMAL true cost: 2 0.13786661624908447\n",
      "REWARD  true cost: 7 0.14507551491260529\n",
      "\n",
      "end-to-end cost: 0.19146451354026794\n",
      "2-stage    cost: 2.4705586433410645\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.5098870992660522\n",
      "RANDOM  true cost:  -1 0.3054263185088833\n",
      "OPTIMAL true cost: 1 0.12353231757879257\n",
      "REWARD  true cost: 5 0.41351160407066345\n",
      "\n",
      "end-to-end cost: 0.2519250512123108\n",
      "2-stage    cost: 2.0686533451080322\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.20277194678783417\n",
      "RANDOM  true cost:  -1 0.2195024893929561\n",
      "OPTIMAL true cost: 2 0.19244524836540222\n",
      "REWARD  true cost: 7 0.1987295001745224\n",
      "\n",
      "end-to-end cost: 0.28047671914100647\n",
      "2-stage    cost: 1.8706960678100586\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.21748241782188416\n",
      "RANDOM  true cost:  -1 0.2347853146493435\n",
      "OPTIMAL true cost: 2 0.20006093382835388\n",
      "REWARD  true cost: 7 0.20712411403656006\n",
      "\n",
      "end-to-end cost: 0.3735193610191345\n",
      "2-stage    cost: 0.1566896140575409\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.269947350025177\n",
      "RANDOM  true cost:  -1 0.30120769515633583\n",
      "OPTIMAL true cost: 5 0.269947350025177\n",
      "REWARD  true cost: 7 0.27407628297805786\n",
      "\n",
      "end-to-end cost: 0.3878345489501953\n",
      "2-stage    cost: 0.8265172839164734\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.21155214309692383\n",
      "RANDOM  true cost:  -1 0.27568517190714675\n",
      "OPTIMAL true cost: 5 0.21155214309692383\n",
      "REWARD  true cost: 2 0.21286962926387787\n",
      "\n",
      "end-to-end cost: 0.3741898536682129\n",
      "2-stage    cost: 0.5201812982559204\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19906064867973328\n",
      "RANDOM  true cost:  -1 0.2648682799190283\n",
      "OPTIMAL true cost: 5 0.19818274676799774\n",
      "REWARD  true cost: 17 0.2917972505092621\n",
      "\n",
      "end-to-end cost: 0.32089895009994507\n",
      "2-stage    cost: 2.8168864250183105\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1564655303955078\n",
      "RANDOM  true cost:  -1 0.22305167404313883\n",
      "OPTIMAL true cost: 2 0.15587402880191803\n",
      "REWARD  true cost: 5 0.1565486192703247\n",
      "\n",
      "end-to-end cost: 0.27698618173599243\n",
      "2-stage    cost: 1.504927635192871\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.16013166308403015\n",
      "RANDOM  true cost:  -1 0.21603544553120932\n",
      "OPTIMAL true cost: 2 0.1581687331199646\n",
      "REWARD  true cost: 17 0.250878244638443\n",
      "\n",
      "end-to-end cost: 0.38357195258140564\n",
      "2-stage    cost: 0.19085240364074707\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.27144742012023926\n",
      "RANDOM  true cost:  -1 0.30570554609100026\n",
      "OPTIMAL true cost: 2 0.2699509561061859\n",
      "REWARD  true cost: 3 0.2712322473526001\n",
      "\n",
      "end-to-end cost: 0.37181079387664795\n",
      "2-stage    cost: 4.116578102111816\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2020646035671234\n",
      "RANDOM  true cost:  -1 0.2688558803250392\n",
      "OPTIMAL true cost: 5 0.20052844285964966\n",
      "REWARD  true cost: 6 0.20635151863098145\n",
      "\n",
      "end-to-end cost: 0.20248958468437195\n",
      "2-stage    cost: 1.3331055641174316\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.15942582488059998\n",
      "RANDOM  true cost:  -1 0.17455859978993735\n",
      "OPTIMAL true cost: 2 0.14980091154575348\n",
      "REWARD  true cost: 17 0.1851760447025299\n",
      "\n",
      "end-to-end cost: 0.26125770807266235\n",
      "2-stage    cost: 0.5718867778778076\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.16752412915229797\n",
      "RANDOM  true cost:  -1 0.19340922931830087\n",
      "OPTIMAL true cost: 2 0.1513873189687729\n",
      "REWARD  true cost: 2 0.1513873189687729\n",
      "\n",
      "end-to-end cost: 0.2066868245601654\n",
      "2-stage    cost: 7.336648941040039\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.11246508359909058\n",
      "RANDOM  true cost:  -1 0.15099941473454237\n",
      "OPTIMAL true cost: 2 0.10198607295751572\n",
      "REWARD  true cost: 3 0.10308515280485153\n",
      "\n",
      "end-to-end cost: 0.3482065200805664\n",
      "2-stage    cost: 6.393017768859863\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.38244080543518066\n",
      "RANDOM  true cost:  -1 0.369830260053277\n",
      "OPTIMAL true cost: 9 0.23555730283260345\n",
      "REWARD  true cost: 3 0.4085502028465271\n",
      "\n",
      "end-to-end cost: 0.7264895439147949\n",
      "2-stage    cost: 1.8250234127044678\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.735374391078949\n",
      "RANDOM  true cost:  -1 0.44540524544815224\n",
      "OPTIMAL true cost: 10 0.12572580575942993\n",
      "REWARD  true cost: 3 0.13970820605754852\n",
      "\n",
      "end-to-end cost: 0.17325221002101898\n",
      "2-stage    cost: 4.621770858764648\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15535888075828552\n",
      "RANDOM  true cost:  -1 0.1669849008321762\n",
      "OPTIMAL true cost: 15 0.1539594829082489\n",
      "REWARD  true cost: 3 0.17047053575515747\n",
      "\n",
      "end-to-end cost: 0.2195274531841278\n",
      "2-stage    cost: 2.3642737865448\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.17768153548240662\n",
      "RANDOM  true cost:  -1 0.19161305079857507\n",
      "OPTIMAL true cost: 2 0.17313385009765625\n",
      "REWARD  true cost: 2 0.17313385009765625\n",
      "\n",
      "end-to-end cost: 0.09809476137161255\n",
      "2-stage    cost: 4.639866828918457\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.09454111754894257\n",
      "RANDOM  true cost:  -1 0.09030057303607464\n",
      "OPTIMAL true cost: 3 0.05583006143569946\n",
      "REWARD  true cost: 5 0.056288205087184906\n",
      "\n",
      "end-to-end cost: 0.11803498864173889\n",
      "2-stage    cost: 0.19673284888267517\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.11853670328855515\n",
      "RANDOM  true cost:  -1 0.12903092646350464\n",
      "OPTIMAL true cost: 1 0.11686934530735016\n",
      "REWARD  true cost: 2 0.13192453980445862\n",
      "\n",
      "end-to-end cost: 0.261728972196579\n",
      "2-stage    cost: 0.07349938154220581\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.21209578216075897\n",
      "RANDOM  true cost:  -1 0.2205090963592132\n",
      "OPTIMAL true cost: 2 0.20172660052776337\n",
      "REWARD  true cost: 5 0.20409858226776123\n",
      "\n",
      "end-to-end cost: 0.17788049578666687\n",
      "2-stage    cost: 7.370619773864746\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14832304418087006\n",
      "RANDOM  true cost:  -1 0.13136768651505312\n",
      "OPTIMAL true cost: 2 0.08984219282865524\n",
      "REWARD  true cost: 7 0.0978916585445404\n",
      "\n",
      "end-to-end cost: 0.21545302867889404\n",
      "2-stage    cost: 0.11062982678413391\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.18718330562114716\n",
      "RANDOM  true cost:  -1 0.19047672425707182\n",
      "OPTIMAL true cost: 2 0.17399989068508148\n",
      "REWARD  true cost: 2 0.17399989068508148\n",
      "\n",
      "end-to-end cost: 0.31998133659362793\n",
      "2-stage    cost: 4.013813495635986\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.22357508540153503\n",
      "RANDOM  true cost:  -1 0.2501206863671541\n",
      "OPTIMAL true cost: 2 0.20844630897045135\n",
      "REWARD  true cost: 7 0.2175459861755371\n",
      "\n",
      "end-to-end cost: 0.27264174818992615\n",
      "2-stage    cost: 7.536250591278076\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1725672483444214\n",
      "RANDOM  true cost:  -1 0.2116338051855564\n",
      "OPTIMAL true cost: 2 0.1671178936958313\n",
      "REWARD  true cost: 2 0.1671178936958313\n",
      "\n",
      "end-to-end cost: 0.1322922706604004\n",
      "2-stage    cost: 3.27960467338562\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14114761352539062\n",
      "RANDOM  true cost:  -1 0.12318014570822318\n",
      "OPTIMAL true cost: 2 0.10196303576231003\n",
      "REWARD  true cost: 7 0.10879271477460861\n",
      "\n",
      "end-to-end cost: 0.11291475594043732\n",
      "2-stage    cost: 1.5997695922851562\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.13397619128227234\n",
      "RANDOM  true cost:  -1 0.14223995680610338\n",
      "OPTIMAL true cost: 0 0.11291475594043732\n",
      "REWARD  true cost: 17 0.12350925803184509\n",
      "\n",
      "end-to-end cost: 0.19116626679897308\n",
      "2-stage    cost: 2.14492130279541\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.1358570158481598\n",
      "RANDOM  true cost:  -1 0.16004154148201147\n",
      "OPTIMAL true cost: 2 0.1358570158481598\n",
      "REWARD  true cost: 3 0.139244943857193\n",
      "\n",
      "end-to-end cost: 0.2637864649295807\n",
      "2-stage    cost: 0.1554989516735077\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.21912726759910583\n",
      "RANDOM  true cost:  -1 0.22068962082266808\n",
      "OPTIMAL true cost: 2 0.19640645384788513\n",
      "REWARD  true cost: 7 0.20404404401779175\n",
      "\n",
      "end-to-end cost: 0.2579720914363861\n",
      "2-stage    cost: 3.210723876953125\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1571483463048935\n",
      "RANDOM  true cost:  -1 0.1981462879727284\n",
      "OPTIMAL true cost: 2 0.1520269215106964\n",
      "REWARD  true cost: 2 0.1520269215106964\n",
      "\n",
      "end-to-end cost: 0.3602135181427002\n",
      "2-stage    cost: 0.10620734095573425\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2890876531600952\n",
      "RANDOM  true cost:  -1 0.3048971891403198\n",
      "OPTIMAL true cost: 2 0.2856014668941498\n",
      "REWARD  true cost: 2 0.2856014668941498\n",
      "\n",
      "end-to-end cost: 0.4552273750305176\n",
      "2-stage    cost: 0.07942493259906769\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3104568421840668\n",
      "RANDOM  true cost:  -1 0.35638057192166644\n",
      "OPTIMAL true cost: 2 0.3084315061569214\n",
      "REWARD  true cost: 7 0.31388357281684875\n",
      "\n",
      "end-to-end cost: 0.38185417652130127\n",
      "2-stage    cost: 1.037935495376587\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18433134257793427\n",
      "RANDOM  true cost:  -1 0.263620354856054\n",
      "OPTIMAL true cost: 5 0.18433134257793427\n",
      "REWARD  true cost: 6 0.18940597772598267\n",
      "\n",
      "end-to-end cost: 0.3247993588447571\n",
      "2-stage    cost: 1.2354882955551147\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.172227144241333\n",
      "RANDOM  true cost:  -1 0.23443030441800752\n",
      "OPTIMAL true cost: 2 0.17057618498802185\n",
      "REWARD  true cost: 7 0.17715351283550262\n",
      "\n",
      "end-to-end cost: 0.31973469257354736\n",
      "2-stage    cost: 0.8171113729476929\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.180587038397789\n",
      "RANDOM  true cost:  -1 0.23270902534325918\n",
      "OPTIMAL true cost: 2 0.1777375191450119\n",
      "REWARD  true cost: 2 0.1777375191450119\n",
      "\n",
      "end-to-end cost: 0.31109896302223206\n",
      "2-stage    cost: 0.3441559076309204\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19037263095378876\n",
      "RANDOM  true cost:  -1 0.23582535795867443\n",
      "OPTIMAL true cost: 2 0.18817970156669617\n",
      "REWARD  true cost: 2 0.18817970156669617\n",
      "\n",
      "end-to-end cost: 0.33265021443367004\n",
      "2-stage    cost: 0.799385666847229\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2106253206729889\n",
      "RANDOM  true cost:  -1 0.25841039170821506\n",
      "OPTIMAL true cost: 2 0.2106253206729889\n",
      "REWARD  true cost: 15 0.2610708177089691\n",
      "\n",
      "end-to-end cost: 0.35774800181388855\n",
      "2-stage    cost: 0.8149029612541199\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.23659980297088623\n",
      "RANDOM  true cost:  -1 0.2827928240100543\n",
      "OPTIMAL true cost: 3 0.2358664721250534\n",
      "REWARD  true cost: 5 0.23659980297088623\n",
      "\n",
      "end-to-end cost: 0.3555877208709717\n",
      "2-stage    cost: 2.3862485885620117\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.22174572944641113\n",
      "RANDOM  true cost:  -1 0.2715348210185766\n",
      "OPTIMAL true cost: 2 0.2211202085018158\n",
      "REWARD  true cost: 8 0.2310105562210083\n",
      "\n",
      "end-to-end cost: 0.189085453748703\n",
      "2-stage    cost: 2.5390520095825195\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.12815378606319427\n",
      "RANDOM  true cost:  -1 0.15443618471423784\n",
      "OPTIMAL true cost: 2 0.1232481300830841\n",
      "REWARD  true cost: 3 0.12573286890983582\n",
      "\n",
      "end-to-end cost: 0.12607984244823456\n",
      "2-stage    cost: 6.429172515869141\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.13696569204330444\n",
      "RANDOM  true cost:  -1 0.36572355404496193\n",
      "OPTIMAL true cost: 15 0.1251426488161087\n",
      "REWARD  true cost: 2 0.644462525844574\n",
      "\n",
      "end-to-end cost: 0.20931154489517212\n",
      "2-stage    cost: 1.0776803493499756\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17127451300621033\n",
      "RANDOM  true cost:  -1 0.19697951587537924\n",
      "OPTIMAL true cost: 16 0.17127451300621033\n",
      "REWARD  true cost: 7 0.20991480350494385\n",
      "\n",
      "end-to-end cost: 0.198089599609375\n",
      "2-stage    cost: 6.051952362060547\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18479809165000916\n",
      "RANDOM  true cost:  -1 0.272294366111358\n",
      "OPTIMAL true cost: 1 0.13380715250968933\n",
      "REWARD  true cost: 5 0.35842165350914\n",
      "\n",
      "end-to-end cost: 0.29074591398239136\n",
      "2-stage    cost: 0.07317906618118286\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.23327991366386414\n",
      "RANDOM  true cost:  -1 0.2442974771062533\n",
      "OPTIMAL true cost: 2 0.22256414592266083\n",
      "REWARD  true cost: 7 0.23072998225688934\n",
      "\n",
      "end-to-end cost: 0.32893186807632446\n",
      "2-stage    cost: 4.690886497497559\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.21453553438186646\n",
      "RANDOM  true cost:  -1 0.2607148252427578\n",
      "OPTIMAL true cost: 2 0.21204963326454163\n",
      "REWARD  true cost: 2 0.21204963326454163\n",
      "\n",
      "end-to-end cost: 0.35186243057250977\n",
      "2-stage    cost: 0.053326111286878586\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.25367864966392517\n",
      "RANDOM  true cost:  -1 0.28985893229643506\n",
      "OPTIMAL true cost: 2 0.25257599353790283\n",
      "REWARD  true cost: 2 0.25257599353790283\n",
      "\n",
      "end-to-end cost: 0.20579448342323303\n",
      "2-stage    cost: 7.906376838684082\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.6154444217681885\n",
      "RANDOM  true cost:  -1 0.39677874216188985\n",
      "OPTIMAL true cost: 1 0.11769794672727585\n",
      "REWARD  true cost: 8 0.7159861326217651\n",
      "\n",
      "end-to-end cost: 0.1728309839963913\n",
      "2-stage    cost: 0.17966686189174652\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17773908376693726\n",
      "RANDOM  true cost:  -1 0.1634265979131063\n",
      "OPTIMAL true cost: 1 0.14511226117610931\n",
      "REWARD  true cost: 3 0.15059930086135864\n",
      "\n",
      "end-to-end cost: 0.2183590531349182\n",
      "2-stage    cost: 1.047011375427246\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18284505605697632\n",
      "RANDOM  true cost:  -1 0.18079319720466933\n",
      "OPTIMAL true cost: 2 0.15485113859176636\n",
      "REWARD  true cost: 7 0.16401490569114685\n",
      "\n",
      "end-to-end cost: 0.2758997678756714\n",
      "2-stage    cost: 0.3157206177711487\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.16414302587509155\n",
      "RANDOM  true cost:  -1 0.2024638938407103\n",
      "OPTIMAL true cost: 2 0.15135613083839417\n",
      "REWARD  true cost: 3 0.15271836519241333\n",
      "\n",
      "end-to-end cost: 0.21765947341918945\n",
      "2-stage    cost: 3.1162757873535156\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17872744798660278\n",
      "RANDOM  true cost:  -1 0.2021719366312027\n",
      "OPTIMAL true cost: 1 0.13588587939739227\n",
      "REWARD  true cost: 3 0.14625094830989838\n",
      "\n",
      "end-to-end cost: 0.13807067275047302\n",
      "2-stage    cost: 6.505702018737793\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.14776331186294556\n",
      "RANDOM  true cost:  -1 0.1469983346760273\n",
      "OPTIMAL true cost: 1 0.12715847790241241\n",
      "REWARD  true cost: 17 0.1574592888355255\n",
      "\n",
      "end-to-end cost: 0.10112195461988449\n",
      "2-stage    cost: 3.483372449874878\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.11564948409795761\n",
      "RANDOM  true cost:  -1 0.13859701436012983\n",
      "OPTIMAL true cost: 0 0.10112195461988449\n",
      "REWARD  true cost: 2 0.15359169244766235\n",
      "\n",
      "end-to-end cost: 0.0886794775724411\n",
      "2-stage    cost: 1.6734166145324707\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.12238514423370361\n",
      "RANDOM  true cost:  -1 0.10893301883091529\n",
      "OPTIMAL true cost: 1 0.0844198614358902\n",
      "REWARD  true cost: 5 0.11603035032749176\n",
      "\n",
      "end-to-end cost: 0.2114887535572052\n",
      "2-stage    cost: 1.066240668296814\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.2254646122455597\n",
      "RANDOM  true cost:  -1 0.19733081633845964\n",
      "OPTIMAL true cost: 11 0.14120054244995117\n",
      "REWARD  true cost: 7 0.16653333604335785\n",
      "\n",
      "end-to-end cost: 0.22889195382595062\n",
      "2-stage    cost: 0.3831988275051117\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.1528131067752838\n",
      "RANDOM  true cost:  -1 0.18405962052444616\n",
      "OPTIMAL true cost: 2 0.1528131067752838\n",
      "REWARD  true cost: 15 0.18360690772533417\n",
      "\n",
      "end-to-end cost: 0.21946142613887787\n",
      "2-stage    cost: 2.4670591354370117\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.12208367884159088\n",
      "RANDOM  true cost:  -1 0.1643098872154951\n",
      "OPTIMAL true cost: 2 0.11794131994247437\n",
      "REWARD  true cost: 2 0.11794131994247437\n",
      "\n",
      "end-to-end cost: 0.20438024401664734\n",
      "2-stage    cost: 1.3181103467941284\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.17888230085372925\n",
      "RANDOM  true cost:  -1 0.163176870594422\n",
      "OPTIMAL true cost: 2 0.12815579771995544\n",
      "REWARD  true cost: 3 0.1302689015865326\n",
      "\n",
      "end-to-end cost: 0.2048792541027069\n",
      "2-stage    cost: 3.6666579246520996\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.1579183042049408\n",
      "RANDOM  true cost:  -1 0.17670890937248865\n",
      "OPTIMAL true cost: 2 0.14980603754520416\n",
      "REWARD  true cost: 2 0.14980603754520416\n",
      "\n",
      "end-to-end cost: 0.1742624044418335\n",
      "2-stage    cost: 1.4096219539642334\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.1720668077468872\n",
      "RANDOM  true cost:  -1 0.17546832313140234\n",
      "OPTIMAL true cost: 1 0.15823516249656677\n",
      "REWARD  true cost: 7 0.17291013896465302\n",
      "\n",
      "end-to-end cost: 0.0679972693324089\n",
      "2-stage    cost: 5.883078575134277\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.09932636469602585\n",
      "RANDOM  true cost:  -1 0.0874941007544597\n",
      "OPTIMAL true cost: 0 0.0679972693324089\n",
      "REWARD  true cost: 7 0.09114688634872437\n",
      "\n",
      "end-to-end cost: 1.3857378959655762\n",
      "2-stage    cost: 5.497653961181641\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 1.1764583587646484\n",
      "RANDOM  true cost:  -1 0.6098003598550955\n",
      "OPTIMAL true cost: 9 0.08079129457473755\n",
      "REWARD  true cost: 3 0.12797164916992188\n",
      "\n",
      "end-to-end cost: 3.349475383758545\n",
      "2-stage    cost: 5.963890075683594\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 1.8511747121810913\n",
      "RANDOM  true cost:  -1 1.077838004566729\n",
      "OPTIMAL true cost: 10 0.07672522962093353\n",
      "REWARD  true cost: 7 0.09856368601322174\n",
      "\n",
      "end-to-end cost: 1.4273736476898193\n",
      "2-stage    cost: 0.3641013503074646\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.30063411593437195\n",
      "RANDOM  true cost:  -1 1.243825304011504\n",
      "OPTIMAL true cost: 1 0.2197863757610321\n",
      "REWARD  true cost: 19 1.4654639959335327\n",
      "\n",
      "end-to-end cost: 0.11617254465818405\n",
      "2-stage    cost: 0.596298336982727\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.12194380164146423\n",
      "RANDOM  true cost:  -1 0.1473954857016603\n",
      "OPTIMAL true cost: 0 0.11617254465818405\n",
      "REWARD  true cost: 1 0.13670063018798828\n",
      "\n",
      "end-to-end cost: 0.21783092617988586\n",
      "2-stage    cost: 1.2470738887786865\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.21531987190246582\n",
      "RANDOM  true cost:  -1 0.2107388967027267\n",
      "OPTIMAL true cost: 1 0.2008293867111206\n",
      "REWARD  true cost: 7 0.21499386429786682\n",
      "\n",
      "end-to-end cost: 0.24041634798049927\n",
      "2-stage    cost: 5.355321884155273\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.17634856700897217\n",
      "RANDOM  true cost:  -1 0.1943606504549583\n",
      "OPTIMAL true cost: 2 0.15846982598304749\n",
      "REWARD  true cost: 7 0.16421626508235931\n",
      "\n",
      "end-to-end cost: 0.175885409116745\n",
      "2-stage    cost: 0.07955823093652725\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1733902394771576\n",
      "RANDOM  true cost:  -1 0.1799313152829806\n",
      "OPTIMAL true cost: 1 0.16813963651657104\n",
      "REWARD  true cost: 2 0.18150553107261658\n",
      "\n",
      "end-to-end cost: 0.18650999665260315\n",
      "2-stage    cost: 2.5711097717285156\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.16241435706615448\n",
      "RANDOM  true cost:  -1 0.14972168486565351\n",
      "OPTIMAL true cost: 2 0.11629414558410645\n",
      "REWARD  true cost: 3 0.12110698223114014\n",
      "\n",
      "end-to-end cost: 0.2040245532989502\n",
      "2-stage    cost: 0.07028468698263168\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1791735142469406\n",
      "RANDOM  true cost:  -1 0.16840289098521075\n",
      "OPTIMAL true cost: 2 0.13820648193359375\n",
      "REWARD  true cost: 3 0.14100971817970276\n",
      "\n",
      "end-to-end cost: 0.29235658049583435\n",
      "2-stage    cost: 0.10399124026298523\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.2338527888059616\n",
      "RANDOM  true cost:  -1 0.2389199665437142\n",
      "OPTIMAL true cost: 2 0.2125273197889328\n",
      "REWARD  true cost: 2 0.2125273197889328\n",
      "\n",
      "end-to-end cost: 0.3002791404724121\n",
      "2-stage    cost: 1.5799812078475952\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17475228011608124\n",
      "RANDOM  true cost:  -1 0.22596658890446028\n",
      "OPTIMAL true cost: 2 0.17189262807369232\n",
      "REWARD  true cost: 7 0.1794309914112091\n",
      "\n",
      "end-to-end cost: 0.30513012409210205\n",
      "2-stage    cost: 4.216628074645996\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.20596086978912354\n",
      "RANDOM  true cost:  -1 0.24189458166559538\n",
      "OPTIMAL true cost: 2 0.19850754737854004\n",
      "REWARD  true cost: 7 0.204005166888237\n",
      "\n",
      "end-to-end cost: 0.23519456386566162\n",
      "2-stage    cost: 4.876256942749023\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17382147908210754\n",
      "RANDOM  true cost:  -1 0.20040981595714888\n",
      "OPTIMAL true cost: 2 0.1690884530544281\n",
      "REWARD  true cost: 3 0.17276613414287567\n",
      "\n",
      "end-to-end cost: 0.1262909471988678\n",
      "2-stage    cost: 1.1744074821472168\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14473775029182434\n",
      "RANDOM  true cost:  -1 0.1324902018532157\n",
      "OPTIMAL true cost: 1 0.11269943416118622\n",
      "REWARD  true cost: 7 0.1316237896680832\n",
      "\n",
      "end-to-end cost: 0.14567479491233826\n",
      "2-stage    cost: 0.5063581466674805\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14329461753368378\n",
      "RANDOM  true cost:  -1 0.15222523547708988\n",
      "OPTIMAL true cost: 1 0.14012163877487183\n",
      "REWARD  true cost: 7 0.1642058938741684\n",
      "\n",
      "end-to-end cost: 0.23244911432266235\n",
      "2-stage    cost: 0.05418476462364197\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.19493888318538666\n",
      "RANDOM  true cost:  -1 0.19493446685373783\n",
      "OPTIMAL true cost: 2 0.17174741625785828\n",
      "REWARD  true cost: 3 0.17427699267864227\n",
      "\n",
      "end-to-end cost: 0.2708742022514343\n",
      "2-stage    cost: 0.27916419506073\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1637040078639984\n",
      "RANDOM  true cost:  -1 0.20552893355488777\n",
      "OPTIMAL true cost: 2 0.16070541739463806\n",
      "REWARD  true cost: 2 0.16070541739463806\n",
      "\n",
      "end-to-end cost: 0.216827392578125\n",
      "2-stage    cost: 4.259097099304199\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.11297108978033066\n",
      "RANDOM  true cost:  -1 0.15909322164952755\n",
      "OPTIMAL true cost: 2 0.10849888622760773\n",
      "REWARD  true cost: 3 0.11177214235067368\n",
      "\n",
      "end-to-end cost: 0.20677515864372253\n",
      "2-stage    cost: 3.351533889770508\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.18145865201950073\n",
      "RANDOM  true cost:  -1 0.1867036297917366\n",
      "OPTIMAL true cost: 2 0.16686749458312988\n",
      "REWARD  true cost: 3 0.1709485650062561\n",
      "\n",
      "end-to-end cost: 0.1598241627216339\n",
      "2-stage    cost: 3.9382693767547607\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.1489105075597763\n",
      "RANDOM  true cost:  -1 0.15415671095252037\n",
      "OPTIMAL true cost: 1 0.13575902581214905\n",
      "REWARD  true cost: 2 0.14020729064941406\n",
      "\n",
      "end-to-end cost: 0.18641512095928192\n",
      "2-stage    cost: 2.7060604095458984\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1937772035598755\n",
      "RANDOM  true cost:  -1 0.1403699383760492\n",
      "OPTIMAL true cost: 13 0.07977104932069778\n",
      "REWARD  true cost: 2 0.08419202268123627\n",
      "\n",
      "end-to-end cost: 0.1378995031118393\n",
      "2-stage    cost: 0.11397277563810349\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.13967663049697876\n",
      "RANDOM  true cost:  -1 0.16850188126166663\n",
      "OPTIMAL true cost: 17 0.1365097463130951\n",
      "REWARD  true cost: 3 0.2027038186788559\n",
      "\n",
      "end-to-end cost: 0.08439081162214279\n",
      "2-stage    cost: 10.56855583190918\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1081792339682579\n",
      "RANDOM  true cost:  -1 0.24413821194320917\n",
      "OPTIMAL true cost: 0 0.08439081162214279\n",
      "REWARD  true cost: 7 0.3226957321166992\n",
      "\n",
      "end-to-end cost: 0.11070390045642853\n",
      "2-stage    cost: 0.4752292335033417\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.11774475872516632\n",
      "RANDOM  true cost:  -1 0.14939361965904632\n",
      "OPTIMAL true cost: 0 0.11070390045642853\n",
      "REWARD  true cost: 2 0.17737707495689392\n",
      "\n",
      "end-to-end cost: 0.23858559131622314\n",
      "2-stage    cost: 0.45705080032348633\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16978006064891815\n",
      "RANDOM  true cost:  -1 0.1965356469154358\n",
      "OPTIMAL true cost: 2 0.16863858699798584\n",
      "REWARD  true cost: 2 0.16863858699798584\n",
      "\n",
      "end-to-end cost: 0.3374362885951996\n",
      "2-stage    cost: 0.12209489941596985\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2277543544769287\n",
      "RANDOM  true cost:  -1 0.26606229568521184\n",
      "OPTIMAL true cost: 2 0.22618421912193298\n",
      "REWARD  true cost: 3 0.22721779346466064\n",
      "\n",
      "end-to-end cost: 0.3303348422050476\n",
      "2-stage    cost: 2.8914599418640137\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19590458273887634\n",
      "RANDOM  true cost:  -1 0.24666941600541273\n",
      "OPTIMAL true cost: 2 0.19356021285057068\n",
      "REWARD  true cost: 10 0.21100816130638123\n",
      "\n",
      "end-to-end cost: 0.2135237455368042\n",
      "2-stage    cost: 0.23552505671977997\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.14934438467025757\n",
      "RANDOM  true cost:  -1 0.17343088115255037\n",
      "OPTIMAL true cost: 2 0.14453139901161194\n",
      "REWARD  true cost: 7 0.1523122638463974\n",
      "\n",
      "end-to-end cost: 0.33114904165267944\n",
      "2-stage    cost: 0.0822102278470993\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.21783141791820526\n",
      "RANDOM  true cost:  -1 0.25866114410261315\n",
      "OPTIMAL true cost: 2 0.2166212797164917\n",
      "REWARD  true cost: 3 0.2173304259777069\n",
      "\n",
      "end-to-end cost: 0.3761158883571625\n",
      "2-stage    cost: 0.36013150215148926\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2101890742778778\n",
      "RANDOM  true cost:  -1 0.2711002541085084\n",
      "OPTIMAL true cost: 5 0.2101890742778778\n",
      "REWARD  true cost: 7 0.21397864818572998\n",
      "\n",
      "end-to-end cost: 0.37318000197410583\n",
      "2-stage    cost: 0.04944336414337158\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.20337781310081482\n",
      "RANDOM  true cost:  -1 0.2685813046991825\n",
      "OPTIMAL true cost: 5 0.20337781310081482\n",
      "REWARD  true cost: 5 0.20337781310081482\n",
      "\n",
      "end-to-end cost: 0.33641883730888367\n",
      "2-stage    cost: 2.2955594062805176\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16991662979125977\n",
      "RANDOM  true cost:  -1 0.23798183600107828\n",
      "OPTIMAL true cost: 5 0.1692574918270111\n",
      "REWARD  true cost: 3 0.16991662979125977\n",
      "\n",
      "end-to-end cost: 0.33662962913513184\n",
      "2-stage    cost: 3.4821109771728516\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.2028135359287262\n",
      "RANDOM  true cost:  -1 0.2520521009961764\n",
      "OPTIMAL true cost: 2 0.1961384415626526\n",
      "REWARD  true cost: 7 0.20111875236034393\n",
      "\n",
      "end-to-end cost: 0.2582037150859833\n",
      "2-stage    cost: 2.8936374187469482\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18575772643089294\n",
      "RANDOM  true cost:  -1 0.21442185466488203\n",
      "OPTIMAL true cost: 2 0.1821025013923645\n",
      "REWARD  true cost: 2 0.1821025013923645\n",
      "\n",
      "end-to-end cost: 0.10314726084470749\n",
      "2-stage    cost: 4.335233211517334\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.1039716824889183\n",
      "RANDOM  true cost:  -1 0.14081364031881094\n",
      "OPTIMAL true cost: 8 0.08246371150016785\n",
      "REWARD  true cost: 3 0.12347658723592758\n",
      "\n",
      "end-to-end cost: 0.1640111654996872\n",
      "2-stage    cost: 4.290090560913086\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.13555902242660522\n",
      "RANDOM  true cost:  -1 0.11808813301225503\n",
      "OPTIMAL true cost: 10 0.07186528295278549\n",
      "REWARD  true cost: 2 0.1328705996274948\n",
      "\n",
      "end-to-end cost: 0.1572863906621933\n",
      "2-stage    cost: 3.1585493087768555\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.1654391586780548\n",
      "RANDOM  true cost:  -1 0.1143870751063029\n",
      "OPTIMAL true cost: 1 0.0673275887966156\n",
      "REWARD  true cost: 3 0.10207279771566391\n",
      "\n",
      "end-to-end cost: 0.13605253398418427\n",
      "2-stage    cost: 2.0357978343963623\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.1553889960050583\n",
      "RANDOM  true cost:  -1 0.13458973603943983\n",
      "OPTIMAL true cost: 1 0.08770594000816345\n",
      "REWARD  true cost: 7 0.12304069846868515\n",
      "\n",
      "end-to-end cost: 0.07181879878044128\n",
      "2-stage    cost: 5.207857608795166\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.08396550267934799\n",
      "RANDOM  true cost:  -1 0.09197279221067826\n",
      "OPTIMAL true cost: 0 0.07181879878044128\n",
      "REWARD  true cost: 7 0.10237325727939606\n",
      "\n",
      "end-to-end cost: 0.17130061984062195\n",
      "2-stage    cost: 2.4699740409851074\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.17972658574581146\n",
      "RANDOM  true cost:  -1 0.1817892361432314\n",
      "OPTIMAL true cost: 1 0.1684286892414093\n",
      "REWARD  true cost: 17 0.18815211951732635\n",
      "\n",
      "end-to-end cost: 0.2124294489622116\n",
      "2-stage    cost: 5.392806053161621\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.1640070527791977\n",
      "RANDOM  true cost:  -1 0.183477987224857\n",
      "OPTIMAL true cost: 2 0.1553221493959427\n",
      "REWARD  true cost: 7 0.16258051991462708\n",
      "\n",
      "end-to-end cost: 0.15534958243370056\n",
      "2-stage    cost: 3.2624118328094482\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1328977346420288\n",
      "RANDOM  true cost:  -1 0.1467507854104042\n",
      "OPTIMAL true cost: 1 0.12665659189224243\n",
      "REWARD  true cost: 3 0.13295209407806396\n",
      "\n",
      "end-to-end cost: 1.2474846839904785\n",
      "2-stage    cost: 5.93270206451416\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.450670063495636\n",
      "RANDOM  true cost:  -1 1.007758726676305\n",
      "OPTIMAL true cost: 15 0.44034886360168457\n",
      "REWARD  true cost: 3 1.1772044897079468\n",
      "\n",
      "end-to-end cost: 0.45650264620780945\n",
      "2-stage    cost: 0.9530531764030457\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.47681522369384766\n",
      "RANDOM  true cost:  -1 0.29181880597025156\n",
      "OPTIMAL true cost: 12 0.10806633532047272\n",
      "REWARD  true cost: 7 0.12676934897899628\n",
      "\n",
      "end-to-end cost: 0.23945334553718567\n",
      "2-stage    cost: 0.1293134242296219\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1936866044998169\n",
      "RANDOM  true cost:  -1 0.22209731427331766\n",
      "OPTIMAL true cost: 16 0.1936866044998169\n",
      "REWARD  true cost: 3 0.22988104820251465\n",
      "\n",
      "end-to-end cost: 0.2849917411804199\n",
      "2-stage    cost: 1.9037206172943115\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17047441005706787\n",
      "RANDOM  true cost:  -1 0.2149955698599418\n",
      "OPTIMAL true cost: 2 0.16827166080474854\n",
      "REWARD  true cost: 3 0.16971008479595184\n",
      "\n",
      "end-to-end cost: 0.4088827073574066\n",
      "2-stage    cost: 0.5729281306266785\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2953389883041382\n",
      "RANDOM  true cost:  -1 0.3279958975811799\n",
      "OPTIMAL true cost: 2 0.29366517066955566\n",
      "REWARD  true cost: 2 0.29366517066955566\n",
      "\n",
      "end-to-end cost: 0.5017926096916199\n",
      "2-stage    cost: 0.11412803828716278\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30212265253067017\n",
      "RANDOM  true cost:  -1 0.3700957161684831\n",
      "OPTIMAL true cost: 7 0.30080747604370117\n",
      "REWARD  true cost: 7 0.30080747604370117\n",
      "\n",
      "end-to-end cost: 0.41279613971710205\n",
      "2-stage    cost: 1.2065032720565796\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19391904771327972\n",
      "RANDOM  true cost:  -1 0.27789518361290294\n",
      "OPTIMAL true cost: 7 0.18945705890655518\n",
      "REWARD  true cost: 10 0.22191396355628967\n",
      "\n",
      "end-to-end cost: 0.35941752791404724\n",
      "2-stage    cost: 2.3805665969848633\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1690264195203781\n",
      "RANDOM  true cost:  -1 0.24391755213340124\n",
      "OPTIMAL true cost: 5 0.16723313927650452\n",
      "REWARD  true cost: 8 0.1771899163722992\n",
      "\n",
      "end-to-end cost: 0.29904213547706604\n",
      "2-stage    cost: 2.1806955337524414\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.14722543954849243\n",
      "RANDOM  true cost:  -1 0.20997619132200876\n",
      "OPTIMAL true cost: 2 0.1465681791305542\n",
      "REWARD  true cost: 2 0.1465681791305542\n",
      "\n",
      "end-to-end cost: 0.26296502351760864\n",
      "2-stage    cost: 2.0233514308929443\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.13032671809196472\n",
      "RANDOM  true cost:  -1 0.18615636974573135\n",
      "OPTIMAL true cost: 2 0.1287504881620407\n",
      "REWARD  true cost: 3 0.13032671809196472\n",
      "\n",
      "end-to-end cost: 0.24551519751548767\n",
      "2-stage    cost: 0.6306815147399902\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1370430886745453\n",
      "RANDOM  true cost:  -1 0.18315698206424713\n",
      "OPTIMAL true cost: 2 0.13523796200752258\n",
      "REWARD  true cost: 3 0.1370430886745453\n",
      "\n",
      "end-to-end cost: 0.30290859937667847\n",
      "2-stage    cost: 2.319681167602539\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2057380974292755\n",
      "RANDOM  true cost:  -1 0.24257857662936053\n",
      "OPTIMAL true cost: 2 0.2018222212791443\n",
      "REWARD  true cost: 2 0.2018222212791443\n",
      "\n",
      "end-to-end cost: 0.427068293094635\n",
      "2-stage    cost: 0.058534204959869385\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2694249749183655\n",
      "RANDOM  true cost:  -1 0.3228229930003484\n",
      "OPTIMAL true cost: 5 0.2694249749183655\n",
      "REWARD  true cost: 7 0.27291926741600037\n",
      "\n",
      "end-to-end cost: 0.38945531845092773\n",
      "2-stage    cost: 0.018752247095108032\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1879328489303589\n",
      "RANDOM  true cost:  -1 0.2664193535844485\n",
      "OPTIMAL true cost: 7 0.18754860758781433\n",
      "REWARD  true cost: 10 0.2159397304058075\n",
      "\n",
      "end-to-end cost: 0.3546416163444519\n",
      "2-stage    cost: 2.0369973182678223\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16749446094036102\n",
      "RANDOM  true cost:  -1 0.2408283967524767\n",
      "OPTIMAL true cost: 5 0.16615425050258636\n",
      "REWARD  true cost: 10 0.19423195719718933\n",
      "\n",
      "end-to-end cost: 0.33964499831199646\n",
      "2-stage    cost: 0.543144702911377\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18151259422302246\n",
      "RANDOM  true cost:  -1 0.24339846645792326\n",
      "OPTIMAL true cost: 5 0.18143391609191895\n",
      "REWARD  true cost: 2 0.18160149455070496\n",
      "\n",
      "end-to-end cost: 0.32078373432159424\n",
      "2-stage    cost: 0.8515520095825195\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16676019132137299\n",
      "RANDOM  true cost:  -1 0.22803627389172712\n",
      "OPTIMAL true cost: 2 0.1659241020679474\n",
      "REWARD  true cost: 10 0.18965011835098267\n",
      "\n",
      "end-to-end cost: 0.3383864760398865\n",
      "2-stage    cost: 0.03324641287326813\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.17861372232437134\n",
      "RANDOM  true cost:  -1 0.24111535772681236\n",
      "OPTIMAL true cost: 5 0.17824743688106537\n",
      "REWARD  true cost: 3 0.17861372232437134\n",
      "\n",
      "end-to-end cost: 0.431004136800766\n",
      "2-stage    cost: 0.6170674562454224\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.27155089378356934\n",
      "RANDOM  true cost:  -1 0.32551025226712227\n",
      "OPTIMAL true cost: 2 0.2702394425868988\n",
      "REWARD  true cost: 3 0.27155089378356934\n",
      "\n",
      "end-to-end cost: 0.4652741849422455\n",
      "2-stage    cost: 0.3218490481376648\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2702699303627014\n",
      "RANDOM  true cost:  -1 0.34011795620123547\n",
      "OPTIMAL true cost: 5 0.2686462104320526\n",
      "REWARD  true cost: 6 0.2739938199520111\n",
      "\n",
      "end-to-end cost: 0.3471456468105316\n",
      "2-stage    cost: 1.2875282764434814\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.16507413983345032\n",
      "RANDOM  true cost:  -1 0.23673244069019952\n",
      "OPTIMAL true cost: 5 0.16507413983345032\n",
      "REWARD  true cost: 10 0.19415238499641418\n",
      "\n",
      "end-to-end cost: 0.32784441113471985\n",
      "2-stage    cost: 0.40871185064315796\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18795804679393768\n",
      "RANDOM  true cost:  -1 0.23982208967208862\n",
      "OPTIMAL true cost: 2 0.1851184070110321\n",
      "REWARD  true cost: 3 0.18795804679393768\n",
      "\n",
      "end-to-end cost: 0.37497198581695557\n",
      "2-stage    cost: 0.05535551905632019\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22883814573287964\n",
      "RANDOM  true cost:  -1 0.27894834118584794\n",
      "OPTIMAL true cost: 2 0.22692227363586426\n",
      "REWARD  true cost: 7 0.23349933326244354\n",
      "\n",
      "end-to-end cost: 0.41740986704826355\n",
      "2-stage    cost: 0.019721619784832\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22161108255386353\n",
      "RANDOM  true cost:  -1 0.29152988518277806\n",
      "OPTIMAL true cost: 5 0.21971404552459717\n",
      "REWARD  true cost: 3 0.22161108255386353\n",
      "\n",
      "end-to-end cost: 0.43238839507102966\n",
      "2-stage    cost: 0.08755140006542206\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23848406970500946\n",
      "RANDOM  true cost:  -1 0.3068804647773504\n",
      "OPTIMAL true cost: 5 0.23634123802185059\n",
      "REWARD  true cost: 10 0.264723539352417\n",
      "\n",
      "end-to-end cost: 0.4997047185897827\n",
      "2-stage    cost: 0.20182541012763977\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.29525551199913025\n",
      "RANDOM  true cost:  -1 0.36626694227258366\n",
      "OPTIMAL true cost: 7 0.29420554637908936\n",
      "REWARD  true cost: 10 0.3201303482055664\n",
      "\n",
      "end-to-end cost: 0.5126131772994995\n",
      "2-stage    cost: 0.09440373629331589\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30070605874061584\n",
      "RANDOM  true cost:  -1 0.3731943356494109\n",
      "OPTIMAL true cost: 7 0.29878339171409607\n",
      "REWARD  true cost: 10 0.3241478204727173\n",
      "\n",
      "end-to-end cost: 0.43338543176651\n",
      "2-stage    cost: 0.014757586643099785\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.21466605365276337\n",
      "RANDOM  true cost:  -1 0.2952173035591841\n",
      "OPTIMAL true cost: 7 0.20962515473365784\n",
      "REWARD  true cost: 5 0.21466605365276337\n",
      "\n",
      "end-to-end cost: 0.41143202781677246\n",
      "2-stage    cost: 0.7307388186454773\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.20175442099571228\n",
      "RANDOM  true cost:  -1 0.27945593061546486\n",
      "OPTIMAL true cost: 7 0.1996747851371765\n",
      "REWARD  true cost: 10 0.22915767133235931\n",
      "\n",
      "end-to-end cost: 0.4041023254394531\n",
      "2-stage    cost: 0.051451683044433594\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21948429942131042\n",
      "RANDOM  true cost:  -1 0.2852924590309461\n",
      "OPTIMAL true cost: 5 0.21780744194984436\n",
      "REWARD  true cost: 3 0.21948429942131042\n",
      "\n",
      "end-to-end cost: 0.3981275260448456\n",
      "2-stage    cost: 0.378567636013031\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2071382999420166\n",
      "RANDOM  true cost:  -1 0.27885582111775875\n",
      "OPTIMAL true cost: 5 0.20498722791671753\n",
      "REWARD  true cost: 3 0.2071382999420166\n",
      "\n",
      "end-to-end cost: 0.40142008662223816\n",
      "2-stage    cost: 0.1591130793094635\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21751372516155243\n",
      "RANDOM  true cost:  -1 0.28576950666805107\n",
      "OPTIMAL true cost: 5 0.2157670110464096\n",
      "REWARD  true cost: 7 0.21864214539527893\n",
      "\n",
      "end-to-end cost: 0.4957999587059021\n",
      "2-stage    cost: 0.41659122705459595\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2941212058067322\n",
      "RANDOM  true cost:  -1 0.3611507328848044\n",
      "OPTIMAL true cost: 7 0.2907640337944031\n",
      "REWARD  true cost: 7 0.2907640337944031\n",
      "\n",
      "end-to-end cost: 0.5263628959655762\n",
      "2-stage    cost: 0.0287467148154974\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30049291253089905\n",
      "RANDOM  true cost:  -1 0.3797272555530071\n",
      "OPTIMAL true cost: 7 0.2982763350009918\n",
      "REWARD  true cost: 7 0.2982763350009918\n",
      "\n",
      "end-to-end cost: 0.42232751846313477\n",
      "2-stage    cost: 3.8208446502685547\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.2007756531238556\n",
      "RANDOM  true cost:  -1 0.2830003642787536\n",
      "OPTIMAL true cost: 7 0.19129209220409393\n",
      "REWARD  true cost: 10 0.22704318165779114\n",
      "\n",
      "end-to-end cost: 0.39361000061035156\n",
      "2-stage    cost: 0.8266948461532593\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20389387011528015\n",
      "RANDOM  true cost:  -1 0.27332742263873416\n",
      "OPTIMAL true cost: 5 0.20279225707054138\n",
      "REWARD  true cost: 7 0.2040254920721054\n",
      "\n",
      "end-to-end cost: 0.41227900981903076\n",
      "2-stage    cost: 0.024828996509313583\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22228187322616577\n",
      "RANDOM  true cost:  -1 0.2903632416079442\n",
      "OPTIMAL true cost: 5 0.22112545371055603\n",
      "REWARD  true cost: 3 0.22228187322616577\n",
      "\n",
      "end-to-end cost: 0.41506117582321167\n",
      "2-stage    cost: 0.3251437544822693\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22727607190608978\n",
      "RANDOM  true cost:  -1 0.2930911760777235\n",
      "OPTIMAL true cost: 5 0.22700676321983337\n",
      "REWARD  true cost: 10 0.25507497787475586\n",
      "\n",
      "end-to-end cost: 0.44301456212997437\n",
      "2-stage    cost: 0.028005680069327354\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2413901686668396\n",
      "RANDOM  true cost:  -1 0.31196735613048077\n",
      "OPTIMAL true cost: 5 0.23944281041622162\n",
      "REWARD  true cost: 10 0.2692030370235443\n",
      "\n",
      "end-to-end cost: 0.48895263671875\n",
      "2-stage    cost: 1.5856025218963623\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.281198114156723\n",
      "RANDOM  true cost:  -1 0.3525812824567159\n",
      "OPTIMAL true cost: 7 0.27949756383895874\n",
      "REWARD  true cost: 10 0.3065381944179535\n",
      "\n",
      "end-to-end cost: 0.4971657693386078\n",
      "2-stage    cost: 0.018422510474920273\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2920852601528168\n",
      "RANDOM  true cost:  -1 0.3611378185451031\n",
      "OPTIMAL true cost: 7 0.29039275646209717\n",
      "REWARD  true cost: 10 0.3161020874977112\n",
      "\n",
      "end-to-end cost: 0.421902596950531\n",
      "2-stage    cost: 0.367297887802124\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.22803807258605957\n",
      "RANDOM  true cost:  -1 0.29583848267793655\n",
      "OPTIMAL true cost: 5 0.22803807258605957\n",
      "REWARD  true cost: 10 0.25677821040153503\n",
      "\n",
      "end-to-end cost: 0.4201624393463135\n",
      "2-stage    cost: 0.13330864906311035\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2227143943309784\n",
      "RANDOM  true cost:  -1 0.2925477810204029\n",
      "OPTIMAL true cost: 5 0.2220567911863327\n",
      "REWARD  true cost: 3 0.2227143943309784\n",
      "\n",
      "end-to-end cost: 0.4181463122367859\n",
      "2-stage    cost: 0.16590796411037445\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21467697620391846\n",
      "RANDOM  true cost:  -1 0.28778262188037235\n",
      "OPTIMAL true cost: 7 0.2116677463054657\n",
      "REWARD  true cost: 10 0.24218671023845673\n",
      "\n",
      "end-to-end cost: 0.4138970375061035\n",
      "2-stage    cost: 0.737337052822113\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2079744040966034\n",
      "RANDOM  true cost:  -1 0.28386298194527626\n",
      "OPTIMAL true cost: 7 0.20468096435070038\n",
      "REWARD  true cost: 5 0.20622265338897705\n",
      "\n",
      "end-to-end cost: 0.4379623532295227\n",
      "2-stage    cost: 0.032254718244075775\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23263035714626312\n",
      "RANDOM  true cost:  -1 0.30525296181440353\n",
      "OPTIMAL true cost: 7 0.22967791557312012\n",
      "REWARD  true cost: 10 0.259568452835083\n",
      "\n",
      "end-to-end cost: 0.4973953366279602\n",
      "2-stage    cost: 0.7447742223739624\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.28624898195266724\n",
      "RANDOM  true cost:  -1 0.3594883258144061\n",
      "OPTIMAL true cost: 7 0.28445351123809814\n",
      "REWARD  true cost: 10 0.3117198348045349\n",
      "\n",
      "end-to-end cost: 0.5269696116447449\n",
      "2-stage    cost: 0.02569718286395073\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30502980947494507\n",
      "RANDOM  true cost:  -1 0.38181611026326817\n",
      "OPTIMAL true cost: 7 0.30283769965171814\n",
      "REWARD  true cost: 10 0.3296296298503876\n",
      "\n",
      "end-to-end cost: 0.43292033672332764\n",
      "2-stage    cost: 0.580065131187439\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2083936333656311\n",
      "RANDOM  true cost:  -1 0.2914509146163861\n",
      "OPTIMAL true cost: 7 0.20624688267707825\n",
      "REWARD  true cost: 10 0.2418040931224823\n",
      "\n",
      "end-to-end cost: 0.41189131140708923\n",
      "2-stage    cost: 0.4661308228969574\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21606950461864471\n",
      "RANDOM  true cost:  -1 0.2849266454577446\n",
      "OPTIMAL true cost: 5 0.21556410193443298\n",
      "REWARD  true cost: 10 0.24474768340587616\n",
      "\n",
      "end-to-end cost: 0.4064098298549652\n",
      "2-stage    cost: 0.746062159538269\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21270054578781128\n",
      "RANDOM  true cost:  -1 0.28287246202429134\n",
      "OPTIMAL true cost: 5 0.21106553077697754\n",
      "REWARD  true cost: 3 0.21270054578781128\n",
      "\n",
      "end-to-end cost: 0.4294975996017456\n",
      "2-stage    cost: 0.05034497380256653\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23663848638534546\n",
      "RANDOM  true cost:  -1 0.30360896823306877\n",
      "OPTIMAL true cost: 5 0.23475126922130585\n",
      "REWARD  true cost: 3 0.23663848638534546\n",
      "\n",
      "end-to-end cost: 0.42415517568588257\n",
      "2-stage    cost: 0.15012885630130768\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2297605574131012\n",
      "RANDOM  true cost:  -1 0.29896166548132896\n",
      "OPTIMAL true cost: 5 0.2297605574131012\n",
      "REWARD  true cost: 10 0.2585974633693695\n",
      "\n",
      "end-to-end cost: 0.4832930266857147\n",
      "2-stage    cost: 1.0385456085205078\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2929356098175049\n",
      "RANDOM  true cost:  -1 0.3554735295474529\n",
      "OPTIMAL true cost: 5 0.2916538715362549\n",
      "REWARD  true cost: 10 0.3163415789604187\n",
      "\n",
      "end-to-end cost: 0.5065061450004578\n",
      "2-stage    cost: 0.26310405135154724\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2983984351158142\n",
      "RANDOM  true cost:  -1 0.369635949532191\n",
      "OPTIMAL true cost: 7 0.2969391942024231\n",
      "REWARD  true cost: 10 0.322609007358551\n",
      "\n",
      "end-to-end cost: 0.41563892364501953\n",
      "2-stage    cost: 0.4636786878108978\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.19195395708084106\n",
      "RANDOM  true cost:  -1 0.27529066366453964\n",
      "OPTIMAL true cost: 7 0.19004300236701965\n",
      "REWARD  true cost: 10 0.22315382957458496\n",
      "\n",
      "end-to-end cost: 0.4095444083213806\n",
      "2-stage    cost: 0.17298093438148499\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.20919057726860046\n",
      "RANDOM  true cost:  -1 0.2780008551975091\n",
      "OPTIMAL true cost: 7 0.20265057682991028\n",
      "REWARD  true cost: 10 0.23188623785972595\n",
      "\n",
      "end-to-end cost: 0.38844043016433716\n",
      "2-stage    cost: 1.3959341049194336\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1833532303571701\n",
      "RANDOM  true cost:  -1 0.2591928355395794\n",
      "OPTIMAL true cost: 7 0.18047408759593964\n",
      "REWARD  true cost: 10 0.21009892225265503\n",
      "\n",
      "end-to-end cost: 0.385731041431427\n",
      "2-stage    cost: 0.5902472734451294\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1907104253768921\n",
      "RANDOM  true cost:  -1 0.26394308047990006\n",
      "OPTIMAL true cost: 5 0.18899784982204437\n",
      "REWARD  true cost: 17 0.29719001054763794\n",
      "\n",
      "end-to-end cost: 0.39142704010009766\n",
      "2-stage    cost: 0.6424399018287659\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1945764422416687\n",
      "RANDOM  true cost:  -1 0.26889292150735855\n",
      "OPTIMAL true cost: 5 0.19315288960933685\n",
      "REWARD  true cost: 17 0.29997724294662476\n",
      "\n",
      "end-to-end cost: 0.4812524914741516\n",
      "2-stage    cost: 0.5807844996452332\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.26984548568725586\n",
      "RANDOM  true cost:  -1 0.34293102597196895\n",
      "OPTIMAL true cost: 7 0.2682899832725525\n",
      "REWARD  true cost: 17 0.35966619849205017\n",
      "\n",
      "end-to-end cost: 0.4891226291656494\n",
      "2-stage    cost: 0.32431760430336\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2767067849636078\n",
      "RANDOM  true cost:  -1 0.3476856177051862\n",
      "OPTIMAL true cost: 7 0.2743884027004242\n",
      "REWARD  true cost: 10 0.30111560225486755\n",
      "\n",
      "end-to-end cost: 0.39866575598716736\n",
      "2-stage    cost: 0.7553491592407227\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19516560435295105\n",
      "RANDOM  true cost:  -1 0.26606633079548675\n",
      "OPTIMAL true cost: 7 0.19313953816890717\n",
      "REWARD  true cost: 10 0.2225721776485443\n",
      "\n",
      "end-to-end cost: 0.3907511234283447\n",
      "2-stage    cost: 0.09892623126506805\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20136213302612305\n",
      "RANDOM  true cost:  -1 0.26902434540291625\n",
      "OPTIMAL true cost: 5 0.2005351036787033\n",
      "REWARD  true cost: 17 0.2894524931907654\n",
      "\n",
      "end-to-end cost: 0.40112754702568054\n",
      "2-stage    cost: 1.1508523225784302\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.21831533312797546\n",
      "RANDOM  true cost:  -1 0.27905027692516643\n",
      "OPTIMAL true cost: 5 0.21293072402477264\n",
      "REWARD  true cost: 3 0.2139207124710083\n",
      "\n",
      "end-to-end cost: 0.3810160160064697\n",
      "2-stage    cost: 0.19940964877605438\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2027733027935028\n",
      "RANDOM  true cost:  -1 0.2655169318119685\n",
      "OPTIMAL true cost: 5 0.20231454074382782\n",
      "REWARD  true cost: 2 0.2038331925868988\n",
      "\n",
      "end-to-end cost: 0.3814997673034668\n",
      "2-stage    cost: 0.08862423896789551\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19941966235637665\n",
      "RANDOM  true cost:  -1 0.2639741289118926\n",
      "OPTIMAL true cost: 3 0.19941966235637665\n",
      "REWARD  true cost: 10 0.22693145275115967\n",
      "\n",
      "end-to-end cost: 0.45067545771598816\n",
      "2-stage    cost: 0.43655121326446533\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2788412570953369\n",
      "RANDOM  true cost:  -1 0.3346220577756564\n",
      "OPTIMAL true cost: 5 0.27849891781806946\n",
      "REWARD  true cost: 17 0.3376527428627014\n",
      "\n",
      "end-to-end cost: 0.48253756761550903\n",
      "2-stage    cost: 0.062261492013931274\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2999226450920105\n",
      "RANDOM  true cost:  -1 0.3571782124539216\n",
      "OPTIMAL true cost: 5 0.29802942276000977\n",
      "REWARD  true cost: 10 0.320930540561676\n",
      "\n",
      "end-to-end cost: 0.40503281354904175\n",
      "2-stage    cost: 0.3620072305202484\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1976863145828247\n",
      "RANDOM  true cost:  -1 0.27188229995469254\n",
      "OPTIMAL true cost: 7 0.19655315577983856\n",
      "REWARD  true cost: 10 0.2276638150215149\n",
      "\n",
      "end-to-end cost: 0.4010087847709656\n",
      "2-stage    cost: 0.06862941384315491\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21004347503185272\n",
      "RANDOM  true cost:  -1 0.27728421178956825\n",
      "OPTIMAL true cost: 5 0.20886078476905823\n",
      "REWARD  true cost: 17 0.29599303007125854\n",
      "\n",
      "end-to-end cost: 0.3971993923187256\n",
      "2-stage    cost: 0.0411667600274086\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2050902545452118\n",
      "RANDOM  true cost:  -1 0.2734263800084591\n",
      "OPTIMAL true cost: 5 0.20388196408748627\n",
      "REWARD  true cost: 10 0.23218536376953125\n",
      "\n",
      "end-to-end cost: 0.3945065140724182\n",
      "2-stage    cost: 0.36437785625457764\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19859832525253296\n",
      "RANDOM  true cost:  -1 0.26920725032687187\n",
      "OPTIMAL true cost: 5 0.19743919372558594\n",
      "REWARD  true cost: 10 0.22692792117595673\n",
      "\n",
      "end-to-end cost: 0.3913986384868622\n",
      "2-stage    cost: 0.39142853021621704\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19794166088104248\n",
      "RANDOM  true cost:  -1 0.2664514196415742\n",
      "OPTIMAL true cost: 3 0.19794166088104248\n",
      "REWARD  true cost: 10 0.2265246957540512\n",
      "\n",
      "end-to-end cost: 0.45361757278442383\n",
      "2-stage    cost: 0.16393354535102844\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.28748223185539246\n",
      "RANDOM  true cost:  -1 0.34066350509723026\n",
      "OPTIMAL true cost: 5 0.2873099148273468\n",
      "REWARD  true cost: 7 0.2906879484653473\n",
      "\n",
      "end-to-end cost: 0.43118816614151\n",
      "2-stage    cost: 2.4877805709838867\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2527349591255188\n",
      "RANDOM  true cost:  -1 0.3117038930455844\n",
      "OPTIMAL true cost: 5 0.2511252164840698\n",
      "REWARD  true cost: 10 0.27369168400764465\n",
      "\n",
      "end-to-end cost: 0.34003257751464844\n",
      "2-stage    cost: 0.7299231886863708\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18522754311561584\n",
      "RANDOM  true cost:  -1 0.23833316999177137\n",
      "OPTIMAL true cost: 2 0.1825554072856903\n",
      "REWARD  true cost: 7 0.19091825187206268\n",
      "\n",
      "end-to-end cost: 0.3561677932739258\n",
      "2-stage    cost: 0.09572487324476242\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21725177764892578\n",
      "RANDOM  true cost:  -1 0.261522797246774\n",
      "OPTIMAL true cost: 2 0.21342508494853973\n",
      "REWARD  true cost: 3 0.21725177764892578\n",
      "\n",
      "end-to-end cost: 0.37281593680381775\n",
      "2-stage    cost: 0.11544942855834961\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2279571145772934\n",
      "RANDOM  true cost:  -1 0.2741093846658866\n",
      "OPTIMAL true cost: 2 0.22419320046901703\n",
      "REWARD  true cost: 10 0.25081247091293335\n",
      "\n",
      "end-to-end cost: 0.4825555682182312\n",
      "2-stage    cost: 0.07725053280591965\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.31182312965393066\n",
      "RANDOM  true cost:  -1 0.359537264953057\n",
      "OPTIMAL true cost: 5 0.3013334274291992\n",
      "REWARD  true cost: 10 0.32387956976890564\n",
      "\n",
      "end-to-end cost: 0.48381996154785156\n",
      "2-stage    cost: 0.06940673291683197\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.26248738169670105\n",
      "RANDOM  true cost:  -1 0.3390861786901951\n",
      "OPTIMAL true cost: 7 0.2595676779747009\n",
      "REWARD  true cost: 10 0.28887251019477844\n",
      "\n",
      "end-to-end cost: 0.4640386998653412\n",
      "2-stage    cost: 1.8000907897949219\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.24781489372253418\n",
      "RANDOM  true cost:  -1 0.3250972057382266\n",
      "OPTIMAL true cost: 7 0.2455597221851349\n",
      "REWARD  true cost: 10 0.2731326222419739\n",
      "\n",
      "end-to-end cost: 0.44767850637435913\n",
      "2-stage    cost: 0.4650495946407318\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2564031481742859\n",
      "RANDOM  true cost:  -1 0.3213202046851317\n",
      "OPTIMAL true cost: 5 0.25557637214660645\n",
      "REWARD  true cost: 10 0.27883556485176086\n",
      "\n",
      "end-to-end cost: 0.35831528902053833\n",
      "2-stage    cost: 0.23339179158210754\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19800174236297607\n",
      "RANDOM  true cost:  -1 0.2524636077384154\n",
      "OPTIMAL true cost: 2 0.19514207541942596\n",
      "REWARD  true cost: 10 0.2222369909286499\n",
      "\n",
      "end-to-end cost: 0.37141627073287964\n",
      "2-stage    cost: 0.03424941003322601\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20504717528820038\n",
      "RANDOM  true cost:  -1 0.2636691027631362\n",
      "OPTIMAL true cost: 5 0.20456354320049286\n",
      "REWARD  true cost: 10 0.2302507609128952\n",
      "\n",
      "end-to-end cost: 0.3788146376609802\n",
      "2-stage    cost: 0.015743765980005264\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19461584091186523\n",
      "RANDOM  true cost:  -1 0.2605365638931592\n",
      "OPTIMAL true cost: 5 0.19309958815574646\n",
      "REWARD  true cost: 17 0.27987366914749146\n",
      "\n",
      "end-to-end cost: 0.3372601270675659\n",
      "2-stage    cost: 2.2526257038116455\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16811369359493256\n",
      "RANDOM  true cost:  -1 0.2294220613936583\n",
      "OPTIMAL true cost: 3 0.16811369359493256\n",
      "REWARD  true cost: 10 0.19536618888378143\n",
      "\n",
      "end-to-end cost: 0.35995030403137207\n",
      "2-stage    cost: 0.10671161860227585\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22181737422943115\n",
      "RANDOM  true cost:  -1 0.2654300183057785\n",
      "OPTIMAL true cost: 2 0.21868197619915009\n",
      "REWARD  true cost: 17 0.26297056674957275\n",
      "\n",
      "end-to-end cost: 0.41210150718688965\n",
      "2-stage    cost: 0.6983555555343628\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.26985204219818115\n",
      "RANDOM  true cost:  -1 0.3125866974393527\n",
      "OPTIMAL true cost: 2 0.26634103059768677\n",
      "REWARD  true cost: 10 0.28952622413635254\n",
      "\n",
      "end-to-end cost: 0.4297568202018738\n",
      "2-stage    cost: 0.015358632430434227\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.27783459424972534\n",
      "RANDOM  true cost:  -1 0.3245198739071687\n",
      "OPTIMAL true cost: 2 0.2752886712551117\n",
      "REWARD  true cost: 10 0.29788878560066223\n",
      "\n",
      "end-to-end cost: 0.33866453170776367\n",
      "2-stage    cost: 0.2804459035396576\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18617133796215057\n",
      "RANDOM  true cost:  -1 0.23846367498238882\n",
      "OPTIMAL true cost: 2 0.1836574673652649\n",
      "REWARD  true cost: 10 0.21158307790756226\n",
      "\n",
      "end-to-end cost: 0.32987555861473083\n",
      "2-stage    cost: 0.07254486531019211\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20246700942516327\n",
      "RANDOM  true cost:  -1 0.24321196538706621\n",
      "OPTIMAL true cost: 2 0.19883298873901367\n",
      "REWARD  true cost: 6 0.21168732643127441\n",
      "\n",
      "end-to-end cost: 0.34963077306747437\n",
      "2-stage    cost: 0.021211324259638786\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20738843083381653\n",
      "RANDOM  true cost:  -1 0.2537928447127342\n",
      "OPTIMAL true cost: 2 0.20404955744743347\n",
      "REWARD  true cost: 10 0.23062124848365784\n",
      "\n",
      "end-to-end cost: 0.3628213405609131\n",
      "2-stage    cost: 0.24400243163108826\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19063380360603333\n",
      "RANDOM  true cost:  -1 0.25090479105710983\n",
      "OPTIMAL true cost: 5 0.18992885947227478\n",
      "REWARD  true cost: 2 0.19150285422801971\n",
      "\n",
      "end-to-end cost: 0.37594231963157654\n",
      "2-stage    cost: 0.02916787378489971\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20599083602428436\n",
      "RANDOM  true cost:  -1 0.26516178001960117\n",
      "OPTIMAL true cost: 5 0.2057194709777832\n",
      "REWARD  true cost: 10 0.23218655586242676\n",
      "\n",
      "end-to-end cost: 0.45532071590423584\n",
      "2-stage    cost: 0.03170974552631378\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2768517732620239\n",
      "RANDOM  true cost:  -1 0.3360612938801448\n",
      "OPTIMAL true cost: 5 0.2746874690055847\n",
      "REWARD  true cost: 17 0.34472689032554626\n",
      "\n",
      "end-to-end cost: 0.4752431809902191\n",
      "2-stage    cost: 0.02680170349776745\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2724047303199768\n",
      "RANDOM  true cost:  -1 0.3421713163455327\n",
      "OPTIMAL true cost: 7 0.271153062582016\n",
      "REWARD  true cost: 10 0.2956276535987854\n",
      "\n",
      "end-to-end cost: 0.3777216374874115\n",
      "2-stage    cost: 0.24350658059120178\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17046582698822021\n",
      "RANDOM  true cost:  -1 0.2486927801122268\n",
      "OPTIMAL true cost: 7 0.1697550117969513\n",
      "REWARD  true cost: 10 0.19997632503509521\n",
      "\n",
      "end-to-end cost: 0.36778363585472107\n",
      "2-stage    cost: 0.029484223574399948\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19060085713863373\n",
      "RANDOM  true cost:  -1 0.2539389195541541\n",
      "OPTIMAL true cost: 5 0.18895035982131958\n",
      "REWARD  true cost: 10 0.21724733710289001\n",
      "\n",
      "end-to-end cost: 0.37469035387039185\n",
      "2-stage    cost: 0.03805512934923172\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2100956290960312\n",
      "RANDOM  true cost:  -1 0.2658104555060466\n",
      "OPTIMAL true cost: 5 0.20987895131111145\n",
      "REWARD  true cost: 10 0.23565077781677246\n",
      "\n",
      "end-to-end cost: 0.36121630668640137\n",
      "2-stage    cost: 0.6590855121612549\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.18579304218292236\n",
      "RANDOM  true cost:  -1 0.24907436532278857\n",
      "OPTIMAL true cost: 5 0.1846051663160324\n",
      "REWARD  true cost: 7 0.1879977434873581\n",
      "\n",
      "end-to-end cost: 0.32336586713790894\n",
      "2-stage    cost: 0.8696929812431335\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1761312335729599\n",
      "RANDOM  true cost:  -1 0.22876925766468048\n",
      "OPTIMAL true cost: 2 0.17378883063793182\n",
      "REWARD  true cost: 10 0.20138633251190186\n",
      "\n",
      "end-to-end cost: 0.3612470030784607\n",
      "2-stage    cost: 0.6980557441711426\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.26015979051589966\n",
      "RANDOM  true cost:  -1 0.2872697189450264\n",
      "OPTIMAL true cost: 2 0.2559799551963806\n",
      "REWARD  true cost: 7 0.2654761075973511\n",
      "\n",
      "end-to-end cost: 0.3940735459327698\n",
      "2-stage    cost: 0.03178884834051132\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2802213132381439\n",
      "RANDOM  true cost:  -1 0.3106033330162366\n",
      "OPTIMAL true cost: 2 0.2764672040939331\n",
      "REWARD  true cost: 10 0.2946109175682068\n",
      "\n",
      "end-to-end cost: 0.34588462114334106\n",
      "2-stage    cost: 0.04006355628371239\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20620176196098328\n",
      "RANDOM  true cost:  -1 0.2538119504849116\n",
      "OPTIMAL true cost: 2 0.2038663625717163\n",
      "REWARD  true cost: 17 0.25997665524482727\n",
      "\n",
      "end-to-end cost: 0.3768994212150574\n",
      "2-stage    cost: 0.04094017297029495\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21407181024551392\n",
      "RANDOM  true cost:  -1 0.27035845443606377\n",
      "OPTIMAL true cost: 5 0.21389588713645935\n",
      "REWARD  true cost: 10 0.23902398347854614\n",
      "\n",
      "end-to-end cost: 0.38802143931388855\n",
      "2-stage    cost: 0.03848883509635925\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2176932990550995\n",
      "RANDOM  true cost:  -1 0.27710433801015216\n",
      "OPTIMAL true cost: 5 0.217035174369812\n",
      "REWARD  true cost: 10 0.24374952912330627\n",
      "\n",
      "end-to-end cost: 0.4629095494747162\n",
      "2-stage    cost: 0.10026373714208603\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.27133047580718994\n",
      "RANDOM  true cost:  -1 0.33511515458424884\n",
      "OPTIMAL true cost: 5 0.26799172163009644\n",
      "REWARD  true cost: 10 0.29435089230537415\n",
      "\n",
      "end-to-end cost: 0.4923422336578369\n",
      "2-stage    cost: 0.1496654748916626\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.2960585653781891\n",
      "RANDOM  true cost:  -1 0.35637390861908597\n",
      "OPTIMAL true cost: 7 0.28717130422592163\n",
      "REWARD  true cost: 10 0.31163570284843445\n",
      "\n",
      "end-to-end cost: 0.48241639137268066\n",
      "2-stage    cost: 0.8494263887405396\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2679535150527954\n",
      "RANDOM  true cost:  -1 0.34303275495767593\n",
      "OPTIMAL true cost: 7 0.26586753129959106\n",
      "REWARD  true cost: 10 0.2931317687034607\n",
      "\n",
      "end-to-end cost: 0.4703825116157532\n",
      "2-stage    cost: 0.09388434141874313\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2650989294052124\n",
      "RANDOM  true cost:  -1 0.33577771484851837\n",
      "OPTIMAL true cost: 7 0.2633489966392517\n",
      "REWARD  true cost: 2 0.2729937434196472\n",
      "\n",
      "end-to-end cost: 0.35525697469711304\n",
      "2-stage    cost: 0.49295663833618164\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.17846113443374634\n",
      "RANDOM  true cost:  -1 0.2436933989326159\n",
      "OPTIMAL true cost: 3 0.17828369140625\n",
      "REWARD  true cost: 10 0.204519122838974\n",
      "\n",
      "end-to-end cost: 0.377617210149765\n",
      "2-stage    cost: 0.07534309476613998\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23411688208580017\n",
      "RANDOM  true cost:  -1 0.2820431689421336\n",
      "OPTIMAL true cost: 2 0.23185889422893524\n",
      "REWARD  true cost: 10 0.25477033853530884\n",
      "\n",
      "end-to-end cost: 0.37632691860198975\n",
      "2-stage    cost: 0.09015467017889023\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21729505062103271\n",
      "RANDOM  true cost:  -1 0.27195351632932824\n",
      "OPTIMAL true cost: 2 0.2165592610836029\n",
      "REWARD  true cost: 10 0.24061059951782227\n",
      "\n",
      "end-to-end cost: 0.37726959586143494\n",
      "2-stage    cost: 0.04638725146651268\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21396708488464355\n",
      "RANDOM  true cost:  -1 0.2715417668223381\n",
      "OPTIMAL true cost: 5 0.21375340223312378\n",
      "REWARD  true cost: 10 0.23775355517864227\n",
      "\n",
      "end-to-end cost: 0.40698298811912537\n",
      "2-stage    cost: 0.268675297498703\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.2620694637298584\n",
      "RANDOM  true cost:  -1 0.3035442866384983\n",
      "OPTIMAL true cost: 2 0.2529086470603943\n",
      "REWARD  true cost: 10 0.27437925338745117\n",
      "\n",
      "end-to-end cost: 0.405073881149292\n",
      "2-stage    cost: 0.9382479190826416\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.251253604888916\n",
      "RANDOM  true cost:  -1 0.3020879998803139\n",
      "OPTIMAL true cost: 2 0.24766413867473602\n",
      "REWARD  true cost: 7 0.2538992464542389\n",
      "\n",
      "end-to-end cost: 0.39904671907424927\n",
      "2-stage    cost: 0.7334415912628174\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2670226991176605\n",
      "RANDOM  true cost:  -1 0.30871250728766125\n",
      "OPTIMAL true cost: 2 0.26356929540634155\n",
      "REWARD  true cost: 7 0.2719455361366272\n",
      "\n",
      "end-to-end cost: 0.29463326930999756\n",
      "2-stage    cost: 1.0225131511688232\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.15844511985778809\n",
      "RANDOM  true cost:  -1 0.2050414402037859\n",
      "OPTIMAL true cost: 2 0.15430760383605957\n",
      "REWARD  true cost: 10 0.18100091814994812\n",
      "\n",
      "end-to-end cost: 0.24651353061199188\n",
      "2-stage    cost: 0.68923419713974\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1698472499847412\n",
      "RANDOM  true cost:  -1 0.19635028516252837\n",
      "OPTIMAL true cost: 16 0.1698472499847412\n",
      "REWARD  true cost: 17 0.17630045115947723\n",
      "\n",
      "end-to-end cost: 0.2640267312526703\n",
      "2-stage    cost: 0.296793669462204\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.18271902203559875\n",
      "RANDOM  true cost:  -1 0.2153529499967893\n",
      "OPTIMAL true cost: 16 0.18271902203559875\n",
      "REWARD  true cost: 7 0.21252986788749695\n",
      "\n",
      "end-to-end cost: 0.2948303818702698\n",
      "2-stage    cost: 0.14746597409248352\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.20173363387584686\n",
      "RANDOM  true cost:  -1 0.22810271568596363\n",
      "OPTIMAL true cost: 2 0.20015375316143036\n",
      "REWARD  true cost: 5 0.21111325919628143\n",
      "\n",
      "end-to-end cost: 0.31197893619537354\n",
      "2-stage    cost: 0.36269304156303406\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20132604241371155\n",
      "RANDOM  true cost:  -1 0.23561486105124155\n",
      "OPTIMAL true cost: 2 0.1968977302312851\n",
      "REWARD  true cost: 5 0.20514020323753357\n",
      "\n",
      "end-to-end cost: 0.4180520176887512\n",
      "2-stage    cost: 0.031115930527448654\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.27467843890190125\n",
      "RANDOM  true cost:  -1 0.31961094588041306\n",
      "OPTIMAL true cost: 2 0.27467843890190125\n",
      "REWARD  true cost: 3 0.2781275510787964\n",
      "\n",
      "end-to-end cost: 0.4128274917602539\n",
      "2-stage    cost: 3.0109333992004395\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2497987002134323\n",
      "RANDOM  true cost:  -1 0.3032372072339058\n",
      "OPTIMAL true cost: 2 0.24712269008159637\n",
      "REWARD  true cost: 10 0.2682521939277649\n",
      "\n",
      "end-to-end cost: 0.25801628828048706\n",
      "2-stage    cost: 1.831795573234558\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18744516372680664\n",
      "RANDOM  true cost:  -1 0.193368935957551\n",
      "OPTIMAL true cost: 2 0.1519232839345932\n",
      "REWARD  true cost: 10 0.1744575798511505\n",
      "\n",
      "end-to-end cost: 0.2571694552898407\n",
      "2-stage    cost: 1.6158206462860107\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.18322274088859558\n",
      "RANDOM  true cost:  -1 0.1999787501990795\n",
      "OPTIMAL true cost: 2 0.17282800376415253\n",
      "REWARD  true cost: 7 0.18401587009429932\n",
      "\n",
      "end-to-end cost: 0.20460698008537292\n",
      "2-stage    cost: 1.8917293548583984\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1402980536222458\n",
      "RANDOM  true cost:  -1 0.17158240266144276\n",
      "OPTIMAL true cost: 16 0.1402980536222458\n",
      "REWARD  true cost: 7 0.16932307183742523\n",
      "\n",
      "end-to-end cost: 0.28004759550094604\n",
      "2-stage    cost: 0.2700323760509491\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.19968855381011963\n",
      "RANDOM  true cost:  -1 0.2329162129511436\n",
      "OPTIMAL true cost: 16 0.19968855381011963\n",
      "REWARD  true cost: 17 0.20402169227600098\n",
      "\n",
      "end-to-end cost: 0.33569884300231934\n",
      "2-stage    cost: 0.047300368547439575\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2060907781124115\n",
      "RANDOM  true cost:  -1 0.24678288089732328\n",
      "OPTIMAL true cost: 2 0.20185279846191406\n",
      "REWARD  true cost: 5 0.20879702270030975\n",
      "\n",
      "end-to-end cost: 0.38171395659446716\n",
      "2-stage    cost: 4.48817777633667\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23123471438884735\n",
      "RANDOM  true cost:  -1 0.283672006179889\n",
      "OPTIMAL true cost: 2 0.2285541146993637\n",
      "REWARD  true cost: 3 0.23123471438884735\n",
      "\n",
      "end-to-end cost: 0.3751809000968933\n",
      "2-stage    cost: 2.2938740253448486\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.24668821692466736\n",
      "RANDOM  true cost:  -1 0.2869765553623438\n",
      "OPTIMAL true cost: 2 0.2404494732618332\n",
      "REWARD  true cost: 7 0.25001490116119385\n",
      "\n",
      "end-to-end cost: 0.2301112413406372\n",
      "2-stage    cost: 7.393540859222412\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.16526809334754944\n",
      "RANDOM  true cost:  -1 0.17822753017147383\n",
      "OPTIMAL true cost: 2 0.1470421403646469\n",
      "REWARD  true cost: 17 0.17212140560150146\n",
      "\n",
      "end-to-end cost: 0.20164906978607178\n",
      "2-stage    cost: 0.5440360307693481\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14355462789535522\n",
      "RANDOM  true cost:  -1 0.17814119222263494\n",
      "OPTIMAL true cost: 16 0.14355462789535522\n",
      "REWARD  true cost: 17 0.14753001928329468\n",
      "\n",
      "end-to-end cost: 0.2104312628507614\n",
      "2-stage    cost: 0.734444797039032\n",
      "TRUE\n",
      "CHOSEN  true cost: 17 0.15609170496463776\n",
      "RANDOM  true cost:  -1 0.18548674881458282\n",
      "OPTIMAL true cost: 16 0.15301144123077393\n",
      "REWARD  true cost: 17 0.15609170496463776\n",
      "\n",
      "end-to-end cost: 0.2220059335231781\n",
      "2-stage    cost: 0.9476785659790039\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15696795284748077\n",
      "RANDOM  true cost:  -1 0.18560227937996387\n",
      "OPTIMAL true cost: 16 0.15696795284748077\n",
      "REWARD  true cost: 17 0.16167809069156647\n",
      "\n",
      "end-to-end cost: 0.22192883491516113\n",
      "2-stage    cost: 2.476309299468994\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15681760013103485\n",
      "RANDOM  true cost:  -1 0.18430985696613789\n",
      "OPTIMAL true cost: 16 0.15681760013103485\n",
      "REWARD  true cost: 7 0.18311914801597595\n",
      "\n",
      "end-to-end cost: 0.2977568507194519\n",
      "2-stage    cost: 1.601172685623169\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2389361560344696\n",
      "RANDOM  true cost:  -1 0.25286627126236755\n",
      "OPTIMAL true cost: 16 0.2255387008190155\n",
      "REWARD  true cost: 2 0.2389361560344696\n",
      "\n",
      "end-to-end cost: 0.3202771246433258\n",
      "2-stage    cost: 1.0898159742355347\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2565954923629761\n",
      "RANDOM  true cost:  -1 0.2641397671153148\n",
      "OPTIMAL true cost: 16 0.23293326795101166\n",
      "REWARD  true cost: 6 0.26224562525749207\n",
      "\n",
      "end-to-end cost: 0.2910534143447876\n",
      "2-stage    cost: 0.2164074182510376\n",
      "TRUE\n",
      "CHOSEN  true cost: 13 0.22154764831066132\n",
      "RANDOM  true cost:  -1 0.22553550451993942\n",
      "OPTIMAL true cost: 2 0.19787633419036865\n",
      "REWARD  true cost: 7 0.21051228046417236\n",
      "\n",
      "end-to-end cost: 0.3251766562461853\n",
      "2-stage    cost: 0.7170777320861816\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2016526758670807\n",
      "RANDOM  true cost:  -1 0.24156136686603227\n",
      "OPTIMAL true cost: 2 0.19815103709697723\n",
      "REWARD  true cost: 17 0.24127250909805298\n",
      "\n",
      "end-to-end cost: 0.2835058569908142\n",
      "2-stage    cost: 2.830522298812866\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16018754243850708\n",
      "RANDOM  true cost:  -1 0.20330002903938293\n",
      "OPTIMAL true cost: 2 0.1558327078819275\n",
      "REWARD  true cost: 7 0.185014545917511\n",
      "\n",
      "end-to-end cost: 0.2970389723777771\n",
      "2-stage    cost: 0.22151754796504974\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.20989958941936493\n",
      "RANDOM  true cost:  -1 0.2280198453615109\n",
      "OPTIMAL true cost: 2 0.19543921947479248\n",
      "REWARD  true cost: 7 0.207683727145195\n",
      "\n",
      "end-to-end cost: 0.2952520251274109\n",
      "2-stage    cost: 2.5450963973999023\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.17227086424827576\n",
      "RANDOM  true cost:  -1 0.21531313844025135\n",
      "OPTIMAL true cost: 2 0.16752979159355164\n",
      "REWARD  true cost: 17 0.22199749946594238\n",
      "\n",
      "end-to-end cost: 0.3917808532714844\n",
      "2-stage    cost: 0.6099627614021301\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.3069361746311188\n",
      "RANDOM  true cost:  -1 0.32322027658422786\n",
      "OPTIMAL true cost: 16 0.292402446269989\n",
      "REWARD  true cost: 3 0.3069361746311188\n",
      "\n",
      "end-to-end cost: 0.4651782214641571\n",
      "2-stage    cost: 0.0425519160926342\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.29813021421432495\n",
      "RANDOM  true cost:  -1 0.35034459705154103\n",
      "OPTIMAL true cost: 2 0.2979450225830078\n",
      "REWARD  true cost: 7 0.301535964012146\n",
      "\n",
      "end-to-end cost: 0.40069326758384705\n",
      "2-stage    cost: 0.4048278331756592\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.19263111054897308\n",
      "RANDOM  true cost:  -1 0.2687317008773486\n",
      "OPTIMAL true cost: 7 0.19181615114212036\n",
      "REWARD  true cost: 10 0.2227916121482849\n",
      "\n",
      "end-to-end cost: 0.3635573089122772\n",
      "2-stage    cost: 0.4015754163265228\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20658406615257263\n",
      "RANDOM  true cost:  -1 0.2591735565414031\n",
      "OPTIMAL true cost: 2 0.204393669962883\n",
      "REWARD  true cost: 6 0.2160361111164093\n",
      "\n",
      "end-to-end cost: 0.38659536838531494\n",
      "2-stage    cost: 0.027783840894699097\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21503743529319763\n",
      "RANDOM  true cost:  -1 0.2738869159171979\n",
      "OPTIMAL true cost: 3 0.21503743529319763\n",
      "REWARD  true cost: 17 0.28431665897369385\n",
      "\n",
      "end-to-end cost: 0.3606991171836853\n",
      "2-stage    cost: 2.101851224899292\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.17791160941123962\n",
      "RANDOM  true cost:  -1 0.2446316902836164\n",
      "OPTIMAL true cost: 3 0.17791160941123962\n",
      "REWARD  true cost: 6 0.18461516499519348\n",
      "\n",
      "end-to-end cost: 0.34407100081443787\n",
      "2-stage    cost: 0.4092063903808594\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20242737233638763\n",
      "RANDOM  true cost:  -1 0.24874526945253214\n",
      "OPTIMAL true cost: 2 0.1984272003173828\n",
      "REWARD  true cost: 10 0.22620496153831482\n",
      "\n",
      "end-to-end cost: 0.42422598600387573\n",
      "2-stage    cost: 0.12771442532539368\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2848411798477173\n",
      "RANDOM  true cost:  -1 0.32558396210273105\n",
      "OPTIMAL true cost: 2 0.2804328501224518\n",
      "REWARD  true cost: 17 0.31726711988449097\n",
      "\n",
      "end-to-end cost: 0.44161972403526306\n",
      "2-stage    cost: 0.12366147339344025\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.29005104303359985\n",
      "RANDOM  true cost:  -1 0.3343345622221629\n",
      "OPTIMAL true cost: 2 0.2844715118408203\n",
      "REWARD  true cost: 7 0.29238319396972656\n",
      "\n",
      "end-to-end cost: 0.36897286772727966\n",
      "2-stage    cost: 1.0521173477172852\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19436880946159363\n",
      "RANDOM  true cost:  -1 0.25575660169124603\n",
      "OPTIMAL true cost: 3 0.19436880946159363\n",
      "REWARD  true cost: 3 0.19436880946159363\n",
      "\n",
      "end-to-end cost: 0.32487958669662476\n",
      "2-stage    cost: 2.176077365875244\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1673734188079834\n",
      "RANDOM  true cost:  -1 0.22437365849812826\n",
      "OPTIMAL true cost: 2 0.16542251408100128\n",
      "REWARD  true cost: 10 0.19355450570583344\n",
      "\n",
      "end-to-end cost: 0.2712482213973999\n",
      "2-stage    cost: 1.9695199728012085\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.16334661841392517\n",
      "RANDOM  true cost:  -1 0.19874612614512444\n",
      "OPTIMAL true cost: 2 0.1582285463809967\n",
      "REWARD  true cost: 3 0.16334661841392517\n",
      "\n",
      "end-to-end cost: 0.2429376095533371\n",
      "2-stage    cost: 0.6925665736198425\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.17530135810375214\n",
      "RANDOM  true cost:  -1 0.19412940492232642\n",
      "OPTIMAL true cost: 16 0.17123600840568542\n",
      "REWARD  true cost: 7 0.1852579116821289\n",
      "\n",
      "end-to-end cost: 0.23180937767028809\n",
      "2-stage    cost: 0.8056355714797974\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.16420182585716248\n",
      "RANDOM  true cost:  -1 0.1926074450214704\n",
      "OPTIMAL true cost: 16 0.16420182585716248\n",
      "REWARD  true cost: 3 0.1872478425502777\n",
      "\n",
      "end-to-end cost: 0.27218273282051086\n",
      "2-stage    cost: 4.563994407653809\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.21432402729988098\n",
      "RANDOM  true cost:  -1 0.22920327509442964\n",
      "OPTIMAL true cost: 16 0.2019808292388916\n",
      "REWARD  true cost: 17 0.2055412232875824\n",
      "\n",
      "end-to-end cost: 0.29104873538017273\n",
      "2-stage    cost: 0.7777692675590515\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.24148225784301758\n",
      "RANDOM  true cost:  -1 0.2602909505367279\n",
      "OPTIMAL true cost: 16 0.21787838637828827\n",
      "REWARD  true cost: 18 0.23719076812267303\n",
      "\n",
      "end-to-end cost: 0.27351367473602295\n",
      "2-stage    cost: 2.076155185699463\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.21201615035533905\n",
      "RANDOM  true cost:  -1 0.2205243812253078\n",
      "OPTIMAL true cost: 2 0.19673237204551697\n",
      "REWARD  true cost: 3 0.2037910670042038\n",
      "\n",
      "end-to-end cost: 0.28513455390930176\n",
      "2-stage    cost: 1.2083587646484375\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.16387201845645905\n",
      "RANDOM  true cost:  -1 0.20761158193151155\n",
      "OPTIMAL true cost: 2 0.16387201845645905\n",
      "REWARD  true cost: 2 0.16387201845645905\n",
      "\n",
      "end-to-end cost: 0.28682610392570496\n",
      "2-stage    cost: 0.645831286907196\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.17713455855846405\n",
      "RANDOM  true cost:  -1 0.21225269697606564\n",
      "OPTIMAL true cost: 2 0.1722283810377121\n",
      "REWARD  true cost: 3 0.17713455855846405\n",
      "\n",
      "end-to-end cost: 0.2884337306022644\n",
      "2-stage    cost: 0.36039096117019653\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.2012181133031845\n",
      "RANDOM  true cost:  -1 0.22081811788181463\n",
      "OPTIMAL true cost: 2 0.19006910920143127\n",
      "REWARD  true cost: 7 0.20860855281352997\n",
      "\n",
      "end-to-end cost: 0.34103378653526306\n",
      "2-stage    cost: 0.0594792477786541\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.24820956587791443\n",
      "RANDOM  true cost:  -1 0.27063782202700776\n",
      "OPTIMAL true cost: 2 0.24220743775367737\n",
      "REWARD  true cost: 3 0.24796579778194427\n",
      "\n",
      "end-to-end cost: 0.45998257398605347\n",
      "2-stage    cost: 0.06500814855098724\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2874165177345276\n",
      "RANDOM  true cost:  -1 0.3421630697945754\n",
      "OPTIMAL true cost: 5 0.2861523926258087\n",
      "REWARD  true cost: 7 0.2894677519798279\n",
      "\n",
      "end-to-end cost: 0.46802908182144165\n",
      "2-stage    cost: 0.2215452790260315\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2687566876411438\n",
      "RANDOM  true cost:  -1 0.3346116940180461\n",
      "OPTIMAL true cost: 7 0.2668403387069702\n",
      "REWARD  true cost: 17 0.34560978412628174\n",
      "\n",
      "end-to-end cost: 0.3982599973678589\n",
      "2-stage    cost: 0.0731903612613678\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21579673886299133\n",
      "RANDOM  true cost:  -1 0.2770359528561433\n",
      "OPTIMAL true cost: 3 0.2143215388059616\n",
      "REWARD  true cost: 6 0.22116336226463318\n",
      "\n",
      "end-to-end cost: 0.39064455032348633\n",
      "2-stage    cost: 0.05387140065431595\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21877631545066833\n",
      "RANDOM  true cost:  -1 0.27760255212585133\n",
      "OPTIMAL true cost: 3 0.21877631545066833\n",
      "REWARD  true cost: 17 0.28682467341423035\n",
      "\n",
      "end-to-end cost: 0.39090585708618164\n",
      "2-stage    cost: 0.06240649148821831\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21876227855682373\n",
      "RANDOM  true cost:  -1 0.27760238262514275\n",
      "OPTIMAL true cost: 3 0.21876227855682373\n",
      "REWARD  true cost: 17 0.28753846883773804\n",
      "\n",
      "end-to-end cost: 0.3440867066383362\n",
      "2-stage    cost: 4.012507438659668\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1547122299671173\n",
      "RANDOM  true cost:  -1 0.22507028778394064\n",
      "OPTIMAL true cost: 3 0.1547122299671173\n",
      "REWARD  true cost: 6 0.16102007031440735\n",
      "\n",
      "end-to-end cost: 0.31924504041671753\n",
      "2-stage    cost: 0.1866859644651413\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.19119898974895477\n",
      "RANDOM  true cost:  -1 0.23318330074350038\n",
      "OPTIMAL true cost: 2 0.1859811246395111\n",
      "REWARD  true cost: 6 0.2012304663658142\n",
      "\n",
      "end-to-end cost: 0.40997204184532166\n",
      "2-stage    cost: 0.23751229047775269\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.27258580923080444\n",
      "RANDOM  true cost:  -1 0.3172144517302513\n",
      "OPTIMAL true cost: 2 0.27258580923080444\n",
      "REWARD  true cost: 17 0.31002792716026306\n",
      "\n",
      "end-to-end cost: 0.46390625834465027\n",
      "2-stage    cost: 0.1600850522518158\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3170498013496399\n",
      "RANDOM  true cost:  -1 0.35816891491413116\n",
      "OPTIMAL true cost: 2 0.31232088804244995\n",
      "REWARD  true cost: 15 0.33830341696739197\n",
      "\n",
      "end-to-end cost: 0.40185534954071045\n",
      "2-stage    cost: 0.6456934213638306\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.19884562492370605\n",
      "RANDOM  true cost:  -1 0.2738030714293321\n",
      "OPTIMAL true cost: 7 0.1981954276561737\n",
      "REWARD  true cost: 6 0.2046501487493515\n",
      "\n",
      "end-to-end cost: 0.39466381072998047\n",
      "2-stage    cost: 0.0710337832570076\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21650008857250214\n",
      "RANDOM  true cost:  -1 0.2762154856075843\n",
      "OPTIMAL true cost: 3 0.21650008857250214\n",
      "REWARD  true cost: 6 0.22248302400112152\n",
      "\n",
      "end-to-end cost: 0.3293946385383606\n",
      "2-stage    cost: 5.109748363494873\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.14260709285736084\n",
      "RANDOM  true cost:  -1 0.22340834264953932\n",
      "OPTIMAL true cost: 3 0.14260709285736084\n",
      "REWARD  true cost: 17 0.23814663290977478\n",
      "\n",
      "end-to-end cost: 0.3329283893108368\n",
      "2-stage    cost: 0.03466085344552994\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2122422307729721\n",
      "RANDOM  true cost:  -1 0.24904189072549343\n",
      "OPTIMAL true cost: 2 0.20697687566280365\n",
      "REWARD  true cost: 7 0.21832899749279022\n",
      "\n",
      "end-to-end cost: 0.3420533537864685\n",
      "2-stage    cost: 0.08269839733839035\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20543131232261658\n",
      "RANDOM  true cost:  -1 0.2508709157506625\n",
      "OPTIMAL true cost: 2 0.20109449326992035\n",
      "REWARD  true cost: 7 0.2109357714653015\n",
      "\n",
      "end-to-end cost: 0.42655283212661743\n",
      "2-stage    cost: 0.1344204992055893\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2814555764198303\n",
      "RANDOM  true cost:  -1 0.32581767067313194\n",
      "OPTIMAL true cost: 2 0.2782427668571472\n",
      "REWARD  true cost: 6 0.2895253002643585\n",
      "\n",
      "end-to-end cost: 0.43828970193862915\n",
      "2-stage    cost: 0.21797165274620056\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.268088161945343\n",
      "RANDOM  true cost:  -1 0.3225739945967992\n",
      "OPTIMAL true cost: 2 0.26579612493515015\n",
      "REWARD  true cost: 7 0.2689424753189087\n",
      "\n",
      "end-to-end cost: 0.41239291429519653\n",
      "2-stage    cost: 0.08849456906318665\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24489405751228333\n",
      "RANDOM  true cost:  -1 0.2989722614487012\n",
      "OPTIMAL true cost: 2 0.24419593811035156\n",
      "REWARD  true cost: 7 0.24945560097694397\n",
      "\n",
      "end-to-end cost: 0.4325490891933441\n",
      "2-stage    cost: 0.03107624128460884\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22206704318523407\n",
      "RANDOM  true cost:  -1 0.29596916027367115\n",
      "OPTIMAL true cost: 7 0.2177790403366089\n",
      "REWARD  true cost: 5 0.22141331434249878\n",
      "\n",
      "end-to-end cost: 0.4115654230117798\n",
      "2-stage    cost: 0.3305584788322449\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.20032267272472382\n",
      "RANDOM  true cost:  -1 0.27730425881842774\n",
      "OPTIMAL true cost: 7 0.19925008714199066\n",
      "REWARD  true cost: 6 0.20633363723754883\n",
      "\n",
      "end-to-end cost: 0.41333460807800293\n",
      "2-stage    cost: 0.22265172004699707\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2023845613002777\n",
      "RANDOM  true cost:  -1 0.2782572153955698\n",
      "OPTIMAL true cost: 7 0.1974448561668396\n",
      "REWARD  true cost: 10 0.22836026549339294\n",
      "\n",
      "end-to-end cost: 0.4332139492034912\n",
      "2-stage    cost: 0.04387614130973816\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2265496850013733\n",
      "RANDOM  true cost:  -1 0.29836664410928887\n",
      "OPTIMAL true cost: 7 0.22298239171504974\n",
      "REWARD  true cost: 10 0.25261586904525757\n",
      "\n",
      "end-to-end cost: 0.48412901163101196\n",
      "2-stage    cost: 0.28258663415908813\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.28033995628356934\n",
      "RANDOM  true cost:  -1 0.34741559624671936\n",
      "OPTIMAL true cost: 7 0.2790285348892212\n",
      "REWARD  true cost: 6 0.285398006439209\n",
      "\n",
      "end-to-end cost: 0.5055338740348816\n",
      "2-stage    cost: 0.03755682334303856\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2805134057998657\n",
      "RANDOM  true cost:  -1 0.35872238377730054\n",
      "OPTIMAL true cost: 7 0.2769249677658081\n",
      "REWARD  true cost: 6 0.28655490279197693\n",
      "\n",
      "end-to-end cost: 0.4369848668575287\n",
      "2-stage    cost: 0.03288101777434349\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2242482602596283\n",
      "RANDOM  true cost:  -1 0.3013134313126405\n",
      "OPTIMAL true cost: 7 0.2226453721523285\n",
      "REWARD  true cost: 10 0.25420451164245605\n",
      "\n",
      "end-to-end cost: 0.4285425543785095\n",
      "2-stage    cost: 0.13180488348007202\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2158111184835434\n",
      "RANDOM  true cost:  -1 0.29446713005503017\n",
      "OPTIMAL true cost: 7 0.21451568603515625\n",
      "REWARD  true cost: 10 0.24626651406288147\n",
      "\n",
      "end-to-end cost: 0.43255823850631714\n",
      "2-stage    cost: 0.023120244964957237\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.23169073462486267\n",
      "RANDOM  true cost:  -1 0.30329072164992493\n",
      "OPTIMAL true cost: 7 0.23078128695487976\n",
      "REWARD  true cost: 6 0.2361474484205246\n",
      "\n",
      "end-to-end cost: 0.4400714039802551\n",
      "2-stage    cost: 0.0468716137111187\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22919349372386932\n",
      "RANDOM  true cost:  -1 0.30343784019351006\n",
      "OPTIMAL true cost: 7 0.22441011667251587\n",
      "REWARD  true cost: 8 0.23348179459571838\n",
      "\n",
      "end-to-end cost: 0.4427288770675659\n",
      "2-stage    cost: 0.042694978415966034\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24273955821990967\n",
      "RANDOM  true cost:  -1 0.31081739626824856\n",
      "OPTIMAL true cost: 7 0.2406911849975586\n",
      "REWARD  true cost: 10 0.2698666453361511\n",
      "\n",
      "end-to-end cost: 0.47586458921432495\n",
      "2-stage    cost: 2.2154541015625\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.26875871419906616\n",
      "RANDOM  true cost:  -1 0.34062500049670535\n",
      "OPTIMAL true cost: 7 0.2667395770549774\n",
      "REWARD  true cost: 7 0.2667395770549774\n",
      "\n",
      "end-to-end cost: 0.46314987540245056\n",
      "2-stage    cost: 1.1577575206756592\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.27497273683547974\n",
      "RANDOM  true cost:  -1 0.33835866923133534\n",
      "OPTIMAL true cost: 5 0.2738165259361267\n",
      "REWARD  true cost: 5 0.2738165259361267\n",
      "\n",
      "end-to-end cost: 0.3896416127681732\n",
      "2-stage    cost: 0.16013675928115845\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21090295910835266\n",
      "RANDOM  true cost:  -1 0.2729445043951273\n",
      "OPTIMAL true cost: 3 0.20910626649856567\n",
      "REWARD  true cost: 10 0.23664161562919617\n",
      "\n",
      "end-to-end cost: 0.41056057810783386\n",
      "2-stage    cost: 0.11888152360916138\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2448292225599289\n",
      "RANDOM  true cost:  -1 0.2995318075021108\n",
      "OPTIMAL true cost: 2 0.24387149512767792\n",
      "REWARD  true cost: 5 0.2458423674106598\n",
      "\n",
      "end-to-end cost: 0.43897199630737305\n",
      "2-stage    cost: 0.031077519059181213\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2445879876613617\n",
      "RANDOM  true cost:  -1 0.3122907516856988\n",
      "OPTIMAL true cost: 5 0.24369488656520844\n",
      "REWARD  true cost: 5 0.24369488656520844\n",
      "\n",
      "end-to-end cost: 0.4329683482646942\n",
      "2-stage    cost: 0.7074441909790039\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2242060750722885\n",
      "RANDOM  true cost:  -1 0.2989153768867254\n",
      "OPTIMAL true cost: 7 0.2226332128047943\n",
      "REWARD  true cost: 10 0.25165829062461853\n",
      "\n",
      "end-to-end cost: 0.4460880756378174\n",
      "2-stage    cost: 0.2503138780593872\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.23772236704826355\n",
      "RANDOM  true cost:  -1 0.3123306880394618\n",
      "OPTIMAL true cost: 7 0.23643481731414795\n",
      "REWARD  true cost: 6 0.24369320273399353\n",
      "\n",
      "end-to-end cost: 0.4966660439968109\n",
      "2-stage    cost: 0.6009657382965088\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3090909719467163\n",
      "RANDOM  true cost:  -1 0.3688785806298256\n",
      "OPTIMAL true cost: 5 0.3076570928096771\n",
      "REWARD  true cost: 10 0.33184927701950073\n",
      "\n",
      "end-to-end cost: 0.5207028985023499\n",
      "2-stage    cost: 0.10275143384933472\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30702143907546997\n",
      "RANDOM  true cost:  -1 0.37702713906764984\n",
      "OPTIMAL true cost: 7 0.3041379749774933\n",
      "REWARD  true cost: 6 0.3122102618217468\n",
      "\n",
      "end-to-end cost: 0.4462721347808838\n",
      "2-stage    cost: 0.9245691299438477\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22001922130584717\n",
      "RANDOM  true cost:  -1 0.3048027145365874\n",
      "OPTIMAL true cost: 7 0.2177525758743286\n",
      "REWARD  true cost: 10 0.24964356422424316\n",
      "\n",
      "end-to-end cost: 0.41961830854415894\n",
      "2-stage    cost: 0.21704894304275513\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22094309329986572\n",
      "RANDOM  true cost:  -1 0.29091989000638324\n",
      "OPTIMAL true cost: 5 0.22034507989883423\n",
      "REWARD  true cost: 6 0.2254646122455597\n",
      "\n",
      "end-to-end cost: 0.4168282747268677\n",
      "2-stage    cost: 0.5214545726776123\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23128649592399597\n",
      "RANDOM  true cost:  -1 0.29432631470263004\n",
      "OPTIMAL true cost: 3 0.23128649592399597\n",
      "REWARD  true cost: 6 0.23714321851730347\n",
      "\n",
      "end-to-end cost: 0.4292958974838257\n",
      "2-stage    cost: 0.1348925083875656\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22369246184825897\n",
      "RANDOM  true cost:  -1 0.2970988067487876\n",
      "OPTIMAL true cost: 7 0.2202076017856598\n",
      "REWARD  true cost: 2 0.23000496625900269\n",
      "\n",
      "end-to-end cost: 0.4509159326553345\n",
      "2-stage    cost: 0.036433205008506775\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24577561020851135\n",
      "RANDOM  true cost:  -1 0.3177074268460274\n",
      "OPTIMAL true cost: 7 0.24206697940826416\n",
      "REWARD  true cost: 17 0.3400244116783142\n",
      "\n",
      "end-to-end cost: 0.4932096004486084\n",
      "2-stage    cost: 1.527745246887207\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2755381762981415\n",
      "RANDOM  true cost:  -1 0.35090304911136627\n",
      "OPTIMAL true cost: 7 0.27326834201812744\n",
      "REWARD  true cost: 6 0.282481849193573\n",
      "\n",
      "end-to-end cost: 0.47069233655929565\n",
      "2-stage    cost: 1.270129919052124\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2895021438598633\n",
      "RANDOM  true cost:  -1 0.34756458302338916\n",
      "OPTIMAL true cost: 5 0.28770744800567627\n",
      "REWARD  true cost: 5 0.28770744800567627\n",
      "\n",
      "end-to-end cost: 0.41453152894973755\n",
      "2-stage    cost: 0.451021671295166\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21429471671581268\n",
      "RANDOM  true cost:  -1 0.2866407874971628\n",
      "OPTIMAL true cost: 7 0.2134641855955124\n",
      "REWARD  true cost: 2 0.2202124297618866\n",
      "\n",
      "end-to-end cost: 0.39085477590560913\n",
      "2-stage    cost: 0.3107011318206787\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2325182855129242\n",
      "RANDOM  true cost:  -1 0.2854522094130516\n",
      "OPTIMAL true cost: 2 0.23064374923706055\n",
      "REWARD  true cost: 2 0.23064374923706055\n",
      "\n",
      "end-to-end cost: 0.41554778814315796\n",
      "2-stage    cost: 0.08932795375585556\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.25581812858581543\n",
      "RANDOM  true cost:  -1 0.30787355080246925\n",
      "OPTIMAL true cost: 2 0.25411590933799744\n",
      "REWARD  true cost: 7 0.26060786843299866\n",
      "\n",
      "end-to-end cost: 0.43175405263900757\n",
      "2-stage    cost: 0.24465970695018768\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22784332931041718\n",
      "RANDOM  true cost:  -1 0.2990422397851944\n",
      "OPTIMAL true cost: 7 0.22484830021858215\n",
      "REWARD  true cost: 2 0.23357032239437103\n",
      "\n",
      "end-to-end cost: 0.4053391218185425\n",
      "2-stage    cost: 0.5637577772140503\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22300752997398376\n",
      "RANDOM  true cost:  -1 0.286142027626435\n",
      "OPTIMAL true cost: 3 0.22300752997398376\n",
      "REWARD  true cost: 3 0.22300752997398376\n",
      "\n",
      "end-to-end cost: 0.44146427512168884\n",
      "2-stage    cost: 2.954021453857422\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.26557356119155884\n",
      "RANDOM  true cost:  -1 0.3253713349501292\n",
      "OPTIMAL true cost: 5 0.2653554081916809\n",
      "REWARD  true cost: 2 0.26612380146980286\n",
      "\n",
      "end-to-end cost: 0.44447121024131775\n",
      "2-stage    cost: 0.9890506267547607\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.29620033502578735\n",
      "RANDOM  true cost:  -1 0.3409523566563924\n",
      "OPTIMAL true cost: 2 0.29068899154663086\n",
      "REWARD  true cost: 2 0.29068899154663086\n",
      "\n",
      "end-to-end cost: 0.4258953034877777\n",
      "2-stage    cost: 0.03944374620914459\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2357109785079956\n",
      "RANDOM  true cost:  -1 0.3025594850381215\n",
      "OPTIMAL true cost: 5 0.2357109785079956\n",
      "REWARD  true cost: 2 0.23936673998832703\n",
      "\n",
      "end-to-end cost: 0.4272325932979584\n",
      "2-stage    cost: 0.15032143890857697\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2222355604171753\n",
      "RANDOM  true cost:  -1 0.2930128990362088\n",
      "OPTIMAL true cost: 7 0.21926407516002655\n",
      "REWARD  true cost: 2 0.2286478728055954\n",
      "\n",
      "end-to-end cost: 0.41871124505996704\n",
      "2-stage    cost: 0.5289238691329956\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2297850102186203\n",
      "RANDOM  true cost:  -1 0.29390983656048775\n",
      "OPTIMAL true cost: 3 0.2297850102186203\n",
      "REWARD  true cost: 3 0.2297850102186203\n",
      "\n",
      "end-to-end cost: 0.43439221382141113\n",
      "2-stage    cost: 0.022771410644054413\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.24003326892852783\n",
      "RANDOM  true cost:  -1 0.30644379556179047\n",
      "OPTIMAL true cost: 3 0.24003326892852783\n",
      "REWARD  true cost: 2 0.24403950572013855\n",
      "\n",
      "end-to-end cost: 0.4471069276332855\n",
      "2-stage    cost: 0.02377108857035637\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.23863260447978973\n",
      "RANDOM  true cost:  -1 0.31125033770998317\n",
      "OPTIMAL true cost: 7 0.23413555324077606\n",
      "REWARD  true cost: 6 0.24207818508148193\n",
      "\n",
      "end-to-end cost: 0.5100408792495728\n",
      "2-stage    cost: 0.19499418139457703\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.28551945090293884\n",
      "RANDOM  true cost:  -1 0.364824365824461\n",
      "OPTIMAL true cost: 7 0.28331488370895386\n",
      "REWARD  true cost: 3 0.29151076078414917\n",
      "\n",
      "end-to-end cost: 0.5040038824081421\n",
      "2-stage    cost: 0.2990216016769409\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2728639841079712\n",
      "RANDOM  true cost:  -1 0.3565621313949426\n",
      "OPTIMAL true cost: 7 0.27061551809310913\n",
      "REWARD  true cost: 6 0.28024521470069885\n",
      "\n",
      "end-to-end cost: 0.41754573583602905\n",
      "2-stage    cost: 0.03340046852827072\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19983503222465515\n",
      "RANDOM  true cost:  -1 0.2837004289031029\n",
      "OPTIMAL true cost: 7 0.19567708671092987\n",
      "REWARD  true cost: 10 0.22744862735271454\n",
      "\n",
      "end-to-end cost: 0.42057549953460693\n",
      "2-stage    cost: 0.04003794863820076\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2134460210800171\n",
      "RANDOM  true cost:  -1 0.29225765354931355\n",
      "OPTIMAL true cost: 7 0.21291020512580872\n",
      "REWARD  true cost: 10 0.24090594053268433\n",
      "\n",
      "end-to-end cost: 0.4294533431529999\n",
      "2-stage    cost: 0.022535083815455437\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.20847928524017334\n",
      "RANDOM  true cost:  -1 0.2921757126847903\n",
      "OPTIMAL true cost: 7 0.20671358704566956\n",
      "REWARD  true cost: 6 0.21572372317314148\n",
      "\n",
      "end-to-end cost: 0.42343419790267944\n",
      "2-stage    cost: 0.054303012788295746\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.20605206489562988\n",
      "RANDOM  true cost:  -1 0.2894392566134532\n",
      "OPTIMAL true cost: 7 0.20480966567993164\n",
      "REWARD  true cost: 6 0.21326760947704315\n",
      "\n",
      "end-to-end cost: 0.42866477370262146\n",
      "2-stage    cost: 0.06298264116048813\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21762526035308838\n",
      "RANDOM  true cost:  -1 0.29651298622290295\n",
      "OPTIMAL true cost: 7 0.216579407453537\n",
      "REWARD  true cost: 10 0.24769577383995056\n",
      "\n",
      "end-to-end cost: 0.5185229778289795\n",
      "2-stage    cost: 0.20586900413036346\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2998772859573364\n",
      "RANDOM  true cost:  -1 0.376761960486571\n",
      "OPTIMAL true cost: 7 0.29847750067710876\n",
      "REWARD  true cost: 2 0.31542524695396423\n",
      "\n",
      "end-to-end cost: 0.5262347459793091\n",
      "2-stage    cost: 0.18650639057159424\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2949678301811218\n",
      "RANDOM  true cost:  -1 0.3753594768544038\n",
      "OPTIMAL true cost: 7 0.29199421405792236\n",
      "REWARD  true cost: 6 0.3022131323814392\n",
      "\n",
      "end-to-end cost: 0.42124566435813904\n",
      "2-stage    cost: 1.3878734111785889\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1840762346982956\n",
      "RANDOM  true cost:  -1 0.27837421869238216\n",
      "OPTIMAL true cost: 7 0.1812436431646347\n",
      "REWARD  true cost: 2 0.20826898515224457\n",
      "\n",
      "end-to-end cost: 0.4140737056732178\n",
      "2-stage    cost: 0.036546528339385986\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.21489392220973969\n",
      "RANDOM  true cost:  -1 0.28931746321419877\n",
      "OPTIMAL true cost: 5 0.21189641952514648\n",
      "REWARD  true cost: 10 0.2404661625623703\n",
      "\n",
      "end-to-end cost: 0.435072660446167\n",
      "2-stage    cost: 0.05626708269119263\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22112557291984558\n",
      "RANDOM  true cost:  -1 0.2993527476986249\n",
      "OPTIMAL true cost: 7 0.22008436918258667\n",
      "REWARD  true cost: 6 0.2277917116880417\n",
      "\n",
      "end-to-end cost: 0.4434421956539154\n",
      "2-stage    cost: 0.06464561074972153\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22174569964408875\n",
      "RANDOM  true cost:  -1 0.303162032738328\n",
      "OPTIMAL true cost: 7 0.21905001997947693\n",
      "REWARD  true cost: 6 0.22834675014019012\n",
      "\n",
      "end-to-end cost: 0.45179057121276855\n",
      "2-stage    cost: 0.03223494440317154\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2363971471786499\n",
      "RANDOM  true cost:  -1 0.3144458656509717\n",
      "OPTIMAL true cost: 7 0.23491567373275757\n",
      "REWARD  true cost: 6 0.24338996410369873\n",
      "\n",
      "end-to-end cost: 0.5126321315765381\n",
      "2-stage    cost: 0.18183374404907227\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2952963411808014\n",
      "RANDOM  true cost:  -1 0.3699139381448428\n",
      "OPTIMAL true cost: 7 0.2931433916091919\n",
      "REWARD  true cost: 2 0.3082071542739868\n",
      "\n",
      "end-to-end cost: 0.5076788067817688\n",
      "2-stage    cost: 0.17104238271713257\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.28175216913223267\n",
      "RANDOM  true cost:  -1 0.3628651363154252\n",
      "OPTIMAL true cost: 7 0.27964505553245544\n",
      "REWARD  true cost: 2 0.29904091358184814\n",
      "\n",
      "end-to-end cost: 0.44469594955444336\n",
      "2-stage    cost: 0.032493866980075836\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2252916395664215\n",
      "RANDOM  true cost:  -1 0.30613079605003196\n",
      "OPTIMAL true cost: 7 0.21922950446605682\n",
      "REWARD  true cost: 6 0.22933852672576904\n",
      "\n",
      "end-to-end cost: 0.45746469497680664\n",
      "2-stage    cost: 0.02500317245721817\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22479622066020966\n",
      "RANDOM  true cost:  -1 0.3122854388008515\n",
      "OPTIMAL true cost: 7 0.22247058153152466\n",
      "REWARD  true cost: 6 0.23290173709392548\n",
      "\n",
      "end-to-end cost: 0.4353482723236084\n",
      "2-stage    cost: 0.5569748878479004\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.21398155391216278\n",
      "RANDOM  true cost:  -1 0.29484859233101207\n",
      "OPTIMAL true cost: 7 0.21134017407894135\n",
      "REWARD  true cost: 6 0.22042958438396454\n",
      "\n",
      "end-to-end cost: 0.4543493688106537\n",
      "2-stage    cost: 0.052870094776153564\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2524576187133789\n",
      "RANDOM  true cost:  -1 0.31848939321935177\n",
      "OPTIMAL true cost: 7 0.24082088470458984\n",
      "REWARD  true cost: 6 0.2483808845281601\n",
      "\n",
      "end-to-end cost: 0.4600144028663635\n",
      "2-stage    cost: 0.09402431547641754\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.25387123227119446\n",
      "RANDOM  true cost:  -1 0.32098176268239814\n",
      "OPTIMAL true cost: 7 0.24053560197353363\n",
      "REWARD  true cost: 10 0.27181047201156616\n",
      "\n",
      "end-to-end cost: 0.5175038576126099\n",
      "2-stage    cost: 0.06616617739200592\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2950461804866791\n",
      "RANDOM  true cost:  -1 0.3723289209107558\n",
      "OPTIMAL true cost: 7 0.2927146553993225\n",
      "REWARD  true cost: 5 0.2974119186401367\n",
      "\n",
      "end-to-end cost: 0.539124071598053\n",
      "2-stage    cost: 0.06552278250455856\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.31615763902664185\n",
      "RANDOM  true cost:  -1 0.39313049738605815\n",
      "OPTIMAL true cost: 7 0.31403908133506775\n",
      "REWARD  true cost: 17 0.4109499454498291\n",
      "\n",
      "end-to-end cost: 0.46430692076683044\n",
      "2-stage    cost: 0.2261119931936264\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2323712557554245\n",
      "RANDOM  true cost:  -1 0.31880131798485917\n",
      "OPTIMAL true cost: 7 0.22970816493034363\n",
      "REWARD  true cost: 10 0.2627549469470978\n",
      "\n",
      "end-to-end cost: 0.4394169747829437\n",
      "2-stage    cost: 0.06019454449415207\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2295471429824829\n",
      "RANDOM  true cost:  -1 0.29807665944099426\n",
      "OPTIMAL true cost: 7 0.21166536211967468\n",
      "REWARD  true cost: 2 0.2295471429824829\n",
      "\n",
      "end-to-end cost: 0.42830806970596313\n",
      "2-stage    cost: 0.0616510771214962\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.22457396984100342\n",
      "RANDOM  true cost:  -1 0.2994930986315012\n",
      "OPTIMAL true cost: 7 0.22355139255523682\n",
      "REWARD  true cost: 2 0.23310533165931702\n",
      "\n",
      "end-to-end cost: 0.4108876883983612\n",
      "2-stage    cost: 0.5517503023147583\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1995360553264618\n",
      "RANDOM  true cost:  -1 0.283774146810174\n",
      "OPTIMAL true cost: 7 0.19834409654140472\n",
      "REWARD  true cost: 6 0.20583802461624146\n",
      "\n",
      "end-to-end cost: 0.42534899711608887\n",
      "2-stage    cost: 0.12661826610565186\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.24099695682525635\n",
      "RANDOM  true cost:  -1 0.3079467552403609\n",
      "OPTIMAL true cost: 5 0.23871496319770813\n",
      "REWARD  true cost: 2 0.2437686026096344\n",
      "\n",
      "end-to-end cost: 0.5184246897697449\n",
      "2-stage    cost: 0.3691510558128357\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2957507371902466\n",
      "RANDOM  true cost:  -1 0.37476781383156776\n",
      "OPTIMAL true cost: 7 0.2939494550228119\n",
      "REWARD  true cost: 7 0.2939494550228119\n",
      "\n",
      "end-to-end cost: 0.5233868956565857\n",
      "2-stage    cost: 0.20524680614471436\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.30141526460647583\n",
      "RANDOM  true cost:  -1 0.37779804940025014\n",
      "OPTIMAL true cost: 7 0.2990655303001404\n",
      "REWARD  true cost: 6 0.30821970105171204\n",
      "\n",
      "end-to-end cost: 0.4624413847923279\n",
      "2-stage    cost: 0.1550353467464447\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.25499576330184937\n",
      "RANDOM  true cost:  -1 0.32081669258574647\n",
      "OPTIMAL true cost: 7 0.23959796130657196\n",
      "REWARD  true cost: 5 0.245182603597641\n",
      "\n",
      "end-to-end cost: 0.4709141254425049\n",
      "2-stage    cost: 0.036292701959609985\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2635035514831543\n",
      "RANDOM  true cost:  -1 0.3291879991690318\n",
      "OPTIMAL true cost: 7 0.24362215399742126\n",
      "REWARD  true cost: 6 0.25404563546180725\n",
      "\n",
      "end-to-end cost: 0.45003899931907654\n",
      "2-stage    cost: 0.02617223933339119\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.24382838606834412\n",
      "RANDOM  true cost:  -1 0.3106910859545072\n",
      "OPTIMAL true cost: 7 0.22740381956100464\n",
      "REWARD  true cost: 6 0.23660771548748016\n",
      "\n",
      "end-to-end cost: 0.43225497007369995\n",
      "2-stage    cost: 0.3371906876564026\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.23138123750686646\n",
      "RANDOM  true cost:  -1 0.29855159608026344\n",
      "OPTIMAL true cost: 7 0.22126911580562592\n",
      "REWARD  true cost: 2 0.23138123750686646\n",
      "\n",
      "end-to-end cost: 0.4426475465297699\n",
      "2-stage    cost: 0.02766112983226776\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.24083217978477478\n",
      "RANDOM  true cost:  -1 0.30893996854623157\n",
      "OPTIMAL true cost: 7 0.22685359418392181\n",
      "REWARD  true cost: 5 0.2298450469970703\n",
      "\n",
      "end-to-end cost: 0.501024603843689\n",
      "2-stage    cost: 0.5569959878921509\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2906881868839264\n",
      "RANDOM  true cost:  -1 0.36424214268724125\n",
      "OPTIMAL true cost: 7 0.2890821397304535\n",
      "REWARD  true cost: 2 0.30198442935943604\n",
      "\n",
      "end-to-end cost: 0.521309494972229\n",
      "2-stage    cost: 0.10595783591270447\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2974540591239929\n",
      "RANDOM  true cost:  -1 0.37579169124364853\n",
      "OPTIMAL true cost: 7 0.2952595353126526\n",
      "REWARD  true cost: 6 0.3045513331890106\n",
      "\n",
      "end-to-end cost: 0.42860281467437744\n",
      "2-stage    cost: 0.09594963490962982\n",
      "TRUE\n",
      "CHOSEN  true cost: 2 0.2220914363861084\n",
      "RANDOM  true cost:  -1 0.29286078984538716\n",
      "OPTIMAL true cost: 7 0.2054385542869568\n",
      "REWARD  true cost: 10 0.23683542013168335\n",
      "\n",
      "end-to-end cost: 0.4054977595806122\n",
      "2-stage    cost: 0.13027147948741913\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.20101308822631836\n",
      "RANDOM  true cost:  -1 0.28088513637582463\n",
      "OPTIMAL true cost: 7 0.20044821500778198\n",
      "REWARD  true cost: 3 0.20329618453979492\n",
      "\n",
      "end-to-end cost: 0.34242483973503113\n",
      "2-stage    cost: 1.3379567861557007\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.17565613985061646\n",
      "RANDOM  true cost:  -1 0.24244929539660612\n",
      "OPTIMAL true cost: 5 0.17426106333732605\n",
      "REWARD  true cost: 6 0.17972144484519958\n",
      "\n",
      "end-to-end cost: 0.27184170484542847\n",
      "2-stage    cost: 2.156562328338623\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.14487072825431824\n",
      "RANDOM  true cost:  -1 0.19755457155406475\n",
      "OPTIMAL true cost: 2 0.1417008340358734\n",
      "REWARD  true cost: 7 0.14898896217346191\n",
      "\n",
      "end-to-end cost: 0.1960114687681198\n",
      "2-stage    cost: 3.4239935874938965\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1756536215543747\n",
      "RANDOM  true cost:  -1 0.15553864339987436\n",
      "OPTIMAL true cost: 2 0.11765053868293762\n",
      "REWARD  true cost: 7 0.12466074526309967\n",
      "\n",
      "end-to-end cost: 0.20759449899196625\n",
      "2-stage    cost: 4.149365425109863\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.17062002420425415\n",
      "RANDOM  true cost:  -1 0.18774685263633728\n",
      "OPTIMAL true cost: 2 0.16645534336566925\n",
      "REWARD  true cost: 7 0.17188255488872528\n",
      "\n",
      "end-to-end cost: 0.3150554597377777\n",
      "2-stage    cost: 0.1317281574010849\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.29610538482666016\n",
      "RANDOM  true cost:  -1 0.2998906100789706\n",
      "OPTIMAL true cost: 17 0.2785923182964325\n",
      "REWARD  true cost: 7 0.3047339916229248\n",
      "\n",
      "end-to-end cost: 0.33358055353164673\n",
      "2-stage    cost: 5.665313720703125\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.185365229845047\n",
      "RANDOM  true cost:  -1 0.2415999627361695\n",
      "OPTIMAL true cost: 5 0.174788236618042\n",
      "REWARD  true cost: 7 0.17850355803966522\n",
      "\n",
      "end-to-end cost: 0.22454355657100677\n",
      "2-stage    cost: 1.3981375694274902\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1696872115135193\n",
      "RANDOM  true cost:  -1 0.20675384470572075\n",
      "OPTIMAL true cost: 2 0.1211843192577362\n",
      "REWARD  true cost: 3 0.12386008352041245\n",
      "\n",
      "end-to-end cost: 0.1511748880147934\n",
      "2-stage    cost: 3.421143054962158\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3914799392223358\n",
      "RANDOM  true cost:  -1 0.270850345492363\n",
      "OPTIMAL true cost: 14 0.1256275624036789\n",
      "REWARD  true cost: 10 0.5015586614608765\n",
      "\n",
      "end-to-end cost: 0.16221126914024353\n",
      "2-stage    cost: 0.054735299199819565\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.14861714839935303\n",
      "RANDOM  true cost:  -1 0.1532159106185039\n",
      "OPTIMAL true cost: 1 0.14350473880767822\n",
      "REWARD  true cost: 2 0.14738719165325165\n",
      "\n",
      "end-to-end cost: 0.18144826591014862\n",
      "2-stage    cost: 1.5575536489486694\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.16114893555641174\n",
      "RANDOM  true cost:  -1 0.15014396328479052\n",
      "OPTIMAL true cost: 2 0.1232423409819603\n",
      "REWARD  true cost: 2 0.1232423409819603\n",
      "\n",
      "end-to-end cost: 0.29990124702453613\n",
      "2-stage    cost: 0.045412831008434296\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.2526967227458954\n",
      "RANDOM  true cost:  -1 0.2589604891836643\n",
      "OPTIMAL true cost: 2 0.24025815725326538\n",
      "REWARD  true cost: 3 0.24199524521827698\n",
      "\n",
      "end-to-end cost: 0.3618595600128174\n",
      "2-stage    cost: 0.11665799468755722\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2862749993801117\n",
      "RANDOM  true cost:  -1 0.3029626210530599\n",
      "OPTIMAL true cost: 2 0.2825735807418823\n",
      "REWARD  true cost: 7 0.288781076669693\n",
      "\n",
      "end-to-end cost: 0.3045210838317871\n",
      "2-stage    cost: 1.5355067253112793\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1598576307296753\n",
      "RANDOM  true cost:  -1 0.21972762669126192\n",
      "OPTIMAL true cost: 2 0.15765896439552307\n",
      "REWARD  true cost: 2 0.15765896439552307\n",
      "\n",
      "end-to-end cost: 0.3494967818260193\n",
      "2-stage    cost: 0.10515910387039185\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.20534729957580566\n",
      "RANDOM  true cost:  -1 0.2605009724696477\n",
      "OPTIMAL true cost: 2 0.20387646555900574\n",
      "REWARD  true cost: 6 0.21130824089050293\n",
      "\n",
      "end-to-end cost: 0.4305098056793213\n",
      "2-stage    cost: 0.2552027702331543\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.24326108396053314\n",
      "RANDOM  true cost:  -1 0.3092956493298213\n",
      "OPTIMAL true cost: 5 0.24125266075134277\n",
      "REWARD  true cost: 4 0.24326108396053314\n",
      "\n",
      "end-to-end cost: 0.4235774278640747\n",
      "2-stage    cost: 0.05927147716283798\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.22172772884368896\n",
      "RANDOM  true cost:  -1 0.2987921703606844\n",
      "OPTIMAL true cost: 7 0.22152897715568542\n",
      "REWARD  true cost: 5 0.22172772884368896\n",
      "\n",
      "end-to-end cost: 0.357455849647522\n",
      "2-stage    cost: 3.437359571456909\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1687043160200119\n",
      "RANDOM  true cost:  -1 0.24456445624430975\n",
      "OPTIMAL true cost: 5 0.16660824418067932\n",
      "REWARD  true cost: 6 0.17241567373275757\n",
      "\n",
      "end-to-end cost: 0.25589519739151\n",
      "2-stage    cost: 8.28280258178711\n",
      "TRUE\n",
      "CHOSEN  true cost: 7 0.1531859040260315\n",
      "RANDOM  true cost:  -1 0.2068797027071317\n",
      "OPTIMAL true cost: 2 0.1471339464187622\n",
      "REWARD  true cost: 3 0.14880229532718658\n",
      "\n",
      "end-to-end cost: 0.2964409291744232\n",
      "2-stage    cost: 0.6300200819969177\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.2634015381336212\n",
      "RANDOM  true cost:  -1 0.28269150480628014\n",
      "OPTIMAL true cost: 17 0.24753336608409882\n",
      "REWARD  true cost: 2 0.2917013168334961\n",
      "\n",
      "end-to-end cost: 0.35509225726127625\n",
      "2-stage    cost: 0.03691653162240982\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.19114968180656433\n",
      "RANDOM  true cost:  -1 0.2532485456516345\n",
      "OPTIMAL true cost: 5 0.19114968180656433\n",
      "REWARD  true cost: 7 0.19499270617961884\n",
      "\n",
      "end-to-end cost: 0.34461283683776855\n",
      "2-stage    cost: 0.41476890444755554\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.1660279780626297\n",
      "RANDOM  true cost:  -1 0.23822471189002195\n",
      "OPTIMAL true cost: 5 0.1639004349708557\n",
      "REWARD  true cost: 10 0.1908864676952362\n",
      "\n",
      "end-to-end cost: 0.2345752716064453\n",
      "2-stage    cost: 4.995182991027832\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3367205858230591\n",
      "RANDOM  true cost:  -1 0.3174515614906947\n",
      "OPTIMAL true cost: 2 0.13806001842021942\n",
      "REWARD  true cost: 2 0.13806001842021942\n",
      "\n",
      "end-to-end cost: 0.2401120364665985\n",
      "2-stage    cost: 0.09623261541128159\n",
      "TRUE\n",
      "CHOSEN  true cost: 18 0.21143738925457\n",
      "RANDOM  true cost:  -1 0.20566276460886002\n",
      "OPTIMAL true cost: 2 0.18730995059013367\n",
      "REWARD  true cost: 3 0.1912621110677719\n",
      "\n",
      "end-to-end cost: 0.26992765069007874\n",
      "2-stage    cost: 2.263467311859131\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.2190822809934616\n",
      "RANDOM  true cost:  -1 0.20550096904238066\n",
      "OPTIMAL true cost: 2 0.15975885093212128\n",
      "REWARD  true cost: 7 0.16699174046516418\n",
      "\n",
      "end-to-end cost: 0.2681618630886078\n",
      "2-stage    cost: 3.444735288619995\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.1798652708530426\n",
      "RANDOM  true cost:  -1 0.2152315489947796\n",
      "OPTIMAL true cost: 2 0.17368289828300476\n",
      "REWARD  true cost: 4 0.17615953087806702\n",
      "\n",
      "end-to-end cost: 0.27312806248664856\n",
      "2-stage    cost: 1.0114638805389404\n",
      "TRUE\n",
      "CHOSEN  true cost: 6 0.19450905919075012\n",
      "RANDOM  true cost:  -1 0.2248072773218155\n",
      "OPTIMAL true cost: 2 0.1900012195110321\n",
      "REWARD  true cost: 7 0.19370949268341064\n",
      "\n",
      "end-to-end cost: 0.14224475622177124\n",
      "2-stage    cost: 3.783766508102417\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.3715423345565796\n",
      "RANDOM  true cost:  -1 0.28297713305801153\n",
      "OPTIMAL true cost: 14 0.11878039687871933\n",
      "REWARD  true cost: 2 0.3129926919937134\n",
      "\n",
      "end-to-end cost: 0.12959137558937073\n",
      "2-stage    cost: 0.07692315429449081\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.13066911697387695\n",
      "RANDOM  true cost:  -1 0.14914709205428758\n",
      "OPTIMAL true cost: 0 0.12959137558937073\n",
      "REWARD  true cost: 17 0.1322571039199829\n",
      "\n",
      "end-to-end cost: 0.22755751013755798\n",
      "2-stage    cost: 0.055655062198638916\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1943013072013855\n",
      "RANDOM  true cost:  -1 0.19228395509223142\n",
      "OPTIMAL true cost: 2 0.17030775547027588\n",
      "REWARD  true cost: 3 0.1717916578054428\n",
      "\n",
      "end-to-end cost: 0.27711209654808044\n",
      "2-stage    cost: 0.461273729801178\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.2186584323644638\n",
      "RANDOM  true cost:  -1 0.22948366527756056\n",
      "OPTIMAL true cost: 2 0.20630089938640594\n",
      "REWARD  true cost: 7 0.21551816165447235\n",
      "\n",
      "end-to-end cost: 0.24203598499298096\n",
      "2-stage    cost: 5.306203842163086\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.13790404796600342\n",
      "RANDOM  true cost:  -1 0.1811147897193829\n",
      "OPTIMAL true cost: 2 0.13347817957401276\n",
      "REWARD  true cost: 7 0.14139702916145325\n",
      "\n",
      "end-to-end cost: 0.21987804770469666\n",
      "2-stage    cost: 4.724768161773682\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.18826055526733398\n",
      "RANDOM  true cost:  -1 0.18714373372495174\n",
      "OPTIMAL true cost: 2 0.15615643560886383\n",
      "REWARD  true cost: 5 0.15866096317768097\n",
      "\n",
      "end-to-end cost: 0.16587838530540466\n",
      "2-stage    cost: 4.387317180633545\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.13791608810424805\n",
      "RANDOM  true cost:  -1 0.15609896245102087\n",
      "OPTIMAL true cost: 2 0.13740286231040955\n",
      "REWARD  true cost: 7 0.1424485743045807\n",
      "\n",
      "end-to-end cost: 0.06788123399019241\n",
      "2-stage    cost: 0.581438422203064\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.09148377180099487\n",
      "RANDOM  true cost:  -1 0.0968556022271514\n",
      "OPTIMAL true cost: 0 0.06788123399019241\n",
      "REWARD  true cost: 5 0.1159677729010582\n",
      "\n",
      "end-to-end cost: 0.14827798306941986\n",
      "2-stage    cost: 0.06278359889984131\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.15606839954853058\n",
      "RANDOM  true cost:  -1 0.16652962130804858\n",
      "OPTIMAL true cost: 0 0.14827798306941986\n",
      "REWARD  true cost: 3 0.17854103446006775\n",
      "\n",
      "end-to-end cost: 0.30300459265708923\n",
      "2-stage    cost: 0.09186257421970367\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.2188635766506195\n",
      "RANDOM  true cost:  -1 0.24014594281713167\n",
      "OPTIMAL true cost: 2 0.20795419812202454\n",
      "REWARD  true cost: 6 0.2140602171421051\n",
      "\n",
      "end-to-end cost: 0.3153730034828186\n",
      "2-stage    cost: 1.4904980659484863\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.16118358075618744\n",
      "RANDOM  true cost:  -1 0.22451227034131685\n",
      "OPTIMAL true cost: 5 0.16118358075618744\n",
      "REWARD  true cost: 3 0.16145768761634827\n",
      "\n",
      "end-to-end cost: 0.31347203254699707\n",
      "2-stage    cost: 0.06379988044500351\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18839053809642792\n",
      "RANDOM  true cost:  -1 0.2381647750735283\n",
      "OPTIMAL true cost: 2 0.18740078806877136\n",
      "REWARD  true cost: 10 0.2051522433757782\n",
      "\n",
      "end-to-end cost: 0.43084749579429626\n",
      "2-stage    cost: 0.2079009711742401\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.28095507621765137\n",
      "RANDOM  true cost:  -1 0.33273671567440033\n",
      "OPTIMAL true cost: 2 0.28095299005508423\n",
      "REWARD  true cost: 2 0.28095299005508423\n",
      "\n",
      "end-to-end cost: 0.4897596836090088\n",
      "2-stage    cost: 0.1512255072593689\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.2979733943939209\n",
      "RANDOM  true cost:  -1 0.3660587842265765\n",
      "OPTIMAL true cost: 5 0.2957846522331238\n",
      "REWARD  true cost: 17 0.39016637206077576\n",
      "\n",
      "end-to-end cost: 0.4345580041408539\n",
      "2-stage    cost: 0.28382402658462524\n",
      "TRUE\n",
      "CHOSEN  true cost: 11 0.29084646701812744\n",
      "RANDOM  true cost:  -1 0.3199232965707779\n",
      "OPTIMAL true cost: 5 0.2488943338394165\n",
      "REWARD  true cost: 5 0.2488943338394165\n",
      "\n",
      "end-to-end cost: 0.24381372332572937\n",
      "2-stage    cost: 9.194320678710938\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.5345024466514587\n",
      "RANDOM  true cost:  -1 0.37984275569518405\n",
      "OPTIMAL true cost: 1 0.14804740250110626\n",
      "REWARD  true cost: 5 0.5345024466514587\n",
      "\n",
      "end-to-end cost: 0.13174277544021606\n",
      "2-stage    cost: 1.8303111791610718\n",
      "TRUE\n",
      "CHOSEN  true cost: 18 0.14619451761245728\n",
      "RANDOM  true cost:  -1 0.12672665684173504\n",
      "OPTIMAL true cost: 1 0.10743404924869537\n",
      "REWARD  true cost: 4 0.11311962455511093\n",
      "\n",
      "end-to-end cost: 0.12647509574890137\n",
      "2-stage    cost: 1.2740235328674316\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.11853818595409393\n",
      "RANDOM  true cost:  -1 0.11744095043589671\n",
      "OPTIMAL true cost: 1 0.1046021431684494\n",
      "REWARD  true cost: 2 0.10648694634437561\n",
      "\n",
      "end-to-end cost: 0.12325702607631683\n",
      "2-stage    cost: 2.3726675510406494\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.12399061769247055\n",
      "RANDOM  true cost:  -1 0.11545818982024987\n",
      "OPTIMAL true cost: 1 0.0987047553062439\n",
      "REWARD  true cost: 3 0.1052478775382042\n",
      "\n",
      "end-to-end cost: 0.22134122252464294\n",
      "2-stage    cost: 0.568141758441925\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.21412765979766846\n",
      "RANDOM  true cost:  -1 0.22487259345750013\n",
      "OPTIMAL true cost: 17 0.2109239101409912\n",
      "REWARD  true cost: 3 0.23524069786071777\n",
      "\n",
      "end-to-end cost: 0.31233924627304077\n",
      "2-stage    cost: 2.0645229816436768\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.21471178531646729\n",
      "RANDOM  true cost:  -1 0.24542501382529736\n",
      "OPTIMAL true cost: 2 0.20372669398784637\n",
      "REWARD  true cost: 7 0.20884108543395996\n",
      "\n",
      "end-to-end cost: 0.1980731338262558\n",
      "2-stage    cost: 1.7848118543624878\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.09950777143239975\n",
      "RANDOM  true cost:  -1 0.15046125122656426\n",
      "OPTIMAL true cost: 2 0.09825795143842697\n",
      "REWARD  true cost: 10 0.14605823159217834\n",
      "\n",
      "end-to-end cost: 0.21053561568260193\n",
      "2-stage    cost: 5.38297176361084\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.13217924535274506\n",
      "RANDOM  true cost:  -1 0.3336856023718913\n",
      "OPTIMAL true cost: 15 0.12027327716350555\n",
      "REWARD  true cost: 3 0.47564834356307983\n",
      "\n",
      "end-to-end cost: 0.28980553150177\n",
      "2-stage    cost: 1.3344677686691284\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.11644500494003296\n",
      "RANDOM  true cost:  -1 0.11441855334366362\n",
      "OPTIMAL true cost: 20 0.05935848876833916\n",
      "REWARD  true cost: 3 0.12091702222824097\n",
      "\n",
      "end-to-end cost: 0.07414080202579498\n",
      "2-stage    cost: 0.5715305209159851\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 0.11046480387449265\n",
      "RANDOM  true cost:  -1 0.13974048321445784\n",
      "OPTIMAL true cost: 0 0.07414080202579498\n",
      "REWARD  true cost: 3 0.18693962693214417\n",
      "\n",
      "end-to-end cost: 0.104453444480896\n",
      "2-stage    cost: 0.4472220540046692\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.11338387429714203\n",
      "RANDOM  true cost:  -1 0.12327519959459703\n",
      "OPTIMAL true cost: 0 0.104453444480896\n",
      "REWARD  true cost: 3 0.13505542278289795\n",
      "\n",
      "end-to-end cost: 0.2194204330444336\n",
      "2-stage    cost: 0.044781506061553955\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.2217319905757904\n",
      "RANDOM  true cost:  -1 0.21782968689997992\n",
      "OPTIMAL true cost: 14 0.20564711093902588\n",
      "REWARD  true cost: 3 0.22551056742668152\n",
      "\n",
      "end-to-end cost: 0.22057101130485535\n",
      "2-stage    cost: 3.0506131649017334\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.17385366559028625\n",
      "RANDOM  true cost:  -1 0.19027715610961118\n",
      "OPTIMAL true cost: 2 0.1643991470336914\n",
      "REWARD  true cost: 7 0.16969263553619385\n",
      "\n",
      "end-to-end cost: 0.10538118332624435\n",
      "2-stage    cost: 1.613119125366211\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.09878747165203094\n",
      "RANDOM  true cost:  -1 0.10673028447975715\n",
      "OPTIMAL true cost: 1 0.09032826125621796\n",
      "REWARD  true cost: 2 0.09879358112812042\n",
      "\n",
      "end-to-end cost: 0.13643941283226013\n",
      "2-stage    cost: 0.05206775665283203\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.1460469365119934\n",
      "RANDOM  true cost:  -1 0.15138189432521662\n",
      "OPTIMAL true cost: 0 0.13643941283226013\n",
      "REWARD  true cost: 3 0.15896427631378174\n",
      "\n",
      "end-to-end cost: 0.1804405152797699\n",
      "2-stage    cost: 0.41642993688583374\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.16869008541107178\n",
      "RANDOM  true cost:  -1 0.1601362799604734\n",
      "OPTIMAL true cost: 2 0.14105331897735596\n",
      "REWARD  true cost: 3 0.14373862743377686\n",
      "\n",
      "end-to-end cost: 0.12711606919765472\n",
      "2-stage    cost: 5.441534042358398\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 1.7241771221160889\n",
      "RANDOM  true cost:  -1 0.8868721798062325\n",
      "OPTIMAL true cost: 15 0.12698371708393097\n",
      "REWARD  true cost: 7 1.6552278995513916\n",
      "\n",
      "end-to-end cost: 0.10549610108137131\n",
      "2-stage    cost: 0.18664157390594482\n",
      "TRUE\n",
      "CHOSEN  true cost: 13 0.13335581123828888\n",
      "RANDOM  true cost:  -1 0.13600902383526167\n",
      "OPTIMAL true cost: 16 0.0981861799955368\n",
      "REWARD  true cost: 3 0.17292365431785583\n",
      "\n",
      "end-to-end cost: 0.16742905974388123\n",
      "2-stage    cost: 5.960880279541016\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.182903453707695\n",
      "RANDOM  true cost:  -1 0.16428200621157885\n",
      "OPTIMAL true cost: 11 0.12272145599126816\n",
      "REWARD  true cost: 1 0.14208543300628662\n",
      "\n",
      "end-to-end cost: 0.14675477147102356\n",
      "2-stage    cost: 2.62416410446167\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.1613798588514328\n",
      "RANDOM  true cost:  -1 0.17403434589505196\n",
      "OPTIMAL true cost: 0 0.14675477147102356\n",
      "REWARD  true cost: 3 0.18333624303340912\n",
      "\n",
      "end-to-end cost: 1.8591512441635132\n",
      "2-stage    cost: 11.51844596862793\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 1.3908947706222534\n",
      "RANDOM  true cost:  -1 1.9251474142074585\n",
      "OPTIMAL true cost: 14 1.186238169670105\n",
      "REWARD  true cost: 7 2.226348876953125\n",
      "\n",
      "end-to-end cost: 0.22821557521820068\n",
      "2-stage    cost: 0.3806019723415375\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 0.2654724717140198\n",
      "RANDOM  true cost:  -1 0.1959578851237893\n",
      "OPTIMAL true cost: 1 0.10240259021520615\n",
      "REWARD  true cost: 3 0.1454504430294037\n",
      "\n",
      "end-to-end cost: 0.16928105056285858\n",
      "2-stage    cost: 5.574777603149414\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.18392156064510345\n",
      "RANDOM  true cost:  -1 0.10384704327831666\n",
      "OPTIMAL true cost: 13 0.07579101622104645\n",
      "REWARD  true cost: 7 0.0872364491224289\n",
      "\n",
      "end-to-end cost: 0.16729745268821716\n",
      "2-stage    cost: 0.11775456368923187\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.16648490726947784\n",
      "RANDOM  true cost:  -1 0.1920977315555016\n",
      "OPTIMAL true cost: 17 0.15459156036376953\n",
      "REWARD  true cost: 3 0.2241567224264145\n",
      "\n",
      "end-to-end cost: 0.17987339198589325\n",
      "2-stage    cost: 8.1273193359375\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15871191024780273\n",
      "RANDOM  true cost:  -1 0.1446415592605869\n",
      "OPTIMAL true cost: 2 0.11135312169790268\n",
      "REWARD  true cost: 7 0.12009846419095993\n",
      "\n",
      "end-to-end cost: 0.26118025183677673\n",
      "2-stage    cost: 0.07722479104995728\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.2287215292453766\n",
      "RANDOM  true cost:  -1 0.24652765008310476\n",
      "OPTIMAL true cost: 17 0.2154024839401245\n",
      "REWARD  true cost: 3 0.25870341062545776\n",
      "\n",
      "end-to-end cost: 0.23622040450572968\n",
      "2-stage    cost: 5.491549968719482\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.16815254092216492\n",
      "RANDOM  true cost:  -1 0.1939223681886991\n",
      "OPTIMAL true cost: 2 0.16294309496879578\n",
      "REWARD  true cost: 5 0.16773538291454315\n",
      "\n",
      "end-to-end cost: 0.0989270806312561\n",
      "2-stage    cost: 1.9630708694458008\n",
      "TRUE\n",
      "CHOSEN  true cost: 14 0.10409367084503174\n",
      "RANDOM  true cost:  -1 0.10330543511857589\n",
      "OPTIMAL true cost: 1 0.07875913381576538\n",
      "REWARD  true cost: 3 0.08889144659042358\n",
      "\n",
      "end-to-end cost: 0.09940680116415024\n",
      "2-stage    cost: 2.278140068054199\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.11053068935871124\n",
      "RANDOM  true cost:  -1 0.10625806637108326\n",
      "OPTIMAL true cost: 1 0.0875202938914299\n",
      "REWARD  true cost: 2 0.09652093052864075\n",
      "\n",
      "end-to-end cost: 0.09693899005651474\n",
      "2-stage    cost: 2.748074531555176\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.11074464023113251\n",
      "RANDOM  true cost:  -1 0.10872581135481596\n",
      "OPTIMAL true cost: 1 0.09162956476211548\n",
      "REWARD  true cost: 3 0.10509639978408813\n",
      "\n",
      "end-to-end cost: 0.10746701806783676\n",
      "2-stage    cost: 0.37797972559928894\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.11373644322156906\n",
      "RANDOM  true cost:  -1 0.13015690135459104\n",
      "OPTIMAL true cost: 0 0.10746701806783676\n",
      "REWARD  true cost: 3 0.15162047743797302\n",
      "\n",
      "end-to-end cost: 0.09670080989599228\n",
      "2-stage    cost: 6.809798717498779\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.12430929392576218\n",
      "RANDOM  true cost:  -1 0.20338502464195093\n",
      "OPTIMAL true cost: 0 0.09670080989599228\n",
      "REWARD  true cost: 3 0.28937703371047974\n",
      "\n",
      "end-to-end cost: 0.161134272813797\n",
      "2-stage    cost: 1.0113247632980347\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.1656227856874466\n",
      "RANDOM  true cost:  -1 0.18930394450823465\n",
      "OPTIMAL true cost: 17 0.1609058976173401\n",
      "REWARD  true cost: 2 0.21022343635559082\n",
      "\n",
      "end-to-end cost: 0.2628692388534546\n",
      "2-stage    cost: 2.410572052001953\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.19473284482955933\n",
      "RANDOM  true cost:  -1 0.21757422325511774\n",
      "OPTIMAL true cost: 2 0.18685123324394226\n",
      "REWARD  true cost: 8 0.1942960023880005\n",
      "\n",
      "end-to-end cost: 0.1757734715938568\n",
      "2-stage    cost: 0.8977106809616089\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.11109995096921921\n",
      "RANDOM  true cost:  -1 0.13830636131266752\n",
      "OPTIMAL true cost: 2 0.10679146647453308\n",
      "REWARD  true cost: 8 0.11854091286659241\n",
      "\n",
      "end-to-end cost: 0.11559560894966125\n",
      "2-stage    cost: 3.979325294494629\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.12908776104450226\n",
      "RANDOM  true cost:  -1 0.14996473708500466\n",
      "OPTIMAL true cost: 1 0.07983902096748352\n",
      "REWARD  true cost: 3 0.1350764036178589\n",
      "\n",
      "end-to-end cost: 0.8461155891418457\n",
      "2-stage    cost: 4.2025556564331055\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.7215831279754639\n",
      "RANDOM  true cost:  -1 0.44218038270870846\n",
      "OPTIMAL true cost: 10 0.08484198898077011\n",
      "REWARD  true cost: 7 0.10087206214666367\n",
      "\n",
      "end-to-end cost: 1.5020369291305542\n",
      "2-stage    cost: 7.270171642303467\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 1.5133333206176758\n",
      "RANDOM  true cost:  -1 0.6996011094500622\n",
      "OPTIMAL true cost: 10 0.08508174121379852\n",
      "REWARD  true cost: 7 0.1026107668876648\n",
      "\n",
      "end-to-end cost: 1.2487006187438965\n",
      "2-stage    cost: 3.165071487426758\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 1.286802053451538\n",
      "RANDOM  true cost:  -1 0.7921663224697113\n",
      "OPTIMAL true cost: 2 0.11817312240600586\n",
      "REWARD  true cost: 7 0.40148961544036865\n",
      "\n",
      "end-to-end cost: 0.10506274551153183\n",
      "2-stage    cost: 7.203113555908203\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.12459161877632141\n",
      "RANDOM  true cost:  -1 0.14384413044899702\n",
      "OPTIMAL true cost: 0 0.10506274551153183\n",
      "REWARD  true cost: 7 0.16991391777992249\n",
      "\n",
      "end-to-end cost: 0.18136587738990784\n",
      "2-stage    cost: 0.9324091672897339\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.1809423565864563\n",
      "RANDOM  true cost:  -1 0.20845096496244273\n",
      "OPTIMAL true cost: 17 0.16910657286643982\n",
      "REWARD  true cost: 3 0.2441900670528412\n",
      "\n",
      "end-to-end cost: 0.18113481998443604\n",
      "2-stage    cost: 5.287100315093994\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.12808457016944885\n",
      "RANDOM  true cost:  -1 0.1548629365861416\n",
      "OPTIMAL true cost: 1 0.12808457016944885\n",
      "REWARD  true cost: 7 0.1589815318584442\n",
      "\n",
      "end-to-end cost: 0.2658420205116272\n",
      "2-stage    cost: 7.058877944946289\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.29314348101615906\n",
      "RANDOM  true cost:  -1 0.57835195834438\n",
      "OPTIMAL true cost: 0 0.2658420205116272\n",
      "REWARD  true cost: 7 0.8233346343040466\n",
      "\n",
      "end-to-end cost: 0.17457115650177002\n",
      "2-stage    cost: 1.2249383926391602\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.1512024998664856\n",
      "RANDOM  true cost:  -1 0.17136802275975546\n",
      "OPTIMAL true cost: 17 0.15046793222427368\n",
      "REWARD  true cost: 2 0.1742185801267624\n",
      "\n",
      "end-to-end cost: 0.15404373407363892\n",
      "2-stage    cost: 8.802978515625\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.143728569149971\n",
      "RANDOM  true cost:  -1 0.13987901713699102\n",
      "OPTIMAL true cost: 1 0.09855777025222778\n",
      "REWARD  true cost: 2 0.1338304877281189\n",
      "\n",
      "end-to-end cost: 0.14374294877052307\n",
      "2-stage    cost: 2.4915835857391357\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15805619955062866\n",
      "RANDOM  true cost:  -1 0.1380567786594232\n",
      "OPTIMAL true cost: 1 0.11772924661636353\n",
      "REWARD  true cost: 3 0.1226595863699913\n",
      "\n",
      "end-to-end cost: 0.15395116806030273\n",
      "2-stage    cost: 5.555337905883789\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.1323217749595642\n",
      "RANDOM  true cost:  -1 0.14957459395130476\n",
      "OPTIMAL true cost: 1 0.1323217749595642\n",
      "REWARD  true cost: 7 0.14215528964996338\n",
      "\n",
      "end-to-end cost: 0.2526305913925171\n",
      "2-stage    cost: 0.5581957101821899\n",
      "TRUE\n",
      "CHOSEN  true cost: 1 0.25219616293907166\n",
      "RANDOM  true cost:  -1 0.25432795472443104\n",
      "OPTIMAL true cost: 17 0.21774469316005707\n",
      "REWARD  true cost: 2 0.26984912157058716\n",
      "\n",
      "end-to-end cost: 0.2827831506729126\n",
      "2-stage    cost: 0.05739615485072136\n",
      "TRUE\n",
      "CHOSEN  true cost: 11 0.1888534277677536\n",
      "RANDOM  true cost:  -1 0.2067261232684056\n",
      "OPTIMAL true cost: 2 0.15392926335334778\n",
      "REWARD  true cost: 18 0.24156080186367035\n",
      "\n",
      "end-to-end cost: 0.2623671889305115\n",
      "2-stage    cost: 2.528815507888794\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.132395938038826\n",
      "RANDOM  true cost:  -1 0.18862892997761568\n",
      "OPTIMAL true cost: 2 0.13029712438583374\n",
      "REWARD  true cost: 7 0.13688208162784576\n",
      "\n",
      "end-to-end cost: 0.19338957965373993\n",
      "2-stage    cost: 3.789093017578125\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.12948328256607056\n",
      "RANDOM  true cost:  -1 0.15451626727978388\n",
      "OPTIMAL true cost: 2 0.10192564129829407\n",
      "REWARD  true cost: 3 0.102719746530056\n",
      "\n",
      "end-to-end cost: 0.2785526216030121\n",
      "2-stage    cost: 8.005020141601562\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.06257861107587814\n",
      "RANDOM  true cost:  -1 0.12093245672682922\n",
      "OPTIMAL true cost: 5 0.05302653834223747\n",
      "REWARD  true cost: 2 0.18057861924171448\n",
      "\n",
      "end-to-end cost: 0.07995589822530746\n",
      "2-stage    cost: 0.4253969192504883\n",
      "TRUE\n",
      "CHOSEN  true cost: 19 0.1116376519203186\n",
      "RANDOM  true cost:  -1 0.13452487221608558\n",
      "OPTIMAL true cost: 0 0.07995589822530746\n",
      "REWARD  true cost: 3 0.1703108549118042\n",
      "\n",
      "end-to-end cost: 0.13049590587615967\n",
      "2-stage    cost: 8.020963668823242\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.14121964573860168\n",
      "RANDOM  true cost:  -1 0.1296980225791534\n",
      "OPTIMAL true cost: 11 0.11330598592758179\n",
      "REWARD  true cost: 2 0.11944382637739182\n",
      "\n",
      "end-to-end cost: 0.11312048137187958\n",
      "2-stage    cost: 2.02848482131958\n",
      "TRUE\n",
      "CHOSEN  true cost: 22 0.12898384034633636\n",
      "RANDOM  true cost:  -1 0.14769066528727612\n",
      "OPTIMAL true cost: 0 0.11312048137187958\n",
      "REWARD  true cost: 3 0.16853246092796326\n",
      "\n",
      "end-to-end cost: 0.10200335830450058\n",
      "2-stage    cost: 2.2832324504852295\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.10973736643791199\n",
      "RANDOM  true cost:  -1 0.10025571472942829\n",
      "OPTIMAL true cost: 1 0.08548899739980698\n",
      "REWARD  true cost: 7 0.09983628988265991\n",
      "\n",
      "end-to-end cost: 0.1608254760503769\n",
      "2-stage    cost: 0.8493859171867371\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.15281757712364197\n",
      "RANDOM  true cost:  -1 0.14116829602668682\n",
      "OPTIMAL true cost: 2 0.11995013803243637\n",
      "REWARD  true cost: 3 0.12248800694942474\n",
      "\n",
      "end-to-end cost: 0.2009209394454956\n",
      "2-stage    cost: 0.12721222639083862\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.14528754353523254\n",
      "RANDOM  true cost:  -1 0.16041687379280725\n",
      "OPTIMAL true cost: 2 0.13402502238750458\n",
      "REWARD  true cost: 2 0.13402502238750458\n",
      "\n",
      "end-to-end cost: 0.26783955097198486\n",
      "2-stage    cost: 0.04196207970380783\n",
      "TRUE\n",
      "CHOSEN  true cost: 16 0.21855247020721436\n",
      "RANDOM  true cost:  -1 0.21417970272401968\n",
      "OPTIMAL true cost: 2 0.1801605224609375\n",
      "REWARD  true cost: 3 0.1832924485206604\n",
      "\n",
      "end-to-end cost: 0.32941538095474243\n",
      "2-stage    cost: 0.031190965324640274\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18698495626449585\n",
      "RANDOM  true cost:  -1 0.24229299339155355\n",
      "OPTIMAL true cost: 2 0.18504834175109863\n",
      "REWARD  true cost: 3 0.18622469902038574\n",
      "\n",
      "end-to-end cost: 0.4124922454357147\n",
      "2-stage    cost: 0.5449248552322388\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2455681562423706\n",
      "RANDOM  true cost:  -1 0.30760587379336357\n",
      "OPTIMAL true cost: 5 0.2440023422241211\n",
      "REWARD  true cost: 7 0.24697166681289673\n",
      "\n",
      "end-to-end cost: 0.4070814549922943\n",
      "2-stage    cost: 0.8654333353042603\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.23046836256980896\n",
      "RANDOM  true cost:  -1 0.2997403747091691\n",
      "OPTIMAL true cost: 5 0.23046836256980896\n",
      "REWARD  true cost: 8 0.24208495020866394\n",
      "\n",
      "end-to-end cost: 0.3362197279930115\n",
      "2-stage    cost: 2.9289817810058594\n",
      "TRUE\n",
      "CHOSEN  true cost: 8 0.18849310278892517\n",
      "RANDOM  true cost:  -1 0.2425662831713756\n",
      "OPTIMAL true cost: 5 0.1775180697441101\n",
      "REWARD  true cost: 10 0.1963857114315033\n",
      "\n",
      "end-to-end cost: 0.17541474103927612\n",
      "2-stage    cost: 4.83664608001709\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 2.3685543537139893\n",
      "RANDOM  true cost:  -1 1.2815361494819324\n",
      "OPTIMAL true cost: 16 0.16780781745910645\n",
      "REWARD  true cost: 3 1.907536506652832\n",
      "\n",
      "end-to-end cost: 0.20206448435783386\n",
      "2-stage    cost: 4.385106086730957\n",
      "TRUE\n",
      "CHOSEN  true cost: 23 0.20943647623062134\n",
      "RANDOM  true cost:  -1 0.25173648322621983\n",
      "OPTIMAL true cost: 14 0.1282077431678772\n",
      "REWARD  true cost: 3 0.35270625352859497\n",
      "\n",
      "end-to-end cost: 0.18296746909618378\n",
      "2-stage    cost: 3.3154494762420654\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.20329976081848145\n",
      "RANDOM  true cost:  -1 0.15171939879655838\n",
      "OPTIMAL true cost: 1 0.07719414681196213\n",
      "REWARD  true cost: 3 0.11783427000045776\n",
      "\n",
      "end-to-end cost: 0.1321282982826233\n",
      "2-stage    cost: 0.07363750040531158\n",
      "TRUE\n",
      "CHOSEN  true cost: 21 0.13390304148197174\n",
      "RANDOM  true cost:  -1 0.1617523841559887\n",
      "OPTIMAL true cost: 17 0.12780585885047913\n",
      "REWARD  true cost: 3 0.19602195918560028\n",
      "\n",
      "end-to-end cost: 0.16172581911087036\n",
      "2-stage    cost: 11.595497131347656\n",
      "TRUE\n",
      "CHOSEN  true cost: 15 0.16670219600200653\n",
      "RANDOM  true cost:  -1 0.15768523017565408\n",
      "OPTIMAL true cost: 1 0.13400709629058838\n",
      "REWARD  true cost: 7 0.1442822813987732\n",
      "\n",
      "end-to-end cost: 0.3236251771450043\n",
      "2-stage    cost: 0.1359911412000656\n",
      "TRUE\n",
      "CHOSEN  true cost: 9 0.3057945966720581\n",
      "RANDOM  true cost:  -1 0.2976708735028903\n",
      "OPTIMAL true cost: 16 0.26963669061660767\n",
      "REWARD  true cost: 7 0.30526891350746155\n",
      "\n",
      "end-to-end cost: 0.2966560125350952\n",
      "2-stage    cost: 1.6937074661254883\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.1301959902048111\n",
      "RANDOM  true cost:  -1 0.19857823910812536\n",
      "OPTIMAL true cost: 5 0.12914596498012543\n",
      "REWARD  true cost: 10 0.15479111671447754\n",
      "\n",
      "end-to-end cost: 0.24691081047058105\n",
      "2-stage    cost: 3.332862377166748\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.11077907681465149\n",
      "RANDOM  true cost:  -1 0.21113086181382337\n",
      "OPTIMAL true cost: 2 0.10864615440368652\n",
      "REWARD  true cost: 10 0.27189257740974426\n",
      "\n",
      "end-to-end cost: 0.25450509786605835\n",
      "2-stage    cost: 0.31013941764831543\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.14583414793014526\n",
      "RANDOM  true cost:  -1 0.19371792611976466\n",
      "OPTIMAL true cost: 2 0.14425471425056458\n",
      "REWARD  true cost: 7 0.15118831396102905\n",
      "\n",
      "end-to-end cost: 0.3251407742500305\n",
      "2-stage    cost: 0.029444513842463493\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.18072430789470673\n",
      "RANDOM  true cost:  -1 0.23570593694845834\n",
      "OPTIMAL true cost: 2 0.1788909137248993\n",
      "REWARD  true cost: 3 0.180393248796463\n",
      "\n",
      "end-to-end cost: 0.31009185314178467\n",
      "2-stage    cost: 3.5953845977783203\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.13694645464420319\n",
      "RANDOM  true cost:  -1 0.20859037525951862\n",
      "OPTIMAL true cost: 5 0.1354924440383911\n",
      "REWARD  true cost: 3 0.13694645464420319\n",
      "\n",
      "end-to-end cost: 0.3290513753890991\n",
      "2-stage    cost: 1.8097319602966309\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.20097637176513672\n",
      "RANDOM  true cost:  -1 0.24987554363906384\n",
      "OPTIMAL true cost: 2 0.1988038718700409\n",
      "REWARD  true cost: 3 0.20097637176513672\n",
      "\n",
      "end-to-end cost: 0.35960230231285095\n",
      "2-stage    cost: 0.0681276023387909\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2769227921962738\n",
      "RANDOM  true cost:  -1 0.2987034507095814\n",
      "OPTIMAL true cost: 2 0.272128164768219\n",
      "REWARD  true cost: 10 0.2843143343925476\n",
      "\n",
      "end-to-end cost: 0.2626383304595947\n",
      "2-stage    cost: 3.483309507369995\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.12857604026794434\n",
      "RANDOM  true cost:  -1 0.18262619338929653\n",
      "OPTIMAL true cost: 2 0.12515594065189362\n",
      "REWARD  true cost: 7 0.1327984780073166\n",
      "\n",
      "end-to-end cost: 0.23650793731212616\n",
      "2-stage    cost: 3.384460210800171\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.11934597790241241\n",
      "RANDOM  true cost:  -1 0.17029316537082195\n",
      "OPTIMAL true cost: 2 0.11709462106227875\n",
      "REWARD  true cost: 3 0.11934597790241241\n",
      "\n",
      "end-to-end cost: 0.20839819312095642\n",
      "2-stage    cost: 2.0464227199554443\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.10476723313331604\n",
      "RANDOM  true cost:  -1 0.15051376912742853\n",
      "OPTIMAL true cost: 2 0.10344027727842331\n",
      "REWARD  true cost: 8 0.11548110842704773\n",
      "\n",
      "end-to-end cost: 0.196096271276474\n",
      "2-stage    cost: 1.9724959135055542\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.10810830444097519\n",
      "RANDOM  true cost:  -1 0.14639955976357064\n",
      "OPTIMAL true cost: 2 0.10404183715581894\n",
      "REWARD  true cost: 3 0.10630206763744354\n",
      "\n",
      "end-to-end cost: 0.17578765749931335\n",
      "2-stage    cost: 3.3822684288024902\n",
      "TRUE\n",
      "CHOSEN  true cost: 4 0.23136691749095917\n",
      "RANDOM  true cost:  -1 0.20917411738385758\n",
      "OPTIMAL true cost: 1 0.10742606967687607\n",
      "REWARD  true cost: 3 0.1651081144809723\n",
      "\n",
      "end-to-end cost: 0.3357381522655487\n",
      "2-stage    cost: 0.5890231132507324\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.2845926880836487\n",
      "RANDOM  true cost:  -1 0.28878844901919365\n",
      "OPTIMAL true cost: 16 0.2606624364852905\n",
      "REWARD  true cost: 2 0.2783425450325012\n",
      "\n",
      "end-to-end cost: 0.45958656072616577\n",
      "2-stage    cost: 0.07273821532726288\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2732347249984741\n",
      "RANDOM  true cost:  -1 0.3383026073376338\n",
      "OPTIMAL true cost: 5 0.2700687050819397\n",
      "REWARD  true cost: 2 0.27690714597702026\n",
      "\n",
      "end-to-end cost: 0.37634629011154175\n",
      "2-stage    cost: 0.9913161993026733\n",
      "TRUE\n",
      "CHOSEN  true cost: 5 0.1743767261505127\n",
      "RANDOM  true cost:  -1 0.2734130024909973\n",
      "OPTIMAL true cost: 4 0.17371897399425507\n",
      "REWARD  true cost: 10 0.25304388999938965\n",
      "\n",
      "end-to-end cost: 0.41030535101890564\n",
      "2-stage    cost: 0.044390253722667694\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.22401216626167297\n",
      "RANDOM  true cost:  -1 0.2929221012940009\n",
      "OPTIMAL true cost: 5 0.22102177143096924\n",
      "REWARD  true cost: 3 0.22401216626167297\n",
      "\n",
      "end-to-end cost: 0.4861762225627899\n",
      "2-stage    cost: 1.4475209712982178\n",
      "TRUE\n",
      "CHOSEN  true cost: 3 0.2942321300506592\n",
      "RANDOM  true cost:  -1 0.3528251349925995\n",
      "OPTIMAL true cost: 3 0.2942321300506592\n",
      "REWARD  true cost: 10 0.3162403106689453\n",
      "\n"
     ]
    }
   ],
   "source": [
    "vanilla = [] \n",
    "ours = [] \n",
    "random = []\n",
    "optimal = []\n",
    "two_stage = []\n",
    "all_costs = []\n",
    "end_to_end_net.eval()\n",
    "f_net.eval()\n",
    "p_net.eval()\n",
    "reward_losses = []\n",
    "\n",
    "my_decisions = []\n",
    "\n",
    "\n",
    "for indx in range(len(X_test_pt)):\n",
    "# for indx in [2]:\n",
    "    X_t = X_test_pt[indx:indx+1,:]\n",
    "    Y_t = Y_test_pt[indx:indx+1,:]\n",
    "    # X_t = X_train_pt[indx:indx+1,:]\n",
    "    # Y_t = Y_train_pt[indx:indx+1,:]\n",
    "\n",
    "    # e2e = nets.task_loss(end_to_end_net.predict(X_t), Y_t, params).mean().item()\n",
    "    e2e_pred = p_net(X_t, torch.zeros_like(Y_t), torch.zeros_like(Y_t))\n",
    "    e2e = nets.task_loss(e2e_pred, Y_t, params).mean().item() \n",
    "\n",
    "    ts = nets.task_loss(model_rmse(X_t), Y_t, params).mean().item()\n",
    "    \n",
    "    print(\"end-to-end cost:\", e2e)\n",
    "    print(\"2-stage    cost:\", ts)\n",
    "\n",
    "    a = 0.0\n",
    "    best_cost = 1e5 \n",
    "    best_w = -1\n",
    "    cur_costs = [] \n",
    "    for w in range(24):\n",
    "        c = pred_obj(X_t, w)\n",
    "        # print(w, c)\n",
    "        if c < best_cost: \n",
    "            best_cost = c\n",
    "            best_w = w\n",
    "            \n",
    "    my_decisions.append(best_w)\n",
    "    our = eval_decision(X_t, Y_t, best_w) + a*best_w\n",
    "\n",
    "    r = np.random.randint(24)\n",
    "    rand = eval_decision(X_t, Y_t, r) + a*r\n",
    "    \n",
    "    print(\"TRUE\")\n",
    "    best_cost = 1e5 \n",
    "    best_dec = -1\n",
    "    uniform_random = 0\n",
    "    for w in range(24): \n",
    "        cur = eval_decision(X_t, Y_t, w) + a*w\n",
    "        # print(w, cur)\n",
    "        if cur < best_cost: \n",
    "            best_cost = cur \n",
    "            best_dec = w\n",
    "        uniform_random += cur\n",
    "        cur_costs.append(cur)\n",
    "    all_costs.append(cur_costs)\n",
    "    \n",
    "    reward_loss = eval_decision(X_t, Y_t, reward_actions[indx]) \n",
    "    reward_losses.append(reward_loss)\n",
    "    \n",
    "    # if best_dec == 0: continue \n",
    "    \n",
    "    optimal.append(best_cost)\n",
    "    vanilla.append(e2e)    \n",
    "    ours.append(our)\n",
    "    random.append(uniform_random/24)\n",
    "    two_stage.append(ts)\n",
    "    \n",
    "    print(\"CHOSEN  true cost:\", best_w, our)\n",
    "    print(\"RANDOM  true cost: \", -1, uniform_random/24)\n",
    "    print(\"OPTIMAL true cost:\", best_dec, best_cost)\n",
    "    print(\"REWARD  true cost:\", reward_actions[indx], reward_loss)\n",
    "    print()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "3d6b489c-818b-4e37-b888-5940ae3cfefd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# best sinle action\n",
    "avg_cost_per_action = np.mean(all_costs, axis=0)\n",
    "all_costs = np.array(all_costs)\n",
    "\n",
    "single_action=1\n",
    "\n",
    "ours = np.array(ours) \n",
    "reward_losses = np.array(reward_losses) \n",
    "vanilla = np.array(vanilla) \n",
    "random = np.array(random)\n",
    "# single_action = np.argmin(avg_cost_per_action)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "180ddd4a-6a9f-4c63-92e2-ce0d84efe5ab",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "VANILLA e2e 0.34955737082191474 0.21092612916485454\n",
      "Our app     0.23371138570594116 0.1831784826860976\n",
      "Reward     0.23666919817993526 0.15589484795428954\n",
      "random      0.2690549707304964 0.1398300638928127\n",
      "optimal     0.19746924370107516 0.0708102836430697\n",
      "2-s         1.425195986585741 1.9306447946765468\n",
      "single ac   0.26670864894869556 1\n"
     ]
    }
   ],
   "source": [
    "print(\"VANILLA e2e\", np.mean(vanilla), np.std(vanilla))\n",
    "print(\"Our app    \", np.mean(ours), np.std(ours))\n",
    "print(\"Reward    \", np.mean(reward_losses), np.std(reward_losses))\n",
    "print(\"random     \", np.mean(random), np.std(random))\n",
    "print(\"optimal    \", np.mean(optimal), np.std(optimal))\n",
    "print(\"2-s        \", np.mean(two_stage), np.std(two_stage))\n",
    "print(\"single ac  \", avg_cost_per_action[single_action], single_action)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "id": "b206be77-1be8-4c9f-8c99-c90b44ad603c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "VANILLA e2e   0.3502837121486664 0.21092612916485454\n",
      "Our app       0.20919057726860046 0.1831784826860976\n",
      "random        0.26394308047990006 0.1398300638928127\n",
      "reward        0.22011375427246094 0.1398300638928127\n",
      "optimal       0.19834409654140472 0.0708102836430697\n",
      "single ac     0.2607725262641907\n",
      "2-stage       0.5649001598358154 1.9306447946765468\n"
     ]
    }
   ],
   "source": [
    "QUANTILE = 0.5\n",
    "print(\"VANILLA e2e  \", np.quantile(vanilla, QUANTILE), np.std(vanilla))\n",
    "print(\"Our app      \", np.quantile(ours, QUANTILE), np.std(ours))\n",
    "print(\"random       \", np.quantile(random, QUANTILE), np.std(random))\n",
    "print(\"reward       \", np.quantile(reward_losses, QUANTILE), np.std(random))\n",
    "print(\"optimal      \", np.quantile(optimal, QUANTILE), np.std(optimal))\n",
    "print(\"single ac    \", np.quantile(all_costs[:,single_action], QUANTILE))\n",
    "print(\"2-stage      \", np.quantile(two_stage, QUANTILE), np.std(two_stage))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 138,
   "id": "caefc04d-36ea-4f39-ae73-e6b5a85cfa2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "P = 1.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "340b0473-0594-40e7-afed-763489a57358",
   "metadata": {},
   "outputs": [],
   "source": [
    "single = np.array(all_costs[:,single_action])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 149,
   "id": "920a970b-92b7-4157-8763-d60a6b8a0a7d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8153364632237872\n"
     ]
    }
   ],
   "source": [
    "print(sum(np.array(ours) <= np.array(all_costs[:,single_action]) * P) / len(ours))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "c338df27-6d23-472f-a3d0-1a94b461eaf8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8794992175273866\n"
     ]
    }
   ],
   "source": [
    "print(sum(np.array(ours) <= np.array(random) * P) / len(ours))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "d47b7bb1-67bf-4d46-942b-ccb4b050f770",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.6557120500782473\n"
     ]
    }
   ],
   "source": [
    "print(sum(np.array(ours) <= np.array(two_stage) * P) / len(ours))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "f9b8f118-8d76-466f-abe3-e96f7d2a3879",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8951486697965572\n"
     ]
    }
   ],
   "source": [
    "print(sum(np.array(ours) <= np.array(vanilla) * P) / len(ours))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "id": "8a357538-bbeb-42bc-8ef6-13d0e06aae5d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7089201877934272\n"
     ]
    }
   ],
   "source": [
    "print(sum(np.array(ours) <= np.array(reward_losses) * P) / len(ours))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 154,
   "id": "d5ffb4ad-f94f-4fae-824a-8ffc9dcd077e",
   "metadata": {},
   "outputs": [],
   "source": [
    "np.save(\"ours.npy\", ours)\n",
    "np.save(\"two_stage.npy\", two_stage)\n",
    "np.save(\"reward_losses.npy\", reward_losses)\n",
    "np.save(\"vanilla.npy\", vanilla)\n",
    "np.save(\"random.npy\", random)\n",
    "np.save(\"single.npy\", single)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "id": "b8bf81bf-57b6-41f7-bd7a-5acdc601f7a5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "HI\n"
     ]
    }
   ],
   "source": [
    "print(\"HI\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 145,
   "id": "de35ef4b-345f-4f6f-8a37-ccbc4f46bce3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAACcEAAAKKCAYAAAD/DwGfAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACpQElEQVR4nOzde5xXdZ0/8NcMA8NtLqLAMArKminrmpqWl2zFwBRd1LISl1VXXdEKN9PylpialzRvoW7aVd1VS7eNn7mbRaChpiYaXYw23fCSOgzKZWZAcGC+vz9cvsvIDHKZYZjh+Xw8vg+Z7znnc97nOzjz4pz3+ZySQqFQCAAAAAAAAAAAAHRDpV1dAAAAAAAAAAAAAGwsTXAAAAAAAAAAAAB0W5rgAAAAAAAAAAAA6LY0wQEAAAAAAAAAANBtaYIDAAAAAAAAAACg29IEBwAAAAAAAAAAQLelCQ4AAAAAAAAAAIBuSxMcAAAAAAAAAAAA3VZZVxewMVpaWvLqq6+moqIiJSUlXV0OANDNFAqFNDY2pra2NqWl7gnYUsl8AMCmkPm6B5kPANhY8l73IO8BAJtiQzJft2yCe/XVVzN8+PCuLgMA6OZefvnl7LDDDl1dBu2Q+QCAjiDzbdlkPgBgU8l7WzZ5DwDoCOuT+bplE1xFRUWStw+wsrKyi6sBALqbhoaGDB8+vJgp2DLJfADAppD5ugeZDwDYWPJe9yDvAQCbYkMyX7dsgls9VW5lZaWwBABsNNPvb9lkPgCgI8h8WzaZDwDYVPLelk3eAwA6wvpkvnU/LLUNs2bNyvjx41NbW5uSkpJMmzat3XXPOOOMlJSU5MYbb2z1/sKFCzNx4sRUVlamuro6p556apqamja0FAAAAAAAAAAAALZyG9wEt3Tp0uy555655ZZb1rnej370ozzxxBOpra1da9nEiRPz7LPPZvr06XnggQcya9asTJo0aUNLAQAAAAAAAAAAYCu3wY9DHTduXMaNG7fOdV555ZWceeaZ+elPf5ojjzyy1bK5c+fmwQcfzFNPPZV99903SXLTTTfliCOOyLXXXttm0xwAAAAAAAAAAAC0ZYNngns3LS0tOeGEE/LFL34xu++++1rLH3/88VRXVxcb4JJk7NixKS0tzZNPPtnmmCtWrEhDQ0OrFwAAAAAAAAAAAHR4E9zVV1+dsrKy/PM//3Oby+vq6jJkyJBW75WVlWXQoEGpq6trc5urrroqVVVVxdfw4cM7umwAAAAAAAAAAAC6oQ5tgnv66afz9a9/PbfffntKSko6bNwLLrggS5YsKb5efvnlDhsbAAAAAAAAAACA7qtDm+AeeeSR1NfXZ8SIESkrK0tZWVlefPHFnHPOOdlpp52SJDU1Namvr2+13cqVK7Nw4cLU1NS0OW55eXkqKytbvQAAAAAAAAAAAKCsIwc74YQTMnbs2FbvHXbYYTnhhBNy8sknJ0kOOOCALF68OE8//XT22WefJMnMmTPT0tKS/fbbryPLAQAAAAAAAAAAoIfb4Ca4pqamPP/888Wv582blzlz5mTQoEEZMWJEtt1221br9+7dOzU1Ndl1112TJKNGjcrhhx+e0047Lbfeemuam5szefLkTJgwIbW1tZt4OEBnKhQKaW5uTktLS1eXAmzlSktL07t37w59/DoAPYvsCt2fzAcAbZN16UlkPgA6iowEW67Nlfk2uAlu9uzZOeSQQ4pfn3322UmSk046Kbfffvt6jXHXXXdl8uTJGTNmTEpLS3Psscdm6tSpG1oKsJmsWrUqr7/+ehobG9Pc3NzV5QAkebvRvqKiItttt1169erV1eUAsIWQXaFnkfkA4P/IuvRUMl/nmTVrVr72ta/l6aefzmuvvZYf/ehHOeaYY9pc94wzzshtt92WG264IWeddVbx/YULF+bMM8/Mj3/84+J13a9//esZOHDg5jkIgHchI0H3sDky3wY3wY0ePTqFQmG913/hhRfWem/QoEG5++67N3TXQBdYtWpVXn755axYsSJVVVUZOHBgevXq5a4soMsUCoWsWrUqTU1NWbx4cd58880MHz7cCTIAZFfoQWQ+AGhN1qUnkvk639KlS7PnnnvmlFNOycc//vF21/vRj36UJ554os2ndk2cODGvvfZapk+fnubm5px88smZNGmSa73AFkFGgi3f5sx8G9wEB2xdXn/99axYsSIjRoxIv379urocgKKBAwemqqoqL730Ul5//fUMHTq0q0sCoIvJrtDzyHwA8DZZl55M5us848aNy7hx49a5ziuvvJIzzzwzP/3pT3PkkUe2WjZ37tw8+OCDeeqpp7LvvvsmSW666aYcccQRufbaa9tsmgPYnGQk6D42R+Yr7fARgR6jUCiksbExVVVVQgOwRerXr18qKyvT2Ni4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T39qc51Vq1bloYceStL2s8hffvnl/M///E+b2zY2Nubpp59uta/VVk/BuqV2nb/88svFP++9995trvPzn/98c5UDALDVk13bJ7sCAHRvsm77ZF0A2HrJSO2TkbofM8EBdLJDDz002267bd54441ccsklufvuu9da57bbbsurr76aJDn++OPbHOcrX/lKbr/99rXev+666/Lmm2+mrKwsxx57bKtllZWVSZLFixdv2kF0kqqqquKff/Ob3+SDH/xgq+WNjY25/PLLN3dZAABbLdm1fbIrAKxt/E2PZkHjik7fz+CK8vz4zIM6fT/0bLJu+2RdANh6yUjtk5G6HzPBAXSyfv365ZJLLkny9jSpZ5xxRubPn58kWbZsWaZOnZqzzjorSXLcccdln332WWuMqqqq3HHHHfnc5z6X119/Pcnbv1SvvPLKXHbZZUmSz372s6mtrW213d/8zd8kSR555JH88Y9/7IzD2ySjRo3KiBEjkiSnnHJK8S6AJHn88cczevToLFq0qKvKAwDY6siu7ZNdAWBtCxpXpK5heae/NkejHT2frNs+WRcAtl4yUvtkpO5HExzAZjB58uR8/vOfT/J2p/ywYcMyaNCgVFVV5XOf+1yam5tzyCGH5Fvf+lab2++1114599xzM3Xq1AwZMiSDBg3KNttsky996UspFAoZO3ZsvvrVr6613bHHHpvBgwdn0aJFGTVqVAYPHpyddtopO+20U5544olOPeb1UVpamltuuSVlZWV59tlns++++2bAgAEZMGBADjzwwPz3f/93fvCDH3R1mQAAWxXZtW2yKwC0r7Qkqans2+Gv0pKuPjJ6Glm3bbIuAGzdZKS2yUjdj8ehAh2nqS65blRXV7Hxmuo6dfjrr78+48ePzy233JLHHnssb7zxRioqKrLXXnvlhBNOyIknnphevXq1u/3VV1+d97///bnlllvyu9/9Ln369Mmuu+6ak08+OZ/97Gfb3HabbbbJrFmzcumll+aRRx5JfX19sft++fLlnXasG+Lv/u7vMmvWrFxxxRV57LHHsmzZstTU1GTMmDE577zzsuuuu3Z1iQBATyS7rpPs2jbZFQDaNqSib564cEyHj7v/lTNS17Bl5IBuRdZdJ1m3bbIuAD2ejLROMlLbZKTuRRMc0HEKLUnjq11dxRbtkEMOySGHHLLR2x933HE57rjjNmib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S01NTfr27Zu/+qu/yplnnpn6+vo8/PDDKSkpSUlJSbvbNzY25qtf/WoOOOCADBo0KOXl5Rk+fHgmTJiQxx9/vM1tXnjhheK4L7zwQubPn5/Pfe5zGTlyZPr27ZuhQ4dmwoQJ+eMf/7jO2pcsWZLLLrss73//+1NZWZl+/fpll112yac//en8+c9/Xq99t2ennXZKSUlJm7OiLVq0KBdffHFxv3369ElNTU3e97735YwzzsiMGTPWWXdH23XXXddqgFtTdXV1Pv7xjydJnnrqqc1VFp2kqakpc+bMyZw5c5Ik8+bNy5w5c/LSSy+lubk5n/jEJzJ79uzcddddWbVqVerq6lJXV5e33norSTJq1KgcfvjhOe200/KrX/0qjz32WCZPnpwJEyas8+8RAFuOH/zgBxk3blyGDh2a3r17p7q6OrvsskuOOuqo3HLLLVm+vPVdp5dccklKSkoyevTotcb6x3/8x5SUlBQfz/nv//7vGT16dAYNGpT+/ftnr732yte//vW0tLS0W0+hUMj3vve9HHDAAamoqEhVVVX222+/fPOb30yhUFhrHxvq97//fSZNmpRddtkl/fv3z8CBA/O+970vX/rSl/L6669v1JjNzc25//77M2nSpOy7774ZNmxY+vTpkyFDhuSwww7LPffck0Jh3c+waGlpyb333ptjjjkm22+/fcrLyzN48ODss88+Oe+88/L73/8+yf/lz9WPmPzFL35RzKOrX2tmzvX5vB5++OF88pOfLO53u+22y5gxY/K9730vq1atanObd/49mDFjRo488sgMHjw4ffv2zahRo3LppZeu9feHriHzAbA1Gj16dEpKSnLJJZekubk51113Xfbdd99UV1enpKQkDz/8cFpaWjJjxoz88z//c/bff//ssMMO6dOnT7bddtscfPDBufXWW9Pc3Nzm+B11TvKVV17J6aefnuHDh6e8vDw77LBDTj755Dz//PPrdZx1dXX54he/mN133z0DBgzIgAEDsvvuu+fcc8/N/Pnz16v2F198MaeddlpGjBiRvn37Zuedd85FF12UpUuXFrf5/e9/n3/4h3/I8OHD07dv3+yyyy65/PLL2/18AIAt28svv5xzzz03e+21V6qqqtKvX7/svPPOOfroo3PnnXe2eU5n1apV+e53v5uPfOQj2W677VJeXp7tt98+n/zkJ9/1yVTrew5y9fXkO+64I0lyxx13rHXua0OfgvVuNuZ84aacD3znNfNf//rXmThxYnbYYYf07t27eL6to3oHOuL6+//8z/9k0qRJGTlyZMrLy4s1dalCN7RkyZJCksKSJUu6uhRo034X/Fthx/MeKOx3wb91zg6u3a1Q+HLl2//tBPtd8fPCjuc9UDjqxpmFP/zhD4U333xzvdbf74qfd0o9m0tnH8e//du/FcrLywtJCkkK5eXlhX79+hW/rqioKPz0pz9da7vvfe97hSSFHXfcsXDXXXcVevfuXUhSqKqqKpSWlha333333QuNjY1t7vs73/lOq3WrqqoKffr0KSQp7LbbboXrr7++uI+2XH/99YWSkpJW26+uI0nhfe97X+HVV19tc9v/+I//aLXuwIEDC3379i0kKQwbNqx4fO39Svr1r39d2GGHHYrr9OrVq1BRUVH8uqSkpHDllVeutd28efOK6zzwwAOFIUOGFJIU+vfv3+r7UFlZWZgzZ06b+/7973/fat99+/Ztte/y8vLCv//7v69z3/PmzWtz7EKhUNhxxx0LSQrf+973Wr3/8ssvF0aMGFEco7S0tLDNNtsUevXqVXzv4IMPbnfc9hx88MEbve36OPvsswtJCgMGDGhz+erjPemkkzp0v2+++eZ6/axakyyxbg899FDx79qar5NOOqnV3+93vh566KHiGG+88Ubh+OOPLwwcOLBQWVlZOPnkk9v9GdUe3ye2eJ2cyTpdd6//Hdb394Hs+u5OPvnkVj/fBw4cWOjfv3+r996Zcb785S+3mzNOOumk4u+Rz372s8V8U11d3WrME088sc16Vq5cWTjuuONa5b9tttmmmG+PP/74Vvt4p9UZ6Mtf/nKb41999dWtsnL//v2LWXl1Zn3mmWc28FNc+/dpZWVlqyyZpPDJT36ysGrVqja3X7BgQeFv//ZvW61fXV1dGDhwYPHro48+ulAoFAovvfRSYejQoYUBAwYUkhR69+5dGDp0aKvX97///eLY6/q8CoVC4fOf/3yrz7u6urpVFv3IRz5SaGhoWGu7Nf8eXHPNNYWSkpLi9mv+e+KQQw4prFy5coM+T5mv48l8sB56Ql7aTOcROytb9ZTstqlk3Y6zOhued955hQMPPLCQpFBWVlbYZpttCiUlJYWHHnpord+DAwcOLFRVVbV678Mf/nBh2bJla43fEeckn3766cI222xTXLdfv37FDFhZWVn4wQ9+sM5zjw8//HCrrD1gwIBiTkxS2GabbQqPPPLIOmv/4Q9/WByjsrKyVRb88Ic/XHjrrbcKDzzwQPHfCVVVVa3y3nHHHbdR358NzXxyRPfg+8TWTl7qPDJSx7rzzjuL13CTFPr06VPYdtttC2VlZcX3fv3rX7faZvHixYXRo0e3uo77zvNAX/jCF9rc34acg3zssccKQ4cOLdbXt2/ftc59PfbYY+t9rJ11vnBTzgeuue2///u/F6+vV1ZWFvr27Vs879oRvQMdcf39rrvuKmbU/v37FwYMGNBur8E7dWbmM50UwGYwffr0nHjiiVm1alXOPffczJs3L2+++WaWLl2aP/7xj/nkJz+ZxsbGfPKTn2x3RrgFCxbklFNOyUknnZSXXnopixcvTmNjY26++eb07t07zz77bK655pq1tnvmmWdy+umnp6WlJaNHj87cuXOzePHiNDU15Z577kldXV0uu+yydmt/4IEHcvbZZ6dQKOToo4/On//85+L2d955ZyoqKvLb3/42n/jEJ9aaEeLPf/5z/uEf/iHNzc15//vfn9mzZ6exsTHLli3L9OnT06dPn5x99tnt7vu1117LYYcdlr/85S/5+Mc/ntmzZ+fNN99MQ0ND5s+fnylTpqRXr1658MILM23atHbHOeGEE7LLLrvkqaeeytKlS9PU1JTp06dn2LBhaWhoyJlnnrnWNo2NjRk/fnz+8pe/ZPvtt89//ud/ZunSpWloaMicOXOy//77Z8WKFZk4cWJ+85vftLvvjXHJJZfkpZdeyk477ZSf//zneeutt7Jw4cKsWLEiL7zwQr7xjW9k//3379B9doTVd1jsscceXVsIm2z06NEpFAprvW6//fbstNNObS4rFAqtZv8ZNGhQ7r777jQ2NmbJkiX57ne/m4EDB3bdQQGwXh599NF873vfS2lpaa6++uq88cYbaWxszNKlS/P666/npz/9aU466aT06dNng8e+//77861vfSvXX399Fi1alEWLFuX111/PP/3TPyVJ7rzzzsycOXOt7b72ta/lBz/4QZLk7LPPzoIFC7Jw4cIsWrQoV155Zb7//e/n/vvv36jj/c53vpPzzjsv/fv3zxVXXJHXXnstS5cuzbJlyzJ79ux85CMfyWuvvZajjjpqvWdQXq1///45/fTTM3369CxZsiRLlixJQ0ND3njjjXz9619PZWVl7rvvvtx8881rbbty5cocc8wxmTVrVsrLy3P11Venvr4+ixYtSmNjY1555ZXcdttt+eu//uskyfDhw1NXV5cvfOELSZIDDzywOGvX6tdxxx23XnXffPPNueGGG5IkkyZNyquvvppFixZlyZIlueGGG1JWVpaZM2fmtNNOa3eM3/zmNzn//PNz/vnnF+tevHhxLr744iTJQw89VLxzl64j8wGwNbvlllvy29/+Nt/73vfS0NCQhQsXZsGCBXnf+96XsrKyTJw4Mffff38xD68+F/u9730vtbW1eeSRR/KlL31pnfvY2HOSH/vYx7Jo0aKMGDEiP/vZz7J06dI0Njbml7/8ZYYPH57TTz+93X2+/PLLOeaYY7J48eL89V//dR599NE0NTWlqakps2bNyq677ppFixbl6KOPziuvvNLuOKeeemr22WefPPvss1myZEkaGxszderU9OrVK4888kguu+yyTJw4MePHj88LL7yQxYsXp6GhofiZ/OAHP8jPf/7z9fxuAABd7T//8z9z0kknZfny5fnQhz6URx55JG+++WZef/31LF26NI888khOO+20tc4JnnrqqXn44YfTp0+fTJ06NQ0NDVm0aFFeffXVnHLKKUmSa6+9Nrfeemur7Tb0HOTqc12rz28dd9xxa537OvDAAzvks9iU84Wbcj5wTf/4j/+YQw89NHPnzs2SJUvy5ptv5lvf+lardTa2d6Cjrr+ffvrp2X333Vtl3Z/97Gfr/0F3lvVqq9vCuGOALZ2Z4LqnzjqOVatWFXbZZZdCksJtt93W7npHHXVUIUnhc5/7XKv315wprb2ZGlbPwPWe97xnrWXjxo0rJCm8973vbfPuxAcffLA4flvd2aNGjSre4dfWbA33339/cfv77ruv1bJTTz21kKQwZMiQwhtvvLHWtn/84x9b3QH5TqecckohSeHv//7v2zzuQqFQnMVuzz33bPX+mp3ou+22W5vHvmbtL7/8cqtlX/3qV4uzaPzud79ba9uGhobCTjvtVEhSOPLII9vd98bMBLf6M7/77rvb3XZjrL6roa2ZQdY1U8j6+P73v1885u985zttrrP6eNu6O2NT7tYwK0jP5fvEFq+7zwzS3et/B3d+doyrr766kKTw0Y9+dIO2W5+Z4NrKPavts88+hSSFf/qnf2r1flNTU6GysrKQpHDqqaeuc9/t5eX27uxsaGgozm7x4IMPtjl2c3NzsbYbbrihzXU21n333VdIUth5553XWvbtb3+7eNflf/7nf673mOv6PqypvZngli1bVhg0aFAheXuGvbZMnTq1+HnPnj27zf239Xmv9vGPf7yQpDB27Nj1PaxCoSDz9WS+T2zRekJeMhNcjyDrdpzV2TBJ4f7779+oMZ566qniDGvv/J5s6jnJ1Xm8T58+hT/84Q9rbfvaa6+1miXunecezzjjjOJsb6+99tpa27/88svFfP3Zz3623dp33333wvLly9fa/oQTTiiuc+ihhxZaWlrWWufDH/7wOvP7upgJrmfyfWJrJy91HhmpYzQ3NxdGjhxZSFI46KCDCitWrFiv7Z544oliLmjvGvixxx5bSFLYbrvtWn2fNvYc5Ls93WB9ddX5wnWdD1xzJrgPfvCD7T5FYVN7Bzrq+vuOO+64wU8DWM1McADd2KxZs/Lcc89lu+22K85y0ZYTTzwxSfLTn/603XUuuuiiNt8/+uijkyTPP/98li1bVnx/8eLFxfG++MUvpl+/fmtte9hhh+WAAw5oc9zf/va3mTt3bnHfvXr1Wmud8ePH54Mf/GCS5J577im+XygU8sMf/jBJ8ulPfzqDBg1aa9tdd901n/rUp9rc9/Lly3P33XcnSc4777w210n+73P7zW9+k/nz57e5zjnnnNPmsY8bN654B8Hvfve7VstWzzbyiU98In/zN3+z1rYVFRU599xzkyQ/+clPsmTJknZr3FDV1dVJ3u7E7wzNzc2ZP3/+Ol9vvvnmeo/3pz/9KWeccUaS5KCDDso//uM/rnP95cuXv+v+33rrrU05RABgI63OIQsWLFhrlt9NNXz48Jx00kltLjvqqKOSvJ0/1/Szn/0sDQ0NSdLuTBvnnHNO+vfvv8H1/PCHP8zixYuz995757DDDmtznbKyshx//PFJ1p3TN8aRRx6ZJPmf//mf1NXVtVr23e9+N0lyxBFH5IgjjujQ/a7L9OnTs3DhwiRvz07cls985jMZNmxYkhTz+juVl5cXZ6V7p9X/dnnn9xoAYHPafffdM378+I3adt99982QIUOydOnSzJkzp931Nuac5Pe///0kySc/+cmMGjVqrW1ramqK5+HeqVAo5N57702SnHHGGampqVlrnR122KG4/ep9teXzn/98ysvL13p/zdx8/vnnp6SkpN115D0A6B4eeuihzJs3L0lyww03rPcTIFZfS91hhx3avQb+la98JUny+uuvZ/r06cX3O/Mc5Kbo7POF6zofuKYvfvGLbV6Xf6cN7R3oyOvvkydP3iKfBqAJDqCTPfbYY0mSJUuWpLa2NjU1NW2+Vj9O6MUXX2xznEGDBuU973lPm8tqa2uLf160aFHxz88880xaWlqSJB/5yEfarbG9ZbNnz07y9i/zgw8+uN3tDz300FbrJyk+NjXJOrdd81E6a3r66aezfPnyJMlHP/rRdj+33XffvbhNe5/dfvvt1+b7ZWVlGTx4cJIUL/YlyVtvvVU8STN27Nh2a1993C0tLXnmmWfaXW9D/d3f/V2St08kTZo0KQ8++GDx4m9HOPjgg9t9tNHq17s1sq1WV1eXI488MosXL05tbW3uueeelJauO16cdNJJ77r/9v5eAACda8yYMenbt29+/etf58Mf/nC+853vFE+CbaoPfOADbV4kS/4vz66ZyZIUM9aIESMycuTINretqKjIPvvss8H1rM7pc+fObTdr1tTU5LLLLkvSftZcl8bGxnzta1/LwQcfnCFDhqRPnz4pKSlJSUlJq8a9v/zlL8U/r1y5Mk899VSSbPSF2Y21Os8PHz48733ve9tcp1evXsV/P6yZ/9e0++67t3sSrL3vNQDA5vShD31oncvfeuut3HrrrfnoRz+a2tralJeXF3NcSUlJ6uvrk7TOce+0MeckVzfFbcy53Hnz5hXHW59zmm+88Ua7WX/1Tc/vNHTo0OKfP/CBD6xznTXPUwMAW65f/vKXSd5utt93333Xe7vV54UOOeSQdq8Njho1Kttvv32r9ZPOPQe5KTrifOHGnA98p3fLqsnG9Q505PX39amxK5R1dQEAPd2rr76a5P9m33o37c3AVVFR0e42ZWX/9+O8ubm5+OfVJ2OSFANGW3bYYYc231+9/XbbbdfmnX/v3H7N/S1YsKD45zV/0b5Te3Wt/tySrNfnlqRVJ/ua1uezW/NzW7hwYfGug/X93NY89k31xS9+Mb/5zW9y77335lvf+la+9a1vpaSkJLvvvnsOP/zw/NM//VN23XXXDtvfxqqvr8+YMWPy/PPPZ+jQoZkxY0a7f5cAgO5h5513zre//e2cccYZefzxx/P4448nSQYPHpxDDjkkf//3f5+jjjqq3Wa2ddnQTJb8X6ZcV55M1p3Z2rM6by5fvrx48mdd2sua7fnTn/6UMWPGtDqh1b9//1RXVxdPDK7OuUuXLi2u88YbbxQ/hx133HGD9rmpVmfad/s828r/a1qf7/XKlSs3pkQAgA4xZMiQdpfV19dn7NixrWZp69u3b7bbbrvijBwLFixIS0tLqxz3ThtzTnJ1RtqUc7kbsn19fX2bN5u0V/ua56HfbZ13ZnuALdZtBydNHXeNZy1NFyWpTpYueLc1oUusnpFsQ89Dbch5pFdeeaVVVunMc5CbYlPPF27s+cB3WldWXW1jegc68vr7+tTYFcwEB9DJVjdT7bfffu86+9XqV0+zMQFlzalv33zzzfX63HrK7GG9e/fOD37wg8yZMycXX3xxPvKRj6R///75/e9/n2uvvTa77757rrvuui6tsb6+Ph/5yEfyhz/8IUOGDMnMmTOz2267dWlNAEDHmDhxYl588cXceuutOe644zJ8+PAsWLAg9957b4455pgcfPDBHTpL7frojBNeq/Pmcccdt15Z84UXXtig8U8++eT85S9/yU477ZT77rsvb7zxRpYuXZr6+vrU1dXllVdeKa675r8BNvfJPQCArdG6Hi/1+c9/Pr/73e+y7bbb5rvf/W5ee+21vPnmm1mwYEHq6upSV1dXvEmjJ57LBdjqNNUnja923qvlf693FbacRz7CmrrqXNSWeA5yU88Xbuz5wHdan0ehbsrxJZt+/b2zatxUmuAAOllNTU2SjXt80qZaswN7zV+q79TestXbv/7661mxYkW726/uZl9zf6un9E9ad5Wv775Xf27J5v/sBg0aVPzFva6paNdctuaxr9ldv667BJYsWbLOOvbcc89ceumlmTFjRhYvXpyf//zn+du//dusWrWqOFtcV6ivr88hhxySZ599ttgA99d//dddUgsA0DkGDRqU008/Pd///vfz0ksv5fnnn8/555+fkpKSPPLII7nkkks2Sx2rM+W68mSy7qzbns7M6S+//HLxURL33HNPPvGJT2TQoEGt1ll9l+07DRo0KL179+602tZldaZdVwZec/mWescnAMDGam5uzn/8x38kSW6++eacfPLJrc5TJm9fPHz99dc7fN9rnpPclHO5ycad0wTY6pWUJhW1Hf+Km93Ysm3sObKOOI+0pZyDXG1TzhduyvnAzaUrr79vLprgADrZ6udh19XVtXrW+ebw/ve/vzi16kMPPdTuejNnzmzz/dXPfV+5cmV+8YtftLv9z3/+8yTJBz7wgeJ7f/VXf5Xq6uokycMPP9zutu0t+8AHPpA+ffokSX784x+3u31n6NOnT973vvclSWbMmNHuequPu7S0NO9///uL72+zzTbFP7/88sttbvunP/0pixcvXu+aysrKMmbMmPznf/5nysvLUygUivvfnObPn59DDjmk1Qxwaz4XHgDomXbeeedcddVV+fu///skyfTp0zfLfldnrBdffLHdmdiampry9NNPb/DYq3P6008/nddee22ja2zLmhlw7733bnOd9rJcWVlZPvjBDybZ8By8Ovtv7Iwkq/P/X/7yl/zpT39qc51Vq1YV/22xZv4HAOgJFixYULyptb0c9+ijj67X47E21JrnJDfmXO7IkSOLF1rX55zmtttu2+ajUAG2WgNrknPmdvyrVEsGW7YDDzwwyYZfy159Humhhx5KS0tLm+v88Y9/LDbwr895pHc7B7mp577ezaacL9yU84GbS1def99c/MQF6GSHHHJI3vOe9yR5eyr9t956a53rL1y4sMP2XV1dnY9+9KNJkmuvvbbNkzM///nPi13p7/S+972vOMPX5Zdf3mqK1NX+67/+K08++WSS5Pjjjy++X1JSko9//ONJkltvvTWLFi1aa9vnnnsu9957b5v7HjBgQDHgXH311XnppZfaPc6kYz+3JJkwYUKS5N///d/z+9//fq3lTU1Nueaaa5IkRxxxRKqqqorLBgwYkJ133jlJ8sMf/rDN8a+44op2972uWffKy8uLd4SWbuZ/OK35CNShQ4fmoYce0gAHAD3MunJIkvTr1y/J5sshH/3oR1NZWZkkufLKK9tc54YbbsiyZcs2eOxPfvKTqa6uTnNzc84+++x1njxraWnZoBsY1syGbc3e29jYmMsvv7zd7U899dQkb2ft//qv/1rv/a7+rDak1jUdeuih2XbbbZOk3Tttb7vttuLMfGvmfwCAnqCysrL4SLC2ctzKlSvzpS99qdP2f9xxxyVJ7rvvvvz3f//3Wsvr6+tz6623trltSUlJcfvbbrutzZlGXn311dx2221JZDkA4G2HHHJI/uqv/irJ+l3LXm31tdRXXnkl3/72t9tc5+KLL06SbLfddhk7dmzx/Y09B7mp577ezaacL9zU84GbQ1dff98cNMEBdLKysrLceuutKSsry6OPPpq//du/zYwZM9Lc3Fxc589//nNuvfXWfOADH8i//Mu/dOj+v/KVr6RXr1754x//mCOPPLJ48mTlypW5995786lPfao4Y1tbrr766iTJI488kk984hOZN29ekrcfDXDXXXcVT5YceOCBOeaYY1pte8EFF6Rfv36ZP39+PvrRj+bXv/51kre782fOnJnDDjss/fv3b3ffV155ZWpra/P666/ngAMOyL/+67+msbGxuHzBggX54Q9/mI997GMdftLm05/+dEaOHJnm5uaMGzcuP/nJT4p3Mfzud7/LYYcdlnnz5qW8vLzNwLK6nu9+97v5l3/5l7z55ptJ3r4L4J/+6Z/ygx/8oN1j33HHHXPBBRfkiSeeaBUCn3/++UycODHLli1LaWlpDjvssA495nVZsGBBsQGupqYmDz30kEegAkAPNHny5HzqU5/KD3/4w9TX1xffb2pqyq233po777wzSXLkkUdulnoGDBiQ8847L0nyrW99K+eee27x5EtjY2OuvvrqXHLJJa1m4l1f1dXVufHGG5Mk3//+93PkkUfmySefLGa+lpaWzJ07N9ddd1123333PPDAA+s99qhRozJixIgkySmnnNJqprrHH388o0ePbvMmkdVOOOGEHHTQQSkUCjn22GPzta99rdUjt1599dXccMMNxc9mtb/5m79Jkjz77LPt3uiyLv369Ss2v91zzz0544wzMn/+/CTJsmXLMnXq1Jx11llJ3r5Au88++2zwPgAAtmQDBw4szgBy9tlnZ+bMmcV8+Pvf/z5HHHFEZs+enQEDBnTK/j/96U9nhx12yIoVK3L44YdnxowZxYuvTz75ZMaOHdvuTCtJcuGFF6a6ujoLFy7M2LFjW2XCxx57LGPHjs3ixYszaNCgnH/++Z1yDABA99KrV6/cfPPNKSkpyaOPPpoxY8bk0UcfLWaOt956Kw8//HD+4R/+IX/4wx+K233wgx/MsccemyQ588wzc/PNNxdvVK2rq8tpp52W++67L8nb16v79u1b3HZjz0GuPvf1yCOP5I9//GNHfxSbdL5wU88Hbi5def19cyjr6gIAtgZjxozJfffdlxNPPLF4sqJ3796prKxMU1NTq0andzaSbap99903//Iv/5IzzjgjM2fOzG677ZaqqqosX748K1asyG677ZZJkybl7LPPbnP7v/u7v8v111+fc845J9OmTcu0adNSXV2dZcuWFe8E2GOPPXLfffcVZyhb7T3veU/uvPPOHH/88Zk9e3be//73p6KiIqtWrcqyZcuy/fbb5/rrr8/JJ5+c8vLytfY9bNiw/PznP88xxxyTP/3pTznxxBNTWlqa6urqrFixIkuXLi2uu+bdAx2hoqIi999/fw4//PD85S9/yRFHHJG+ffumT58+aWhoSPL2rGz/9m//lj333HOt7c8777z8x3/8R/7whz/ks5/9bM4888xUVlZm8eLF6d27d+68886cf/75bT5vff78+fnqV7+ar371qyktLU1VVVXefPPN4kx+JSUlue666za6Ce2Xv/xlq2e+t2fNu0W/8Y1v5Nlnn03y9gXnQw45ZJ3bPvXUUxk+fHiby37wgx/kwQcfXOf2w4cPz1NPPfWuNQIAHau5uTn33Xdf8QTVwIEDU1ZW1uquxoMOOqhTZ794p3PPPTe//vWv8+///u/52te+luuuuy5VVVVpaGjIqlWrcsIJJ6SkpCR33nlnq5Np6+Okk07Km2++mc997nP5yU9+kp/85CcpLy/PwIED09DQ0OrGldUzgqyP0tLS3HLLLfnYxz6WZ599Nvvuu2/xBohly5ZlwIAB+X//7/+1m2HLysryox/9KB//+MfzyCOP5Nxzz815552XqqqqrFy5Mk1NTUmSo48+utV2o0ePzq677pr//u//zoc+9KFss802xTtkr7322nziE59419onT56cP//5z7nhhhty22235Zvf/Gaqq6vT2NiYlStXJnn7DuFvfetb6/15AAB0JzfeeGMOPvjgvPLKKxkzZkzKy8vTp0+fNDY2pqysLN/97nczZcqUVucmO0plZWV+9KMf5dBDD80LL7yQsWPHpn///iktLU1TU1MqKiry7W9/uzjj2zvtsMMOmTZtWo4++ug8++yz+dCHPlRs2Ftdb3V1daZNm5btt9++w+sHALqncePG5fbbb8+kSZPy6KOP5sMf/nDxHNmSJUuK54S+8IUvtNruO9/5Tl5//fX84he/yJlnnpnPf/7zqaioyOLFi4uN/F/4whdyxhlntNpuY89BHnvssbnwwguzYMGCjBo1Ktttt10x63z/+9/P/vvvv8mfxcaeL9zU84GbS1def98cNMEBHaa+cXn2v3JGV5ex0eob135UaEc65phj8vzzz+df/uVf8pOf/CTPPfdcFi9enAEDBmS33XbLBz7wgRx55JE54ogjOnzfkyZNyh577JGrrroqjz32WJYtW5Ydd9wxxx57bC644IJ2H9m52uc///kcfPDBueGGG/KLX/wi8+fPT79+/fL+978/xx13XD796U+32cSWJJ/4xCeyyy675IorrsjDDz+cJUuWZPvtt89RRx2VL33pS3n00UeTpN3Z6EaNGpXf/va3ueOOO/LDH/4wc+bMycKFC9OnT5+85z3vyd57751DDz10vS7obai/+Zu/ybPPPpsbb7wx06ZNy/PPP58VK1Zk5513zqGHHpovfOELxceevtPAgQPz6KOP5vLLL8+PfvSjvPLKK+ndu3fxM99nn33avdvyZz/7WR566KE8+uijeemll4qzb7znPe/Jhz/84Xz2s5/dpFk3mpubi2OurzXvMF26dOm7nuRr69G5qy1fvrzNR/OuaUMvYAPAhpJd2zZlypTss88+eeihhzJ37tzU1dWlqakpQ4YMyZ577pnjjz8+J5544lo3P3SmsrKy3Hvvvfnud7+bb37zm3n22WezcuXK7LvvvjnttNNy6qmnFpvB1jXDcXvOOOOMHH744bnlllsyffr0zJs3L4sXL05lZWV23nnnHHDAATnqqKPykY98ZIPG/bu/+7vMmjUrV1xxRTGD19TUZMyYMTnvvPOy6667rnP77bbbLg8//HDuueee3HXXXXn66aezaNGibLPNNtl1111z6KGH5oQTTmi1TVlZWWbMmJFLLrkkM2bMyCuvvFK8w3R149z6uP766zN+/Pjccssteeyxx/LGG2+koqIie+21V0444YTN/ncAANgwsu6m2WefffKrX/0ql156aWbOnJklS5akoqIi48aNyxe+8IV84AMfyJQpUzpt//vuu29++9vf5rLLLstPfvKTLFiwIIMHD86xxx6biy66KGVl6760d/DBBxdnKPmv//qvvPDCCykpKcmoUaNy5JFH5pxzzlmvG2QBoKeRkdbtxBNPzN/+7d/m61//en72s5/lxRdfzJtvvpkdd9wxe+yxR4499tiMGjWq1TZVVVWZMWNG7rjjjvzrv/5rfvOb36SpqSk1NTU58MADM3ny5IwePXqtfW3sOchtttkms2bNyqWXXppHHnkk9fX1xacnvNu1xw2xsecL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AO/wy1/+MkcffXSOPPLIJMlOO+2Ue+65J7/61a+SvD0L3I033piLLrooRx99dJLkzjvvzNChQzNt2rTipChA1/nxNl9PGl9NKmqTc+Z2yj72v3JG6hqWd8rYAB2pwx+HOn78+FxxxRX5z//8z7zwwgv50Y9+lOuvvz4f+9jHkiQlJSU566yzcvnll+f+++/P7373u5x44ompra3NMccc09HlAAAAAAAAAPAOBx54YGbMmJE//elPSZLf/OY3efTRRzNu3Lgkybx581JXV5exY8cWt6mqqsp+++2Xxx9/vM0xV6xYkYaGhlYvAIDNocNngrvpppsyZcqUfOYzn0l9fX1qa2tz+umn5+KLLy6uc+6552bp0qWZNGlSFi9enIMOOigPPvigKXMBAAAAAIBW6huXZ/8rZ3Ta+IMryvPjMw/qtPEBtlTnn39+Ghoasttuu6VXr15ZtWpVrrjiikycODFJUldXlyQZOnRoq+2GDh1aXPZOV111VS699NLOLRwAoA0d3gRXUVGRG2+8MTfeeGO765SUlOSyyy7LZZdd1tG7BwAAAAAAepCWQjyCC6AT3Hvvvbnrrrty9913Z/fdd8+cOXNy1llnpba2NieddNJGjXnBBRfk7LPPLn7d0NCQ4cOHd1TJAADt6vAmOAAAAAAAgE01uKK8U8evb1yelkKn7gJgi/bFL34x559/fiZMmJAk2WOPPfLiiy/mqquuykknnZSampokyfz58zNs2LDidvPnz89ee+3V5pjl5eUpL+/cn98AAG3RBAcAAAAAAGxxOvsRpftfOcMMc8BWbdmyZSktLW31Xq9evdLS0pIkGTlyZGpqajJjxoxi01tDQ0OefPLJfPrTn97c5QIArJMmOAAAAAAAAICtzPjx43PFFVdkxIgR2X333fPrX/86119/fU455ZQkSUlJSc4666xcfvnl2WWXXTJy5MhMmTIltbW1OeaYY7q2eACAd9AEBwAAAAAAALCVuemmmzJlypR85jOfSX19fWpra3P66afn4osvLq5z7rnnZunSpZk0aVIWL16cgw46KA8++GD69u3bhZUDAKxNExwAAAAAAADAVqaioiI33nhjbrzxxnbXKSkpyWWXXZbLLrts8xUGALARNMGxZbrt4KSpvvPGb7mw88YGAAAAAAAAAAA2G01wbJma6pPGVztxB4VOHBsAAAAAAAAA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",
      "text/plain": [
       "<Figure size 3149.61x787.402 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "bins = 20\n",
    "\n",
    "cm = 1/2.54  # centimeters in inches\n",
    "# fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(2,2, figsize=(40*cm, 40*cm))\n",
    "fig, (ax1, ax2, ax3, ax4) = plt.subplots(1,4, figsize=(80*cm, 20*cm))\n",
    "ax1.hist([ours, optimal], label=['endogenous E2E', 'optimal'], bins=bins, histtype='step', range=[0, 0.6], linewidth=2.0)\n",
    "ax1.legend(fontsize=\"18\")\n",
    "ax2.hist([all_costs[:,single_action], optimal], label=['single action', 'optimal'], bins=bins, histtype='step', range=[0,0.6], linewidth=2.0)\n",
    "ax2.legend(fontsize=\"18\")\n",
    "ax3.hist([random, optimal], label=['random', 'optimal'], bins=bins, histtype='step', range=[0,0.6], linewidth=2.0)\n",
    "ax3.legend(fontsize=\"18\")\n",
    "ax4.hist([reward_losses, optimal], label=['cost learner', 'optimal'], bins=bins, histtype='step', range=[0,0.6], linewidth=2.0)\n",
    "ax4.legend(fontsize=\"18\")\n",
    "plt.savefig('cost_distribution_long.png')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "85b813cb-fb61-48c4-94b2-0a73dc80b357",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([  2.,  91., 126.,   4.,  35.,  56., 136.,   0.,   9.,   0., 110.,\n",
       "          0.,   0.,   1.,   1.,   0.,   6.,   0.,  56.,   3.,   1.,   1.,\n",
       "          0.,   1.]),\n",
       " array([ 1.   ,  1.875,  2.75 ,  3.625,  4.5  ,  5.375,  6.25 ,  7.125,\n",
       "         8.   ,  8.875,  9.75 , 10.625, 11.5  , 12.375, 13.25 , 14.125,\n",
       "        15.   , 15.875, 16.75 , 17.625, 18.5  , 19.375, 20.25 , 21.125,\n",
       "        22.   ]),\n",
       " <BarContainer object of 24 artists>)"
      ]
     },
     "execution_count": 83,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(reward_actions,bins=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "66efef73-beba-45b8-8579-45928e540aa4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 16.,  34., 182., 127.,  76.,  10.,   1.,   8.,  13.,   0.,   2.,\n",
       "          0.,   0.,   2.,  15.,  30.,  77.,   4.,   2.,   6.,   0.,  10.,\n",
       "         17.,   7.]),\n",
       " array([ 1.        ,  1.91666667,  2.83333333,  3.75      ,  4.66666667,\n",
       "         5.58333333,  6.5       ,  7.41666667,  8.33333333,  9.25      ,\n",
       "        10.16666667, 11.08333333, 12.        , 12.91666667, 13.83333333,\n",
       "        14.75      , 15.66666667, 16.58333333, 17.5       , 18.41666667,\n",
       "        19.33333333, 20.25      , 21.16666667, 22.08333333, 23.        ]),\n",
       " <BarContainer object of 24 artists>)"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(my_decisions,bins=24)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "5429819c-2371-481f-a0f6-16a1eac6df6b",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_costs = np.array(all_costs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 255,
   "id": "39defa82-e220-459f-84fd-cfc915d9cce5",
   "metadata": {},
   "outputs": [],
   "source": [
    "import plotly.graph_objects as go\n",
    "\n",
    "fig = go.Figure()\n",
    "fig.add_trace(go.Scatter(x=[i for i in range(24)], y=, mode='lines', name='data', marker=dict(color='green')))\n",
    "fig.update_layout(xaxis_title='alpha', yaxis_title='Loss', title='Loss at w = 0.25, g(w,z)=1', width = 600, height = 600)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3142fcf3-f5f1-4f6d-a922-10df595d00cb",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "174d797d-df98-4059-9f44-4069f3b30cc0",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:rares_env]",
   "language": "python",
   "name": "conda-env-rares_env-py"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
