compbio
CwiseUnaryOp.h
1 // This file is part of Eigen, a lightweight C++ template library
2 // for linear algebra.
3 //
4 // Copyright (C) 2008-2014 Gael Guennebaud <gael.guennebaud@inria.fr>
5 // Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
6 //
7 // This Source Code Form is subject to the terms of the Mozilla
8 // Public License v. 2.0. If a copy of the MPL was not distributed
9 // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10 
11 #ifndef EIGEN_CWISE_UNARY_OP_H
12 #define EIGEN_CWISE_UNARY_OP_H
13 
14 namespace Eigen {
15 
16 namespace internal {
17 template<typename UnaryOp, typename XprType>
18 struct traits<CwiseUnaryOp<UnaryOp, XprType> >
19  : traits<XprType>
20 {
21  typedef typename result_of<
22  UnaryOp(const typename XprType::Scalar&)
23  >::type Scalar;
24  typedef typename XprType::Nested XprTypeNested;
26  enum {
27  Flags = _XprTypeNested::Flags & RowMajorBit
28  };
29 };
30 }
31 
32 template<typename UnaryOp, typename XprType, typename StorageKind>
34 
54 template<typename UnaryOp, typename XprType>
55 class CwiseUnaryOp : public CwiseUnaryOpImpl<UnaryOp, XprType, typename internal::traits<XprType>::StorageKind>, internal::no_assignment_operator
56 {
57  public:
58 
60  EIGEN_GENERIC_PUBLIC_INTERFACE(CwiseUnaryOp)
63 
64  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
65  explicit CwiseUnaryOp(const XprType& xpr, const UnaryOp& func = UnaryOp())
66  : m_xpr(xpr), m_functor(func) {}
67 
68  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
69  Index rows() const { return m_xpr.rows(); }
70  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
71  Index cols() const { return m_xpr.cols(); }
72 
74  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
75  const UnaryOp& functor() const { return m_functor; }
76 
78  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
80  nestedExpression() const { return m_xpr; }
81 
83  EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE
85  nestedExpression() { return m_xpr; }
86 
87  protected:
88  XprTypeNested m_xpr;
89  const UnaryOp m_functor;
90 };
91 
92 // Generic API dispatcher
93 template<typename UnaryOp, typename XprType, typename StorageKind>
94 class CwiseUnaryOpImpl
95  : public internal::generic_xpr_base<CwiseUnaryOp<UnaryOp, XprType> >::type
96 {
97 public:
99 };
100 
101 } // end namespace Eigen
102 
103 #endif // EIGEN_CWISE_UNARY_OP_H
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const UnaryOp & functor() const
Definition: CwiseUnaryOp.h:75
Namespace containing all symbols from the Eigen library.
Definition: bench_norm.cpp:85
const unsigned int RowMajorBit
for a matrix, this means that the storage order is row-major.
Definition: Constants.h:61
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE internal::remove_all< XprTypeNested >::type & nestedExpression()
Definition: CwiseUnaryOp.h:85
Definition: XprHelper.h:89
Definition: Meta.h:294
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:33
Definition: benchGeometry.cpp:23
Definition: BandTriangularSolver.h:13
Definition: CwiseUnaryOp.h:33
Definition: XprHelper.h:481
Generic expression where a coefficient-wise unary operator is applied to an expression.
Definition: CwiseUnaryOp.h:55
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE const internal::remove_all< XprTypeNested >::type & nestedExpression() const
Definition: CwiseUnaryOp.h:80
Definition: ForwardDeclarations.h:17