{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-23T12:37:20.269722Z",
     "start_time": "2023-05-23T12:37:20.267879Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[complexity]:  145755.42894163335\n",
      "[pareto set]:  [0, 3, 4, 5, 8, 9]\n"
     ]
    }
   ],
   "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 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",
    "# this instance was chosen on purpose\n",
    "means = np.array([[0.79561747, 0.08965442, 0.21217508, 0.70586195, 0.85819025,\n",
    "        0.40859756, 0.85187629, 0.26564671, 0.53383054, 0.45786114],\n",
    "       [0.68397918, 0.40962332, 0.51441263, 0.96336578, 0.9490486 ,\n",
    "        0.04884175, 0.48071441, 0.87318481, 0.83631854, 0.66747994],\n",
    "       [0.74498482, 0.93739875, 0.40593968, 0.04332119, 0.20483421,\n",
    "        0.48585313, 0.48112598, 0.92750909, 0.38463631, 0.73104455],\n",
    "       [0.62638832, 0.39101109, 0.53579913, 0.95666807, 0.18012455,\n",
    "        0.68562863, 0.40986873, 0.61513398, 0.40567299, 0.53075932],\n",
    "       [0.95920701, 0.96463939, 0.17122914, 0.36154627, 0.87221403,\n",
    "        0.5284141 , 0.12388823, 0.84222524, 0.55235171, 0.965719  ],\n",
    "       [0.74142809, 0.04686739, 0.29850367, 0.62044755, 0.27879997,\n",
    "        0.44565204, 0.99344779, 0.43686477, 0.54659127, 0.41559037],\n",
    "       [0.33184379, 0.27260587, 0.35171687, 0.04939323, 0.08526793,\n",
    "        0.93581788, 0.64451766, 0.93243308, 0.20377   , 0.71414572],\n",
    "       [0.04325666, 0.07968207, 0.05145856, 0.02163207, 0.16509912,\n",
    "        0.06796036, 0.09336317, 0.10700092, 0.16536946, 0.32714854],\n",
    "       [0.55893345, 0.82885115, 0.63973835, 0.74127859, 0.6955197 ,\n",
    "        0.79306507, 0.47312767, 0.55239446, 0.20746722, 0.67216129],\n",
    "       [0.19430824, 0.33757437, 0.66866928, 0.13386218, 0.59399642,\n",
    "        0.0776997 , 0.33667443, 0.77578558, 0.72887183, 0.19002947],\n",
    "       [0.94917574, 0.49893058, 0.05923611, 0.56557108, 0.30197238,\n",
    "        0.60146629, 0.68608079, 0.56349484, 0.16967495, 0.37826134],\n",
    "       [0.55682717, 0.57309861, 0.98388775, 0.07924336, 0.06012158,\n",
    "        0.21823514, 0.61801114, 0.90617615, 0.24620713, 0.06375816]])\n",
    "K = 12\n",
    "D = 10\n",
    "inf = 1e12\n",
    "bandit = Bernoulli(means)\n",
    "print(\"[complexity]: \", bandit.H)\n",
    "print(\"[pareto set]: \", bandit.optimal_arms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-23T12:37:33.045207Z",
     "start_time": "2023-05-23T12:37:33.042246Z"
    }
   },
   "outputs": [],
   "source": [
    "numiter = 2000\n",
    "seeds = (np.random.uniform(size=numiter)*2**31).astype(np.uint)\n",
    "delta = 0.1\n",
    "eps_1 = 0.\n",
    "eps_2 = 0."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "psi_ape = p_ape(bandit)\n",
    "psi_auer = p_auer(bandit)\n",
    "res_psi_ape = []\n",
    "pull_of_each_arm_ape = np.zeros(K, int)\n",
    "pull_of_each_arm_auer = np.zeros(K, int)\n",
    "for seed in seeds:\n",
    "    __res = psi_ape.loop(seed, delta, eps_1, eps_2, K)\n",
    "    res_psi_ape += [sum(__res[0][1])]\n",
    "    pull_of_each_arm_ape += np.array(__res[0][1])\n",
    "res_psi_auer = []\n",
    "for seed in seeds:\n",
    "     __res = psi_auer.loop(seed, delta, eps_1)\n",
    "     res_psi_auer += [sum(__res[0][1])]\n",
    "     pull_of_each_arm_auer += np.array(__res[0][1])\n",
    "res_psi_ape = np.array(res_psi_ape, dtype=float)\n",
    "res_psi_auer  = np.array(res_psi_auer, dtype=float)\n",
    "print(\"[k=%d] [APE]:\"%K, np.mean(res_psi_ape))\n",
    "print(\"[Auer]:\", np.mean(res_psi_auer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "outputs": [
    {
     "data": {
      "text/plain": "array([1.4102037 , 1.98219653, 1.41020015, 3.80080266, 6.91901638,\n       1.33765361, 2.48554128, 1.33765312, 3.47957836, 9.46502574])"
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pull_of_each_arm_auer/ pull_of_each_arm_ape"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-05-23T12:39:02.969110Z",
     "start_time": "2023-05-23T12:39:02.961055Z"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-23T11:23:23.564373Z",
     "start_time": "2023-05-23T11:23:23.447762Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = np.concatenate((res_psi_ape, res_psi_auer))\n",
    "df = pd.DataFrame({\"sc\": data, \"names\": [\"APE[k=%s]\"%K]*seeds.size + [\"PSI-Unif-Elim\"]*seeds.size  })\n",
    "sns.boxplot(data=df, x=\"names\", y=\"sc\",  orient=\"v\", showmeans=True, showfliers=True, notch=True).set(\n",
    "    xlabel=' ',\n",
    "    ylabel=r'')\n",
    "plt.ticklabel_format(axis=\"y\", style=\"sci\", scilimits=(0,0))"
   ]
  }
 ],
 "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
