T - data type for out() output@Operator(group="train") public final class SparseApplyFtrl<T> extends PrimitiveOp implements Operand<T>
That is for rows we have grad for, we update var, accum and linear as follows: grad_with_shrinkage = grad + 2 * l2_shrinkage * var accum_new = accum + grad_with_shrinkage * grad_with_shrinkage linear += grad_with_shrinkage + (accum_new^(-lr_power) - accum^(-lr_power)) / lr * var quadratic = 1.0 / (accum_new^(lr_power) * lr) + 2 * l2 var = (sign(linear) * l1 - linear) / quadratic if |linear| > l1 else 0.0 accum = accum_new
| Modifier and Type | Class | Description |
|---|---|---|
static class |
SparseApplyFtrl.Options |
Optional attributes for
SparseApplyFtrl |
operation| Modifier and Type | Method | Description |
|---|---|---|
Output<T> |
asOutput() |
Returns the symbolic handle of a tensor.
|
static <T,U extends java.lang.Number> |
create(Scope scope,
Operand<T> var,
Operand<T> accum,
Operand<T> linear,
Operand<T> grad,
Operand<U> indices,
Operand<T> lr,
Operand<T> l1,
Operand<T> l2,
Operand<T> l2Shrinkage,
Operand<T> lrPower,
SparseApplyFtrl.Options... options) |
Factory method to create a class to wrap a new SparseApplyFtrl operation to the graph.
|
Output<T> |
out() |
Same as "var".
|
static SparseApplyFtrl.Options |
useLocking(java.lang.Boolean useLocking) |
clone, finalize, getClass, notify, notifyAll, wait, wait, waitequals, hashCode, toStringpublic static <T,U extends java.lang.Number> SparseApplyFtrl<T> create(Scope scope, Operand<T> var, Operand<T> accum, Operand<T> linear, Operand<T> grad, Operand<U> indices, Operand<T> lr, Operand<T> l1, Operand<T> l2, Operand<T> l2Shrinkage, Operand<T> lrPower, SparseApplyFtrl.Options... options)
scope - current graph scopevar - Should be from a Variable().accum - Should be from a Variable().linear - Should be from a Variable().grad - The gradient.indices - A vector of indices into the first dimension of var and accum.lr - Scaling factor. Must be a scalar.l1 - L1 regularization. Must be a scalar.l2 - L2 shrinkage regulariation. Must be a scalar.l2Shrinkage - lrPower - Scaling factor. Must be a scalar.options - carries optional attributes valuespublic static SparseApplyFtrl.Options useLocking(java.lang.Boolean useLocking)
useLocking - If `True`, updating of the var and accum tensors will be protected
by a lock; otherwise the behavior is undefined, but may exhibit less
contention.public Output<T> asOutput()
OperandInputs to TensorFlow operations are outputs of another TensorFlow operation. This method is used to obtain a symbolic handle that represents the computation of the input.
asOutput in interface Operand<T>OperationBuilder.addInput(Output)