{
 "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_1 = get_train_or_test_set(batch_size,n,m,prob_single_1)\n",
    "test_set_prob_1 = get_train_or_test_set(batch_size,n,m,prob_single_1)\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": "6a534fd4",
   "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.49707406759262085 rgt:  0.14291121065616608 loss:  -0.1840875893831253\n",
      "1 revenue:  0.5058401226997375 rgt:  0.1608307659626007 loss:  -0.14935648441314697\n",
      "2 revenue:  0.49364519119262695 rgt:  0.1617286056280136 loss:  -0.13871531188488007\n",
      "3 revenue:  0.4790712893009186 rgt:  0.15855498611927032 loss:  -0.13540513813495636\n",
      "4 revenue:  0.465899795293808 rgt:  0.15452119708061218 loss:  -0.134955495595932\n",
      "5 revenue:  0.4540979862213135 rgt:  0.15002597868442535 loss:  -0.13651008903980255\n",
      "6 revenue:  0.4428885579109192 rgt:  0.14435814321041107 loss:  -0.14119566977024078\n",
      "7 revenue:  0.4329712390899658 rgt:  0.13625967502593994 loss:  -0.1526121199131012\n",
      "8 revenue:  0.4255305528640747 rgt:  0.12284387648105621 loss:  -0.17899222671985626\n",
      "9 revenue:  0.422292023897171 rgt:  0.098277248442173 loss:  -0.23807072639465332\n",
      "10 revenue:  0.4227469563484192 rgt:  0.05894548073410988 loss:  -0.34845757484436035\n",
      "11 revenue:  0.5276615619659424 rgt:  0.06063554808497429 loss:  -0.41952475905418396\n",
      "12 revenue:  0.6397894024848938 rgt:  0.054223064333200455 loss:  -0.5127868056297302\n",
      "13 revenue:  0.7465537786483765 rgt:  0.041234418749809265 loss:  -0.6197364330291748\n",
      "14 revenue:  0.8575156331062317 rgt:  0.031922709196805954 loss:  -0.715429425239563\n",
      "15 revenue:  0.9802157878875732 rgt:  0.03726845234632492 loss:  -0.7597396373748779\n",
      "16 revenue:  0.8890442848205566 rgt:  0.014349278062582016 loss:  -0.8087537288665771\n",
      "17 revenue:  1.2079905271530151 rgt:  0.04992847144603729 loss:  -0.8257108926773071\n",
      "18 revenue:  1.0575517416000366 rgt:  0.012712261639535427 loss:  -0.902912437915802\n",
      "19 revenue:  1.4017318487167358 rgt:  0.06003473699092865 loss:  -0.8788929581642151\n",
      "20 revenue:  1.207253336906433 rgt:  0.012342081405222416 loss:  -0.9753137826919556\n",
      "21 revenue:  1.5752824544906616 rgt:  0.06998629868030548 loss:  -0.920566976070404\n",
      "22 revenue:  1.3448905944824219 rgt:  0.010400132276117802 loss:  -1.0473129749298096\n",
      "23 revenue:  1.7661710977554321 rgt:  0.08877117931842804 loss:  -0.9422575831413269\n",
      "24 revenue:  1.5054229497909546 rgt:  0.010222872719168663 loss:  -1.1156256198883057\n",
      "25 revenue:  2.0236945152282715 rgt:  0.1146191880106926 loss:  -0.9693923592567444\n",
      "26 revenue:  1.7503479719161987 rgt:  0.023482946678996086 loss:  -1.1462827920913696\n",
      "27 revenue:  1.9878487586975098 rgt:  0.049436599016189575 loss:  -1.1381309032440186\n",
      "28 revenue:  2.4564595222473145 rgt:  0.1120862141251564 loss:  -1.120430588722229\n",
      "29 revenue:  1.876906156539917 rgt:  0.030868053436279297 loss:  -1.1634411811828613\n",
      "30 revenue:  2.9427037239074707 rgt:  0.1442926824092865 loss:  -1.191279649734497\n",
      "31 revenue:  2.206965684890747 rgt:  0.05074748024344444 loss:  -1.209566354751587\n",
      "32 revenue:  3.2771925926208496 rgt:  0.17880062758922577 loss:  -1.2086529731750488\n",
      "33 revenue:  2.427337408065796 rgt:  0.06529151648283005 loss:  -1.2371779680252075\n",
      "34 revenue:  3.346320152282715 rgt:  0.18183256685733795 loss:  -1.2210441827774048\n",
      "35 revenue:  2.4966721534729004 rgt:  0.06714370101690292 loss:  -1.2538213729858398\n",
      "36 revenue:  3.5338428020477295 rgt:  0.23906049132347107 loss:  -1.1518532037734985\n",
      "37 revenue:  2.6029722690582275 rgt:  0.08257418870925903 loss:  -1.2434415817260742\n",
      "38 revenue:  3.526602268218994 rgt:  0.24228042364120483 loss:  -1.1434247493743896\n",
      "39 revenue:  2.6228721141815186 rgt:  0.08605612814426422 loss:  -1.2401190996170044\n",
      "40 revenue:  3.537325382232666 rgt:  0.1941525787115097 loss:  -1.2459977865219116\n",
      "41 revenue:  2.668248176574707 rgt:  0.07594861835241318 loss:  -1.2819409370422363\n",
      "42 revenue:  3.67539119720459 rgt:  0.20893484354019165 loss:  -1.2511022090911865\n",
      "43 revenue:  2.7801320552825928 rgt:  0.08521393686532974 loss:  -1.290244698524475\n",
      "44 revenue:  3.7589304447174072 rgt:  0.21656936407089233 loss:  -1.2568566799163818\n",
      "45 revenue:  2.850452184677124 rgt:  0.09040745347738266 loss:  -1.297242522239685\n",
      "46 revenue:  3.814589023590088 rgt:  0.2683476209640503 loss:  -1.1667269468307495\n",
      "47 revenue:  2.8892855644226074 rgt:  0.10294017940759659 loss:  -1.276006817817688\n",
      "48 revenue:  3.813430070877075 rgt:  0.2761017680168152 loss:  -1.151244878768921\n",
      "49 revenue:  2.891303539276123 rgt:  0.10706627368927002 loss:  -1.266107201576233\n",
      "50 revenue:  3.8062431812286377 rgt:  0.21394328773021698 loss:  -1.2744762897491455\n",
      "51 revenue:  2.9198901653289795 rgt:  0.0937495231628418 loss:  -1.3088335990905762\n",
      "52 revenue:  3.860816240310669 rgt:  0.218926802277565 loss:  -1.2780730724334717\n",
      "53 revenue:  2.972494125366211 rgt:  0.09696908295154572 loss:  -1.315724492073059\n",
      "54 revenue:  3.901594877243042 rgt:  0.22197206318378448 loss:  -1.2821342945098877\n",
      "55 revenue:  3.017744779586792 rgt:  0.09882253408432007 loss:  -1.3239827156066895\n",
      "56 revenue:  3.9379963874816895 rgt:  0.2240082025527954 loss:  -1.2871352434158325\n",
      "57 revenue:  3.0632474422454834 rgt:  0.1020461767911911 loss:  -1.3287206888198853\n",
      "58 revenue:  3.965524435043335 rgt:  0.22561238706111908 loss:  -1.2907633781433105\n",
      "59 revenue:  3.099378824234009 rgt:  0.10517000406980515 loss:  -1.33103609085083\n",
      "60 revenue:  3.9834835529327393 rgt:  0.22448104619979858 loss:  -1.297591209411621\n",
      "61 revenue:  3.124845266342163 rgt:  0.10480548441410065 loss:  -1.3391809463500977\n",
      "62 revenue:  4.000211715698242 rgt:  0.22579701244831085 loss:  -1.2990747690200806\n",
      "63 revenue:  3.154759168624878 rgt:  0.10818616300821304 loss:  -1.3390613794326782\n",
      "64 revenue:  4.015726566314697 rgt:  0.2273133546113968 loss:  -1.2998403310775757\n",
      "65 revenue:  3.1799697875976562 rgt:  0.10970540344715118 loss:  -1.3423235416412354\n",
      "66 revenue:  4.028013229370117 rgt:  0.2627767324447632 loss:  -1.231596827507019\n",
      "67 revenue:  3.1975595951080322 rgt:  0.11788543313741684 loss:  -1.3269422054290771\n",
      "68 revenue:  4.035874843597412 rgt:  0.3004888594150543 loss:  -1.160291314125061\n",
      "69 revenue:  3.2080376148223877 rgt:  0.1335105150938034 loss:  -1.2921981811523438\n",
      "70 revenue:  4.021070957183838 rgt:  0.21725761890411377 loss:  -1.3218940496444702\n",
      "71 revenue:  3.115121841430664 rgt:  0.10381706058979034 loss:  -1.3389471769332886\n",
      "72 revenue:  4.029881000518799 rgt:  0.21621257066726685 loss:  -1.3262572288513184\n",
      "73 revenue:  3.149466037750244 rgt:  0.10561494529247284 loss:  -1.344074010848999\n",
      "74 revenue:  4.042356967926025 rgt:  0.21822360157966614 loss:  -1.3251937627792358\n",
      "75 revenue:  3.170116424560547 rgt:  0.10514980554580688 loss:  -1.3510642051696777\n",
      "76 revenue:  4.050082683563232 rgt:  0.2184983789920807 loss:  -1.326545238494873\n",
      "77 revenue:  3.1894419193267822 rgt:  0.10563673824071884 loss:  -1.3552460670471191\n",
      "78 revenue:  4.05435848236084 rgt:  0.21859915554523468 loss:  -1.3273987770080566\n",
      "79 revenue:  3.205073833465576 rgt:  0.10590452700853348 loss:  -1.3589376211166382\n",
      "80 revenue:  4.055208683013916 rgt:  0.21734778583049774 loss:  -1.3302013874053955\n",
      "81 revenue:  3.220838785171509 rgt:  0.10577458143234253 loss:  -1.3636648654937744\n",
      "82 revenue:  4.063077926635742 rgt:  0.21879053115844727 loss:  -1.3291666507720947\n",
      "83 revenue:  3.2465639114379883 rgt:  0.10737294703722 loss:  -1.3667713403701782\n",
      "84 revenue:  4.067015647888184 rgt:  0.21899212896823883 loss:  -1.329726219177246\n",
      "85 revenue:  3.264174461364746 rgt:  0.10912493616342545 loss:  -1.3672370910644531\n",
      "86 revenue:  4.071644306182861 rgt:  0.21961474418640137 loss:  -1.329586148262024\n",
      "87 revenue:  3.2792437076568604 rgt:  0.10985933244228363 loss:  -1.369558572769165\n",
      "88 revenue:  4.072638034820557 rgt:  0.21759150922298431 loss:  -1.3340193033218384\n",
      "89 revenue:  3.2808475494384766 rgt:  0.10783553868532181 loss:  -1.3750922679901123\n",
      "90 revenue:  4.072396755218506 rgt:  0.21103554964065552 loss:  -1.3475964069366455\n",
      "91 revenue:  3.296928882598877 rgt:  0.11540449410676956 loss:  -1.3606278896331787\n",
      "92 revenue:  4.080061435699463 rgt:  0.2115444391965866 loss:  -1.3484323024749756\n",
      "93 revenue:  3.328430414199829 rgt:  0.11415602266788483 loss:  -1.3723728656768799\n",
      "94 revenue:  4.087248802185059 rgt:  0.210103839635849 loss:  -1.3532196283340454\n",
      "95 revenue:  3.3431553840637207 rgt:  0.11190985143184662 loss:  -1.381990671157837\n",
      "96 revenue:  4.093342304229736 rgt:  0.2133924514055252 loss:  -1.3478642702102661\n",
      "97 revenue:  3.353524923324585 rgt:  0.11059428751468658 loss:  -1.3881117105484009\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "98 revenue:  4.091233253479004 rgt:  0.21347609162330627 loss:  -1.347169041633606\n",
      "99 revenue:  3.3539421558380127 rgt:  0.11240503937005997 loss:  -1.3837034702301025\n",
      "100 revenue:  4.091870307922363 rgt:  0.21299463510513306 loss:  -1.3483290672302246\n",
      "101 revenue:  3.3631908893585205 rgt:  0.11612680554389954 loss:  -1.376999855041504\n",
      "102 revenue:  4.091201305389404 rgt:  0.21493802964687347 loss:  -1.3441197872161865\n",
      "103 revenue:  3.3740320205688477 rgt:  0.1159747913479805 loss:  -1.3803282976150513\n",
      "104 revenue:  4.089057922363281 rgt:  0.21184539794921875 loss:  -1.3500299453735352\n",
      "105 revenue:  3.3735945224761963 rgt:  0.11308731138706207 loss:  -1.3873628377914429\n",
      "106 revenue:  4.089687347412109 rgt:  0.20979082584381104 loss:  -1.3544775247573853\n",
      "107 revenue:  3.364464044570923 rgt:  0.11156399548053741 loss:  -1.3886715173721313\n",
      "108 revenue:  4.0865254402160645 rgt:  0.20862556993961334 loss:  -1.3561345338821411\n",
      "109 revenue:  3.3790717124938965 rgt:  0.11252395808696747 loss:  -1.390255331993103\n",
      "110 revenue:  4.0950469970703125 rgt:  0.2080765813589096 loss:  -1.3593915700912476\n",
      "111 revenue:  3.4020557403564453 rgt:  0.12152008712291718 loss:  -1.3743488788604736\n",
      "112 revenue:  4.099844932556152 rgt:  0.20788754522800446 loss:  -1.3609730005264282\n",
      "113 revenue:  3.398719072341919 rgt:  0.11448036134243011 loss:  -1.390731692314148\n",
      "114 revenue:  4.093564033508301 rgt:  0.20554639399051666 loss:  -1.3643372058868408\n",
      "115 revenue:  3.444467782974243 rgt:  0.11526979506015778 loss:  -1.4011439085006714\n",
      "116 revenue:  4.107999324798584 rgt:  0.20962871611118317 loss:  -1.3593389987945557\n",
      "117 revenue:  3.4279613494873047 rgt:  0.11232908815145493 loss:  -1.4039911031723022\n",
      "118 revenue:  4.095962047576904 rgt:  0.2519380748271942 loss:  -1.2699759006500244\n",
      "119 revenue:  3.418632745742798 rgt:  0.13164851069450378 loss:  -1.354472041130066\n",
      "120 revenue:  3.1691484451293945 rgt:  0.09899801015853882 loss:  -1.3665728569030762\n",
      "121 revenue:  3.977963924407959 rgt:  0.1833769530057907 loss:  -1.3828810453414917\n",
      "122 revenue:  3.1838595867156982 rgt:  0.0995398759841919 loss:  -1.369297981262207\n",
      "123 revenue:  3.981262445449829 rgt:  0.181886225938797 loss:  -1.3869426250457764\n",
      "124 revenue:  3.2421560287475586 rgt:  0.10315437614917755 loss:  -1.3762677907943726\n",
      "125 revenue:  3.958784341812134 rgt:  0.17739923298358917 loss:  -1.3910822868347168\n",
      "126 revenue:  3.260685443878174 rgt:  0.10259508341550827 loss:  -1.3828370571136475\n",
      "127 revenue:  3.9933550357818604 rgt:  0.17942959070205688 loss:  -1.3953173160552979\n",
      "128 revenue:  3.2785494327545166 rgt:  0.10343940556049347 loss:  -1.3856170177459717\n",
      "129 revenue:  4.0069990158081055 rgt:  0.18170012533664703 loss:  -1.3937859535217285\n",
      "130 revenue:  3.2885537147521973 rgt:  0.10598832368850708 loss:  -1.3818902969360352\n",
      "131 revenue:  4.007009506225586 rgt:  0.18480293452739716 loss:  -1.3870617151260376\n",
      "132 revenue:  3.332240104675293 rgt:  0.10606516152620316 loss:  -1.3937008380889893\n",
      "133 revenue:  4.025446891784668 rgt:  0.18685556948184967 loss:  -1.38722825050354\n",
      "134 revenue:  3.33152174949646 rgt:  0.10403301566839218 loss:  -1.3986711502075195\n",
      "135 revenue:  4.014549255371094 rgt:  0.18542902171611786 loss:  -1.3875902891159058\n",
      "136 revenue:  3.322932004928589 rgt:  0.10628766566514969 loss:  -1.3905855417251587\n",
      "137 revenue:  4.034820079803467 rgt:  0.19991862773895264 loss:  -1.3616448640823364\n",
      "138 revenue:  3.3337666988372803 rgt:  0.105610691010952 loss:  -1.3952717781066895\n",
      "139 revenue:  4.048409461975098 rgt:  0.19631487131118774 loss:  -1.3726766109466553\n",
      "140 revenue:  3.3441011905670166 rgt:  0.10688234120607376 loss:  -1.3948774337768555\n",
      "141 revenue:  4.059782028198242 rgt:  0.18811620771884918 loss:  -1.3930503129959106\n",
      "142 revenue:  3.3567867279052734 rgt:  0.11146452277898788 loss:  -1.3868260383605957\n",
      "143 revenue:  4.058022499084473 rgt:  0.2044709324836731 loss:  -1.3577978610992432\n",
      "144 revenue:  3.3385233879089355 rgt:  0.11333250254392624 loss:  -1.3771811723709106\n",
      "145 revenue:  4.032641887664795 rgt:  0.2451399266719818 loss:  -1.267887830734253\n",
      "146 revenue:  3.286597490310669 rgt:  0.12523455917835236 loss:  -1.3337780237197876\n",
      "147 revenue:  4.022763729095459 rgt:  0.25238773226737976 loss:  -1.250913143157959\n",
      "148 revenue:  3.2742867469787598 rgt:  0.12774616479873657 loss:  -1.3243370056152344\n",
      "149 revenue:  4.0149760246276855 rgt:  0.25606483221054077 loss:  -1.2416472434997559\n",
      "150 revenue:  3.2890865802764893 rgt:  0.10244763642549515 loss:  -1.391061782836914\n",
      "151 revenue:  4.02042293548584 rgt:  0.19476567208766937 loss:  -1.3690110445022583\n",
      "152 revenue:  3.3724827766418457 rgt:  0.11612129211425781 loss:  -1.3795450925827026\n",
      "153 revenue:  4.041628837585449 rgt:  0.2007041722536087 loss:  -1.3616758584976196\n",
      "154 revenue:  3.4039881229400635 rgt:  0.11786381155252457 loss:  -1.3838132619857788\n",
      "155 revenue:  4.053475856781006 rgt:  0.20417673885822296 loss:  -1.3572884798049927\n",
      "156 revenue:  3.404599189758301 rgt:  0.12201029062271118 loss:  -1.3738455772399902\n",
      "157 revenue:  4.038647651672363 rgt:  0.19741219282150269 loss:  -1.3679156303405762\n",
      "158 revenue:  3.3496253490448 rgt:  0.11832477152347565 loss:  -1.3678897619247437\n",
      "159 revenue:  4.034402847290039 rgt:  0.19848839938640594 loss:  -1.36457359790802\n",
      "160 revenue:  3.3232734203338623 rgt:  0.10891237109899521 loss:  -1.3840537071228027\n",
      "161 revenue:  4.032898902893066 rgt:  0.18441817164421082 loss:  -1.394350290298462\n",
      "162 revenue:  3.351867198944092 rgt:  0.1116708368062973 loss:  -1.3849678039550781\n",
      "163 revenue:  4.050417423248291 rgt:  0.18364082276821136 loss:  -1.4003907442092896\n",
      "164 revenue:  3.3788537979125977 rgt:  0.11803024262189865 loss:  -1.3765803575515747\n",
      "165 revenue:  4.054076671600342 rgt:  0.19193339347839355 loss:  -1.3834383487701416\n",
      "166 revenue:  3.3983116149902344 rgt:  0.11923133581876755 loss:  -1.3789207935333252\n",
      "167 revenue:  4.055893421173096 rgt:  0.19312036037445068 loss:  -1.3813499212265015\n",
      "168 revenue:  3.4017179012298584 rgt:  0.11676641553640366 loss:  -1.385897159576416\n",
      "169 revenue:  4.048213005065918 rgt:  0.19439980387687683 loss:  -1.3767094612121582\n",
      "170 revenue:  3.4241843223571777 rgt:  0.11501632630825043 loss:  -1.3962982892990112\n",
      "171 revenue:  4.048176288604736 rgt:  0.1847938448190689 loss:  -1.397337555885315\n",
      "172 revenue:  3.3917272090911865 rgt:  0.10982898622751236 loss:  -1.400430679321289\n",
      "173 revenue:  4.043038845062256 rgt:  0.18395501375198364 loss:  -1.397876262664795\n",
      "174 revenue:  3.414976119995117 rgt:  0.10991399735212326 loss:  -1.406518578529358\n",
      "175 revenue:  4.052562236785889 rgt:  0.18318381905555725 loss:  -1.4019142389297485\n",
      "176 revenue:  3.416292190551758 rgt:  0.11270123720169067 loss:  -1.3999102115631104\n",
      "177 revenue:  4.053405284881592 rgt:  0.18610146641731262 loss:  -1.395810842514038\n",
      "178 revenue:  3.430300235748291 rgt:  0.11585328727960587 loss:  -1.3958814144134521\n",
      "179 revenue:  4.03320837020874 rgt:  0.1806713193655014 loss:  -1.4025591611862183\n",
      "180 revenue:  3.3831472396850586 rgt:  0.11197208613157272 loss:  -1.3927390575408936\n",
      "181 revenue:  4.021953582763672 rgt:  0.17898645997047424 loss:  -1.4034266471862793\n",
      "182 revenue:  3.4307713508605957 rgt:  0.11498194932937622 loss:  -1.3981623649597168\n",
      "183 revenue:  4.0478315353393555 rgt:  0.18864913284778595 loss:  -1.3889355659484863\n",
      "184 revenue:  3.412241220474243 rgt:  0.12061481922864914 loss:  -1.3793140649795532\n",
      "185 revenue:  3.96108078956604 rgt:  0.21574655175209045 loss:  -1.3100146055221558\n",
      "186 revenue:  3.2151272296905518 rgt:  0.12084194272756577 loss:  -1.3246123790740967\n",
      "187 revenue:  3.955869436264038 rgt:  0.22268974781036377 loss:  -1.2943469285964966\n",
      "188 revenue:  3.264540195465088 rgt:  0.12878458201885223 loss:  -1.3191536664962769\n",
      "189 revenue:  3.9717581272125244 rgt:  0.23080158233642578 loss:  -1.2817072868347168\n",
      "190 revenue:  3.3592984676361084 rgt:  0.10793983191251755 loss:  -1.3963570594787598\n",
      "191 revenue:  4.019629001617432 rgt:  0.1799786537885666 loss:  -1.4006836414337158\n",
      "192 revenue:  3.3647327423095703 rgt:  0.11583538353443146 loss:  -1.3781393766403198\n",
      "193 revenue:  4.01321268081665 rgt:  0.17854614555835724 loss:  -1.4022070169448853\n",
      "194 revenue:  3.36977481842041 rgt:  0.1047973558306694 loss:  -1.4071731567382812\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "195 revenue:  3.9999101161956787 rgt:  0.17826324701309204 loss:  -1.3995018005371094\n",
      "196 revenue:  3.3887288570404053 rgt:  0.1133255809545517 loss:  -1.3908857107162476\n",
      "197 revenue:  4.009123802185059 rgt:  0.1853301227092743 loss:  -1.3864498138427734\n",
      "198 revenue:  3.4094045162200928 rgt:  0.1182899922132492 loss:  -1.3842341899871826\n",
      "199 revenue:  3.9894232749938965 rgt:  0.18437926471233368 loss:  -1.3835808038711548\n",
      "200 revenue:  3.4120378494262695 rgt:  0.10723429173231125 loss:  -1.412469506263733\n",
      "201 revenue:  3.496370553970337 rgt:  0.11308977752923965 loss:  -1.4204803705215454\n",
      "202 revenue:  3.566354513168335 rgt:  0.11767244338989258 loss:  -1.427772879600525\n",
      "203 revenue:  3.643550395965576 rgt:  0.13384465873241425 loss:  -1.4091161489486694\n",
      "204 revenue:  3.6891419887542725 rgt:  0.1710439771413803 loss:  -1.3360952138900757\n",
      "205 revenue:  3.6251866817474365 rgt:  0.16763877868652344 loss:  -1.3269163370132446\n",
      "206 revenue:  3.67868971824646 rgt:  0.1767875999212265 loss:  -1.3207422494888306\n",
      "207 revenue:  3.6270437240600586 rgt:  0.17096295952796936 loss:  -1.320040225982666\n",
      "208 revenue:  3.5557754039764404 rgt:  0.16223694384098053 loss:  -1.320652961730957\n",
      "209 revenue:  3.629040479660034 rgt:  0.17104290425777435 loss:  -1.320387840270996\n",
      "210 revenue:  3.5479986667633057 rgt:  0.11470106244087219 loss:  -1.43023681640625\n",
      "211 revenue:  3.620529890060425 rgt:  0.12108777463436127 loss:  -1.4337044954299927\n",
      "212 revenue:  3.682553768157959 rgt:  0.12670810520648956 loss:  -1.4363291263580322\n",
      "213 revenue:  3.7439913749694824 rgt:  0.132709801197052 loss:  -1.4379363059997559\n",
      "214 revenue:  3.8013787269592285 rgt:  0.14292532205581665 loss:  -1.4287326335906982\n",
      "215 revenue:  3.7636897563934326 rgt:  0.13857071101665497 loss:  -1.429201602935791\n",
      "216 revenue:  3.7160983085632324 rgt:  0.1330064982175827 loss:  -1.4300113916397095\n",
      "217 revenue:  3.766239643096924 rgt:  0.1384119689464569 loss:  -1.4302306175231934\n",
      "218 revenue:  3.7211546897888184 rgt:  0.1334657222032547 loss:  -1.4302340745925903\n",
      "219 revenue:  3.7698605060577393 rgt:  0.13875533640384674 loss:  -1.4303587675094604\n",
      "220 revenue:  3.7152671813964844 rgt:  0.12938593327999115 loss:  -1.4384143352508545\n",
      "221 revenue:  3.7725162506103516 rgt:  0.13800030946731567 loss:  -1.4328124523162842\n",
      "222 revenue:  3.7158873081207275 rgt:  0.13283245265483856 loss:  -1.4303693771362305\n",
      "223 revenue:  3.7816197872161865 rgt:  0.1404375284910202 loss:  -1.4294513463974\n",
      "224 revenue:  3.730755090713501 rgt:  0.1347408890724182 loss:  -1.4297046661376953\n",
      "225 revenue:  3.7118828296661377 rgt:  0.13270600140094757 loss:  -1.4296303987503052\n",
      "226 revenue:  3.7723655700683594 rgt:  0.13914930820465088 loss:  -1.4300813674926758\n",
      "227 revenue:  3.71144437789917 rgt:  0.13217931985855103 loss:  -1.4307668209075928\n",
      "228 revenue:  3.773683547973633 rgt:  0.13853593170642853 loss:  -1.4318569898605347\n",
      "229 revenue:  3.707458019256592 rgt:  0.13159452378749847 loss:  -1.4311219453811646\n",
      "230 revenue:  3.7685675621032715 rgt:  0.13468235731124878 loss:  -1.4396066665649414\n",
      "231 revenue:  3.705904245376587 rgt:  0.12999141216278076 loss:  -1.4345378875732422\n",
      "232 revenue:  3.77005934715271 rgt:  0.13642866909503937 loss:  -1.4358729124069214\n",
      "233 revenue:  3.7885518074035645 rgt:  0.13872487843036652 loss:  -1.4352375268936157\n",
      "234 revenue:  3.7278881072998047 rgt:  0.13246449828147888 loss:  -1.4343527555465698\n",
      "235 revenue:  3.7804484367370605 rgt:  0.13772575557231903 loss:  -1.4354976415634155\n",
      "236 revenue:  3.7559072971343994 rgt:  0.1348375827074051 loss:  -1.435976266860962\n",
      "237 revenue:  3.8109099864959717 rgt:  0.14202392101287842 loss:  -1.4332706928253174\n",
      "238 revenue:  3.7561776638031006 rgt:  0.13505761325359344 loss:  -1.4355266094207764\n",
      "239 revenue:  3.794602155685425 rgt:  0.1394709348678589 loss:  -1.4350448846817017\n",
      "240 revenue:  3.7324109077453613 rgt:  0.1292176991701126 loss:  -1.4432584047317505\n",
      "241 revenue:  3.7930068969726562 rgt:  0.1364937424659729 loss:  -1.441620111465454\n",
      "242 revenue:  3.732524871826172 rgt:  0.13021282851696014 loss:  -1.4409112930297852\n",
      "243 revenue:  3.7953100204467773 rgt:  0.14949218928813934 loss:  -1.4120211601257324\n",
      "244 revenue:  3.7433888912200928 rgt:  0.17568443715572357 loss:  -1.3399522304534912\n",
      "245 revenue:  3.7647414207458496 rgt:  0.1833391934633255 loss:  -1.3287736177444458\n",
      "246 revenue:  3.6952531337738037 rgt:  0.1752060502767563 loss:  -1.3285218477249146\n",
      "247 revenue:  3.7571659088134766 rgt:  0.1829422563314438 loss:  -1.3276811838150024\n",
      "248 revenue:  3.684889793395996 rgt:  0.1775503307580948 loss:  -1.3206892013549805\n",
      "249 revenue:  3.632035493850708 rgt:  0.1706046611070633 loss:  -1.3221421241760254\n",
      "250 revenue:  3.5596365928649902 rgt:  0.11592892557382584 loss:  -1.4302875995635986\n",
      "251 revenue:  3.6389412879943848 rgt:  0.12327850610017776 loss:  -1.4332119226455688\n",
      "252 revenue:  3.6980998516082764 rgt:  0.1282287985086441 loss:  -1.43672513961792\n",
      "253 revenue:  3.763333559036255 rgt:  0.13544532656669617 loss:  -1.4364569187164307\n",
      "254 revenue:  3.7585909366607666 rgt:  0.1345171183347702 loss:  -1.4374257326126099\n",
      "255 revenue:  3.80730938911438 rgt:  0.13998943567276 loss:  -1.4370918273925781\n",
      "256 revenue:  3.7520103454589844 rgt:  0.14127932488918304 loss:  -1.4198598861694336\n",
      "257 revenue:  3.8026397228240967 rgt:  0.13434632122516632 loss:  -1.449156641960144\n",
      "258 revenue:  3.8585896492004395 rgt:  0.1964811086654663 loss:  -1.3245863914489746\n",
      "259 revenue:  3.801424980163574 rgt:  0.19025911390781403 loss:  -1.3232781887054443\n",
      "260 revenue:  3.73164439201355 rgt:  0.13007919490337372 loss:  -1.441002368927002\n",
      "261 revenue:  3.787411689758301 rgt:  0.13666991889476776 loss:  -1.4397685527801514\n",
      "262 revenue:  3.819119930267334 rgt:  0.14589177072048187 loss:  -1.4264073371887207\n",
      "263 revenue:  3.7705228328704834 rgt:  0.1405470222234726 loss:  -1.4263403415679932\n",
      "264 revenue:  3.816141366958618 rgt:  0.14608727395534515 loss:  -1.4251936674118042\n",
      "265 revenue:  3.764064073562622 rgt:  0.1396535187959671 loss:  -1.426763653755188\n",
      "266 revenue:  3.7975757122039795 rgt:  0.14326433837413788 loss:  -1.4269698858261108\n",
      "267 revenue:  3.7449216842651367 rgt:  0.13698160648345947 loss:  -1.4280881881713867\n",
      "268 revenue:  3.799982786178589 rgt:  0.1428215354681015 loss:  -1.4286154508590698\n",
      "269 revenue:  3.7494592666625977 rgt:  0.13633574545383453 loss:  -1.4307795763015747\n",
      "270 revenue:  3.783099889755249 rgt:  0.1352498084306717 loss:  -1.4420061111450195\n",
      "271 revenue:  3.825028896331787 rgt:  0.1418815553188324 loss:  -1.4372148513793945\n",
      "272 revenue:  3.777841329574585 rgt:  0.13591939210891724 loss:  -1.439074993133545\n",
      "273 revenue:  3.8276755809783936 rgt:  0.14196471869945526 loss:  -1.4376978874206543\n",
      "274 revenue:  3.777052164077759 rgt:  0.1353611797094345 loss:  -1.4401880502700806\n",
      "275 revenue:  3.828813076019287 rgt:  0.14118851721286774 loss:  -1.4397960901260376\n",
      "276 revenue:  3.7854866981506348 rgt:  0.1355554610490799 loss:  -1.4418985843658447\n",
      "277 revenue:  3.7444753646850586 rgt:  0.13127923011779785 loss:  -1.4414607286453247\n",
      "278 revenue:  3.8035380840301514 rgt:  0.1381848007440567 loss:  -1.4403491020202637\n",
      "279 revenue:  3.7598531246185303 rgt:  0.1342252790927887 loss:  -1.4384411573410034\n",
      "280 revenue:  3.738921880722046 rgt:  0.1307716816663742 loss:  -1.4412338733673096\n",
      "281 revenue:  3.8041553497314453 rgt:  0.1437389999628067 loss:  -1.4275561571121216\n",
      "282 revenue:  3.7463736534118652 rgt:  0.137757807970047 loss:  -1.4266399145126343\n",
      "283 revenue:  3.7929365634918213 rgt:  0.14225657284259796 loss:  -1.428120493888855\n",
      "284 revenue:  3.7375967502593994 rgt:  0.1361718475818634 loss:  -1.4280999898910522\n",
      "285 revenue:  3.7768092155456543 rgt:  0.139786034822464 loss:  -1.429735779762268\n",
      "286 revenue:  3.7454237937927246 rgt:  0.13606271147727966 loss:  -1.4303802251815796\n",
      "287 revenue:  3.7845458984375 rgt:  0.14025439321994781 loss:  -1.4306310415267944\n",
      "288 revenue:  3.7291104793548584 rgt:  0.13403037190437317 loss:  -1.4309585094451904\n",
      "289 revenue:  3.786994457244873 rgt:  0.14019905030727386 loss:  -1.4313894510269165\n",
      "290 revenue:  3.743717908859253 rgt:  0.13067905604839325 loss:  -1.4426943063735962\n",
      "291 revenue:  3.8025858402252197 rgt:  0.13748477399349213 loss:  -1.441747784614563\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "292 revenue:  3.745338201522827 rgt:  0.13085396587848663 loss:  -1.442696213722229\n",
      "293 revenue:  3.760047197341919 rgt:  0.13205531239509583 loss:  -1.4436347484588623\n",
      "294 revenue:  3.755390167236328 rgt:  0.16046613454818726 loss:  -1.3768343925476074\n",
      "295 revenue:  3.810450315475464 rgt:  0.18811990320682526 loss:  -1.3301897048950195\n",
      "296 revenue:  3.7473201751708984 rgt:  0.18653051555156708 loss:  -1.3173773288726807\n",
      "297 revenue:  3.678849220275879 rgt:  0.1773442178964615 loss:  -1.3195658922195435\n",
      "298 revenue:  3.729599952697754 rgt:  0.18544933199882507 loss:  -1.3151295185089111\n",
      "299 revenue:  3.6610734462738037 rgt:  0.17738226056098938 loss:  -1.3148431777954102\n",
      "300 revenue:  3.5886361598968506 rgt:  0.12135631591081619 loss:  -1.4246509075164795\n",
      "301 revenue:  3.659931182861328 rgt:  0.127949059009552 loss:  -1.427445888519287\n",
      "302 revenue:  3.727783441543579 rgt:  0.1342853158712387 loss:  -1.4300119876861572\n",
      "303 revenue:  3.715121030807495 rgt:  0.13183937966823578 loss:  -1.4325286149978638\n",
      "304 revenue:  3.772491693496704 rgt:  0.13775058090686798 loss:  -1.43339204788208\n",
      "305 revenue:  3.746088981628418 rgt:  0.14103086292743683 loss:  -1.4189099073410034\n",
      "306 revenue:  3.7968311309814453 rgt:  0.1488112360239029 loss:  -1.4139741659164429\n",
      "307 revenue:  3.73874831199646 rgt:  0.1428755521774292 loss:  -1.412719964981079\n",
      "308 revenue:  3.785085916519165 rgt:  0.1485416293144226 loss:  -1.4115769863128662\n",
      "309 revenue:  3.7328944206237793 rgt:  0.14368513226509094 loss:  -1.4093266725540161\n",
      "310 revenue:  3.790771722793579 rgt:  0.13749898970127106 loss:  -1.4386827945709229\n",
      "311 revenue:  3.7318334579467773 rgt:  0.13189081847667694 loss:  -1.436736822128296\n",
      "312 revenue:  3.785311698913574 rgt:  0.13756592571735382 loss:  -1.4371229410171509\n",
      "313 revenue:  3.7479405403137207 rgt:  0.13321435451507568 loss:  -1.4377599954605103\n",
      "314 revenue:  3.699176549911499 rgt:  0.12872441112995148 loss:  -1.435818076133728\n",
      "315 revenue:  3.7522566318511963 rgt:  0.1388012319803238 loss:  -1.4257127046585083\n",
      "316 revenue:  3.803905487060547 rgt:  0.14430518448352814 loss:  -1.4261798858642578\n",
      "317 revenue:  3.7518560886383057 rgt:  0.1428128033876419 loss:  -1.4162521362304688\n",
      "318 revenue:  3.7801737785339355 rgt:  0.14665889739990234 loss:  -1.4146473407745361\n",
      "319 revenue:  3.7283499240875244 rgt:  0.14086154103279114 loss:  -1.4147167205810547\n",
      "320 revenue:  3.7807767391204834 rgt:  0.13617201149463654 loss:  -1.439234972000122\n",
      "321 revenue:  3.796370267868042 rgt:  0.14068278670310974 loss:  -1.432667851448059\n",
      "322 revenue:  3.737496852874756 rgt:  0.13427245616912842 loss:  -1.43255615234375\n",
      "323 revenue:  3.7844362258911133 rgt:  0.1400955468416214 loss:  -1.4309738874435425\n",
      "324 revenue:  3.7327795028686523 rgt:  0.1337612271308899 loss:  -1.4325451850891113\n",
      "325 revenue:  3.786771774291992 rgt:  0.13927596807479858 loss:  -1.4334900379180908\n",
      "326 revenue:  3.765470504760742 rgt:  0.13701950013637543 loss:  -1.4333010911941528\n",
      "327 revenue:  3.801168203353882 rgt:  0.1416151076555252 loss:  -1.4317255020141602\n",
      "328 revenue:  3.745532989501953 rgt:  0.13472262024879456 loss:  -1.4335695505142212\n",
      "329 revenue:  3.712806463241577 rgt:  0.13120774924755096 loss:  -1.433430552482605\n",
      "330 revenue:  3.767774820327759 rgt:  0.1339615434408188 loss:  -1.4411065578460693\n",
      "331 revenue:  3.7814362049102783 rgt:  0.13615311682224274 loss:  -1.4394490718841553\n",
      "332 revenue:  3.7259230613708496 rgt:  0.13200071454048157 loss:  -1.4349453449249268\n",
      "333 revenue:  3.7796990871429443 rgt:  0.13695642352104187 loss:  -1.4371120929718018\n",
      "334 revenue:  3.7462315559387207 rgt:  0.1333114206790924 loss:  -1.4370886087417603\n",
      "335 revenue:  3.8031678199768066 rgt:  0.13935966789722443 loss:  -1.437502384185791\n",
      "336 revenue:  3.74169921875 rgt:  0.13265405595302582 loss:  -1.4374761581420898\n",
      "337 revenue:  3.7915689945220947 rgt:  0.13758999109268188 loss:  -1.438673973083496\n",
      "338 revenue:  3.7379603385925293 rgt:  0.1318463534116745 loss:  -1.4384278059005737\n",
      "339 revenue:  3.7849514484405518 rgt:  0.13648223876953125 loss:  -1.4395778179168701\n",
      "340 revenue:  3.7252538204193115 rgt:  0.13155145943164825 loss:  -1.4358398914337158\n",
      "341 revenue:  3.737433910369873 rgt:  0.13462062180042267 loss:  -1.4317169189453125\n",
      "342 revenue:  3.765211582183838 rgt:  0.13795582950115204 loss:  -1.4310353994369507\n",
      "343 revenue:  3.7523515224456787 rgt:  0.13622024655342102 loss:  -1.4317982196807861\n",
      "344 revenue:  3.719590425491333 rgt:  0.13321374356746674 loss:  -1.4304256439208984\n",
      "345 revenue:  3.7776730060577393 rgt:  0.13895761966705322 loss:  -1.4318958520889282\n",
      "346 revenue:  3.7189221382141113 rgt:  0.132394939661026 loss:  -1.4321945905685425\n",
      "347 revenue:  3.7734580039978027 rgt:  0.13782505691051483 loss:  -1.4334660768508911\n",
      "348 revenue:  3.71762752532959 rgt:  0.13167928159236908 loss:  -1.4335592985153198\n",
      "349 revenue:  3.777499198913574 rgt:  0.13806433975696564 loss:  -1.4339444637298584\n",
      "350 revenue:  3.7258994579315186 rgt:  0.130104660987854 loss:  -1.4394539594650269\n",
      "351 revenue:  3.780681848526001 rgt:  0.13670581579208374 loss:  -1.4379541873931885\n",
      "352 revenue:  3.7294819355010986 rgt:  0.13106302917003632 loss:  -1.4380974769592285\n",
      "353 revenue:  3.7894108295440674 rgt:  0.13811467587947845 loss:  -1.4368884563446045\n",
      "354 revenue:  3.7331702709198 rgt:  0.13166531920433044 loss:  -1.4376188516616821\n",
      "355 revenue:  3.7900681495666504 rgt:  0.1375347375869751 loss:  -1.4384182691574097\n",
      "356 revenue:  3.734726905822754 rgt:  0.13121972978115082 loss:  -1.4390817880630493\n",
      "357 revenue:  3.791907787322998 rgt:  0.13704447448253632 loss:  -1.4400426149368286\n",
      "358 revenue:  3.7399609088897705 rgt:  0.13093943893909454 loss:  -1.4411028623580933\n",
      "359 revenue:  3.793062448501587 rgt:  0.1366506963968277 loss:  -1.4412649869918823\n",
      "360 revenue:  3.737428903579712 rgt:  0.13384456932544708 loss:  -1.4335508346557617\n",
      "361 revenue:  3.7926108837127686 rgt:  0.1416846364736557 loss:  -1.4293678998947144\n",
      "362 revenue:  3.7410123348236084 rgt:  0.13549838960170746 loss:  -1.4305702447891235\n",
      "363 revenue:  3.7831168174743652 rgt:  0.1401333063840866 loss:  -1.430546522140503\n",
      "364 revenue:  3.730238914489746 rgt:  0.13421675562858582 loss:  -1.4308098554611206\n",
      "365 revenue:  3.7653417587280273 rgt:  0.13736800849437714 loss:  -1.4324489831924438\n",
      "366 revenue:  3.7228710651397705 rgt:  0.13283857703208923 loss:  -1.432165503501892\n",
      "367 revenue:  3.7776761054992676 rgt:  0.13856647908687592 loss:  -1.4328128099441528\n",
      "368 revenue:  3.7205862998962402 rgt:  0.1320781111717224 loss:  -1.4333784580230713\n",
      "369 revenue:  3.763317823410034 rgt:  0.1363479048013687 loss:  -1.434326171875\n",
      "370 revenue:  3.7367749214172363 rgt:  0.13047689199447632 loss:  -1.4413812160491943\n",
      "371 revenue:  3.7893173694610596 rgt:  0.13802672922611237 loss:  -1.4370707273483276\n",
      "372 revenue:  3.735480308532715 rgt:  0.1324649155139923 loss:  -1.4363168478012085\n",
      "373 revenue:  3.7894928455352783 rgt:  0.13818682730197906 loss:  -1.4367402791976929\n",
      "374 revenue:  3.73608660697937 rgt:  0.13216999173164368 loss:  -1.4371740818023682\n",
      "375 revenue:  3.7923312187194824 rgt:  0.13813206553459167 loss:  -1.437597632408142\n",
      "376 revenue:  3.7398948669433594 rgt:  0.13195541501045227 loss:  -1.4386687278747559\n",
      "377 revenue:  3.7914557456970215 rgt:  0.1373661607503891 loss:  -1.439170479774475\n",
      "378 revenue:  3.7373857498168945 rgt:  0.13108953833580017 loss:  -1.4400794506072998\n",
      "379 revenue:  3.7927896976470947 rgt:  0.13741004467010498 loss:  -1.439409852027893\n",
      "380 revenue:  3.7369468212127686 rgt:  0.13231781125068665 loss:  -1.4370455741882324\n",
      "381 revenue:  3.788384199142456 rgt:  0.1397039145231247 loss:  -1.4329034090042114\n",
      "382 revenue:  3.7296218872070312 rgt:  0.13340267539024353 loss:  -1.4325768947601318\n",
      "383 revenue:  3.7870287895202637 rgt:  0.13932979106903076 loss:  -1.4334300756454468\n",
      "384 revenue:  3.7334115505218506 rgt:  0.1332693099975586 loss:  -1.4338737726211548\n",
      "385 revenue:  3.7783658504486084 rgt:  0.13836584985256195 loss:  -1.4334603548049927\n",
      "386 revenue:  3.7499890327453613 rgt:  0.13464154303073883 loss:  -1.4349119663238525\n",
      "387 revenue:  3.78599214553833 rgt:  0.13845238089561462 loss:  -1.435218334197998\n",
      "388 revenue:  3.729207992553711 rgt:  0.13198252022266388 loss:  -1.4358391761779785\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "389 revenue:  3.781480312347412 rgt:  0.1383616328239441 loss:  -1.4342713356018066\n",
      "390 revenue:  3.72583270072937 rgt:  0.13082127273082733 loss:  -1.4377281665802002\n",
      "391 revenue:  3.784419536590576 rgt:  0.1378113329410553 loss:  -1.4363176822662354\n",
      "392 revenue:  3.736619472503662 rgt:  0.13610531389713287 loss:  -1.4280039072036743\n",
      "393 revenue:  3.795456886291504 rgt:  0.14789709448814392 loss:  -1.415722131729126\n",
      "394 revenue:  3.7341537475585938 rgt:  0.14169993996620178 loss:  -1.4142653942108154\n",
      "395 revenue:  3.7875897884368896 rgt:  0.14763684570789337 loss:  -1.414300799369812\n",
      "396 revenue:  3.744292974472046 rgt:  0.14257483184337616 loss:  -1.4148519039154053\n",
      "397 revenue:  3.728043556213379 rgt:  0.1429169923067093 loss:  -1.4098535776138306\n",
      "398 revenue:  3.780590057373047 rgt:  0.15014927089214325 loss:  -1.406733751296997\n",
      "399 revenue:  3.721669912338257 rgt:  0.1438804268836975 loss:  -1.4059667587280273\n",
      "400 revenue:  3.778783082962036 rgt:  0.13641591370105743 loss:  -1.438148021697998\n",
      "401 revenue:  3.7743752002716064 rgt:  0.13666783273220062 loss:  -1.4364211559295654\n",
      "402 revenue:  3.7696781158447266 rgt:  0.1363515853881836 loss:  -1.4359561204910278\n",
      "403 revenue:  3.7646400928497314 rgt:  0.13589365780353546 loss:  -1.4357367753982544\n",
      "404 revenue:  3.76078200340271 rgt:  0.13538333773612976 loss:  -1.4359455108642578\n",
      "405 revenue:  3.7576565742492676 rgt:  0.134964257478714 loss:  -1.4361286163330078\n",
      "406 revenue:  3.758758544921875 rgt:  0.1349961906671524 loss:  -1.4363373517990112\n",
      "407 revenue:  3.7595577239990234 rgt:  0.13506554067134857 loss:  -1.4363796710968018\n",
      "408 revenue:  3.760881185531616 rgt:  0.1351509839296341 loss:  -1.4365192651748657\n",
      "409 revenue:  3.7587358951568604 rgt:  0.13485416769981384 loss:  -1.4366668462753296\n",
      "410 revenue:  3.7575435638427734 rgt:  0.13290415704250336 loss:  -1.4409739971160889\n",
      "411 revenue:  3.7604405879974365 rgt:  0.13399656116962433 loss:  -1.4391335248947144\n",
      "412 revenue:  3.7636351585388184 rgt:  0.13458868861198425 loss:  -1.4385571479797363\n",
      "413 revenue:  3.764153003692627 rgt:  0.13484898209571838 loss:  -1.4380756616592407\n",
      "414 revenue:  3.7652316093444824 rgt:  0.1349508911371231 loss:  -1.4381129741668701\n",
      "415 revenue:  3.7665975093841553 rgt:  0.13562364876270294 loss:  -1.4368774890899658\n",
      "416 revenue:  3.762571096420288 rgt:  0.13517378270626068 loss:  -1.4369010925292969\n",
      "417 revenue:  3.7643213272094727 rgt:  0.1353166103363037 loss:  -1.4370152950286865\n",
      "418 revenue:  3.766247272491455 rgt:  0.1354561597108841 loss:  -1.4371823072433472\n",
      "419 revenue:  3.7677013874053955 rgt:  0.13555534183979034 loss:  -1.437322974205017\n",
      "420 revenue:  3.768707752227783 rgt:  0.13533498346805573 loss:  -1.4381020069122314\n",
      "421 revenue:  3.7629847526550293 rgt:  0.13567529618740082 loss:  -1.4358247518539429\n",
      "422 revenue:  3.760528087615967 rgt:  0.1353941559791565 loss:  -1.4358546733856201\n",
      "423 revenue:  3.7607648372650146 rgt:  0.13537979125976562 loss:  -1.435949444770813\n",
      "424 revenue:  3.760110855102539 rgt:  0.1353750228881836 loss:  -1.4357919692993164\n",
      "425 revenue:  3.757629632949829 rgt:  0.13511429727077484 loss:  -1.4357672929763794\n",
      "426 revenue:  3.7600908279418945 rgt:  0.1353839784860611 loss:  -1.4357658624649048\n",
      "427 revenue:  3.763519525527954 rgt:  0.13580095767974854 loss:  -1.435666561126709\n",
      "428 revenue:  3.758371114730835 rgt:  0.13535581529140472 loss:  -1.4353886842727661\n",
      "429 revenue:  3.756049633026123 rgt:  0.13513633608818054 loss:  -1.4353077411651611\n",
      "430 revenue:  3.7561628818511963 rgt:  0.13237455487251282 loss:  -1.4418745040893555\n",
      "431 revenue:  3.761214017868042 rgt:  0.13431835174560547 loss:  -1.4385719299316406\n",
      "432 revenue:  3.763418197631836 rgt:  0.13502977788448334 loss:  -1.4374593496322632\n",
      "433 revenue:  3.7656381130218506 rgt:  0.13542677462100983 loss:  -1.4370946884155273\n",
      "434 revenue:  3.765589714050293 rgt:  0.1354208141565323 loss:  -1.437096357345581\n",
      "435 revenue:  3.7663800716400146 rgt:  0.13542869687080383 loss:  -1.4372813701629639\n",
      "436 revenue:  3.767308473587036 rgt:  0.1354427933692932 loss:  -1.4374871253967285\n",
      "437 revenue:  3.768693685531616 rgt:  0.13550277054309845 loss:  -1.4377024173736572\n",
      "438 revenue:  3.7704646587371826 rgt:  0.1356040984392166 loss:  -1.4379196166992188\n",
      "439 revenue:  3.7718865871429443 rgt:  0.13566067814826965 loss:  -1.4381524324417114\n",
      "440 revenue:  3.7729125022888184 rgt:  0.13376310467720032 loss:  -1.442899227142334\n",
      "441 revenue:  3.773000717163086 rgt:  0.1347629576921463 loss:  -1.440557599067688\n",
      "442 revenue:  3.7711992263793945 rgt:  0.13465677201747894 loss:  -1.4403446912765503\n",
      "443 revenue:  3.772084951400757 rgt:  0.1349387764930725 loss:  -1.4399068355560303\n",
      "444 revenue:  3.77370023727417 rgt:  0.13509242236614227 loss:  -1.4399598836898804\n",
      "445 revenue:  3.775693655014038 rgt:  0.13523666560649872 loss:  -1.4401323795318604\n",
      "446 revenue:  3.7761013507843018 rgt:  0.13519729673862457 loss:  -1.440330147743225\n",
      "447 revenue:  3.777561664581299 rgt:  0.13534410297870636 loss:  -1.4403594732284546\n",
      "448 revenue:  3.77394437789917 rgt:  0.1348443478345871 loss:  -1.4406083822250366\n",
      "449 revenue:  3.770667791366577 rgt:  0.13439643383026123 loss:  -1.4408230781555176\n",
      "450 revenue:  3.7687058448791504 rgt:  0.13310779631137848 loss:  -1.4433683156967163\n",
      "451 revenue:  3.773902177810669 rgt:  0.13450253009796143 loss:  -1.4414050579071045\n",
      "452 revenue:  3.76981782913208 rgt:  0.1340218335390091 loss:  -1.4414900541305542\n",
      "453 revenue:  3.7660932540893555 rgt:  0.13355250656604767 loss:  -1.4416415691375732\n",
      "454 revenue:  3.76279354095459 rgt:  0.1331273317337036 loss:  -1.4417985677719116\n",
      "455 revenue:  3.7621514797210693 rgt:  0.14357897639274597 loss:  -1.417129397392273\n",
      "456 revenue:  3.7671475410461426 rgt:  0.17589819431304932 loss:  -1.3456138372421265\n",
      "457 revenue:  3.760780096054077 rgt:  0.1792355179786682 loss:  -1.3366754055023193\n",
      "458 revenue:  3.754006862640381 rgt:  0.1795254647731781 loss:  -1.3342961072921753\n",
      "459 revenue:  3.7470569610595703 rgt:  0.1790376901626587 loss:  -1.3335654735565186\n",
      "460 revenue:  3.7398335933685303 rgt:  0.13121753931045532 loss:  -1.4404077529907227\n",
      "461 revenue:  3.7465405464172363 rgt:  0.13295763731002808 loss:  -1.438007116317749\n",
      "462 revenue:  3.751901149749756 rgt:  0.13348670303821564 loss:  -1.438137412071228\n",
      "463 revenue:  3.7558038234710693 rgt:  0.13382238149642944 loss:  -1.438349723815918\n",
      "464 revenue:  3.7587928771972656 rgt:  0.13418801128864288 loss:  -1.438255786895752\n",
      "465 revenue:  3.763174057006836 rgt:  0.1349400132894516 loss:  -1.4376083612442017\n",
      "466 revenue:  3.7602429389953613 rgt:  0.1351032257080078 loss:  -1.4364674091339111\n",
      "467 revenue:  3.7645771503448486 rgt:  0.1355285793542862 loss:  -1.4365811347961426\n",
      "468 revenue:  3.761150360107422 rgt:  0.13510684669017792 loss:  -1.4366929531097412\n",
      "469 revenue:  3.765542507171631 rgt:  0.1355154812335968 loss:  -1.4368609189987183\n",
      "470 revenue:  3.7666866779327393 rgt:  0.1324187070131302 loss:  -1.4444829225540161\n",
      "471 revenue:  3.767796277999878 rgt:  0.13312672078609467 loss:  -1.4430891275405884\n",
      "472 revenue:  3.76407527923584 rgt:  0.13275712728500366 loss:  -1.4430067539215088\n",
      "473 revenue:  3.7636070251464844 rgt:  0.13280510902404785 loss:  -1.442772388458252\n",
      "474 revenue:  3.765253782272339 rgt:  0.15164153277873993 loss:  -1.399372935295105\n",
      "475 revenue:  3.7704343795776367 rgt:  0.17122188210487366 loss:  -1.356749176979065\n",
      "476 revenue:  3.7642130851745605 rgt:  0.1785537600517273 loss:  -1.339047908782959\n",
      "477 revenue:  3.7583742141723633 rgt:  0.17778633534908295 loss:  -1.339219093322754\n",
      "478 revenue:  3.751699209213257 rgt:  0.1791222095489502 loss:  -1.3345797061920166\n",
      "479 revenue:  3.7445991039276123 rgt:  0.1787971705198288 loss:  -1.3334553241729736\n",
      "480 revenue:  3.737654685974121 rgt:  0.13308113813400269 loss:  -1.4354174137115479\n",
      "481 revenue:  3.7438175678253174 rgt:  0.13473282754421234 loss:  -1.4331021308898926\n",
      "482 revenue:  3.7498619556427 rgt:  0.1357487440109253 loss:  -1.432266354560852\n",
      "483 revenue:  3.7502224445343018 rgt:  0.13570855557918549 loss:  -1.4324541091918945\n",
      "484 revenue:  3.7510745525360107 rgt:  0.13572640717029572 loss:  -1.4326319694519043\n",
      "485 revenue:  3.752176523208618 rgt:  0.1359879970550537 loss:  -1.432300090789795\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "486 revenue:  3.7556705474853516 rgt:  0.13634686172008514 loss:  -1.4323567152023315\n",
      "487 revenue:  3.7580037117004395 rgt:  0.1365099996328354 loss:  -1.4325745105743408\n",
      "488 revenue:  3.7570173740386963 rgt:  0.13631223142147064 loss:  -1.4327856302261353\n",
      "489 revenue:  3.755510091781616 rgt:  0.13604290783405304 loss:  -1.4330309629440308\n",
      "490 revenue:  3.7551639080047607 rgt:  0.1317524015903473 loss:  -1.4430949687957764\n",
      "491 revenue:  3.759854555130005 rgt:  0.1326591670513153 loss:  -1.4421511888504028\n",
      "492 revenue:  3.7630295753479004 rgt:  0.13310934603214264 loss:  -1.4419021606445312\n",
      "493 revenue:  3.7644553184509277 rgt:  0.13341104984283447 loss:  -1.4415546655654907\n",
      "494 revenue:  3.764906167984009 rgt:  0.13362838327884674 loss:  -1.441156029701233\n",
      "495 revenue:  3.761798620223999 rgt:  0.13344185054302216 loss:  -1.4407968521118164\n",
      "496 revenue:  3.7628190517425537 rgt:  0.13358771800994873 loss:  -1.4407144784927368\n",
      "497 revenue:  3.7653920650482178 rgt:  0.13395027816295624 loss:  -1.4405194520950317\n",
      "498 revenue:  3.7678310871124268 rgt:  0.1342177391052246 loss:  -1.4405150413513184\n",
      "499 revenue:  3.7693300247192383 rgt:  0.13429251313209534 loss:  -1.44072425365448\n",
      "500 revenue:  3.7704687118530273 rgt:  0.13532668352127075 loss:  -1.438575029373169\n",
      "501 revenue:  3.766432046890259 rgt:  0.13702607154846191 loss:  -1.4335333108901978\n",
      "502 revenue:  3.761630058288574 rgt:  0.13670168817043304 loss:  -1.4330586194992065\n",
      "503 revenue:  3.757244348526001 rgt:  0.13629363477230072 loss:  -1.4328880310058594\n",
      "504 revenue:  3.754350185394287 rgt:  0.1359366625547409 loss:  -1.432982087135315\n",
      "505 revenue:  3.756161689758301 rgt:  0.13607965409755707 loss:  -1.4331125020980835\n",
      "506 revenue:  3.756004571914673 rgt:  0.1360110193490982 loss:  -1.4332337379455566\n",
      "507 revenue:  3.756014347076416 rgt:  0.13596220314502716 loss:  -1.4333511590957642\n",
      "508 revenue:  3.7561140060424805 rgt:  0.13592301309108734 loss:  -1.433469295501709\n",
      "509 revenue:  3.754262685775757 rgt:  0.13567949831485748 loss:  -1.433565616607666\n",
      "510 revenue:  3.7531187534332275 rgt:  0.13173364102840424 loss:  -1.442611813545227\n",
      "511 revenue:  3.7587122917175293 rgt:  0.13288597762584686 loss:  -1.4413186311721802\n",
      "512 revenue:  3.7598671913146973 rgt:  0.1329512894153595 loss:  -1.4414615631103516\n",
      "513 revenue:  3.7605502605438232 rgt:  0.1329609751701355 loss:  -1.4416146278381348\n",
      "514 revenue:  3.7612268924713135 rgt:  0.13296426832675934 loss:  -1.4417814016342163\n",
      "515 revenue:  3.7620279788970947 rgt:  0.13297638297080994 loss:  -1.441959023475647\n",
      "516 revenue:  3.7628886699676514 rgt:  0.13299377262592316 loss:  -1.442139744758606\n",
      "517 revenue:  3.7633728981018066 rgt:  0.1329846829175949 loss:  -1.4422862529754639\n",
      "518 revenue:  3.7605092525482178 rgt:  0.13261139392852783 loss:  -1.4424333572387695\n",
      "519 revenue:  3.7621865272521973 rgt:  0.1496979147195816 loss:  -1.4030295610427856\n",
      "520 revenue:  3.755478858947754 rgt:  0.13361723721027374 loss:  -1.4387515783309937\n",
      "521 revenue:  3.761972188949585 rgt:  0.13593409955501556 loss:  -1.4349539279937744\n",
      "522 revenue:  3.7598931789398193 rgt:  0.13584940135478973 loss:  -1.4346174001693726\n",
      "523 revenue:  3.757134199142456 rgt:  0.13555532693862915 loss:  -1.4345991611480713\n",
      "524 revenue:  3.755333423614502 rgt:  0.1353321373462677 loss:  -1.4346609115600586\n",
      "525 revenue:  3.759209394454956 rgt:  0.13572606444358826 loss:  -1.4347317218780518\n",
      "526 revenue:  3.7590491771698 rgt:  0.1356506198644638 loss:  -1.434868335723877\n",
      "527 revenue:  3.7582921981811523 rgt:  0.1355111300945282 loss:  -1.4350019693374634\n",
      "528 revenue:  3.757652997970581 rgt:  0.13540922105312347 loss:  -1.4350775480270386\n",
      "529 revenue:  3.758978843688965 rgt:  0.135513573884964 loss:  -1.4351732730865479\n",
      "530 revenue:  3.7576711177825928 rgt:  0.13190630078315735 loss:  -1.4433759450912476\n",
      "531 revenue:  3.7622220516204834 rgt:  0.1332361251115799 loss:  -1.4413933753967285\n",
      "532 revenue:  3.7617225646972656 rgt:  0.13342352211475372 loss:  -1.4408206939697266\n",
      "533 revenue:  3.7627553939819336 rgt:  0.13375189900398254 loss:  -1.4403092861175537\n",
      "534 revenue:  3.7628421783447266 rgt:  0.13387145102024078 loss:  -1.4400488138198853\n",
      "535 revenue:  3.7626736164093018 rgt:  0.13384786248207092 loss:  -1.4400612115859985\n",
      "536 revenue:  3.763908863067627 rgt:  0.1339583843946457 loss:  -1.4401179552078247\n",
      "537 revenue:  3.7636654376983643 rgt:  0.13398699462413788 loss:  -1.4399875402450562\n",
      "538 revenue:  3.7651498317718506 rgt:  0.13408266007900238 loss:  -1.4401437044143677\n",
      "539 revenue:  3.7631404399871826 rgt:  0.13379356265068054 loss:  -1.440310001373291\n",
      "540 revenue:  3.7651779651641846 rgt:  0.13393957912921906 loss:  -1.4404895305633545\n",
      "541 revenue:  3.767508029937744 rgt:  0.13549286127090454 loss:  -1.4374206066131592\n",
      "542 revenue:  3.7624030113220215 rgt:  0.13570567965507507 loss:  -1.435603141784668\n",
      "543 revenue:  3.7650253772735596 rgt:  0.13612671196460724 loss:  -1.4352869987487793\n",
      "544 revenue:  3.762174129486084 rgt:  0.13575677573680878 loss:  -1.4354238510131836\n",
      "545 revenue:  3.764965534210205 rgt:  0.13600564002990723 loss:  -1.4355568885803223\n",
      "546 revenue:  3.7618913650512695 rgt:  0.14379939436912537 loss:  -1.4165512323379517\n",
      "547 revenue:  3.760606050491333 rgt:  0.14374639093875885 loss:  -1.4163427352905273\n",
      "548 revenue:  3.764111280441284 rgt:  0.1448453664779663 loss:  -1.4147008657455444\n",
      "549 revenue:  3.76334285736084 rgt:  0.14487546682357788 loss:  -1.414433240890503\n",
      "550 revenue:  3.768063545227051 rgt:  0.13543333113193512 loss:  -1.437704086303711\n",
      "551 revenue:  3.7629201412200928 rgt:  0.13612017035484314 loss:  -1.4347599744796753\n",
      "552 revenue:  3.7654733657836914 rgt:  0.13640278577804565 loss:  -1.4347524642944336\n",
      "553 revenue:  3.764216423034668 rgt:  0.1362006962299347 loss:  -1.4349043369293213\n",
      "554 revenue:  3.762425184249878 rgt:  0.1359509527683258 loss:  -1.4350309371948242\n",
      "555 revenue:  3.7654757499694824 rgt:  0.13643839955329895 loss:  -1.4346692562103271\n",
      "556 revenue:  3.7639451026916504 rgt:  0.1362381875514984 loss:  -1.4347461462020874\n",
      "557 revenue:  3.7606070041656494 rgt:  0.13582484424114227 loss:  -1.4348593950271606\n",
      "558 revenue:  3.7630765438079834 rgt:  0.13607549667358398 loss:  -1.4349055290222168\n",
      "559 revenue:  3.761178731918335 rgt:  0.13617010414600372 loss:  -1.4341933727264404\n",
      "560 revenue:  3.7634968757629395 rgt:  0.13210904598236084 loss:  -1.4443963766098022\n",
      "561 revenue:  3.767890453338623 rgt:  0.13359636068344116 loss:  -1.4420008659362793\n",
      "562 revenue:  3.764338254928589 rgt:  0.13377021253108978 loss:  -1.4406739473342896\n",
      "563 revenue:  3.761591672897339 rgt:  0.13346925377845764 loss:  -1.4406787157058716\n",
      "564 revenue:  3.7639505863189697 rgt:  0.13386891782283783 loss:  -1.440340280532837\n",
      "565 revenue:  3.7650156021118164 rgt:  0.13395196199417114 loss:  -1.4404184818267822\n",
      "566 revenue:  3.764204978942871 rgt:  0.13381327688694 loss:  -1.4405375719070435\n",
      "567 revenue:  3.7640373706817627 rgt:  0.13373170793056488 loss:  -1.4406875371932983\n",
      "568 revenue:  3.7626874446868896 rgt:  0.13353198766708374 loss:  -1.440812349319458\n",
      "569 revenue:  3.762899398803711 rgt:  0.13349272310733795 loss:  -1.440960168838501\n",
      "570 revenue:  3.7602553367614746 rgt:  0.13215065002441406 loss:  -1.4434618949890137\n",
      "571 revenue:  3.7656428813934326 rgt:  0.13332611322402954 loss:  -1.4420619010925293\n",
      "572 revenue:  3.7627241611480713 rgt:  0.1330781728029251 loss:  -1.4418972730636597\n",
      "573 revenue:  3.7646050453186035 rgt:  0.13327737152576447 loss:  -1.4419097900390625\n",
      "574 revenue:  3.7661397457122803 rgt:  0.13338318467140198 loss:  -1.4420547485351562\n",
      "575 revenue:  3.7678451538085938 rgt:  0.13374318182468414 loss:  -1.4416414499282837\n",
      "576 revenue:  3.762807607650757 rgt:  0.1333083063364029 loss:  -1.441373348236084\n",
      "577 revenue:  3.764801025390625 rgt:  0.133493110537529 loss:  -1.4414494037628174\n",
      "578 revenue:  3.7682783603668213 rgt:  0.13381484150886536 loss:  -1.4415833950042725\n",
      "579 revenue:  3.7695796489715576 rgt:  0.13389992713928223 loss:  -1.4417171478271484\n",
      "580 revenue:  3.769303798675537 rgt:  0.13561385869979858 loss:  -1.4375977516174316\n",
      "581 revenue:  3.765126943588257 rgt:  0.13692809641361237 loss:  -1.433427333831787\n",
      "582 revenue:  3.761676073074341 rgt:  0.13692086935043335 loss:  -1.4325549602508545\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583 revenue:  3.760995626449585 rgt:  0.13685064017772675 loss:  -1.4325448274612427\n",
      "584 revenue:  3.760669708251953 rgt:  0.13674180209636688 loss:  -1.432716727256775\n",
      "585 revenue:  3.7604198455810547 rgt:  0.13660481572151184 loss:  -1.4329745769500732\n",
      "586 revenue:  3.7598655223846436 rgt:  0.1365044116973877 loss:  -1.4330679178237915\n",
      "587 revenue:  3.758763074874878 rgt:  0.13628290593624115 loss:  -1.4333049058914185\n",
      "588 revenue:  3.758145332336426 rgt:  0.13625000417232513 loss:  -1.433223009109497\n",
      "589 revenue:  3.7632014751434326 rgt:  0.13673141598701477 loss:  -1.4333938360214233\n",
      "590 revenue:  3.7659029960632324 rgt:  0.13329580426216125 loss:  -1.4422006607055664\n",
      "591 revenue:  3.769860029220581 rgt:  0.1346302032470703 loss:  -1.4400626420974731\n",
      "592 revenue:  3.77205228805542 rgt:  0.13479791581630707 loss:  -1.4402308464050293\n",
      "593 revenue:  3.77211594581604 rgt:  0.13469615578651428 loss:  -1.4404877424240112\n",
      "594 revenue:  3.7725675106048584 rgt:  0.13465440273284912 loss:  -1.4407025575637817\n",
      "595 revenue:  3.768913984298706 rgt:  0.13416755199432373 loss:  -1.4409126043319702\n",
      "596 revenue:  3.7706658840179443 rgt:  0.1342734545469284 loss:  -1.4411134719848633\n",
      "597 revenue:  3.7706663608551025 rgt:  0.1346629112958908 loss:  -1.4401930570602417\n",
      "598 revenue:  3.7652628421783447 rgt:  0.13404828310012817 loss:  -1.4402542114257812\n",
      "599 revenue:  3.7615880966186523 rgt:  0.13362115621566772 loss:  -1.4403178691864014\n"
     ]
    }
   ],
   "source": [
    "training_set = train_set_prob_1\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": "a655cb80",
   "metadata": {},
   "source": [
    "# Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "765e24b8",
   "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": [
      "3.7254865169525146 0.13886913657188416 2.4258076412295124\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_1) # roughly 3.37752\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "9f7e2064",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.333520889282227 0.5856632590293884 2.384415569681127\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": "bd4b543e",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.463420391082764 0.2609747350215912 3.336245475119825\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": "4bd97454",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.753689765930176 0.4560055434703827 2.265067057683485\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": "66ecefe2",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.994933128356934 1.4686055183410645 1.046681123724152\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": "9c836f25",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0021834124345332384 2.5474928833091326e-09 0.0021786981069426355\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": "1b59b2ae",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.427793025970459 5.0712991651380435e-05 4.397873978818921\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": "d8ed9b45",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.059654712677002 0.10317442566156387 2.8684527736521415\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": "0e0a1dce",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5f7b2549",
   "metadata": {},
   "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
}
