{
 "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",
    "log_dir = os.path.join(project_dir, 'log')  \n",
    "os.makedirs(fig_dir, exist_ok=True)\n",
    "os.makedirs(data_dir, exist_ok=True)\n",
    "os.makedirs(log_dir, exist_ok=True)\n",
    "\n",
    "# Add the src directory to sys.path\n",
    "sys.path.append(src_dir)\n",
    "\n",
    "import logging\n",
    "import numpy as np\n",
    "from datetime import datetime\n",
    "\n",
    "from utils import setup_logging\n",
    "from OAEGN_analysis.spherical_generalized_gamma import compute_empirical_optimal_generalized_gamma_parameters_under_privacy_constraint, gen_optimizer_params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "timestamp = datetime.now().strftime(\"%Y%m%d_%H%M%S\")\n",
    "log_file = os.path.join(log_dir, f'accuracy_generalized_gamma_test_{timestamp}.log')\n",
    "logger = setup_logging(log_file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-12-31 10:06:37,483 - INFO - Computed noise budget upper bound: 81.21527978671585 for epsilon=2, delta=0.0001, T=3, database_sensitivity=3, error_metric=second_moment\n",
      "2025-12-31 10:06:55,348 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=0.0390, p=2.7896, delta=0.0541041446468828\n",
      "2025-12-31 10:06:55,348 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.5707, p=1.5923, delta=0.0000004908991696\n",
      "2025-12-31 10:06:55,350 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.7467, p=1.3090, delta=0.0000000203470111\n",
      "2025-12-31 10:06:55,350 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=0.9059, p=2.8559, delta=0.0014408771060262\n",
      "2025-12-31 10:06:55,351 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.6157, p=1.2821, delta=0.0000020437947616\n",
      "2025-12-31 10:06:55,351 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=0.1453, p=2.4503, delta=0.0408040569219027\n",
      "2025-12-31 10:06:55,352 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.4953, p=1.9356, delta=0.0000137512238962\n",
      "2025-12-31 10:06:55,352 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.4048, p=1.8180, delta=0.0000135237885345\n",
      "2025-12-31 10:06:55,353 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.0069, p=1.8099, delta=0.0010151080396413\n",
      "2025-12-31 10:06:55,354 - INFO - Noise budget 81.21527978671585 iteration 0: alpha=1.2417, p=1.2418, delta=0.0005898251195474\n",
      "2025-12-31 10:06:55,354 - INFO - Early stopping at iteration 0 as delta_goal 0.0001 is reached with delta 2.0347011117240117e-08\n",
      "2025-12-31 10:06:55,361 - INFO - \u001b[91mInitial result: alpha=1.746687, p=1.308956, delta=2.034701e-08\u001b[0m\n",
      "2025-12-31 10:06:55,362 - INFO - \u001b[96mBinary search iteration 1/50:\u001b[0m c_lower=\u001b[93m0.000000\u001b[0m, c_upper=\u001b[93m81.215280\u001b[0m, c_mid=\u001b[1m40.607640\u001b[0m\n",
      "2025-12-31 10:07:13,751 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.5890, p=2.8687, delta=0.0133262806085252\n",
      "2025-12-31 10:07:13,752 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=0.3355, p=2.0474, delta=0.0412961417559842\n",
      "2025-12-31 10:07:13,752 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.6126, p=2.2631, delta=0.0053391520441368\n",
      "2025-12-31 10:07:13,753 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.0611, p=1.3181, delta=0.0062976244471583\n",
      "2025-12-31 10:07:13,753 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.4757, p=1.8894, delta=0.0013154236035583\n",
      "2025-12-31 10:07:13,753 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.2843, p=2.4782, delta=0.0052770118215341\n",
      "2025-12-31 10:07:13,754 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=0.6921, p=1.7199, delta=0.0152883214662658\n",
      "2025-12-31 10:07:13,754 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=0.5564, p=2.1629, delta=0.0184130542279979\n",
      "2025-12-31 10:07:13,754 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.9360, p=2.2329, delta=0.0075836982397450\n",
      "2025-12-31 10:07:13,755 - INFO - Noise budget 40.60763989335793 iteration 0: alpha=1.9816, p=2.8406, delta=0.0184299134508859\n",
      "2025-12-31 10:07:33,418 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=1.9131, p=1.0000, delta=0.0000005178184871\n",
      "2025-12-31 10:07:33,418 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.8503, p=3.0000, delta=0.0091035666544946\n",
      "2025-12-31 10:07:33,419 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=1.5633, p=1.0000, delta=0.0014893312521605\n",
      "2025-12-31 10:07:33,419 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=1.5672, p=1.1094, delta=0.0003866526653614\n",
      "2025-12-31 10:07:33,420 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.0004, p=2.9690, delta=0.0861615587396957\n",
      "2025-12-31 10:07:33,420 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=1.8105, p=1.4776, delta=0.0001830519756050\n",
      "2025-12-31 10:07:33,420 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.2244, p=2.6067, delta=0.0483445459892061\n",
      "2025-12-31 10:07:33,420 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.0932, p=1.2039, delta=0.1397419536664393\n",
      "2025-12-31 10:07:33,421 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.0421, p=1.5663, delta=0.1163251610336830\n",
      "2025-12-31 10:07:33,421 - INFO - Noise budget 40.60763989335793 iteration 1: alpha=0.1015, p=2.3730, delta=0.0724175952895586\n",
      "2025-12-31 10:07:33,422 - INFO - Early stopping at iteration 1 as delta_goal 0.0001 is reached with delta 5.178184871365595e-07\n",
      "2025-12-31 10:07:33,422 - INFO - \u001b[94mIteration 1/50's delta_opt:\u001b[0m \u001b[92m5.178185e-07\u001b[0m, \u001b[92mError: 40.607640\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m9.948218e-05\u001b[0m\n",
      "2025-12-31 10:07:33,427 - INFO - \u001b[96mBinary search iteration 2/50:\u001b[0m c_lower=\u001b[93m0.000000\u001b[0m, c_upper=\u001b[93m40.607640\u001b[0m, c_mid=\u001b[1m20.303820\u001b[0m\n",
      "2025-12-31 10:07:52,197 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=1.4562, p=2.3828, delta=0.0437787397844199\n",
      "2025-12-31 10:07:52,198 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=0.4421, p=2.8537, delta=0.0590934393031073\n",
      "2025-12-31 10:07:52,198 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=1.9726, p=2.3063, delta=0.0584649845514378\n",
      "2025-12-31 10:07:52,198 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=1.4269, p=2.5649, delta=0.0489741139452364\n",
      "2025-12-31 10:07:52,198 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=0.9275, p=2.6178, delta=0.0374994500825071\n",
      "2025-12-31 10:07:52,199 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=1.1971, p=2.7880, delta=0.0475842282286221\n",
      "2025-12-31 10:07:52,199 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=0.6628, p=2.0076, delta=0.0423780393653930\n",
      "2025-12-31 10:07:52,199 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=0.3359, p=1.7192, delta=0.0999023529923972\n",
      "2025-12-31 10:07:52,200 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=1.4680, p=2.4050, delta=0.0449377859196150\n",
      "2025-12-31 10:07:52,200 - INFO - Noise budget 20.303819946678964 iteration 0: alpha=0.6771, p=1.0459, delta=0.1309659655559788\n",
      "2025-12-31 10:08:12,090 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=0.7820, p=2.2877, delta=0.0345086019314746\n",
      "2025-12-31 10:08:12,092 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=2.0000, p=1.4152, delta=0.0226143276427829\n",
      "2025-12-31 10:08:12,092 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=1.2583, p=1.8658, delta=0.0229487932529962\n",
      "2025-12-31 10:08:12,093 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=2.0000, p=1.0000, delta=0.0193195757350493\n",
      "2025-12-31 10:08:12,094 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=1.0258, p=2.0956, delta=0.0270328342964333\n",
      "2025-12-31 10:08:12,094 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=1.6555, p=1.3672, delta=0.0158028409078044\n",
      "2025-12-31 10:08:12,095 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=1.6667, p=1.7823, delta=0.0287614366140662\n",
      "2025-12-31 10:08:12,095 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=2.0000, p=3.0000, delta=0.0874726761568885\n",
      "2025-12-31 10:08:12,096 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=0.0000, p=3.0000, delta=0.1332781649323351\n",
      "2025-12-31 10:08:12,096 - INFO - Noise budget 20.303819946678964 iteration 1: alpha=0.0000, p=2.5705, delta=0.1400649406546550\n",
      "2025-12-31 10:08:32,735 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.6674, p=1.0062, delta=0.0317510472169068\n",
      "2025-12-31 10:08:32,736 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.3923, p=1.2555, delta=0.0234894349927033\n",
      "2025-12-31 10:08:32,737 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.1342, p=1.5197, delta=0.0238535707331931\n",
      "2025-12-31 10:08:32,737 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.8355, p=1.1532, delta=0.0157606833119329\n",
      "2025-12-31 10:08:32,737 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=0.7990, p=2.9999, delta=0.0451167542451512\n",
      "2025-12-31 10:08:32,738 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.3518, p=1.5132, delta=0.0176224328204081\n",
      "2025-12-31 10:08:32,738 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.2713, p=1.0044, delta=0.0619711240318478\n",
      "2025-12-31 10:08:32,739 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=0.0038, p=1.0219, delta=0.2933396200662395\n",
      "2025-12-31 10:08:32,739 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=0.6728, p=3.0000, delta=0.0470884445587336\n",
      "2025-12-31 10:08:32,739 - INFO - Noise budget 20.303819946678964 iteration 2: alpha=1.2445, p=1.3153, delta=0.0273402610484004\n",
      "2025-12-31 10:08:56,185 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.9977, p=1.1709, delta=0.0157393206126983\n",
      "2025-12-31 10:08:56,186 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.9993, p=1.8352, delta=0.0394715721049199\n",
      "2025-12-31 10:08:56,186 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.9985, p=1.6671, delta=0.0324174874285673\n",
      "2025-12-31 10:08:56,187 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=0.9796, p=1.7867, delta=0.0257693411574040\n",
      "2025-12-31 10:08:56,187 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.4578, p=3.0000, delta=0.0642625363924359\n",
      "2025-12-31 10:08:56,188 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=0.8080, p=1.6424, delta=0.0404926461881792\n",
      "2025-12-31 10:08:56,188 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.6155, p=3.0000, delta=0.0711092732257578\n",
      "2025-12-31 10:08:56,189 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=1.8284, p=1.5723, delta=0.0248853099010571\n",
      "2025-12-31 10:08:56,190 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=0.6434, p=2.5789, delta=0.0430633834067362\n",
      "2025-12-31 10:08:56,190 - INFO - Noise budget 20.303819946678964 iteration 3: alpha=0.5144, p=2.4344, delta=0.0518811225602509\n",
      "2025-12-31 10:09:17,600 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.9961, p=2.6971, delta=0.0753395437782983\n",
      "2025-12-31 10:09:17,602 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.9992, p=2.6144, delta=0.0720778932221439\n",
      "2025-12-31 10:09:17,602 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.3123, p=1.6795, delta=0.0193276262568290\n",
      "2025-12-31 10:09:17,603 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.4824, p=2.0547, delta=0.0333972730163500\n",
      "2025-12-31 10:09:17,603 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=0.0049, p=2.1111, delta=0.1545063734898017\n",
      "2025-12-31 10:09:17,605 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=0.0000, p=2.0162, delta=0.1609662121754330\n",
      "2025-12-31 10:09:17,606 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=0.1808, p=2.0788, delta=0.1111953001235030\n",
      "2025-12-31 10:09:17,606 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.3117, p=2.1352, delta=0.0314420887622017\n",
      "2025-12-31 10:09:17,607 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.8315, p=1.2673, delta=0.0156783447273926\n",
      "2025-12-31 10:09:17,608 - INFO - Noise budget 20.303819946678964 iteration 4: alpha=1.8259, p=2.6626, delta=0.0674796810251097\n",
      "2025-12-31 10:09:40,294 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.5762, p=1.4359, delta=0.0163716954215795\n",
      "2025-12-31 10:09:40,297 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.7386, p=1.1977, delta=0.0159192235706783\n",
      "2025-12-31 10:09:40,298 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=0.5221, p=2.7137, delta=0.0517188843153425\n",
      "2025-12-31 10:09:40,298 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9934, p=1.0503, delta=0.0168712110228586\n",
      "2025-12-31 10:09:40,298 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9929, p=1.0175, delta=0.0184150725173671\n",
      "2025-12-31 10:09:40,299 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9939, p=1.0278, delta=0.0178578516071889\n",
      "2025-12-31 10:09:40,299 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9970, p=1.2804, delta=0.0181061155603789\n",
      "2025-12-31 10:09:40,299 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9943, p=1.2499, delta=0.0172680970691382\n",
      "2025-12-31 10:09:40,300 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.9790, p=1.0014, delta=0.0197501852964270\n",
      "2025-12-31 10:09:40,300 - INFO - Noise budget 20.303819946678964 iteration 5: alpha=1.5668, p=1.4643, delta=0.0168209336377850\n",
      "2025-12-31 10:09:40,301 - INFO - \u001b[94mIteration 2/50's delta_opt:\u001b[0m \u001b[92m1.567834e-02\u001b[0m, \u001b[92mError: 20.303820\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m1.557834e-02\u001b[0m\n",
      "2025-12-31 10:09:40,302 - INFO - \u001b[96mBinary search iteration 3/50:\u001b[0m c_lower=\u001b[93m20.303820\u001b[0m, c_upper=\u001b[93m40.607640\u001b[0m, c_mid=\u001b[1m30.455730\u001b[0m\n",
      "2025-12-31 10:09:58,821 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=0.4492, p=2.5069, delta=0.0329197529178095\n",
      "2025-12-31 10:09:58,822 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.0806, p=2.5602, delta=0.0125511496442984\n",
      "2025-12-31 10:09:58,822 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.6290, p=1.3779, delta=0.0006062769303441\n",
      "2025-12-31 10:09:58,823 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.7377, p=2.6712, delta=0.0261765093368897\n",
      "2025-12-31 10:09:58,823 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.4139, p=1.5485, delta=0.0014637113670590\n",
      "2025-12-31 10:09:58,823 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=0.9517, p=1.6353, delta=0.0088715000380818\n",
      "2025-12-31 10:09:58,824 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=0.7946, p=2.2541, delta=0.0123468136920113\n",
      "2025-12-31 10:09:58,824 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.8973, p=1.2819, delta=0.0005574750850653\n",
      "2025-12-31 10:09:58,824 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=0.7416, p=1.4579, delta=0.0279697332857923\n",
      "2025-12-31 10:09:58,825 - INFO - Noise budget 30.455729920018445 iteration 0: alpha=1.0498, p=1.9800, delta=0.0058886998700428\n",
      "2025-12-31 10:10:18,582 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=1.3886, p=1.0000, delta=0.0134911719976223\n",
      "2025-12-31 10:10:18,583 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=2.0000, p=1.0000, delta=0.0000000000000000\n",
      "2025-12-31 10:10:18,583 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=0.0000, p=1.0000, delta=0.2393247153233768\n",
      "2025-12-31 10:10:18,583 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=1.5650, p=1.2070, delta=0.0005602197718498\n",
      "2025-12-31 10:10:18,584 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=0.0000, p=3.0000, delta=0.1015731317167089\n",
      "2025-12-31 10:10:18,584 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=0.0775, p=1.8271, delta=0.1127256400650329\n",
      "2025-12-31 10:10:18,585 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=0.1705, p=2.5012, delta=0.0711015683143618\n",
      "2025-12-31 10:10:18,585 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=1.2914, p=2.5761, delta=0.0154206858613680\n",
      "2025-12-31 10:10:18,585 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=0.2543, p=1.6145, delta=0.0864116680865266\n",
      "2025-12-31 10:10:18,586 - INFO - Noise budget 30.455729920018445 iteration 1: alpha=1.2183, p=1.0828, delta=0.0163348407371401\n",
      "2025-12-31 10:10:18,586 - INFO - Early stopping at iteration 1 as delta_goal 0.0001 is reached with delta 0.0\n",
      "2025-12-31 10:10:18,586 - INFO - \u001b[94mIteration 3/50's delta_opt:\u001b[0m \u001b[92m0.000000e+00\u001b[0m, \u001b[92mError: 30.455730\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m1.000000e-04\u001b[0m\n",
      "2025-12-31 10:10:18,590 - INFO - \u001b[96mBinary search iteration 4/50:\u001b[0m c_lower=\u001b[93m20.303820\u001b[0m, c_upper=\u001b[93m30.455730\u001b[0m, c_mid=\u001b[1m25.379775\u001b[0m\n",
      "2025-12-31 10:10:37,150 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=1.3704, p=2.6684, delta=0.0298627403524035\n",
      "2025-12-31 10:10:37,151 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=0.9032, p=2.3253, delta=0.0171415428923202\n",
      "2025-12-31 10:10:37,151 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=0.5660, p=2.0255, delta=0.0345518731581915\n",
      "2025-12-31 10:10:37,152 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=1.9216, p=2.8843, delta=0.0523567870544581\n",
      "2025-12-31 10:10:37,152 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=1.5618, p=2.8661, delta=0.0406239751624719\n",
      "2025-12-31 10:10:37,152 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=1.9805, p=2.3503, delta=0.0364714239162789\n",
      "2025-12-31 10:10:37,153 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=1.7792, p=2.2265, delta=0.0276898220419448\n",
      "2025-12-31 10:10:37,153 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=0.5516, p=1.6470, delta=0.0487349393594684\n",
      "2025-12-31 10:10:37,153 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=0.2825, p=2.0241, delta=0.0732311276500504\n",
      "2025-12-31 10:10:37,154 - INFO - Noise budget 25.379774933348706 iteration 0: alpha=0.9053, p=2.8714, delta=0.0256141764658414\n",
      "2025-12-31 10:10:57,572 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=1.5472, p=1.1191, delta=0.0054641243054783\n",
      "2025-12-31 10:10:57,573 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=1.1799, p=1.2473, delta=0.0152675446414388\n",
      "2025-12-31 10:10:57,574 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=2.0000, p=1.0000, delta=0.0009489360591727\n",
      "2025-12-31 10:10:57,576 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=1.2292, p=1.8224, delta=0.0085644068743108\n",
      "2025-12-31 10:10:57,576 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=1.7516, p=1.0064, delta=0.0053733485587871\n",
      "2025-12-31 10:10:57,577 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=0.4570, p=2.9938, delta=0.0415230976462185\n",
      "2025-12-31 10:10:57,577 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=0.0000, p=3.0000, delta=0.1139714345360670\n",
      "2025-12-31 10:10:57,578 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=1.9275, p=1.5193, delta=0.0093416112384301\n",
      "2025-12-31 10:10:57,578 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=0.9494, p=1.7407, delta=0.0128218702524159\n",
      "2025-12-31 10:10:57,579 - INFO - Noise budget 25.379774933348706 iteration 1: alpha=0.9750, p=1.0021, delta=0.0644497743342765\n",
      "2025-12-31 10:11:17,611 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.5222, p=1.4534, delta=0.0039074059650198\n",
      "2025-12-31 10:11:17,612 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.9000, p=1.1915, delta=0.0020291180045079\n",
      "2025-12-31 10:11:17,613 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=0.0055, p=1.0033, delta=0.2625225404490877\n",
      "2025-12-31 10:11:17,613 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=0.1795, p=1.0000, delta=0.2129427546446503\n",
      "2025-12-31 10:11:17,614 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.3604, p=1.4329, delta=0.0040268424048182\n",
      "2025-12-31 10:11:17,615 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.4937, p=1.8743, delta=0.0123060857859707\n",
      "2025-12-31 10:11:17,615 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.6962, p=1.5941, delta=0.0083847454173405\n",
      "2025-12-31 10:11:17,616 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=0.0036, p=1.3371, delta=0.1972935451568741\n",
      "2025-12-31 10:11:17,616 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=0.1033, p=1.1908, delta=0.1919689406487349\n",
      "2025-12-31 10:11:17,616 - INFO - Noise budget 25.379774933348706 iteration 2: alpha=1.3663, p=1.0000, delta=0.0266149245905617\n",
      "2025-12-31 10:11:38,279 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=0.5466, p=2.6205, delta=0.0332539405225657\n",
      "2025-12-31 10:11:38,280 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=1.9952, p=1.8514, delta=0.0202457307387758\n",
      "2025-12-31 10:11:38,281 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=0.7403, p=2.5979, delta=0.0236647602512594\n",
      "2025-12-31 10:11:38,281 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=0.5764, p=2.4571, delta=0.0308375564337890\n",
      "2025-12-31 10:11:38,282 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=1.9876, p=2.0234, delta=0.0257150192779694\n",
      "2025-12-31 10:11:38,282 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=1.2408, p=1.6186, delta=0.0061057502599202\n",
      "2025-12-31 10:11:38,283 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=1.0222, p=1.4841, delta=0.0136995869667102\n",
      "2025-12-31 10:11:38,283 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=0.3112, p=2.5421, delta=0.0580520893633235\n",
      "2025-12-31 10:11:38,284 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=1.9982, p=1.1775, delta=0.0023792171796375\n",
      "2025-12-31 10:11:38,284 - INFO - Noise budget 25.379774933348706 iteration 3: alpha=0.4197, p=2.6669, delta=0.0442211388407922\n",
      "2025-12-31 10:11:59,618 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.2686, p=2.1915, delta=0.0161261709043162\n",
      "2025-12-31 10:11:59,619 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.6928, p=1.2748, delta=0.0021186808574904\n",
      "2025-12-31 10:11:59,621 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.2110, p=2.9989, delta=0.0335126392325714\n",
      "2025-12-31 10:11:59,621 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.0856, p=2.0629, delta=0.0122334130804390\n",
      "2025-12-31 10:11:59,624 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.4011, p=2.9988, delta=0.0391959374115576\n",
      "2025-12-31 10:11:59,625 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.9003, p=2.9996, delta=0.0553154799165397\n",
      "2025-12-31 10:11:59,625 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.3480, p=2.4096, delta=0.0227685599892427\n",
      "2025-12-31 10:11:59,626 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.9903, p=1.3353, delta=0.0054731954602372\n",
      "2025-12-31 10:11:59,627 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.3352, p=2.0448, delta=0.0138250100301193\n",
      "2025-12-31 10:11:59,628 - INFO - Noise budget 25.379774933348706 iteration 4: alpha=1.0201, p=1.9376, delta=0.0112494934540154\n",
      "2025-12-31 10:12:22,798 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.7245, p=1.1482, delta=0.0011757397015855\n",
      "2025-12-31 10:12:22,799 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.8963, p=1.0776, delta=0.0007521895645282\n",
      "2025-12-31 10:12:22,800 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.5817, p=1.2675, delta=0.0019997857185498\n",
      "2025-12-31 10:12:22,800 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.9982, p=1.0297, delta=0.0007364817536728\n",
      "2025-12-31 10:12:22,801 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.6460, p=1.2171, delta=0.0015729565219648\n",
      "2025-12-31 10:12:22,801 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.7061, p=1.3566, delta=0.0034603218094018\n",
      "2025-12-31 10:12:22,801 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.9957, p=1.0264, delta=0.0007368588296373\n",
      "2025-12-31 10:12:22,802 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.4788, p=1.3054, delta=0.0027882573641587\n",
      "2025-12-31 10:12:22,802 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.8386, p=1.0045, delta=0.0030952129175116\n",
      "2025-12-31 10:12:22,803 - INFO - Noise budget 25.379774933348706 iteration 5: alpha=1.4170, p=1.5903, delta=0.0055643751493286\n",
      "2025-12-31 10:12:22,804 - INFO - \u001b[94mIteration 4/50's delta_opt:\u001b[0m \u001b[92m7.364818e-04\u001b[0m, \u001b[92mError: 25.379775\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m6.364818e-04\u001b[0m\n",
      "2025-12-31 10:12:22,804 - INFO - \u001b[96mBinary search iteration 5/50:\u001b[0m c_lower=\u001b[93m25.379775\u001b[0m, c_upper=\u001b[93m30.455730\u001b[0m, c_mid=\u001b[1m27.917752\u001b[0m\n",
      "2025-12-31 10:12:41,290 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.3707, p=2.8383, delta=0.0272766385892239\n",
      "2025-12-31 10:12:41,291 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.6217, p=2.4378, delta=0.0234731472236579\n",
      "2025-12-31 10:12:41,292 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.8174, p=2.9230, delta=0.0414125106363135\n",
      "2025-12-31 10:12:41,292 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.7181, p=2.8622, delta=0.0369814127374265\n",
      "2025-12-31 10:12:41,292 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.8848, p=1.6391, delta=0.0078197527838107\n",
      "2025-12-31 10:12:41,293 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.0817, p=2.2886, delta=0.0117301182807741\n",
      "2025-12-31 10:12:41,293 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=0.7155, p=1.7514, delta=0.0228213001946732\n",
      "2025-12-31 10:12:41,293 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=1.3626, p=2.2063, delta=0.0132873239006165\n",
      "2025-12-31 10:12:41,294 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=0.8671, p=2.0708, delta=0.0120769701997727\n",
      "2025-12-31 10:12:41,294 - INFO - Noise budget 27.917752426683577 iteration 0: alpha=0.4224, p=1.3470, delta=0.0853345781768110\n",
      "2025-12-31 10:13:01,135 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=0.0000, p=2.7102, delta=0.1108138666997503\n",
      "2025-12-31 10:13:01,136 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=0.0000, p=3.0000, delta=0.1072059775969512\n",
      "2025-12-31 10:13:01,136 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=2.0000, p=1.8389, delta=0.0143057507869141\n",
      "2025-12-31 10:13:01,137 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=2.0000, p=1.0000, delta=0.0000000000000000\n",
      "2025-12-31 10:13:01,137 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=0.0000, p=2.2496, delta=0.1214530322058842\n",
      "2025-12-31 10:13:01,138 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=1.3405, p=1.4154, delta=0.0024103123317853\n",
      "2025-12-31 10:13:01,138 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=0.5172, p=3.0000, delta=0.0320688528499210\n",
      "2025-12-31 10:13:01,138 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=0.4310, p=2.4885, delta=0.0386086079274977\n",
      "2025-12-31 10:13:01,139 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=1.3914, p=1.7295, delta=0.0048424585301211\n",
      "2025-12-31 10:13:01,139 - INFO - Noise budget 27.917752426683577 iteration 1: alpha=1.5922, p=1.0000, delta=0.0075355179881550\n",
      "2025-12-31 10:13:01,139 - INFO - Early stopping at iteration 1 as delta_goal 0.0001 is reached with delta 0.0\n",
      "2025-12-31 10:13:01,140 - INFO - \u001b[94mIteration 5/50's delta_opt:\u001b[0m \u001b[92m0.000000e+00\u001b[0m, \u001b[92mError: 27.917752\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m1.000000e-04\u001b[0m\n",
      "2025-12-31 10:13:01,143 - INFO - \u001b[96mBinary search iteration 6/50:\u001b[0m c_lower=\u001b[93m25.379775\u001b[0m, c_upper=\u001b[93m27.917752\u001b[0m, c_mid=\u001b[1m26.648764\u001b[0m\n",
      "2025-12-31 10:13:19,804 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.2956, p=2.3397, delta=0.0600196896355376\n",
      "2025-12-31 10:13:19,804 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.1879, p=1.7766, delta=0.1002362396766789\n",
      "2025-12-31 10:13:19,805 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.2729, p=1.2205, delta=0.1376027096101969\n",
      "2025-12-31 10:13:19,805 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=1.8888, p=2.0154, delta=0.0201638678614431\n",
      "2025-12-31 10:13:19,805 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.1760, p=2.6712, delta=0.0756607468102383\n",
      "2025-12-31 10:13:19,806 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.8130, p=1.6049, delta=0.0213175664599876\n",
      "2025-12-31 10:13:19,806 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.3068, p=2.8362, delta=0.0541036297491114\n",
      "2025-12-31 10:13:19,807 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=1.8030, p=2.2341, delta=0.0248752075806689\n",
      "2025-12-31 10:13:19,807 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=1.4323, p=2.4006, delta=0.0213232927010007\n",
      "2025-12-31 10:13:19,807 - INFO - Noise budget 26.648763680016142 iteration 0: alpha=0.6654, p=1.8467, delta=0.0266482005204823\n",
      "2025-12-31 10:13:39,344 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=0.9401, p=2.3157, delta=0.0143715760619282\n",
      "2025-12-31 10:13:39,346 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.6061, p=1.0000, delta=0.0090079175703979\n",
      "2025-12-31 10:13:39,347 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.3003, p=1.6391, delta=0.0046019303907383\n",
      "2025-12-31 10:13:39,347 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=2.0000, p=1.0000, delta=0.0000424797641455\n",
      "2025-12-31 10:13:39,348 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=2.0000, p=3.0000, delta=0.0533796257509794\n",
      "2025-12-31 10:13:39,348 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.2687, p=3.0000, delta=0.0315236476271162\n",
      "2025-12-31 10:13:39,348 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.1734, p=2.2948, delta=0.0145021346133331\n",
      "2025-12-31 10:13:39,349 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.8206, p=2.4331, delta=0.0311348703280523\n",
      "2025-12-31 10:13:39,349 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.6493, p=3.0000, delta=0.0426625839588562\n",
      "2025-12-31 10:13:39,350 - INFO - Noise budget 26.648763680016142 iteration 1: alpha=1.5825, p=1.9758, delta=0.0137588695635574\n",
      "2025-12-31 10:13:39,350 - INFO - Early stopping at iteration 1 as delta_goal 0.0001 is reached with delta 4.2479764145495284e-05\n",
      "2025-12-31 10:13:39,351 - INFO - \u001b[94mIteration 6/50's delta_opt:\u001b[0m \u001b[92m4.247976e-05\u001b[0m, \u001b[92mError: 26.648764\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m5.752024e-05\u001b[0m\n",
      "2025-12-31 10:13:39,354 - INFO - \u001b[96mBinary search iteration 7/50:\u001b[0m c_lower=\u001b[93m25.379775\u001b[0m, c_upper=\u001b[93m26.648764\u001b[0m, c_mid=\u001b[1m26.014269\u001b[0m\n",
      "2025-12-31 10:13:57,994 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.8883, p=2.9141, delta=0.0496463904712257\n",
      "2025-12-31 10:13:57,999 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.7604, p=2.1207, delta=0.0223260440543829\n",
      "2025-12-31 10:13:57,999 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.9797, p=1.9779, delta=0.0224072902021771\n",
      "2025-12-31 10:13:58,000 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=0.5872, p=2.0906, delta=0.0304651072047671\n",
      "2025-12-31 10:13:58,001 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.0974, p=1.5139, delta=0.0087839738746575\n",
      "2025-12-31 10:13:58,001 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=0.6898, p=2.0448, delta=0.0230876474281323\n",
      "2025-12-31 10:13:58,001 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.7494, p=2.4369, delta=0.0313646201990239\n",
      "2025-12-31 10:13:58,002 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=0.3015, p=2.4938, delta=0.0584218321812866\n",
      "2025-12-31 10:13:58,002 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=1.7062, p=2.5937, delta=0.0348773311512340\n",
      "2025-12-31 10:13:58,002 - INFO - Noise budget 26.014269306682422 iteration 0: alpha=0.9563, p=1.8080, delta=0.0113988226663399\n",
      "2025-12-31 10:14:17,865 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=1.9122, p=1.0000, delta=0.0010953862993682\n",
      "2025-12-31 10:14:17,866 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=0.7808, p=1.0000, delta=0.0880468632013436\n",
      "2025-12-31 10:14:17,866 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=1.4753, p=1.0000, delta=0.0172987418038841\n",
      "2025-12-31 10:14:17,866 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=0.0000, p=1.0000, delta=0.2615162774471999\n",
      "2025-12-31 10:14:17,867 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=0.3528, p=1.0000, delta=0.1668493498454581\n",
      "2025-12-31 10:14:17,867 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=0.0043, p=1.4005, delta=0.1854202305856155\n",
      "2025-12-31 10:14:17,867 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=1.9864, p=1.3478, delta=0.0048285396926591\n",
      "2025-12-31 10:14:17,868 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=0.5754, p=1.3591, delta=0.0654210559457814\n",
      "2025-12-31 10:14:17,868 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=1.4488, p=1.2745, delta=0.0028654839115245\n",
      "2025-12-31 10:14:17,868 - INFO - Noise budget 26.014269306682422 iteration 1: alpha=1.0837, p=1.1023, delta=0.0346648125808362\n",
      "2025-12-31 10:14:38,375 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=0.8607, p=3.0000, delta=0.0260959043931844\n",
      "2025-12-31 10:14:38,376 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=0.9479, p=2.6475, delta=0.0203951365593553\n",
      "2025-12-31 10:14:38,376 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=1.1125, p=2.9978, delta=0.0292480707097614\n",
      "2025-12-31 10:14:38,376 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=1.5115, p=1.6082, delta=0.0057341124955561\n",
      "2025-12-31 10:14:38,377 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=1.1660, p=2.2957, delta=0.0156227557327210\n",
      "2025-12-31 10:14:38,377 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=0.0162, p=2.9927, delta=0.1081600725472862\n",
      "2025-12-31 10:14:38,377 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=0.3188, p=3.0000, delta=0.0538522832876593\n",
      "2025-12-31 10:14:38,378 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=2.0000, p=1.0000, delta=0.0003441922798438\n",
      "2025-12-31 10:14:38,378 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=1.1777, p=2.6259, delta=0.0226404928110612\n",
      "2025-12-31 10:14:38,378 - INFO - Noise budget 26.014269306682422 iteration 2: alpha=1.7341, p=1.2799, delta=0.0018554314277062\n",
      "2025-12-31 10:14:59,356 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.9969, p=1.1522, delta=0.0014238297910398\n",
      "2025-12-31 10:14:59,358 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.2954, p=1.8786, delta=0.0088854964530925\n",
      "2025-12-31 10:14:59,360 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.9957, p=1.0010, delta=0.0003487622295924\n",
      "2025-12-31 10:14:59,360 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.3362, p=1.5858, delta=0.0046139120831437\n",
      "2025-12-31 10:14:59,361 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.7837, p=1.1592, delta=0.0007250083857726\n",
      "2025-12-31 10:14:59,362 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.9994, p=2.5110, delta=0.0400525888718057\n",
      "2025-12-31 10:14:59,362 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.9985, p=2.3128, delta=0.0335208420853844\n",
      "2025-12-31 10:14:59,363 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=1.1044, p=2.0203, delta=0.0105054586463031\n",
      "2025-12-31 10:14:59,363 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=0.8198, p=2.3060, delta=0.0175028976511951\n",
      "2025-12-31 10:14:59,363 - INFO - Noise budget 26.014269306682422 iteration 3: alpha=0.9374, p=2.1709, delta=0.0137827098161509\n",
      "2025-12-31 10:15:21,111 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.8281, p=1.6415, delta=0.0101651719321900\n",
      "2025-12-31 10:15:21,112 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.6879, p=1.4265, delta=0.0039039445516673\n",
      "2025-12-31 10:15:21,113 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.9979, p=1.4613, delta=0.0075709707773290\n",
      "2025-12-31 10:15:21,113 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.9939, p=1.2177, delta=0.0023851949189435\n",
      "2025-12-31 10:15:21,114 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.7321, p=1.4049, delta=0.0038368875875576\n",
      "2025-12-31 10:15:21,115 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.9990, p=1.0029, delta=0.0003220198995511\n",
      "2025-12-31 10:15:21,115 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.7833, p=1.0100, delta=0.0031863326684559\n",
      "2025-12-31 10:15:21,116 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.8184, p=1.1968, delta=0.0011901705781477\n",
      "2025-12-31 10:15:21,117 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.9934, p=1.5373, delta=0.0094858730976545\n",
      "2025-12-31 10:15:21,117 - INFO - Noise budget 26.014269306682422 iteration 4: alpha=1.7528, p=1.5659, delta=0.0073591254936314\n",
      "2025-12-31 10:15:45,433 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.3873, p=1.3226, delta=0.0034706668875228\n",
      "2025-12-31 10:15:45,434 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=0.6176, p=2.7329, delta=0.0282951087524953\n",
      "2025-12-31 10:15:45,434 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.4716, p=2.9970, delta=0.0393610083429354\n",
      "2025-12-31 10:15:45,435 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=0.6041, p=2.9974, delta=0.0311234406195257\n",
      "2025-12-31 10:15:45,435 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.3678, p=2.9956, delta=0.0360635153212620\n",
      "2025-12-31 10:15:45,435 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.4369, p=2.4129, delta=0.0233500749544858\n",
      "2025-12-31 10:15:45,436 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.4202, p=2.7419, delta=0.0312064517235204\n",
      "2025-12-31 10:15:45,436 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=0.5224, p=2.8220, delta=0.0343667784650378\n",
      "2025-12-31 10:15:45,436 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.5132, p=2.1147, delta=0.0173209454141312\n",
      "2025-12-31 10:15:45,437 - INFO - Noise budget 26.014269306682422 iteration 5: alpha=1.2548, p=1.3244, delta=0.0070839485430259\n",
      "2025-12-31 10:15:45,437 - INFO - \u001b[94mIteration 7/50's delta_opt:\u001b[0m \u001b[92m3.220199e-04\u001b[0m, \u001b[92mError: 26.014269\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m2.220199e-04\u001b[0m\n",
      "2025-12-31 10:15:45,438 - INFO - \u001b[96mBinary search iteration 8/50:\u001b[0m c_lower=\u001b[93m26.014269\u001b[0m, c_upper=\u001b[93m26.648764\u001b[0m, c_mid=\u001b[1m26.331516\u001b[0m\n",
      "2025-12-31 10:16:04,080 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.7127, p=2.0720, delta=0.0192492405020248\n",
      "2025-12-31 10:16:04,081 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=0.0604, p=2.9159, delta=0.0975885681648623\n",
      "2025-12-31 10:16:04,082 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.3032, p=2.4140, delta=0.0197768195005858\n",
      "2025-12-31 10:16:04,082 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.1306, p=1.6958, delta=0.0067453429777004\n",
      "2025-12-31 10:16:04,082 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.0329, p=2.5402, delta=0.0183831368143199\n",
      "2025-12-31 10:16:04,083 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.1356, p=1.6920, delta=0.0066522888401143\n",
      "2025-12-31 10:16:04,083 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=0.6514, p=1.4376, delta=0.0471072990964929\n",
      "2025-12-31 10:16:04,083 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=0.0603, p=2.7699, delta=0.0992230151136410\n",
      "2025-12-31 10:16:04,084 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=0.5106, p=1.5141, delta=0.0605333055222217\n",
      "2025-12-31 10:16:04,084 - INFO - Noise budget 26.331516493349284 iteration 0: alpha=1.8288, p=2.1557, delta=0.0239192165711857\n",
      "2025-12-31 10:16:23,847 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.4740, p=1.0000, delta=0.0165559395833527\n",
      "2025-12-31 10:16:23,848 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.1820, p=1.0000, delta=0.0387167903915237\n",
      "2025-12-31 10:16:23,848 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=2.0000, p=1.0000, delta=0.0001562569699509\n",
      "2025-12-31 10:16:23,849 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.7726, p=1.0000, delta=0.0035954064774804\n",
      "2025-12-31 10:16:23,849 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.4858, p=1.1523, delta=0.0047288042608109\n",
      "2025-12-31 10:16:23,849 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.9901, p=2.9986, delta=0.0543286743126089\n",
      "2025-12-31 10:16:23,850 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.6963, p=3.0000, delta=0.0452532863603898\n",
      "2025-12-31 10:16:23,850 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.2324, p=3.0000, delta=0.0314104407041111\n",
      "2025-12-31 10:16:23,850 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=1.6530, p=1.0762, delta=0.0030519849024930\n",
      "2025-12-31 10:16:23,850 - INFO - Noise budget 26.331516493349284 iteration 1: alpha=0.3793, p=1.2467, delta=0.1122346688512891\n",
      "2025-12-31 10:16:43,888 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=2.0000, p=1.3851, delta=0.0053408254172501\n",
      "2025-12-31 10:16:43,898 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=1.6487, p=1.4366, delta=0.0034516082928277\n",
      "2025-12-31 10:16:43,898 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=0.8775, p=2.1103, delta=0.0140010656378593\n",
      "2025-12-31 10:16:43,898 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=1.9968, p=1.7536, delta=0.0149927352446649\n",
      "2025-12-31 10:16:43,899 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=1.1033, p=2.0485, delta=0.0104730108501528\n",
      "2025-12-31 10:16:43,899 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=0.6862, p=2.9861, delta=0.0274660539217426\n",
      "2025-12-31 10:16:43,899 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=0.6372, p=2.5340, delta=0.0255120243500494\n",
      "2025-12-31 10:16:43,900 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=1.4137, p=1.7081, delta=0.0063371512615847\n",
      "2025-12-31 10:16:43,900 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=0.6431, p=2.1833, delta=0.0248907196118417\n",
      "2025-12-31 10:16:43,900 - INFO - Noise budget 26.331516493349284 iteration 2: alpha=0.5040, p=2.9963, delta=0.0359741924924687\n",
      "2025-12-31 10:17:13,110 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.2851, p=1.4244, delta=0.0042756704608436\n",
      "2025-12-31 10:17:13,112 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.9997, p=1.1476, delta=0.0011609905738969\n",
      "2025-12-31 10:17:13,113 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.9908, p=2.5909, delta=0.0412729444359773\n",
      "2025-12-31 10:17:13,113 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.6882, p=2.6577, delta=0.0352637334628309\n",
      "2025-12-31 10:17:13,114 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.9500, p=2.7301, delta=0.0445869658196419\n",
      "2025-12-31 10:17:13,115 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=1.3502, p=2.7649, delta=0.0291056571474473\n",
      "2025-12-31 10:17:13,115 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=0.9321, p=2.7785, delta=0.0218732186272912\n",
      "2025-12-31 10:17:13,116 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=0.0054, p=1.9766, delta=0.1358322982698933\n",
      "2025-12-31 10:17:13,116 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=0.4360, p=1.9377, delta=0.0497261119572114\n",
      "2025-12-31 10:17:13,117 - INFO - Noise budget 26.331516493349284 iteration 3: alpha=0.0000, p=2.1078, delta=0.1312657401959881\n",
      "2025-12-31 10:17:40,941 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=1.8005, p=1.2417, delta=0.0014634252588979\n",
      "2025-12-31 10:17:40,942 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=0.0078, p=1.0062, delta=0.2556688267395770\n",
      "2025-12-31 10:17:40,943 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=0.8397, p=1.7748, delta=0.0163041473064565\n",
      "2025-12-31 10:17:40,943 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=0.9633, p=1.5091, delta=0.0148334242568534\n",
      "2025-12-31 10:17:40,944 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=1.3764, p=2.0248, delta=0.0122046566111086\n",
      "2025-12-31 10:17:40,945 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=1.7818, p=1.6403, delta=0.0089642979741352\n",
      "2025-12-31 10:17:40,946 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=1.1014, p=1.3804, delta=0.0116051648528424\n",
      "2025-12-31 10:17:40,947 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=1.6228, p=1.7670, delta=0.0099204826323742\n",
      "2025-12-31 10:17:40,948 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=0.0016, p=1.1803, delta=0.2190671299690068\n",
      "2025-12-31 10:17:40,948 - INFO - Noise budget 26.331516493349284 iteration 4: alpha=0.7076, p=1.8208, delta=0.0242639057186491\n",
      "2025-12-31 10:18:08,519 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.4998, p=1.3643, delta=0.0020646871432966\n",
      "2025-12-31 10:18:08,523 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.9621, p=1.0021, delta=0.0002959557120692\n",
      "2025-12-31 10:18:08,523 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.6823, p=1.2595, delta=0.0012195109591433\n",
      "2025-12-31 10:18:08,524 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.8279, p=1.1661, delta=0.0007265774045329\n",
      "2025-12-31 10:18:08,524 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.9716, p=1.1621, delta=0.0012268614520710\n",
      "2025-12-31 10:18:08,525 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.4386, p=1.4231, delta=0.0026143772397833\n",
      "2025-12-31 10:18:08,525 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.9968, p=1.0021, delta=0.0001498733986757\n",
      "2025-12-31 10:18:08,525 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.5771, p=1.2466, delta=0.0013285471339596\n",
      "2025-12-31 10:18:08,526 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.8752, p=1.0304, delta=0.0005192964364818\n",
      "2025-12-31 10:18:08,526 - INFO - Noise budget 26.331516493349284 iteration 5: alpha=1.4420, p=1.5260, delta=0.0036578928500461\n",
      "2025-12-31 10:18:08,527 - INFO - \u001b[94mIteration 8/50's delta_opt:\u001b[0m \u001b[92m1.498734e-04\u001b[0m, \u001b[92mError: 26.331516\u001b[0m, \u001b[95mtarget delta:\u001b[0m \u001b[92m1.000000e-04\u001b[0m, \u001b[91mdifference:\u001b[0m \u001b[1m4.987340e-05\u001b[0m\n",
      "2025-12-31 10:18:08,527 - INFO - \u001b[91mFinal result: error=26.331516, alpha=2.000000, p=1.000000, beta=0.671046, delta=4.247976e-05\u001b[0m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "alpha_opt: 2.0, p_opt: 1.0, beta_opt: 0.671045688356926, delta_opt: 4.2479764145495284e-05\n"
     ]
    }
   ],
   "source": [
    "T = 3\n",
    "epsilon = 2\n",
    "delta = 1e-4\n",
    "database_sensitivity = 3\n",
    "error_metric = 'second_moment'\n",
    "prec = 50\n",
    "\n",
    "opt_params = gen_optimizer_params(T)\n",
    "alpha_opt, p_opt, beta_opt, delta_opt = compute_empirical_optimal_generalized_gamma_parameters_under_privacy_constraint(T=T, epsilon=epsilon, delta=delta, database_sensitivity=database_sensitivity, error_metric=error_metric, prec=prec, opt_params=opt_params, logger=logger)\n",
    "print(f\"alpha_opt: {alpha_opt}, p_opt: {p_opt}, beta_opt: {beta_opt}, delta_opt: {delta_opt}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gaussian_error: 139.17612394691452, generalized_gamma_error: 139.17612394687745\n"
     ]
    }
   ],
   "source": [
    "from scipy.optimize import root_scalar\n",
    "from OAEGN_analysis.spherical_generalized_gamma import privacy_gaussian_mechanis_via_analytic_formula\n",
    "from OAEGN_analysis.radial_rv import generalized_gamma_moments\n",
    "\n",
    "epsilon = 1\n",
    "delta = 1e-5\n",
    "\n",
    "result = root_scalar(lambda sigma: privacy_gaussian_mechanis_via_analytic_formula(sigma, epsilon)-delta, bracket=[1e-6, 1e6], method='bisect', xtol=1e-12)\n",
    "sigma = result.root if result.converged else None\n",
    "\n",
    "gaussian_error = T*(sigma**2)\n",
    "\n",
    "generalized_gamma_error = generalized_gamma_moments(alpha_opt, beta_opt, p_opt, moment=2)\n",
    "print(f\"gaussian_error: {gaussian_error}, generalized_gamma_error: {generalized_gamma_error}\")"
   ]
  }
 ],
 "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
}
