{
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "# Old Successive Rejects"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from math import ceil"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "Visualizaion of the phases"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "outputs": [],
   "source": [
    "# log bar definition\n",
    "def log_bar(K):\n",
    "    res = .5\n",
    "    for i in range(2, K+1):\n",
    "        res += 1/i\n",
    "    return res"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "outputs": [],
   "source": [
    "# Definition of parameters\n",
    "K = 10\n",
    "T = 200\n",
    "log = log_bar(K)\n",
    "\n",
    "# build the number of pulls per phase\n",
    "phases = [0] * (K-1)\n",
    "for i in range(1, K):\n",
    "    phases[i-1] = ceil((1/log) * (T-K)/(K + 1 - i))"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pulls per agent in each phase: [8, 9, 10, 12, 14, 16, 20, 27, 40]\n",
      "Total budget consumed: 196\n"
     ]
    }
   ],
   "source": [
    "print(\"Pulls per agent in each phase: \" + str(phases))\n",
    "\n",
    "res = sum(phases) + phases[len(phases)-1]\n",
    "print(\"Total budget consumed: \" + str(res))"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 432x288 with 0 Axes>"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": "<Figure size 720x720 with 1 Axes>",
      "image/png": "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AgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACAButGVlWdX1W3VtX719hfVfWKqrq+qt5bVQ89aP+9quqmqnrlZi0aAGC728gzWRckOeMQ+89MctL055wkrz5o/y8kuequLA4A4Ei1bmSNMa5K8ulDHHJWkovGzDuSHFdV90uSqnpYkt1J3rQZiwUAOFLUGGP9g6r2JLl8jHHKKvsuT/JLY4y3T7ffkuRnkvxpkiuT/HCSf5lk7xjj3DUe/5zMngXL7t27H7Zv3767NMydsX///uzatav9PNvRIs+eLPb8Zl/M2ZPFnn+RZ08We/6tmP3000+/Zoyxd7V9Rzee9zlJrhhj3FRVhzxwjHFekvOSZO/evWNpaalxWTPLy8vZivNsR4s8e7LY85t9ad7LmJtFnn+RZ08We/55z74ZkXVzkhNX3D5h2vbIJI+qquck2ZXk2KraP8Z4/iacEwBgW9uMyLosyblVtS/Jw5N8doxxS5KnHjigqp6Z2cuFAgsAWAjrRlZVXZxkKcnxVXVTkhclOSZJxhi/luSKJI9Pcn2S25P8SNdiAQCOFOtG1hjj7HX2jyTPXeeYCzL7VRAAAAvBb3wHAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogsAIAGIgsAoIHIAgBoILIAABqILACABiILAKCByAIAaCCyAAAaiCwAgAYiCwCggcgCAGggsgAAGogs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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot phases pull\n",
    "x = np.arange(0, max(phases))\n",
    "y = [1] * max(phases)\n",
    "\n",
    "# clear the plot\n",
    "plt.clf()\n",
    "plt.figure(figsize=(10, 10))\n",
    "\n",
    "# plot a line\n",
    "plt.plot(x, y, \"-\", color=\"blue\")\n",
    "\n",
    "# plot the phases\n",
    "for elem in phases:\n",
    "    plt.plot(elem, 1, \"o\", color=\"orange\")\n",
    "\n",
    "# set visualization stuff\n",
    "plt.title(\"Pulls Visualization\")\n",
    "plt.grid()"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false
   }
  }
 ],
 "metadata": {},
 "nbformat": 4,
 "nbformat_minor": 5
}
