{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5ac754fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "%run NNs.ipynb\n",
    "%run Helpers.ipynb\n",
    "torch.manual_seed(42)\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b8dc75f6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ca124b90",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "cuda\n"
     ]
    }
   ],
   "source": [
    "print(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "38b59e27",
   "metadata": {},
   "outputs": [],
   "source": [
    "n = 3 #number of bidders\n",
    "m = 10 #number of items\n",
    "\n",
    "nLayersAllocation   = 17 #minimum 2\n",
    "nLayersPayment      = 17 #minimum 2\n",
    "nLayersMisreport    = 17 #minimum 2\n",
    "widthAllocation     = 120\n",
    "widthPayment        = 120\n",
    "widthMisreport      = 120\n",
    "\n",
    "batch_size = 20000"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "021a570a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AllocationNet(\n",
      "  (mlp1): MLP(\n",
      "    (model): Sequential(\n",
      "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
      "      (tanh1): Tanh()\n",
      "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh2): Tanh()\n",
      "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh3): Tanh()\n",
      "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh4): Tanh()\n",
      "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh5): Tanh()\n",
      "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh6): Tanh()\n",
      "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh7): Tanh()\n",
      "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh8): Tanh()\n",
      "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh9): Tanh()\n",
      "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh10): Tanh()\n",
      "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh11): Tanh()\n",
      "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh12): Tanh()\n",
      "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh13): Tanh()\n",
      "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh14): Tanh()\n",
      "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh15): Tanh()\n",
      "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh16): Tanh()\n",
      "      (fc17): Linear(in_features=120, out_features=10, bias=True)\n",
      "    )\n",
      "  )\n",
      "  (mlp2): MLP(\n",
      "    (model): Sequential(\n",
      "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
      "      (tanh1): Tanh()\n",
      "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh2): Tanh()\n",
      "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh3): Tanh()\n",
      "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh4): Tanh()\n",
      "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh5): Tanh()\n",
      "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh6): Tanh()\n",
      "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh7): Tanh()\n",
      "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh8): Tanh()\n",
      "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh9): Tanh()\n",
      "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh10): Tanh()\n",
      "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh11): Tanh()\n",
      "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh12): Tanh()\n",
      "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh13): Tanh()\n",
      "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh14): Tanh()\n",
      "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh15): Tanh()\n",
      "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh16): Tanh()\n",
      "      (fc17): Linear(in_features=120, out_features=30, bias=True)\n",
      "    )\n",
      "  )\n",
      ")\n",
      "PaymentNet(\n",
      "  (mlp): MLP(\n",
      "    (model): Sequential(\n",
      "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
      "      (tanh1): Tanh()\n",
      "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh2): Tanh()\n",
      "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh3): Tanh()\n",
      "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh4): Tanh()\n",
      "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh5): Tanh()\n",
      "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh6): Tanh()\n",
      "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh7): Tanh()\n",
      "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh8): Tanh()\n",
      "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh9): Tanh()\n",
      "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh10): Tanh()\n",
      "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh11): Tanh()\n",
      "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh12): Tanh()\n",
      "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh13): Tanh()\n",
      "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh14): Tanh()\n",
      "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh15): Tanh()\n",
      "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh16): Tanh()\n",
      "      (fc17): Linear(in_features=120, out_features=3, bias=True)\n",
      "    )\n",
      "  )\n",
      ")\n",
      "MisreportNetBNIC(\n",
      "  (mlp): MLP(\n",
      "    (model): Sequential(\n",
      "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
      "      (tanh1): Tanh()\n",
      "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh2): Tanh()\n",
      "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh3): Tanh()\n",
      "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh4): Tanh()\n",
      "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh5): Tanh()\n",
      "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh6): Tanh()\n",
      "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh7): Tanh()\n",
      "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh8): Tanh()\n",
      "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh9): Tanh()\n",
      "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh10): Tanh()\n",
      "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh11): Tanh()\n",
      "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh12): Tanh()\n",
      "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh13): Tanh()\n",
      "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh14): Tanh()\n",
      "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh15): Tanh()\n",
      "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
      "      (tanh16): Tanh()\n",
      "      (fc17): Linear(in_features=120, out_features=30, bias=True)\n",
      "    )\n",
      "  )\n",
      ")\n"
     ]
    }
   ],
   "source": [
    "ANet = AllocationNet(n,m,nLayersAllocation,widthAllocation)\n",
    "ANet.to(device)\n",
    "ANet.train()\n",
    "\n",
    "\n",
    "PNet = PaymentNet(n,m,nLayersPayment,widthPayment)\n",
    "PNet.to(device)\n",
    "PNet.train()\n",
    "\n",
    "MNet = MisreportNetBNIC(n,m,nLayersMisreport,widthMisreport)\n",
    "MNet.to(device)\n",
    "MNet.train()\n",
    "\n",
    "print(ANet)\n",
    "print(PNet)\n",
    "print(MNet)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e10ea38c",
   "metadata": {},
   "source": [
    "# set up dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "da032379",
   "metadata": {},
   "outputs": [],
   "source": [
    "prob_single_1 = torch.tensor([0.2,0.2,0.8]).to(device)\n",
    "prob_single_2 = torch.tensor([0.5,0.5,0.7]).to(device)\n",
    "prob_single_3 = torch.tensor([0.7,0.7,0.9]).to(device)\n",
    "\n",
    "benchmark1_single = torch.tensor([1,1,1]).to(device)\n",
    "benchmark2_single = torch.tensor([0,1,1]).to(device)\n",
    "benchmark3_single = torch.tensor([1,0,1]).to(device)\n",
    "benchmark4_single = torch.tensor([1,1,0]).to(device)\n",
    "benchmark5_single = torch.tensor([1,0,0]).to(device)\n",
    "benchmark6_single = torch.tensor([0,1,0]).to(device)\n",
    "benchmark7_single = torch.tensor([0,0,1]).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4cb66a55",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_set_prob_2 = get_train_or_test_set(batch_size,n,m,prob_single_2)\n",
    "test_set_prob_2 = get_train_or_test_set(batch_size,n,m,prob_single_2)\n",
    "\n",
    "test_set_b_1 = get_train_or_test_set(batch_size,n,m,benchmark1_single)\n",
    "test_set_b_2 = get_train_or_test_set(batch_size,n,m,benchmark2_single)\n",
    "test_set_b_3 = get_train_or_test_set(batch_size,n,m,benchmark3_single)\n",
    "test_set_b_4 = get_train_or_test_set(batch_size,n,m,benchmark4_single)\n",
    "test_set_b_5 = get_train_or_test_set(batch_size,n,m,benchmark5_single)\n",
    "test_set_b_6 = get_train_or_test_set(batch_size,n,m,benchmark6_single)\n",
    "test_set_b_7 = get_train_or_test_set(batch_size,n,m,benchmark7_single)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b444698",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "531955b6",
   "metadata": {},
   "source": [
    "# train"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "6435cdcd",
   "metadata": {},
   "outputs": [],
   "source": [
    "#learning_rates = [0.0005] * 200  + [0.00005] * 200 + [0.000005] * 200\n",
    "learning_rates = [0.0005] * 200 + [0.00005] * 200 + [0.000005] * 200"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1a70c85f",
   "metadata": {
    "pycharm": {
     "is_executing": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 revenue:  0.7064918875694275 rgt:  0.20093528926372528 loss:  -0.19133733212947845\n",
      "1 revenue:  0.701363742351532 rgt:  0.22231723368167877 loss:  -0.14365212619304657\n",
      "2 revenue:  0.6851896047592163 rgt:  0.2243034541606903 loss:  -0.12985152006149292\n",
      "3 revenue:  0.668266236782074 rgt:  0.22116048634052277 loss:  -0.12603797018527985\n",
      "4 revenue:  0.6503227353096008 rgt:  0.21585875749588013 loss:  -0.12596115469932556\n",
      "5 revenue:  0.6307119727134705 rgt:  0.20901702344417572 loss:  -0.12797294557094574\n",
      "6 revenue:  0.6084752678871155 rgt:  0.20017728209495544 loss:  -0.13245922327041626\n",
      "7 revenue:  0.5825726389884949 rgt:  0.18802809715270996 loss:  -0.14161431789398193\n",
      "8 revenue:  0.5524995923042297 rgt:  0.17017129063606262 loss:  -0.16061365604400635\n",
      "9 revenue:  0.5207067131996155 rgt:  0.1429535448551178 loss:  -0.20055457949638367\n",
      "10 revenue:  0.4919627904891968 rgt:  0.0887802466750145 loss:  -0.3146601915359497\n",
      "11 revenue:  0.469210684299469 rgt:  0.04282212629914284 loss:  -0.43523237109184265\n",
      "12 revenue:  0.4486636519432068 rgt:  0.016302483156323433 loss:  -0.5258399248123169\n",
      "13 revenue:  0.5786734223365784 rgt:  0.016949757933616638 loss:  -0.6135648488998413\n",
      "14 revenue:  0.7398261427879333 rgt:  0.026093723252415657 loss:  -0.6725022196769714\n",
      "15 revenue:  0.8117166757583618 rgt:  0.01858016848564148 loss:  -0.7460639476776123\n",
      "16 revenue:  0.9924679398536682 rgt:  0.03685375675559044 loss:  -0.767399787902832\n",
      "17 revenue:  0.9456565976142883 rgt:  0.01868627592921257 loss:  -0.8170647025108337\n",
      "18 revenue:  1.1756614446640015 rgt:  0.04640211537480354 loss:  -0.8224655985832214\n",
      "19 revenue:  1.0466804504394531 rgt:  0.01667206734418869 loss:  -0.8772816061973572\n",
      "20 revenue:  1.296582579612732 rgt:  0.04069003090262413 loss:  -0.8962680697441101\n",
      "21 revenue:  1.1434316635131836 rgt:  0.010617580264806747 loss:  -0.9556544423103333\n",
      "22 revenue:  1.4428837299346924 rgt:  0.046176668256521225 loss:  -0.940136730670929\n",
      "23 revenue:  1.2790272235870361 rgt:  0.011998751200735569 loss:  -1.0094033479690552\n",
      "24 revenue:  1.6338298320770264 rgt:  0.06332112103700638 loss:  -0.9632555246353149\n",
      "25 revenue:  1.4861856698989868 rgt:  0.024353353306651115 loss:  -1.0386831760406494\n",
      "26 revenue:  1.9002248048782349 rgt:  0.09031472355127335 loss:  -0.987647533416748\n",
      "27 revenue:  1.6936640739440918 rgt:  0.036172542721033096 loss:  -1.0750452280044556\n",
      "28 revenue:  2.192903757095337 rgt:  0.11041416972875595 loss:  -1.0381451845169067\n",
      "29 revenue:  1.9025075435638428 rgt:  0.046099260449409485 loss:  -1.1185075044631958\n",
      "30 revenue:  2.4770889282226562 rgt:  0.11185024678707123 loss:  -1.1275866031646729\n",
      "31 revenue:  2.0320422649383545 rgt:  0.056258365511894226 loss:  -1.1320503950119019\n",
      "32 revenue:  2.640077590942383 rgt:  0.11809196323156357 loss:  -1.1630945205688477\n",
      "33 revenue:  2.1671111583709717 rgt:  0.0499589778482914 loss:  -1.1986371278762817\n",
      "34 revenue:  2.743161678314209 rgt:  0.12189055979251862 loss:  -1.1852304935455322\n",
      "35 revenue:  2.222010374069214 rgt:  0.04016464203596115 loss:  -1.2500650882720947\n",
      "36 revenue:  2.9549994468688965 rgt:  0.13845854997634888 loss:  -1.2084524631500244\n",
      "37 revenue:  2.3746349811553955 rgt:  0.043870966881513596 loss:  -1.2876602411270142\n",
      "38 revenue:  3.11006760597229 rgt:  0.14762483537197113 loss:  -1.2316937446594238\n",
      "39 revenue:  2.4855451583862305 rgt:  0.046698324382305145 loss:  -1.3137649297714233\n",
      "40 revenue:  3.1922264099121094 rgt:  0.13031725585460663 loss:  -1.2953681945800781\n",
      "41 revenue:  2.5940001010894775 rgt:  0.048428021371364594 loss:  -1.3420982360839844\n",
      "42 revenue:  3.388648748397827 rgt:  0.14717712998390198 loss:  -1.3100144863128662\n",
      "43 revenue:  2.712986707687378 rgt:  0.05566136911511421 loss:  -1.3555266857147217\n",
      "44 revenue:  3.4791336059570312 rgt:  0.15347620844841003 loss:  -1.3200068473815918\n",
      "45 revenue:  2.774564266204834 rgt:  0.055732812732458115 loss:  -1.3738914728164673\n",
      "46 revenue:  3.5278475284576416 rgt:  0.151983842253685 loss:  -1.3364216089248657\n",
      "47 revenue:  2.8370513916015625 rgt:  0.057864829897880554 loss:  -1.3859390020370483\n",
      "48 revenue:  3.572216749191284 rgt:  0.15062421560287476 loss:  -1.3513033390045166\n",
      "49 revenue:  2.87269926071167 rgt:  0.059417176991701126 loss:  -1.3917303085327148\n",
      "50 revenue:  3.5792577266693115 rgt:  0.142265185713768 loss:  -1.372446894645691\n",
      "51 revenue:  2.902949094772339 rgt:  0.05563125014305115 loss:  -1.412310242652893\n",
      "52 revenue:  3.717156171798706 rgt:  0.15443943440914154 loss:  -1.3805655241012573\n",
      "53 revenue:  2.995670795440674 rgt:  0.06391558796167374 loss:  -1.414069652557373\n",
      "54 revenue:  3.7458808422088623 rgt:  0.15493415296077728 loss:  -1.3868768215179443\n",
      "55 revenue:  3.013449192047119 rgt:  0.06423082947731018 loss:  -1.418260097503662\n",
      "56 revenue:  3.7648260593414307 rgt:  0.15339255332946777 loss:  -1.395269751548767\n",
      "57 revenue:  3.0318174362182617 rgt:  0.06471125781536102 loss:  -1.4221162796020508\n",
      "58 revenue:  3.7546920776367188 rgt:  0.1486760824918747 loss:  -1.403441309928894\n",
      "59 revenue:  3.0442492961883545 rgt:  0.06452178955078125 loss:  -1.4262444972991943\n",
      "60 revenue:  3.754997968673706 rgt:  0.14285609126091003 loss:  -1.4169625043869019\n",
      "61 revenue:  3.0568745136260986 rgt:  0.06147942692041397 loss:  -1.4389621019363403\n",
      "62 revenue:  3.8593811988830566 rgt:  0.1526254415512085 loss:  -1.4212323427200317\n",
      "63 revenue:  3.127159357070923 rgt:  0.06774426251649857 loss:  -1.4403561353683472\n",
      "64 revenue:  3.874945878982544 rgt:  0.15516753494739532 loss:  -1.4194074869155884\n",
      "65 revenue:  3.102837562561035 rgt:  0.06384093314409256 loss:  -1.4449787139892578\n",
      "66 revenue:  3.88425612449646 rgt:  0.15544059872627258 loss:  -1.4211515188217163\n",
      "67 revenue:  3.1227312088012695 rgt:  0.06415525823831558 loss:  -1.449681043624878\n",
      "68 revenue:  3.8915388584136963 rgt:  0.16775740683078766 loss:  -1.395358920097351\n",
      "69 revenue:  3.136258602142334 rgt:  0.06403196603059769 loss:  -1.4538711309432983\n",
      "70 revenue:  3.88368821144104 rgt:  0.14470140635967255 loss:  -1.4456098079681396\n",
      "71 revenue:  3.1825854778289795 rgt:  0.06735917180776596 loss:  -1.4570846557617188\n",
      "72 revenue:  3.924419403076172 rgt:  0.15011106431484222 loss:  -1.4434620141983032\n",
      "73 revenue:  3.1932849884033203 rgt:  0.06921959668397903 loss:  -1.4546606540679932\n",
      "74 revenue:  3.8959834575653076 rgt:  0.14480838179588318 loss:  -1.4484792947769165\n",
      "75 revenue:  3.189436912536621 rgt:  0.06847312301397324 loss:  -1.4557527303695679\n",
      "76 revenue:  3.9199790954589844 rgt:  0.14659357070922852 loss:  -1.4504246711730957\n",
      "77 revenue:  3.2069971561431885 rgt:  0.06993474811315536 loss:  -1.4564224481582642\n",
      "78 revenue:  3.922860860824585 rgt:  0.14660683274269104 loss:  -1.4511218070983887\n",
      "79 revenue:  3.2146542072296143 rgt:  0.07048376649618149 loss:  -1.4569740295410156\n",
      "80 revenue:  3.9225850105285645 rgt:  0.1418103575706482 loss:  -1.4621641635894775\n",
      "81 revenue:  3.2523648738861084 rgt:  0.07045507431030273 loss:  -1.4675425291061401\n",
      "82 revenue:  3.9495553970336914 rgt:  0.1430586278438568 loss:  -1.4660592079162598\n",
      "83 revenue:  3.2679495811462402 rgt:  0.07104481011629105 loss:  -1.4701600074768066\n",
      "84 revenue:  3.9598052501678467 rgt:  0.14493876695632935 loss:  -1.4642789363861084\n",
      "85 revenue:  3.274167776107788 rgt:  0.07257641851902008 loss:  -1.4674896001815796\n",
      "86 revenue:  3.952810764312744 rgt:  0.14293785393238068 loss:  -1.467158555984497\n",
      "87 revenue:  3.271049737930298 rgt:  0.07245182245969772 loss:  -1.4669837951660156\n",
      "88 revenue:  3.9499764442443848 rgt:  0.14280325174331665 loss:  -1.4667582511901855\n",
      "89 revenue:  3.2709591388702393 rgt:  0.07238875329494476 loss:  -1.4671390056610107\n",
      "90 revenue:  3.9485249519348145 rgt:  0.13783258199691772 loss:  -1.4779987335205078\n",
      "91 revenue:  3.298297643661499 rgt:  0.07156826555728912 loss:  -1.477030873298645\n",
      "92 revenue:  3.9586784839630127 rgt:  0.13761506974697113 loss:  -1.4810627698898315\n",
      "93 revenue:  3.3076186180114746 rgt:  0.07144840806722641 loss:  -1.4799392223358154\n",
      "94 revenue:  3.9960756301879883 rgt:  0.14329543709754944 loss:  -1.4771794080734253\n",
      "95 revenue:  3.328763484954834 rgt:  0.07542569190263748 loss:  -1.4744268655776978\n",
      "96 revenue:  3.987464427947998 rgt:  0.14156849682331085 loss:  -1.479039192199707\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "97 revenue:  3.322500228881836 rgt:  0.07508411258459091 loss:  -1.473673701286316\n",
      "98 revenue:  3.982314348220825 rgt:  0.14132116734981537 loss:  -1.478325366973877\n",
      "99 revenue:  3.3227779865264893 rgt:  0.07482565939426422 loss:  -1.4744805097579956\n",
      "100 revenue:  3.979276418685913 rgt:  0.13671155273914337 loss:  -1.4883555173873901\n",
      "101 revenue:  3.3535232543945312 rgt:  0.07373645156621933 loss:  -1.4859817028045654\n",
      "102 revenue:  3.9987525939941406 rgt:  0.1378583312034607 loss:  -1.4905369281768799\n",
      "103 revenue:  3.3647351264953613 rgt:  0.07413527369499207 loss:  -1.487908124923706\n",
      "104 revenue:  4.02130126953125 rgt:  0.14212045073509216 loss:  -1.4862090349197388\n",
      "105 revenue:  3.3768346309661865 rgt:  0.07749085128307343 loss:  -1.481753945350647\n",
      "106 revenue:  4.002044200897217 rgt:  0.1391412764787674 loss:  -1.4883531332015991\n",
      "107 revenue:  3.3631038665771484 rgt:  0.07624118030071259 loss:  -1.4815175533294678\n",
      "108 revenue:  3.999826431274414 rgt:  0.13947050273418427 loss:  -1.48702871799469\n",
      "109 revenue:  3.359424591064453 rgt:  0.07582147419452667 loss:  -1.4816948175430298\n",
      "110 revenue:  3.9948666095733643 rgt:  0.13494093716144562 loss:  -1.4964321851730347\n",
      "111 revenue:  3.3920392990112305 rgt:  0.0749443769454956 loss:  -1.4930448532104492\n",
      "112 revenue:  4.017214298248291 rgt:  0.13609598577022552 loss:  -1.4992910623550415\n",
      "113 revenue:  3.402198314666748 rgt:  0.07516376674175262 loss:  -1.4951810836791992\n",
      "114 revenue:  4.039982795715332 rgt:  0.1381833702325821 loss:  -1.500057339668274\n",
      "115 revenue:  3.425074577331543 rgt:  0.07712655514478683 loss:  -1.4958524703979492\n",
      "116 revenue:  4.042601585388184 rgt:  0.14070838689804077 loss:  -1.494802713394165\n",
      "117 revenue:  3.4259326457977295 rgt:  0.0797194242477417 loss:  -1.4888617992401123\n",
      "118 revenue:  4.013283729553223 rgt:  0.1376514732837677 loss:  -1.494652509689331\n",
      "119 revenue:  3.4026265144348145 rgt:  0.0775766521692276 loss:  -1.488518476486206\n",
      "120 revenue:  4.01619291305542 rgt:  0.1336383819580078 loss:  -1.5048398971557617\n",
      "121 revenue:  3.450806140899658 rgt:  0.07742460072040558 loss:  -1.5019571781158447\n",
      "122 revenue:  4.05146598815918 rgt:  0.13947878777980804 loss:  -1.4998780488967896\n",
      "123 revenue:  3.4561924934387207 rgt:  0.08067653328180313 loss:  -1.4943710565567017\n",
      "124 revenue:  4.024148941040039 rgt:  0.13579553365707397 loss:  -1.5017280578613281\n",
      "125 revenue:  3.4349234104156494 rgt:  0.07847130298614502 loss:  -1.4947561025619507\n",
      "126 revenue:  4.027472496032715 rgt:  0.13706135749816895 loss:  -1.4995770454406738\n",
      "127 revenue:  3.4331858158111572 rgt:  0.0781363695859909 loss:  -1.49522066116333\n",
      "128 revenue:  4.021514415740967 rgt:  0.13846474885940552 loss:  -1.494798183441162\n",
      "129 revenue:  3.419269561767578 rgt:  0.0760030597448349 loss:  -1.4974371194839478\n",
      "130 revenue:  4.018253803253174 rgt:  0.13210834562778473 loss:  -1.5089828968048096\n",
      "131 revenue:  3.4627928733825684 rgt:  0.07535593211650848 loss:  -1.5109918117523193\n",
      "132 revenue:  4.049466133117676 rgt:  0.13508205115795135 loss:  -1.509711503982544\n",
      "133 revenue:  3.490178346633911 rgt:  0.08153114467859268 loss:  -1.5011340379714966\n",
      "134 revenue:  4.051831245422363 rgt:  0.13736845552921295 loss:  -1.5049151182174683\n",
      "135 revenue:  3.476546049118042 rgt:  0.08002394437789917 loss:  -1.501640796661377\n",
      "136 revenue:  4.045369625091553 rgt:  0.1381974071264267 loss:  -1.501363754272461\n",
      "137 revenue:  3.46431040763855 rgt:  0.07839659601449966 loss:  -1.5028753280639648\n",
      "138 revenue:  4.030999660491943 rgt:  0.13913404941558838 loss:  -1.4955941438674927\n",
      "139 revenue:  3.447749137878418 rgt:  0.07680804282426834 loss:  -1.5028607845306396\n",
      "140 revenue:  4.0232319831848145 rgt:  0.1300688236951828 loss:  -1.515080213546753\n",
      "141 revenue:  3.5019967555999756 rgt:  0.07611548155546188 loss:  -1.5193564891815186\n",
      "142 revenue:  4.0600504875183105 rgt:  0.1341588944196701 loss:  -1.5145207643508911\n",
      "143 revenue:  3.5298373699188232 rgt:  0.07860266417264938 loss:  -1.5198217630386353\n",
      "144 revenue:  4.0774712562561035 rgt:  0.13574159145355225 loss:  -1.5151020288467407\n",
      "145 revenue:  3.553933620452881 rgt:  0.08103517442941666 loss:  -1.5194860696792603\n",
      "146 revenue:  4.082566738128662 rgt:  0.13596902787685394 loss:  -1.5158272981643677\n",
      "147 revenue:  3.5656917095184326 rgt:  0.08183516561985016 loss:  -1.5204002857208252\n",
      "148 revenue:  4.094632625579834 rgt:  0.13681839406490326 loss:  -1.5168116092681885\n",
      "149 revenue:  3.58105731010437 rgt:  0.08304733037948608 loss:  -1.521141529083252\n",
      "150 revenue:  4.0973687171936035 rgt:  0.13565650582313538 loss:  -1.5202237367630005\n",
      "151 revenue:  3.5926005840301514 rgt:  0.08369414508342743 loss:  -1.522422194480896\n",
      "152 revenue:  4.103602886199951 rgt:  0.13798536360263824 loss:  -1.516286015510559\n",
      "153 revenue:  3.5996248722076416 rgt:  0.08968136459589005 loss:  -1.508117914199829\n",
      "154 revenue:  4.081812381744385 rgt:  0.13704103231430054 loss:  -1.513118028640747\n",
      "155 revenue:  3.536579132080078 rgt:  0.08295300602912903 loss:  -1.509610891342163\n",
      "156 revenue:  4.069276332855225 rgt:  0.13673387467861176 loss:  -1.5107355117797852\n",
      "157 revenue:  3.526981830596924 rgt:  0.0815119668841362 loss:  -1.511011004447937\n",
      "158 revenue:  4.054152011871338 rgt:  0.13694651424884796 loss:  -1.5064831972122192\n",
      "159 revenue:  3.512676954269409 rgt:  0.07993291318416595 loss:  -1.511556625366211\n",
      "160 revenue:  4.047337055206299 rgt:  0.1293366402387619 loss:  -1.5228289365768433\n",
      "161 revenue:  3.5826733112335205 rgt:  0.07977638393640518 loss:  -1.5305715799331665\n",
      "162 revenue:  4.0865983963012695 rgt:  0.1362580955028534 loss:  -1.516144037246704\n",
      "163 revenue:  3.605571746826172 rgt:  0.08615532517433167 loss:  -1.519156813621521\n",
      "164 revenue:  4.087278842926025 rgt:  0.13557782769203186 loss:  -1.5179153680801392\n",
      "165 revenue:  3.5759150981903076 rgt:  0.0834118127822876 loss:  -1.518786072731018\n",
      "166 revenue:  4.083407402038574 rgt:  0.1367965191602707 loss:  -1.5140876770019531\n",
      "167 revenue:  3.568516254425049 rgt:  0.08274208754301071 loss:  -1.518660306930542\n",
      "168 revenue:  4.072792053222656 rgt:  0.13866007328033447 loss:  -1.5070850849151611\n",
      "169 revenue:  3.5544822216033936 rgt:  0.08113162219524384 loss:  -1.519365668296814\n",
      "170 revenue:  4.0637946128845215 rgt:  0.12969839572906494 loss:  -1.5260505676269531\n",
      "171 revenue:  3.6295812129974365 rgt:  0.0820961743593216 loss:  -1.5365254878997803\n",
      "172 revenue:  4.106900691986084 rgt:  0.1346292793750763 loss:  -1.525001049041748\n",
      "173 revenue:  3.654607057571411 rgt:  0.0843709334731102 loss:  -1.5368648767471313\n",
      "174 revenue:  4.122578144073486 rgt:  0.13891519606113434 loss:  -1.5187848806381226\n",
      "175 revenue:  3.6653811931610107 rgt:  0.08994895964860916 loss:  -1.524654507637024\n",
      "176 revenue:  4.106396675109863 rgt:  0.13616861402988434 loss:  -1.5212457180023193\n",
      "177 revenue:  3.6103951930999756 rgt:  0.08489727228879929 loss:  -1.5238354206085205\n",
      "178 revenue:  4.103008270263672 rgt:  0.1368376910686493 loss:  -1.5188348293304443\n",
      "179 revenue:  3.6047749519348145 rgt:  0.08458627760410309 loss:  -1.5232011079788208\n",
      "180 revenue:  4.08758020401001 rgt:  0.13139685988426208 loss:  -1.5278924703598022\n",
      "181 revenue:  3.643332004547119 rgt:  0.08240211755037308 loss:  -1.539291501045227\n",
      "182 revenue:  4.122100353240967 rgt:  0.1368137001991272 loss:  -1.5235986709594727\n",
      "183 revenue:  3.665274143218994 rgt:  0.08911940455436707 loss:  -1.5268423557281494\n",
      "184 revenue:  4.121160984039307 rgt:  0.1360131949186325 loss:  -1.5252515077590942\n",
      "185 revenue:  3.6428725719451904 rgt:  0.08720393478870392 loss:  -1.5261240005493164\n",
      "186 revenue:  4.11453104019165 rgt:  0.1369318962097168 loss:  -1.5214557647705078\n",
      "187 revenue:  3.6290812492370605 rgt:  0.08591698855161667 loss:  -1.5259817838668823\n",
      "188 revenue:  4.094640254974365 rgt:  0.13777871429920197 loss:  -1.5145573616027832\n",
      "189 revenue:  3.6136631965637207 rgt:  0.08463087677955627 loss:  -1.5254191160202026\n",
      "190 revenue:  4.086231231689453 rgt:  0.12961310148239136 loss:  -1.5318114757537842\n",
      "191 revenue:  3.694268226623535 rgt:  0.08544423431158066 loss:  -1.544295310974121\n",
      "192 revenue:  4.136620998382568 rgt:  0.13540637493133545 loss:  -1.5304861068725586\n",
      "193 revenue:  3.72326397895813 rgt:  0.0882546603679657 loss:  -1.544244647026062\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "194 revenue:  4.1434431076049805 rgt:  0.13579052686691284 loss:  -1.5312566757202148\n",
      "195 revenue:  3.7328295707702637 rgt:  0.08886167407035828 loss:  -1.5450947284698486\n",
      "196 revenue:  4.149069786071777 rgt:  0.13610485196113586 loss:  -1.531897783279419\n",
      "197 revenue:  3.7408385276794434 rgt:  0.08952456712722778 loss:  -1.545393705368042\n",
      "198 revenue:  4.155373573303223 rgt:  0.13656100630760193 loss:  -1.532370686531067\n",
      "199 revenue:  3.752149820327759 rgt:  0.09067360311746597 loss:  -1.5452524423599243\n",
      "200 revenue:  4.160791397094727 rgt:  0.13511213660240173 loss:  -1.5371136665344238\n",
      "201 revenue:  4.154376029968262 rgt:  0.12677352130413055 loss:  -1.5554026365280151\n",
      "202 revenue:  4.1408514976501465 rgt:  0.11819596588611603 loss:  -1.5729159116744995\n",
      "203 revenue:  4.119686603546143 rgt:  0.11045844107866287 loss:  -1.586889624595642\n",
      "204 revenue:  4.0990681648254395 rgt:  0.10460508614778519 loss:  -1.596583366394043\n",
      "205 revenue:  4.126934051513672 rgt:  0.10551529377698898 loss:  -1.6011390686035156\n",
      "206 revenue:  4.0950751304626465 rgt:  0.10129643976688385 loss:  -1.6040617227554321\n",
      "207 revenue:  4.127161502838135 rgt:  0.10435914993286133 loss:  -1.6041357517242432\n",
      "208 revenue:  4.096805095672607 rgt:  0.10100802779197693 loss:  -1.6052310466766357\n",
      "209 revenue:  4.127233505249023 rgt:  0.10418086498975754 loss:  -1.6046080589294434\n",
      "210 revenue:  4.096920490264893 rgt:  0.10086572170257568 loss:  -1.6056257486343384\n",
      "211 revenue:  4.1265692710876465 rgt:  0.10977918654680252 loss:  -1.590287208557129\n",
      "212 revenue:  4.092861652374268 rgt:  0.10833224654197693 loss:  -1.585611343383789\n",
      "213 revenue:  4.059392929077148 rgt:  0.10474913567304611 loss:  -1.5863949060440063\n",
      "214 revenue:  4.0257768630981445 rgt:  0.10214820504188538 loss:  -1.5846794843673706\n",
      "215 revenue:  4.007022380828857 rgt:  0.10109146684408188 loss:  -1.5827144384384155\n",
      "216 revenue:  4.029280185699463 rgt:  0.10386158525943756 loss:  -1.581169605255127\n",
      "217 revenue:  3.9932401180267334 rgt:  0.1015976220369339 loss:  -1.577967882156372\n",
      "218 revenue:  4.017354488372803 rgt:  0.10455305874347687 loss:  -1.5764342546463013\n",
      "219 revenue:  3.9739773273468018 rgt:  0.10309113562107086 loss:  -1.5693144798278809\n",
      "220 revenue:  3.9967498779296875 rgt:  0.09120029211044312 loss:  -1.6059932708740234\n",
      "221 revenue:  4.034689426422119 rgt:  0.09429687261581421 loss:  -1.607278823852539\n",
      "222 revenue:  4.06864595413208 rgt:  0.09720973670482635 loss:  -1.6080939769744873\n",
      "223 revenue:  4.094928741455078 rgt:  0.10523011535406113 loss:  -1.5939710140228271\n",
      "224 revenue:  4.058140754699707 rgt:  0.102604441344738 loss:  -1.5915590524673462\n",
      "225 revenue:  4.021866798400879 rgt:  0.09895623475313187 loss:  -1.5919300317764282\n",
      "226 revenue:  3.984449625015259 rgt:  0.09579013288021088 loss:  -1.5908186435699463\n",
      "227 revenue:  3.99462890625 rgt:  0.09699912369251251 loss:  -1.5902107954025269\n",
      "228 revenue:  3.965778350830078 rgt:  0.09478843212127686 loss:  -1.588760495185852\n",
      "229 revenue:  4.000010967254639 rgt:  0.09832891076803207 loss:  -1.5880992412567139\n",
      "230 revenue:  3.95906400680542 rgt:  0.08707214146852493 loss:  -1.6075875759124756\n",
      "231 revenue:  4.002557754516602 rgt:  0.0905359610915184 loss:  -1.6092115640640259\n",
      "232 revenue:  4.042398929595947 rgt:  0.09535625576972961 loss:  -1.6064174175262451\n",
      "233 revenue:  4.036804676055908 rgt:  0.09603157639503479 loss:  -1.6032589673995972\n",
      "234 revenue:  4.041337966918945 rgt:  0.09689651429653168 loss:  -1.6021294593811035\n",
      "235 revenue:  4.027149200439453 rgt:  0.09696584939956665 loss:  -1.5984165668487549\n",
      "236 revenue:  4.0142621994018555 rgt:  0.09634365141391754 loss:  -1.5968260765075684\n",
      "237 revenue:  4.029042720794678 rgt:  0.09907903522253036 loss:  -1.593400239944458\n",
      "238 revenue:  3.9989092350006104 rgt:  0.09624844044446945 loss:  -1.5932395458221436\n",
      "239 revenue:  4.025032043457031 rgt:  0.09870751947164536 loss:  -1.5933631658554077\n",
      "240 revenue:  3.9965553283691406 rgt:  0.08946205675601959 loss:  -1.61057448387146\n",
      "241 revenue:  4.040426254272461 rgt:  0.09325605630874634 loss:  -1.6114463806152344\n",
      "242 revenue:  4.068995952606201 rgt:  0.0957815945148468 loss:  -1.6119076013565063\n",
      "243 revenue:  4.091285228729248 rgt:  0.10381382703781128 loss:  -1.596677303314209\n",
      "244 revenue:  4.059916973114014 rgt:  0.10164899379014969 loss:  -1.5944501161575317\n",
      "245 revenue:  4.028564453125 rgt:  0.09812024980783463 loss:  -1.5957667827606201\n",
      "246 revenue:  3.9958724975585938 rgt:  0.09555728733539581 loss:  -1.5942871570587158\n",
      "247 revenue:  3.984525680541992 rgt:  0.094981350004673 loss:  -1.5929559469223022\n",
      "248 revenue:  3.992119789123535 rgt:  0.09641780704259872 loss:  -1.5910990238189697\n",
      "249 revenue:  3.9628117084503174 rgt:  0.09444774687290192 loss:  -1.5889099836349487\n",
      "250 revenue:  3.991410493850708 rgt:  0.0889088585972786 loss:  -1.6107666492462158\n",
      "251 revenue:  4.031614780426025 rgt:  0.09111596643924713 loss:  -1.6149178743362427\n",
      "252 revenue:  4.068609237670898 rgt:  0.09649944305419922 loss:  -1.6099363565444946\n",
      "253 revenue:  4.048120021820068 rgt:  0.0956159308552742 loss:  -1.6071598529815674\n",
      "254 revenue:  4.041616439819336 rgt:  0.09529423713684082 loss:  -1.6063852310180664\n",
      "255 revenue:  4.041501522064209 rgt:  0.09565041959285736 loss:  -1.605424165725708\n",
      "256 revenue:  4.038691520690918 rgt:  0.09598588943481445 loss:  -1.6038477420806885\n",
      "257 revenue:  4.041653156280518 rgt:  0.09666457772254944 loss:  -1.60281240940094\n",
      "258 revenue:  4.023473739624023 rgt:  0.09533265233039856 loss:  -1.6017673015594482\n",
      "259 revenue:  4.045280456542969 rgt:  0.09779965877532959 loss:  -1.6007591485977173\n",
      "260 revenue:  4.014061450958252 rgt:  0.08981292694807053 loss:  -1.6140114068984985\n",
      "261 revenue:  4.048374176025391 rgt:  0.09222758561372757 loss:  -1.6161397695541382\n",
      "262 revenue:  4.082707405090332 rgt:  0.1019248366355896 loss:  -1.5993895530700684\n",
      "263 revenue:  4.051440715789795 rgt:  0.09839274734258652 loss:  -1.600750207901001\n",
      "264 revenue:  4.02616548538208 rgt:  0.09618684649467468 loss:  -1.6002038717269897\n",
      "265 revenue:  4.009256362915039 rgt:  0.09451229870319366 loss:  -1.6003717184066772\n",
      "266 revenue:  4.023575782775879 rgt:  0.09569619596004486 loss:  -1.6008411645889282\n",
      "267 revenue:  4.027795791625977 rgt:  0.09632472693920135 loss:  -1.6002501249313354\n",
      "268 revenue:  4.037827968597412 rgt:  0.09721648693084717 loss:  -1.6004226207733154\n",
      "269 revenue:  4.040326118469238 rgt:  0.09928721934556961 loss:  -1.595670223236084\n",
      "270 revenue:  4.045007228851318 rgt:  0.08950860798358917 loss:  -1.6225316524505615\n",
      "271 revenue:  4.085519313812256 rgt:  0.09141268581151962 loss:  -1.6275087594985962\n",
      "272 revenue:  4.1226630210876465 rgt:  0.09776996821165085 loss:  -1.6199822425842285\n",
      "273 revenue:  4.129767894744873 rgt:  0.0986069068312645 loss:  -1.6195586919784546\n",
      "274 revenue:  4.140604019165039 rgt:  0.09937003999948502 loss:  -1.6202473640441895\n",
      "275 revenue:  4.1338396072387695 rgt:  0.09818879514932632 loss:  -1.6216448545455933\n",
      "276 revenue:  4.149828910827637 rgt:  0.0992463082075119 loss:  -1.6228328943252563\n",
      "277 revenue:  4.138413906097412 rgt:  0.09857209026813507 loss:  -1.6217750310897827\n",
      "278 revenue:  4.152881622314453 rgt:  0.09971664845943451 loss:  -1.622365951538086\n",
      "279 revenue:  4.1513800621032715 rgt:  0.09940148890018463 loss:  -1.622812032699585\n",
      "280 revenue:  4.165226459503174 rgt:  0.09193401783704758 loss:  -1.6457483768463135\n",
      "281 revenue:  4.211857795715332 rgt:  0.09582225233316422 loss:  -1.6469072103500366\n",
      "282 revenue:  4.243237018585205 rgt:  0.09855661541223526 loss:  -1.6474180221557617\n",
      "283 revenue:  4.269027233123779 rgt:  0.10026895999908447 loss:  -1.6492406129837036\n",
      "284 revenue:  4.2826828956604 rgt:  0.10070282965898514 loss:  -1.651424527168274\n",
      "285 revenue:  4.309265613555908 rgt:  0.10263871401548386 loss:  -1.6528656482696533\n",
      "286 revenue:  4.31217098236084 rgt:  0.10220380872488022 loss:  -1.654679536819458\n",
      "287 revenue:  4.335473537445068 rgt:  0.10392048954963684 loss:  -1.6558926105499268\n",
      "288 revenue:  4.32218599319458 rgt:  0.1019701212644577 loss:  -1.6576892137527466\n",
      "289 revenue:  4.351179122924805 rgt:  0.10443605482578278 loss:  -1.6583462953567505\n",
      "290 revenue:  4.328943729400635 rgt:  0.10252226144075394 loss:  -1.6578983068466187\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "291 revenue:  4.294384956359863 rgt:  0.09758628159761429 loss:  -1.6623153686523438\n",
      "292 revenue:  4.34375 rgt:  0.10292983800172806 loss:  -1.660409927368164\n",
      "293 revenue:  4.3648552894592285 rgt:  0.10725143551826477 loss:  -1.6544795036315918\n",
      "294 revenue:  4.326261043548584 rgt:  0.10423196852207184 loss:  -1.652884840965271\n",
      "295 revenue:  4.318429470062256 rgt:  0.10337330400943756 loss:  -1.6531925201416016\n",
      "296 revenue:  4.299928188323975 rgt:  0.10222823917865753 loss:  -1.6516669988632202\n",
      "297 revenue:  4.324364185333252 rgt:  0.10459551215171814 loss:  -1.6515026092529297\n",
      "298 revenue:  4.277061939239502 rgt:  0.10033326596021652 loss:  -1.6510183811187744\n",
      "299 revenue:  4.319688320159912 rgt:  0.10498610883951187 loss:  -1.6493843793869019\n",
      "300 revenue:  4.268306732177734 rgt:  0.09542346000671387 loss:  -1.661657691001892\n",
      "301 revenue:  4.326221466064453 rgt:  0.10023143142461777 loss:  -1.6631321907043457\n",
      "302 revenue:  4.361000061035156 rgt:  0.10566409677267075 loss:  -1.6575764417648315\n",
      "303 revenue:  4.3206257820129395 rgt:  0.10246092826128006 loss:  -1.6560554504394531\n",
      "304 revenue:  4.3199896812438965 rgt:  0.10383621603250504 loss:  -1.6523860692977905\n",
      "305 revenue:  4.289408206939697 rgt:  0.10139179974794388 loss:  -1.6512759923934937\n",
      "306 revenue:  4.283485412597656 rgt:  0.10081310570240021 loss:  -1.651334285736084\n",
      "307 revenue:  4.2882537841796875 rgt:  0.10176897794008255 loss:  -1.6500283479690552\n",
      "308 revenue:  4.267786026000977 rgt:  0.10221973806619644 loss:  -1.6439239978790283\n",
      "309 revenue:  4.307442665100098 rgt:  0.10701686143875122 loss:  -1.641286849975586\n",
      "310 revenue:  4.260200023651123 rgt:  0.09370281547307968 loss:  -1.6642131805419922\n",
      "311 revenue:  4.318423271179199 rgt:  0.09926767647266388 loss:  -1.6637461185455322\n",
      "312 revenue:  4.362615585327148 rgt:  0.10385353118181229 loss:  -1.6625707149505615\n",
      "313 revenue:  4.3405070304870605 rgt:  0.10106933861970901 loss:  -1.6644049882888794\n",
      "314 revenue:  4.380179405212402 rgt:  0.10516945272684097 loss:  -1.6634200811386108\n",
      "315 revenue:  4.337668418884277 rgt:  0.10030470788478851 loss:  -1.6656930446624756\n",
      "316 revenue:  4.386496543884277 rgt:  0.10551644116640091 loss:  -1.6640470027923584\n",
      "317 revenue:  4.34002161026001 rgt:  0.10025553405284882 loss:  -1.6663846969604492\n",
      "318 revenue:  4.389938831329346 rgt:  0.10561800748109818 loss:  -1.6646109819412231\n",
      "319 revenue:  4.3446044921875 rgt:  0.10049473494291306 loss:  -1.6668678522109985\n",
      "320 revenue:  4.394583702087402 rgt:  0.10641080886125565 loss:  -1.6637088060379028\n",
      "321 revenue:  4.350372314453125 rgt:  0.10109423846006393 loss:  -1.666707158088684\n",
      "322 revenue:  4.39900541305542 rgt:  0.10697297751903534 loss:  -1.663340449333191\n",
      "323 revenue:  4.352113723754883 rgt:  0.10327412933111191 loss:  -1.6615350246429443\n",
      "324 revenue:  4.340414047241211 rgt:  0.10219545662403107 loss:  -1.6614904403686523\n",
      "325 revenue:  4.338953018188477 rgt:  0.1032586470246315 loss:  -1.6584179401397705\n",
      "326 revenue:  4.317141056060791 rgt:  0.10147421061992645 loss:  -1.657748818397522\n",
      "327 revenue:  4.360206604003906 rgt:  0.10697872191667557 loss:  -1.6540559530258179\n",
      "328 revenue:  4.305037975311279 rgt:  0.10147210210561752 loss:  -1.6548393964767456\n",
      "329 revenue:  4.345463275909424 rgt:  0.10629019141197205 loss:  -1.6522655487060547\n",
      "330 revenue:  4.289155960083008 rgt:  0.09619119018316269 loss:  -1.664689540863037\n",
      "331 revenue:  4.333449363708496 rgt:  0.09960450977087021 loss:  -1.6664875745773315\n",
      "332 revenue:  4.376458644866943 rgt:  0.10487072169780731 loss:  -1.6632906198501587\n",
      "333 revenue:  4.334987163543701 rgt:  0.10471497476100922 loss:  -1.653751254081726\n",
      "334 revenue:  4.304876327514648 rgt:  0.10231609642505646 loss:  -1.652634620666504\n",
      "335 revenue:  4.283527374267578 rgt:  0.1010499820113182 loss:  -1.6507349014282227\n",
      "336 revenue:  4.294796943664551 rgt:  0.10277527570724487 loss:  -1.6490280628204346\n",
      "337 revenue:  4.252344608306885 rgt:  0.09993022680282593 loss:  -1.646073818206787\n",
      "338 revenue:  4.303823947906494 rgt:  0.10592622309923172 loss:  -1.643176555633545\n",
      "339 revenue:  4.242927074432373 rgt:  0.10178817063570023 loss:  -1.6390058994293213\n",
      "340 revenue:  4.284363746643066 rgt:  0.09606482088565826 loss:  -1.6638624668121338\n",
      "341 revenue:  4.329285144805908 rgt:  0.09877031296491623 loss:  -1.667645812034607\n",
      "342 revenue:  4.362460613250732 rgt:  0.10429780185222626 loss:  -1.6614010334014893\n",
      "343 revenue:  4.328438758850098 rgt:  0.10039331018924713 loss:  -1.66324782371521\n",
      "344 revenue:  4.3272905349731445 rgt:  0.10213140398263931 loss:  -1.6585025787353516\n",
      "345 revenue:  4.308009147644043 rgt:  0.10005231946706772 loss:  -1.6592116355895996\n",
      "346 revenue:  4.35159969329834 rgt:  0.10545273870229721 loss:  -1.6558611392974854\n",
      "347 revenue:  4.297616958618164 rgt:  0.10112806409597397 loss:  -1.6539350748062134\n",
      "348 revenue:  4.347288131713867 rgt:  0.10745301097631454 loss:  -1.6497617959976196\n",
      "349 revenue:  4.291386604309082 rgt:  0.1026555523276329 loss:  -1.648511528968811\n",
      "350 revenue:  4.321315765380859 rgt:  0.09823384135961533 loss:  -1.6671209335327148\n",
      "351 revenue:  4.369076251983643 rgt:  0.10246501117944717 loss:  -1.667667031288147\n",
      "352 revenue:  4.336394309997559 rgt:  0.10319693386554718 loss:  -1.6579612493515015\n",
      "353 revenue:  4.296894550323486 rgt:  0.10034798830747604 loss:  -1.6557698249816895\n",
      "354 revenue:  4.284908771514893 rgt:  0.09941458702087402 loss:  -1.6552866697311401\n",
      "355 revenue:  4.3044352531433105 rgt:  0.10207317769527435 loss:  -1.653151035308838\n",
      "356 revenue:  4.248818874359131 rgt:  0.09674803167581558 loss:  -1.6534749269485474\n",
      "357 revenue:  4.306802749633789 rgt:  0.10296077281236649 loss:  -1.6514478921890259\n",
      "358 revenue:  4.243250370025635 rgt:  0.09710711240768433 loss:  -1.6511878967285156\n",
      "359 revenue:  4.298986434936523 rgt:  0.10332608222961426 loss:  -1.648629903793335\n",
      "360 revenue:  4.233603477478027 rgt:  0.09080027043819427 loss:  -1.6654410362243652\n",
      "361 revenue:  4.297506332397461 rgt:  0.09748589247465134 loss:  -1.6633297204971313\n",
      "362 revenue:  4.289785861968994 rgt:  0.09839874505996704 loss:  -1.659095287322998\n",
      "363 revenue:  4.312899589538574 rgt:  0.10065072029829025 loss:  -1.6588464975357056\n",
      "364 revenue:  4.295138359069824 rgt:  0.09972765296697617 loss:  -1.656947135925293\n",
      "365 revenue:  4.329561710357666 rgt:  0.10396310687065125 loss:  -1.654363751411438\n",
      "366 revenue:  4.274388313293457 rgt:  0.09878671914339066 loss:  -1.6543691158294678\n",
      "367 revenue:  4.328106880187988 rgt:  0.10500641167163849 loss:  -1.651356816291809\n",
      "368 revenue:  4.269317626953125 rgt:  0.09951259940862656 loss:  -1.651263952255249\n",
      "369 revenue:  4.324970245361328 rgt:  0.10577738285064697 loss:  -1.6486445665359497\n",
      "370 revenue:  4.268167495727539 rgt:  0.09390048682689667 loss:  -1.6656221151351929\n",
      "371 revenue:  4.325964450836182 rgt:  0.09780828654766083 loss:  -1.6693438291549683\n",
      "372 revenue:  4.3685431480407715 rgt:  0.10430502891540527 loss:  -1.662838101387024\n",
      "373 revenue:  4.327169895172119 rgt:  0.09926142543554306 loss:  -1.6658660173416138\n",
      "374 revenue:  4.353151321411133 rgt:  0.10348471999168396 loss:  -1.661245584487915\n",
      "375 revenue:  4.308797359466553 rgt:  0.09944432973861694 loss:  -1.6609718799591064\n",
      "376 revenue:  4.340576648712158 rgt:  0.10379817336797714 loss:  -1.6574296951293945\n",
      "377 revenue:  4.289555549621582 rgt:  0.09830828756093979 loss:  -1.6592744588851929\n",
      "378 revenue:  4.328968048095703 rgt:  0.10298485308885574 loss:  -1.65671968460083\n",
      "379 revenue:  4.276600360870361 rgt:  0.0990799143910408 loss:  -1.6541447639465332\n",
      "380 revenue:  4.331325054168701 rgt:  0.09750667214393616 loss:  -1.6714164018630981\n",
      "381 revenue:  4.370293617248535 rgt:  0.10168752074241638 loss:  -1.6699522733688354\n",
      "382 revenue:  4.329385280609131 rgt:  0.09756852686405182 loss:  -1.6707894802093506\n",
      "383 revenue:  4.38433313369751 rgt:  0.1029980331659317 loss:  -1.6699488162994385\n",
      "384 revenue:  4.334467887878418 rgt:  0.09769629687070847 loss:  -1.671678066253662\n",
      "385 revenue:  4.390595436096191 rgt:  0.10337911546230316 loss:  -1.6704694032669067\n",
      "386 revenue:  4.3395915031433105 rgt:  0.10096444934606552 loss:  -1.6644550561904907\n",
      "387 revenue:  4.292880058288574 rgt:  0.09803159534931183 loss:  -1.660794973373413\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "388 revenue:  4.3084869384765625 rgt:  0.10027456283569336 loss:  -1.6587533950805664\n",
      "389 revenue:  4.281373977661133 rgt:  0.09881258755922318 loss:  -1.6559908390045166\n",
      "390 revenue:  4.29427433013916 rgt:  0.09448213875293732 loss:  -1.6704013347625732\n",
      "391 revenue:  4.35168981552124 rgt:  0.10202465951442719 loss:  -1.6646329164505005\n",
      "392 revenue:  4.319911003112793 rgt:  0.0995846763253212 loss:  -1.663284420967102\n",
      "393 revenue:  4.3406195640563965 rgt:  0.10187438130378723 loss:  -1.6623632907867432\n",
      "394 revenue:  4.3033766746521 rgt:  0.09897708147764206 loss:  -1.660874843597412\n",
      "395 revenue:  4.344419479370117 rgt:  0.10356421768665314 loss:  -1.6589490175247192\n",
      "396 revenue:  4.284461498260498 rgt:  0.09925733506679535 loss:  -1.6555854082107544\n",
      "397 revenue:  4.335221767425537 rgt:  0.1060117706656456 loss:  -1.6505132913589478\n",
      "398 revenue:  4.2734575271606445 rgt:  0.10056965798139572 loss:  -1.649537444114685\n",
      "399 revenue:  4.330548286437988 rgt:  0.10718495398759842 loss:  -1.6464208364486694\n",
      "400 revenue:  4.271816253662109 rgt:  0.0924977958202362 loss:  -1.670204997062683\n",
      "401 revenue:  4.278319358825684 rgt:  0.09277244657278061 loss:  -1.6710517406463623\n",
      "402 revenue:  4.285061836242676 rgt:  0.09345857053995132 loss:  -1.6708705425262451\n",
      "403 revenue:  4.291635036468506 rgt:  0.0939665287733078 loss:  -1.6711201667785645\n",
      "404 revenue:  4.2980265617370605 rgt:  0.09446592628955841 loss:  -1.6713491678237915\n",
      "405 revenue:  4.304270267486572 rgt:  0.09496862441301346 loss:  -1.6715348958969116\n",
      "406 revenue:  4.310352325439453 rgt:  0.09547385573387146 loss:  -1.6716763973236084\n",
      "407 revenue:  4.316269397735596 rgt:  0.09597571194171906 loss:  -1.6717880964279175\n",
      "408 revenue:  4.32195520401001 rgt:  0.09646658599376678 loss:  -1.6718740463256836\n",
      "409 revenue:  4.327220916748047 rgt:  0.0969231128692627 loss:  -1.6719493865966797\n",
      "410 revenue:  4.332286834716797 rgt:  0.09689632058143616 loss:  -1.6732367277145386\n",
      "411 revenue:  4.335492134094238 rgt:  0.09760628640651703 loss:  -1.6721582412719727\n",
      "412 revenue:  4.339634418487549 rgt:  0.10045654326677322 loss:  -1.665773630142212\n",
      "413 revenue:  4.334846496582031 rgt:  0.1029604971408844 loss:  -1.6581943035125732\n",
      "414 revenue:  4.331170558929443 rgt:  0.10331689566373825 loss:  -1.6564000844955444\n",
      "415 revenue:  4.326724052429199 rgt:  0.10346408188343048 loss:  -1.6549553871154785\n",
      "416 revenue:  4.322002410888672 rgt:  0.10343840718269348 loss:  -1.6538857221603394\n",
      "417 revenue:  4.3171586990356445 rgt:  0.10327760875225067 loss:  -1.6531314849853516\n",
      "418 revenue:  4.312507629394531 rgt:  0.10329291224479675 loss:  -1.6519726514816284\n",
      "419 revenue:  4.308410167694092 rgt:  0.10371335595846176 loss:  -1.6499119997024536\n",
      "420 revenue:  4.304707050323486 rgt:  0.09491030871868134 loss:  -1.6717933416366577\n",
      "421 revenue:  4.310752868652344 rgt:  0.0950910672545433 loss:  -1.6727757453918457\n",
      "422 revenue:  4.317103385925293 rgt:  0.09876088798046112 loss:  -1.664740800857544\n",
      "423 revenue:  4.3133087158203125 rgt:  0.10024083405733109 loss:  -1.660001516342163\n",
      "424 revenue:  4.310710906982422 rgt:  0.10084100812673569 loss:  -1.6578292846679688\n",
      "425 revenue:  4.306415557861328 rgt:  0.10114467889070511 loss:  -1.6560133695602417\n",
      "426 revenue:  4.301721572875977 rgt:  0.10124184936285019 loss:  -1.6546322107315063\n",
      "427 revenue:  4.297013759613037 rgt:  0.10121269524097443 loss:  -1.6535717248916626\n",
      "428 revenue:  4.292957305908203 rgt:  0.10133158415555954 loss:  -1.6522873640060425\n",
      "429 revenue:  4.289467811584473 rgt:  0.10177787393331528 loss:  -1.6502987146377563\n",
      "430 revenue:  4.28626823425293 rgt:  0.09364964067935944 loss:  -1.6706584692001343\n",
      "431 revenue:  4.292411804199219 rgt:  0.09339182823896408 loss:  -1.672821044921875\n",
      "432 revenue:  4.298964977264404 rgt:  0.09629684686660767 loss:  -1.6667804718017578\n",
      "433 revenue:  4.294455528259277 rgt:  0.09786148369312286 loss:  -1.6616171598434448\n",
      "434 revenue:  4.293459892272949 rgt:  0.09858372807502747 loss:  -1.659502387046814\n",
      "435 revenue:  4.29120397567749 rgt:  0.09917064756155014 loss:  -1.657437801361084\n",
      "436 revenue:  4.287095546722412 rgt:  0.0994318276643753 loss:  -1.655770182609558\n",
      "437 revenue:  4.283038139343262 rgt:  0.09962081909179688 loss:  -1.6543017625808716\n",
      "438 revenue:  4.279634475708008 rgt:  0.100099578499794 loss:  -1.6522430181503296\n",
      "439 revenue:  4.276861667633057 rgt:  0.10115349292755127 loss:  -1.6488577127456665\n",
      "440 revenue:  4.274189472198486 rgt:  0.09210982918739319 loss:  -1.6718053817749023\n",
      "441 revenue:  4.280272483825684 rgt:  0.09226000308990479 loss:  -1.672878623008728\n",
      "442 revenue:  4.286628723144531 rgt:  0.09274246543645859 loss:  -1.6731387376785278\n",
      "443 revenue:  4.292855262756348 rgt:  0.09323745965957642 loss:  -1.673335075378418\n",
      "444 revenue:  4.298857688903809 rgt:  0.09441572427749634 loss:  -1.6716816425323486\n",
      "445 revenue:  4.300460338592529 rgt:  0.09491556137800217 loss:  -1.6707558631896973\n",
      "446 revenue:  4.302985668182373 rgt:  0.09594917297363281 loss:  -1.6686581373214722\n",
      "447 revenue:  4.305130958557129 rgt:  0.0991986021399498 loss:  -1.66072416305542\n",
      "448 revenue:  4.303048133850098 rgt:  0.09958010166883469 loss:  -1.6592357158660889\n",
      "449 revenue:  4.299983024597168 rgt:  0.09964772313833237 loss:  -1.6583220958709717\n",
      "450 revenue:  4.296890735626221 rgt:  0.09392262995243073 loss:  -1.6725037097930908\n",
      "451 revenue:  4.3029093742370605 rgt:  0.09387701749801636 loss:  -1.6740748882293701\n",
      "452 revenue:  4.3091959953308105 rgt:  0.09621033817529678 loss:  -1.6694719791412354\n",
      "453 revenue:  4.3132100105285645 rgt:  0.09740635007619858 loss:  -1.6673204898834229\n",
      "454 revenue:  4.315807819366455 rgt:  0.09915761649608612 loss:  -1.6634016036987305\n",
      "455 revenue:  4.315491199493408 rgt:  0.10014056414365768 loss:  -1.6607856750488281\n",
      "456 revenue:  4.314296722412109 rgt:  0.10103730857372284 loss:  -1.6581876277923584\n",
      "457 revenue:  4.31155252456665 rgt:  0.10124661028385162 loss:  -1.6569886207580566\n",
      "458 revenue:  4.308142185211182 rgt:  0.10136787593364716 loss:  -1.6558552980422974\n",
      "459 revenue:  4.304357528686523 rgt:  0.10148859024047852 loss:  -1.6546332836151123\n",
      "460 revenue:  4.30034065246582 rgt:  0.09436341375112534 loss:  -1.672176480293274\n",
      "461 revenue:  4.306403636932373 rgt:  0.0942227840423584 loss:  -1.6740076541900635\n",
      "462 revenue:  4.312803745269775 rgt:  0.09526308625936508 loss:  -1.6728187799453735\n",
      "463 revenue:  4.318953514099121 rgt:  0.09688547998666763 loss:  -1.6700594425201416\n",
      "464 revenue:  4.322439193725586 rgt:  0.0972789078950882 loss:  -1.6698731184005737\n",
      "465 revenue:  4.323903560638428 rgt:  0.09772951155900955 loss:  -1.669053077697754\n",
      "466 revenue:  4.323963165283203 rgt:  0.09978185594081879 loss:  -1.6637495756149292\n",
      "467 revenue:  4.318401336669922 rgt:  0.10223817080259323 loss:  -1.6560912132263184\n",
      "468 revenue:  4.312669277191162 rgt:  0.10328738391399384 loss:  -1.652025818824768\n",
      "469 revenue:  4.307068824768066 rgt:  0.10433923453092575 loss:  -1.6479928493499756\n",
      "470 revenue:  4.301611423492432 rgt:  0.09389529377222061 loss:  -1.6737138032913208\n",
      "471 revenue:  4.307912349700928 rgt:  0.09439364820718765 loss:  -1.6739219427108765\n",
      "472 revenue:  4.314279556274414 rgt:  0.09492064267396927 loss:  -1.6740717887878418\n",
      "473 revenue:  4.320425510406494 rgt:  0.09694637358188629 loss:  -1.6702547073364258\n",
      "474 revenue:  4.32295036315918 rgt:  0.0988934189081192 loss:  -1.6658040285110474\n",
      "475 revenue:  4.322741508483887 rgt:  0.10024385154247284 loss:  -1.6622635126113892\n",
      "476 revenue:  4.320210933685303 rgt:  0.10091836005449295 loss:  -1.6599167585372925\n",
      "477 revenue:  4.316473484039307 rgt:  0.10112428665161133 loss:  -1.6584876775741577\n",
      "478 revenue:  4.312516212463379 rgt:  0.10201560705900192 loss:  -1.6552454233169556\n",
      "479 revenue:  4.3089094161987305 rgt:  0.10320248454809189 loss:  -1.6513375043869019\n",
      "480 revenue:  4.30558443069458 rgt:  0.09486406296491623 loss:  -1.6721261739730835\n",
      "481 revenue:  4.311765670776367 rgt:  0.09466999769210815 loss:  -1.6741242408752441\n",
      "482 revenue:  4.318085670471191 rgt:  0.09632029384374619 loss:  -1.6713249683380127\n",
      "483 revenue:  4.3214921951293945 rgt:  0.0977366641163826 loss:  -1.668454647064209\n",
      "484 revenue:  4.322926998138428 rgt:  0.09896893799304962 loss:  -1.665602684020996\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "485 revenue:  4.321746826171875 rgt:  0.09945119172334671 loss:  -1.6640712022781372\n",
      "486 revenue:  4.317135810852051 rgt:  0.09945111721754074 loss:  -1.6629621982574463\n",
      "487 revenue:  4.312469959259033 rgt:  0.09981577843427658 loss:  -1.6608966588974\n",
      "488 revenue:  4.307676315307617 rgt:  0.10077257454395294 loss:  -1.6572747230529785\n",
      "489 revenue:  4.303361892700195 rgt:  0.10180606693029404 loss:  -1.6535779237747192\n",
      "490 revenue:  4.298741340637207 rgt:  0.09254780411720276 loss:  -1.6765761375427246\n",
      "491 revenue:  4.30497407913208 rgt:  0.09398017823696136 loss:  -1.6743011474609375\n",
      "492 revenue:  4.31130838394165 rgt:  0.09456387162208557 loss:  -1.674292802810669\n",
      "493 revenue:  4.317483901977539 rgt:  0.09510916471481323 loss:  -1.6743485927581787\n",
      "494 revenue:  4.323478698730469 rgt:  0.09566142410039902 loss:  -1.6743443012237549\n",
      "495 revenue:  4.32927942276001 rgt:  0.09621720016002655 loss:  -1.674285888671875\n",
      "496 revenue:  4.334709167480469 rgt:  0.09774532169103622 loss:  -1.6716086864471436\n",
      "497 revenue:  4.330910682678223 rgt:  0.09895524382591248 loss:  -1.6675572395324707\n",
      "498 revenue:  4.327939510345459 rgt:  0.09971849620342255 loss:  -1.6648691892623901\n",
      "499 revenue:  4.323881149291992 rgt:  0.10042272508144379 loss:  -1.6620761156082153\n",
      "500 revenue:  4.318850040435791 rgt:  0.09483034908771515 loss:  -1.6754086017608643\n",
      "501 revenue:  4.32374382019043 rgt:  0.09568938612937927 loss:  -1.67433500289917\n",
      "502 revenue:  4.329378604888916 rgt:  0.096208855509758 loss:  -1.674331545829773\n",
      "503 revenue:  4.334717273712158 rgt:  0.09672285616397858 loss:  -1.6742725372314453\n",
      "504 revenue:  4.339348316192627 rgt:  0.09717758744955063 loss:  -1.6741994619369507\n",
      "505 revenue:  4.343499660491943 rgt:  0.09757405519485474 loss:  -1.674164056777954\n",
      "506 revenue:  4.346677303314209 rgt:  0.10141870379447937 loss:  -1.6649868488311768\n",
      "507 revenue:  4.341932773590088 rgt:  0.10154638439416885 loss:  -1.6635205745697021\n",
      "508 revenue:  4.337255477905273 rgt:  0.10282085090875626 loss:  -1.6591299772262573\n",
      "509 revenue:  4.332357883453369 rgt:  0.10317672789096832 loss:  -1.6570435762405396\n",
      "510 revenue:  4.327293872833252 rgt:  0.09672947973012924 loss:  -1.6724717617034912\n",
      "511 revenue:  4.330502033233643 rgt:  0.09616711735725403 loss:  -1.6747105121612549\n",
      "512 revenue:  4.3364152908325195 rgt:  0.09890667349100113 loss:  -1.669005036354065\n",
      "513 revenue:  4.336073875427246 rgt:  0.10000535845756531 loss:  -1.6660826206207275\n",
      "514 revenue:  4.333454608917236 rgt:  0.10055515170097351 loss:  -1.6640355587005615\n",
      "515 revenue:  4.329451084136963 rgt:  0.10072817653417587 loss:  -1.6626280546188354\n",
      "516 revenue:  4.324958324432373 rgt:  0.1012330874800682 loss:  -1.660248875617981\n",
      "517 revenue:  4.320128440856934 rgt:  0.10162125527858734 loss:  -1.6580897569656372\n",
      "518 revenue:  4.315119743347168 rgt:  0.10169410705566406 loss:  -1.6566975116729736\n",
      "519 revenue:  4.310407638549805 rgt:  0.10163598507642746 loss:  -1.6557121276855469\n",
      "520 revenue:  4.306265354156494 rgt:  0.09314870834350586 loss:  -1.6768028736114502\n",
      "521 revenue:  4.312402248382568 rgt:  0.09461997449398041 loss:  -1.6744089126586914\n",
      "522 revenue:  4.318632125854492 rgt:  0.09518759697675705 loss:  -1.6744195222854614\n",
      "523 revenue:  4.32472038269043 rgt:  0.09571214020252228 loss:  -1.6745102405548096\n",
      "524 revenue:  4.330528736114502 rgt:  0.09623093903064728 loss:  -1.6745500564575195\n",
      "525 revenue:  4.336094379425049 rgt:  0.09675117582082748 loss:  -1.6745293140411377\n",
      "526 revenue:  4.341196060180664 rgt:  0.09724118560552597 loss:  -1.674477458000183\n",
      "527 revenue:  4.345539093017578 rgt:  0.0976649820804596 loss:  -1.6744167804718018\n",
      "528 revenue:  4.3489203453063965 rgt:  0.09808117151260376 loss:  -1.6741461753845215\n",
      "529 revenue:  4.3507819175720215 rgt:  0.1030549630522728 loss:  -1.661776065826416\n",
      "530 revenue:  4.346078395843506 rgt:  0.09760356694459915 loss:  -1.6747056245803833\n",
      "531 revenue:  4.346044063568115 rgt:  0.09757707267999649 loss:  -1.6747664213180542\n",
      "532 revenue:  4.350386619567871 rgt:  0.09804223477840424 loss:  -1.6745986938476562\n",
      "533 revenue:  4.354098320007324 rgt:  0.0986412763595581 loss:  -1.6739341020584106\n",
      "534 revenue:  4.354507923126221 rgt:  0.10273276269435883 loss:  -1.6634935140609741\n",
      "535 revenue:  4.34968900680542 rgt:  0.10365959256887436 loss:  -1.6599690914154053\n",
      "536 revenue:  4.344766139984131 rgt:  0.10415782779455185 loss:  -1.657517433166504\n",
      "537 revenue:  4.339643478393555 rgt:  0.10453222692012787 loss:  -1.65533447265625\n",
      "538 revenue:  4.334167957305908 rgt:  0.10462667793035507 loss:  -1.65377938747406\n",
      "539 revenue:  4.328518867492676 rgt:  0.10461410880088806 loss:  -1.6524540185928345\n",
      "540 revenue:  4.322741985321045 rgt:  0.09610988944768906 loss:  -1.672994613647461\n",
      "541 revenue:  4.328367233276367 rgt:  0.09584440290927887 loss:  -1.6750410795211792\n",
      "542 revenue:  4.334686756134033 rgt:  0.09904256463050842 loss:  -1.6682381629943848\n",
      "543 revenue:  4.335004806518555 rgt:  0.09996545314788818 loss:  -1.6659289598464966\n",
      "544 revenue:  4.334118366241455 rgt:  0.10073654353618622 loss:  -1.663727879524231\n",
      "545 revenue:  4.330586910247803 rgt:  0.1009112000465393 loss:  -1.6624298095703125\n",
      "546 revenue:  4.326373100280762 rgt:  0.10133633017539978 loss:  -1.6603235006332397\n",
      "547 revenue:  4.32181978225708 rgt:  0.10176829993724823 loss:  -1.6581189632415771\n",
      "548 revenue:  4.317095756530762 rgt:  0.10216725617647171 loss:  -1.6559587717056274\n",
      "549 revenue:  4.31244421005249 rgt:  0.10251125693321228 loss:  -1.653957486152649\n",
      "550 revenue:  4.308167934417725 rgt:  0.09494197368621826 loss:  -1.672544240951538\n",
      "551 revenue:  4.313638210296631 rgt:  0.09452024102210999 loss:  -1.6749683618545532\n",
      "552 revenue:  4.319941520690918 rgt:  0.09518422931432724 loss:  -1.6747432947158813\n",
      "553 revenue:  4.325780868530273 rgt:  0.096605084836483 loss:  -1.672432541847229\n",
      "554 revenue:  4.329741954803467 rgt:  0.09802068769931793 loss:  -1.6696999073028564\n",
      "555 revenue:  4.329813003540039 rgt:  0.0992329865694046 loss:  -1.6665745973587036\n",
      "556 revenue:  4.327989101409912 rgt:  0.09986422955989838 loss:  -1.6645046472549438\n",
      "557 revenue:  4.323285102844238 rgt:  0.10012307018041611 loss:  -1.6627057790756226\n",
      "558 revenue:  4.318196773529053 rgt:  0.10041151940822601 loss:  -1.6607379913330078\n",
      "559 revenue:  4.313172340393066 rgt:  0.1009947657585144 loss:  -1.6580262184143066\n",
      "560 revenue:  4.308406829833984 rgt:  0.09458017349243164 loss:  -1.6735512018203735\n",
      "561 revenue:  4.314249038696289 rgt:  0.09458161145448685 loss:  -1.6749542951583862\n",
      "562 revenue:  4.3204264640808105 rgt:  0.09515277296304703 loss:  -1.6749422550201416\n",
      "563 revenue:  4.326369285583496 rgt:  0.09570618718862534 loss:  -1.6749221086502075\n",
      "564 revenue:  4.332085132598877 rgt:  0.0980294793844223 loss:  -1.670240044593811\n",
      "565 revenue:  4.332637310028076 rgt:  0.098898746073246 loss:  -1.6681183576583862\n",
      "566 revenue:  4.331777572631836 rgt:  0.09986013919115067 loss:  -1.6654256582260132\n",
      "567 revenue:  4.328134059906006 rgt:  0.10033273696899414 loss:  -1.6633307933807373\n",
      "568 revenue:  4.323519229888916 rgt:  0.10073980689048767 loss:  -1.6611721515655518\n",
      "569 revenue:  4.318344593048096 rgt:  0.101222462952137 loss:  -1.6586854457855225\n",
      "570 revenue:  4.313118934631348 rgt:  0.09432174265384674 loss:  -1.6753647327423096\n",
      "571 revenue:  4.3189215660095215 rgt:  0.09505803138017654 loss:  -1.6748286485671997\n",
      "572 revenue:  4.324876308441162 rgt:  0.09559159725904465 loss:  -1.6748632192611694\n",
      "573 revenue:  4.330482482910156 rgt:  0.09609391540288925 loss:  -1.6748969554901123\n",
      "574 revenue:  4.335724830627441 rgt:  0.09720571339130402 loss:  -1.673256278038025\n",
      "575 revenue:  4.336907863616943 rgt:  0.09978683292865753 loss:  -1.6668468713760376\n",
      "576 revenue:  4.33436393737793 rgt:  0.10078919678926468 loss:  -1.6636511087417603\n",
      "577 revenue:  4.330648422241211 rgt:  0.10129275918006897 loss:  -1.6614631414413452\n",
      "578 revenue:  4.326446056365967 rgt:  0.10134581476449966 loss:  -1.6603167057037354\n",
      "579 revenue:  4.3221635818481445 rgt:  0.10140159726142883 loss:  -1.6591436862945557\n",
      "580 revenue:  4.318287372589111 rgt:  0.09522124379873276 loss:  -1.674248218536377\n",
      "581 revenue:  4.324531078338623 rgt:  0.09622083604335785 loss:  -1.6731350421905518\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "582 revenue:  4.330682754516602 rgt:  0.09698006510734558 loss:  -1.6726328134536743\n",
      "583 revenue:  4.333600044250488 rgt:  0.09777621924877167 loss:  -1.6712620258331299\n",
      "584 revenue:  4.333295822143555 rgt:  0.0990341454744339 loss:  -1.6679258346557617\n",
      "585 revenue:  4.3322672843933105 rgt:  0.09971337765455246 loss:  -1.6659224033355713\n",
      "586 revenue:  4.327556133270264 rgt:  0.09979889541864395 loss:  -1.66456937789917\n",
      "587 revenue:  4.322415351867676 rgt:  0.09974732995033264 loss:  -1.6634666919708252\n",
      "588 revenue:  4.3171281814575195 rgt:  0.10000688582658768 loss:  -1.6615244150161743\n",
      "589 revenue:  4.3120293617248535 rgt:  0.10074569284915924 loss:  -1.658392310142517\n",
      "590 revenue:  4.307254791259766 rgt:  0.09430090337991714 loss:  -1.6740072965621948\n",
      "591 revenue:  4.312904357910156 rgt:  0.09439723193645477 loss:  -1.6751148700714111\n",
      "592 revenue:  4.319019317626953 rgt:  0.09495550394058228 loss:  -1.6751210689544678\n",
      "593 revenue:  4.324955940246582 rgt:  0.09564699232578278 loss:  -1.6747373342514038\n",
      "594 revenue:  4.3303399085998535 rgt:  0.10153909027576447 loss:  -1.6607557535171509\n",
      "595 revenue:  4.325830936431885 rgt:  0.10199237614870071 loss:  -1.658508539199829\n",
      "596 revenue:  4.3218865394592285 rgt:  0.10246064513921738 loss:  -1.656359314918518\n",
      "597 revenue:  4.317690849304199 rgt:  0.10269710421562195 loss:  -1.6547443866729736\n",
      "598 revenue:  4.312788009643555 rgt:  0.10287047922611237 loss:  -1.653120517730713\n",
      "599 revenue:  4.307661056518555 rgt:  0.10324008762836456 loss:  -1.6509404182434082\n"
     ]
    }
   ],
   "source": [
    "training_set = train_set_prob_2\n",
    "for i in range(len(learning_rates)):\n",
    "    opt_aucter = torch.optim.AdamW(list(ANet.parameters()) + list(PNet.parameters()),learning_rates[i])\n",
    "    \n",
    "    if (i % 10 == 0):\n",
    "        MNet = MisreportNetBNIC(n,m,nLayersMisreport,widthMisreport)\n",
    "        MNet.to(device)\n",
    "    \n",
    "    misreports = find_max_regret_misreport_BNIC(ANet,PNet,MNet,training_set,100, 100,0.0001)\n",
    "    \n",
    "    opt_aucter.zero_grad()\n",
    "\n",
    "    u_orig = truthful_utility_calculation(ANet,PNet,training_set)\n",
    "    u_new = misreport_utility_calculation_BNIC(ANet,PNet, training_set, misreports)\n",
    "        \n",
    "    rgt = torch.mean(u_new - u_orig)\n",
    "    rev = torch.mean(truthful_revenue_calculation(ANet,PNet,training_set))\n",
    "\n",
    "    #update NN\n",
    "    loss =  -1 * (torch.sqrt(rev + 1e-20) -  torch.sqrt(rgt + 1e-20)) + 1*rgt\n",
    "    \n",
    "    loss.backward()\n",
    "    opt_aucter.step()\n",
    "\n",
    "    print(i, 'revenue: ',rev.item(), 'rgt: ', rgt.item(), 'loss: ', loss.item())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3a15334b",
   "metadata": {},
   "source": [
    "# Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "4a9b0f61",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MisreportNetBNIC(\n",
       "  (mlp): MLP(\n",
       "    (model): Sequential(\n",
       "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
       "      (tanh1): Tanh()\n",
       "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh2): Tanh()\n",
       "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh3): Tanh()\n",
       "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh4): Tanh()\n",
       "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh5): Tanh()\n",
       "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh6): Tanh()\n",
       "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh7): Tanh()\n",
       "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh8): Tanh()\n",
       "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh9): Tanh()\n",
       "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh10): Tanh()\n",
       "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh11): Tanh()\n",
       "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh12): Tanh()\n",
       "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh13): Tanh()\n",
       "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh14): Tanh()\n",
       "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh15): Tanh()\n",
       "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh16): Tanh()\n",
       "      (fc17): Linear(in_features=120, out_features=30, bias=True)\n",
       "    )\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MNet = MisreportNetBNIC(n,m,nLayersMisreport,widthMisreport)\n",
    "MNet.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3ac6dc74",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.285429000854492 0.09488335251808167 3.104983579166822\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_2) # roughly 4.1825\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ab260607",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.392241954803467 0.08647780865430832 4.112982939636687\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_1)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "f2498e0b",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.090536594390869 0.14576663076877594 3.5134795334610254\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_2)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "474ce991",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.122079372406006 0.1602196991443634 3.470495532487217\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_3)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "4d54ed88",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.067140579223633 0.13048623502254486 3.57135242594284\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_4)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "97cfeb40",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.6512253284454346 0.1163390502333641 2.4640612725845408\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_5)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "999a75d4",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.5173230171203613 0.08736362308263779 2.496018822815681\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_6)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "2cf48da8",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.675665855407715 0.1308991014957428 2.4192778808136515\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_b_7)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c424cd3b",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
