Zheng Xu
0a0f377f3f
Adaptive clipping in DP-FTRL with restart.
...
PiperOrigin-RevId: 513934548
2023-03-06 07:16:57 -08:00
A. Unique TensorFlower
8bfafdd74d
Efficient DPSGD with support to microbatched losses.
...
PiperOrigin-RevId: 513886957
2023-03-06 07:01:03 -08:00
Walid Krichene
cbf34f2b04
Update type annotations of gradient clipping library.
...
PiperOrigin-RevId: 513640655
2023-03-02 14:29:17 -08:00
A. Unique TensorFlower
7436930c64
Improve documentation and logging of fast gradient clipping modules and callers.
...
PiperOrigin-RevId: 513283486
2023-03-01 10:56:01 -08:00
Andres Munoz MEdina
d7cd3f8af1
Add an announcement on the public README about the new fast implementation of DP-SGD.
...
PiperOrigin-RevId: 512930920
2023-02-28 07:45:47 -08:00
Shuang Song
a3e8a45559
Passes number of microbatches to DP model.
...
PiperOrigin-RevId: 512678620
2023-02-27 11:11:59 -08:00
Shuang Song
4a418e8862
Adds __init__.py for fast_gradient_clipping.
...
PiperOrigin-RevId: 512236191
2023-02-24 21:32:07 -08:00
A. Unique TensorFlower
dda7fa8b39
Add a tf.GradientTape
argument to the layer registry functions
...
PiperOrigin-RevId: 512160655
2023-02-24 14:14:36 -08:00
Shuang Song
4dd8d0ffde
Catches when data is not sufficient for StratifiedKFold split.
...
PiperOrigin-RevId: 510197242
2023-02-16 11:24:12 -08:00
Shuang Song
0c691d0b4d
Returns None for getting max results when results are empty.
...
PiperOrigin-RevId: 510054673
2023-02-15 23:37:43 -08:00
A. Unique TensorFlower
13534e5159
Add better tests for clip_grads.py
...
PiperOrigin-RevId: 509529435
2023-02-14 08:01:56 -08:00
A. Unique TensorFlower
430f103354
Generalize the registry function for the embedding layer for other models.
...
PiperOrigin-RevId: 509528743
2023-02-14 07:59:10 -08:00
A. Unique TensorFlower
410814ec39
Generalize the internal API to allow for more general models + layers.
...
PiperOrigin-RevId: 509518753
2023-02-14 07:10:40 -08:00
Shuang Song
6ee988885a
Fix a bug in get_flattened_attack_metrics that types, slices, metrics do not
...
correspond to values because of PPV.
PiperOrigin-RevId: 509274994
2023-02-13 10:53:29 -08:00
A. Unique TensorFlower
9ed34da715
Integrate the fast gradient clipping algorithm with the DP Keras Model class.
...
PiperOrigin-RevId: 504931452
2023-01-26 13:45:56 -08:00
A. Unique TensorFlower
bc84ed7bfb
Add fast gradient clipping tests.
...
PiperOrigin-RevId: 504923799
2023-01-26 13:16:19 -08:00
A. Unique TensorFlower
a3b14ae20a
First implementation of the fast gradient clipping algorithm.
...
PiperOrigin-RevId: 504668189
2023-01-25 14:51:09 -08:00
Steve Chien
ee3d349a8d
Fix copybara removal of tkinter library.
...
PiperOrigin-RevId: 504656239
2023-01-25 14:06:27 -08:00
Yilei Yang
622282e034
Update dependency on tkinter.
...
PiperOrigin-RevId: 503401013
2023-01-20 03:24:46 -08:00
Thomas Steinke
10c086c46a
Implementation of differentially private second order methods ("Newton's method") for research project.
...
PiperOrigin-RevId: 500821630
2023-01-09 15:22:37 -08:00
Peter Hawkins
3d038a490a
[NumPy] Remove references to deprecated NumPy type aliases.
...
This change replaces references to a number of deprecated NumPy type aliases (np.bool, np.int, np.float, np.complex, np.object, np.str) with their recommended replacement (bool, int, float, complex, object, str).
NumPy 1.24 drops the deprecated aliases, so we must remove uses before updating NumPy.
PiperOrigin-RevId: 497194550
2022-12-22 10:32:59 -08:00
Steve Chien
f99a74c7a4
Fix dependencies required by privacy_tests
.
...
Update `distutils` to `packaging`.
PiperOrigin-RevId: 496713867
2022-12-20 11:49:28 -08:00
Shuang Song
2040f08f0d
Allows slicing by custom indices.
...
PiperOrigin-RevId: 486998645
2022-11-08 11:05:26 -08:00
A. Unique TensorFlower
ec747a8d75
Correct imports of keras loss utils
...
PiperOrigin-RevId: 486795765
2022-11-07 16:34:00 -08:00
A. Unique TensorFlower
e334633466
Bugfix.
...
PiperOrigin-RevId: 486344068
2022-11-05 05:18:58 -07:00
Shuang Song
f7e1e61823
Adds a utility function for formating list into string.
...
PiperOrigin-RevId: 484026229
2022-10-26 11:33:30 -07:00
Shuang Song
7d7b670f5d
Add functions to derive epsilon lower bounds.
...
PiperOrigin-RevId: 484021227
2022-10-26 11:15:47 -07:00
A. Unique TensorFlower
3f16540bfc
Efficient DP optimizers for sparse models.
...
PiperOrigin-RevId: 482871514
2022-10-21 13:15:52 -07:00
Galen Andrew
a7d929a21c
Bump version for release.
...
PiperOrigin-RevId: 482286678
2022-10-19 13:21:35 -07:00
Steve Chien
0fcfd0bf69
Remove pfor dependency in BUILD file, and strengthen unit tests for clip_and_aggregate_gradients.py.
...
PiperOrigin-RevId: 482050282
2022-10-18 16:21:37 -07:00
Steve Chien
4aa531faa4
Remove dependence on six in clip_and_aggregate_gradients.py.
...
PiperOrigin-RevId: 481750014
2022-10-17 15:07:27 -07:00
A. Unique TensorFlower
d5538fccbb
Ensures DPOptimizer objects can be serialized by TensorFlow.
...
Handles by processing tensors to numpy. Adds tests to now capture this.
PiperOrigin-RevId: 481656298
2022-10-17 09:12:10 -07:00
A. Unique TensorFlower
c25cb4a41b
Clip (per-example) and aggregate gradients.
...
PiperOrigin-RevId: 480761907
2022-10-12 17:43:21 -07:00
A. Unique TensorFlower
71837fbeec
Adds DP-FTRL via tree aggregation optimizer DPFTRLTreeAggregationOptimizer
.
...
Includes renaming of `frequency` parameter in restart_query.py to `period` to more more accurately reflect its purpose.
PiperOrigin-RevId: 480736961
2022-10-12 15:47:07 -07:00
A. Unique TensorFlower
5e37c1bc70
Implement initial_sample_state for TreeRangeSumQuery.
...
PiperOrigin-RevId: 480685277
2022-10-12 12:11:21 -07:00
A. Unique TensorFlower
79fe32a60b
Changes DPOptimizerClass
to generically accept and use any dp_sum_query
.
...
This enables creation of generic DPOptimizers by user's passing queries. The most common Gaussian query is automatically performed for convenience and backwards compatibility.
Byproducts of this update:
-ensures consistent implementations between the internal (and legacy) `get_gradients` and newer `_compute_gradients` for all queries.
-refactors for python readability.
-includes new tests ensuring that `_num_microbatches=None` is tested.
-changes the `_global_state` to to be initialized in the init function for `_compute_gradients`.
PiperOrigin-RevId: 480668376
2022-10-12 11:03:55 -07:00
A. Unique TensorFlower
f8ed0fcd9c
Fix SumAggregationDPQuery's initial_sample_state raising a ValueError when called on TensorSpec.
...
PiperOrigin-RevId: 480474975
2022-10-11 16:02:00 -07:00
A. Unique TensorFlower
0738d6f555
Bugfix.
...
PiperOrigin-RevId: 478591776
2022-10-03 13:33:33 -07:00
A. Unique TensorFlower
3f6d0acdef
Add ability to use sample weights to the membership attack models, where they are supported by the underlying Scikit-Learn estimators. Only the Logistic Regression and Random Forest estimators support sample weights.
...
PiperOrigin-RevId: 478542133
2022-10-03 10:32:31 -07:00
Michael Reneer
feddd28a63
Pin tensorflow-probability
to a specific version.
...
This matches the documentation for specifying version for this project. Additionally, recent version of `tensorflow-probability` are releasing breaking changes and the existing version specifier allows these to breaking changes to be unintentionally pulled in.
PiperOrigin-RevId: 476443999
2022-09-23 13:04:47 -07:00
Chen Qian
c6c3334b57
Code changes to get ready for an incoming Keras optimizer migration.
...
DP optimizer only supports legacy optimizer.
PiperOrigin-RevId: 474137890
2022-09-13 15:20:26 -07:00
Shuang Song
08364adcb7
Allow squared loss to take in labels and predictions of the same number of elements but different shapes.
...
PiperOrigin-RevId: 474059427
2022-09-13 10:32:58 -07:00
Yilei Yang
ebae6c086e
Make this code compatible with Python 3.10.
...
PiperOrigin-RevId: 473313795
2022-09-09 12:20:05 -07:00
Chen Qian
715fd1a670
Code changes to get ready for an incoming Keras optimizer migration.
...
Because the code subclasses the legacy Keras optimizer, we should explicitly use the legacy optimizer.
PiperOrigin-RevId: 473092233
2022-09-08 14:56:56 -07:00
Steve Chien
407e5c8e11
Clarify logic in Keras version of DP-SGD optimizer, and add a unit test involving clipping on multiple variables.
...
PiperOrigin-RevId: 472559697
2022-09-06 14:36:43 -07:00
Michael Reneer
628e5bb926
Update the setup.py
to match the requirements.txt
.
...
PiperOrigin-RevId: 471128177
2022-08-30 17:16:42 -07:00
Steve Chien
ed73077b60
Change version to 0.8.5. (Previously incorrectly skipped ahead to 0.8.6)
...
PiperOrigin-RevId: 471118348
2022-08-30 16:28:14 -07:00
Steve Chien
875b7f46bd
Automated rollback of commit cff47686f6
...
PiperOrigin-RevId: 471104040
2022-08-30 15:23:08 -07:00
A. Unique TensorFlower
cff47686f6
Changes DPOptimizerClass
to generically accept and use any dp_sum_query
.
...
This enables creation of generic DPOptimizers by user's passing queries. The most common Gaussian query is automatically performed for convenience and backwards compatibility.
Byproducts of this update:
-ensures consistent implementations between the internal (and legacy) `get_gradients` and newer `_compute_gradients` for all queries.
-refactors for python readability.
PiperOrigin-RevId: 470883774
2022-08-29 20:22:40 -07:00
Steve Chien
ed16033a92
Update pinned commit of dp-accounting library, update dependency versions, and increase version to 0.8.6.
...
PiperOrigin-RevId: 470334560
2022-08-26 14:30:16 -07:00