{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Code was run on Colab Pro"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import collections\n",
    "import torch.optim as optim\n",
    "from torch.optim import Optimizer\n",
    "import time\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from AdamW          import AdamW\n",
    "from utils          import utility, misreportUtility, misreportOptimization, trueUtility, loss\n",
    "from networks       import AdditiveMechanism, Misreports\n",
    "from restrictedAdam import Adam "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = 'cuda' if torch.cuda.is_available() else 'cpu'"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Set Random Seed "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initializing seeds\n",
    "torch.manual_seed(42)\n",
    "np.random.seed(42)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Testing Function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "def test(nBatch, nbrInit, R, gamma=0.001, minimum=0, maximum=1):\n",
    "    \n",
    "    \"\"\" This function computes the regret and payment of mechanism on a test set of size nBatch\n",
    "        The optimal misreport is computed by optimizing the utility function (not by using the Misreport network)\n",
    "        for R gradient steps (of stepsize gamma) and starting from nbrInit initialization, we only keep the best misreport\n",
    "        To compute the regret we evaluate the mechanism at the misreport and compare to the valuation\n",
    "        minimum and maximum indicate the range of the valuations\n",
    "    \"\"\"\n",
    "    \n",
    "    true = np.random.rand(nBatch,nAgent,nObject)\n",
    "\n",
    "    localMisreports     = np.random.rand(nBatch,nbrInit,nAgent,nObject)\n",
    "    batchMisreports     = torch.tensor(localMisreports).float().to(device)\n",
    "    batchTrueValuations = torch.tensor(true).float().to(device)\n",
    "    batchMisreports.requires_grad = True\n",
    "    \n",
    "    opt = Adam([batchMisreports], lr=gamma)\n",
    "    \n",
    "    for k in range(R):\n",
    "        advU         = misreportUtility(mechanism,batchTrueValuations,batchMisreports)\n",
    "        los          =  -1*torch.mean(advU).to(device)\n",
    "        los.backward()\n",
    "        opt.step(restricted= True, min=minimum, max=maximum)\n",
    "        opt.zero_grad()\n",
    "    \n",
    "    misReportUtilityMax  = torch.max(advU, dim =1)[0]\n",
    "    mechanism.zero_grad()\n",
    "    allocation, payment = mechanism(batchTrueValuations)\n",
    "    regret = F.relu(misReportUtilityMax -utility(batchTrueValuations, allocation, payment))\n",
    "    mregret= torch.sum(torch.mean(regret, dim=0)).to(device)\n",
    "    mregret= float(mregret.cpu().detach().numpy())\n",
    "\n",
    "    with torch.no_grad():\n",
    "        l,rMean,p = loss(payment, regret)\n",
    "\n",
    "    testRegret.append(mregret)\n",
    "    testPayment.append(float(p.detach().cpu().numpy() ))\n",
    "    testOptimal.append(float((-l).detach().cpu().numpy())**2)\n",
    "    \n",
    "    print(\"Total regret: \",'{0:.5f}'.format(mregret), \"Average regret per bidder: \",'{0:.5f}'.format(mregret/nAgent), \" Optimal Revenue: \",'{0:.3f}'.format(float((-l).detach().cpu().numpy())**2), \" payment: \",'{0:.3f}'.format(float(p.detach().cpu().numpy() )))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Initializing Networks"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "nAgent   = 5\n",
    "nObject  = 10\n",
    "\n",
    "# Parameters for the mechanism (payment and allocation network)\n",
    "nLayersAllocation   = 8\n",
    "nLayersPayment      = 8\n",
    "widthAllocation     = 200\n",
    "widthPayment        = 200\n",
    "\n",
    "# Parameters for the misreport network\n",
    "nLayersMisreport    = 8\n",
    "widthMisreport      = 200\n",
    "\n",
    "gamma              = 0.001 \n",
    "testBatch          = 10000\n",
    "\n",
    "nExperiments       = 200000\n",
    "batchSize          = 500\n",
    "nbrBatches         = int(nExperiments/batchSize)\n",
    "\n",
    "\n",
    "mechanism            = AdditiveMechanism(nAgent, nObject, nLayersAllocation, widthAllocation).to(device)\n",
    "optimizerMechanism   = AdamW(mechanism.parameters(), lr=0.001)\n",
    "\n",
    "misreport            = Misreports(nAgent,nObject,nLayersMisreport, widthMisreport).to(device)\n",
    "optimizerMisreport   = AdamW(misreport.parameters(), lr=0.001)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "testRegret    = []\n",
    "testMaxRegret = []\n",
    "testPayment   = []\n",
    "testOptimal   = []\n",
    "testTime      = []\n",
    "testIteration = [0]\n",
    "\n",
    "# range of valuations\n",
    "minimum            = 0\n",
    "maximum            = 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Training"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial Test\n",
      "Total regret:  1.92207 Average regret per bidder:  0.38441  Optimal Revenue:  5.994  payment:  0.740\n",
      "Batch:  2\n",
      "Total regret:  1.71574 Average regret per bidder:  0.34315  Optimal Revenue:  0.031  payment:  8.116\n",
      "Batch:  4\n",
      "Total regret:  0.01493 Average regret per bidder:  0.00299  Optimal Revenue:  4.685  payment:  5.298\n",
      "Batch:  6\n",
      "Total regret:  0.02776 Average regret per bidder:  0.00555  Optimal Revenue:  4.908  payment:  5.807\n",
      "Batch:  8\n",
      "Total regret:  0.01982 Average regret per bidder:  0.00396  Optimal Revenue:  5.085  payment:  5.835\n",
      "Batch:  10\n",
      "Total regret:  0.01539 Average regret per bidder:  0.00308  Optimal Revenue:  5.349  payment:  6.013\n",
      "Batch:  12\n",
      "Total regret:  0.01261 Average regret per bidder:  0.00252  Optimal Revenue:  5.433  payment:  6.031\n",
      "Batch:  14\n",
      "Total regret:  0.01541 Average regret per bidder:  0.00308  Optimal Revenue:  5.445  payment:  6.116\n",
      "Batch:  16\n",
      "Total regret:  0.02063 Average regret per bidder:  0.00413  Optimal Revenue:  5.477  payment:  6.273\n",
      "Batch:  18\n",
      "Total regret:  0.02056 Average regret per bidder:  0.00411  Optimal Revenue:  5.646  payment:  6.452\n",
      "Batch:  20\n",
      "Total regret:  0.01550 Average regret per bidder:  0.00310  Optimal Revenue:  5.692  payment:  6.380\n",
      "Batch:  22\n",
      "Total regret:  0.02508 Average regret per bidder:  0.00502  Optimal Revenue:  5.571  payment:  6.471\n",
      "Batch:  24\n",
      "Total regret:  0.01919 Average regret per bidder:  0.00384  Optimal Revenue:  5.699  payment:  6.476\n",
      "Batch:  26\n",
      "Total regret:  0.01999 Average regret per bidder:  0.00400  Optimal Revenue:  5.811  payment:  6.615\n",
      "Batch:  28\n",
      "Total regret:  0.01780 Average regret per bidder:  0.00356  Optimal Revenue:  5.898  payment:  6.655\n",
      "Batch:  30\n",
      "Total regret:  0.02030 Average regret per bidder:  0.00406  Optimal Revenue:  5.640  payment:  6.439\n",
      "Batch:  32\n",
      "Total regret:  0.02194 Average regret per bidder:  0.00439  Optimal Revenue:  5.850  payment:  6.701\n",
      "Batch:  34\n",
      "Total regret:  0.02153 Average regret per bidder:  0.00431  Optimal Revenue:  5.862  payment:  6.705\n",
      "Batch:  36\n",
      "Total regret:  0.01880 Average regret per bidder:  0.00376  Optimal Revenue:  5.973  payment:  6.759\n",
      "Batch:  38\n",
      "Total regret:  0.02455 Average regret per bidder:  0.00491  Optimal Revenue:  5.878  payment:  6.790\n",
      "Batch:  40\n",
      "Total regret:  0.02587 Average regret per bidder:  0.00517  Optimal Revenue:  5.896  payment:  6.838\n",
      "Batch:  42\n",
      "Total regret:  0.02538 Average regret per bidder:  0.00508  Optimal Revenue:  5.971  payment:  6.908\n",
      "Batch:  44\n",
      "Total regret:  0.02414 Average regret per bidder:  0.00483  Optimal Revenue:  5.866  payment:  6.768\n",
      "Batch:  46\n",
      "Total regret:  0.03059 Average regret per bidder:  0.00612  Optimal Revenue:  5.729  payment:  6.755\n",
      "Batch:  48\n",
      "Total regret:  0.03081 Average regret per bidder:  0.00616  Optimal Revenue:  5.854  payment:  6.895\n",
      "Batch:  50\n",
      "Total regret:  0.02439 Average regret per bidder:  0.00488  Optimal Revenue:  5.901  payment:  6.811\n",
      "Batch:  52\n",
      "Total regret:  0.02568 Average regret per bidder:  0.00514  Optimal Revenue:  5.886  payment:  6.823\n",
      "Batch:  54\n",
      "Total regret:  0.02520 Average regret per bidder:  0.00504  Optimal Revenue:  5.955  payment:  6.886\n",
      "Batch:  56\n",
      "Total regret:  0.03366 Average regret per bidder:  0.00673  Optimal Revenue:  5.836  payment:  6.932\n",
      "Batch:  58\n",
      "Total regret:  0.02447 Average regret per bidder:  0.00489  Optimal Revenue:  5.946  payment:  6.861\n",
      "Batch:  60\n",
      "Total regret:  0.01997 Average regret per bidder:  0.00399  Optimal Revenue:  5.981  payment:  6.796\n",
      "\n"
     ]
    }
   ],
   "source": [
    "duration   = 0\n",
    "R          = 100\n",
    "\n",
    "i=0\n",
    "\n",
    "print(\"Initial Test\")\n",
    "test(50, nbrInit=300, R=300, gamma=0.001, minimum=0, maximum=1)\n",
    "\n",
    "for t in range(1,60*nbrBatches+1):\n",
    "    \n",
    "    # Reinitialize Misreport network periodically at the beginning of training\n",
    "    if (t%(2*nbrBatches) ==1):\n",
    "      if   t< 20*nbrBatches+2 :\n",
    "    \n",
    "        misreport            = Misreports(nAgent,nObject,nLayersMisreport, widthMisreport).to(device)\n",
    "        optimizerMisreport   = AdamW(misreport.parameters(), lr=0.001)\n",
    "\n",
    "    batchTrueValuations = torch.tensor(np.random.rand(batchSize,nAgent,nObject)).float().to(device)\n",
    "    \n",
    "    # Optimize Misreport Network for R steps\n",
    "    for k in range(R):\n",
    "  \n",
    "        misreports          = misreport(batchTrueValuations).unsqueeze(1)\n",
    "        mUtility            = misreportUtility(mechanism,batchTrueValuations,misreports).squeeze(1)\n",
    "        mLoss               = torch.sum(torch.mean(-mUtility,dim=0))\n",
    "\n",
    "        optimizerMisreport.zero_grad()\n",
    "        mLoss.backward()\n",
    "        optimizerMisreport.step()\n",
    "\n",
    "    \n",
    "    # Optimize Mechanism network for one step\n",
    "    misreports          = misreport(batchTrueValuations).unsqueeze(1)\n",
    "    mUtility            = misreportUtility(mechanism,batchTrueValuations,misreports).squeeze(1)\n",
    "\n",
    "    allocation, payment = mechanism(batchTrueValuations)\n",
    "\n",
    "    regret     = F.relu(mUtility -utility(batchTrueValuations, allocation, payment))\n",
    "    l,rMean,p = loss(payment, regret)\n",
    "        \n",
    "    optimizerMechanism.zero_grad()\n",
    "\n",
    "    l.backward()\n",
    "\n",
    "    optimizerMechanism.step()\n",
    "    \n",
    "    # Test mechanism periodically\n",
    "    if t % (2*nbrBatches)==0 :\n",
    "        print(\"Batch: \", 2*int(t/(2*nbrBatches)))\n",
    "        testTime.append(duration)\n",
    "        testIteration.append(t/nbrBatches)\n",
    "        test(50, nbrInit=300, R=300, gamma=0.001, minimum=0, maximum=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Testing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total regret:  0.01943 Average regret per bidder:  0.00389  Optimal Revenue:  5.988  payment:  6.791\n",
      "Total regret:  0.02011 Average regret per bidder:  0.00402  Optimal Revenue:  6.049  payment:  6.872\n",
      "Total regret:  0.02389 Average regret per bidder:  0.00478  Optimal Revenue:  5.948  payment:  6.850\n",
      "Total regret:  0.02023 Average regret per bidder:  0.00405  Optimal Revenue:  5.995  payment:  6.817\n",
      "Total regret:  0.01955 Average regret per bidder:  0.00391  Optimal Revenue:  6.041  payment:  6.849\n",
      "Total regret:  0.02040 Average regret per bidder:  0.00408  Optimal Revenue:  6.006  payment:  6.833\n",
      "Total regret:  0.02208 Average regret per bidder:  0.00442  Optimal Revenue:  5.914  payment:  6.773\n",
      "Total regret:  0.01941 Average regret per bidder:  0.00388  Optimal Revenue:  6.006  payment:  6.809\n",
      "Total regret:  0.02135 Average regret per bidder:  0.00427  Optimal Revenue:  6.110  payment:  6.965\n",
      "Total regret:  0.02067 Average regret per bidder:  0.00413  Optimal Revenue:  5.960  payment:  6.789\n",
      "Total regret:  0.01950 Average regret per bidder:  0.00390  Optimal Revenue:  6.064  payment:  6.873\n",
      "Total regret:  0.02010 Average regret per bidder:  0.00402  Optimal Revenue:  6.089  payment:  6.915\n",
      "Total regret:  0.02164 Average regret per bidder:  0.00433  Optimal Revenue:  5.953  payment:  6.804\n",
      "Total regret:  0.01906 Average regret per bidder:  0.00381  Optimal Revenue:  6.025  payment:  6.821\n",
      "Total regret:  0.02068 Average regret per bidder:  0.00414  Optimal Revenue:  5.964  payment:  6.795\n",
      "Total regret:  0.02339 Average regret per bidder:  0.00468  Optimal Revenue:  5.913  payment:  6.802\n",
      "Total regret:  0.02305 Average regret per bidder:  0.00461  Optimal Revenue:  5.885  payment:  6.764\n",
      "Total regret:  0.02458 Average regret per bidder:  0.00492  Optimal Revenue:  5.876  payment:  6.789\n",
      "Total regret:  0.02518 Average regret per bidder:  0.00504  Optimal Revenue:  5.893  payment:  6.820\n",
      "Total regret:  0.01980 Average regret per bidder:  0.00396  Optimal Revenue:  5.987  payment:  6.798\n",
      "Total regret:  0.02243 Average regret per bidder:  0.00449  Optimal Revenue:  5.910  payment:  6.777\n",
      "Total regret:  0.02081 Average regret per bidder:  0.00416  Optimal Revenue:  6.036  payment:  6.874\n",
      "Total regret:  0.02132 Average regret per bidder:  0.00426  Optimal Revenue:  5.948  payment:  6.792\n",
      "Total regret:  0.02061 Average regret per bidder:  0.00412  Optimal Revenue:  6.062  payment:  6.898\n",
      "Total regret:  0.01793 Average regret per bidder:  0.00359  Optimal Revenue:  6.112  payment:  6.886\n",
      "Total regret:  0.01925 Average regret per bidder:  0.00385  Optimal Revenue:  6.005  payment:  6.804\n",
      "Total regret:  0.01995 Average regret per bidder:  0.00399  Optimal Revenue:  6.031  payment:  6.848\n",
      "Total regret:  0.02240 Average regret per bidder:  0.00448  Optimal Revenue:  5.879  payment:  6.743\n",
      "Total regret:  0.01690 Average regret per bidder:  0.00338  Optimal Revenue:  6.115  payment:  6.863\n",
      "Total regret:  0.02329 Average regret per bidder:  0.00466  Optimal Revenue:  5.945  payment:  6.834\n",
      "Total regret:  0.02063 Average regret per bidder:  0.00413  Optimal Revenue:  6.064  payment:  6.900\n",
      "Total regret:  0.02417 Average regret per bidder:  0.00483  Optimal Revenue:  5.862  payment:  6.765\n",
      "Total regret:  0.02231 Average regret per bidder:  0.00446  Optimal Revenue:  5.930  payment:  6.796\n",
      "Total regret:  0.01979 Average regret per bidder:  0.00396  Optimal Revenue:  6.055  payment:  6.871\n",
      "Total regret:  0.02250 Average regret per bidder:  0.00450  Optimal Revenue:  5.938  payment:  6.808\n",
      "Total regret:  0.01856 Average regret per bidder:  0.00371  Optimal Revenue:  5.975  payment:  6.756\n",
      "Total regret:  0.02253 Average regret per bidder:  0.00451  Optimal Revenue:  5.986  payment:  6.861\n",
      "Total regret:  0.02255 Average regret per bidder:  0.00451  Optimal Revenue:  5.961  payment:  6.835\n",
      "Total regret:  0.01892 Average regret per bidder:  0.00378  Optimal Revenue:  5.939  payment:  6.726\n",
      "Total regret:  0.02243 Average regret per bidder:  0.00449  Optimal Revenue:  5.920  payment:  6.788\n",
      "Total regret:  0.01996 Average regret per bidder:  0.00399  Optimal Revenue:  6.111  payment:  6.934\n",
      "Total regret:  0.01909 Average regret per bidder:  0.00382  Optimal Revenue:  6.057  payment:  6.856\n",
      "Total regret:  0.01995 Average regret per bidder:  0.00399  Optimal Revenue:  6.011  payment:  6.828\n",
      "Total regret:  0.02089 Average regret per bidder:  0.00418  Optimal Revenue:  5.898  payment:  6.729\n",
      "Total regret:  0.01879 Average regret per bidder:  0.00376  Optimal Revenue:  5.995  payment:  6.782\n",
      "Total regret:  0.02204 Average regret per bidder:  0.00441  Optimal Revenue:  6.015  payment:  6.880\n",
      "Total regret:  0.02253 Average regret per bidder:  0.00451  Optimal Revenue:  5.851  payment:  6.716\n",
      "Total regret:  0.02241 Average regret per bidder:  0.00448  Optimal Revenue:  5.920  payment:  6.787\n",
      "Total regret:  0.02170 Average regret per bidder:  0.00434  Optimal Revenue:  6.066  payment:  6.927\n",
      "Total regret:  0.02234 Average regret per bidder:  0.00447  Optimal Revenue:  5.942  payment:  6.809\n",
      "Total regret:  0.02041 Average regret per bidder:  0.00408  Optimal Revenue:  6.120  payment:  6.954\n",
      "Total regret:  0.02299 Average regret per bidder:  0.00460  Optimal Revenue:  5.922  payment:  6.802\n",
      "Total regret:  0.02229 Average regret per bidder:  0.00446  Optimal Revenue:  5.965  payment:  6.833\n",
      "Total regret:  0.02608 Average regret per bidder:  0.00522  Optimal Revenue:  5.788  payment:  6.725\n",
      "Total regret:  0.01929 Average regret per bidder:  0.00386  Optimal Revenue:  6.062  payment:  6.866\n",
      "Total regret:  0.02088 Average regret per bidder:  0.00418  Optimal Revenue:  6.005  payment:  6.843\n",
      "Total regret:  0.02013 Average regret per bidder:  0.00403  Optimal Revenue:  5.995  payment:  6.815\n",
      "Total regret:  0.02191 Average regret per bidder:  0.00438  Optimal Revenue:  5.941  payment:  6.798\n",
      "Total regret:  0.02227 Average regret per bidder:  0.00445  Optimal Revenue:  5.923  payment:  6.787\n",
      "Total regret:  0.02193 Average regret per bidder:  0.00439  Optimal Revenue:  5.983  payment:  6.843\n",
      "Total regret:  0.02080 Average regret per bidder:  0.00416  Optimal Revenue:  6.097  payment:  6.939\n",
      "Total regret:  0.01804 Average regret per bidder:  0.00361  Optimal Revenue:  6.040  payment:  6.812\n",
      "Total regret:  0.02034 Average regret per bidder:  0.00407  Optimal Revenue:  5.958  payment:  6.781\n",
      "Total regret:  0.02378 Average regret per bidder:  0.00476  Optimal Revenue:  5.977  payment:  6.879\n",
      "Total regret:  0.02032 Average regret per bidder:  0.00406  Optimal Revenue:  5.977  payment:  6.799\n",
      "Total regret:  0.02002 Average regret per bidder:  0.00400  Optimal Revenue:  6.001  payment:  6.818\n",
      "Total regret:  0.02254 Average regret per bidder:  0.00451  Optimal Revenue:  5.946  payment:  6.818\n",
      "Total regret:  0.01955 Average regret per bidder:  0.00391  Optimal Revenue:  6.044  payment:  6.853\n",
      "Total regret:  0.02062 Average regret per bidder:  0.00412  Optimal Revenue:  6.126  payment:  6.966\n",
      "Total regret:  0.01940 Average regret per bidder:  0.00388  Optimal Revenue:  6.065  payment:  6.872\n",
      "Total regret:  0.02108 Average regret per bidder:  0.00422  Optimal Revenue:  6.017  payment:  6.861\n",
      "Total regret:  0.02326 Average regret per bidder:  0.00465  Optimal Revenue:  5.934  payment:  6.821\n",
      "Total regret:  0.02294 Average regret per bidder:  0.00459  Optimal Revenue:  5.905  payment:  6.783\n",
      "Total regret:  0.02214 Average regret per bidder:  0.00443  Optimal Revenue:  5.971  payment:  6.836\n",
      "Total regret:  0.02057 Average regret per bidder:  0.00411  Optimal Revenue:  5.892  payment:  6.715\n",
      "Total regret:  0.02179 Average regret per bidder:  0.00436  Optimal Revenue:  5.998  payment:  6.857\n",
      "Total regret:  0.01859 Average regret per bidder:  0.00372  Optimal Revenue:  6.031  payment:  6.817\n",
      "Total regret:  0.02106 Average regret per bidder:  0.00421  Optimal Revenue:  5.993  payment:  6.835\n",
      "Total regret:  0.02026 Average regret per bidder:  0.00405  Optimal Revenue:  6.023  payment:  6.848\n",
      "Total regret:  0.02154 Average regret per bidder:  0.00431  Optimal Revenue:  5.980  payment:  6.832\n",
      "Total regret:  0.02421 Average regret per bidder:  0.00484  Optimal Revenue:  5.953  payment:  6.862\n",
      "Total regret:  0.01941 Average regret per bidder:  0.00388  Optimal Revenue:  6.023  payment:  6.827\n",
      "Total regret:  0.01959 Average regret per bidder:  0.00392  Optimal Revenue:  6.052  payment:  6.862\n",
      "Total regret:  0.01981 Average regret per bidder:  0.00396  Optimal Revenue:  5.943  payment:  6.752\n",
      "Total regret:  0.02123 Average regret per bidder:  0.00425  Optimal Revenue:  5.957  payment:  6.800\n",
      "Total regret:  0.02193 Average regret per bidder:  0.00439  Optimal Revenue:  5.929  payment:  6.786\n",
      "Total regret:  0.01818 Average regret per bidder:  0.00364  Optimal Revenue:  6.044  payment:  6.820\n",
      "Total regret:  0.02513 Average regret per bidder:  0.00503  Optimal Revenue:  5.822  payment:  6.743\n",
      "Total regret:  0.02124 Average regret per bidder:  0.00425  Optimal Revenue:  5.951  payment:  6.794\n",
      "Total regret:  0.02312 Average regret per bidder:  0.00462  Optimal Revenue:  5.882  payment:  6.762\n",
      "Total regret:  0.02353 Average regret per bidder:  0.00471  Optimal Revenue:  5.935  payment:  6.828\n",
      "Total regret:  0.02287 Average regret per bidder:  0.00457  Optimal Revenue:  5.957  payment:  6.837\n",
      "Total regret:  0.02316 Average regret per bidder:  0.00463  Optimal Revenue:  5.937  payment:  6.822\n",
      "Total regret:  0.02244 Average regret per bidder:  0.00449  Optimal Revenue:  5.885  payment:  6.750\n",
      "Total regret:  0.02099 Average regret per bidder:  0.00420  Optimal Revenue:  5.943  payment:  6.779\n",
      "Total regret:  0.01945 Average regret per bidder:  0.00389  Optimal Revenue:  5.993  payment:  6.796\n",
      "Total regret:  0.02022 Average regret per bidder:  0.00404  Optimal Revenue:  5.945  payment:  6.763\n",
      "Total regret:  0.02168 Average regret per bidder:  0.00434  Optimal Revenue:  6.011  payment:  6.868\n",
      "Total regret:  0.02208 Average regret per bidder:  0.00442  Optimal Revenue:  5.944  payment:  6.805\n",
      "Total regret:  0.01828 Average regret per bidder:  0.00366  Optimal Revenue:  5.940  payment:  6.712\n",
      "Total regret:  0.01908 Average regret per bidder:  0.00382  Optimal Revenue:  6.083  payment:  6.883\n",
      "Total regret:  0.02047 Average regret per bidder:  0.00409  Optimal Revenue:  5.925  payment:  6.748\n",
      "Total regret:  0.01891 Average regret per bidder:  0.00378  Optimal Revenue:  5.967  payment:  6.756\n",
      "Total regret:  0.01655 Average regret per bidder:  0.00331  Optimal Revenue:  6.130  payment:  6.870\n",
      "Total regret:  0.02363 Average regret per bidder:  0.00473  Optimal Revenue:  6.030  payment:  6.933\n",
      "Total regret:  0.01941 Average regret per bidder:  0.00388  Optimal Revenue:  6.062  payment:  6.869\n",
      "Total regret:  0.02146 Average regret per bidder:  0.00429  Optimal Revenue:  5.966  payment:  6.814\n",
      "Total regret:  0.02136 Average regret per bidder:  0.00427  Optimal Revenue:  5.986  payment:  6.834\n",
      "Total regret:  0.01829 Average regret per bidder:  0.00366  Optimal Revenue:  6.058  payment:  6.837\n",
      "Total regret:  0.02304 Average regret per bidder:  0.00461  Optimal Revenue:  5.982  payment:  6.867\n",
      "Total regret:  0.02254 Average regret per bidder:  0.00451  Optimal Revenue:  5.924  payment:  6.794\n",
      "Total regret:  0.01987 Average regret per bidder:  0.00397  Optimal Revenue:  5.948  payment:  6.758\n",
      "Total regret:  0.02040 Average regret per bidder:  0.00408  Optimal Revenue:  6.068  payment:  6.899\n",
      "Total regret:  0.02079 Average regret per bidder:  0.00416  Optimal Revenue:  5.971  payment:  6.804\n",
      "Total regret:  0.02341 Average regret per bidder:  0.00468  Optimal Revenue:  5.972  payment:  6.865\n",
      "Total regret:  0.02098 Average regret per bidder:  0.00420  Optimal Revenue:  6.024  payment:  6.865\n",
      "Total regret:  0.02522 Average regret per bidder:  0.00504  Optimal Revenue:  5.852  payment:  6.776\n",
      "Total regret:  0.02197 Average regret per bidder:  0.00439  Optimal Revenue:  5.859  payment:  6.712\n",
      "Total regret:  0.01864 Average regret per bidder:  0.00373  Optimal Revenue:  6.009  payment:  6.794\n",
      "Total regret:  0.02254 Average regret per bidder:  0.00451  Optimal Revenue:  5.889  payment:  6.757\n",
      "Total regret:  0.01929 Average regret per bidder:  0.00386  Optimal Revenue:  6.023  payment:  6.825\n",
      "Total regret:  0.02297 Average regret per bidder:  0.00459  Optimal Revenue:  5.893  payment:  6.771\n",
      "Total regret:  0.02089 Average regret per bidder:  0.00418  Optimal Revenue:  5.960  payment:  6.795\n",
      "Total regret:  0.01949 Average regret per bidder:  0.00390  Optimal Revenue:  6.007  payment:  6.812\n",
      "Total regret:  0.02187 Average regret per bidder:  0.00437  Optimal Revenue:  5.939  payment:  6.795\n",
      "Total regret:  0.02081 Average regret per bidder:  0.00416  Optimal Revenue:  5.974  payment:  6.808\n",
      "Total regret:  0.01878 Average regret per bidder:  0.00376  Optimal Revenue:  6.058  payment:  6.850\n",
      "Total regret:  0.02125 Average regret per bidder:  0.00425  Optimal Revenue:  5.906  payment:  6.746\n",
      "Total regret:  0.01768 Average regret per bidder:  0.00354  Optimal Revenue:  6.120  payment:  6.888\n",
      "Total regret:  0.02293 Average regret per bidder:  0.00459  Optimal Revenue:  5.878  payment:  6.754\n",
      "Total regret:  0.01910 Average regret per bidder:  0.00382  Optimal Revenue:  6.011  payment:  6.807\n",
      "Total regret:  0.02303 Average regret per bidder:  0.00461  Optimal Revenue:  5.975  payment:  6.860\n",
      "Total regret:  0.02059 Average regret per bidder:  0.00412  Optimal Revenue:  5.973  payment:  6.801\n",
      "Total regret:  0.02213 Average regret per bidder:  0.00443  Optimal Revenue:  5.894  payment:  6.753\n",
      "Total regret:  0.02036 Average regret per bidder:  0.00407  Optimal Revenue:  6.054  payment:  6.883\n",
      "Total regret:  0.01785 Average regret per bidder:  0.00357  Optimal Revenue:  6.018  payment:  6.784\n",
      "Total regret:  0.01819 Average regret per bidder:  0.00364  Optimal Revenue:  6.094  payment:  6.873\n",
      "Total regret:  0.01843 Average regret per bidder:  0.00369  Optimal Revenue:  6.109  payment:  6.894\n",
      "Total regret:  0.01736 Average regret per bidder:  0.00347  Optimal Revenue:  6.069  payment:  6.826\n",
      "Total regret:  0.01806 Average regret per bidder:  0.00361  Optimal Revenue:  6.126  payment:  6.903\n",
      "Total regret:  0.02201 Average regret per bidder:  0.00440  Optimal Revenue:  5.932  payment:  6.790\n",
      "Total regret:  0.02564 Average regret per bidder:  0.00513  Optimal Revenue:  5.853  payment:  6.786\n",
      "Total regret:  0.02225 Average regret per bidder:  0.00445  Optimal Revenue:  5.955  payment:  6.821\n",
      "Total regret:  0.02280 Average regret per bidder:  0.00456  Optimal Revenue:  5.989  payment:  6.870\n",
      "Total regret:  0.02073 Average regret per bidder:  0.00415  Optimal Revenue:  5.996  payment:  6.830\n",
      "Total regret:  0.01850 Average regret per bidder:  0.00370  Optimal Revenue:  6.045  payment:  6.829\n",
      "Total regret:  0.01991 Average regret per bidder:  0.00398  Optimal Revenue:  6.032  payment:  6.849\n",
      "Total regret:  0.02135 Average regret per bidder:  0.00427  Optimal Revenue:  6.033  payment:  6.884\n",
      "Total regret:  0.02002 Average regret per bidder:  0.00400  Optimal Revenue:  5.978  payment:  6.793\n",
      "Total regret:  0.02231 Average regret per bidder:  0.00446  Optimal Revenue:  5.881  payment:  6.743\n",
      "Total regret:  0.02436 Average regret per bidder:  0.00487  Optimal Revenue:  5.824  payment:  6.728\n",
      "Total regret:  0.01895 Average regret per bidder:  0.00379  Optimal Revenue:  6.039  payment:  6.833\n",
      "Total regret:  0.02075 Average regret per bidder:  0.00415  Optimal Revenue:  5.861  payment:  6.686\n",
      "Total regret:  0.02109 Average regret per bidder:  0.00422  Optimal Revenue:  5.963  payment:  6.803\n",
      "Total regret:  0.01941 Average regret per bidder:  0.00388  Optimal Revenue:  6.055  payment:  6.862\n",
      "Total regret:  0.02543 Average regret per bidder:  0.00509  Optimal Revenue:  5.850  payment:  6.779\n",
      "Total regret:  0.02323 Average regret per bidder:  0.00465  Optimal Revenue:  5.882  payment:  6.765\n",
      "Total regret:  0.02183 Average regret per bidder:  0.00437  Optimal Revenue:  6.054  payment:  6.917\n",
      "Total regret:  0.01970 Average regret per bidder:  0.00394  Optimal Revenue:  5.897  payment:  6.700\n",
      "Total regret:  0.02053 Average regret per bidder:  0.00411  Optimal Revenue:  6.079  payment:  6.913\n",
      "Total regret:  0.02115 Average regret per bidder:  0.00423  Optimal Revenue:  5.920  payment:  6.759\n",
      "Total regret:  0.02345 Average regret per bidder:  0.00469  Optimal Revenue:  5.933  payment:  6.825\n",
      "Total regret:  0.02009 Average regret per bidder:  0.00402  Optimal Revenue:  6.049  payment:  6.871\n",
      "Total regret:  0.01929 Average regret per bidder:  0.00386  Optimal Revenue:  5.961  payment:  6.758\n",
      "Total regret:  0.02108 Average regret per bidder:  0.00422  Optimal Revenue:  5.908  payment:  6.744\n",
      "Total regret:  0.01869 Average regret per bidder:  0.00374  Optimal Revenue:  5.990  payment:  6.775\n",
      "Total regret:  0.01977 Average regret per bidder:  0.00395  Optimal Revenue:  6.079  payment:  6.896\n",
      "Total regret:  0.01935 Average regret per bidder:  0.00387  Optimal Revenue:  6.017  payment:  6.819\n",
      "Total regret:  0.02044 Average regret per bidder:  0.00409  Optimal Revenue:  6.130  payment:  6.966\n",
      "Total regret:  0.02070 Average regret per bidder:  0.00414  Optimal Revenue:  6.016  payment:  6.851\n",
      "Total regret:  0.02297 Average regret per bidder:  0.00459  Optimal Revenue:  6.082  payment:  6.973\n",
      "Total regret:  0.01727 Average regret per bidder:  0.00345  Optimal Revenue:  6.092  payment:  6.848\n",
      "Total regret:  0.02289 Average regret per bidder:  0.00458  Optimal Revenue:  5.989  payment:  6.872\n",
      "Total regret:  0.02314 Average regret per bidder:  0.00463  Optimal Revenue:  5.927  payment:  6.811\n",
      "Total regret:  0.02278 Average regret per bidder:  0.00456  Optimal Revenue:  5.893  payment:  6.766\n",
      "Total regret:  0.02040 Average regret per bidder:  0.00408  Optimal Revenue:  5.872  payment:  6.689\n",
      "Total regret:  0.01935 Average regret per bidder:  0.00387  Optimal Revenue:  6.056  payment:  6.861\n",
      "Total regret:  0.01959 Average regret per bidder:  0.00392  Optimal Revenue:  6.108  payment:  6.922\n",
      "Total regret:  0.02409 Average regret per bidder:  0.00482  Optimal Revenue:  5.900  payment:  6.803\n",
      "Total regret:  0.02319 Average regret per bidder:  0.00464  Optimal Revenue:  5.954  payment:  6.841\n",
      "Total regret:  0.02100 Average regret per bidder:  0.00420  Optimal Revenue:  5.947  payment:  6.784\n",
      "Total regret:  0.02380 Average regret per bidder:  0.00476  Optimal Revenue:  5.903  payment:  6.800\n",
      "Total regret:  0.02166 Average regret per bidder:  0.00433  Optimal Revenue:  5.977  payment:  6.832\n",
      "Total regret:  0.02213 Average regret per bidder:  0.00443  Optimal Revenue:  5.993  payment:  6.859\n",
      "Total regret:  0.02065 Average regret per bidder:  0.00413  Optimal Revenue:  6.024  payment:  6.857\n",
      "Total regret:  0.02364 Average regret per bidder:  0.00473  Optimal Revenue:  5.962  payment:  6.860\n",
      "Total regret:  0.02237 Average regret per bidder:  0.00447  Optimal Revenue:  5.938  payment:  6.805\n",
      "Total regret:  0.02148 Average regret per bidder:  0.00430  Optimal Revenue:  5.956  payment:  6.804\n",
      "Total regret:  0.02290 Average regret per bidder:  0.00458  Optimal Revenue:  5.937  payment:  6.817\n",
      "Total regret:  0.01745 Average regret per bidder:  0.00349  Optimal Revenue:  6.109  payment:  6.870\n",
      "Total regret:  0.02300 Average regret per bidder:  0.00460  Optimal Revenue:  5.870  payment:  6.747\n",
      "Total regret:  0.02133 Average regret per bidder:  0.00427  Optimal Revenue:  5.976  payment:  6.823\n",
      "Total regret:  0.02278 Average regret per bidder:  0.00456  Optimal Revenue:  5.954  payment:  6.832\n",
      "Total regret:  0.01933 Average regret per bidder:  0.00387  Optimal Revenue:  6.028  payment:  6.831\n",
      "Total regret:  0.02069 Average regret per bidder:  0.00414  Optimal Revenue:  5.976  payment:  6.808\n",
      "Total regret:  0.02220 Average regret per bidder:  0.00444  Optimal Revenue:  5.898  payment:  6.759\n",
      "Total regret:  0.01806 Average regret per bidder:  0.00361  Optimal Revenue:  6.085  payment:  6.860\n",
      "Total regret:  0.02229 Average regret per bidder:  0.00446  Optimal Revenue:  6.003  payment:  6.873\n",
      "Total regret:  0.02026 Average regret per bidder:  0.00405  Optimal Revenue:  5.957  payment:  6.777\n",
      "Total regret:  0.02128 Average regret per bidder:  0.00426  Optimal Revenue:  6.004  payment:  6.851\n"
     ]
    }
   ],
   "source": [
    "for i in range(200):\n",
    "    test(50, nbrInit=300, R=300, gamma=0.001, minimum=0, maximum=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final Result\n",
      "Total Regret =  0.02108 Average regret per bidder:  0.00422  Optimal Revenue:  6.084  payment:  6.822\n"
     ]
    }
   ],
   "source": [
    "totalregret = np.mean(np.array(testRegret[-200:]))\n",
    "revenue     = np.mean(np.array(testPayment[-200:]))\n",
    "print(\"Final Result\")\n",
    "print(\"Total Regret = \", '{0:.5f}'.format(totalregret), \"Average regret per bidder: \",'{0:.5f}'.format(totalregret/nAgent), \" Optimal Revenue: \",'{0:.3f}'.format(float(np.sqrt(revenue)-np.sqrt(totalregret))**2), \" payment: \",'{0:.3f}'.format(revenue))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "std Regret =  0.00186 std regret per bidder:  0.00037  std payment:  0.056\n"
     ]
    }
   ],
   "source": [
    "stdregret = np.std(np.array(testRegret[-200:]))\n",
    "stdrevenue= np.std(np.array(testPayment[-200:]))\n",
    "print(\"std Regret = \", '{0:.5f}'.format(stdregret), \"std regret per bidder: \",'{0:.5f}'.format(stdregret/nAgent), \" std payment: \",'{0:.3f}'.format(stdrevenue))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
