forked from mlcommons/GaNDLF
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into dynunet_set_automaticaly_strides_kernels
- Loading branch information
Showing
14 changed files
with
521 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -115,7 +115,7 @@ jobs: | |
flags: unittests | ||
|
||
- name: Upload coverage to Codacy | ||
if: steps.changed-files-specific.outputs.only_modified == 'false' # Run on any non-docs change | ||
if: github.ref == 'refs/heads/master' # only run when on master | ||
uses: codacy/[email protected] | ||
with: | ||
project-token: ${{ secrets.CODACY_PROJECT_TOKEN }} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
from .config_parsing import parse_opacus_params | ||
from .model_handling import opacus_model_fix, prep_for_opacus_training | ||
from .training_utils import handle_dynamic_batch_size |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
from typing import Callable | ||
|
||
|
||
def parse_opacus_params(params: dict, initialize_key: Callable) -> dict: | ||
""" | ||
Function to set defaults and augment the parameters related to making a trained model differentially | ||
private with respect to the training data. | ||
Args: | ||
params (dict): Training parameters. | ||
initialize_key (Callable): Function to fill in value for a missing key. | ||
Returns: | ||
dict: Updated training parameters. | ||
""" | ||
|
||
if not isinstance(params["differential_privacy"], dict): | ||
print( | ||
"WARNING: Non dictionary value for the key: 'differential_privacy' was used, replacing with default valued dictionary." | ||
) | ||
params["differential_privacy"] = {} | ||
# these are some defaults | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "noise_multiplier", 10.0 | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "max_grad_norm", 1.0 | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "accountant", "rdp" | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "secure_mode", False | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "allow_opacus_model_fix", True | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "delta", 1e-5 | ||
) | ||
params["differential_privacy"] = initialize_key( | ||
params["differential_privacy"], "physical_batch_size", params["batch_size"] | ||
) | ||
|
||
if params["differential_privacy"]["physical_batch_size"] > params["batch_size"]: | ||
print( | ||
f"WARNING: The physical batch size {params['differential_privacy']['physical_batch_size']} is greater" | ||
f"than the batch size {params['batch_size']}, setting the physical batch size to the batch size." | ||
) | ||
params["differential_privacy"]["physical_batch_size"] = params["batch_size"] | ||
|
||
# these keys need to be parsed as floats, not strings | ||
for key in ["noise_multiplier", "max_grad_norm", "delta", "epsilon"]: | ||
if key in params["differential_privacy"]: | ||
params["differential_privacy"][key] = float( | ||
params["differential_privacy"][key] | ||
) | ||
|
||
return params |
Oops, something went wrong.