forked from 626_privacy/tensorflow_privacy
Update Huber loss regularization term and some small changes across loss parameters.
This commit is contained in:
parent
935d6e8480
commit
ed7fa73a99
1 changed files with 8 additions and 6 deletions
|
@ -58,7 +58,8 @@ class StrongConvexMixin:
|
||||||
"""Smoothness, beta
|
"""Smoothness, beta
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
class_weight: the class weights used.
|
class_weight: the class weights as scalar or 1d tensor, where its
|
||||||
|
dimensionality is equal to the number of outputs.
|
||||||
|
|
||||||
Returns: Beta
|
Returns: Beta
|
||||||
|
|
||||||
|
@ -154,7 +155,7 @@ class StrongConvexHuber(losses.Loss, StrongConvexMixin):
|
||||||
"""Compute loss
|
"""Compute loss
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
y_true: Ground truth values. One
|
y_true: Ground truth values. One hot encoded using -1 and 1.
|
||||||
y_pred: The predicted values.
|
y_pred: The predicted values.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
@ -211,7 +212,7 @@ class StrongConvexHuber(losses.Loss, StrongConvexMixin):
|
||||||
this loss function to be strongly convex.
|
this loss function to be strongly convex.
|
||||||
:return:
|
:return:
|
||||||
"""
|
"""
|
||||||
return L1L2(l2=self.reg_lambda)
|
return L1L2(l2=self.reg_lambda/2)
|
||||||
|
|
||||||
|
|
||||||
class StrongConvexBinaryCrossentropy(
|
class StrongConvexBinaryCrossentropy(
|
||||||
|
@ -230,7 +231,6 @@ class StrongConvexBinaryCrossentropy(
|
||||||
from_logits: bool = True,
|
from_logits: bool = True,
|
||||||
label_smoothing: float = 0,
|
label_smoothing: float = 0,
|
||||||
reduction: str = losses_utils.ReductionV2.SUM_OVER_BATCH_SIZE,
|
reduction: str = losses_utils.ReductionV2.SUM_OVER_BATCH_SIZE,
|
||||||
name: str = 'binarycrossentropy',
|
|
||||||
dtype=tf.float32):
|
dtype=tf.float32):
|
||||||
"""
|
"""
|
||||||
Args:
|
Args:
|
||||||
|
@ -239,7 +239,9 @@ class StrongConvexBinaryCrossentropy(
|
||||||
radius_constant: constant defining the length of the radius
|
radius_constant: constant defining the length of the radius
|
||||||
reduction: reduction type to use. See super class
|
reduction: reduction type to use. See super class
|
||||||
label_smoothing: amount of smoothing to perform on labels
|
label_smoothing: amount of smoothing to perform on labels
|
||||||
relaxation of trust in labels, e.g. (1 -> 1-x, 0 -> 0+x)
|
relaxation of trust in labels, e.g. (1 -> 1-x, 0 -> 0+x).
|
||||||
|
Note, the impact of this parameter's effect on privacy
|
||||||
|
is not known and thus the default should be used.
|
||||||
name: Name of the loss instance
|
name: Name of the loss instance
|
||||||
dtype: tf datatype to use for tensor conversions.
|
dtype: tf datatype to use for tensor conversions.
|
||||||
"""
|
"""
|
||||||
|
@ -256,7 +258,7 @@ class StrongConvexBinaryCrossentropy(
|
||||||
self.reg_lambda = tf.constant(reg_lambda, dtype=self.dtype)
|
self.reg_lambda = tf.constant(reg_lambda, dtype=self.dtype)
|
||||||
super(StrongConvexBinaryCrossentropy, self).__init__(
|
super(StrongConvexBinaryCrossentropy, self).__init__(
|
||||||
reduction=reduction,
|
reduction=reduction,
|
||||||
name=name,
|
name='binarycrossentropy',
|
||||||
from_logits=from_logits,
|
from_logits=from_logits,
|
||||||
label_smoothing=label_smoothing,
|
label_smoothing=label_smoothing,
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue