{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np \n",
    "from scipy import optimize\n",
    "\n",
    "import matplotlib.pyplot as plt \n",
    "from tueplots import figsizes, fontsizes, fonts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "figsize_factory = figsizes.icml2024_full\n",
    "plt.rcParams.update(fontsizes.icml2024())\n",
    "plt.rcParams.update(fonts.icml2024_tex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def linear_bound(b, sigma, delta, sensitivity):\n",
    "    a = 1 / (2 * b) * np.log(1 / delta)\n",
    "    t = sigma**2\n",
    "    return sensitivity / t * (sensitivity / 2 + b) + sensitivity * a\n",
    "\n",
    "def find_optim_b_linear_bound(sigma, delta, sensitivity):\n",
    "    res = optimize.minimize_scalar(lambda b: linear_bound(b, sigma, delta, sensitivity), (1e-7, 1000))\n",
    "    if res.success:\n",
    "        return res.x\n",
    "    else:\n",
    "        raise Exception(\"Optimisation failed: {}\".format(res))\n",
    "\n",
    "def mixture_bound(rho, sigma, delta, sensitivity):\n",
    "    if rho < 0: return np.inf\n",
    "    t = sigma**2\n",
    "    term1 = sensitivity**2 / (2 * t)\n",
    "    term2 = sensitivity / t \n",
    "    term3 = 2 * (t + rho)\n",
    "    term4 = np.log(1 / delta * np.sqrt((t + rho) / rho))\n",
    "    return term1 + term2 * np.sqrt(term3 * term4)\n",
    "\n",
    "def find_optim_rho_mixture_bound(sigma, delta, sensitivity):\n",
    "    res = optimize.minimize_scalar(lambda b: mixture_bound(b, sigma, delta, sensitivity), (1e-8, 100))\n",
    "    if res.success:\n",
    "        return res.x\n",
    "    else:\n",
    "        raise Exception(\"Optimisation failed: {}\".format(res))\n",
    "\n",
    "def classical_bound(sigma, delta, sensitivity):\n",
    "    return sensitivity / sigma * np.sqrt(2 * np.log(1.25 / delta))\n",
    "\n",
    "def approximate_dp_gaussian_sigma_through_rdp(epsilon, delta, sensitivity):\n",
    "    a = -epsilon\n",
    "    b = 2 * np.sqrt(-0.5 * sensitivity**2 * np.log(delta))\n",
    "    c = sensitivity**2 / 2\n",
    "\n",
    "    sigma = (-b - np.sqrt(b**2 - 4 * a * c)) / (2 * a)\n",
    "    return sigma\n",
    "\n",
    "def approximate_dp_gaussian_epsilon_through_rdp(sigma, delta, sensitivity):\n",
    "    alpha_star = np.sqrt(2 * sigma**2 * np.log(1 / delta) / sensitivity**2) + 1\n",
    "    epsilon = sensitivity**2 * alpha_star / (2 * sigma**2) + np.log(1 / delta) / (alpha_star - 1)\n",
    "    return epsilon"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sensitivity = 1\n",
    "delta = 1e-5\n",
    "\n",
    "epsilons = np.linspace(0.1, 10, 500)\n",
    "rdp_sigmas = [approximate_dp_gaussian_sigma_through_rdp(eps, delta, sensitivity) for eps in epsilons]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "sigmas = np.linspace(0.1, 50, 500)\n",
    "rdp_epsilons = [approximate_dp_gaussian_epsilon_through_rdp(sigma, delta, sensitivity) for sigma in sigmas]\n",
    "classical_epsilons = [classical_bound(sigma, delta, sensitivity) for sigma in sigmas]\n",
    "optim_sigmas = [1, 10]\n",
    "optim_bs = {sigma: find_optim_b_linear_bound(sigma, delta, sensitivity) for sigma in optim_sigmas}\n",
    "optim_rhos = {sigma: find_optim_rho_mixture_bound(sigma, delta, sensitivity) for sigma in optim_sigmas}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "linear_epsilons = {\n",
    "    optim_sigma: [linear_bound(b, sigma, delta, sensitivity) for sigma in sigmas]\n",
    "    for optim_sigma, b in optim_bs.items()\n",
    "}\n",
    "mixture_epsilons = {\n",
    "    optim_sigma: [mixture_bound(rho, sigma, delta, sensitivity) for sigma in sigmas]\n",
    "    for optim_sigma, rho in optim_rhos.items()\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_optim_linear_bound(sigma, delta, sensitivity):\n",
    "    b = find_optim_b_linear_bound(sigma, delta, sensitivity)\n",
    "    return linear_bound(b, sigma, delta, sensitivity)\n",
    "\n",
    "def find_optim_mixture_bound(sigma, delta, sensitivity):\n",
    "    rho = find_optim_rho_mixture_bound(sigma, delta, sensitivity)\n",
    "    return mixture_bound(rho, sigma, delta, sensitivity)\n",
    "\n",
    "optim_linear_epsilons = [find_optim_linear_bound(sigma, delta, sensitivity) for sigma in sigmas]\n",
    "optim_mixture_epsilons = [find_optim_mixture_bound(sigma, delta, sensitivity) for sigma in sigmas]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 675x168.75 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(1, 2, figsize=figsize_factory(nrows=1, ncols=2, height_to_width_ratio=0.5, tight_layout=False)[\"figure.figsize\"], sharey=True)\n",
    "\n",
    "ax = axes[0]\n",
    "ax.plot(epsilons, rdp_sigmas, label=\"RDP (Ours)\")\n",
    "ax.plot(optim_linear_epsilons, sigmas, label=\"Optim. Linear\", linestyle=\"dotted\")\n",
    "ax.plot(optim_mixture_epsilons, sigmas, label=\"Optim. Mixture\", linestyle=\"dashed\")\n",
    "\n",
    "ax.set_xlabel(r\"Epsilon (ADP, $\\delta = 10^{-5}$)\")\n",
    "ax.set_ylabel(\"Sigma\")\n",
    "ax.set_yscale(\"log\")\n",
    "ax.set_xlim(0.05, 10)\n",
    "ax.set_ylim(3e-1, 1e2)\n",
    "ax.grid()\n",
    "ax.legend()\n",
    "ax.set_title(r\"Mixture \\& Linear Tuned Per-$\\sigma$\")\n",
    "\n",
    "ax = axes[1]\n",
    "ax.plot(epsilons, rdp_sigmas, label=\"RDP (Ours)\")\n",
    "for optim_sigma, eps in linear_epsilons.items():\n",
    "    ax.plot(eps, sigmas, label=r\"Linear @ $\\sigma = {}$\".format(optim_sigma), linestyle=\"dotted\")\n",
    "for optim_sigma, eps in mixture_epsilons.items():\n",
    "    ax.plot(eps, sigmas, label=r\"Mixture @ $\\sigma = {}$\".format(optim_sigma), linestyle=\"dashed\")\n",
    "\n",
    "\n",
    "ax.set_xlabel(r\"Epsilon (ADP, $\\delta = 10^{-5}$)\")\n",
    "# ax.set_ylabel(\"Sigma\")\n",
    "ax.set_yscale(\"log\")\n",
    "ax.set_xlim(0.05, 10)\n",
    "ax.grid()\n",
    "ax.legend()\n",
    "ax.set_title(r\"Mixture \\& Linear Tuned for One $\\sigma$\")\n",
    "\n",
    "# plt.tight_layout()\n",
    "plt.savefig(\"figures/brownian-mech-privacy-comparison.pdf\", bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(sigmas, np.array(rdp_epsilons) - np.array(optim_linear_epsilons))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(sigmas, (np.array(optim_mixture_epsilons) - np.array(rdp_epsilons)) / np.array(rdp_epsilons))\n",
    "plt.grid()\n",
    "# plt.yscale(\"log\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "weakening-dp-bounds",
   "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.12.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
