Merge of itasc branch. Project files, scons and cmake should be working. Makefile...
[blender.git] / extern / Eigen2 / Eigen / src / Core / util / ForwardDeclarations.h
1 // This file is part of Eigen, a lightweight C++ template library
2 // for linear algebra. Eigen itself is part of the KDE project.
3 //
4 // Copyright (C) 2006-2008 Benoit Jacob <jacob.benoit.1@gmail.com>
5 //
6 // Eigen is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 3 of the License, or (at your option) any later version.
10 //
11 // Alternatively, you can redistribute it and/or
12 // modify it under the terms of the GNU General Public License as
13 // published by the Free Software Foundation; either version 2 of
14 // the License, or (at your option) any later version.
15 //
16 // Eigen is distributed in the hope that it will be useful, but WITHOUT ANY
17 // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
18 // FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License or the
19 // GNU General Public License for more details.
20 //
21 // You should have received a copy of the GNU Lesser General Public
22 // License and a copy of the GNU General Public License along with
23 // Eigen. If not, see <http://www.gnu.org/licenses/>.
24
25 #ifndef EIGEN_FORWARDDECLARATIONS_H
26 #define EIGEN_FORWARDDECLARATIONS_H
27
28 template<typename T> struct ei_traits;
29 template<typename T> struct NumTraits;
30
31 template<typename _Scalar, int _Rows, int _Cols,
32          int _Options = EIGEN_DEFAULT_MATRIX_STORAGE_ORDER_OPTION | AutoAlign,
33          int _MaxRows = _Rows, int _MaxCols = _Cols> class Matrix;
34
35 template<typename ExpressionType, unsigned int Added, unsigned int Removed> class Flagged;
36 template<typename ExpressionType> class NestByValue;
37 template<typename ExpressionType> class SwapWrapper;
38 template<typename MatrixType> class Minor;
39 template<typename MatrixType, int BlockRows=Dynamic, int BlockCols=Dynamic, int PacketAccess=AsRequested,
40          int _DirectAccessStatus = ei_traits<MatrixType>::Flags&DirectAccessBit ? DirectAccessBit
41                                  : ei_traits<MatrixType>::Flags&SparseBit> class Block;
42 template<typename MatrixType> class Transpose;
43 template<typename MatrixType> class Conjugate;
44 template<typename NullaryOp, typename MatrixType>         class CwiseNullaryOp;
45 template<typename UnaryOp,   typename MatrixType>         class CwiseUnaryOp;
46 template<typename BinaryOp,  typename Lhs, typename Rhs>  class CwiseBinaryOp;
47 template<typename Lhs, typename Rhs, int ProductMode> class Product;
48 template<typename CoeffsVectorType> class DiagonalMatrix;
49 template<typename MatrixType> class DiagonalCoeffs;
50 template<typename MatrixType, int PacketAccess = AsRequested> class Map;
51 template<typename MatrixType, unsigned int Mode> class Part;
52 template<typename MatrixType, unsigned int Mode> class Extract;
53 template<typename ExpressionType> class Cwise;
54 template<typename ExpressionType> class WithFormat;
55 template<typename MatrixType> struct CommaInitializer;
56
57
58 template<typename Lhs, typename Rhs> struct ei_product_mode;
59 template<typename Lhs, typename Rhs, int ProductMode = ei_product_mode<Lhs,Rhs>::value> struct ProductReturnType;
60
61 template<typename Scalar> struct ei_scalar_sum_op;
62 template<typename Scalar> struct ei_scalar_difference_op;
63 template<typename Scalar> struct ei_scalar_product_op;
64 template<typename Scalar> struct ei_scalar_quotient_op;
65 template<typename Scalar> struct ei_scalar_opposite_op;
66 template<typename Scalar> struct ei_scalar_conjugate_op;
67 template<typename Scalar> struct ei_scalar_real_op;
68 template<typename Scalar> struct ei_scalar_imag_op;
69 template<typename Scalar> struct ei_scalar_abs_op;
70 template<typename Scalar> struct ei_scalar_abs2_op;
71 template<typename Scalar> struct ei_scalar_sqrt_op;
72 template<typename Scalar> struct ei_scalar_exp_op;
73 template<typename Scalar> struct ei_scalar_log_op;
74 template<typename Scalar> struct ei_scalar_cos_op;
75 template<typename Scalar> struct ei_scalar_sin_op;
76 template<typename Scalar> struct ei_scalar_pow_op;
77 template<typename Scalar> struct ei_scalar_inverse_op;
78 template<typename Scalar> struct ei_scalar_square_op;
79 template<typename Scalar> struct ei_scalar_cube_op;
80 template<typename Scalar, typename NewType> struct ei_scalar_cast_op;
81 template<typename Scalar> struct ei_scalar_multiple_op;
82 template<typename Scalar> struct ei_scalar_quotient1_op;
83 template<typename Scalar> struct ei_scalar_min_op;
84 template<typename Scalar> struct ei_scalar_max_op;
85 template<typename Scalar> struct ei_scalar_random_op;
86 template<typename Scalar> struct ei_scalar_add_op;
87 template<typename Scalar> struct ei_scalar_constant_op;
88 template<typename Scalar> struct ei_scalar_identity_op;
89
90 struct IOFormat;
91
92 template<typename Scalar>
93 void ei_cache_friendly_product(
94   int _rows, int _cols, int depth,
95   bool _lhsRowMajor, const Scalar* _lhs, int _lhsStride,
96   bool _rhsRowMajor, const Scalar* _rhs, int _rhsStride,
97   bool resRowMajor, Scalar* res, int resStride);
98
99 // Array module
100 template<typename ConditionMatrixType, typename ThenMatrixType, typename ElseMatrixType> class Select;
101 template<typename MatrixType, typename BinaryOp, int Direction> class PartialReduxExpr;
102 template<typename ExpressionType, int Direction> class PartialRedux;
103
104 template<typename MatrixType> class LU;
105 template<typename MatrixType> class QR;
106 template<typename MatrixType> class SVD;
107 template<typename MatrixType> class LLT;
108 template<typename MatrixType> class LDLT;
109
110 // Geometry module:
111 template<typename Derived, int _Dim> class RotationBase;
112 template<typename Lhs, typename Rhs> class Cross;
113 template<typename Scalar> class Quaternion;
114 template<typename Scalar> class Rotation2D;
115 template<typename Scalar> class AngleAxis;
116 template<typename Scalar,int Dim> class Transform;
117 template <typename _Scalar, int _AmbientDim> class ParametrizedLine;
118 template <typename _Scalar, int _AmbientDim> class Hyperplane;
119 template<typename Scalar,int Dim> class Translation;
120 template<typename Scalar,int Dim> class Scaling;
121
122 // Sparse module:
123 template<typename Lhs, typename Rhs, int ProductMode> class SparseProduct;
124
125 #endif // EIGEN_FORWARDDECLARATIONS_H