{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import time\n",
    "\n",
    "# Navigate to the parent directory of the project structure\n",
    "project_dir = os.path.abspath(os.path.join(os.getcwd(), '../../../'))\n",
    "src_dir = os.path.join(project_dir, 'src')\n",
    "data_dir = os.path.join(project_dir, 'data')\n",
    "fig_dir = os.path.join(project_dir, 'fig')\n",
    "os.makedirs(fig_dir, exist_ok=True)\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "\n",
    "# Add the src directory to sys.path\n",
    "sys.path.append(src_dir)\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "from OAEGN_analysis.privacy_analysis import compute_spherical_generalized_gamma_privacy\n",
    "from OAEGN_analysis.privacy_analysis import compute_spherical_gamma_privacy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "privacy of spherical gamma-distribution with 5 degrees of freedom is 0.044244578177929934 computed via analytic formula\n"
     ]
    }
   ],
   "source": [
    "epsilon = 1\n",
    "s = 1\n",
    "T = 10\n",
    "dof = 5\n",
    "mu_0 = np.array([0])\n",
    "mu_1 = np.array([s])\n",
    "theta = 1\n",
    "\n",
    "ret1 = compute_spherical_gamma_privacy(epsilon, theta=theta, alpha=dof, dim=T, mu_0=mu_0, mu_1=mu_1)\n",
    "\n",
    "print(f\"privacy of spherical gamma-distribution with {dof} degrees of freedom is {ret1} computed via analytic formula\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "privacy of spherical generalized Gamma mechanism is 0.044244578190888076 computed via privacy function of spherical generalized Gamma\n",
      "error is smaller than 1e-10: True\n"
     ]
    }
   ],
   "source": [
    "beta = 1/theta\n",
    "p = 1\n",
    "alpha = dof-1\n",
    "\n",
    "mu_0 = np.array([0])\n",
    "mu_1 = np.array([s])\n",
    "\n",
    "ret2 = compute_spherical_generalized_gamma_privacy(epsilon, alpha, beta, p, T, mu_0, mu_1, prec=80, method='exact')\n",
    "\n",
    "print(f\"privacy of spherical generalized Gamma mechanism is {ret2} computed via privacy function of spherical generalized Gamma\")\n",
    "print(f\"error is smaller than 1e-10: {np.abs(ret1 - ret2) < 1e-10}\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (dp-privl-env)",
   "language": "python",
   "name": "dp-privl-env"
  },
  "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
