{
 "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_3 = get_train_or_test_set(batch_size,n,m,prob_single_3)\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": "e285ed39",
   "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.9536595344543457 rgt:  0.27140292525291443 loss:  -0.184188574552536\n",
      "1 revenue:  0.9340193271636963 rgt:  0.29621654748916626 loss:  -0.12597239017486572\n",
      "2 revenue:  0.9122492074966431 rgt:  0.29869794845581055 loss:  -0.10988682508468628\n",
      "3 revenue:  0.8888064026832581 rgt:  0.2941780090332031 loss:  -0.1062055230140686\n",
      "4 revenue:  0.8628962635993958 rgt:  0.28644445538520813 loss:  -0.10727259516716003\n",
      "5 revenue:  0.832930862903595 rgt:  0.27608686685562134 loss:  -0.11112391948699951\n",
      "6 revenue:  0.7968012690544128 rgt:  0.26224571466445923 loss:  -0.11829221248626709\n",
      "7 revenue:  0.7523201107978821 rgt:  0.2429259866476059 loss:  -0.13156266510486603\n",
      "8 revenue:  0.698516309261322 rgt:  0.2148221731185913 loss:  -0.15746158361434937\n",
      "9 revenue:  0.639401376247406 rgt:  0.17313942313194275 loss:  -0.21038606762886047\n",
      "10 revenue:  0.5865421891212463 rgt:  0.09774348884820938 loss:  -0.35547739267349243\n",
      "11 revenue:  0.5494158864021301 rgt:  0.037841781973838806 loss:  -0.5088545083999634\n",
      "12 revenue:  0.667529284954071 rgt:  0.025281768292188644 loss:  -0.6327404379844666\n",
      "13 revenue:  0.8456400036811829 rgt:  0.021335845813155174 loss:  -0.7521830797195435\n",
      "14 revenue:  1.0125786066055298 rgt:  0.01367500051856041 loss:  -0.8756545782089233\n",
      "15 revenue:  1.2105220556259155 rgt:  0.011740005575120449 loss:  -0.9801459312438965\n",
      "16 revenue:  1.4098020792007446 rgt:  0.06148893013596535 loss:  -0.8778923153877258\n",
      "17 revenue:  1.3341675996780396 rgt:  0.015153181739151478 loss:  -1.0168102979660034\n",
      "18 revenue:  1.4650802612304688 rgt:  0.019657989963889122 loss:  -1.0505400896072388\n",
      "19 revenue:  1.650186538696289 rgt:  0.04464707151055336 loss:  -1.028650164604187\n",
      "20 revenue:  1.3767712116241455 rgt:  0.00724529754370451 loss:  -1.0809942483901978\n",
      "21 revenue:  1.7917503118515015 rgt:  0.04813189059495926 loss:  -1.0710409879684448\n",
      "22 revenue:  1.4865753650665283 rgt:  0.0058390372432768345 loss:  -1.1369993686676025\n",
      "23 revenue:  1.9739066362380981 rgt:  0.059735532850027084 loss:  -1.100813865661621\n",
      "24 revenue:  1.646546483039856 rgt:  0.006108394358307123 loss:  -1.1989136934280396\n",
      "25 revenue:  2.2537643909454346 rgt:  0.08279286324977875 loss:  -1.1307239532470703\n",
      "26 revenue:  1.890150785446167 rgt:  0.011152884922921658 loss:  -1.2580673694610596\n",
      "27 revenue:  2.62688946723938 rgt:  0.11717575043439865 loss:  -1.161283016204834\n",
      "28 revenue:  2.1781811714172363 rgt:  0.026895632967352867 loss:  -1.2849717140197754\n",
      "29 revenue:  2.9692375659942627 rgt:  0.1529201865196228 loss:  -1.1791772842407227\n",
      "30 revenue:  2.4396779537200928 rgt:  0.04227862507104874 loss:  -1.314050555229187\n",
      "31 revenue:  3.2598941326141357 rgt:  0.18004374206066132 loss:  -1.2011584043502808\n",
      "32 revenue:  2.6928865909576416 rgt:  0.06348655372858047 loss:  -1.3255497217178345\n",
      "33 revenue:  3.5151703357696533 rgt:  0.21752119064331055 loss:  -1.1909658908843994\n",
      "34 revenue:  2.7780652046203613 rgt:  0.06776683032512665 loss:  -1.33866548538208\n",
      "35 revenue:  3.5885183811187744 rgt:  0.22719846665859222 loss:  -1.1904865503311157\n",
      "36 revenue:  2.8549115657806396 rgt:  0.07380945980548859 loss:  -1.3441599607467651\n",
      "37 revenue:  3.6463053226470947 rgt:  0.2365056723356247 loss:  -1.1867060661315918\n",
      "38 revenue:  2.9253175258636475 rgt:  0.0800231471657753 loss:  -1.3474491834640503\n",
      "39 revenue:  3.7036585807800293 rgt:  0.24706140160560608 loss:  -1.1803749799728394\n",
      "40 revenue:  2.9816360473632812 rgt:  0.08519746363162994 loss:  -1.3496580123901367\n",
      "41 revenue:  3.7422115802764893 rgt:  0.21793584525585175 loss:  -1.2497079372406006\n",
      "42 revenue:  3.073364019393921 rgt:  0.0915328785777092 loss:  -1.3590244054794312\n",
      "43 revenue:  3.8296163082122803 rgt:  0.2320711314678192 loss:  -1.2431317567825317\n",
      "44 revenue:  3.1170623302459717 rgt:  0.09232321381568909 loss:  -1.3693499565124512\n",
      "45 revenue:  3.9080443382263184 rgt:  0.24367597699165344 loss:  -1.2395660877227783\n",
      "46 revenue:  3.1741461753845215 rgt:  0.09633181244134903 loss:  -1.3749078512191772\n",
      "47 revenue:  3.9221560955047607 rgt:  0.24625445902347565 loss:  -1.2379486560821533\n",
      "48 revenue:  3.196943998336792 rgt:  0.09777607768774033 loss:  -1.3775322437286377\n",
      "49 revenue:  3.9590439796447754 rgt:  0.25730252265930176 loss:  -1.2251821756362915\n",
      "50 revenue:  3.21219801902771 rgt:  0.0992860272526741 loss:  -1.3778777122497559\n",
      "51 revenue:  3.9833993911743164 rgt:  0.23798440396785736 loss:  -1.2700246572494507\n",
      "52 revenue:  3.2666854858398438 rgt:  0.10232368111610413 loss:  -1.385193109512329\n",
      "53 revenue:  4.025750160217285 rgt:  0.24818474054336548 loss:  -1.2600610256195068\n",
      "54 revenue:  3.292750597000122 rgt:  0.10309796780347824 loss:  -1.3904070854187012\n",
      "55 revenue:  4.062582492828369 rgt:  0.2541573941707611 loss:  -1.2572872638702393\n",
      "56 revenue:  3.355889081954956 rgt:  0.1095036119222641 loss:  -1.3914916515350342\n",
      "57 revenue:  4.083238124847412 rgt:  0.2570469081401825 loss:  -1.2566574811935425\n",
      "58 revenue:  3.3720953464508057 rgt:  0.11057034879922867 loss:  -1.3932350873947144\n",
      "59 revenue:  4.106616497039795 rgt:  0.2634008824825287 loss:  -1.2498518228530884\n",
      "60 revenue:  3.3761613368988037 rgt:  0.11171840131282806 loss:  -1.3914718627929688\n",
      "61 revenue:  4.122163772583008 rgt:  0.24390915036201477 loss:  -1.2925306558609009\n",
      "62 revenue:  3.411351442337036 rgt:  0.11524038016796112 loss:  -1.3922733068466187\n",
      "63 revenue:  4.152305603027344 rgt:  0.25397664308547974 loss:  -1.279783010482788\n",
      "64 revenue:  3.4304726123809814 rgt:  0.11424103379249573 loss:  -1.3999168872833252\n",
      "65 revenue:  4.184046745300293 rgt:  0.2619328200817108 loss:  -1.2717677354812622\n",
      "66 revenue:  3.467273235321045 rgt:  0.11759619414806366 loss:  -1.40154230594635\n",
      "67 revenue:  4.18897008895874 rgt:  0.26306524872779846 loss:  -1.2707332372665405\n",
      "68 revenue:  3.4744787216186523 rgt:  0.11795183271169662 loss:  -1.4026023149490356\n",
      "69 revenue:  4.196101188659668 rgt:  0.2698163390159607 loss:  -1.2591838836669922\n",
      "70 revenue:  3.472830295562744 rgt:  0.12217608094215393 loss:  -1.3918401002883911\n",
      "71 revenue:  4.20604133605957 rgt:  0.24862460792064667 loss:  -1.3036162853240967\n",
      "72 revenue:  3.4961023330688477 rgt:  0.1257358342409134 loss:  -1.3894582986831665\n",
      "73 revenue:  4.225717067718506 rgt:  0.26001209020614624 loss:  -1.285729169845581\n",
      "74 revenue:  3.505183458328247 rgt:  0.12606878578662872 loss:  -1.391083002090454\n",
      "75 revenue:  4.24080753326416 rgt:  0.278746098279953 loss:  -1.2526118755340576\n",
      "76 revenue:  3.517401933670044 rgt:  0.1294846385717392 loss:  -1.3861494064331055\n",
      "77 revenue:  4.223669528961182 rgt:  0.2878299951553345 loss:  -1.230828881263733\n",
      "78 revenue:  3.5049076080322266 rgt:  0.12905700504779816 loss:  -1.3838376998901367\n",
      "79 revenue:  4.206698894500732 rgt:  0.28270572423934937 loss:  -1.2366173267364502\n",
      "80 revenue:  3.484192132949829 rgt:  0.1205475851893425 loss:  -1.3988518714904785\n",
      "81 revenue:  4.214249134063721 rgt:  0.24675562977790833 loss:  -1.3093630075454712\n",
      "82 revenue:  3.510859251022339 rgt:  0.12011244893074036 loss:  -1.4070439338684082\n",
      "83 revenue:  4.239320755004883 rgt:  0.254358172416687 loss:  -1.3002636432647705\n",
      "84 revenue:  3.529233932495117 rgt:  0.11999163776636124 loss:  -1.4122357368469238\n",
      "85 revenue:  4.2524919509887695 rgt:  0.2571994364261627 loss:  -1.2978094816207886\n",
      "86 revenue:  3.543511152267456 rgt:  0.12065156549215317 loss:  -1.4144207239151\n",
      "87 revenue:  4.267096042633057 rgt:  0.2583521008491516 loss:  -1.2990593910217285\n",
      "88 revenue:  3.556267023086548 rgt:  0.12170349806547165 loss:  -1.4152429103851318\n",
      "89 revenue:  4.2760419845581055 rgt:  0.2590165138244629 loss:  -1.2999060153961182\n",
      "90 revenue:  3.5664093494415283 rgt:  0.12809012830257416 loss:  -1.402506947517395\n",
      "91 revenue:  4.280426502227783 rgt:  0.24617381393909454 loss:  -1.3265862464904785\n",
      "92 revenue:  3.5781545639038086 rgt:  0.12943056225776672 loss:  -1.4024059772491455\n",
      "93 revenue:  4.292925834655762 rgt:  0.2509864866733551 loss:  -1.3199658393859863\n",
      "94 revenue:  3.5912046432495117 rgt:  0.1295083910226822 loss:  -1.4056663513183594\n",
      "95 revenue:  4.300236701965332 rgt:  0.25229504704475403 loss:  -1.3191163539886475\n",
      "96 revenue:  3.5974109172821045 rgt:  0.12693272531032562 loss:  -1.4134752750396729\n",
      "97 revenue:  4.309467315673828 rgt:  0.25923246145248413 loss:  -1.307544231414795\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "98 revenue:  3.6180074214935303 rgt:  0.12780332565307617 loss:  -1.4168068170547485\n",
      "99 revenue:  4.314110279083252 rgt:  0.2590849697589874 loss:  -1.3089547157287598\n",
      "100 revenue:  3.6225507259368896 rgt:  0.1311691701412201 loss:  -1.4099578857421875\n",
      "101 revenue:  4.323137283325195 rgt:  0.2459031343460083 loss:  -1.3374261856079102\n",
      "102 revenue:  3.6282436847686768 rgt:  0.13106092810630798 loss:  -1.4117106199264526\n",
      "103 revenue:  4.339781761169434 rgt:  0.2518223226070404 loss:  -1.3295729160308838\n",
      "104 revenue:  3.642852306365967 rgt:  0.13144473731517792 loss:  -1.4146279096603394\n",
      "105 revenue:  4.347376346588135 rgt:  0.2616279125213623 loss:  -1.3119125366210938\n",
      "106 revenue:  3.652190923690796 rgt:  0.13599123060703278 loss:  -1.4063094854354858\n",
      "107 revenue:  4.344788074493408 rgt:  0.2740221321582794 loss:  -1.2869220972061157\n",
      "108 revenue:  3.6384119987487793 rgt:  0.13558216392993927 loss:  -1.4036651849746704\n",
      "109 revenue:  4.343076229095459 rgt:  0.28102627396583557 loss:  -1.2728594541549683\n",
      "110 revenue:  3.6266796588897705 rgt:  0.13144265115261078 loss:  -1.4103914499282837\n",
      "111 revenue:  4.344428062438965 rgt:  0.24182851612567902 loss:  -1.3507399559020996\n",
      "112 revenue:  3.6321494579315186 rgt:  0.12974897027015686 loss:  -1.415864109992981\n",
      "113 revenue:  4.343408584594727 rgt:  0.23780347406864166 loss:  -1.3586300611495972\n",
      "114 revenue:  3.6302788257598877 rgt:  0.12361828237771988 loss:  -1.4301170110702515\n",
      "115 revenue:  4.33485221862793 rgt:  0.23184612393379211 loss:  -1.368680715560913\n",
      "116 revenue:  3.6283648014068604 rgt:  0.11696956306695938 loss:  -1.445849061012268\n",
      "117 revenue:  4.323834419250488 rgt:  0.22943229973316193 loss:  -1.3709598779678345\n",
      "118 revenue:  3.62322735786438 rgt:  0.10831013321876526 loss:  -1.4660625457763672\n",
      "119 revenue:  4.316672325134277 rgt:  0.2135409563779831 loss:  -1.4020144939422607\n",
      "120 revenue:  3.619452953338623 rgt:  0.09637504816055298 loss:  -1.4956676959991455\n",
      "121 revenue:  4.331545352935791 rgt:  0.18025530874729156 loss:  -1.4764164686203003\n",
      "122 revenue:  3.607269525527954 rgt:  0.10140432417392731 loss:  -1.4794365167617798\n",
      "123 revenue:  4.291452884674072 rgt:  0.1692316085100174 loss:  -1.4909729957580566\n",
      "124 revenue:  3.5923855304718018 rgt:  0.0910528302192688 loss:  -1.502556562423706\n",
      "125 revenue:  4.250689506530762 rgt:  0.15679535269737244 loss:  -1.5089508295059204\n",
      "126 revenue:  3.582338571548462 rgt:  0.08249928802251816 loss:  -1.5229804515838623\n",
      "127 revenue:  4.21466064453125 rgt:  0.1449313759803772 loss:  -1.5273339748382568\n",
      "128 revenue:  3.573082685470581 rgt:  0.07558842748403549 loss:  -1.5397380590438843\n",
      "129 revenue:  4.178317546844482 rgt:  0.13383731245994568 loss:  -1.544418215751648\n",
      "130 revenue:  3.571342945098877 rgt:  0.07150224596261978 loss:  -1.5508984327316284\n",
      "131 revenue:  4.175666809082031 rgt:  0.12752600014209747 loss:  -1.5588109493255615\n",
      "132 revenue:  3.531893730163574 rgt:  0.060624390840530396 loss:  -1.572488784790039\n",
      "133 revenue:  4.173960208892822 rgt:  0.13376663625240326 loss:  -1.5435192584991455\n",
      "134 revenue:  3.5729424953460693 rgt:  0.06357017904520035 loss:  -1.5745214223861694\n",
      "135 revenue:  4.175771713256836 rgt:  0.1293661743402481 loss:  -1.554429292678833\n",
      "136 revenue:  3.613003730773926 rgt:  0.06499003618955612 loss:  -1.5808688402175903\n",
      "137 revenue:  4.185610771179199 rgt:  0.12535206973552704 loss:  -1.5664736032485962\n",
      "138 revenue:  3.6768620014190674 rgt:  0.06729788333177567 loss:  -1.590798258781433\n",
      "139 revenue:  4.190581321716309 rgt:  0.12285824865102768 loss:  -1.5737212896347046\n",
      "140 revenue:  3.7356815338134766 rgt:  0.0686773955821991 loss:  -1.6020499467849731\n",
      "141 revenue:  4.219532489776611 rgt:  0.11829038709402084 loss:  -1.5919259786605835\n",
      "142 revenue:  3.798100233078003 rgt:  0.07160260528326035 loss:  -1.609682321548462\n",
      "143 revenue:  4.254950046539307 rgt:  0.12087062001228333 loss:  -1.5942177772521973\n",
      "144 revenue:  3.836993932723999 rgt:  0.07285638153553009 loss:  -1.61604905128479\n",
      "145 revenue:  4.2672624588012695 rgt:  0.120133176445961 loss:  -1.5989998579025269\n",
      "146 revenue:  3.8663909435272217 rgt:  0.07340886443853378 loss:  -1.6219645738601685\n",
      "147 revenue:  4.283578872680664 rgt:  0.12083353102207184 loss:  -1.6012362241744995\n",
      "148 revenue:  3.889176368713379 rgt:  0.07420335710048676 loss:  -1.6254931688308716\n",
      "149 revenue:  4.295331001281738 rgt:  0.1227259561419487 loss:  -1.599469542503357\n",
      "150 revenue:  3.9104506969451904 rgt:  0.07494883984327316 loss:  -1.6287692785263062\n",
      "151 revenue:  4.28858757019043 rgt:  0.11467960476875305 loss:  -1.6175670623779297\n",
      "152 revenue:  3.9587936401367188 rgt:  0.07749958336353302 loss:  -1.6337846517562866\n",
      "153 revenue:  4.336782455444336 rgt:  0.11943971365690231 loss:  -1.6174540519714355\n",
      "154 revenue:  3.9555318355560303 rgt:  0.07648146152496338 loss:  -1.6358176469802856\n",
      "155 revenue:  4.335419654846191 rgt:  0.11765606701374054 loss:  -1.6215007305145264\n",
      "156 revenue:  3.9609334468841553 rgt:  0.07597348093986511 loss:  -1.6386029720306396\n",
      "157 revenue:  4.338865280151367 rgt:  0.11682619154453278 loss:  -1.6243696212768555\n",
      "158 revenue:  3.964221715927124 rgt:  0.07546354085206985 loss:  -1.6408655643463135\n",
      "159 revenue:  4.340604782104492 rgt:  0.11656279116868973 loss:  -1.6254361867904663\n",
      "160 revenue:  3.9723432064056396 rgt:  0.07646264135837555 loss:  -1.640092372894287\n",
      "161 revenue:  4.328022003173828 rgt:  0.11211862415075302 loss:  -1.6334301233291626\n",
      "162 revenue:  4.001104354858398 rgt:  0.077796071767807 loss:  -1.643560528755188\n",
      "163 revenue:  4.368099689483643 rgt:  0.11656045913696289 loss:  -1.6320300102233887\n",
      "164 revenue:  4.005505561828613 rgt:  0.0776929184794426 loss:  -1.6449486017227173\n",
      "165 revenue:  4.370796203613281 rgt:  0.11776009947061539 loss:  -1.6297228336334229\n",
      "166 revenue:  4.017105579376221 rgt:  0.08646649122238159 loss:  -1.623753309249878\n",
      "167 revenue:  4.345171928405762 rgt:  0.11590809375047684 loss:  -1.628146767616272\n",
      "168 revenue:  4.014282703399658 rgt:  0.08550862967967987 loss:  -1.6256402730941772\n",
      "169 revenue:  4.343040466308594 rgt:  0.11532879620790482 loss:  -1.6290665864944458\n",
      "170 revenue:  4.0254316329956055 rgt:  0.0788431391119957 loss:  -1.6467145681381226\n",
      "171 revenue:  4.354933261871338 rgt:  0.10556388646364212 loss:  -1.656377911567688\n",
      "172 revenue:  4.145084857940674 rgt:  0.08704183250665665 loss:  -1.65387761592865\n",
      "173 revenue:  4.431515693664551 rgt:  0.11277304589748383 loss:  -1.6565265655517578\n",
      "174 revenue:  4.2410101890563965 rgt:  0.098124660551548 loss:  -1.6479979753494263\n",
      "175 revenue:  4.44385290145874 rgt:  0.12218970060348511 loss:  -1.636298656463623\n",
      "176 revenue:  4.182642936706543 rgt:  0.09014004468917847 loss:  -1.6547775268554688\n",
      "177 revenue:  4.421596527099609 rgt:  0.12016937136650085 loss:  -1.6359354257583618\n",
      "178 revenue:  4.174220085144043 rgt:  0.08589469641447067 loss:  -1.6641181707382202\n",
      "179 revenue:  4.436225891113281 rgt:  0.12411817908287048 loss:  -1.6298127174377441\n",
      "180 revenue:  4.170276641845703 rgt:  0.08159136027097702 loss:  -1.6748920679092407\n",
      "181 revenue:  4.438908576965332 rgt:  0.11166920512914658 loss:  -1.661033272743225\n",
      "182 revenue:  4.336622714996338 rgt:  0.10185515880584717 loss:  -1.661453127861023\n",
      "183 revenue:  4.488532066345215 rgt:  0.11922331899404526 loss:  -1.6541049480438232\n",
      "184 revenue:  4.397421836853027 rgt:  0.10539771616458893 loss:  -1.6669551134109497\n",
      "185 revenue:  4.504609107971191 rgt:  0.12788614630699158 loss:  -1.6369086503982544\n",
      "186 revenue:  4.385289192199707 rgt:  0.10448350012302399 loss:  -1.666385531425476\n",
      "187 revenue:  4.4797468185424805 rgt:  0.12741772830486298 loss:  -1.6321672201156616\n",
      "188 revenue:  4.319175720214844 rgt:  0.09647554159164429 loss:  -1.6711819171905518\n",
      "189 revenue:  4.466978549957275 rgt:  0.12906908988952637 loss:  -1.6251918077468872\n",
      "190 revenue:  4.288975715637207 rgt:  0.08519177883863449 loss:  -1.6939160823822021\n",
      "191 revenue:  4.469756126403809 rgt:  0.11099518090486526 loss:  -1.6700252294540405\n",
      "192 revenue:  4.40614128112793 rgt:  0.09727732837200165 loss:  -1.689910650253296\n",
      "193 revenue:  4.563297748565674 rgt:  0.12270534783601761 loss:  -1.6631890535354614\n",
      "194 revenue:  4.457040309906006 rgt:  0.1105898767709732 loss:  -1.6680299043655396\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "195 revenue:  4.537228584289551 rgt:  0.12367580085992813 loss:  -1.6547255516052246\n",
      "196 revenue:  4.324354648590088 rgt:  0.09893598407506943 loss:  -1.6660314798355103\n",
      "197 revenue:  4.534735202789307 rgt:  0.12166903913021088 loss:  -1.6590118408203125\n",
      "198 revenue:  4.300189971923828 rgt:  0.09690089523792267 loss:  -1.6654999256134033\n",
      "199 revenue:  4.521914958953857 rgt:  0.11969397962093353 loss:  -1.6608171463012695\n",
      "200 revenue:  4.274925231933594 rgt:  0.08192915469408035 loss:  -1.6994273662567139\n",
      "201 revenue:  4.3335113525390625 rgt:  0.08338183909654617 loss:  -1.709567666053772\n",
      "202 revenue:  4.38400936126709 rgt:  0.0831340029835701 loss:  -1.7223389148712158\n",
      "203 revenue:  4.4244537353515625 rgt:  0.08314961194992065 loss:  -1.7319321632385254\n",
      "204 revenue:  4.456200122833252 rgt:  0.08393479883670807 loss:  -1.7373216152191162\n",
      "205 revenue:  4.481188774108887 rgt:  0.08497202396392822 loss:  -1.7404102087020874\n",
      "206 revenue:  4.501573085784912 rgt:  0.08601948618888855 loss:  -1.7423806190490723\n",
      "207 revenue:  4.522355079650879 rgt:  0.08751074224710464 loss:  -1.7432500123977661\n",
      "208 revenue:  4.538447856903076 rgt:  0.09173611551523209 loss:  -1.7357474565505981\n",
      "209 revenue:  4.545183181762695 rgt:  0.09232305735349655 loss:  -1.7357733249664307\n",
      "210 revenue:  4.539706707000732 rgt:  0.09077461808919907 loss:  -1.738595962524414\n",
      "211 revenue:  4.541813850402832 rgt:  0.08835180848836899 loss:  -1.7455610036849976\n",
      "212 revenue:  4.556974411010742 rgt:  0.09112970530986786 loss:  -1.741700530052185\n",
      "213 revenue:  4.543787002563477 rgt:  0.0907893106341362 loss:  -1.7395141124725342\n",
      "214 revenue:  4.5314154624938965 rgt:  0.08950783312320709 loss:  -1.7400257587432861\n",
      "215 revenue:  4.522515296936035 rgt:  0.08928772807121277 loss:  -1.7385222911834717\n",
      "216 revenue:  4.528813362121582 rgt:  0.09262789785861969 loss:  -1.7311246395111084\n",
      "217 revenue:  4.52508544921875 rgt:  0.093555748462677 loss:  -1.7278003692626953\n",
      "218 revenue:  4.531518459320068 rgt:  0.09718209505081177 loss:  -1.7198138236999512\n",
      "219 revenue:  4.525178909301758 rgt:  0.09652939438819885 loss:  -1.720025658607483\n",
      "220 revenue:  4.519015789031982 rgt:  0.08922384679317474 loss:  -1.737870216369629\n",
      "221 revenue:  4.528160572052002 rgt:  0.08625790476799011 loss:  -1.7479926347732544\n",
      "222 revenue:  4.542294502258301 rgt:  0.08724769204854965 loss:  -1.7486408948898315\n",
      "223 revenue:  4.554959774017334 rgt:  0.08784880489110947 loss:  -1.7499934434890747\n",
      "224 revenue:  4.562594413757324 rgt:  0.0908958688378334 loss:  -1.7436378002166748\n",
      "225 revenue:  4.552403926849365 rgt:  0.08921334892511368 loss:  -1.745736837387085\n",
      "226 revenue:  4.538589000701904 rgt:  0.08844567090272903 loss:  -1.744552493095398\n",
      "227 revenue:  4.5269036293029785 rgt:  0.09035392105579376 loss:  -1.7367088794708252\n",
      "228 revenue:  4.5398850440979 rgt:  0.09271370619535446 loss:  -1.7334976196289062\n",
      "229 revenue:  4.532761096954346 rgt:  0.09430248290300369 loss:  -1.7276387214660645\n",
      "230 revenue:  4.5331950187683105 rgt:  0.0868217945098877 loss:  -1.7476530075073242\n",
      "231 revenue:  4.5373311042785645 rgt:  0.08462414145469666 loss:  -1.7545747756958008\n",
      "232 revenue:  4.554131031036377 rgt:  0.08621484786272049 loss:  -1.7542024850845337\n",
      "233 revenue:  4.560290336608887 rgt:  0.08910423517227173 loss:  -1.7478761672973633\n",
      "234 revenue:  4.550621032714844 rgt:  0.08713492751121521 loss:  -1.7508972883224487\n",
      "235 revenue:  4.53639030456543 rgt:  0.08569555729627609 loss:  -1.7514469623565674\n",
      "236 revenue:  4.52774715423584 rgt:  0.08614465594291687 loss:  -1.7482014894485474\n",
      "237 revenue:  4.535951614379883 rgt:  0.08900098502635956 loss:  -1.7424461841583252\n",
      "238 revenue:  4.536562442779541 rgt:  0.09083589911460876 loss:  -1.7376948595046997\n",
      "239 revenue:  4.537978172302246 rgt:  0.09213557839393616 loss:  -1.734579086303711\n",
      "240 revenue:  4.54060173034668 rgt:  0.08860806375741959 loss:  -1.7445895671844482\n",
      "241 revenue:  4.543967247009277 rgt:  0.0841732770204544 loss:  -1.7573586702346802\n",
      "242 revenue:  4.55389928817749 rgt:  0.08508061617612839 loss:  -1.7572202682495117\n",
      "243 revenue:  4.567385196685791 rgt:  0.08681787550449371 loss:  -1.7556774616241455\n",
      "244 revenue:  4.55829381942749 rgt:  0.08528385311365128 loss:  -1.7576982975006104\n",
      "245 revenue:  4.556214332580566 rgt:  0.0848124772310257 loss:  -1.758490800857544\n",
      "246 revenue:  4.5500078201293945 rgt:  0.08460196107625961 loss:  -1.7576085329055786\n",
      "247 revenue:  4.562335968017578 rgt:  0.08478034287691116 loss:  -1.7600115537643433\n",
      "248 revenue:  4.566650867462158 rgt:  0.08809627592563629 loss:  -1.7520660161972046\n",
      "249 revenue:  4.557575702667236 rgt:  0.0889243483543396 loss:  -1.7477216720581055\n",
      "250 revenue:  4.549614906311035 rgt:  0.08581658452749252 loss:  -1.7542214393615723\n",
      "251 revenue:  4.562995910644531 rgt:  0.08416233956813812 loss:  -1.7618471384048462\n",
      "252 revenue:  4.57403039932251 rgt:  0.0855587050318718 loss:  -1.760635495185852\n",
      "253 revenue:  4.588057041168213 rgt:  0.0866318792104721 loss:  -1.7610100507736206\n",
      "254 revenue:  4.587070941925049 rgt:  0.09038950502872467 loss:  -1.7507069110870361\n",
      "255 revenue:  4.581579208374023 rgt:  0.08891527354717255 loss:  -1.7533605098724365\n",
      "256 revenue:  4.5765461921691895 rgt:  0.08843788504600525 loss:  -1.7534632682800293\n",
      "257 revenue:  4.582982540130615 rgt:  0.09155131876468658 loss:  -1.7466644048690796\n",
      "258 revenue:  4.57492208480835 rgt:  0.09241483360528946 loss:  -1.742493748664856\n",
      "259 revenue:  4.5683794021606445 rgt:  0.09799772500991821 loss:  -1.7263331413269043\n",
      "260 revenue:  4.580659866333008 rgt:  0.08758015185594559 loss:  -1.756727933883667\n",
      "261 revenue:  4.575806617736816 rgt:  0.085003562271595 loss:  -1.7625560760498047\n",
      "262 revenue:  4.589906692504883 rgt:  0.08634354919195175 loss:  -1.7622203826904297\n",
      "263 revenue:  4.600039958953857 rgt:  0.08798885345458984 loss:  -1.7601523399353027\n",
      "264 revenue:  4.59214448928833 rgt:  0.08906994014978409 loss:  -1.7554129362106323\n",
      "265 revenue:  4.583414077758789 rgt:  0.08768115937709808 loss:  -1.7570996284484863\n",
      "266 revenue:  4.575401782989502 rgt:  0.0879262387752533 loss:  -1.7545689344406128\n",
      "267 revenue:  4.580613136291504 rgt:  0.091184101998806 loss:  -1.747085452079773\n",
      "268 revenue:  4.585426330566406 rgt:  0.09543640911579132 loss:  -1.7369965314865112\n",
      "269 revenue:  4.580520153045654 rgt:  0.09930470585823059 loss:  -1.7257838249206543\n",
      "270 revenue:  4.575213432312012 rgt:  0.08606353402137756 loss:  -1.7595455646514893\n",
      "271 revenue:  4.576908588409424 rgt:  0.08423575758934021 loss:  -1.7649013996124268\n",
      "272 revenue:  4.590403079986572 rgt:  0.08569474518299103 loss:  -1.76409113407135\n",
      "273 revenue:  4.603184700012207 rgt:  0.08654171973466873 loss:  -1.7647818326950073\n",
      "274 revenue:  4.608057498931885 rgt:  0.08698325604200363 loss:  -1.764726161956787\n",
      "275 revenue:  4.615932941436768 rgt:  0.08759432286024094 loss:  -1.764914631843567\n",
      "276 revenue:  4.6110148429870605 rgt:  0.08830274641513824 loss:  -1.7618669271469116\n",
      "277 revenue:  4.6071882247924805 rgt:  0.08907857537269592 loss:  -1.758897304534912\n",
      "278 revenue:  4.597885608673096 rgt:  0.08820778131484985 loss:  -1.7590622901916504\n",
      "279 revenue:  4.599822998046875 rgt:  0.08860262483358383 loss:  -1.7584552764892578\n",
      "280 revenue:  4.590961456298828 rgt:  0.0879920944571495 loss:  -1.7580262422561646\n",
      "281 revenue:  4.595684051513672 rgt:  0.0848616510629654 loss:  -1.767582893371582\n",
      "282 revenue:  4.609506130218506 rgt:  0.08642221242189407 loss:  -1.7665772438049316\n",
      "283 revenue:  4.620649337768555 rgt:  0.08844577521085739 loss:  -1.7637253999710083\n",
      "284 revenue:  4.6123223304748535 rgt:  0.08993332833051682 loss:  -1.7578097581863403\n",
      "285 revenue:  4.605965614318848 rgt:  0.08822271227836609 loss:  -1.7609055042266846\n",
      "286 revenue:  4.594361305236816 rgt:  0.08749726414680481 loss:  -1.760149598121643\n",
      "287 revenue:  4.603386878967285 rgt:  0.09050492942333221 loss:  -1.7542052268981934\n",
      "288 revenue:  4.610715866088867 rgt:  0.09439415484666824 loss:  -1.7456272840499878\n",
      "289 revenue:  4.606884002685547 rgt:  0.1005638986825943 loss:  -1.728683352470398\n",
      "290 revenue:  4.601833343505859 rgt:  0.08646373450756073 loss:  -1.7646775245666504\n",
      "291 revenue:  4.609561920166016 rgt:  0.08588264882564545 loss:  -1.7680490016937256\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "292 revenue:  4.6207404136657715 rgt:  0.08704950660467148 loss:  -1.7674996852874756\n",
      "293 revenue:  4.631056785583496 rgt:  0.08772755414247513 loss:  -1.7680730819702148\n",
      "294 revenue:  4.627992153167725 rgt:  0.08753965049982071 loss:  -1.7678661346435547\n",
      "295 revenue:  4.640071392059326 rgt:  0.09101492166519165 loss:  -1.761380910873413\n",
      "296 revenue:  4.630631923675537 rgt:  0.09075729548931122 loss:  -1.7598735094070435\n",
      "297 revenue:  4.623779773712158 rgt:  0.0920858308672905 loss:  -1.7547552585601807\n",
      "298 revenue:  4.627805233001709 rgt:  0.09415566176176071 loss:  -1.750229835510254\n",
      "299 revenue:  4.6159186363220215 rgt:  0.0935826525092125 loss:  -1.7489734888076782\n",
      "300 revenue:  4.618175029754639 rgt:  0.08752090483903885 loss:  -1.7656337022781372\n",
      "301 revenue:  4.628298282623291 rgt:  0.08720614016056061 loss:  -1.7688350677490234\n",
      "302 revenue:  4.640916347503662 rgt:  0.08921950310468674 loss:  -1.7663627862930298\n",
      "303 revenue:  4.634281635284424 rgt:  0.0881464034318924 loss:  -1.7676970958709717\n",
      "304 revenue:  4.630274295806885 rgt:  0.0897347554564476 loss:  -1.7625149488449097\n",
      "305 revenue:  4.620774745941162 rgt:  0.0887565091252327 loss:  -1.762921929359436\n",
      "306 revenue:  4.6259355545043945 rgt:  0.08930005133152008 loss:  -1.7626676559448242\n",
      "307 revenue:  4.616590976715088 rgt:  0.08829456567764282 loss:  -1.7631866931915283\n",
      "308 revenue:  4.622505187988281 rgt:  0.08939602971076965 loss:  -1.7616136074066162\n",
      "309 revenue:  4.6251702308654785 rgt:  0.09164325147867203 loss:  -1.756251335144043\n",
      "310 revenue:  4.630246639251709 rgt:  0.09013427048921585 loss:  -1.7614428997039795\n",
      "311 revenue:  4.620608329772949 rgt:  0.08578081429004669 loss:  -1.7708954811096191\n",
      "312 revenue:  4.634937286376953 rgt:  0.08717320114374161 loss:  -1.7704660892486572\n",
      "313 revenue:  4.64298152923584 rgt:  0.08768779039382935 loss:  -1.770948886871338\n",
      "314 revenue:  4.642354965209961 rgt:  0.09098630398511887 loss:  -1.7619869709014893\n",
      "315 revenue:  4.638374328613281 rgt:  0.08969142287969589 loss:  -1.7645118236541748\n",
      "316 revenue:  4.6271138191223145 rgt:  0.08878844231367111 loss:  -1.7643104791641235\n",
      "317 revenue:  4.631712436676025 rgt:  0.08929858356714249 loss:  -1.7640140056610107\n",
      "318 revenue:  4.621963977813721 rgt:  0.0890643373131752 loss:  -1.7623745203018188\n",
      "319 revenue:  4.630969047546387 rgt:  0.09383105486631393 loss:  -1.751819133758545\n",
      "320 revenue:  4.6257805824279785 rgt:  0.08923619240522385 loss:  -1.7628023624420166\n",
      "321 revenue:  4.634652137756348 rgt:  0.08664324879646301 loss:  -1.7718286514282227\n",
      "322 revenue:  4.645795822143555 rgt:  0.08770621567964554 loss:  -1.7715522050857544\n",
      "323 revenue:  4.644317626953125 rgt:  0.08792754262685776 loss:  -1.7706146240234375\n",
      "324 revenue:  4.6509857177734375 rgt:  0.09177057445049286 loss:  -1.7619072198867798\n",
      "325 revenue:  4.649500846862793 rgt:  0.09022015333175659 loss:  -1.7656831741333008\n",
      "326 revenue:  4.637824058532715 rgt:  0.08924204111099243 loss:  -1.7655847072601318\n",
      "327 revenue:  4.64076566696167 rgt:  0.08970538526773453 loss:  -1.765029788017273\n",
      "328 revenue:  4.630709171295166 rgt:  0.08873353898525238 loss:  -1.7652928829193115\n",
      "329 revenue:  4.639373302459717 rgt:  0.0897546038031578 loss:  -1.7645751237869263\n",
      "330 revenue:  4.632290363311768 rgt:  0.08791406452655792 loss:  -1.7678583860397339\n",
      "331 revenue:  4.6442790031433105 rgt:  0.08726631104946136 loss:  -1.7723838090896606\n",
      "332 revenue:  4.658039093017578 rgt:  0.0885108932852745 loss:  -1.7722305059432983\n",
      "333 revenue:  4.653656005859375 rgt:  0.08789733797311783 loss:  -1.772861361503601\n",
      "334 revenue:  4.665966510772705 rgt:  0.08957475423812866 loss:  -1.7712194919586182\n",
      "335 revenue:  4.659012317657471 rgt:  0.08976133167743683 loss:  -1.769111156463623\n",
      "336 revenue:  4.659631729125977 rgt:  0.0920054018497467 loss:  -1.7632886171340942\n",
      "337 revenue:  4.652571678161621 rgt:  0.09324420988559723 loss:  -1.7583788633346558\n",
      "338 revenue:  4.663230895996094 rgt:  0.09585683792829514 loss:  -1.753987193107605\n",
      "339 revenue:  4.665702819824219 rgt:  0.09781955182552338 loss:  -1.7494429349899292\n",
      "340 revenue:  4.67140007019043 rgt:  0.09175793081521988 loss:  -1.7666685581207275\n",
      "341 revenue:  4.6705241203308105 rgt:  0.08954986184835434 loss:  -1.7723407745361328\n",
      "342 revenue:  4.683277606964111 rgt:  0.09115519374608994 loss:  -1.771013855934143\n",
      "343 revenue:  4.690248966217041 rgt:  0.09512214362621307 loss:  -1.7621574401855469\n",
      "344 revenue:  4.68150520324707 rgt:  0.09387075155973434 loss:  -1.7634245157241821\n",
      "345 revenue:  4.671960830688477 rgt:  0.09268613159656525 loss:  -1.7643417119979858\n",
      "346 revenue:  4.663137435913086 rgt:  0.09173288941383362 loss:  -1.7648226022720337\n",
      "347 revenue:  4.667847633361816 rgt:  0.09209040552377701 loss:  -1.7649660110473633\n",
      "348 revenue:  4.6564459800720215 rgt:  0.09099918603897095 loss:  -1.7652201652526855\n",
      "349 revenue:  4.663237571716309 rgt:  0.09255079925060272 loss:  -1.7626807689666748\n",
      "350 revenue:  4.6667656898498535 rgt:  0.09112755954265594 loss:  -1.7672687768936157\n",
      "351 revenue:  4.658087730407715 rgt:  0.0878976434469223 loss:  -1.773887276649475\n",
      "352 revenue:  4.673052787780762 rgt:  0.08862211555242538 loss:  -1.7754077911376953\n",
      "353 revenue:  4.665707111358643 rgt:  0.09100215137004852 loss:  -1.7673571109771729\n",
      "354 revenue:  4.65876579284668 rgt:  0.09053497761487961 loss:  -1.766992211341858\n",
      "355 revenue:  4.672184944152832 rgt:  0.0918438509106636 loss:  -1.766622543334961\n",
      "356 revenue:  4.6564154624938965 rgt:  0.09043426066637039 loss:  -1.7667157649993896\n",
      "357 revenue:  4.672624111175537 rgt:  0.09199243038892746 loss:  -1.7663304805755615\n",
      "358 revenue:  4.654811382293701 rgt:  0.09092443436384201 loss:  -1.7650400400161743\n",
      "359 revenue:  4.6730875968933105 rgt:  0.09714749455451965 loss:  -1.7529000043869019\n",
      "360 revenue:  4.672674655914307 rgt:  0.09047155827283859 loss:  -1.7703806161880493\n",
      "361 revenue:  4.6661696434021 rgt:  0.08831624686717987 loss:  -1.7746351957321167\n",
      "362 revenue:  4.677122116088867 rgt:  0.089682936668396 loss:  -1.773511528968811\n",
      "363 revenue:  4.678914546966553 rgt:  0.08944586664438248 loss:  -1.7745591402053833\n",
      "364 revenue:  4.687506198883057 rgt:  0.09160079807043076 loss:  -1.7708081007003784\n",
      "365 revenue:  4.684103012084961 rgt:  0.09126469492912292 loss:  -1.77091383934021\n",
      "366 revenue:  4.674313545227051 rgt:  0.0934847965836525 loss:  -1.7627785205841064\n",
      "367 revenue:  4.684421062469482 rgt:  0.09553562104701996 loss:  -1.7597284317016602\n",
      "368 revenue:  4.673871040344238 rgt:  0.09610382467508316 loss:  -1.7558037042617798\n",
      "369 revenue:  4.687563896179199 rgt:  0.09790929406881332 loss:  -1.754264235496521\n",
      "370 revenue:  4.678508758544922 rgt:  0.09083865582942963 loss:  -1.7707529067993164\n",
      "371 revenue:  4.692564487457275 rgt:  0.0907796174287796 loss:  -1.7741565704345703\n",
      "372 revenue:  4.702285289764404 rgt:  0.09186828136444092 loss:  -1.7735092639923096\n",
      "373 revenue:  4.6992950439453125 rgt:  0.09137537330389023 loss:  -1.7741267681121826\n",
      "374 revenue:  4.703239917755127 rgt:  0.09618237614631653 loss:  -1.7623802423477173\n",
      "375 revenue:  4.6966962814331055 rgt:  0.09393778443336487 loss:  -1.7667558193206787\n",
      "376 revenue:  4.684370517730713 rgt:  0.09266852587461472 loss:  -1.7672572135925293\n",
      "377 revenue:  4.685309886932373 rgt:  0.09293491393327713 loss:  -1.7667704820632935\n",
      "378 revenue:  4.672576904296875 rgt:  0.09220875054597855 loss:  -1.7657467126846313\n",
      "379 revenue:  4.683473110198975 rgt:  0.09567230194807053 loss:  -1.7591516971588135\n",
      "380 revenue:  4.691040992736816 rgt:  0.09192010015249252 loss:  -1.770777702331543\n",
      "381 revenue:  4.6811747550964355 rgt:  0.08917642384767532 loss:  -1.775801658630371\n",
      "382 revenue:  4.694662570953369 rgt:  0.09059359133243561 loss:  -1.7751357555389404\n",
      "383 revenue:  4.685792446136475 rgt:  0.08958784490823746 loss:  -1.7757688760757446\n",
      "384 revenue:  4.700702667236328 rgt:  0.09333479404449463 loss:  -1.7692681550979614\n",
      "385 revenue:  4.689821720123291 rgt:  0.09258048236370087 loss:  -1.7687487602233887\n",
      "386 revenue:  4.675553798675537 rgt:  0.09184098243713379 loss:  -1.7674092054367065\n",
      "387 revenue:  4.688340663909912 rgt:  0.09272424131631851 loss:  -1.7680269479751587\n",
      "388 revenue:  4.673473358154297 rgt:  0.0919056311249733 loss:  -1.7667567729949951\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "389 revenue:  4.683635711669922 rgt:  0.09298340231180191 loss:  -1.7662558555603027\n",
      "390 revenue:  4.670406341552734 rgt:  0.09066575020551682 loss:  -1.7693390846252441\n",
      "391 revenue:  4.68593168258667 rgt:  0.08954060822725296 loss:  -1.775927186012268\n",
      "392 revenue:  4.69748592376709 rgt:  0.09094308316707611 loss:  -1.7748576402664185\n",
      "393 revenue:  4.691038131713867 rgt:  0.09281197935342789 loss:  -1.7684179544448853\n",
      "394 revenue:  4.687829494476318 rgt:  0.09404505789279938 loss:  -1.7644269466400146\n",
      "395 revenue:  4.678439140319824 rgt:  0.09305711090564728 loss:  -1.7648602724075317\n",
      "396 revenue:  4.690322399139404 rgt:  0.09392676502466202 loss:  -1.765313744544983\n",
      "397 revenue:  4.678234100341797 rgt:  0.09339310228824615 loss:  -1.7639267444610596\n",
      "398 revenue:  4.689431667327881 rgt:  0.09412761777639389 loss:  -1.7645795345306396\n",
      "399 revenue:  4.6763410568237305 rgt:  0.09375406801700592 loss:  -1.762537956237793\n",
      "400 revenue:  4.686243534088135 rgt:  0.09137500077486038 loss:  -1.7711151838302612\n",
      "401 revenue:  4.6873016357421875 rgt:  0.08953890949487686 loss:  -1.7762480974197388\n",
      "402 revenue:  4.688926696777344 rgt:  0.08973675966262817 loss:  -1.7760951519012451\n",
      "403 revenue:  4.69038200378418 rgt:  0.08977928012609482 loss:  -1.7763179540634155\n",
      "404 revenue:  4.691758155822754 rgt:  0.09181902557611465 loss:  -1.77121102809906\n",
      "405 revenue:  4.691370010375977 rgt:  0.09460753947496414 loss:  -1.7637660503387451\n",
      "406 revenue:  4.692059516906738 rgt:  0.0975302904844284 loss:  -1.7562875747680664\n",
      "407 revenue:  4.691303730010986 rgt:  0.10022732615470886 loss:  -1.7491273880004883\n",
      "408 revenue:  4.690264701843262 rgt:  0.1026918962597847 loss:  -1.7425541877746582\n",
      "409 revenue:  4.689326763153076 rgt:  0.10366237163543701 loss:  -1.7398566007614136\n",
      "410 revenue:  4.688385009765625 rgt:  0.08973439037799835 loss:  -1.775976538658142\n",
      "411 revenue:  4.689436912536621 rgt:  0.08928252011537552 loss:  -1.7774266004562378\n",
      "412 revenue:  4.690866947174072 rgt:  0.08949584513902664 loss:  -1.777186393737793\n",
      "413 revenue:  4.692288875579834 rgt:  0.08984700590372086 loss:  -1.776577353477478\n",
      "414 revenue:  4.691510200500488 rgt:  0.09245650470256805 loss:  -1.7694662809371948\n",
      "415 revenue:  4.6904449462890625 rgt:  0.09239298850297928 loss:  -1.7693884372711182\n",
      "416 revenue:  4.689297676086426 rgt:  0.09236720204353333 loss:  -1.7691917419433594\n",
      "417 revenue:  4.6881537437438965 rgt:  0.09241009503602982 loss:  -1.768814206123352\n",
      "418 revenue:  4.687064170837402 rgt:  0.09261186420917511 loss:  -1.7680288553237915\n",
      "419 revenue:  4.68704080581665 rgt:  0.09418849647045135 loss:  -1.7638676166534424\n",
      "420 revenue:  4.6864094734191895 rgt:  0.09052448719739914 loss:  -1.7734143733978271\n",
      "421 revenue:  4.688086032867432 rgt:  0.08928924053907394 loss:  -1.7770965099334717\n",
      "422 revenue:  4.68972635269165 rgt:  0.08970680087804794 loss:  -1.7763599157333374\n",
      "423 revenue:  4.689083576202393 rgt:  0.09187682718038559 loss:  -1.7704403400421143\n",
      "424 revenue:  4.687952995300293 rgt:  0.09182872623205185 loss:  -1.7703068256378174\n",
      "425 revenue:  4.686923503875732 rgt:  0.09184525161981583 loss:  -1.7700252532958984\n",
      "426 revenue:  4.686516284942627 rgt:  0.09203924983739853 loss:  -1.769417405128479\n",
      "427 revenue:  4.686928749084473 rgt:  0.10024429857730865 loss:  -1.7480734586715698\n",
      "428 revenue:  4.686400890350342 rgt:  0.1024874672293663 loss:  -1.7421855926513672\n",
      "429 revenue:  4.685935020446777 rgt:  0.1025586947798729 loss:  -1.7418955564498901\n",
      "430 revenue:  4.685384750366211 rgt:  0.09031558036804199 loss:  -1.7737337350845337\n",
      "431 revenue:  4.687018871307373 rgt:  0.08904100954532623 loss:  -1.777513861656189\n",
      "432 revenue:  4.688800811767578 rgt:  0.08921030163764954 loss:  -1.7774726152420044\n",
      "433 revenue:  4.6905035972595215 rgt:  0.09038954973220825 loss:  -1.7747187614440918\n",
      "434 revenue:  4.691915512084961 rgt:  0.09204086661338806 loss:  -1.7706598043441772\n",
      "435 revenue:  4.690846920013428 rgt:  0.09207502007484436 loss:  -1.7703226804733276\n",
      "436 revenue:  4.689671993255615 rgt:  0.09204024076461792 loss:  -1.7701435089111328\n",
      "437 revenue:  4.688530445098877 rgt:  0.09204551577568054 loss:  -1.7698659896850586\n",
      "438 revenue:  4.688918590545654 rgt:  0.09227549284696579 loss:  -1.769346833229065\n",
      "439 revenue:  4.689618110656738 rgt:  0.09512751549482346 loss:  -1.7619976997375488\n",
      "440 revenue:  4.6907124519348145 rgt:  0.09122269600629807 loss:  -1.7725517749786377\n",
      "441 revenue:  4.6921467781066895 rgt:  0.08960195630788803 loss:  -1.7771984338760376\n",
      "442 revenue:  4.693752288818359 rgt:  0.08975943922996521 loss:  -1.777148723602295\n",
      "443 revenue:  4.69514274597168 rgt:  0.09077845513820648 loss:  -1.7747548818588257\n",
      "444 revenue:  4.694572448730469 rgt:  0.09195420145988464 loss:  -1.7715024948120117\n",
      "445 revenue:  4.693730354309082 rgt:  0.09368173778057098 loss:  -1.7667453289031982\n",
      "446 revenue:  4.692389011383057 rgt:  0.09339802712202072 loss:  -1.7671834230422974\n",
      "447 revenue:  4.692990303039551 rgt:  0.09350184351205826 loss:  -1.7670485973358154\n",
      "448 revenue:  4.691679000854492 rgt:  0.09408706426620483 loss:  -1.7652053833007812\n",
      "449 revenue:  4.690539836883545 rgt:  0.09491271525621414 loss:  -1.7627737522125244\n",
      "450 revenue:  4.689164161682129 rgt:  0.0902366042137146 loss:  -1.7748169898986816\n",
      "451 revenue:  4.690816402435303 rgt:  0.08947041630744934 loss:  -1.7772427797317505\n",
      "452 revenue:  4.692575454711914 rgt:  0.08958710730075836 loss:  -1.7773370742797852\n",
      "453 revenue:  4.6942362785339355 rgt:  0.08965721726417542 loss:  -1.7775331735610962\n",
      "454 revenue:  4.695804595947266 rgt:  0.09070203453302383 loss:  -1.7751107215881348\n",
      "455 revenue:  4.6972270011901855 rgt:  0.09382651746273041 loss:  -1.7671711444854736\n",
      "456 revenue:  4.696216583251953 rgt:  0.09325850009918213 loss:  -1.7684346437454224\n",
      "457 revenue:  4.6947407722473145 rgt:  0.09327434748411179 loss:  -1.768052101135254\n",
      "458 revenue:  4.693127155303955 rgt:  0.0933930054306984 loss:  -1.7673671245574951\n",
      "459 revenue:  4.691547393798828 rgt:  0.09363042563199997 loss:  -1.7663766145706177\n",
      "460 revenue:  4.690047264099121 rgt:  0.09088872373104095 loss:  -1.7732855081558228\n",
      "461 revenue:  4.6915669441223145 rgt:  0.08936610817909241 loss:  -1.777694821357727\n",
      "462 revenue:  4.69322395324707 rgt:  0.08956841379404068 loss:  -1.7775367498397827\n",
      "463 revenue:  4.6948561668396 rgt:  0.09110172837972641 loss:  -1.7738292217254639\n",
      "464 revenue:  4.695568561553955 rgt:  0.09198048710823059 loss:  -1.7716628313064575\n",
      "465 revenue:  4.6946330070495605 rgt:  0.09390830993652344 loss:  -1.766357183456421\n",
      "466 revenue:  4.694031715393066 rgt:  0.09370370954275131 loss:  -1.7667570114135742\n",
      "467 revenue:  4.694315433502197 rgt:  0.09398026764392853 loss:  -1.76609468460083\n",
      "468 revenue:  4.694972991943359 rgt:  0.09454923868179321 loss:  -1.7647507190704346\n",
      "469 revenue:  4.694302082061768 rgt:  0.09488170593976974 loss:  -1.7637234926223755\n",
      "470 revenue:  4.693593502044678 rgt:  0.09109126031398773 loss:  -1.7735657691955566\n",
      "471 revenue:  4.695357799530029 rgt:  0.08965876698493958 loss:  -1.7777880430221558\n",
      "472 revenue:  4.697048187255859 rgt:  0.09173213690519333 loss:  -1.7726622819900513\n",
      "473 revenue:  4.696460247039795 rgt:  0.0926225483417511 loss:  -1.7701698541641235\n",
      "474 revenue:  4.695600509643555 rgt:  0.09472136199474335 loss:  -1.7644438743591309\n",
      "475 revenue:  4.694636821746826 rgt:  0.09390600770711899 loss:  -1.7663642168045044\n",
      "476 revenue:  4.693625450134277 rgt:  0.09365149587392807 loss:  -1.766800880432129\n",
      "477 revenue:  4.694523811340332 rgt:  0.09409024566411972 loss:  -1.7658532857894897\n",
      "478 revenue:  4.693955898284912 rgt:  0.09404367953538895 loss:  -1.7658448219299316\n",
      "479 revenue:  4.694579601287842 rgt:  0.09408028423786163 loss:  -1.7658923864364624\n",
      "480 revenue:  4.693485260009766 rgt:  0.09088744968175888 loss:  -1.7740823030471802\n",
      "481 revenue:  4.695103168487549 rgt:  0.08940795809030533 loss:  -1.7783989906311035\n",
      "482 revenue:  4.696589469909668 rgt:  0.09047815948724747 loss:  -1.7758876085281372\n",
      "483 revenue:  4.69592809677124 rgt:  0.09259557723999023 loss:  -1.7701183557510376\n",
      "484 revenue:  4.694835186004639 rgt:  0.0925590768456459 loss:  -1.7699625492095947\n",
      "485 revenue:  4.693695068359375 rgt:  0.09253005683422089 loss:  -1.7697761058807373\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "486 revenue:  4.692539691925049 rgt:  0.09258834272623062 loss:  -1.7693554162979126\n",
      "487 revenue:  4.692474365234375 rgt:  0.09293472021818161 loss:  -1.7684253454208374\n",
      "488 revenue:  4.6927103996276855 rgt:  0.09679016470909119 loss:  -1.7583650350570679\n",
      "489 revenue:  4.6923699378967285 rgt:  0.1033119484782219 loss:  -1.7414541244506836\n",
      "490 revenue:  4.691957473754883 rgt:  0.09098245203495026 loss:  -1.7734771966934204\n",
      "491 revenue:  4.693592548370361 rgt:  0.08939513564109802 loss:  -1.778084635734558\n",
      "492 revenue:  4.694998264312744 rgt:  0.08945707231760025 loss:  -1.7782437801361084\n",
      "493 revenue:  4.696549892425537 rgt:  0.08956050127744675 loss:  -1.7783253192901611\n",
      "494 revenue:  4.698030948638916 rgt:  0.09247973561286926 loss:  -1.7709095478057861\n",
      "495 revenue:  4.69694185256958 rgt:  0.09240005165338516 loss:  -1.7708691358566284\n",
      "496 revenue:  4.6957478523254395 rgt:  0.09235379844903946 loss:  -1.7707159519195557\n",
      "497 revenue:  4.694491386413574 rgt:  0.09231656789779663 loss:  -1.770524501800537\n",
      "498 revenue:  4.6932454109191895 rgt:  0.09231310337781906 loss:  -1.770246148109436\n",
      "499 revenue:  4.693448543548584 rgt:  0.09267310798168182 loss:  -1.769341230392456\n",
      "500 revenue:  4.694250106811523 rgt:  0.09150167554616928 loss:  -1.772627830505371\n",
      "501 revenue:  4.695829391479492 rgt:  0.08956682682037354 loss:  -1.7781422138214111\n",
      "502 revenue:  4.697275161743164 rgt:  0.0897548496723175 loss:  -1.7779738903045654\n",
      "503 revenue:  4.698710918426514 rgt:  0.09030502289533615 loss:  -1.7768380641937256\n",
      "504 revenue:  4.699582099914551 rgt:  0.09284117817878723 loss:  -1.7703123092651367\n",
      "505 revenue:  4.698732376098633 rgt:  0.0945354476571083 loss:  -1.7656543254852295\n",
      "506 revenue:  4.697871685028076 rgt:  0.09575856477022171 loss:  -1.7622499465942383\n",
      "507 revenue:  4.696926593780518 rgt:  0.09655573964118958 loss:  -1.7599495649337769\n",
      "508 revenue:  4.695910930633545 rgt:  0.0970185250043869 loss:  -1.7585086822509766\n",
      "509 revenue:  4.694957256317139 rgt:  0.09740421921014786 loss:  -1.7572842836380005\n",
      "510 revenue:  4.694108486175537 rgt:  0.09073779731988907 loss:  -1.7746241092681885\n",
      "511 revenue:  4.695720195770264 rgt:  0.08952657878398895 loss:  -1.7782244682312012\n",
      "512 revenue:  4.697499752044678 rgt:  0.08975157886743546 loss:  -1.7780342102050781\n",
      "513 revenue:  4.69915771484375 rgt:  0.09071055799722672 loss:  -1.7758617401123047\n",
      "514 revenue:  4.700555324554443 rgt:  0.09290094673633575 loss:  -1.7703789472579956\n",
      "515 revenue:  4.699595928192139 rgt:  0.09278878569602966 loss:  -1.770453929901123\n",
      "516 revenue:  4.6984968185424805 rgt:  0.09274334460496902 loss:  -1.7703202962875366\n",
      "517 revenue:  4.697336673736572 rgt:  0.09275506436824799 loss:  -1.7700217962265015\n",
      "518 revenue:  4.696220397949219 rgt:  0.09394703805446625 loss:  -1.766621470451355\n",
      "519 revenue:  4.697175025939941 rgt:  0.09877514839172363 loss:  -1.7542363405227661\n",
      "520 revenue:  4.698019027709961 rgt:  0.09178297966718674 loss:  -1.7727514505386353\n",
      "521 revenue:  4.699251651763916 rgt:  0.08981812745332718 loss:  -1.7782608270645142\n",
      "522 revenue:  4.700647354125977 rgt:  0.08999758213758469 loss:  -1.778104305267334\n",
      "523 revenue:  4.70196533203125 rgt:  0.0900481715798378 loss:  -1.7782729864120483\n",
      "524 revenue:  4.70306921005249 rgt:  0.09040664881467819 loss:  -1.777572512626648\n",
      "525 revenue:  4.702192783355713 rgt:  0.09274183958768845 loss:  -1.7711766958236694\n",
      "526 revenue:  4.701016426086426 rgt:  0.09270630776882172 loss:  -1.7709994316101074\n",
      "527 revenue:  4.699717044830322 rgt:  0.09268095344305038 loss:  -1.7707667350769043\n",
      "528 revenue:  4.698357105255127 rgt:  0.09269864857196808 loss:  -1.7704061269760132\n",
      "529 revenue:  4.697041988372803 rgt:  0.09327393025159836 loss:  -1.7685844898223877\n",
      "530 revenue:  4.697333335876465 rgt:  0.09189995378255844 loss:  -1.7722830772399902\n",
      "531 revenue:  4.698707103729248 rgt:  0.08992195874452591 loss:  -1.7778583765029907\n",
      "532 revenue:  4.700226306915283 rgt:  0.09003276377916336 loss:  -1.7779130935668945\n",
      "533 revenue:  4.701596260070801 rgt:  0.0908375009894371 loss:  -1.7760863304138184\n",
      "534 revenue:  4.702697277069092 rgt:  0.0903049036860466 loss:  -1.7777576446533203\n",
      "535 revenue:  4.703212261199951 rgt:  0.0940466970205307 loss:  -1.7679719924926758\n",
      "536 revenue:  4.70197868347168 rgt:  0.09370511770248413 loss:  -1.7685866355895996\n",
      "537 revenue:  4.700686454772949 rgt:  0.09392031282186508 loss:  -1.7677220106124878\n",
      "538 revenue:  4.6994428634643555 rgt:  0.09375926107168198 loss:  -1.7678591012954712\n",
      "539 revenue:  4.698497772216797 rgt:  0.09398239105939865 loss:  -1.7670539617538452\n",
      "540 revenue:  4.698080539703369 rgt:  0.09116776287555695 loss:  -1.7743977308273315\n",
      "541 revenue:  4.699573993682861 rgt:  0.08970766514539719 loss:  -1.778630018234253\n",
      "542 revenue:  4.7010602951049805 rgt:  0.09051906317472458 loss:  -1.7768099308013916\n",
      "543 revenue:  4.702525615692139 rgt:  0.09224531799554825 loss:  -1.7725661993026733\n",
      "544 revenue:  4.701609134674072 rgt:  0.09019316732883453 loss:  -1.7778044939041138\n",
      "545 revenue:  4.702432155609131 rgt:  0.09379588812589645 loss:  -1.7684521675109863\n",
      "546 revenue:  4.701220989227295 rgt:  0.0937381386756897 loss:  -1.768324851989746\n",
      "547 revenue:  4.700013160705566 rgt:  0.09367077797651291 loss:  -1.768223762512207\n",
      "548 revenue:  4.699005126953125 rgt:  0.0936347171664238 loss:  -1.768086314201355\n",
      "549 revenue:  4.698235988616943 rgt:  0.09350480884313583 loss:  -1.7682511806488037\n",
      "550 revenue:  4.697453498840332 rgt:  0.09103550016880035 loss:  -1.7746046781539917\n",
      "551 revenue:  4.69895076751709 rgt:  0.0895925909280777 loss:  -1.778793454170227\n",
      "552 revenue:  4.7003583908081055 rgt:  0.09047747403383255 loss:  -1.7767587900161743\n",
      "553 revenue:  4.701722145080566 rgt:  0.09184738248586655 loss:  -1.7734346389770508\n",
      "554 revenue:  4.700967788696289 rgt:  0.09319884330034256 loss:  -1.7696878910064697\n",
      "555 revenue:  4.6996235847473145 rgt:  0.0931745320558548 loss:  -1.769441843032837\n",
      "556 revenue:  4.6982903480529785 rgt:  0.09319614619016647 loss:  -1.7690773010253906\n",
      "557 revenue:  4.6969895362854 rgt:  0.09330426901578903 loss:  -1.7684922218322754\n",
      "558 revenue:  4.696014404296875 rgt:  0.09362666308879852 loss:  -1.767417550086975\n",
      "559 revenue:  4.694864273071289 rgt:  0.09425017982721329 loss:  -1.765511393547058\n",
      "560 revenue:  4.694175720214844 rgt:  0.0911768227815628 loss:  -1.7734729051589966\n",
      "561 revenue:  4.69589376449585 rgt:  0.08945751935243607 loss:  -1.7784490585327148\n",
      "562 revenue:  4.6972336769104 rgt:  0.08961891382932663 loss:  -1.7783271074295044\n",
      "563 revenue:  4.698853015899658 rgt:  0.08968255668878555 loss:  -1.7785308361053467\n",
      "564 revenue:  4.7005205154418945 rgt:  0.09159581363201141 loss:  -1.7738245725631714\n",
      "565 revenue:  4.699761390686035 rgt:  0.09449616074562073 loss:  -1.7659950256347656\n",
      "566 revenue:  4.698807716369629 rgt:  0.09377594292163849 loss:  -1.7676687240600586\n",
      "567 revenue:  4.699217796325684 rgt:  0.09389878064393997 loss:  -1.7674400806427002\n",
      "568 revenue:  4.699719429016113 rgt:  0.09400594234466553 loss:  -1.7672737836837769\n",
      "569 revenue:  4.69892692565918 rgt:  0.09407664835453033 loss:  -1.7669049501419067\n",
      "570 revenue:  4.698300838470459 rgt:  0.09130702912807465 loss:  -1.7740789651870728\n",
      "571 revenue:  4.699947357177734 rgt:  0.08970574289560318 loss:  -1.7787212133407593\n",
      "572 revenue:  4.701654434204102 rgt:  0.09131643921136856 loss:  -1.7748273611068726\n",
      "573 revenue:  4.700718402862549 rgt:  0.09282591938972473 loss:  -1.7706146240234375\n",
      "574 revenue:  4.6996355056762695 rgt:  0.09275545179843903 loss:  -1.770551085472107\n",
      "575 revenue:  4.698494911193848 rgt:  0.0927538126707077 loss:  -1.7702921628952026\n",
      "576 revenue:  4.697575092315674 rgt:  0.09295154362916946 loss:  -1.7695578336715698\n",
      "577 revenue:  4.69774055480957 rgt:  0.09704507142305374 loss:  -1.7588614225387573\n",
      "578 revenue:  4.698800563812256 rgt:  0.09994138777256012 loss:  -1.7515952587127686\n",
      "579 revenue:  4.699573516845703 rgt:  0.10485460609197617 loss:  -1.7391828298568726\n",
      "580 revenue:  4.699361801147461 rgt:  0.09125586599111557 loss:  -1.7744593620300293\n",
      "581 revenue:  4.700813293457031 rgt:  0.08993430435657501 loss:  -1.778311014175415\n",
      "582 revenue:  4.702032089233398 rgt:  0.09165555983781815 loss:  -1.7740147113800049\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "583 revenue:  4.701094627380371 rgt:  0.09226716309785843 loss:  -1.7721785306930542\n",
      "584 revenue:  4.700067043304443 rgt:  0.0922173336148262 loss:  -1.7720733880996704\n",
      "585 revenue:  4.700854778289795 rgt:  0.09381601214408875 loss:  -1.7680354118347168\n",
      "586 revenue:  4.699914932250977 rgt:  0.09384051710367203 loss:  -1.7677541971206665\n",
      "587 revenue:  4.6989545822143555 rgt:  0.09378911554813385 loss:  -1.7676680088043213\n",
      "588 revenue:  4.698389053344727 rgt:  0.0938250795006752 loss:  -1.7674429416656494\n",
      "589 revenue:  4.6978373527526855 rgt:  0.0938514694571495 loss:  -1.767246127128601\n",
      "590 revenue:  4.697431564331055 rgt:  0.08967682719230652 loss:  -1.7782180309295654\n",
      "591 revenue:  4.698698043823242 rgt:  0.0893966406583786 loss:  -1.7792587280273438\n",
      "592 revenue:  4.700109481811523 rgt:  0.08960624784231186 loss:  -1.7790242433547974\n",
      "593 revenue:  4.7017083168029785 rgt:  0.08973011374473572 loss:  -1.7790623903274536\n",
      "594 revenue:  4.700872421264648 rgt:  0.09263397008180618 loss:  -1.7711572647094727\n",
      "595 revenue:  4.699752330780029 rgt:  0.09259873628616333 loss:  -1.7709920406341553\n",
      "596 revenue:  4.698544502258301 rgt:  0.09263405203819275 loss:  -1.7706199884414673\n",
      "597 revenue:  4.69735860824585 rgt:  0.09307140856981277 loss:  -1.7691915035247803\n",
      "598 revenue:  4.697452068328857 rgt:  0.10152558982372284 loss:  -1.7472041845321655\n",
      "599 revenue:  4.696925640106201 rgt:  0.10279180109500885 loss:  -1.7438358068466187\n"
     ]
    }
   ],
   "source": [
    "training_set = train_set_prob_3\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": "ee4569f5",
   "metadata": {},
   "source": [
    "# Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "7d6d573b",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MisreportNetBNIC(\n",
       "  (mlp): MLP(\n",
       "    (model): Sequential(\n",
       "      (fc1): Linear(in_features=30, out_features=120, bias=True)\n",
       "      (tanh1): Tanh()\n",
       "      (fc2): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh2): Tanh()\n",
       "      (fc3): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh3): Tanh()\n",
       "      (fc4): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh4): Tanh()\n",
       "      (fc5): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh5): Tanh()\n",
       "      (fc6): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh6): Tanh()\n",
       "      (fc7): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh7): Tanh()\n",
       "      (fc8): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh8): Tanh()\n",
       "      (fc9): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh9): Tanh()\n",
       "      (fc10): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh10): Tanh()\n",
       "      (fc11): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh11): Tanh()\n",
       "      (fc12): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh12): Tanh()\n",
       "      (fc13): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh13): Tanh()\n",
       "      (fc14): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh14): Tanh()\n",
       "      (fc15): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh15): Tanh()\n",
       "      (fc16): Linear(in_features=120, out_features=120, bias=True)\n",
       "      (tanh16): Tanh()\n",
       "      (fc17): Linear(in_features=120, out_features=30, bias=True)\n",
       "    )\n",
       "  )\n",
       ")"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "MNet = MisreportNetBNIC(n,m,nLayersMisreport,widthMisreport)\n",
    "MNet.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3ac6dc74",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4.696081638336182 0.09256371855735779 3.4700297508986373\n"
     ]
    }
   ],
   "source": [
    "rev,rgt = test(ANet,PNet,MNet,test_set_prob_3) # roughly 4.81721\n",
    "print(rev,rgt,(np.sqrt(rev) - np.sqrt(rgt))**2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "79e5cd6e",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.427196502685547 0.08607874810695648 4.146283984278157\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": "1e75c6ca",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.0678510665893555 0.11908210068941116 3.633240339219715\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": "b53e4d4f",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.094731330871582 0.14851480722427368 3.503541517806699\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": "206463f5",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5.014227867126465 0.2066597044467926 3.1849712186262846\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": "9397a13b",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.287034273147583 0.16255462169647217 1.9876414090911045\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": "5e386506",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3.62485933303833 0.13971763849258423 2.34126142551883\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": "a1000a09",
   "metadata": {
    "pycharm": {
     "is_executing": true,
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0006401389837265015 0.00010659615509212017 0.00022429335492371778\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": "5a6abd75",
   "metadata": {
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
