{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-16T18:09:56.380921Z",
     "start_time": "2023-05-16T18:09:56.372345Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[complexity]:  549.6836351585227\n",
      "[pareto set]:  [8, 18]\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",
    "means = np.log(np.array([[1.3424e+04, 9.5000e+02, 9.5800e+01],\n",
    "        [1.0862e+04, 7.6600e+02, 5.6600e+01],\n",
    "        [8.5500e+03, 6.0600e+02, 3.5300e+01],\n",
    "        [2.7242e+04, 1.7890e+03, 8.3800e+01],\n",
    "        [2.3082e+04, 1.3390e+03, 7.8400e+01],\n",
    "        [4.2040e+03, 2.8900e+02, 3.3500e+01],\n",
    "        [3.7210e+03, 2.3400e+02, 3.8100e+01],\n",
    "        [1.7079e+04, 1.4410e+03, 1.1100e+02],\n",
    "        [3.3768e+04, 2.0190e+03, 1.1200e+02],\n",
    "        [7.6130e+03, 4.8700e+02, 4.6700e+01],\n",
    "        [2.4570e+03, 1.9300e+02, 5.3000e+01],\n",
    "        [6.9750e+03, 7.2700e+02, 1.1370e+02],\n",
    "        [4.6340e+03, 4.7000e+02, 9.8400e+01],\n",
    "        [2.0517e+04, 1.6210e+03, 1.1550e+02],\n",
    "        [1.6045e+04, 1.3440e+03, 1.3590e+02],\n",
    "        [1.8350e+03, 2.0200e+02, 5.2200e+01],\n",
    "        [1.4300e+03, 1.4700e+02, 5.5500e+01],\n",
    "        [5.5170e+03, 5.6300e+02, 1.0600e+02],\n",
    "        [3.1111e+04, 2.3680e+03, 1.4890e+02],\n",
    "        [3.9960e+03, 3.7300e+02, 4.7800e+01]]))\n",
    "K = 20\n",
    "D = 3\n",
    "inf = 1e12\n",
    "stddev = np.sqrt(np.array([0.70437039, 0.82845749, 1.53743137]))\n",
    "bandit = Gaussian(means, stddev)\n",
    "print(\"[complexity]: \", bandit.H)\n",
    "print(\"[pareto set]: \", bandit.optimal_arms)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-16T18:09:59.916116Z",
     "start_time": "2023-05-16T18:09:59.910656Z"
    }
   },
   "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": 3,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-16T18:24:27.176223Z",
     "start_time": "2023-05-16T18:10:43.069019Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n",
      "2\n",
      "3\n",
      "20\n",
      "[m=1] [APE]: 2403.797\n",
      "[m=2] [APE]: 11870.617\n",
      "[m=3] [APE]: 27579.365\n",
      "[m=20] [APE]: 27579.365\n",
      "[Auer]: 40070.219\n"
     ]
    }
   ],
   "source": [
    "psi_ape = p_ape(bandit)\n",
    "psi_auer = p_auer(bandit)\n",
    "psi_unif = p_unif(bandit)\n",
    "res_psi_ape = []\n",
    "mvals = [*range(1, len(bandit.optimal_arms)+2), 20]#,\n",
    "for k in mvals:\n",
    "    print(k)\n",
    "    res_ = []\n",
    "    for seed in seeds:\n",
    "        __res = psi_ape.loop(seed, delta, eps_1, eps_2, k)\n",
    "        res_  += [sum(__res[0][1])]\n",
    "    res_psi_ape += [res_]\n",
    "res_psi_auer = []\n",
    "for seed in seeds:\n",
    "    res_psi_auer += [sum(psi_auer.loop(seed, delta, eps_1)[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",
    "for k, m in enumerate(mvals):\n",
    "    print(\"[m=%d] [APE]:\"%m, np.mean(res_psi_ape[k], axis=0))\n",
    "print(\"[Auer]:\", np.mean(res_psi_auer))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "ExecuteTime": {
     "end_time": "2023-05-16T21:55:16.223981Z",
     "start_time": "2023-05-16T21:55:16.076750Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAiEAAAG6CAYAAADeXpaaAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy88F64QAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA5OElEQVR4nO3de3RU5b3G8WfPJGESLqIEgwQIHhTwEiRc1Bq0FatWlKCWizaop4quCnJKxFasS12goD2ithg856hHoRq8i7ei1nrUKuWmUoFaLCokBApKuIYkJLPnPX+ExMQkJJO5vDOT72etWczsvefdv8zOsJ+87744xhgjAACAKPPYLgAAAHRMhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFXEVQnbv3q3zzz9fq1atCvq9Tz75pK666qoIVAUAANojbkLIJ598okmTJqmkpCSo91VUVOi+++7TfffdF6HKAABAe8RFCFm6dKluueUWFRQUNJn317/+VePHj9eIESN08cUX67XXXms0f9y4cfr222915ZVXRqtcAADQBnERQkaNGqV33nlHY8aMaTR948aNuvHGG3XDDTdo1apVuvvuuzVv3jx9+OGH9cs89dRTeuCBB9SjR49olw0AAI4gLkJIz549lZSU1GT6s88+q/POO08XXHCBvF6vhg0bpokTJ6qoqKh+mV69ekWzVAAA0EZN9+xxZNu2bVq5cqVGjBhRP811XfXr189iVQAAoC3iOoT06tVLl112mebMmVM/7ZtvvpExxmJVAACgLeJiOKYl48eP1xtvvKGPPvpIgUBAW7Zs0eTJk/XEE0/YLg0AALQirntCTjvtND344IN68MEH9ctf/lKpqam65JJLdPPNN9suDQAAtMIxjF0AAAAL4no4BgAAxC9CCAAAsCJmjwkJBALy+/3yeDxyHMd2OQAAoA2MMQoEAkpKSpLHc+S+jpgNIX6/X+vXr7ddBgAAaIfs7GylpKQccZmYDSF16Sk7O1ter9dyNQAAoC1c19X69etb7QWRYjiE1A3BeL1eQggAAHGmLYdScGAqAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgBADFi+fLkmTJig5cuX2y4lagghAABYVlVVpQceeEA7d+7U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AJEkR4fnc00PAEDHRk9ImDkmSclfXyXjrWx5GX+aHMNHDwDo2NgTRoBT001OTTfbZQAAENMYjgEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCIs2Y2gcAAGgkYU7RTSlZJXm8tstozBh592yRJLlH95di7I6tnoNltksAAHRgCRNCkr/9wnYJR+T55h+2SwAAIKbEdQhxHEf//u//bruMFtXU1KioqEiSlJ+fr+TkZMsVNW/w4MG2SwAAdEBxHUKSkpJ07bXX2i6jRZWVlfUh5Oqrr1ZqaqrligAAiB0cmAoAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACsIIQAAwApCCAAAsIIQAgAArCCEAAAAKwghAADACkIIAACwghACAACsIIQAAAArCCEAAMAKQggAALCCEAIAAKwghAAAACuSgn1DWVmZ7rjjDq1evVper1d5eXm69dZblZTUuKkpU6bok08+aTStoqJCkyZN0pw5c0KrGgAAxL2gQ8iMGTOUkZGhDz/8ULt27dKNN96oRYsWacqUKY2We/zxxxu9fvHFF1VYWKibbroptIoBAEBCCGo4pri4WKtXr9avfvUrpaamqm/fvpo6daqKioqO+L6vv/5ad999t+bPn69jjz02pIIBAEBiCCqEbNq0Sd27d1dGRkb9tAEDBmj79u3av39/i++bPXu2Lr30Uo0YMaL9lQIAgIQS1HDMwYMHlZqa2mha3euKigp169atyXs+/vhjffbZZ5o/f367CnRdt13viwUNa3ddN65/FgAA2iKYfV1QISQtLU2VlZWNptW97ty5c7Pvee6553TRRRepZ8+ewayq3vr169v1vlhw6NCh+ufr1q1Tp06dLFYDAEBsCSqEnHjiidq7d6927dql9PR0SdJXX32lXr16qWvXrk2W9/v9evfdd7Vw4cJ2F5idnS2v19vu99vUMLANGTKkSS8SAACJxnXdNncgBBVC+vfvr+HDh2vevHmaM2eO9uzZo0ceeUTjx49vdvkvvvhChw4d0rBhw4JZTSNerzduQ0jDuuP55wAAIBKCvljZggUL5Pf7dd5552nixIk6++yzNXXqVElSTk6OXnvttfplt27dqqOOOophCAAA0ETQ1wlJ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trQdyvojocP2hKxYsUJlZWWaNWuWAoGA3n777SMuf8wxx+jiiy/W3//+97Cs3xij22+/XRdffLF27typ//7v/242vebk5Gj79u2SpMLCQj344IMqKCgISw22xds22Lp1q0aPHq2JEyfK6/XquOOO07hx47RmzRpJ0pNPPql9+/aprKxM1157rS655JKw1Blt8bZdBg8erJUrV2rUqFEKBALas2ePampqdPTRR4elnmiKt8++te/E0qVLNWLECP34xz9WUlKSxowZo5EjR+q5554LS73hMmjQII0cOVKff/65PvnkEw0ePFhDhw6Vx+NRSkqKLr30Ut14443at29fWNdb16PywgsvaPTo0Ro+fLh+/vOfa8eOHZIa91rk5uaqpKREDz74oK6++uqwrL9hL1hdLa+88orOPfdcDR06VLfddps+/vhj5eXlKScnR9dcc019r1u4xOy9YyLtqaee0sSJE+Xz+fSzn/1MTzzxRKNur4aMMdq8ebNeeeUVjRo1KuR1BwIB3X777friiy/01FNP6ZhjjtEvfvEL/eIXvzji+yZMmKBp06Zp27ZtIdcQC+JtG/Tu3VsjRoxo1MY777yjU045RZK0efNmpaWl6ZFHHtFjjz2mH/7whyHXaUO8bRdJ6tKli6qqqjRixAjV1NTooosu0jnnnBNyPdEWb599a9+JL7/8UgMHDmz0nhNOOKHZoQRbampq9Omnn2rlypWaPn26TjjhBE2ZMkXXXXedzj33XJ122mkaPHiwpk2bFrEa3n//fb3yyiuqrq7Wz3/+cz3yyCOaM2dOo2WWL1+u0aNH66abbtLll18esVo++OADLVu2TFu3btWll16qzz//XI899piSk5N1xRVXaMmSJbrpppvCtr4OGUK2bdumDz/8UHfeeackaeLEiVq4cKFWr16t008/XZL0xhtv6M9//rOk2i/7UUcdpdzcXN1yyy2N2mr4Baxzww036IYbbmhx/bfeeqtWrFiht956S126dGlz3RkZGW1eNtbF6zaoU1NTozvuuENbt27V/PnzJUknnXSSHn74YUmq/zfexPN2SUlJ0aeffqpt27Zp+vTpuvvuuzV79uyg2rApnj97qfnvxMGDB5WamtpoOZ/Pp4qKiqDbD6fZs2dr3rx59a979eqln//855o8ebIcx9FLL72kJUuWaPHixSopKVFaWpry8vL061//Wp07dw57Pddff726desmqfZYkrVr17a7re3btze7/e+66y6NHTu21fdfe+21Sk1N1cCBA9WzZ09ddtll9fueoUOHhv2P4A4ZQpYsWSK/369x48bVT/P7/XriiSfqv+yXXHKJ7rvvvlbb+vjjj4Ne/44dO3Tw4EH95S9/0ZgxYyRJjz76qB599NFml3/ttdfUu3fvoNcTy+J5G3zzzTcqKChQeXm5nnnmmYQKh/G8Xeq6zo8//nhNnTpVd9xxR1yFkHj+7Fv6TqSmpqqqqqrR+6qqqiKyIw/GXXfddcTehMGDB9f3ROzevVt//etfdf/996uiokL3339/o2W3b9/eqLdq7NixmjNnjlJSUupvad+Q67pKSUlpNC09Pb3+eVJSkkwbbul255136vXXX69//cc//lFSbe/U//3f/7X6/pZ07969/rnX660PR1Ltd6wttQWjw4WQQ4cO6cUXX9TcuXN11lln1U//5z//qRtuuEFfffVVxGv43//9Xz3//POaPXu2RowYoWOPPbbVv1ISSTxvg3Xr1mnq1Kk688wzdffddzf5Ky+exet2efPNN/WHP/xBzzzzTP206upqHXXUURGvN1zi9bOXjvydGDhwYJPjVb788kudeuqpEfkZwuFHP/qRrr/+euXn50uqPe7mkksu0Z49e5o9lqV3797N9lwcd9xxzfYaFBcXKzMzM+Q658yZ02TIJhyifdf6Dndg6uuvvy7HcTR27Fj16tWr/nHOOedo4MCBTU6Li4SUlBTl5+dr4MCBuv322yO+vlgTr9tg69atuvbaazVhwgTNnz8/oQKIFL/bZejQofrnP/+pJ598Uq7ratOmTVq4cKGuvPLKCFcbPvH62bf2ncjLy9Pq1au1bNky+f1+LVu2TKtXr27U2xNr8vLy9F//9V967733dODAAfn9fm3cuFEvvviiLrjggja3M27cOD3zzDNavny5AoGAqqur9Ze//EUvvPBCRI/piDcdridkyZIlGjt2rJKTk5vMmzRpkn7729/qjDPOUI8ePdrUXkvnWL/11ltHfJ/jOJo3b57y8vL07LPP6oorrmjT+hJBvG6DxYsX68CBA1q0aFGjnULv3r3ru0LjWbxul+OOO06PPfaY/vM//1OFhYVKT09Xfn5+2M4giIZ4/exb+04MGDBACxcu1Pz583X77bcrMzNTDz/8sI4//vg2/Rw2FBQU6Nhjj9XDDz+szZs3yxijPn36aPz48brmmmva3M6ll16qmpoazZ8/XyUlJQoEAjr++OP1m9/8psWDjcNh+/btzW5/r9fbrmG6SHNMuAd4UK+0tFTnnXee3n33XfXp0yfi66u7GFNbxow7imhvg+asWrVKV199tb744gsr649FfDfsiYXvREPROOMDsavDDccAAIDYQAiJgksuuURz586NWPt1l6ZueKQ0Gov0NmjJtGnTdP3110d9vfGC74Y9tr4Tdeou2153MUZ0TAzHAAAAK+gJAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWEEIAAIAVhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgBSEEAABYQQgBAABWEEIAAIAVhBAAAGAFIQQAAFhBCAEAAFYQQgAAgBWEEAAAYAUhBAAAWEEIAQAAVhBCAACAFYQQAABgxf8D6tAhkP4Fh2oAAAAASUVORK5CYII=\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "data = np.log(np.concatenate((*res_psi_ape, res_psi_auer))) #, res_psi_auer, res_psi_lucb\n",
    "labels = [str(m) + \"*\"*(m==len(bandit.optimal_arms)) for m in mvals ]\n",
    "df = pd.DataFrame({\"sc\": data, \"names\": reduce(add, [[\"APE[k=%s]\"%m]*seeds.size for m in labels]) + [\"PSI-Unif-Elim\"]*seeds.size  }) #[\"Auer\"]*seeds.size + [\"LUCB\"]*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))\n",
    "np.save(\"log-main-all-arms-d3.npy\", data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "outputs": [
    {
     "data": {
      "text/plain": "<Figure size 640x480 with 1 Axes>",
      "image/png": "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Bfr06QMvLy/069cPK1asQFJSkrniIyIikqTk07mYkphR4UWS14uUmJKYgeTTuVaKzDaJKmiKiorg4aFfUXp4ePAJvkREROWoNQJik85U+moC7bbYpDMcfjIhUQWNt7c3tm7dqrdt69attV75REREZEvScgor9MyUJwDILVIiLafQckHZOFFzaGbMmIHXXnsNu3fvRuvWrfH333/j/PnzWLdunbniIyIikpz8O8aNXBjbjqonqocmKCgIO3fuRK9evdCwYUOEhoZiz549CAwMNFd8REREkuPWWGHSdlQ9cQ+RAdCmTRv06NEDN27cgIeHR7VvyiYiIqpvurZ1hYeLAteLlJXOo5HhwYsku7Z1tXRoNktUQXPhwgVMnjwZubm5aNKkCW7duoXHH38ca9euhbu7u7liJCIikhS5nQwx4T6YkpgBGaBX1Mj+/39jwn0gt5NVcjTVhKghp3fffRdPPfUU0tPT8fPPPyMtLQ1PPvmk6NcQEBER2bowXw+sGhcIdxf9YSV3FwVWjQvkc2hMTFQPzW+//YZ169bB0dERANCwYUNER0ejd+/eZgmOiIhIysJ8PRDq4460nELk31HCrfGDYSb2zJieqILGzc0NOTk58Pb21m3TzqUhIiKiiuR2MvTwambtMGyeqIJm6NChmDhxIsaPH482bdogLy8P69ev161+0hoxYoSJwyQiIiIyTFRBs337dsjlcmzcuFFv+y+//IJffvkFACCTyVjQEBERkUWJKmgOHTpkrjiIiIiIakzUKieNRoMDBw4AAPLy8jBjxgwsWLAAxcXFZgmOiIiIyBiiCpolS5Zg0aJFAICYmBjcvHkTFy9exIIFC8wSHBEREZExRA05HT58GFu2bEFJSQl+/vln7N27F82aNUP//v3NFR8RERFRtUT10Ny6dQuenp44ceIE3Nzc0KZNGzg5OUGtVpsrPiIiIqJqieqhad26NXbu3Ink5GT06tULGo0G69evR7t27cwVHxEREVG1RBU0UVFRmDNnDhQKBRYsWIBjx45h3bp1WL16tbniIyIiIqqWqIImODhYb+l2kyZNcOTIEd2rEIiIiIisQdQcGuDBG7cXLVqEadOmoaSkBNu2bTNHXERERERGE1XQHD16FKNHj8atW7fwyy+/QKlUYuXKlVizZo254iMiIiKqlqiCZtmyZfjkk0/w8ccfQy6Xw8PD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\n"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "mask = np.ones(K, bool)\n",
    "mask[bandit.optimal_arms] = False\n",
    "names = [\"BNT/BNT/m1273\", \"ChAd/ChAd/m1273\"]\n",
    "plt.scatter(*means[mask][:, [0, 2]].T, marker=\"o\")\n",
    "markers = [\"P\", \"X\"]\n",
    "for k,v in enumerate(bandit.optimal_arms):\n",
    "    plt.scatter(*means[v][[0, 2]], label=\"%s\"%names[k], marker=markers[k])\n",
    "plt.legend(frameon=True)\n",
    "plt.xlabel(\"anti-spike IgG\")\n",
    "plt.ylabel(\"cellular response\")"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2023-05-16T14:49:05.987375Z",
     "start_time": "2023-05-16T14:49:05.815202Z"
    }
   }
  }
 ],
 "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
}
