{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2023-05-23T19:30:48.964175Z",
     "start_time": "2023-05-23T19:30:48.963635Z"
    }
   },
   "outputs": [],
   "source": [
    "# coding=utf-8\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "from time import time\n",
    "from operator import add\n",
    "from functools import reduce\n",
    "import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from numpy.random import uniform\n",
    "from lib.bandits import Bernoulli, Gaussian\n",
    "from lib.policies import p_auer, p_ape, p_unif\n",
    "K = 10\n",
    "D = 2\n",
    "numiter = 2000\n",
    "seeds = (np.random.uniform(size=numiter)*2**31).astype(np.uint)\n",
    "m = K\n",
    "delta = 0.1\n",
    "eps_1 = 0.05\n",
    "eps_2 = 0."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 36094.63it/s]\n"
     ]
    }
   ],
   "source": [
    "res_ape_k = [[] for _ in range(5)]\n",
    "res_auer_k = [[] for _ in range(5)]\n",
    "for i in tqdm.trange(numiter):\n",
    "    means = np.random.uniform(size=(K, D))\n",
    "    bandit = Bernoulli(means)\n",
    "    #if bandit.H>5000: continue\n",
    "    psi_ape = p_ape(bandit)\n",
    "    psi_auer = p_auer(bandit)\n",
    "    for j in range(5):\n",
    "       res_ape_k[j]+=[sum(psi_ape.loop(i, delta, eps_1, eps_2, j+1)[0][1])]\n",
    "       res_auer_k[j]+=[sum(psi_auer.loop(i, delta, eps_1, j+1)[0][1])]\n",
    "res_auer_k = np.array(res_auer_k)\n",
    "res_ape_k = np.array(res_ape_k)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-05-23T19:30:49.940113Z",
     "start_time": "2023-05-23T19:30:49.871882Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "outputs": [
    {
     "data": {
      "text/plain": "array([2.59440158, 1.96255797, 1.67134466, 1.52871765, 1.44075579])"
     },
     "execution_count": 78,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "res_auer_k.mean(-1) / res_ape_k.mean(-1)"
   ],
   "metadata": {
    "collapsed": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "outputs": [],
   "source": [
    "d = {'x': reduce(add, [[f\"k=%d\"%k]*numiter for k in range(1, 6) ]*2),\n",
    "     'y': np.concatenate((*res_ape_k[:5], *res_auer_k[:5])),\n",
    "     'Algorithm': [r\"$\\varepsilon_1$-APE-$k$\"]*K*numiter + [r\"Heuristic-PSI-Unif-Elim\"]*K*numiter }\n",
    "df = pd.DataFrame(data=d)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-05-23T19:14:35.555105Z",
     "start_time": "2023-05-23T19:14:35.549012Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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AABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgegQaAABgev6+LgAAgM6upKREq1atkiTNnDlTUVFRPq7IfNhCAwCAj61evVoFBQUqKChQdna2r8sxJQINAAA+dvToUff0kSNHfFiJeRFoAACA6RFoAACA6RFoAACA6RFoAACA6RFoAACA6RFoAACA6RFoAACA6bXpSsFFRUVavny5Dhw4oICAAA0bNkwPP/ywwsPD9cknn+jXv/61iouLFRYWprS0NE2YMMG97qZNm5Sdna2TJ0/q+uuv12OPPab4+HhJktPp1G9/+1u99dZbqq2t1ZAhQ/TEE0/ommuukSSVl5frscce0549e2S1WjVmzBjNnTtX/v5c6BgA4DuVtfVy1NV73I/TZTSb/vJ0tcd9+lksCnW6PO7HLFqdCOrq6jRt2jT99Kc/1dq1a+VwODR37lw9+uijWr58ue677z7Nnj1bEydO1N69ezVjxgz169dPAwYMUH5+vhYvXqycnBwNGDBAeXl5SktL07Zt22Sz2bRmzRrt3LlTb7zxhkJCQvTYY49p/vz5euGFFyRJDzzwgCIjI7Vjxw6VlZUpLS1Nubm5mjZt2hX7YAAAuBRHXb3eK/xc1bWehRrH2YZm0xs/POhpaYq0B2tUbJDH/ZhFqwNNaWmpbrjhBs2YMUNWq1VdunTRxIkTNWfOHG3dulV2u12TJk2SJA0dOlSjR49WXl6eBgwYoA0bNmjUqFFKSEiQJE2dOlXr16/Xli1bNH78eG3YsEEZGRnq1auXJGnevHkaPny4SkpK5HK5tGfPHm3fvl02m01RUVFKT0/XihUrCDQAAJ+rrq1XpYeBxjCMZtOe9idJ3QIDJBFoWrj++uu1bt26ZvPef/993XTTTTp06JBiY2ObtUVHR2vjxo2SpOLiYo0fP75Fe1FRkaqqqvTVV181Wz8iIkKhoaE6ePBcQrXb7YqMjHS39+3bV6WlpaqsrFT37t1b+xbkdDpbvSwA4DIZhlySXF/7km43DMOr3wWGy5BhGM0CyeV11Hza4/4kGca5btvtWEiXHI+2jNVlHYRiGIZW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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = sns.barplot(\n",
    "    data=df,\n",
    "    x=\"x\", y=\"y\", hue=\"Algorithm\", palette=\"tab10\", alpha=0.6,\n",
    ")\n",
    "\n",
    "g.set(\n",
    "    xlabel='',\n",
    "    ylabel=''\n",
    ")\n",
    "#g.legend_.remove()\n",
    "g.legend_.set_title(\"\")"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-05-23T19:23:14.869918Z",
     "start_time": "2023-05-23T19:23:14.554601Z"
    }
   }
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
