{
 "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": [
    "no_prob_single = torch.tensor([1,1,1]).to(device)\n",
    "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_no_prob = get_train_or_test_set(batch_size,n,m,no_prob_single)\n",
    "test_set_no_prob = get_train_or_test_set(batch_size,n,m,no_prob_single)\n",
    "\n",
    "test_set_prob_1 = get_train_or_test_set(batch_size,n,m,prob_single_1)\n",
    "test_set_prob_2 = get_train_or_test_set(batch_size,n,m,prob_single_2)\n",
    "test_set_prob_3 = get_train_or_test_set(batch_size,n,m,prob_single_3)\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": "32542dcf",
   "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:  1.2393085956573486 rgt:  0.35435253381729126 loss:  -0.1636146903038025\n",
      "1 revenue:  1.2122001647949219 rgt:  0.3844417333602905 loss:  -0.096524178981781\n",
      "2 revenue:  1.184639811515808 rgt:  0.387810081243515 loss:  -0.07785752415657043\n",
      "3 revenue:  1.1550116539001465 rgt:  0.38220760226249695 loss:  -0.07427766919136047\n",
      "4 revenue:  1.1216402053833008 rgt:  0.37217873334884644 loss:  -0.0768318772315979\n",
      "5 revenue:  1.082207441329956 rgt:  0.35833218693733215 loss:  -0.08335128426551819\n",
      "6 revenue:  1.0332258939743042 rgt:  0.33914923667907715 loss:  -0.09496277570724487\n",
      "7 revenue:  0.9707767367362976 rgt:  0.3113146424293518 loss:  -0.1160096526145935\n",
      "8 revenue:  0.8922388553619385 rgt:  0.2694672644138336 loss:  -0.1560143530368805\n",
      "9 revenue:  0.8005319833755493 rgt:  0.2061230093240738 loss:  -0.23459382355213165\n",
      "10 revenue:  0.7135311365127563 rgt:  0.10096719115972519 loss:  -0.42598721385002136\n",
      "11 revenue:  0.6512970328330994 rgt:  0.04036148265004158 loss:  -0.5657666325569153\n",
      "12 revenue:  0.8424849510192871 rgt:  0.0264677032828331 loss:  -0.7287131547927856\n",
      "13 revenue:  1.0577131509780884 rgt:  0.014595157466828823 loss:  -0.8930462598800659\n",
      "14 revenue:  1.226412296295166 rgt:  0.006403736304491758 loss:  -1.021008014678955\n",
      "15 revenue:  1.5267590284347534 rgt:  0.018033795058727264 loss:  -1.0832971334457397\n",
      "16 revenue:  1.6239889860153198 rgt:  0.008933217264711857 loss:  -1.1709094047546387\n",
      "17 revenue:  1.8429815769195557 rgt:  0.024930285289883614 loss:  -1.1747410297393799\n",
      "18 revenue:  1.8938913345336914 rgt:  0.01131141185760498 loss:  -1.2585207223892212\n",
      "19 revenue:  2.049680709838867 rgt:  0.026660213246941566 loss:  -1.241730809211731\n",
      "20 revenue:  2.092655897140503 rgt:  0.01606232486665249 loss:  -1.3038018941879272\n",
      "21 revenue:  2.083768606185913 rgt:  0.014324424788355827 loss:  -1.3095173835754395\n",
      "22 revenue:  2.258681297302246 rgt:  0.0164838545024395 loss:  -1.3580175638198853\n",
      "23 revenue:  2.3500709533691406 rgt:  0.02149488590657711 loss:  -1.3648879528045654\n",
      "24 revenue:  2.51469087600708 rgt:  0.019631339237093925 loss:  -1.4260343313217163\n",
      "25 revenue:  2.761622905731201 rgt:  0.04066435620188713 loss:  -1.4194947481155396\n",
      "26 revenue:  2.8869943618774414 rgt:  0.03370639681816101 loss:  -1.481816291809082\n",
      "27 revenue:  3.2358920574188232 rgt:  0.07567533105611801 loss:  -1.4480916261672974\n",
      "28 revenue:  3.3036749362945557 rgt:  0.055222440510988235 loss:  -1.5273845195770264\n",
      "29 revenue:  3.6304543018341064 rgt:  0.09869354218244553 loss:  -1.4925264120101929\n",
      "30 revenue:  3.6998291015625 rgt:  0.07748110592365265 loss:  -1.567658543586731\n",
      "31 revenue:  3.935636520385742 rgt:  0.12375333905220032 loss:  -1.5083047151565552\n",
      "32 revenue:  4.0032806396484375 rgt:  0.10184020549058914 loss:  -1.5798555612564087\n",
      "33 revenue:  4.1227126121521 rgt:  0.13393834233283997 loss:  -1.5305321216583252\n",
      "34 revenue:  4.205888748168945 rgt:  0.11613638699054718 loss:  -1.5939019918441772\n",
      "35 revenue:  4.272960186004639 rgt:  0.1475556343793869 loss:  -1.535428524017334\n",
      "36 revenue:  4.345308780670166 rgt:  0.1257333755493164 loss:  -1.6042180061340332\n",
      "37 revenue:  4.33044958114624 rgt:  0.1664564311504364 loss:  -1.506525993347168\n",
      "38 revenue:  4.437057018280029 rgt:  0.13870780169963837 loss:  -1.5952894687652588\n",
      "39 revenue:  4.059787273406982 rgt:  0.13730524480342865 loss:  -1.5070388317108154\n",
      "40 revenue:  4.445441722869873 rgt:  0.1266835480928421 loss:  -1.6258116960525513\n",
      "41 revenue:  4.10788106918335 rgt:  0.11707770079374313 loss:  -1.5675469636917114\n",
      "42 revenue:  4.509346008300781 rgt:  0.13050968945026398 loss:  -1.6317510604858398\n",
      "43 revenue:  4.184685230255127 rgt:  0.12205806374549866 loss:  -1.5742241144180298\n",
      "44 revenue:  4.555112361907959 rgt:  0.1325874924659729 loss:  -1.6375577449798584\n",
      "45 revenue:  4.255836009979248 rgt:  0.14549407362937927 loss:  -1.5360368490219116\n",
      "46 revenue:  4.602472305297852 rgt:  0.141911119222641 loss:  -1.6267153024673462\n",
      "47 revenue:  4.192708492279053 rgt:  0.14046801626682281 loss:  -1.5323518514633179\n",
      "48 revenue:  4.609567165374756 rgt:  0.14524391293525696 loss:  -1.6206376552581787\n",
      "49 revenue:  4.181942939758301 rgt:  0.1393103003501892 loss:  -1.5324268341064453\n",
      "50 revenue:  4.614941120147705 rgt:  0.1335923671722412 loss:  -1.649146318435669\n",
      "51 revenue:  4.206649303436279 rgt:  0.115018330514431 loss:  -1.5968499183654785\n",
      "52 revenue:  4.65513277053833 rgt:  0.13574999570846558 loss:  -1.6533830165863037\n",
      "53 revenue:  4.273496150970459 rgt:  0.1375659555196762 loss:  -1.5587787628173828\n",
      "54 revenue:  4.67135763168335 rgt:  0.1432429999113083 loss:  -1.6396148204803467\n",
      "55 revenue:  4.227500915527344 rgt:  0.13419677317142487 loss:  -1.55556321144104\n",
      "56 revenue:  4.667951583862305 rgt:  0.14390906691551208 loss:  -1.6372817754745483\n",
      "57 revenue:  4.218720436096191 rgt:  0.1354566216468811 loss:  -1.5504515171051025\n",
      "58 revenue:  4.667118072509766 rgt:  0.14509274065494537 loss:  -1.6343481540679932\n",
      "59 revenue:  4.208213806152344 rgt:  0.13412010669708252 loss:  -1.5510488748550415\n",
      "60 revenue:  4.667790412902832 rgt:  0.13343681395053864 loss:  -1.6617801189422607\n",
      "61 revenue:  4.24929666519165 rgt:  0.11258804053068161 loss:  -1.6132527589797974\n",
      "62 revenue:  4.703012466430664 rgt:  0.13637882471084595 loss:  -1.6629691123962402\n",
      "63 revenue:  4.30776309967041 rgt:  0.11730830371379852 loss:  -1.6157037019729614\n",
      "64 revenue:  4.723715305328369 rgt:  0.14152221381664276 loss:  -1.6556943655014038\n",
      "65 revenue:  4.295840740203857 rgt:  0.13731186091899872 loss:  -1.5647729635238647\n",
      "66 revenue:  4.704742431640625 rgt:  0.14681527018547058 loss:  -1.6390618085861206\n",
      "67 revenue:  4.240140438079834 rgt:  0.13187536597251892 loss:  -1.5641382932662964\n",
      "68 revenue:  4.692979335784912 rgt:  0.1462194174528122 loss:  -1.6377226114273071\n",
      "69 revenue:  4.215969562530518 rgt:  0.12839041650295258 loss:  -1.5665762424468994\n",
      "70 revenue:  4.6957831382751465 rgt:  0.1365939974784851 loss:  -1.6607952117919922\n",
      "71 revenue:  4.259863376617432 rgt:  0.10812436789274216 loss:  -1.6269965171813965\n",
      "72 revenue:  4.731558322906494 rgt:  0.13945500552654266 loss:  -1.6623228788375854\n",
      "73 revenue:  4.3190836906433105 rgt:  0.11348579078912735 loss:  -1.6278783082962036\n",
      "74 revenue:  4.742208480834961 rgt:  0.13982722163200378 loss:  -1.6638991832733154\n",
      "75 revenue:  4.349254608154297 rgt:  0.11593600362539291 loss:  -1.6290568113327026\n",
      "76 revenue:  4.759173393249512 rgt:  0.1411171555519104 loss:  -1.6647801399230957\n",
      "77 revenue:  4.369853973388672 rgt:  0.13695190846920013 loss:  -1.5833975076675415\n",
      "78 revenue:  4.759224891662598 rgt:  0.1491309553384781 loss:  -1.646259069442749\n",
      "79 revenue:  4.305963516235352 rgt:  0.13298363983631134 loss:  -1.5774286985397339\n",
      "80 revenue:  4.726851463317871 rgt:  0.13588176667690277 loss:  -1.6696290969848633\n",
      "81 revenue:  4.3093461990356445 rgt:  0.10986830294132233 loss:  -1.6345643997192383\n",
      "82 revenue:  4.767827033996582 rgt:  0.13978347182273865 loss:  -1.6698755025863647\n",
      "83 revenue:  4.36132287979126 rgt:  0.11465875804424286 loss:  -1.6351062059402466\n",
      "84 revenue:  4.77933406829834 rgt:  0.14457285404205322 loss:  -1.661368727684021\n",
      "85 revenue:  4.336757659912109 rgt:  0.13298644125461578 loss:  -1.5848288536071777\n",
      "86 revenue:  4.752093315124512 rgt:  0.14838679134845734 loss:  -1.646332859992981\n",
      "87 revenue:  4.291141510009766 rgt:  0.12865853309631348 loss:  -1.5841584205627441\n",
      "88 revenue:  4.7443013191223145 rgt:  0.1478596180677414 loss:  -1.6457568407058716\n",
      "89 revenue:  4.273228645324707 rgt:  0.12663695216178894 loss:  -1.5846811532974243\n",
      "90 revenue:  4.742591857910156 rgt:  0.13735921680927277 loss:  -1.6697698831558228\n",
      "91 revenue:  4.30838680267334 rgt:  0.10659705847501755 loss:  -1.6425763368606567\n",
      "92 revenue:  4.778642177581787 rgt:  0.14000852406024933 loss:  -1.6718249320983887\n",
      "93 revenue:  4.3627800941467285 rgt:  0.11189376562833786 loss:  -1.642327904701233\n",
      "94 revenue:  4.788840293884277 rgt:  0.14078660309314728 loss:  -1.6723397970199585\n",
      "95 revenue:  4.387054443359375 rgt:  0.11420930176973343 loss:  -1.642371654510498\n",
      "96 revenue:  4.803195953369141 rgt:  0.14224307239055634 loss:  -1.6722251176834106\n",
      "97 revenue:  4.401700496673584 rgt:  0.1154853031039238 loss:  -1.642706274986267\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "98 revenue:  4.811398506164551 rgt:  0.14226064085960388 loss:  -1.674054741859436\n",
      "99 revenue:  4.420720100402832 rgt:  0.11694080382585526 loss:  -1.6436437368392944\n",
      "100 revenue:  4.822139263153076 rgt:  0.1408444195985794 loss:  -1.679800033569336\n",
      "101 revenue:  4.451507091522217 rgt:  0.11873675882816315 loss:  -1.6465407609939575\n",
      "102 revenue:  4.848389148712158 rgt:  0.14474862813949585 loss:  -1.6766986846923828\n",
      "103 revenue:  4.456950664520264 rgt:  0.11905255913734436 loss:  -1.6470565795898438\n",
      "104 revenue:  4.8559160232543945 rgt:  0.14625664055347443 loss:  -1.6749224662780762\n",
      "105 revenue:  4.462718486785889 rgt:  0.11954164505004883 loss:  -1.6472251415252686\n",
      "106 revenue:  4.858152866363525 rgt:  0.1557920277118683 loss:  -1.6536247730255127\n",
      "107 revenue:  4.415913105010986 rgt:  0.13653406500816345 loss:  -1.5953682661056519\n",
      "108 revenue:  4.812185287475586 rgt:  0.15485292673110962 loss:  -1.6453027725219727\n",
      "109 revenue:  4.3452043533325195 rgt:  0.12885478138923645 loss:  -1.5966970920562744\n",
      "110 revenue:  4.813714027404785 rgt:  0.14414598047733307 loss:  -1.6702063083648682\n",
      "111 revenue:  4.3647942543029785 rgt:  0.10596432536840439 loss:  -1.6577231884002686\n",
      "112 revenue:  4.8470540046691895 rgt:  0.147271066904068 loss:  -1.6705725193023682\n",
      "113 revenue:  4.42201566696167 rgt:  0.11190911382436752 loss:  -1.6564216613769531\n",
      "114 revenue:  4.856931209564209 rgt:  0.14826172590255737 loss:  -1.6705350875854492\n",
      "115 revenue:  4.441998481750488 rgt:  0.11361559480428696 loss:  -1.6569201946258545\n",
      "116 revenue:  4.865082263946533 rgt:  0.1492321491241455 loss:  -1.6701552867889404\n",
      "117 revenue:  4.456465721130371 rgt:  0.11510861665010452 loss:  -1.6566492319107056\n",
      "118 revenue:  4.870436668395996 rgt:  0.15006300806999207 loss:  -1.669463872909546\n",
      "119 revenue:  4.467953205108643 rgt:  0.11617232859134674 loss:  -1.656740427017212\n",
      "120 revenue:  4.87468957901001 rgt:  0.148923859000206 loss:  -1.6730395555496216\n",
      "121 revenue:  4.479063034057617 rgt:  0.1159389466047287 loss:  -1.6599427461624146\n",
      "122 revenue:  4.880825519561768 rgt:  0.14990289509296417 loss:  -1.6721831560134888\n",
      "123 revenue:  4.485381126403809 rgt:  0.11640623211860657 loss:  -1.660282015800476\n",
      "124 revenue:  4.883225440979004 rgt:  0.15038667619228363 loss:  -1.6716182231903076\n",
      "125 revenue:  4.4890289306640625 rgt:  0.11673220247030258 loss:  -1.6603397130966187\n",
      "126 revenue:  4.8816447257995605 rgt:  0.16549192368984222 loss:  -1.6371456384658813\n",
      "127 revenue:  4.4853997230529785 rgt:  0.1160656288266182 loss:  -1.6611266136169434\n",
      "128 revenue:  4.872283458709717 rgt:  0.17644941806793213 loss:  -1.6108167171478271\n",
      "129 revenue:  4.476016521453857 rgt:  0.11545141786336899 loss:  -1.6604268550872803\n",
      "130 revenue:  4.842370986938477 rgt:  0.14415113627910614 loss:  -1.67671537399292\n",
      "131 revenue:  4.495211124420166 rgt:  0.11540782451629639 loss:  -1.6650662422180176\n",
      "132 revenue:  4.885138988494873 rgt:  0.15008001029491425 loss:  -1.6727535724639893\n",
      "133 revenue:  4.493945598602295 rgt:  0.1257811188697815 loss:  -1.6394553184509277\n",
      "134 revenue:  4.87444543838501 rgt:  0.1551637351512909 loss:  -1.6587426662445068\n",
      "135 revenue:  4.443194389343262 rgt:  0.12660431861877441 loss:  -1.625469446182251\n",
      "136 revenue:  4.830434799194336 rgt:  0.15142907202243805 loss:  -1.6572569608688354\n",
      "137 revenue:  4.38819694519043 rgt:  0.12303214520215988 loss:  -1.6210108995437622\n",
      "138 revenue:  4.8032121658325195 rgt:  0.15155215561389923 loss:  -1.6507740020751953\n",
      "139 revenue:  4.340941905975342 rgt:  0.12052163481712341 loss:  -1.6158088445663452\n",
      "140 revenue:  4.803524971008301 rgt:  0.1422547996044159 loss:  -1.6722729206085205\n",
      "141 revenue:  4.364630222320557 rgt:  0.1004316434264183 loss:  -1.6718285083770752\n",
      "142 revenue:  4.836989879608154 rgt:  0.14488893747329712 loss:  -1.6737840175628662\n",
      "143 revenue:  4.418242931365967 rgt:  0.10573621839284897 loss:  -1.6710543632507324\n",
      "144 revenue:  4.858648777008057 rgt:  0.14666703343391418 loss:  -1.6745960712432861\n",
      "145 revenue:  4.445928573608398 rgt:  0.10815659165382385 loss:  -1.6715086698532104\n",
      "146 revenue:  4.861942768096924 rgt:  0.14671345055103302 loss:  -1.6752359867095947\n",
      "147 revenue:  4.457916736602783 rgt:  0.10907519608736038 loss:  -1.6720374822616577\n",
      "148 revenue:  4.8673014640808105 rgt:  0.14730769395828247 loss:  -1.675081491470337\n",
      "149 revenue:  4.4647216796875 rgt:  0.10979098081588745 loss:  -1.6718504428863525\n",
      "150 revenue:  4.870979309082031 rgt:  0.1460745483636856 loss:  -1.6787580251693726\n",
      "151 revenue:  4.471198558807373 rgt:  0.10995025187730789 loss:  -1.6729830503463745\n",
      "152 revenue:  4.8756327629089355 rgt:  0.14744903147220612 loss:  -1.6766434907913208\n",
      "153 revenue:  4.481834411621094 rgt:  0.11107397824525833 loss:  -1.672682762145996\n",
      "154 revenue:  4.88323974609375 rgt:  0.14904849231243134 loss:  -1.6746888160705566\n",
      "155 revenue:  4.489396095275879 rgt:  0.11169338971376419 loss:  -1.6729204654693604\n",
      "156 revenue:  4.884474754333496 rgt:  0.15240448713302612 loss:  -1.6672899723052979\n",
      "157 revenue:  4.460481643676758 rgt:  0.1282224953174591 loss:  -1.6256810426712036\n",
      "158 revenue:  4.842318534851074 rgt:  0.15569186210632324 loss:  -1.6502569913864136\n",
      "159 revenue:  4.3975019454956055 rgt:  0.1224021166563034 loss:  -1.6247597932815552\n",
      "160 revenue:  4.812038898468018 rgt:  0.1414555013179779 loss:  -1.676074743270874\n",
      "161 revenue:  4.369666576385498 rgt:  0.09824176877737045 loss:  -1.6786974668502808\n",
      "162 revenue:  4.844522953033447 rgt:  0.1446155607700348 loss:  -1.6761285066604614\n",
      "163 revenue:  4.421062469482422 rgt:  0.10324350744485855 loss:  -1.678073525428772\n",
      "164 revenue:  4.856249809265137 rgt:  0.146264910697937 loss:  -1.6749792098999023\n",
      "165 revenue:  4.442636966705322 rgt:  0.10573723167181015 loss:  -1.6768465042114258\n",
      "166 revenue:  4.8668718338012695 rgt:  0.16157230734825134 loss:  -1.6425658464431763\n",
      "167 revenue:  4.452584266662598 rgt:  0.10685309022665024 loss:  -1.676377773284912\n",
      "168 revenue:  4.864965438842773 rgt:  0.17394690215587616 loss:  -1.6146504878997803\n",
      "169 revenue:  4.450582027435303 rgt:  0.10779397934675217 loss:  -1.6735265254974365\n",
      "170 revenue:  4.829730987548828 rgt:  0.14083027839660645 loss:  -1.6815611124038696\n",
      "171 revenue:  4.4778218269348145 rgt:  0.10850172489881516 loss:  -1.6781888008117676\n",
      "172 revenue:  4.886295318603516 rgt:  0.14911165833473206 loss:  -1.6752352714538574\n",
      "173 revenue:  4.475539684295654 rgt:  0.10716469585895538 loss:  -1.6810222864151\n",
      "174 revenue:  4.8986077308654785 rgt:  0.15213026106357574 loss:  -1.671110987663269\n",
      "175 revenue:  4.485750675201416 rgt:  0.10806907713413239 loss:  -1.681151270866394\n",
      "176 revenue:  4.898928642272949 rgt:  0.17535120248794556 loss:  -1.6192517280578613\n",
      "177 revenue:  4.48486852645874 rgt:  0.10904078185558319 loss:  -1.6784968376159668\n",
      "178 revenue:  4.858800888061523 rgt:  0.17323678731918335 loss:  -1.6148147583007812\n",
      "179 revenue:  4.456819534301758 rgt:  0.1086394414305687 loss:  -1.672873616218567\n",
      "180 revenue:  4.811192512512207 rgt:  0.13928155601024628 loss:  -1.6809570789337158\n",
      "181 revenue:  4.464483261108398 rgt:  0.10603995621204376 loss:  -1.6812546253204346\n",
      "182 revenue:  4.865529537200928 rgt:  0.14580655097961426 loss:  -1.6781418323516846\n",
      "183 revenue:  4.4609694480896 rgt:  0.10447154939174652 loss:  -1.68440842628479\n",
      "184 revenue:  4.885905742645264 rgt:  0.14879117906093597 loss:  -1.6758826971054077\n",
      "185 revenue:  4.47418212890625 rgt:  0.1055193543434143 loss:  -1.6848695278167725\n",
      "186 revenue:  4.892289161682129 rgt:  0.1492452621459961 loss:  -1.6762840747833252\n",
      "187 revenue:  4.48716402053833 rgt:  0.10672340542078018 loss:  -1.684883952140808\n",
      "188 revenue:  4.896787166595459 rgt:  0.14944398403167725 loss:  -1.676844596862793\n",
      "189 revenue:  4.4963531494140625 rgt:  0.10767357051372528 loss:  -1.6846505403518677\n",
      "190 revenue:  4.899008274078369 rgt:  0.14633125066757202 loss:  -1.6845064163208008\n",
      "191 revenue:  4.503190517425537 rgt:  0.1069263368844986 loss:  -1.6881499290466309\n",
      "192 revenue:  4.904406547546387 rgt:  0.14778678119182587 loss:  -1.6823722124099731\n",
      "193 revenue:  4.512527942657471 rgt:  0.10750952363014221 loss:  -1.6888751983642578\n",
      "194 revenue:  4.905245780944824 rgt:  0.14824314415454865 loss:  -1.6815121173858643\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "195 revenue:  4.518874168395996 rgt:  0.10775189101696014 loss:  -1.6897566318511963\n",
      "196 revenue:  4.905550956726074 rgt:  0.14759418368339539 loss:  -1.6830737590789795\n",
      "197 revenue:  4.523722171783447 rgt:  0.10770028829574585 loss:  -1.6910266876220703\n",
      "198 revenue:  4.905455112457275 rgt:  0.1462862491607666 loss:  -1.6860660314559937\n",
      "199 revenue:  4.524848937988281 rgt:  0.10699523240327835 loss:  -1.6930726766586304\n",
      "200 revenue:  4.903919219970703 rgt:  0.14053896069526672 loss:  -1.6990551948547363\n",
      "201 revenue:  4.906563758850098 rgt:  0.13798101246356964 loss:  -1.7056374549865723\n",
      "202 revenue:  4.904523849487305 rgt:  0.13235032558441162 loss:  -1.7184659242630005\n",
      "203 revenue:  4.8968400955200195 rgt:  0.12683282792568207 loss:  -1.7299118041992188\n",
      "204 revenue:  4.883236408233643 rgt:  0.12212927639484406 loss:  -1.7382051944732666\n",
      "205 revenue:  4.86290979385376 rgt:  0.11802902072668076 loss:  -1.743618130683899\n",
      "206 revenue:  4.864217281341553 rgt:  0.11697474122047424 loss:  -1.7465065717697144\n",
      "207 revenue:  4.869477272033691 rgt:  0.11658959090709686 loss:  -1.7486474514007568\n",
      "208 revenue:  4.855589866638184 rgt:  0.11449601501226425 loss:  -1.7506717443466187\n",
      "209 revenue:  4.879887580871582 rgt:  0.11609520018100739 loss:  -1.7522242069244385\n",
      "210 revenue:  4.847776412963867 rgt:  0.11322181671857834 loss:  -1.7520605325698853\n",
      "211 revenue:  4.869429588317871 rgt:  0.11438603699207306 loss:  -1.754082202911377\n",
      "212 revenue:  4.8478240966796875 rgt:  0.11207251995801926 loss:  -1.7549326419830322\n",
      "213 revenue:  4.871984481811523 rgt:  0.11352711915969849 loss:  -1.7567923069000244\n",
      "214 revenue:  4.840572357177734 rgt:  0.11030791699886322 loss:  -1.7576956748962402\n",
      "215 revenue:  4.872030258178711 rgt:  0.1126040667295456 loss:  -1.7590981721878052\n",
      "216 revenue:  4.841550350189209 rgt:  0.10950778424739838 loss:  -1.7599250078201294\n",
      "217 revenue:  4.871438026428223 rgt:  0.11159031838178635 loss:  -1.7614918947219849\n",
      "218 revenue:  4.841208457946777 rgt:  0.10852699726819992 loss:  -1.7623133659362793\n",
      "219 revenue:  4.870923042297363 rgt:  0.12037333846092224 loss:  -1.7396947145462036\n",
      "220 revenue:  4.836545944213867 rgt:  0.10642296075820923 loss:  -1.7665667533874512\n",
      "221 revenue:  4.8535308837890625 rgt:  0.10805059969425201 loss:  -1.7663118839263916\n",
      "222 revenue:  4.838014125823975 rgt:  0.10563237220048904 loss:  -1.7689049243927002\n",
      "223 revenue:  4.85073184967041 rgt:  0.11077417433261871 loss:  -1.7588359117507935\n",
      "224 revenue:  4.816539764404297 rgt:  0.1152307465672493 loss:  -1.7399742603302002\n",
      "225 revenue:  4.779458045959473 rgt:  0.11386854201555252 loss:  -1.7348846197128296\n",
      "226 revenue:  4.740452766418457 rgt:  0.11335190385580063 loss:  -1.7272282838821411\n",
      "227 revenue:  4.738583564758301 rgt:  0.11409793049097061 loss:  -1.7249470949172974\n",
      "228 revenue:  4.7022786140441895 rgt:  0.11280599236488342 loss:  -1.7198017835617065\n",
      "229 revenue:  4.67538595199585 rgt:  0.10970170050859451 loss:  -1.721349835395813\n",
      "230 revenue:  4.680570602416992 rgt:  0.08735771477222443 loss:  -1.7805414199829102\n",
      "231 revenue:  4.727170467376709 rgt:  0.08936963230371475 loss:  -1.7858885526657104\n",
      "232 revenue:  4.755037784576416 rgt:  0.09094703942537308 loss:  -1.7880836725234985\n",
      "233 revenue:  4.768458366394043 rgt:  0.09096740186214447 loss:  -1.7911045551300049\n",
      "234 revenue:  4.745616436004639 rgt:  0.08788719773292542 loss:  -1.7940987348556519\n",
      "235 revenue:  4.777275085449219 rgt:  0.08997102826833725 loss:  -1.795775055885315\n",
      "236 revenue:  4.745433807373047 rgt:  0.08640093356370926 loss:  -1.798060417175293\n",
      "237 revenue:  4.778185844421387 rgt:  0.08848144859075546 loss:  -1.7999664545059204\n",
      "238 revenue:  4.746924877166748 rgt:  0.08507809042930603 loss:  -1.801984190940857\n",
      "239 revenue:  4.780452251434326 rgt:  0.08723314106464386 loss:  -1.8038387298583984\n",
      "240 revenue:  4.7483086585998535 rgt:  0.0845257043838501 loss:  -1.8038026094436646\n",
      "241 revenue:  4.766102313995361 rgt:  0.08432938903570175 loss:  -1.8084158897399902\n",
      "242 revenue:  4.767016887664795 rgt:  0.08396602421998978 loss:  -1.809614896774292\n",
      "243 revenue:  4.744038105010986 rgt:  0.07995852828025818 loss:  -1.815353274345398\n",
      "244 revenue:  4.765491485595703 rgt:  0.08183963596820831 loss:  -1.8150845766067505\n",
      "245 revenue:  4.750209808349609 rgt:  0.07879017293453217 loss:  -1.8200116157531738\n",
      "246 revenue:  4.765174865722656 rgt:  0.07991205900907516 loss:  -1.8203288316726685\n",
      "247 revenue:  4.747581958770752 rgt:  0.07666124403476715 loss:  -1.825355887413025\n",
      "248 revenue:  4.7639994621276855 rgt:  0.07804775983095169 loss:  -1.8252408504486084\n",
      "249 revenue:  4.743208408355713 rgt:  0.07441763579845428 loss:  -1.8306772708892822\n",
      "250 revenue:  4.760168075561523 rgt:  0.07434283941984177 loss:  -1.8347793817520142\n",
      "251 revenue:  4.734551429748535 rgt:  0.07180815190076828 loss:  -1.8361238241195679\n",
      "252 revenue:  4.750613689422607 rgt:  0.07291903346776962 loss:  -1.836635947227478\n",
      "253 revenue:  4.74995231628418 rgt:  0.07202766835689545 loss:  -1.8390312194824219\n",
      "254 revenue:  4.7718825340271 rgt:  0.07285862416028976 loss:  -1.8416820764541626\n",
      "255 revenue:  4.7559428215026855 rgt:  0.07073736190795898 loss:  -1.8441100120544434\n",
      "256 revenue:  4.781383514404297 rgt:  0.0720398798584938 loss:  -1.846195101737976\n",
      "257 revenue:  4.758890628814697 rgt:  0.06972252577543259 loss:  -1.8477154970169067\n",
      "258 revenue:  4.784902572631836 rgt:  0.07080752402544022 loss:  -1.850537657737732\n",
      "259 revenue:  4.765023708343506 rgt:  0.06845054030418396 loss:  -1.85281240940094\n",
      "260 revenue:  4.786746025085449 rgt:  0.0693083256483078 loss:  -1.8552902936935425\n",
      "261 revenue:  4.764437198638916 rgt:  0.0657089501619339 loss:  -1.8607124090194702\n",
      "262 revenue:  4.775704383850098 rgt:  0.06693298369646072 loss:  -1.8596913814544678\n",
      "263 revenue:  4.789058685302734 rgt:  0.06688390672206879 loss:  -1.8628885746002197\n",
      "264 revenue:  4.786133289337158 rgt:  0.0660528838634491 loss:  -1.8646628856658936\n",
      "265 revenue:  4.809581756591797 rgt:  0.06753572076559067 loss:  -1.865663766860962\n",
      "266 revenue:  4.794175624847412 rgt:  0.06556940823793411 loss:  -1.867926001548767\n",
      "267 revenue:  4.817197322845459 rgt:  0.06672023236751556 loss:  -1.8697885274887085\n",
      "268 revenue:  4.80055046081543 rgt:  0.06481923162937164 loss:  -1.8716005086898804\n",
      "269 revenue:  4.823357105255127 rgt:  0.06592895090579987 loss:  -1.873518943786621\n",
      "270 revenue:  4.811041831970215 rgt:  0.06391977518796921 loss:  -1.8766653537750244\n",
      "271 revenue:  4.786474227905273 rgt:  0.06215707212686539 loss:  -1.876330852508545\n",
      "272 revenue:  4.8050856590271 rgt:  0.06259164959192276 loss:  -1.8792755603790283\n",
      "273 revenue:  4.82020902633667 rgt:  0.06338781118392944 loss:  -1.880340337753296\n",
      "274 revenue:  4.821781158447266 rgt:  0.06261102855205536 loss:  -1.883022427558899\n",
      "275 revenue:  4.840159893035889 rgt:  0.06378711014986038 loss:  -1.8836880922317505\n",
      "276 revenue:  4.840696811676025 rgt:  0.06325222551822662 loss:  -1.885406255722046\n",
      "277 revenue:  4.859267234802246 rgt:  0.06472549587488174 loss:  -1.8852369785308838\n",
      "278 revenue:  4.8586530685424805 rgt:  0.06391686946153641 loss:  -1.887500524520874\n",
      "279 revenue:  4.8767991065979 rgt:  0.06524960696697235 loss:  -1.8876579999923706\n",
      "280 revenue:  4.874007701873779 rgt:  0.05948822945356369 loss:  -1.904325246810913\n",
      "281 revenue:  4.851452350616455 rgt:  0.06277453154325485 loss:  -1.8892781734466553\n",
      "282 revenue:  4.868298530578613 rgt:  0.0635836273431778 loss:  -1.8906805515289307\n",
      "283 revenue:  4.886963844299316 rgt:  0.06443508714437485 loss:  -1.8923720121383667\n",
      "284 revenue:  4.888111114501953 rgt:  0.06376125663518906 loss:  -1.8946360349655151\n",
      "285 revenue:  4.905697345733643 rgt:  0.06490349024534225 loss:  -1.8952157497406006\n",
      "286 revenue:  4.905606746673584 rgt:  0.06449808925390244 loss:  -1.896397590637207\n",
      "287 revenue:  4.921826362609863 rgt:  0.0665505900979042 loss:  -1.8939943313598633\n",
      "288 revenue:  4.920403957366943 rgt:  0.06523053348064423 loss:  -1.8975651264190674\n",
      "289 revenue:  4.933063983917236 rgt:  0.06790732592344284 loss:  -1.8925526142120361\n",
      "290 revenue:  4.926401615142822 rgt:  0.05579053610563278 loss:  -1.9275591373443604\n",
      "291 revenue:  4.906814098358154 rgt:  0.06506671011447906 loss:  -1.894984483718872\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "292 revenue:  4.920324325561523 rgt:  0.06366988271474838 loss:  -1.902181625366211\n",
      "293 revenue:  4.936254501342773 rgt:  0.06502173095941544 loss:  -1.9017530679702759\n",
      "294 revenue:  4.937768459320068 rgt:  0.06471547484397888 loss:  -1.9030011892318726\n",
      "295 revenue:  4.951403617858887 rgt:  0.06553491950035095 loss:  -1.9036420583724976\n",
      "296 revenue:  4.954097270965576 rgt:  0.06551265716552734 loss:  -1.9043132066726685\n",
      "297 revenue:  4.968072414398193 rgt:  0.06651707738637924 loss:  -1.9044911861419678\n",
      "298 revenue:  4.9707465171813965 rgt:  0.06637588143348694 loss:  -1.9055062532424927\n",
      "299 revenue:  4.981992244720459 rgt:  0.06822214275598526 loss:  -1.902621865272522\n",
      "300 revenue:  4.977540493011475 rgt:  0.04910343140363693 loss:  -1.9603439569473267\n",
      "301 revenue:  4.969348430633545 rgt:  0.06674011796712875 loss:  -1.904122233390808\n",
      "302 revenue:  4.979767799377441 rgt:  0.06566444784402847 loss:  -1.9096240997314453\n",
      "303 revenue:  4.995376110076904 rgt:  0.06740091741085052 loss:  -1.9080159664154053\n",
      "304 revenue:  4.995887279510498 rgt:  0.06701409071683884 loss:  -1.909263253211975\n",
      "305 revenue:  5.006955146789551 rgt:  0.0675935372710228 loss:  -1.9100415706634521\n",
      "306 revenue:  5.008927822113037 rgt:  0.06758345663547516 loss:  -1.9105117321014404\n",
      "307 revenue:  5.0196685791015625 rgt:  0.0684129074215889 loss:  -1.9104900360107422\n",
      "308 revenue:  5.016273498535156 rgt:  0.06762413680553436 loss:  -1.9120333194732666\n",
      "309 revenue:  5.026958465576172 rgt:  0.06907527893781662 loss:  -1.9101910591125488\n",
      "310 revenue:  5.019992828369141 rgt:  0.052923284471035004 loss:  -1.9575601816177368\n",
      "311 revenue:  5.003320217132568 rgt:  0.06818386912345886 loss:  -1.9075058698654175\n",
      "312 revenue:  5.017239093780518 rgt:  0.06657292693853378 loss:  -1.9153292179107666\n",
      "313 revenue:  5.030124664306641 rgt:  0.06775031983852386 loss:  -1.9147547483444214\n",
      "314 revenue:  5.030045032501221 rgt:  0.06760619580745697 loss:  -1.9151580333709717\n",
      "315 revenue:  5.042129039764404 rgt:  0.06817412376403809 loss:  -1.9161927700042725\n",
      "316 revenue:  5.042603492736816 rgt:  0.06808870285749435 loss:  -1.916547417640686\n",
      "317 revenue:  5.054500102996826 rgt:  0.06890275329351425 loss:  -1.916825532913208\n",
      "318 revenue:  5.054317951202393 rgt:  0.0686921626329422 loss:  -1.9173970222473145\n",
      "319 revenue:  5.062739372253418 rgt:  0.06959127634763718 loss:  -1.9166603088378906\n",
      "320 revenue:  5.058684825897217 rgt:  0.04971228539943695 loss:  -1.976477026939392\n",
      "321 revenue:  5.049513816833496 rgt:  0.052439238876104355 loss:  -1.9656767845153809\n",
      "322 revenue:  5.059001445770264 rgt:  0.07150140404701233 loss:  -1.9103237390518188\n",
      "323 revenue:  5.069458484649658 rgt:  0.06912092864513397 loss:  -1.9195164442062378\n",
      "324 revenue:  5.066841125488281 rgt:  0.06876977533102036 loss:  -1.9199546575546265\n",
      "325 revenue:  5.074658393859863 rgt:  0.06899182498455048 loss:  -1.9210456609725952\n",
      "326 revenue:  5.07607889175415 rgt:  0.06902378052473068 loss:  -1.9212679862976074\n",
      "327 revenue:  5.085378170013428 rgt:  0.0737321749329567 loss:  -1.9098094701766968\n",
      "328 revenue:  5.078543186187744 rgt:  0.07666925340890884 loss:  -1.900001049041748\n",
      "329 revenue:  5.0591511726379395 rgt:  0.0762089341878891 loss:  -1.8969870805740356\n",
      "330 revenue:  5.060274600982666 rgt:  0.04037864878773689 loss:  -2.0081825256347656\n",
      "331 revenue:  5.050799369812012 rgt:  0.05036414414644241 loss:  -1.9726146459579468\n",
      "332 revenue:  5.065279483795166 rgt:  0.07021556794643402 loss:  -1.9154196977615356\n",
      "333 revenue:  5.076169967651367 rgt:  0.06873243302106857 loss:  -1.9221347570419312\n",
      "334 revenue:  5.081145763397217 rgt:  0.0682128444314003 loss:  -1.9247509241104126\n",
      "335 revenue:  5.092945575714111 rgt:  0.06879308074712753 loss:  -1.9256782531738281\n",
      "336 revenue:  5.091306209564209 rgt:  0.06846736371517181 loss:  -1.9262621402740479\n",
      "337 revenue:  5.107381820678711 rgt:  0.06974033266305923 loss:  -1.926127552986145\n",
      "338 revenue:  5.10272216796875 rgt:  0.0690242350101471 loss:  -1.9271718263626099\n",
      "339 revenue:  5.116641044616699 rgt:  0.07017960399389267 loss:  -1.9269055128097534\n",
      "340 revenue:  5.111523151397705 rgt:  0.05972561985254288 loss:  -1.9567538499832153\n",
      "341 revenue:  5.1011223793029785 rgt:  0.06385490298271179 loss:  -1.9420161247253418\n",
      "342 revenue:  5.107645511627197 rgt:  0.06948383897542953 loss:  -1.9269282817840576\n",
      "343 revenue:  5.117766857147217 rgt:  0.06961285322904587 loss:  -1.928792953491211\n",
      "344 revenue:  5.117234230041504 rgt:  0.07041964679956436 loss:  -1.9263437986373901\n",
      "345 revenue:  5.125687599182129 rgt:  0.07496541738510132 loss:  -1.9152345657348633\n",
      "346 revenue:  5.113039970397949 rgt:  0.07507737725973129 loss:  -1.9121233224868774\n",
      "347 revenue:  5.099577903747559 rgt:  0.07448393851518631 loss:  -1.9108229875564575\n",
      "348 revenue:  5.104724884033203 rgt:  0.07657954096794128 loss:  -1.9060542583465576\n",
      "349 revenue:  5.088966369628906 rgt:  0.07635753601789474 loss:  -1.9031875133514404\n",
      "350 revenue:  5.069083213806152 rgt:  0.05907822400331497 loss:  -1.949324131011963\n",
      "351 revenue:  5.059609889984131 rgt:  0.06455286592245102 loss:  -1.930732250213623\n",
      "352 revenue:  5.08729887008667 rgt:  0.06612443178892136 loss:  -1.9322329759597778\n",
      "353 revenue:  5.109189987182617 rgt:  0.06736065447330475 loss:  -1.9334516525268555\n",
      "354 revenue:  5.117317199707031 rgt:  0.06798437982797623 loss:  -1.9334263801574707\n",
      "355 revenue:  5.12192440032959 rgt:  0.06808432191610336 loss:  -1.9341527223587036\n",
      "356 revenue:  5.129570484161377 rgt:  0.06881103664636612 loss:  -1.9337259531021118\n",
      "357 revenue:  5.131899833679199 rgt:  0.06869068741798401 loss:  -1.9345899820327759\n",
      "358 revenue:  5.13980770111084 rgt:  0.06944308429956436 loss:  -1.9341508150100708\n",
      "359 revenue:  5.140690803527832 rgt:  0.06919195502996445 loss:  -1.9350736141204834\n",
      "360 revenue:  5.148484230041504 rgt:  0.06022179126739502 loss:  -1.9634040594100952\n",
      "361 revenue:  5.145240306854248 rgt:  0.06971831619739532 loss:  -1.93455171585083\n",
      "362 revenue:  5.146040439605713 rgt:  0.06894329190254211 loss:  -1.9369747638702393\n",
      "363 revenue:  5.152850151062012 rgt:  0.07034841924905777 loss:  -1.9344078302383423\n",
      "364 revenue:  5.139283180236816 rgt:  0.06840003281831741 loss:  -1.93706476688385\n",
      "365 revenue:  5.154443740844727 rgt:  0.06980671733617783 loss:  -1.9363237619400024\n",
      "366 revenue:  5.148268699645996 rgt:  0.06888463348150253 loss:  -1.937636137008667\n",
      "367 revenue:  5.162783622741699 rgt:  0.07030069828033447 loss:  -1.9367326498031616\n",
      "368 revenue:  5.153249740600586 rgt:  0.07217516005039215 loss:  -1.929247498512268\n",
      "369 revenue:  5.152748107910156 rgt:  0.0754590854048729 loss:  -1.919809341430664\n",
      "370 revenue:  5.145654678344727 rgt:  0.056148454546928406 loss:  -1.975298523902893\n",
      "371 revenue:  5.134617328643799 rgt:  0.06876004487276077 loss:  -1.9349881410598755\n",
      "372 revenue:  5.150171756744385 rgt:  0.06832776963710785 loss:  -1.9396754503250122\n",
      "373 revenue:  5.164593696594238 rgt:  0.06993094086647034 loss:  -1.9381986856460571\n",
      "374 revenue:  5.154696941375732 rgt:  0.06854892522096634 loss:  -1.940028429031372\n",
      "375 revenue:  5.17003870010376 rgt:  0.06994611024856567 loss:  -1.9393527507781982\n",
      "376 revenue:  5.159394264221191 rgt:  0.06869402527809143 loss:  -1.9406405687332153\n",
      "377 revenue:  5.173523426055908 rgt:  0.06997514516115189 loss:  -1.9400346279144287\n",
      "378 revenue:  5.163192272186279 rgt:  0.06879698485136032 loss:  -1.9411770105361938\n",
      "379 revenue:  5.176826477050781 rgt:  0.07003253698348999 loss:  -1.9405949115753174\n",
      "380 revenue:  5.166097640991211 rgt:  0.056786809116601944 loss:  -1.977818489074707\n",
      "381 revenue:  5.15834903717041 rgt:  0.06236245483160019 loss:  -1.9591126441955566\n",
      "382 revenue:  5.168922424316406 rgt:  0.06862010061740875 loss:  -1.942952036857605\n",
      "383 revenue:  5.177367210388184 rgt:  0.0699450671672821 loss:  -1.9409663677215576\n",
      "384 revenue:  5.175790786743164 rgt:  0.06969422101974487 loss:  -1.941345453262329\n",
      "385 revenue:  5.183023929595947 rgt:  0.07039908319711685 loss:  -1.9408984184265137\n",
      "386 revenue:  5.179866790771484 rgt:  0.07490527629852295 loss:  -1.9273384809494019\n",
      "387 revenue:  5.164862155914307 rgt:  0.07549729198217392 loss:  -1.9223684072494507\n",
      "388 revenue:  5.1762590408325195 rgt:  0.07692879438400269 loss:  -1.9208500385284424\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "389 revenue:  5.174312591552734 rgt:  0.0776883214712143 loss:  -1.9182970523834229\n",
      "390 revenue:  5.164597988128662 rgt:  0.062478866428136826 loss:  -1.9601384401321411\n",
      "391 revenue:  5.150591850280762 rgt:  0.0673910453915596 loss:  -1.9425026178359985\n",
      "392 revenue:  5.172674655914307 rgt:  0.06894950568675995 loss:  -1.9428198337554932\n",
      "393 revenue:  5.179988861083984 rgt:  0.06927605718374252 loss:  -1.943479299545288\n",
      "394 revenue:  5.174391269683838 rgt:  0.06847166270017624 loss:  -1.9445862770080566\n",
      "395 revenue:  5.179650783538818 rgt:  0.06870156526565552 loss:  -1.9450733661651611\n",
      "396 revenue:  5.177100658416748 rgt:  0.06837493926286697 loss:  -1.9454632997512817\n",
      "397 revenue:  5.186302185058594 rgt:  0.06907065212726593 loss:  -1.9454618692398071\n",
      "398 revenue:  5.18058443069458 rgt:  0.06843692809343338 loss:  -1.9460481405258179\n",
      "399 revenue:  5.187923908233643 rgt:  0.06901407986879349 loss:  -1.9459819793701172\n",
      "400 revenue:  5.182894229888916 rgt:  0.05646362528204918 loss:  -1.9825125932693481\n",
      "401 revenue:  5.181572437286377 rgt:  0.0692279115319252 loss:  -1.9439668655395508\n",
      "402 revenue:  5.182872295379639 rgt:  0.06846395879983902 loss:  -1.9464720487594604\n",
      "403 revenue:  5.184175491333008 rgt:  0.06841331720352173 loss:  -1.9469056129455566\n",
      "404 revenue:  5.1854047775268555 rgt:  0.06839510798454285 loss:  -1.9472286701202393\n",
      "405 revenue:  5.186557769775391 rgt:  0.06840550154447556 loss:  -1.9474514722824097\n",
      "406 revenue:  5.1875433921813965 rgt:  0.06843601912260056 loss:  -1.947579026222229\n",
      "407 revenue:  5.1883625984191895 rgt:  0.06848327815532684 loss:  -1.947621464729309\n",
      "408 revenue:  5.188905239105225 rgt:  0.06850791722536087 loss:  -1.9476687908172607\n",
      "409 revenue:  5.188933849334717 rgt:  0.0684874951839447 loss:  -1.9477344751358032\n",
      "410 revenue:  5.18882942199707 rgt:  0.06434743851423264 loss:  -1.959884762763977\n",
      "411 revenue:  5.188087463378906 rgt:  0.06857237964868546 loss:  -1.9473017454147339\n",
      "412 revenue:  5.188509941101074 rgt:  0.06839863210916519 loss:  -1.9479001760482788\n",
      "413 revenue:  5.188501358032227 rgt:  0.06838184595108032 loss:  -1.9479472637176514\n",
      "414 revenue:  5.1877570152282715 rgt:  0.06829226016998291 loss:  -1.9480446577072144\n",
      "415 revenue:  5.188002109527588 rgt:  0.06830374896526337 loss:  -1.948064923286438\n",
      "416 revenue:  5.187180042266846 rgt:  0.06820633262395859 loss:  -1.9481682777404785\n",
      "417 revenue:  5.18735933303833 rgt:  0.06821200251579285 loss:  -1.9481911659240723\n",
      "418 revenue:  5.186549186706543 rgt:  0.06811408698558807 loss:  -1.948298692703247\n",
      "419 revenue:  5.186666488647461 rgt:  0.06811337172985077 loss:  -1.948326587677002\n",
      "420 revenue:  5.185800552368164 rgt:  0.05459275096654892 loss:  -1.988991618156433\n",
      "421 revenue:  5.185243606567383 rgt:  0.06902307271957397 loss:  -1.9453673362731934\n",
      "422 revenue:  5.185800075531006 rgt:  0.0679931715130806 loss:  -1.9484870433807373\n",
      "423 revenue:  5.18678092956543 rgt:  0.06807240843772888 loss:  -1.948471188545227\n",
      "424 revenue:  5.185957908630371 rgt:  0.06797728687524796 loss:  -1.9485679864883423\n",
      "425 revenue:  5.185741424560547 rgt:  0.06794364005327225 loss:  -1.948618769645691\n",
      "426 revenue:  5.184839248657227 rgt:  0.06783846765756607 loss:  -1.9487276077270508\n",
      "427 revenue:  5.185309886932373 rgt:  0.06787215173244476 loss:  -1.9487324953079224\n",
      "428 revenue:  5.1844916343688965 rgt:  0.06777343153953552 loss:  -1.9488412141799927\n",
      "429 revenue:  5.185187339782715 rgt:  0.06783244013786316 loss:  -1.9488215446472168\n",
      "430 revenue:  5.184309959411621 rgt:  0.06299515068531036 loss:  -1.9629244804382324\n",
      "431 revenue:  5.1835503578186035 rgt:  0.0678996667265892 loss:  -1.9482660293579102\n",
      "432 revenue:  5.18397855758667 rgt:  0.06768403202295303 loss:  -1.9489895105361938\n",
      "433 revenue:  5.184841156005859 rgt:  0.06773761659860611 loss:  -1.9490227699279785\n",
      "434 revenue:  5.183938026428223 rgt:  0.06763565540313721 loss:  -1.9491220712661743\n",
      "435 revenue:  5.1844868659973145 rgt:  0.0676816999912262 loss:  -1.9491080045700073\n",
      "436 revenue:  5.183769226074219 rgt:  0.06759480386972427 loss:  -1.949204444885254\n",
      "437 revenue:  5.184088230133057 rgt:  0.06761574745178223 loss:  -1.9492132663726807\n",
      "438 revenue:  5.183298587799072 rgt:  0.06752003729343414 loss:  -1.9493197202682495\n",
      "439 revenue:  5.183909893035889 rgt:  0.0675700306892395 loss:  -1.949307918548584\n",
      "440 revenue:  5.183106422424316 rgt:  0.06355981528759003 loss:  -1.9609732627868652\n",
      "441 revenue:  5.182241439819336 rgt:  0.06744350492954254 loss:  -1.949311375617981\n",
      "442 revenue:  5.18270206451416 rgt:  0.06741273403167725 loss:  -1.9495025873184204\n",
      "443 revenue:  5.183023929595947 rgt:  0.06741896271705627 loss:  -1.9495550394058228\n",
      "444 revenue:  5.182884216308594 rgt:  0.06739415973424911 loss:  -1.9495970010757446\n",
      "445 revenue:  5.183378219604492 rgt:  0.06743545085191727 loss:  -1.9495844841003418\n",
      "446 revenue:  5.18252420425415 rgt:  0.06733566522598267 loss:  -1.9496889114379883\n",
      "447 revenue:  5.183081150054932 rgt:  0.06738001853227615 loss:  -1.9496814012527466\n",
      "448 revenue:  5.182219982147217 rgt:  0.06727725267410278 loss:  -1.9497931003570557\n",
      "449 revenue:  5.182592868804932 rgt:  0.06730270385742188 loss:  -1.949800729751587\n",
      "450 revenue:  5.18173885345459 rgt:  0.04985637962818146 loss:  -2.003201484680176\n",
      "451 revenue:  5.181229114532471 rgt:  0.06856049597263336 loss:  -1.945830225944519\n",
      "452 revenue:  5.1816630363464355 rgt:  0.067184679210186 loss:  -1.949941873550415\n",
      "453 revenue:  5.182592868804932 rgt:  0.06724145263433456 loss:  -1.9499800205230713\n",
      "454 revenue:  5.181718349456787 rgt:  0.06714680045843124 loss:  -1.9500651359558105\n",
      "455 revenue:  5.18145751953125 rgt:  0.06710770726203918 loss:  -1.950122356414795\n",
      "456 revenue:  5.180546283721924 rgt:  0.06700544059276581 loss:  -1.9502217769622803\n",
      "457 revenue:  5.180519104003906 rgt:  0.06699024885892868 loss:  -1.9502602815628052\n",
      "458 revenue:  5.179777145385742 rgt:  0.06690236181020737 loss:  -1.950355052947998\n",
      "459 revenue:  5.179657459259033 rgt:  0.06687714159488678 loss:  -1.9504027366638184\n",
      "460 revenue:  5.1790595054626465 rgt:  0.05561443045735359 loss:  -1.9843130111694336\n",
      "461 revenue:  5.178461074829102 rgt:  0.06751711666584015 loss:  -1.9482656717300415\n",
      "462 revenue:  5.1788716316223145 rgt:  0.06677576899528503 loss:  -1.9505276679992676\n",
      "463 revenue:  5.179672718048096 rgt:  0.06681766360998154 loss:  -1.9505807161331177\n",
      "464 revenue:  5.179049491882324 rgt:  0.06674991548061371 loss:  -1.950642466545105\n",
      "465 revenue:  5.179185390472412 rgt:  0.06675467640161514 loss:  -1.9506584405899048\n",
      "466 revenue:  5.178538799285889 rgt:  0.06667777895927429 loss:  -1.9507420063018799\n",
      "467 revenue:  5.178248405456543 rgt:  0.06663387268781662 loss:  -1.9508074522018433\n",
      "468 revenue:  5.177776336669922 rgt:  0.06657378375530243 loss:  -1.9508801698684692\n",
      "469 revenue:  5.177848815917969 rgt:  0.0665670782327652 loss:  -1.9509156942367554\n",
      "470 revenue:  5.1773786544799805 rgt:  0.05933954194188118 loss:  -1.9724488258361816\n",
      "471 revenue:  5.1766886711120605 rgt:  0.06700920313596725 loss:  -1.9493632316589355\n",
      "472 revenue:  5.177402973175049 rgt:  0.06650982797145844 loss:  -1.9509857892990112\n",
      "473 revenue:  5.177791118621826 rgt:  0.0665053054690361 loss:  -1.9510844945907593\n",
      "474 revenue:  5.1774373054504395 rgt:  0.06646236032247543 loss:  -1.951132893562317\n",
      "475 revenue:  5.177089691162109 rgt:  0.06641645729541779 loss:  -1.9511916637420654\n",
      "476 revenue:  5.176650047302246 rgt:  0.06636124104261398 loss:  -1.9512572288513184\n",
      "477 revenue:  5.177396774291992 rgt:  0.06642524152994156 loss:  -1.9512332677841187\n",
      "478 revenue:  5.176507472991943 rgt:  0.06632327288389206 loss:  -1.9513375759124756\n",
      "479 revenue:  5.176924705505371 rgt:  0.0663522258400917 loss:  -1.9513441324234009\n",
      "480 revenue:  5.17608118057251 rgt:  0.06095567345619202 loss:  -1.9672526121139526\n",
      "481 revenue:  5.175405979156494 rgt:  0.066597580909729 loss:  -1.9502893686294556\n",
      "482 revenue:  5.176242351531982 rgt:  0.06625501066446304 loss:  -1.9514802694320679\n",
      "483 revenue:  5.176848888397217 rgt:  0.06629110127687454 loss:  -1.951507329940796\n",
      "484 revenue:  5.175926685333252 rgt:  0.06619041413068771 loss:  -1.9516009092330933\n",
      "485 revenue:  5.1763505935668945 rgt:  0.06622319668531418 loss:  -1.9515974521636963\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "486 revenue:  5.175485134124756 rgt:  0.06612555682659149 loss:  -1.9516948461532593\n",
      "487 revenue:  5.176158905029297 rgt:  0.06618071347475052 loss:  -1.9516806602478027\n",
      "488 revenue:  5.17537260055542 rgt:  0.06609073281288147 loss:  -1.9517725706100464\n",
      "489 revenue:  5.175660610198975 rgt:  0.06610497087240219 loss:  -1.9517937898635864\n",
      "490 revenue:  5.174873352050781 rgt:  0.053409624844789505 loss:  -1.9903199672698975\n",
      "491 revenue:  5.174311637878418 rgt:  0.06712140142917633 loss:  -1.9485119581222534\n",
      "492 revenue:  5.174789905548096 rgt:  0.06600290536880493 loss:  -1.9519033432006836\n",
      "493 revenue:  5.175207614898682 rgt:  0.06601358205080032 loss:  -1.9519636631011963\n",
      "494 revenue:  5.174697399139404 rgt:  0.0659550353884697 loss:  -1.9520238637924194\n",
      "495 revenue:  5.175355911254883 rgt:  0.06600181758403778 loss:  -1.9520310163497925\n",
      "496 revenue:  5.174675941467285 rgt:  0.06593230366706848 loss:  -1.9520864486694336\n",
      "497 revenue:  5.175191879272461 rgt:  0.06596239656209946 loss:  -1.9521108865737915\n",
      "498 revenue:  5.174169063568115 rgt:  0.06585673987865448 loss:  -1.952197551727295\n",
      "499 revenue:  5.1748762130737305 rgt:  0.06590589880943298 loss:  -1.9522079229354858\n",
      "500 revenue:  5.173756122589111 rgt:  0.06404727697372437 loss:  -1.9574663639068604\n",
      "501 revenue:  5.172688961029053 rgt:  0.06567741930484772 loss:  -1.9524011611938477\n",
      "502 revenue:  5.173929214477539 rgt:  0.06576582789421082 loss:  -1.9524128437042236\n",
      "503 revenue:  5.1746344566345215 rgt:  0.0658264011144638 loss:  -1.9523892402648926\n",
      "504 revenue:  5.1739349365234375 rgt:  0.06575581431388855 loss:  -1.9524438381195068\n",
      "505 revenue:  5.1739630699157715 rgt:  0.06574567407369614 loss:  -1.9524797201156616\n",
      "506 revenue:  5.173509120941162 rgt:  0.06569377332925797 loss:  -1.9525333642959595\n",
      "507 revenue:  5.173422336578369 rgt:  0.06566914916038513 loss:  -1.9525867700576782\n",
      "508 revenue:  5.173173904418945 rgt:  0.06563666462898254 loss:  -1.9526281356811523\n",
      "509 revenue:  5.173230171203613 rgt:  0.06562566757202148 loss:  -1.9526729583740234\n",
      "510 revenue:  5.1729655265808105 rgt:  0.060155972838401794 loss:  -1.9689923524856567\n",
      "511 revenue:  5.172196388244629 rgt:  0.06593824177980423 loss:  -1.9515235424041748\n",
      "512 revenue:  5.172717571258545 rgt:  0.06554940342903137 loss:  -1.9527852535247803\n",
      "513 revenue:  5.173654556274414 rgt:  0.06562107801437378 loss:  -1.9527795314788818\n",
      "514 revenue:  5.173419952392578 rgt:  0.06559141725301743 loss:  -1.9528156518936157\n",
      "515 revenue:  5.173257827758789 rgt:  0.06556020677089691 loss:  -1.9528721570968628\n",
      "516 revenue:  5.172279357910156 rgt:  0.06545262038707733 loss:  -1.952974796295166\n",
      "517 revenue:  5.172440528869629 rgt:  0.06545284390449524 loss:  -1.953009843826294\n",
      "518 revenue:  5.17216682434082 rgt:  0.06541719287633896 loss:  -1.9530547857284546\n",
      "519 revenue:  5.172374725341797 rgt:  0.06542092561721802 loss:  -1.9530894756317139\n",
      "520 revenue:  5.1721930503845215 rgt:  0.06596112996339798 loss:  -1.9514553546905518\n",
      "521 revenue:  5.171300888061523 rgt:  0.06526263058185577 loss:  -1.9533213376998901\n",
      "522 revenue:  5.172532558441162 rgt:  0.06539728492498398 loss:  -1.9531939029693604\n",
      "523 revenue:  5.172097206115723 rgt:  0.0653461143374443 loss:  -1.9532495737075806\n",
      "524 revenue:  5.172320365905762 rgt:  0.06535407900810242 loss:  -1.9532749652862549\n",
      "525 revenue:  5.171173095703125 rgt:  0.06523603945970535 loss:  -1.9533717632293701\n",
      "526 revenue:  5.1721577644348145 rgt:  0.06531614810228348 loss:  -1.9533514976501465\n",
      "527 revenue:  5.171051979064941 rgt:  0.06520086526870728 loss:  -1.9534492492675781\n",
      "528 revenue:  5.172107219696045 rgt:  0.06528622657060623 loss:  -1.9534286260604858\n",
      "529 revenue:  5.1710028648376465 rgt:  0.06517121195793152 loss:  -1.953526258468628\n",
      "530 revenue:  5.172182559967041 rgt:  0.058081675320863724 loss:  -1.9751603603363037\n",
      "531 revenue:  5.171504497528076 rgt:  0.06586787849664688 loss:  -1.9515788555145264\n",
      "532 revenue:  5.171913146972656 rgt:  0.06524309515953064 loss:  -1.953513503074646\n",
      "533 revenue:  5.171389102935791 rgt:  0.065169557929039 loss:  -1.9536159038543701\n",
      "534 revenue:  5.172295093536377 rgt:  0.06523380428552628 loss:  -1.9536253213882446\n",
      "535 revenue:  5.171115875244141 rgt:  0.06511470675468445 loss:  -1.9537181854248047\n",
      "536 revenue:  5.172333717346191 rgt:  0.06521588563919067 loss:  -1.9536867141723633\n",
      "537 revenue:  5.17119026184082 rgt:  0.06509765237569809 loss:  -1.9537850618362427\n",
      "538 revenue:  5.172370433807373 rgt:  0.06519504636526108 loss:  -1.953756332397461\n",
      "539 revenue:  5.1711955070495605 rgt:  0.06507328897714615 loss:  -1.9538583755493164\n",
      "540 revenue:  5.1722731590271 rgt:  0.056987591087818146 loss:  -1.9785548448562622\n",
      "541 revenue:  5.171637535095215 rgt:  0.06586401164531708 loss:  -1.9516197443008423\n",
      "542 revenue:  5.172255992889404 rgt:  0.06516024470329285 loss:  -1.953834056854248\n",
      "543 revenue:  5.17149543762207 rgt:  0.0650528147816658 loss:  -1.9539848566055298\n",
      "544 revenue:  5.1718668937683105 rgt:  0.0650695264339447 loss:  -1.9540170431137085\n",
      "545 revenue:  5.171325206756592 rgt:  0.06501466035842896 loss:  -1.9540603160858154\n",
      "546 revenue:  5.172277450561523 rgt:  0.06508906930685043 loss:  -1.9540494680404663\n",
      "547 revenue:  5.171145915985107 rgt:  0.06497129052877426 loss:  -1.9541493654251099\n",
      "548 revenue:  5.172120094299316 rgt:  0.06504832208156586 loss:  -1.954135537147522\n",
      "549 revenue:  5.171041965484619 rgt:  0.0649355873465538 loss:  -1.9542323350906372\n",
      "550 revenue:  5.172028064727783 rgt:  0.05718512460589409 loss:  -1.9778900146484375\n",
      "551 revenue:  5.171372413635254 rgt:  0.06570993363857269 loss:  -1.95201575756073\n",
      "552 revenue:  5.171983242034912 rgt:  0.06501873582601547 loss:  -1.9541929960250854\n",
      "553 revenue:  5.171522617340088 rgt:  0.06493023037910461 loss:  -1.9543538093566895\n",
      "554 revenue:  5.171806335449219 rgt:  0.06493981927633286 loss:  -1.9543877840042114\n",
      "555 revenue:  5.171424865722656 rgt:  0.0649004578590393 loss:  -1.954420566558838\n",
      "556 revenue:  5.171392917633057 rgt:  0.06487894058227539 loss:  -1.954477310180664\n",
      "557 revenue:  5.171027183532715 rgt:  0.06484091281890869 loss:  -1.9545096158981323\n",
      "558 revenue:  5.171614646911621 rgt:  0.06487837433815002 loss:  -1.954527735710144\n",
      "559 revenue:  5.170757293701172 rgt:  0.06478908658027649 loss:  -1.954603672027588\n",
      "560 revenue:  5.171887397766113 rgt:  0.062343671917915344 loss:  -1.96214759349823\n",
      "561 revenue:  5.171109199523926 rgt:  0.06496342271566391 loss:  -1.9541646242141724\n",
      "562 revenue:  5.171112537384033 rgt:  0.0647892877459526 loss:  -1.954681396484375\n",
      "563 revenue:  5.171100616455078 rgt:  0.06476373225450516 loss:  -1.95475435256958\n",
      "564 revenue:  5.171760082244873 rgt:  0.06481009721755981 loss:  -1.9547619819641113\n",
      "565 revenue:  5.1706695556640625 rgt:  0.06470085680484772 loss:  -1.9548461437225342\n",
      "566 revenue:  5.171847820281982 rgt:  0.06479769200086594 loss:  -1.9548180103302002\n",
      "567 revenue:  5.170717239379883 rgt:  0.06468217074871063 loss:  -1.9549120664596558\n",
      "568 revenue:  5.171896934509277 rgt:  0.06477820873260498 loss:  -1.954886555671692\n",
      "569 revenue:  5.170766830444336 rgt:  0.06466247886419296 loss:  -1.9549813270568848\n",
      "570 revenue:  5.171972751617432 rgt:  0.0664822980761528 loss:  -1.9498732089996338\n",
      "571 revenue:  5.17174768447876 rgt:  0.06462323665618896 loss:  -1.9553135633468628\n",
      "572 revenue:  5.1714301109313965 rgt:  0.06469065696001053 loss:  -1.9550436735153198\n",
      "573 revenue:  5.170806407928467 rgt:  0.06461887061595917 loss:  -1.9551196098327637\n",
      "574 revenue:  5.1720356941223145 rgt:  0.06472207605838776 loss:  -1.9550836086273193\n",
      "575 revenue:  5.1709184646606445 rgt:  0.06460879743099213 loss:  -1.9551739692687988\n",
      "576 revenue:  5.17212438583374 rgt:  0.06470789015293121 loss:  -1.955145239830017\n",
      "577 revenue:  5.170928955078125 rgt:  0.06458618491888046 loss:  -1.9552435874938965\n",
      "578 revenue:  5.172054767608643 rgt:  0.06467634439468384 loss:  -1.955223560333252\n",
      "579 revenue:  5.171052932739258 rgt:  0.0645742118358612 loss:  -1.955306053161621\n",
      "580 revenue:  5.172152042388916 rgt:  0.05909406393766403 loss:  -1.9720498323440552\n",
      "581 revenue:  5.1714582443237305 rgt:  0.06505803018808365 loss:  -1.9539613723754883\n",
      "582 revenue:  5.1721014976501465 rgt:  0.06464055180549622 loss:  -1.9553399085998535\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583 revenue:  5.171077728271484 rgt:  0.06453879922628403 loss:  -1.9554167985916138\n",
      "584 revenue:  5.172230243682861 rgt:  0.06462889909744263 loss:  -1.9554028511047363\n",
      "585 revenue:  5.171216011047363 rgt:  0.0645253136754036 loss:  -1.9554870128631592\n",
      "586 revenue:  5.172245025634766 rgt:  0.06460418552160263 loss:  -1.9554792642593384\n",
      "587 revenue:  5.171082973480225 rgt:  0.06448542326688766 loss:  -1.9555763006210327\n",
      "588 revenue:  5.172301292419434 rgt:  0.06458543241024017 loss:  -1.9555473327636719\n",
      "589 revenue:  5.171138763427734 rgt:  0.06446556746959686 loss:  -1.9556474685668945\n",
      "590 revenue:  5.172348499298096 rgt:  0.061232633888721466 loss:  -1.9655948877334595\n",
      "591 revenue:  5.1716413497924805 rgt:  0.06480640172958374 loss:  -1.954746961593628\n",
      "592 revenue:  5.172403335571289 rgt:  0.0645546242594719 loss:  -1.9556611776351929\n",
      "593 revenue:  5.171549320220947 rgt:  0.06446006894111633 loss:  -1.955754280090332\n",
      "594 revenue:  5.17280912399292 rgt:  0.06456439942121506 loss:  -1.9557214975357056\n",
      "595 revenue:  5.171675682067871 rgt:  0.0644487664103508 loss:  -1.9558154344558716\n",
      "596 revenue:  5.172881603240967 rgt:  0.06454851478338242 loss:  -1.9557843208312988\n",
      "597 revenue:  5.171706676483154 rgt:  0.06442950665950775 loss:  -1.9558794498443604\n",
      "598 revenue:  5.172916412353516 rgt:  0.0645282194018364 loss:  -1.9558522701263428\n",
      "599 revenue:  5.171744346618652 rgt:  0.06440933048725128 loss:  -1.955947756767273\n"
     ]
    }
   ],
   "source": [
    "training_set = train_set_no_prob\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": "a75ae301",
   "metadata": {},
   "source": [
    "# Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "774688a7",
   "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": [
      "5.172068119049072 0.06518134474754333 4.076004691794577\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_no_prob)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "d173c250",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8160191178321838 0.014704270288348198 0.6116438074283655\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_1)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "668653df",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1.917839765548706 0.02984047122299671 1.469227554328914\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_2)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "7fac5483",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.2973039150238037 0.046599380671978 2.559933091345138\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_3)\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3049ef95",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca6521f1",
   "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
}
