diff options
Diffstat (limited to 'tensorflow/core/kernels/l2loss_op.h')
-rw-r--r-- | tensorflow/core/kernels/l2loss_op.h | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/tensorflow/core/kernels/l2loss_op.h b/tensorflow/core/kernels/l2loss_op.h new file mode 100644 index 0000000000..d307353e24 --- /dev/null +++ b/tensorflow/core/kernels/l2loss_op.h @@ -0,0 +1,24 @@ +#ifndef TENSORFLOW_KERNELS_L2LOSS_OP_H_ +#define TENSORFLOW_KERNELS_L2LOSS_OP_H_ +// Functor definition for L2LossOp, must be compilable by nvcc. +#include "tensorflow/core/framework/tensor_types.h" +#include "third_party/eigen3/unsupported/Eigen/CXX11/Tensor" + +namespace tensorflow { +namespace functor { + +// Functor used by L2LossOp to do the computations. +template <typename Device, typename T> +struct L2Loss { + void operator()(const Device& d, typename TTypes<T>::ConstTensor input, + typename TTypes<T>::Scalar output) { + // We flatten the input tensor and reduce on dimension 0, producing + // a single number which is Mul(Sum(x^2), 0.5). + output.device(d) = input.square().sum() * static_cast<T>(0.5); + } +}; + +} // namespace functor +} // namespace tensorflow + +#endif // TENSORFLOW_KERNELS_L2LOSS_OP_H_ |