{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams.update(plt.rcParamsDefault)\n",
    "from scipy.stats import norm\n",
    "from scipy.stats import mstats\n",
    "from scipy.special import lambertw\n",
    "from scipy.optimize import fsolve\n",
    "from time import time\n",
    "from math import e\n",
    "import progressbar\n",
    "from scipy.optimize import minimize \n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Error estimates and optimal allocation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# count errors made by the threshold decision rule on a vector of means.\n",
    "def count_errors(means, threshold, classes):\n",
    "    return np.sum((means>threshold) != classes)\n",
    "\n",
    "def optimal_allocation_exp(mu, s2, t):\n",
    "    K = len(mu)\n",
    "    idx = np.argsort(np.abs(mu))\n",
    "    mu_sort = mu[idx]\n",
    "    KLs = 0.5 * mu_sort**2/s2\n",
    "    Hs = np.cumsum(1/KLs[::-1])[::-1] \n",
    "    Hlogs = np.cumsum(np.log(KLs[::-1])/KLs[::-1])[::-1] \n",
    "    log_gammas = -(t-Hlogs)/Hs\n",
    "    gammas = np.exp(log_gammas)\n",
    "    err_values = range(K) + Hs * gammas\n",
    "    for i in range(K):\n",
    "        if KLs[i] < gammas[i]:\n",
    "            err_values[i] = np.inf\n",
    "        if i>0:\n",
    "            if KLs[i-1] > gammas[i]:\n",
    "                err_values[i] = np.inf\n",
    "    kopt = np.argmin(err_values)\n",
    "    N = np.zeros(K)\n",
    "    N[idx[kopt:K]] = (np.log(KLs[kopt:K]) - log_gammas[kopt]) / KLs[kopt:K]\n",
    "    return N"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Sampling rules\n",
    "\n",
    "Tracking methods compute the optimal allocation at some point and pull to approach it. These functions are named sample_tracking_XYZ, where X, Y and Z indicate variants and take values among the following:\n",
    "- X: the sub-gaussian error estimate (\"exp\") is used (instead of the gaussian one)\n",
    "- O: the allocation is computed at an optimistic point (instead of the empirical means)\n",
    "- W: the pulling decision uses a weighted argmin. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# optimistic Frank-Wolfe, sub-gaussian version (based on the \"exp\" error estimate)\n",
    "\n",
    "def sample_FWT(empirical_means, N, s2, mu, T):\n",
    "    #X = np.maximum(1, 0.5 * N * empirical_means**2 / s2)\n",
    "    X = (1 + np.sqrt(0.5 * N * empirical_means**2 / s2))**2\n",
    "    return np.argmin(X - np.log(X) + np.log(N))\n",
    "\n",
    "\n",
    "# oracle optimal allocation tracking\n",
    "def sample_tracking_knowing_mu(empirical_means, N, s2, mu, T):\n",
    "    X = np.abs(mu)\n",
    "    t = sum(N)+1\n",
    "    opt_alloc = optimal_allocation_exp(X, s2, t)\n",
    "    return np.argmin(N - opt_alloc)\n",
    "\n",
    "# --------------------------- Baselines --------------------------------\n",
    "# uniform sampling\n",
    "def sample_uniform(empirical_means, N, s2, mu, T):\n",
    "    return int(np.sum(N)%len(N))\n",
    "\n",
    "# LSA \n",
    "def sample_lsa(empirical_means, N, s2, mu, T):\n",
    "    return np.argmin(N * 0.5 * empirical_means**2/s2 + np.log(N))\n",
    "\n",
    "# APT\n",
    "def sample_apt(empirical_means, N, s2, mu, T):\n",
    "    return np.argmin(N * empirical_means**2)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Threshold computations"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def threshold_zero(means, N, s2):\n",
    "    return 0\n",
    "\n",
    "def threshold_mean_of_means(means, N, s2):\n",
    "    return np.mean(means)\n",
    "\n",
    "def threshold_median_of_means(means, N, s2):\n",
    "    return np.median(means)\n",
    "\n",
    "def threshold_minimizer(means, N, s2):\n",
    "    t = sum(N)\n",
    "    def func(theta):\n",
    "        return np.sum(np.exp(- (N/t)*(theta - means * np.sqrt(t/s2))**2 / 2) * np.tanh(means) * np.sqrt(N))\n",
    "    return fsolve(func, np.median(means)) * np.sqrt(s2/t)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### The function used to run experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def runit_given_mu(sampling_rule, nb_exp, T, mu, sigma, seed=0):\n",
    "    np.random.seed(seed)\n",
    "    s2 = sigma**2\n",
    "    K = len(mu)\n",
    "    empirical_means = np.zeros((nb_exp, T, K))\n",
    "    N = np.zeros((nb_exp, T, K))\n",
    "    for i in range(nb_exp):\n",
    "        n = np.zeros(K)\n",
    "        emp_means = np.zeros(K)\n",
    "        for t in range(T):\n",
    "            if t<K:\n",
    "                k = t\n",
    "            else:\n",
    "                # query sampling rule for next arm to sample\n",
    "                k = sampling_rule(emp_means, n, s2, mu, T)\n",
    "            # update pull counts and empirical means\n",
    "            n[k] += 1\n",
    "            X = np.random.normal(loc=mu[k], scale=sigma)\n",
    "            emp_means[k] += (X-emp_means[k])/n[k]\n",
    "            # store n and emp_means for that experiment and time\n",
    "            N[i,t,:] = n[:]\n",
    "            empirical_means[i,t,:] = emp_means[:]\n",
    "    return empirical_means, N"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Experiments"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Improvement over non adaptive methods\n",
    "\n",
    "The goal of this experiment is to show the improvement of adaptive algorithms over optimal non-adaptive sampling. We consider fixed $\\mu_i \\in \\{-1,1\\}$. The optimal non-adaptive allocation rule is the uniform one. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "nu = np.array([-1, 1]) # means of the two classes. \n",
    "K = 100  # number of points\n",
    "T = 800  # total number of samples to be allocated to the points\n",
    "sigma = 1  # standard deviation of a sample given the mean of the point\n",
    "s2 = sigma**1\n",
    "classes = np.tile(np.array([0,1]), int(K/2))  # K/2 first points are negative"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "nb_exp = 500\n",
    "seed = 10\n",
    "mu = nu[classes] * np.ones(K) # all the mus are either 1 or -1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sampling_rules = [\n",
    "    (sample_uniform, \"Oracle\"),\n",
    "    (sample_FWT, \"FWT\"),\n",
    "    (sample_lsa, \"LSA\"),\n",
    "    (sample_apt, \"APT\"),\n",
    "]\n",
    "nb_sr = len(sampling_rules)\n",
    "\n",
    "empirical_means = np.zeros((nb_sr, nb_exp, T, K))\n",
    "N = np.zeros((nb_sr, nb_exp, T, K))\n",
    "errors = np.zeros((nb_sr, nb_exp, T))\n",
    "opt_errors = np.zeros(nb_exp)\n",
    "opt_errors_median = np.zeros(nb_exp)\n",
    "for j,sr_tuple in enumerate(sampling_rules):\n",
    "    sr = sr_tuple[0]\n",
    "    t_start = time()\n",
    "    empirical_means[j,:,:,:], N[j,:,:,:] = runit_given_mu(sr, nb_exp, T, mu, sigma, seed)\n",
    "    t_end = time()\n",
    "    print(\"sampling rule \", sr_tuple[1], \", \", np.round(t_end-t_start,2), \"s\")\n",
    "    for i in range(nb_exp):\n",
    "        for t in range(T):\n",
    "            errors[j,i,t] = count_errors(empirical_means[j,i,t,:], 0, (mu[:]>0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "mean_error = np.round(np.mean(errors, 1),2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "colors = plt.rcParams[\"axes.prop_cycle\"].by_key()[\"color\"]\n",
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "T_plot = 400\n",
    "for i in range(len(sampling_rules)):\n",
    "    means = np.mean(errors[i,:,:]/errors[0,:,:], axis=0)\n",
    "    quantiles = mstats.mquantiles(errors[i,:,:]/errors[0,:,:], axis=0)\n",
    "    plt.plot(np.arange(T_plot-1),quantiles[1,1:T_plot], label=sampling_rules[i][1], color = colors[i+1], linewidth=2)\n",
    "    plt.fill_between(np.arange(T_plot-1), quantiles[0,1:T_plot] ,quantiles[2,1:T_plot], color= colors[i+1], alpha=.2)\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Ratio of errors')\n",
    "plt.legend()\n",
    "plt.savefig('improvement_over_uniform.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "collapsed": true
   },
   "source": [
    "## About the upper-bounds"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "K = 50  # number of arms\n",
    "T = 4.5e8 # total number of samples to be allocated to the points\n",
    "n = 100 # number of points to be computed for the plots\n",
    "sigma = 1  # standard deviation of a sample given the mean of the point\n",
    "s2 = sigma**2\n",
    "classes = np.repeat(np.array([0,1]), K/2)  # K/2 first points are negative\n",
    "bar = progressbar.ProgressBar(maxval=T, \\\n",
    "    widgets=[progressbar.Bar('=', '[', ']'), ' ', progressbar.Percentage()])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "p = 2\n",
    "mu = np.linspace(1, 1/K, K)**p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "times = np.concatenate((np.arange(int(n/2)) + 1, (np.arange(int(n/2))+1) * T/(n/2-1)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# Upper-bounds of APT\n",
    "apt_bound = 2 * K * np.sqrt(e * times) * np.exp(- times / (4 * np.sum(1/mu**2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "# The asymptotic bound of Corollary 1\n",
    "fwt_asympt_bound = 2 * np.sum(np.minimum(np.outer(np.exp(-(np.sum(1/mu**2)*np.log(mu**2) + np.sum(1/mu**2 * np.log(1/mu**2)))/(2 * np.sum(1/mu**2))),\n",
    "                                       np.sqrt(e * times) * np.exp(-times / (4 * np.sum(1/mu**2)))),1), \n",
    "                   axis = 0)\n",
    "times2 = 2 * np.sum(1/mu**2) * (2  - np.log(times / e)) + 2 * np.sum(1/mu**2 * np.log((mu**2 * np.max(mu**2))/np.min(mu**4)) )\n",
    "fwt_asympt_bound[np.where(times < times2)] = K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# The non-adaptive oracle bound\n",
    "oracle_bound = np.zeros(n)\n",
    "bound = K\n",
    "mu_sort = np.sort(np.abs(mu))\n",
    "mcurrent = K-1\n",
    "\n",
    "bar.start()\n",
    "for i in range(n):\n",
    "    oracle_bound[i] = bound\n",
    "    bar.update(i+1)\n",
    "    t = times[i]\n",
    "\n",
    "    for k in range(mcurrent+1): \n",
    "        m = mcurrent - k \n",
    "        delta2_S = mu_sort[m:K]**2\n",
    "        tau = (t + np.sum(1/delta2_S * np.log(1/delta2_S)))/np.sum(1/delta2_S)\n",
    "        if (tau + np.log(mu_sort[m]**2) >=1) and  ((m == 0) or (tau + np.log(mu_sort[m-1]**2) < 1)):\n",
    "            bound = m + np.sum(1/delta2_S)  * np.exp(-tau)\n",
    "            if (bound < oracle_bound[i]):\n",
    "                oracle_bound[i] = bound\n",
    "                mcurrent = m\n",
    "\n",
    "bar.finish()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# LSA bound\n",
    "lsa_bound = K * np.ones(n)\n",
    "ms = (K-1) * np.ones(n)\n",
    "js = (K-1) * np.ones(n)\n",
    "mu_sort = np.sort(np.abs(mu))\n",
    "jcurrent = K-1\n",
    "mcurrent = K-1\n",
    "\n",
    "Cold = 1\n",
    "Cs = np.ones(n)\n",
    "\n",
    "bar = progressbar.ProgressBar(maxval=T*K, \\\n",
    "    widgets=[progressbar.Bar('=', '[', ']'), ' ', progressbar.Percentage()])\n",
    "bar.start()\n",
    "it = 0\n",
    "for i in range(n):\n",
    "    t = times[i]\n",
    "    if (i > 0):\n",
    "        jcurrent = int(js[i-1])\n",
    "        mcurrent = int(ms[i-1])\n",
    "        Cold = Cs[i-1]\n",
    "        \n",
    "    # S' corresponds to the set j,...,K-1\n",
    "    # S corresponds to the set m,...,K with m <= j\n",
    "    for k in range(min(jcurrent+1, K-1)): \n",
    "        it += 1\n",
    "        bar.update(it+1)\n",
    "        j = jcurrent - k\n",
    "        m0 = min(mcurrent,j)\n",
    "        for l in range(m0+1):\n",
    "            m = m0 - l\n",
    "            delta2_S1 = mu_sort[j:K]**2\n",
    "            delta2_SC = mu_sort[m:K]**2\n",
    "            delta2_SCinv = np.sum(1/delta2_SC) \n",
    "            delta2_S1inv = np.sum(1/delta2_S1) \n",
    "            \n",
    "            tau = (t/2 + np.sum(1/delta2_SC * np.log(1/delta2_SC))) / delta2_SCinv\n",
    "            \n",
    "            def f(C):\n",
    "                t0 = min(m * np.exp(C),t)\n",
    "                return j + e * (K-j) * np.exp(-tau + t0/(2*delta2_SCinv) + C) + t * np.sum(np.exp(-np.real(lambertw(np.exp(C) * delta2_S1))))\n",
    "            \n",
    "\n",
    "            Cmin = 1 + np.log(1/mu_sort[m]**2)\n",
    "            Cminimize = minimize(f, Cold, bounds=((Cmin,None),)).x[0]\n",
    "            \n",
    "            bound = f(Cminimize)\n",
    "        \n",
    "            if (bound < lsa_bound[i]):\n",
    "                lsa_bound[i] = bound\n",
    "                ms[i] = m\n",
    "                js[i] = j\n",
    "                Cs[i] = Cminimize\n",
    "                \n",
    "bar.finish()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "# To specify the number of ticks on both or any single axes\n",
    "plt.plot(times, np.minimum(apt_bound, K), label = \"APT\")\n",
    "plt.plot(times, np.minimum(lsa_bound, K), label = \"LSA\")\n",
    "plt.plot(times,np.minimum(oracle_bound,K), label = \"Oracle\")\n",
    "plt.plot(times, np.minimum(fwt_asympt_bound, K), label = \"FWT (asymp)\")\n",
    "plt.locator_params(axis='x', nbins=6)\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Upper-bound')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# FWT bound\n",
    "fwt_bound = K * np.ones(n)\n",
    "ms = (K-1) * np.ones(n)\n",
    "js = (K-1) * np.ones(n)\n",
    "mu_sort = np.sort(np.abs(mu))\n",
    "jcurrent = K-1\n",
    "mcurrent = K-1\n",
    "\n",
    "Cold = 1\n",
    "Cs = np.ones(n)\n",
    "\n",
    "bar = progressbar.ProgressBar(maxval=T*K, \\\n",
    "    widgets=[progressbar.Bar('=', '[', ']'), ' ', progressbar.Percentage()])\n",
    "bar.start()\n",
    "it = 0\n",
    "for i in range(n):\n",
    "    t = times[i]\n",
    "    if (i > 0):\n",
    "        jcurrent = int(js[i-1])\n",
    "        mcurrent = int(ms[i-1])\n",
    "        Cold = Cs[i-1]\n",
    "        \n",
    "    # S' corresponds to the set j,...,K-1\n",
    "    # S corresponds to the set m,...,K with m <= j\n",
    "    for k in range(min(jcurrent+1, K-1)): \n",
    "        it += 1\n",
    "        bar.update(it+1)\n",
    "        j = jcurrent - k\n",
    "        m0 = min(mcurrent,j)\n",
    "        for l in range(m0+1):\n",
    "            m = m0 - l\n",
    "            delta2_S1 = mu_sort[j:K]**2\n",
    "            delta2_SC = mu_sort[m:K]**2\n",
    "            delta2_SCinv = np.sum(1/delta2_SC) \n",
    "            delta2_S1inv = np.sum(1/delta2_S1) \n",
    "            \n",
    "            tau = (t/2 + np.sum(1/delta2_SC * np.log(1/delta2_SC))) / delta2_SCinv\n",
    "            \n",
    "            def f(C):\n",
    "                t0 = min(m * np.exp(C-1),t)\n",
    "                return j + e * (K-j) * np.exp(-tau + t0/(2*delta2_SCinv) + C) + t * delta2_S1inv * np.exp(-C) \n",
    "\n",
    "            Cmin = 1 + np.log(1/mu_sort[m]**2)\n",
    "            if (m > 0):\n",
    "                Cminimize = minimize(f, Cold).x[0]\n",
    "            else:\n",
    "                Cminimize = tau / 2 + np.log(t * delta2_S1inv / (e * (K-j))) / 2\n",
    "            \n",
    "            bound = f(max(Cminimize, Cmin))\n",
    "        \n",
    "            if (bound < fwt_bound[i]):\n",
    "                fwt_bound[i] = bound\n",
    "                ms[i] = m\n",
    "                js[i] = j\n",
    "                Cs[i] = Cminimize\n",
    "                \n",
    "bar.finish()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "plt.plot(times, K - ms , label = \"Size of S\")\n",
    "plt.plot(times, K - js, label = \"Size of S'\")\n",
    "plt.locator_params(axis='x', nbins=6)\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Number of arms')\n",
    "plt.legend()\n",
    "plt.savefig('evolution_of_S.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "plt.locator_params(axis='x', nbins=6)\n",
    "plt.plot(times,oracle_bound, label = \"Oracle\")\n",
    "plt.plot(times,np.minimum(fwt_bound, K), label = \"FWT\")\n",
    "plt.plot(times,np.minimum(lsa_bound, K), label = \"LSA\")\n",
    "plt.plot(times,np.minimum(apt_bound, K), label = \"APT\")\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Upper-bound')\n",
    "plt.legend()\n",
    "plt.savefig('upper_bounds_comparison.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Experiments with the algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "K = 50  # number of arms (should be even)\n",
    "T = 3000  # total number of samples to be allocated to the points\n",
    "n = 100\n",
    "times = (np.arange(n)+1) * T/n\n",
    "sigma = 1  # standard deviation of a sample given the mean of the point\n",
    "s2 = sigma**2\n",
    "classes = np.tile(np.array([0,1]), int(K/2))  # half of the points are negative"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "p = 1\n",
    "mu = (2 * classes -1) * np.linspace(1, 1/K, K)**p\n",
    "mu = np.sort(mu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "sampling rule  Uniform ,  16.55 s\n",
      "sampling rule  Oracle ,  160.23 s\n",
      "sampling rule  FWT ,  27.15 s\n",
      "sampling rule  LSA ,  22.56 s\n",
      "sampling rule  APT ,  15.02 s\n"
     ]
    }
   ],
   "source": [
    "nb_exp = 500\n",
    "seed = 1989\n",
    "sampling_rules = [\n",
    "    (sample_uniform, \"Uniform\"),\n",
    "    (sample_tracking_knowing_mu, \"Oracle\"),\n",
    "    (sample_FWT, \"FWT\"),\n",
    "    (sample_lsa, \"LSA\"),\n",
    "    (sample_apt, \"APT\"),\n",
    "]\n",
    "nb_sr = len(sampling_rules)\n",
    "\n",
    "empirical_means = np.zeros((nb_sr, nb_exp, T, K))\n",
    "N = np.zeros((nb_sr, nb_exp, T, K))\n",
    "errors = np.zeros((nb_sr, nb_exp, T))\n",
    "opt_errors = np.zeros(nb_exp)\n",
    "opt_errors_median = np.zeros(nb_exp)\n",
    "for j,sr_tuple in enumerate(sampling_rules):\n",
    "    sr = sr_tuple[0]\n",
    "    t_start = time()\n",
    "    empirical_means[j,:,:,:], N[j,:,:,:] = runit_given_mu(sr, nb_exp, T, mu, sigma, seed)\n",
    "    t_end = time()\n",
    "    print(\"sampling rule \", sr_tuple[1], \", \", np.round(t_end-t_start,2), \"s\")\n",
    "    for i in range(nb_exp):\n",
    "        for t in range(T):\n",
    "            errors[j,i,t] = count_errors(empirical_means[j,i,t,:], 0, (mu[:]>0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\nTv8f/jPWTSSDgvcAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "mean_error = np.round(np.mean(errors, 1),2)\n",
    "\n",
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "Tplot = 1000\n",
    "for i in range(len(sampling_rules)):\n",
    "    plt.plot((mean_error[i,:]), label=sampling_rules[i][1])\n",
    "    \n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Number of errors')\n",
    "plt.xlim(0, Tplot)\n",
    "plt.ylim(0, K/2)\n",
    "plt.legend()\n",
    "plt.savefig('performance_comparison.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig=plt.figure(figsize=(4,3), dpi= 100, facecolor='w', edgecolor='k')  # to have big plots\n",
    "T_plot = T\n",
    "for i in range(len(sampling_rules)):\n",
    "    plt.plot(np.divide(mean_error[i,1:T_plot],mean_error[1,1:T_plot]), label=sampling_rules[i][1])\n",
    "plt.xlabel(\"Time\")\n",
    "plt.ylabel('Ratio of mean errors')\n",
    "plt.legend()\n",
    "plt.savefig('improvement_over_oracle.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "fig=plt.figure(figsize=(12,3), dpi= 100, facecolor='w', edgecolor='k')  \n",
    "plt.subplot(1,3,1)\n",
    "plt.title(\"T=500\")\n",
    "plt.plot(mu,np.transpose(np.mean(N[:,:,500-1,:],axis=1))*K/500)\n",
    "plt.xlabel(\"mu\")\n",
    "plt.subplot(1,3,2)\n",
    "plt.title(\"T=3000\")\n",
    "plt.plot(mu,np.transpose(np.mean(N[:,:,3000-1,:],axis=1))*K/3000)\n",
    "plt.xlabel(\"mu\")\n",
    "plt.subplot(1,3,3)\n",
    "plt.title(\"T=10000\")\n",
    "for i in range(len(sampling_rules)):\n",
    "    plt.plot(mu,np.mean(N[i,:,10000-1,:], axis = 0)*K/10000, label=sampling_rules[i][1])\n",
    "plt.xlabel(\"mu\")\n",
    "plt.legend()\n",
    "plt.savefig('sampling_distribution.pdf', bbox_inches = \"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": []
  }
 ],
 "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.6.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
