forked from 626_privacy/tensorflow_privacy
Sparsity Preserving DP-SGD in TF Privacy [1 of 4]
Adds layer registry and type aliases. See https://research.google/blog/sparsity-preserving-differentially-private-training/ for more details on the algorithm. PiperOrigin-RevId: 648747866
This commit is contained in:
parent
00384db109
commit
348895a7a3
3 changed files with 96 additions and 0 deletions
14
tensorflow_privacy/privacy/sparsity_preserving_noise/BUILD
Normal file
14
tensorflow_privacy/privacy/sparsity_preserving_noise/BUILD
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
package(default_visibility = ["//visibility:public"])
|
||||||
|
|
||||||
|
licenses(["notice"])
|
||||||
|
|
||||||
|
py_library(
|
||||||
|
name = "type_aliases",
|
||||||
|
srcs = ["type_aliases.py"],
|
||||||
|
)
|
||||||
|
|
||||||
|
py_library(
|
||||||
|
name = "layer_registry",
|
||||||
|
srcs = ["layer_registry.py"],
|
||||||
|
deps = [":type_aliases"],
|
||||||
|
)
|
|
@ -0,0 +1,51 @@
|
||||||
|
# Copyright 2024, The TensorFlow Authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
"""Registry of layer classes to their contribution histogram functions."""
|
||||||
|
|
||||||
|
from typing import Type
|
||||||
|
|
||||||
|
import tensorflow as tf
|
||||||
|
from tensorflow_privacy.privacy.sparsity_preserving_noise import type_aliases
|
||||||
|
|
||||||
|
|
||||||
|
# ==============================================================================
|
||||||
|
# Main class
|
||||||
|
# ==============================================================================
|
||||||
|
class LayerRegistry:
|
||||||
|
"""Custom container for layer registry functions."""
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
"""Basic initialization of various internal dictionaries."""
|
||||||
|
self._layer_class_dict = {}
|
||||||
|
self._registry = {}
|
||||||
|
|
||||||
|
def is_elem(self, layer_instance: tf.keras.layers.Layer) -> bool:
|
||||||
|
"""Checks if a layer instance's class is in the registry."""
|
||||||
|
return hash(layer_instance.__class__) in self._registry
|
||||||
|
|
||||||
|
def lookup(
|
||||||
|
self, layer_instance: tf.keras.layers.Layer
|
||||||
|
) -> type_aliases.SparsityPreservingNoiseLayerRegistryFunction:
|
||||||
|
"""Returns the layer registry function for a given layer instance."""
|
||||||
|
return self._registry[hash(layer_instance.__class__)]
|
||||||
|
|
||||||
|
def insert(
|
||||||
|
self,
|
||||||
|
layer_class: Type[tf.keras.layers.Layer],
|
||||||
|
layer_registry_function: type_aliases.SparsityPreservingNoiseLayerRegistryFunction,
|
||||||
|
):
|
||||||
|
"""Inserts a layer registry function into the internal dictionaries."""
|
||||||
|
layer_key = hash(layer_class)
|
||||||
|
self._layer_class_dict[layer_key] = layer_class
|
||||||
|
self._registry[layer_key] = layer_registry_function
|
|
@ -0,0 +1,31 @@
|
||||||
|
# Copyright 2024, The TensorFlow Authors.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
"""Type aliases for sparsity preserving noise."""
|
||||||
|
|
||||||
|
from collections.abc import Callable, Mapping, Sequence
|
||||||
|
from typing import Any
|
||||||
|
import tensorflow as tf
|
||||||
|
|
||||||
|
InputArgs = Sequence[Any]
|
||||||
|
InputKwargs = Mapping[str, Any]
|
||||||
|
SparseGradient = tf.IndexedSlices
|
||||||
|
ContributionCountHistogram = tf.SparseTensor
|
||||||
|
ContributionCountHistogramFn = Callable[
|
||||||
|
[SparseGradient], Mapping[str, ContributionCountHistogram]
|
||||||
|
]
|
||||||
|
NumMicrobatches = int | tf.Tensor
|
||||||
|
SparsityPreservingNoiseLayerRegistryFunction = Callable[
|
||||||
|
[tf.keras.layers.Layer, InputArgs, InputKwargs, NumMicrobatches | None],
|
||||||
|
ContributionCountHistogramFn,
|
||||||
|
]
|
Loading…
Reference in a new issue