Go to the source code of this file.
Defines | |
#define | _DO_MATRIX_SET_RESIZE(_R_, _C_) cml::et::detail::Resize(*this,_R_,_C_) |
#define | CML_ACCUMULATED_MATRIX_MULT(_arg_type_) |
Accumulated matrix multiplication. | |
#define | CML_ASSIGN_MAT_22 |
Set a matrix from 2x2 values. | |
#define | CML_ASSIGN_MAT_33 |
Create a matrix from 3x3 values. | |
#define | CML_ASSIGN_MAT_44 |
Create a matrix from 4x4 values. | |
#define | CML_CONSTRUCT_MAT_22 |
Create a matrix from 2x2 values. | |
#define | CML_CONSTRUCT_MAT_33 |
Create a matrix from 3x3 values. | |
#define | CML_CONSTRUCT_MAT_44 |
Create a matrix from 4x4 values. | |
#define | CML_MAT_ASSIGN_FROM_MAT(_op_, _op_name_) |
Assign this matrix from another using the given elementwise op. | |
#define | CML_MAT_ASSIGN_FROM_MATTYPE |
Assign from the same matrix type. | |
#define | CML_MAT_ASSIGN_FROM_MATXPR(_op_, _op_name_) |
Declare a function to assign this matrix from a matrix expression. | |
#define | CML_MAT_ASSIGN_FROM_SCALAR(_op_, _op_name_) |
Declare a function to assign this matrix from a scalar. | |
#define | CML_MAT_COPY_FROM_ARRAY(_add_) |
Copy-construct a matrix from a runtime-sized array of values. | |
#define | CML_MAT_COPY_FROM_FIXED_ARRAY(_R_, _C_) |
Copy-construct a matrix from a fixed-size array of values. | |
#define | CML_MAT_COPY_FROM_MAT |
Copy this matrix from another using the given elementwise op. | |
#define | CML_MAT_COPY_FROM_MATTYPE |
Copy this matrix from another using the given elementwise op. | |
#define | CML_MAT_COPY_FROM_MATXPR |
Declare a function to copy this matrix from a matrix expression. | |
#define | CML_MATRIX_BRACE_OPERATORS |
#define | TEMPLATED_MATRIX_MACRO matrix<E,AT,BO,L> |
Definition in file class_ops.h.
#define _DO_MATRIX_SET_RESIZE | ( | _R_, | |||
_C_ | ) | cml::et::detail::Resize(*this,_R_,_C_) |
Definition at line 34 of file class_ops.h.
#define CML_ACCUMULATED_MATRIX_MULT | ( | _arg_type_ | ) |
Value:
matrix_type& operator*=(_arg_type_ m) { \ typedef typename et::MatrixPromote< \ matrix_type, _arg_type_>::type result_type; \ cml::et::CheckedSquare(*this, typename result_type::size_tag()); \ return (*this = (*this)*m); \ }
std::invalid_argument | if the matrices are not square. |
Definition at line 305 of file class_ops.h.
#define CML_ASSIGN_MAT_22 |
Value:
matrix_type& \ set( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11 \ ) \ { \ _DO_MATRIX_SET_RESIZE(2,2); \ /* This is overkill, but simplifies size checking: */ \ value_type v[2][2] = {{e00,e01},{e10,e11}}; \ typedef et::OpAssign<Element,Element> OpT; \ typedef const value_type element; \ cml::matrix<element, external<2,2>, basis_orient, row_major> \ src(&v[0][0]); \ et::UnrollAssignment<OpT>(*this,src); \ return *this; \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 43 of file class_ops.h.
#define CML_ASSIGN_MAT_33 |
Value:
matrix_type& \ set( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, ELEMENT_ARG_TYPE e02, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11, ELEMENT_ARG_TYPE e12, \ ELEMENT_ARG_TYPE e20, ELEMENT_ARG_TYPE e21, ELEMENT_ARG_TYPE e22 \ ) \ { \ _DO_MATRIX_SET_RESIZE(3,3); \ /* This is overkill, but simplifies size checking: */ \ value_type v[3][3] = { \ {e00,e01,e02}, \ {e10,e11,e12}, \ {e20,e21,e22} \ }; \ typedef et::OpAssign<Element,Element> OpT; \ typedef const value_type element; \ cml::matrix<element, external<3,3>, basis_orient, row_major> \ src(&v[0][0]); \ et::UnrollAssignment<OpT>(*this,src); \ return *this; \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 65 of file class_ops.h.
#define CML_ASSIGN_MAT_44 |
Value:
matrix_type& \ set( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, \ ELEMENT_ARG_TYPE e02, ELEMENT_ARG_TYPE e03, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11, \ ELEMENT_ARG_TYPE e12, ELEMENT_ARG_TYPE e13, \ ELEMENT_ARG_TYPE e20, ELEMENT_ARG_TYPE e21, \ ELEMENT_ARG_TYPE e22, ELEMENT_ARG_TYPE e23, \ ELEMENT_ARG_TYPE e30, ELEMENT_ARG_TYPE e31, \ ELEMENT_ARG_TYPE e32, ELEMENT_ARG_TYPE e33 \ ) \ { \ _DO_MATRIX_SET_RESIZE(4,4); \ /* This is overkill, but simplifies size checking: */ \ value_type v[4][4] = { \ {e00,e01,e02,e03}, \ {e10,e11,e12,e13}, \ {e20,e21,e22,e23}, \ {e30,e31,e32,e33} \ }; \ typedef et::OpAssign<Element,Element> OpT; \ typedef const value_type element; \ cml::matrix<element, external<4,4>, basis_orient, row_major> \ src(&v[0][0]); \ et::UnrollAssignment<OpT>(*this,src); \ return *this; \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 92 of file class_ops.h.
#define CML_CONSTRUCT_MAT_22 |
Value:
matrix( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11 \ ) \ { \ set( \ e00,e01, \ e10,e11 \ ); \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 125 of file class_ops.h.
#define CML_CONSTRUCT_MAT_33 |
Value:
matrix( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, ELEMENT_ARG_TYPE e02, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11, ELEMENT_ARG_TYPE e12, \ ELEMENT_ARG_TYPE e20, ELEMENT_ARG_TYPE e21, ELEMENT_ARG_TYPE e22 \ ) \ { \ set( \ e00,e01,e02, \ e10,e11,e12, \ e20,e21,e22 \ ); \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 141 of file class_ops.h.
#define CML_CONSTRUCT_MAT_44 |
Value:
matrix( \ ELEMENT_ARG_TYPE e00, ELEMENT_ARG_TYPE e01, \ ELEMENT_ARG_TYPE e02, ELEMENT_ARG_TYPE e03, \ ELEMENT_ARG_TYPE e10, ELEMENT_ARG_TYPE e11, \ ELEMENT_ARG_TYPE e12, ELEMENT_ARG_TYPE e13, \ ELEMENT_ARG_TYPE e20, ELEMENT_ARG_TYPE e21, \ ELEMENT_ARG_TYPE e22, ELEMENT_ARG_TYPE e23, \ ELEMENT_ARG_TYPE e30, ELEMENT_ARG_TYPE e31, \ ELEMENT_ARG_TYPE e32, ELEMENT_ARG_TYPE e33 \ ) \ { \ set( \ e00,e01,e02,e03, \ e10,e11,e12,e13, \ e20,e21,e22,e23, \ e30,e31,e32,e33 \ ); \ }
The layout assumed for the values is that of the matrix being assigned.
Definition at line 159 of file class_ops.h.
#define CML_MAT_ASSIGN_FROM_MAT | ( | _op_, | |||
_op_name_ | ) |
Value:
template<typename E, class AT, typename BO, typename L> matrix_type& \ operator _op_ (const TEMPLATED_MATRIX_MACRO& m) { \ typedef _op_name_ <Element,E> OpT; \ et::UnrollAssignment<OpT>(*this,m); \ return *this; \ }
This allows assignment from arbitrary matrix types.
_op_ | the operator (e.g. +=) | |
_op_name_ | the op functor (e.g. et::OpAssign) |
Definition at line 260 of file class_ops.h.
#define CML_MAT_ASSIGN_FROM_MATTYPE |
Value:
matrix_type& operator=(const matrix_type& m) { \ typedef et::OpAssign<Element,Element> OpT; \ et::UnrollAssignment<OpT>(*this,m); \ return *this; \ }
m | the matrix to copy from. |
ICC9/Linux-x86 seems to prefer its own assignment operator (need to figure out why).
Definition at line 244 of file class_ops.h.
#define CML_MAT_ASSIGN_FROM_MATXPR | ( | _op_, | |||
_op_name_ | ) |
Value:
template<class XprT> matrix_type& \ operator _op_ (MATXPR_ARG_TYPE e) { \ /* Verify that a promotion exists at compile time: */ \ typedef typename et::MatrixPromote< \ matrix_type, typename XprT::result_type>::type result_type; \ typedef typename XprT::value_type src_value_type; \ typedef _op_name_ <Element,src_value_type> OpT; \ et::UnrollAssignment<OpT>(*this,e); \ return *this; \ }
_op_ | the operator (e.g. +=) | |
_op_name_ | the op functor (e.g. et::OpAssign) |
Definition at line 273 of file class_ops.h.
#define CML_MAT_ASSIGN_FROM_SCALAR | ( | _op_, | |||
_op_name_ | ) |
Value:
matrix_type& operator _op_ (ELEMENT_ARG_TYPE s) { \ typedef _op_name_ <Element,value_type> OpT; \ et::UnrollAssignment<OpT>(*this,s); \ return *this; \ }
_op_ | the operator (e.g. +=) | |
_op_name_ | the op functor (e.g. et::OpAssign) |
Definition at line 293 of file class_ops.h.
#define CML_MAT_COPY_FROM_ARRAY | ( | _add_ | ) |
Value:
matrix(const value_type* const v, size_t R, size_t C) _add_ { \ typedef et::OpAssign<Element,Element> OpT; \ cml::matrix<value_type, external<>, basis_orient, \ row_major > src(const_cast<value_type*>(v),R,C); \ et::UnrollAssignment<OpT>(*this,src); \ }
Definition at line 189 of file class_ops.h.
#define CML_MAT_COPY_FROM_FIXED_ARRAY | ( | _R_, | |||
_C_ | ) |
Value:
matrix(const value_type m[_R_][_C_]) { \ typedef et::OpAssign<Element,Element> OpT; \ cml::matrix<const value_type, external<_R_,_C_>, \ basis_orient, row_major> src(&m[0][0]); \ et::UnrollAssignment<OpT>(*this,src); \ }
Definition at line 180 of file class_ops.h.
#define CML_MAT_COPY_FROM_MAT |
Value:
template<typename E, class AT, typename BO, typename L> \ matrix(const TEMPLATED_MATRIX_MACRO& m) { \ typedef et::OpAssign <Element,E> OpT; \ et::UnrollAssignment<OpT>(*this,m); \ }
This allows copies from arbitrary matrix types.
Definition at line 212 of file class_ops.h.
#define CML_MAT_COPY_FROM_MATTYPE |
Value:
matrix(const matrix_type& m) : array_type() { \ typedef et::OpAssign <Element,Element> OpT; \ et::UnrollAssignment<OpT>(*this,m); \ }
Definition at line 202 of file class_ops.h.
#define CML_MAT_COPY_FROM_MATXPR |
Value:
template<class XprT> \ matrix(MATXPR_ARG_TYPE e) { \ /* Verify that a promotion exists at compile time: */ \ typedef typename et::MatrixPromote< \ matrix_type, typename XprT::result_type>::type result_type; \ typedef typename XprT::value_type src_value_type; \ typedef et::OpAssign <Element,src_value_type> OpT; \ et::UnrollAssignment<OpT>(*this,e); \ }
Definition at line 220 of file class_ops.h.
#define CML_MATRIX_BRACE_OPERATORS |
Value:
template<class Matrix> struct row_ref { \ typedef typename Matrix::reference reference; \ reference operator[](size_t col) { return m(row,col); } \ Matrix& m; \ size_t row; \ }; \ \ template<class Matrix> struct const_row_ref { \ typedef typename Matrix::const_reference const_reference; \ const_reference operator[](size_t col) const { return m(row,col); } \ const Matrix& m; \ size_t row; \ }; \ \ row_ref<matrix_type> operator[](size_t row) { \ row_ref<matrix_type> ref = { *this, row }; return ref; \ } \ \ const_row_ref<matrix_type> operator[](size_t row) const { \ const_row_ref<matrix_type> ref = { *this, row }; return ref; \ }
Definition at line 315 of file class_ops.h.
#define TEMPLATED_MATRIX_MACRO matrix<E,AT,BO,L> |
Definition at line 28 of file class_ops.h.