aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiao Wang <miaowang@google.com>2017-07-26 08:35:37 +0000
committerandroid-build-merger <android-build-merger@google.com>2017-07-26 08:35:37 +0000
commite4c40d123aea2bc2493e53fb6d18df5e5e1cd955 (patch)
tree3ff1e643f70aad062b94a29f53ea8f422ed59e18
parent52289ab445e4f09a541e9845e46c3898c992e2f3 (diff)
parente241ae53c5a2c986c6077fac054d74f648079ea6 (diff)
downloadeigen-e4c40d123aea2bc2493e53fb6d18df5e5e1cd955.tar.gz
Add sigmoid functors to Eigen/Core.
am: e241ae53c5 Change-Id: I5e3ba0610dd2ad501d4a95e292c5df6daa261633
-rw-r--r--Eigen/src/Core/functors/UnaryFunctors.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/Eigen/src/Core/functors/UnaryFunctors.h b/Eigen/src/Core/functors/UnaryFunctors.h
index 2e6a00ffd..581a3c93a 100644
--- a/Eigen/src/Core/functors/UnaryFunctors.h
+++ b/Eigen/src/Core/functors/UnaryFunctors.h
@@ -14,6 +14,37 @@ namespace Eigen {
namespace internal {
+// Copied from unsupported/Eigen/CXX11/src/Tensor/TensorFunctors.h
+// TODO: remove or update after upstream
+/** \internal
+ * \brief Template functor to compute the sigmoid of a scalar
+ * \sa class CwiseUnaryOp, ArrayBase::sigmoid()
+ */
+template <typename T>
+struct scalar_sigmoid_op {
+ EIGEN_EMPTY_STRUCT_CTOR(scalar_sigmoid_op)
+ EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE T operator()(const T& x) const {
+ const T one = T(1);
+ return one / (one + numext::exp(-x));
+ }
+
+ template <typename Packet> EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
+ Packet packetOp(const Packet& x) const {
+ const Packet one = pset1<Packet>(T(1));
+ return pdiv(one, padd(one, pexp(pnegate(x))));
+ }
+};
+
+template <typename T>
+struct functor_traits<scalar_sigmoid_op<T> > {
+ enum {
+ Cost = NumTraits<T>::AddCost * 2 + NumTraits<T>::MulCost * 6,
+ PacketAccess = packet_traits<T>::HasAdd && packet_traits<T>::HasDiv &&
+ packet_traits<T>::HasNegate && packet_traits<T>::HasExp
+ };
+};
+
+
/** \internal
* \brief Template functor to compute the opposite of a scalar
*