{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a90fa5f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import math"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43e57082",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 500\n",
    "\n",
    "n = 150\n",
    "\n",
    "\n",
    "p = 0.99\n",
    "plt.rcParams.update({'font.size': 13})\n",
    "labels = [r'$\\frac{\\hat{b}}{\\hat{n}} \\approx \\frac{b}{n}$', r'$\\frac{\\hat{b}}{\\hat{n}}  = \\frac{\\frac{b}{n} + 0.5}{2}$', r'$\\frac{\\hat{b}}{\\hat{n}} \\approx \\frac{1}{2}$']\n",
    "linestyles = ['-', ':','-.','-']\n",
    "colors = [(0, 0.4470, 0.7410), (0.8500, 0.3250, 0.0980), (0.4660, 0.6740, 0.1880), (0.4660, 0.6740, 0.1880)]\n",
    "\n",
    "nb_points = 100\n",
    "steps = 0.4999/nb_points\n",
    "tab_th = []\n",
    "tab_opt = []\n",
    "\n",
    "tab_bis = []\n",
    "\n",
    "tab_x = []\n",
    "for i in range(nb_points):\n",
    "    beta = steps*(i+1)\n",
    "\n",
    "    tab_x.append(beta)\n",
    "    C_beta = (1/2)*np.log(1/2/beta) + (1- 1/2)*np.log((1-1/2)/(1-beta))\n",
    "    n_ = np.min([n, math.ceil(2+ np.log(4*T/(1-p))/C_beta)+2])\n",
    "    \n",
    "    n_opt = np.min([n, math.ceil(np.max([1/((1/2 - beta)**2), 3/(beta)]) * np.log(4*T/(1-p))) +2])\n",
    "\n",
    "    tab_th.append(n_)\n",
    "    tab_opt.append(n_opt)\n",
    "\n",
    "plt.ylabel('Sample size')\n",
    "plt.xlabel(r'Fraction of Byzantine clients $\\frac{b}{n}$')\n",
    "\n",
    "plt.plot(tab_x, tab_th, label = r'$\\hat{n}_{\\mathrm{th}}$', linestyle = linestyles[1], linewidth=2, color = colors[0])\n",
    "plt.plot(tab_x, tab_opt, label = r'$\\hat{n}_{\\mathrm{opt}}$', linestyle = linestyles[2], linewidth=2, color = colors[1])\n",
    "plt.grid()\n",
    "plt.xlim(0,0.5)\n",
    "plt.ylim(0,n+10)\n",
    "# plt.yscale('log')\n",
    "plt.legend()\n",
    "plt.savefig('./fig2.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f7d715be",
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 500\n",
    "\n",
    "n = 1000\n",
    "plt.rcParams.update({'font.size': 12})\n",
    "\n",
    "\n",
    "p_1 = 0.1\n",
    "p_2 = 0.5\n",
    "p_3 = 0.99\n",
    "p = p_3\n",
    "plt.rcParams.update({'font.size': 13})\n",
    "labels = [r'$\\frac{\\hat{b}}{\\hat{n}} \\approx \\frac{b}{n}$', r'$\\frac{\\hat{b}}{\\hat{n}}  = \\frac{\\frac{b}{n} + 0.5}{2}$', r'$\\frac{\\hat{b}}{\\hat{n}} \\approx \\frac{1}{2}$']\n",
    "linestyles = ['-', ':','-.','-']\n",
    "colors = [(0, 0.4470, 0.7410), (0.8500, 0.3250, 0.0980), (0.4660, 0.6740, 0.1880), (0.4660, 0.6740, 0.1880)]\n",
    "\n",
    "nb_points = 1000\n",
    "steps = 0.4999/nb_points\n",
    "tab_th = []\n",
    "tab_opt = []\n",
    "\n",
    "tab_bis = []\n",
    "\n",
    "tab_x = []\n",
    "for i in range(nb_points):\n",
    "    beta = steps*(i+1)\n",
    "\n",
    "    tab_x.append(beta)\n",
    "    C_beta = (1/2)*np.log(1/2/beta) + (1- 1/2)*np.log((1-1/2)/(1-beta))\n",
    "    n_ = np.min([n, math.ceil(2+ np.log(4*T/(1-p))/C_beta)+2])\n",
    "    \n",
    "    n_opt = np.min([n, math.ceil(np.max([1/((1/2 - beta)**2), 3/(beta)]) * np.log(4*T/(1-p))) +2])\n",
    "\n",
    "    tab_th.append(n_)\n",
    "    tab_opt.append(n_opt)\n",
    "\n",
    "plt.ylabel('Sample size')\n",
    "plt.xlabel(r'Fraction of Byzantine clients $\\frac{b}{n}$')\n",
    "\n",
    "plt.plot(tab_x, tab_th, label = r'$\\hat{n}_{\\mathrm{th}}$', linestyle = linestyles[1], linewidth=2, color = colors[0])\n",
    "plt.plot(tab_x, tab_opt, label = r'$\\hat{n}_{\\mathrm{opt}}$', linestyle = linestyles[2], linewidth=2, color = colors[1])\n",
    "plt.grid()\n",
    "plt.xlim(0,0.5)\n",
    "plt.ylim(0,n+50)\n",
    "# plt.yscale('log')\n",
    "plt.legend()\n",
    "plt.savefig('./fig2.pdf')"
   ]
  }
 ],
 "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": 5
}
