{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": [
        "import os\n",
        "import sys\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",
        "fig_dir = os.path.join(project_dir, 'fig')\n",
        "os.makedirs(fig_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",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "from OAEGN_analysis.accounting_SGG import sgg_delta_via_fft_accounting\n",
        "from OAEGN_analysis.privacy_analysis import compute_spherical_generalized_gamma_privacy\n",
        "from OAEGN_analysis.radial_rv import generalized_gamma_moments"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": [
        "# Parameters setup\n",
        "eps_tot = 1.0\n",
        "delta_target = 1e-5\n",
        "\n",
        "s = 1.0\n",
        "T = 10\n",
        "p = 1.0\n",
        "alpha = T - 1\n",
        "workers = 50\n",
        "\n",
        "mu_0 = np.zeros(T)\n",
        "mu_1 = np.zeros(T); mu_1[0] = s  # ||mu_1 - mu_0||_2 = s"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": [
        "def delta_single_beta(beta, eps):\n",
        "    return float(compute_spherical_generalized_gamma_privacy(eps, alpha, beta, p, T, mu_0, mu_1))\n",
        "\n",
        "def delta_seq_beta(beta, eps_tot, k):\n",
        "    # standard sequential with equal eps split, delta adds\n",
        "    return k * delta_single_beta(beta, eps_tot / k)\n",
        "\n",
        "def delta_tight_beta(beta, eps_tot, k):\n",
        "    return float(sgg_delta_via_fft_accounting(eps_tot, T, alpha, beta, p, s, k, workers=workers))\n",
        "\n",
        "# ----------------------------\n",
        "# Robust beta solver: bracket + bisection (no monotonicity assumption hard-coded)\n",
        "# ----------------------------\n",
        "def solve_beta_for_delta(\n",
        "    delta_of_beta,\n",
        "    delta_target,\n",
        "    beta_init=1.0,  # starting beta guess\n",
        "    expand_factor=2.0,\n",
        "    max_expand=60,\n",
        "    tol_abs=1e-9,\n",
        "    max_bisect=80,\n",
        "    *,\n",
        "    verbose=True,\n",
        "    log_every=1,\n",
        "    log_prefix=\"solve_beta_for_delta\",\n",
        "):\n",
        "    \"\"\"Solve for beta>0 such that delta_of_beta(beta) ~= delta_target.\n",
        "\n",
        "    Returns (beta_star, info_dict).\n",
        "\n",
        "    Notes:\n",
        "    - `delta_of_beta(beta)` can be very expensive; enable `verbose=True` to get\n",
        "      progress logs and timings.\n",
        "    - `log_every` controls how often we print evaluation logs (by eval count).\n",
        "    \"\"\"\n",
        "    import time\n",
        "\n",
        "    t0 = time.perf_counter()\n",
        "    n_eval = 0\n",
        "\n",
        "    def _log(msg):\n",
        "        if verbose:\n",
        "            elapsed = time.perf_counter() - t0\n",
        "            print(f\"[{log_prefix}] {msg} (elapsed={elapsed:.2f}s)\")\n",
        "\n",
        "    def f(beta, *, tag=\"\"):\n",
        "        nonlocal n_eval\n",
        "        t1 = time.perf_counter()\n",
        "        delta_val = delta_of_beta(beta)\n",
        "        # robust numeric conversion for logging / sign checks\n",
        "        try:\n",
        "            delta_val_f = float(delta_val)\n",
        "        except Exception:\n",
        "            delta_val_f = float(np.asarray(delta_val))\n",
        "\n",
        "        f_val = delta_val_f - float(delta_target)\n",
        "        n_eval += 1\n",
        "\n",
        "        if verbose and (n_eval % max(1, int(log_every)) == 0):\n",
        "            dt = time.perf_counter() - t1\n",
        "            _log(\n",
        "                f\"eval#{n_eval} beta={beta:.6e} delta={delta_val_f:.6e} f={f_val:.6e} dt={dt:.2f}s {tag}\".rstrip()\n",
        "            )\n",
        "\n",
        "        return f_val\n",
        "\n",
        "    _log(\n",
        "        f\"start: target_delta={float(delta_target):.3e}, beta_init={beta_init:.3e}, \"\n",
        "        f\"expand_factor={expand_factor}, max_expand={max_expand}, max_bisect={max_bisect}\"\n",
        "    )\n",
        "\n",
        "    # start with a bracket around beta_init in log-space\n",
        "    beta_lo = max(beta_init / expand_factor, 1e-12)\n",
        "    beta_hi = max(beta_init * expand_factor, 1e-12)\n",
        "\n",
        "    flo = f(beta_lo, tag=\"[init lo]\")\n",
        "    fhi = f(beta_hi, tag=\"[init hi]\")\n",
        "\n",
        "    # Expand until sign change (or until max_expand)\n",
        "    n_expand = 0\n",
        "    while flo * fhi > 0 and n_expand < max_expand:\n",
        "        n_expand += 1\n",
        "        beta_lo = max(beta_lo / expand_factor, 1e-12)\n",
        "        beta_hi = beta_hi * expand_factor\n",
        "        _log(f\"expand#{n_expand}: beta_lo={beta_lo:.3e}, beta_hi={beta_hi:.3e}\")\n",
        "        flo = f(beta_lo, tag=f\"[expand#{n_expand} lo]\")\n",
        "        fhi = f(beta_hi, tag=f\"[expand#{n_expand} hi]\")\n",
        "\n",
        "    if flo * fhi > 0:\n",
        "        raise RuntimeError(\n",
        "            \"Failed to bracket a root for beta. \"\n",
        "            f\"Try different beta_init or widen search. \"\n",
        "            f\"Got f(beta_lo)={flo:.3e}, f(beta_hi)={fhi:.3e}, \"\n",
        "            f\"beta_lo={beta_lo:.3e}, beta_hi={beta_hi:.3e}.\"\n",
        "        )\n",
        "\n",
        "    _log(f\"bracket found: beta_lo={beta_lo:.3e} (f={flo:.3e}), beta_hi={beta_hi:.3e} (f={fhi:.3e})\")\n",
        "\n",
        "    # Bisection\n",
        "    for it in range(max_bisect):\n",
        "        beta_mid = np.sqrt(beta_lo * beta_hi)  # geometric mid keeps positivity and handles wide ranges well\n",
        "        fmid = f(beta_mid, tag=f\"[bisect it={it}] \")\n",
        "\n",
        "        # stopping criteria\n",
        "        if abs(fmid) <= tol_abs:\n",
        "            _log(f\"converged at it={it + 1}: beta={beta_mid:.6e}, f={fmid:.3e}\")\n",
        "            return beta_mid, {\"iters\": it + 1, \"bracket\": (beta_lo, beta_hi), \"fmid\": fmid, \"n_eval\": n_eval}\n",
        "\n",
        "        # keep the sub-bracket containing the root\n",
        "        if flo * fmid <= 0:\n",
        "            beta_hi, fhi = beta_mid, fmid\n",
        "        else:\n",
        "            beta_lo, flo = beta_mid, fmid\n",
        "\n",
        "        # periodic iteration log (in addition to eval logs)\n",
        "        if verbose and ((it + 1) % 10 == 0 or it == max_bisect - 1):\n",
        "            _log(\n",
        "                f\"bisect progress it={it + 1}: beta_lo={beta_lo:.3e} (f={flo:.3e}), \"\n",
        "                f\"beta_hi={beta_hi:.3e} (f={fhi:.3e})\"\n",
        "            )\n",
        "\n",
        "    _log(f\"max_bisect reached: beta={beta_mid:.6e}, f={fmid:.3e}\")\n",
        "    return beta_mid, {\n",
        "        \"iters\": max_bisect,\n",
        "        \"bracket\": (beta_lo, beta_hi),\n",
        "        \"fmid\": fmid,\n",
        "        \"n_eval\": n_eval,\n",
        "        \"warning\": \"max_bisect reached\",\n",
        "    }\n",
        "\n",
        "# ----------------------------\n",
        "# Example: solve beta for one k under sequential and tight\n",
        "# ----------------------------\n",
        "def beta_required_seq(eps_tot, delta_target, k, beta_init=1.0):\n",
        "    return solve_beta_for_delta(lambda b: delta_seq_beta(b, eps_tot, k),\n",
        "                                delta_target, beta_init=beta_init)[0]\n",
        "\n",
        "def beta_required_tight(eps_tot, delta_target, k, beta_init=1.0):\n",
        "    return solve_beta_for_delta(lambda b: delta_tight_beta(b, eps_tot, k),\n",
        "                                delta_target, beta_init=beta_init)[0]\n",
        "\n",
        "def beta_to_mse(beta, *, alpha, p, prec=50):\n",
        "    return float(generalized_gamma_moments(alpha, beta, p, moment=2, prec=prec))"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {},
      "outputs": [],
      "source": [
        "k_list = [2, 4, 8, 16, 32] \n",
        "\n",
        "beta_seq_list = []\n",
        "beta_tight_list = []\n",
        "\n",
        "beta_init_seq = 1.0\n",
        "beta_init_tight = 1.0\n",
        "\n",
        "for k in k_list:\n",
        "    b_seq = beta_required_seq(eps_tot, delta_target, k, beta_init=beta_init_seq)\n",
        "    b_tight = beta_required_tight(eps_tot, delta_target, k, beta_init=beta_init_tight)\n",
        "\n",
        "    beta_seq_list.append(b_seq)\n",
        "    beta_tight_list.append(b_tight)\n",
        "\n",
        "    # warm-start next k (usually helps a lot)\n",
        "    beta_init_seq = b_seq\n",
        "    beta_init_tight = b_tight\n",
        "\n",
        "    print(f\"k={k:>4d}  beta_seq={b_seq:.6g}  beta_tight={b_tight:.6g}\")\n",
        "\n",
        "\n",
        "mse_seq_list = [beta_to_mse(b, alpha=alpha, p=p, prec=50) for b in beta_seq_list]\n",
        "mse_tight_list = [beta_to_mse(b, alpha=alpha, p=p, prec=50) for b in beta_tight_list]"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 18,
      "metadata": {},
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "k\tbeta_seq\tmse_seq\tbeta_tight\tmse_tight\n",
            "2\t0.576569\t330.895\t0.696183\t226.958\n",
            "4\t0.28936\t1313.76\t0.453563\t534.709\n",
            "8\t0.145072\t5226.67\t0.310464\t1141.22\n",
            "16\t0.0725361\t20906.6\t0.212513\t2435.69\n",
            "32\t0.0363664\t83174.9\t0.139676\t5638.31\n"
          ]
        },
        {
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAvcAAAHWCAYAAADzZ6a1AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAnIZJREFUeJzs3XlcVNX/x/HXsIMsiiK4oCiuCGiaW6VmmWuae7tL5rd982eppWmaqe0b7aVle26tWmqmpaYpKiDu4a64solsM/f3xySIoAICwwzv5+Pho+bcO/d+ZuHOZ86c8zkmwzAMRERERETE7jnZOgARERERESkdSu5FRERERByEknsREREREQeh5F5ERERExEEouRcRERERcRBK7kVEREREHISSexERERERB6HkXkRERETEQSi5FxERERFxEEruRUREREQchJJ7EREREREH4TDJ/Zw5czCZTOzdu7fMzzVlyhRMJlOZn6e8/PPPP1xzzTVUqVIFk8nE5s2by/ycL774Is2aNcNisZT5uSqy9957j3r16pGZmVmqx9XzW7pK63U6d+04ceJEKUWW34gRIzCZTJhMJsLDw8vkHGJ7r7/+eu7rXJbvJxGxTw6T3FdE575wmEwm/vrrrwLbDcMgODgYk8nEzTffXGB7bGwsgwcPpn79+nh4eFCnTh1uuukm3nrrrULPUdi/v//++5IxZmdnM2TIEE6dOsVrr73G3LlzqV+//pU/+EtISUlh1qxZjBs3DienivsW3LJlC0OGDKFOnTq4u7sTGBhIv379OHLkSKmdY8SIEWRlZfH++++X2jEv9vympaUxefJkevbsib+/PyaTiTlz5hTr2JmZmYwbN47atWvj6elJ+/btWbp0aZHuWxrnL+04//jjjyL97ZTF61RWatSowdy5c5k5c2Zu2z///MPDDz9MixYtqFKlCvXq1WPo0KHs3Lmz1M47ffr0UvlSsWvXLm677Tbq1q2Ll5cXzZo1Y+rUqaSnp5f4mMV970VHR9OvXz/8/f3x8vIiPDycN998s0Tn3rp1K0OGDKFhw4Z4eXlRo0YNOnfuzI8//lhg36K+Tj179mTu3LkMGDCgRDEBHDhw4JKfHef/+/fff0t8nsIU9/W4kutORbRx40Z69uyJr68vPj4+dO/evVw61crKlV7bHeX1tfVn7Plcin2PCuruu+/mtttuw93d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BWRlZbFlyxYWLlzIa6+9xuDBg9m8eTNhYWG5+7Zr167QYQQlcfz4cdLT0wudtd+8eXMsFgsHDhzI9zNxYZV6iiM0NJQPPviAhx56iI8++giA+Ph4mjdvnrtPSEgIn3/+eZFnjBd3f4D169ezfv16nn766QLbzo3HPveFoyTHv5hzH8bn5pJUq1at0HHztuTp6VlonfeMjIzc7VeqqH+fWVlZBRLfgIAAnJ2drzjORo0accstt7BgwQLMZnO+L8kXvk4l1bdvXwIDA/n1118LfBEzm80F3vuXcmG1nMs5evQoffr0wc/PL3eMZ0lMnDgRf3//ApW7rsTXX3/N//73P3bu3EndunUBa3JtsVgYN24ct99++yWHGl6pc++NCytN3XHHHbz//vusXbu2xMn9uQo3AMOGDaN79+707duXdevWFfp+Kq3XqSiOHDnCiRMnijS0qryvTaV93TnXedW3b99CO0FGjhx50aG3pfHY77//fg4cOMBLL73Ep59+CsDVV1/NU089xfTp00vcMRMbGwtYKwcWprAhbRXhc6asPleGDRvGxx9/TNeuXWndujW33XYbd911F7Vq1Sqwb0V4HqB0n4sSJ/fnn+TchKO77rrror0LlxvHV5iLfYCazeYiH+PCJ6OosZbFJKo77riD0aNHc/ToUXr16lXoZNnCuLm50bZtW9q2bUuTJk0YOXIk3333HZMnTy71GEuqqG+66tWrk5OTQ2pqar6x9FFRUUyYMIGnnnqKtm3b4unpWeCXiPKwbt06oPDe0M2bN9O0adNSSWJzcnLyJWSnT5/Gy8sr99iFJa8Xcy6phYs/v6WhVq1aHDp0qED7uR6n2rVrX/E5ivr3ea5U7PkSEhIICQkplTiDg4PJysrizJkz+XrVL3ydSmrQoEF8+umnfPHFF9x33335tjVr1owGDRqUem1xsM7N6dWrF0lJSfz5558lfs127drFBx98wOuvv87hw4dz2zMyMsjOzmbv3r34+vri7+9frOO+8847XHXVVbmJ/Tn9+vVjzpw5bNq0qUw/hGvXrs3WrVsLJHfnihicPn261M41ePBg7rvvPnbu3FmgI6W0XqeiKup4eyj5tamkSvu68++//5KamlpgXtLx48cBeOihhy5639J67NOnT2fs2LFs3boVPz8/IiIicjuUSvq5FxcXh7+/f4G/nYyMDOLj4wv9El7er2VhyupzpXHjxuzcuZMFCxbw448/MmnSJKZOncqSJUsK/PJbEZ4HKN3nolTq3AcEBODj44PZbL7shTcgIABPT0927dpVYNuOHTvy3a5WrVqBagJgrS5R1rGazeYix1lUAwYM4L777uPvv//mm2++KdExzvXOl+ZCShcKCAjAy8ur0Me5fft2nJycSjxx8lzSnJCQkPtBcvDgQZ544gneffddRo0aVej97r33Xvbv30/37t1xcnLi/fff584772Tr1q3cf//9xMbGEhoayptvvsm111570f0v5+TJkwAFKlbs2bOHf/75J/cCXNjx9+3bx/vvv8/p06dp0aIF77//fr4PS5PJxFtvvcUrr7xC3bp1+fPPP3O3JSQk5OupLSx5vZhzSS0U/vyWllatWrFixYoCw5LOfSFq1arVFZ+jqH+frq6uBX5GPfdzaWnE+e+//+Lh4VGgF+3C16mkXnrpJVxcXHjwwQfx8fHJVzVr8ODBPPbYY/zwww8Fht9diYyMDPr27cvOnTtZtmxZvl/+iuvQoUNYLBYeffRRHn300QLbGzRowGOPPVbsCjqJiYlUq1atQHt2djbAJasZlYY2bdqwdOlSDh06lC/hPvcFpjSHH537if3CiXyl+ToV1ble36JcM0p6bSqp0r7unEvia9Soka99xowZhbafrzQf+4WV5ZYtW0bdunVLNMwOrK9hYUnn7NmzycjIYNCgQQW2lfdrWZiy/Fzx9vZm2LBhDBs2jB07dhAREcG3335bILmvCM8DlO5zUSrJvbOzM4MGDeLLL78stLrL8ePHcy+Kzs7O9OjRg0WLFrF///7c8ezbtm3j119/zXe/0NBQkpOTiYmJyb3oHDlypMSLdhQn1uLEWVTe3t68++677N27l759+15y3xUrVnD99dcX+PXi3HCgslzowtnZme7du/P999+zd+/e3DdyYmJi7mJcJR1z3rFjRwA2bNiQ+5pu2bKF7OxsQkNDL3q/jz76iGXLluUbBpOVlUXfvn15/PHH+f3331mwYAF9+/Zlz549he5fFOe+GS9btozRo0cD1uoG9913H1WrVs3tZS3s+AsWLGDDhg1UrVqVadOmMWzYsAKrDi5dupQtW7YUmEsQHR2d78tHSccAFvb8Fld6ejr79++nRo0a+T7oBg8ezMsvv8wHH3zA2LFjAetzM3v2bNq3b18q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/EDDLj0REVG3YBP1iBVg557UVVNxa136ll36QeHA8N+yS09ERER0D1jcU9drNAJl+5u69CU7b3XpHfvcWpe+n7+KARIRERH1TCzuqevUVLSYS3/u1v5B4U0FvWEyu/RERERE94HFPVlWoxEoO9C04k17XfrQ3wCeP1M1RCIiIiJrweKeLKOmAji5DjjWuks/Ghj2W8AwCejlpF58RERERFaIxT11no669MHTmqbesEtPREREZDEs7un+1V5qWvGm3S59zM259OzSExEREVkai3v6aRobgW/2A0dbd+m1N9el/w3gOVjdGImIiIhsDIt7ujfNXfrjfweqWnTpfUY1rUvPLj0RERGRaljcU9Nc+W8/B+ouAy79Ad9wwE7T4vjNLn3zuvSNN5r2O2pbzKVnl56IiIhIbSzubd3XW4Fdi4Cai7f2uQ0AnvpfwGfkzS79mrZd+mExQMAUdumJiIiIuhEW97bs663AxzMBiPn+movAxy8Cih0gjU37mrv0ob8B+hu6PFQiIiIiujMW97aq0djUsW9d2LckjYD3CGD4rKa59PbOXRYeEREREd07Fve26tvPzafi3M4TbwEP/Y/l4yEiIiKi+2andgCkkrrLnXseEREREamOxb2tcunfuecRERERkepY3Nsq3/CmVXGg3OYEBXAb2HQeEREREfUILO5tlZ2mablLAG0L/JvbTy0zX++eiIiIiLo1Fve2zDAJeP7vgJuX+X63AU37DZPUiYuIiIiIfhKulmPrDJOAnz3d8RNqiYiIiKhHYHFPTYU8l7skIiIi6vE4LacbS0tLg8FgQFhYmNqhEBEREVEPoIhIB48ope6gpqYGWq0W1dXVcHNzUzscIiIiskGsR3oGdu6JiIiIiKwEi3siIiIiIivB4p6IiIiIyEqwuCciIiIishIs7omIiIiIrASLeyIiIiIiK8HinoiIiIjISvAJtT1A86MIampqVI6EiIiIbFVzHcJHJHVvLO57gNraWgCAj4+PypEQERGRrautrYVWq1U7DLoNPqG2B2hsbMTFixfh6uoKRVEsMkZNTQ18fHxw/vx5PnXOBjDftoc5ty3Mt+3pipyLCGprazFgwADY2XFmd3fFzn0PYGdnB29v7y4Zy83Njf8Q2BDm2/Yw57aF+bY9ls45O/bdHz92ERERERFZCRb3RERERERWgsU9AQAcHByQnJwM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",
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Report as a small table\n",
        "print(\"k\\tbeta_seq\\tmse_seq\\tbeta_tight\\tmse_tight\")\n",
        "for k, b1, m1, b2, m2 in zip(k_list, beta_seq_list, mse_seq_list, beta_tight_list, mse_tight_list):\n",
        "    print(f\"{k}\\t{b1:.6g}\\t{m1:.6g}\\t{b2:.6g}\\t{m2:.6g}\")\n",
        "\n",
        "# Plot MSE vs k\n",
        "plt.figure()\n",
        "plt.plot(k_list, mse_seq_list, marker=\"o\", label=\"Sequential\")\n",
        "plt.plot(k_list, mse_tight_list, marker=\"o\", label=\"FFT Accountant\")\n",
        "plt.xscale(\"log\", base=2)\n",
        "plt.yscale(\"log\")\n",
        "plt.xlabel(\"k (number of invocations)\")\n",
        "plt.ylabel(r\"MSE (noise budget) $E[R^2]$\")\n",
        "plt.title(\n",
        "    rf\"required MSE for $(\\varepsilon_{{\\mathrm{{tot}}}},\\delta_{{\\mathrm{{tar}}}})$=\"\n",
        "    rf\"({eps_tot},{delta_target}), k∈{k_list}; $T={T}$, $\\alpha={alpha}$, $p={p}$, $s={s}$\"\n",
        ")\n",
        "plt.legend()\n",
        "plt.tight_layout()\n",
        "# Save figure under fig/\n",
        "out_path = os.path.join(fig_dir, \"sgg_fft_required_mse_vs_k.png\")\n",
        "plt.savefig(out_path, dpi=300, bbox_inches=\"tight\")\n",
        "plt.show()\n",
        "\n"
      ]
    }
  ],
  "metadata": {
    "kernelspec": {
      "display_name": "dp_privl_venv",
      "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.11.9"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 2
}
