// This file is part of gen, a lightweight C++ template library // for linear algebra. gen itself is part of the KDE project. // // Copyright (C) 2006-2007 Benoit Jacob // // gen is free software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the Free Software // Foundation; either version 2 or (at your option) any later version. // // gen is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS // FOR A PARTICULAR PURPOSE. See the GNU General Public License for more // details. // // You should have received a copy of the GNU General Public License along // with gen; if not, write to the Free Software Foundation, Inc., 51 // Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. // // As a special exception, if other files instantiate templates or use macros // or functions from this file, or you compile this file and link it // with other works to produce a work based on this file, this file does not // by itself cause the resulting work to be covered by the GNU General Public // License. This exception does not invalidate any other reasons why a work // based on this file might be covered by the GNU General Public License. #ifndef EI_UTIL_H #define EI_UTIL_H #undef minor #define USING_EIGEN_DATA_TYPES \ EI_USING_MATRIX_TYPEDEFS \ using Eigen::Matrix; #define EI_UNUSED(x) (void)x #define EI_CHECK_RANGES(matrix, row, col) \ assert(row >= 0 && row < (matrix).rows() && col >= 0 && col < (matrix).cols()) #define EI_CHECK_ROW_RANGE(matrix, row) \ assert(row >= 0 && row < (matrix).rows()) #define EI_CHECK_COL_RANGE(matrix, col) \ assert(col >= 0 && col < (matrix).cols()) //forward declarations template class Matrix; template class MatrixRef; template class MatrixConstRef; template class Row; template class Column; template class Minor; template class Block; template class Transpose; template class Conjugate; template class Sum; template class Difference; template class MatrixProduct; template class ScalarProduct; template class Random; template class Eval; template struct ForwardDecl { typedef T Ref; typedef T ConstRef; }; template struct ForwardDecl > { typedef MatrixRef > Ref; typedef MatrixConstRef > ConstRef; }; const int Dynamic = -1; #define EI_LOOP_UNROLLING_LIMIT 25 #define EI_UNUSED(x) (void)x #ifdef __GNUC__ # define EI_ALWAYS_INLINE __attribute__((always_inline)) # define EI_RESTRICT /*__restrict__*/ #else # define EI_ALWAYS_INLINE # define EI_RESTRICT #endif #define EI_INHERIT_ASSIGNMENT_OPERATOR(Derived, Op) \ template \ Derived& operator Op(const Object& other) \ { \ return Object::operator Op(other); \ } \ Derived& operator Op(const Derived& other) \ { \ return Object::operator Op(other); \ } #define EI_INHERIT_SCALAR_ASSIGNMENT_OPERATOR(Derived, Op) \ template \ Derived& operator Op(const Other& scalar) \ { \ return Object::operator Op(scalar); \ } #define EI_INHERIT_ASSIGNMENT_OPERATORS(Derived) \ EI_INHERIT_ASSIGNMENT_OPERATOR(Derived, =) \ EI_INHERIT_ASSIGNMENT_OPERATOR(Derived, +=) \ EI_INHERIT_ASSIGNMENT_OPERATOR(Derived, -=) \ EI_INHERIT_SCALAR_ASSIGNMENT_OPERATOR(Derived, *=) \ EI_INHERIT_SCALAR_ASSIGNMENT_OPERATOR(Derived, /=) #endif // EI_UTIL_H