Add a function to compute RDP under heterogeneous applications of the subsampled Gaussian mechanism.

PiperOrigin-RevId: 335706732
This commit is contained in:
Peter Kairouz 2020-10-06 13:20:05 -07:00 committed by A. Unique TensorFlower
parent ab1090717c
commit e19c53a78c
2 changed files with 36 additions and 0 deletions

View file

@ -264,6 +264,32 @@ def compute_rdp(q, noise_multiplier, steps, orders):
return rdp * steps 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): def get_privacy_spent(orders, rdp, target_eps=None, target_delta=None):
"""Compute delta (or eps) for given eps (or delta) from RDP values. """Compute delta (or eps) for given eps (or delta) from RDP values.

View file

@ -79,6 +79,16 @@ class TestGaussianMoments(parameterized.TestCase):
return a_alpha return a_alpha
# TEST ROUTINES # 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): def test_compute_rdp_no_data(self):
# q = 0 # q = 0
self.assertEqual(rdp_accountant.compute_rdp(0, 10, 1, 20), 0) self.assertEqual(rdp_accountant.compute_rdp(0, 10, 1, 20), 0)