{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "38be6d14",
   "metadata": {},
   "source": [
    "## This notebook is used to generate pgf plots from .npy files, generated using the notebook Generating_experiment_results.ipnyb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c420d9c8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "matplotlib.use(\"pgf\")\n",
    "matplotlib.rcParams.update({\n",
    "    \"pgf.texsystem\": \"pdflatex\",\n",
    "    'font.family': 'serif',\n",
    "    'text.usetex': True,\n",
    "    'pgf.rcfonts': False,\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "c8c6f2bb",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_iter = 10**7\n",
    "n_mc = 20\n",
    "list_mu1 = [0.8,0.1,0.1,0.1,0.1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "fe266f11",
   "metadata": {},
   "outputs": [],
   "source": [
    "def kl(x, y, eps = 1e-15):\n",
    "    x = min(max(x, eps), 1 - eps)\n",
    "    y = min(max(y, eps), 1 - eps)\n",
    "    return x * np.log(x / y) + (1 - x) * np.log((1 - x) / (1 - y))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d3f91e24",
   "metadata": {},
   "source": [
    "# Two regimes of privacy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "57e5b760",
   "metadata": {},
   "outputs": [],
   "source": [
    "def private_lower_bound_list_mu_1_n10_7(epsilon):\n",
    "    return 4 * 0.7 * np.log(10**7) / (min(kl(0.1, 0.8), 5*epsilon*0.7))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "67291f89",
   "metadata": {},
   "outputs": [],
   "source": [
    "def lower_bound_list_mu_1_n10_7(epsilon):\n",
    "    return 4 * 0.7 * np.log(10**7) / kl(0.1, 0.8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "6d2215c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "epsilons = np.linspace(0.05, 1, 50)\n",
    "private_lower_bounds = np.array([private_lower_bound_list_mu_1_n10_7(epsilon) for epsilon in  epsilons ])\n",
    "non_private_lower_bounds = np.array([lower_bound_list_mu_1_n10_7(epsilon) for epsilon in  epsilons ])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "83ae1813",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('adap_kl_upper_bound.npy', 'rb') as f:\n",
    "    UCB_upper_bounds = np.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "9f13d23b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.3273501436944752"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "e = kl(0.1, 0.8) / (5*0.7); e"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d68e0c3c",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig = plt.figure()\n",
    "fig.set_size_inches(w=4.6, h=3.5)\n",
    "ax = fig.add_subplot(1, 1, 1)\n",
    "ax.plot(epsilons, non_private_lower_bounds, color='k', ls='solid', label = \"no privacy\")\n",
    "ax.plot(epsilons, private_lower_bounds, color='0.2', ls='dashed', label = \"global DP\")\n",
    "ax.plot(epsilons, UCB_upper_bounds[:,0], color='0.4', ls='dotted', label = \"Adap-KLUCB\")\n",
    "ax.fill_between(epsilons, UCB_upper_bounds[:,0] - UCB_upper_bounds[:,1], UCB_upper_bounds[:,0] + UCB_upper_bounds[:,1], facecolor='0.4', alpha=0.5)\n",
    "plt.axvline(x=e, color='k', linestyle='--')\n",
    "plt.xlabel(r\"Privacy budget $\\epsilon$\")\n",
    "plt.text(0.07, 250, 'High Privacy Regime')\n",
    "plt.text(0.35, 250, 'Low Privacy Regime')\n",
    "plt.ylabel(r\"Regret for $T=10^7$\")\n",
    "ax.legend(loc='upper right', borderpad=0, bbox_to_anchor=(1.01, 1.0))\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.savefig('lower_bound_regimes.pgf', bbox_inches='tight')\n",
    "#plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e8427c9a",
   "metadata": {},
   "source": [
    "# Comparaison of algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b3d65188",
   "metadata": {},
   "outputs": [],
   "source": [
    "list_mu1 = [0.75,0.70,0.70,0.70,0.70]\n",
    "list_mu2 = [0.75,0.625,0.5,0.375,0.25]\n",
    "list_mu3 = [0.75,0.53125,0.375,0.28125,0.25]\n",
    "list_mu4 = [0.75,0.71875,0.625,0.46875,0.25]\n",
    "eps1, eps2, eps3, eps4 = 0.1, 0.25, 0.5, 1\n",
    "list_mu = [list_mu1, list_mu2, list_mu3, list_mu4]\n",
    "epss = [eps1, eps2 ,eps3, eps4]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "852328b1",
   "metadata": {},
   "source": [
    "### Generating 16 figures for every (list_mu,eps) combination"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0895f336",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(4):\n",
    "    for j in range(4):\n",
    "        name_file_ucb = \"dp_ucb_\" + str(i+1) + \"_eps\" + str(j+1) + \".npy\"\n",
    "        with open(name_file_ucb, 'rb') as f:\n",
    "            gen_res_private_ucb = np.load(f)\n",
    "        name_file_se = \"dp_se_\" + str(i+1) + \"_eps\" + str(j+1) + \".npy\"\n",
    "        with open(name_file_se, 'rb') as f:\n",
    "            gen_res_private_se = np.load(f)\n",
    "        name_file_ucb_sliding = \"dp_ucb_\" + str(i+1) + \"_sliding_eps\" + str(j+1) + \".npy\"\n",
    "        with open(name_file_ucb_sliding, 'rb') as f:\n",
    "            gen_res_private_ucb_sliding = np.load(f)\n",
    "        name_file_kl_ucb_sliding = \"dp_kl_ucb_\" + str(i+1) + \"_sliding_eps\" + str(j+1) + \".npy\"\n",
    "        with open(name_file_kl_ucb_sliding, 'rb') as f:\n",
    "            gen_res_private_kl_ucb_sliding = np.load(f)\n",
    "        fig = plt.figure()\n",
    "        fig.set_size_inches(w=4.6, h=3.5)\n",
    "        ax = fig.add_subplot(1, 1, 1)\n",
    "        ax.plot(np.arange(len(gen_res_private_ucb.mean(axis=0))), gen_res_private_ucb.mean(axis=0), color='k', ls='solid', label = r\"DP-UCB($\\gamma = 0.1$)\")\n",
    "        # uncomment the 4 lines to add std error bars, they are not noticable in the figure scale and make .pgf voluminous\n",
    "        #ax.fill_between(np.arange(len(gen_res_private_ucb.mean(axis=0))), gen_res_private_ucb.mean(axis=0) - gen_res_private_ucb.std(axis=0), gen_res_private_ucb.mean(axis=0) + gen_res_private_ucb.std(axis=0), facecolor='0.4', alpha=0.5)\n",
    "        ax.plot(np.arange(len(gen_res_private_se.mean(axis=0))), gen_res_private_se.mean(axis=0), color='0.2', ls='dashed', label = r\"DP-SE\")\n",
    "        #ax.fill_between(np.arange(len(gen_res_private_se.mean(axis=0))), gen_res_private_se.mean(axis=0) - gen_res_private_se.std(axis=0), gen_res_private_se.mean(axis=0) + gen_res_private_se.std(axis=0), facecolor='0.4', alpha=0.5)\n",
    "        ax.plot(np.arange(len(gen_res_private_ucb_sliding.mean(axis=0))), gen_res_private_ucb_sliding.mean(axis=0), color='0.3', ls='dotted', label = r\"AdaP-UCB($\\alpha = 3.1$)\")\n",
    "        #ax.fill_between(np.arange(len(gen_res_private_ucb_sliding.mean(axis=0))), gen_res_private_ucb_sliding.mean(axis=0) - gen_res_private_ucb_sliding.std(axis=0), gen_res_private_ucb_sliding.mean(axis=0) + gen_res_private_ucb_sliding.std(axis=0), facecolor='0.4', alpha=0.5)\n",
    "        ax.plot(np.arange(len(gen_res_private_kl_ucb_sliding.mean(axis=0))), gen_res_private_kl_ucb_sliding.mean(axis=0), color='0.4', ls='dashdot', label = r\"AdaP-KLUCB($\\alpha = 3.1$)\")\n",
    "        #ax.fill_between(np.arange(len(gen_res_private_kl_ucb_sliding.mean(axis=0))), gen_res_private_kl_ucb_sliding.mean(axis=0) - gen_res_private_kl_ucb_sliding.std(axis=0), gen_res_private_kl_ucb_sliding.mean(axis=0) + gen_res_private_kl_ucb_sliding.std(axis=0), facecolor='0.4', alpha=0.5)\n",
    "        plt.xlabel(r\"Step $t\")\n",
    "        plt.ylabel(r\"Regret\")\n",
    "        ax.legend(loc='lower right')\n",
    "        plt.yscale('log')\n",
    "        name_fig = \"comparison_algorithms_list_mu\" + str(i+1)+ \"_eps\" + str(j+1) + \".pgf\"\n",
    "        plt.savefig(name_fig, bbox_inches='tight')"
   ]
  }
 ],
 "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
