From 369249ce69e5216a89072e6d3588bbfc245e7933 Mon Sep 17 00:00:00 2001 From: Akemi Izuko Date: Tue, 3 Dec 2024 23:26:50 -0700 Subject: [PATCH] O1: add epsilon audit --- one_run_audit/audit.py | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/one_run_audit/audit.py b/one_run_audit/audit.py index 32d935d..48012f3 100644 --- a/one_run_audit/audit.py +++ b/one_run_audit/audit.py @@ -17,6 +17,7 @@ import opacus from opacus.validators import ModuleValidator from opacus.utils.batch_memory_manager import BatchMemoryManager from WideResNet import WideResNet +from equations import get_eps_audit import warnings warnings.filterwarnings("ignore") @@ -225,9 +226,10 @@ def main(): "delta": 1e-5, "norm": args.norm, "batch_size": 4096, - "epochs": 2, + "epochs": 100, "k+": 300, "k-": 300, + "p_value": 0.05, } hp['logfile'] = Path('WideResNet_{}_{}_{}_{}s_x{}_{}e_{}d_{}C.txt'.format( @@ -277,7 +279,17 @@ def main(): correct = np.sum(~scores[:hp['k-']]) + np.sum(scores[-hp['k+']:]) total = len(scores) + + eps_lb = get_eps_audit( + hp['target_points'], + hp['k+'] + hp['k-'], + correct, + hp['delta'], + hp['p_value'] + ) + print(f"Audit total: {correct}/{total} = {round(correct/total*100, 2)}") + print(f"p[ε < {eps_lb}] < {hp['p_value']}") correct, total = evaluate_on(model_init, train_dl) print(f"Init model accuracy: {correct}/{total} = {round(correct/total*100, 2)}")