Add a function to compute RDP under heterogeneous applications of the subsampled Gaussian mechanism.
PiperOrigin-RevId: 335706732
This commit is contained in:
parent
ab1090717c
commit
e19c53a78c
2 changed files with 36 additions and 0 deletions
|
@ -264,6 +264,32 @@ def compute_rdp(q, noise_multiplier, steps, orders):
|
|||
return rdp * steps
|
||||
|
||||
|
||||
def compute_heterogenous_rdp(sampling_probabilities, noise_multipliers,
|
||||
steps_list, orders):
|
||||
"""Compute RDP of Heteregoneous Applications of Sampled Gaussian Mechanisms.
|
||||
|
||||
Args:
|
||||
sampling_probabilities: A list containing the sampling rates.
|
||||
noise_multipliers: A list containing the noise multipliers: the ratio of the
|
||||
standard deviation of the Gaussian noise to the l2-sensitivity of the
|
||||
function to which it is added.
|
||||
steps_list: A list containing the number of steps at each
|
||||
`sampling_probability` and `noise_multiplier`.
|
||||
orders: An array (or a scalar) of RDP orders.
|
||||
|
||||
Returns:
|
||||
The RDPs at all orders, can be np.inf.
|
||||
"""
|
||||
assert len(sampling_probabilities) == len(noise_multipliers)
|
||||
|
||||
rdp = 0
|
||||
for q, noise_multiplier, steps in zip(sampling_probabilities,
|
||||
noise_multipliers, steps_list):
|
||||
rdp += compute_rdp(q, noise_multiplier, steps, orders)
|
||||
|
||||
return rdp
|
||||
|
||||
|
||||
def get_privacy_spent(orders, rdp, target_eps=None, target_delta=None):
|
||||
"""Compute delta (or eps) for given eps (or delta) from RDP values.
|
||||
|
||||
|
|
|
@ -79,6 +79,16 @@ class TestGaussianMoments(parameterized.TestCase):
|
|||
return a_alpha
|
||||
|
||||
# TEST ROUTINES
|
||||
def test_compute_heterogeneous_rdp_different_sampling_probabilities(self):
|
||||
sampling_probabilities = [0, 1]
|
||||
noise_multipliers = [10, 10]
|
||||
steps_list = [1, 1]
|
||||
orders = 20
|
||||
self.assertEqual(
|
||||
rdp_accountant.compute_heterogenous_rdp(sampling_probabilities,
|
||||
noise_multipliers, steps_list,
|
||||
orders), 0.1)
|
||||
|
||||
def test_compute_rdp_no_data(self):
|
||||
# q = 0
|
||||
self.assertEqual(rdp_accountant.compute_rdp(0, 10, 1, 20), 0)
|
||||
|
|
Loading…
Reference in a new issue