Go to the documentation of this file.
   33 #ifndef EIGEN_SELFADJOINT_MATRIX_MATRIX_BLAS_H 
   34 #define EIGEN_SELFADJOINT_MATRIX_MATRIX_BLAS_H 
   43 #define EIGEN_BLAS_SYMM_L(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC) \ 
   44 template <typename Index, \ 
   45           int LhsStorageOrder, bool ConjugateLhs, \ 
   46           int RhsStorageOrder, bool ConjugateRhs> \ 
   47 struct product_selfadjoint_matrix<EIGTYPE,Index,LhsStorageOrder,true,ConjugateLhs,RhsStorageOrder,false,ConjugateRhs,ColMajor> \ 
   51     Index rows, Index cols, \ 
   52     const EIGTYPE* _lhs, Index lhsStride, \ 
   53     const EIGTYPE* _rhs, Index rhsStride, \ 
   54     EIGTYPE* res,        Index resStride, \ 
   55     EIGTYPE alpha, level3_blocking<EIGTYPE, EIGTYPE>& ) \ 
   57     char side='L', uplo='L'; \ 
   58     BlasIndex m, n, lda, ldb, ldc; \ 
   59     const EIGTYPE *a, *b; \ 
   61     MatrixX##EIGPREFIX b_tmp; \ 
   65     m = convert_index<BlasIndex>(rows);  \ 
   66     n = convert_index<BlasIndex>(cols);  \ 
   69     lda = convert_index<BlasIndex>(lhsStride); \ 
   70     ldb = convert_index<BlasIndex>(rhsStride); \ 
   71     ldc = convert_index<BlasIndex>(resStride); \ 
   74     if (LhsStorageOrder==RowMajor) uplo='U'; \ 
   77     if (RhsStorageOrder==RowMajor) { \ 
   78       Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > rhs(_rhs,n,m,OuterStride<>(rhsStride)); \ 
   79       b_tmp = rhs.adjoint(); \ 
   81       ldb = convert_index<BlasIndex>(b_tmp.outerStride()); \ 
   84     BLASFUNC(&side, &uplo, &m, &n, (const BLASTYPE*)&numext::real_ref(alpha), (const BLASTYPE*)a, &lda, (const BLASTYPE*)b, &ldb, (const BLASTYPE*)&numext::real_ref(beta), (BLASTYPE*)res, &ldc); \ 
   90 #define EIGEN_BLAS_HEMM_L(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC) \ 
   91 template <typename Index, \ 
   92           int LhsStorageOrder, bool ConjugateLhs, \ 
   93           int RhsStorageOrder, bool ConjugateRhs> \ 
   94 struct product_selfadjoint_matrix<EIGTYPE,Index,LhsStorageOrder,true,ConjugateLhs,RhsStorageOrder,false,ConjugateRhs,ColMajor> \ 
   97     Index rows, Index cols, \ 
   98     const EIGTYPE* _lhs, Index lhsStride, \ 
   99     const EIGTYPE* _rhs, Index rhsStride, \ 
  100     EIGTYPE* res,        Index resStride, \ 
  101     EIGTYPE alpha, level3_blocking<EIGTYPE, EIGTYPE>& ) \ 
  103     char side='L', uplo='L'; \ 
  104     BlasIndex m, n, lda, ldb, ldc; \ 
  105     const EIGTYPE *a, *b; \ 
  107     MatrixX##EIGPREFIX b_tmp; \ 
  108     Matrix<EIGTYPE, Dynamic, Dynamic, LhsStorageOrder> a_tmp; \ 
  112     m = convert_index<BlasIndex>(rows); \ 
  113     n = convert_index<BlasIndex>(cols); \ 
  116     lda = convert_index<BlasIndex>(lhsStride); \ 
  117     ldb = convert_index<BlasIndex>(rhsStride); \ 
  118     ldc = convert_index<BlasIndex>(resStride); \ 
  121     if (((LhsStorageOrder==ColMajor) && ConjugateLhs) || ((LhsStorageOrder==RowMajor) && (!ConjugateLhs))) { \ 
  122       Map<const Matrix<EIGTYPE, Dynamic, Dynamic, LhsStorageOrder>, 0, OuterStride<> > lhs(_lhs,m,m,OuterStride<>(lhsStride)); \ 
  123       a_tmp = lhs.conjugate(); \ 
  125       lda = convert_index<BlasIndex>(a_tmp.outerStride()); \ 
  127     if (LhsStorageOrder==RowMajor) uplo='U'; \ 
  129     if (RhsStorageOrder==ColMajor && (!ConjugateRhs)) { \ 
  132       if (RhsStorageOrder==ColMajor && ConjugateRhs) { \ 
  133         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > rhs(_rhs,m,n,OuterStride<>(rhsStride)); \ 
  134         b_tmp = rhs.conjugate(); \ 
  136       if (ConjugateRhs) { \ 
  137         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > rhs(_rhs,n,m,OuterStride<>(rhsStride)); \ 
  138         b_tmp = rhs.adjoint(); \ 
  140         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > rhs(_rhs,n,m,OuterStride<>(rhsStride)); \ 
  141         b_tmp = rhs.transpose(); \ 
  144       ldb = convert_index<BlasIndex>(b_tmp.outerStride()); \ 
  147     BLASFUNC(&side, &uplo, &m, &n, (const BLASTYPE*)&numext::real_ref(alpha), (const BLASTYPE*)a, &lda, (const BLASTYPE*)b, &ldb, (const BLASTYPE*)&numext::real_ref(beta), (BLASTYPE*)res, &ldc); \ 
  166 #define EIGEN_BLAS_SYMM_R(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC) \ 
  167 template <typename Index, \ 
  168           int LhsStorageOrder, bool ConjugateLhs, \ 
  169           int RhsStorageOrder, bool ConjugateRhs> \ 
  170 struct product_selfadjoint_matrix<EIGTYPE,Index,LhsStorageOrder,false,ConjugateLhs,RhsStorageOrder,true,ConjugateRhs,ColMajor> \ 
  174     Index rows, Index cols, \ 
  175     const EIGTYPE* _lhs, Index lhsStride, \ 
  176     const EIGTYPE* _rhs, Index rhsStride, \ 
  177     EIGTYPE* res,        Index resStride, \ 
  178     EIGTYPE alpha, level3_blocking<EIGTYPE, EIGTYPE>& ) \ 
  180     char side='R', uplo='L'; \ 
  181     BlasIndex m, n, lda, ldb, ldc; \ 
  182     const EIGTYPE *a, *b; \ 
  184     MatrixX##EIGPREFIX b_tmp; \ 
  187     m = convert_index<BlasIndex>(rows);  \ 
  188     n = convert_index<BlasIndex>(cols);  \ 
  191     lda = convert_index<BlasIndex>(rhsStride); \ 
  192     ldb = convert_index<BlasIndex>(lhsStride); \ 
  193     ldc = convert_index<BlasIndex>(resStride); \ 
  196     if (RhsStorageOrder==RowMajor) uplo='U'; \ 
  199     if (LhsStorageOrder==RowMajor) { \ 
  200       Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > lhs(_lhs,n,m,OuterStride<>(rhsStride)); \ 
  201       b_tmp = lhs.adjoint(); \ 
  203       ldb = convert_index<BlasIndex>(b_tmp.outerStride()); \ 
  206     BLASFUNC(&side, &uplo, &m, &n, (const BLASTYPE*)&numext::real_ref(alpha), (const BLASTYPE*)a, &lda, (const BLASTYPE*)b, &ldb, (const BLASTYPE*)&numext::real_ref(beta), (BLASTYPE*)res, &ldc); \ 
  212 #define EIGEN_BLAS_HEMM_R(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC) \ 
  213 template <typename Index, \ 
  214           int LhsStorageOrder, bool ConjugateLhs, \ 
  215           int RhsStorageOrder, bool ConjugateRhs> \ 
  216 struct product_selfadjoint_matrix<EIGTYPE,Index,LhsStorageOrder,false,ConjugateLhs,RhsStorageOrder,true,ConjugateRhs,ColMajor> \ 
  219     Index rows, Index cols, \ 
  220     const EIGTYPE* _lhs, Index lhsStride, \ 
  221     const EIGTYPE* _rhs, Index rhsStride, \ 
  222     EIGTYPE* res,        Index resStride, \ 
  223     EIGTYPE alpha, level3_blocking<EIGTYPE, EIGTYPE>& ) \ 
  225     char side='R', uplo='L'; \ 
  226     BlasIndex m, n, lda, ldb, ldc; \ 
  227     const EIGTYPE *a, *b; \ 
  229     MatrixX##EIGPREFIX b_tmp; \ 
  230     Matrix<EIGTYPE, Dynamic, Dynamic, RhsStorageOrder> a_tmp; \ 
  233     m = convert_index<BlasIndex>(rows); \ 
  234     n = convert_index<BlasIndex>(cols); \ 
  237     lda = convert_index<BlasIndex>(rhsStride); \ 
  238     ldb = convert_index<BlasIndex>(lhsStride); \ 
  239     ldc = convert_index<BlasIndex>(resStride); \ 
  242     if (((RhsStorageOrder==ColMajor) && ConjugateRhs) || ((RhsStorageOrder==RowMajor) && (!ConjugateRhs))) { \ 
  243       Map<const Matrix<EIGTYPE, Dynamic, Dynamic, RhsStorageOrder>, 0, OuterStride<> > rhs(_rhs,n,n,OuterStride<>(rhsStride)); \ 
  244       a_tmp = rhs.conjugate(); \ 
  246       lda = convert_index<BlasIndex>(a_tmp.outerStride()); \ 
  248     if (RhsStorageOrder==RowMajor) uplo='U'; \ 
  250     if (LhsStorageOrder==ColMajor && (!ConjugateLhs)) { \ 
  253       if (LhsStorageOrder==ColMajor && ConjugateLhs) { \ 
  254         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > lhs(_lhs,m,n,OuterStride<>(lhsStride)); \ 
  255         b_tmp = lhs.conjugate(); \ 
  257       if (ConjugateLhs) { \ 
  258         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > lhs(_lhs,n,m,OuterStride<>(lhsStride)); \ 
  259         b_tmp = lhs.adjoint(); \ 
  261         Map<const MatrixX##EIGPREFIX, 0, OuterStride<> > lhs(_lhs,n,m,OuterStride<>(lhsStride)); \ 
  262         b_tmp = lhs.transpose(); \ 
  265       ldb = convert_index<BlasIndex>(b_tmp.outerStride()); \ 
  268     BLASFUNC(&side, &uplo, &m, &n, (const BLASTYPE*)&numext::real_ref(alpha), (const BLASTYPE*)a, &lda, (const BLASTYPE*)b, &ldb, (const BLASTYPE*)&numext::real_ref(beta), (BLASTYPE*)res, &ldc); \ 
  287 #endif // EIGEN_SELFADJOINT_MATRIX_MATRIX_BLAS_H 
  
int BLASFUNC() zhemm(const char *, const char *, const int *, const int *, const double *, const double *, const int *, const double *, const int *, const double *, double *, const int *)
#define EIGEN_BLAS_SYMM_L(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC)
#define EIGEN_BLAS_HEMM_R(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC)
int BLASFUNC() dsymm(const char *, const char *, const int *, const int *, const double *, const double *, const int *, const double *, const int *, const double *, double *, const int *)
#define EIGEN_BLAS_SYMM_R(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC)
int BLASFUNC() ssymm(const char *, const char *, const int *, const int *, const float *, const float *, const int *, const float *, const int *, const float *, float *, const int *)
std::complex< float > scomplex
std::complex< double > dcomplex
#define EIGEN_BLAS_HEMM_L(EIGTYPE, BLASTYPE, EIGPREFIX, BLASFUNC)
int BLASFUNC() chemm(const char *, const char *, const int *, const int *, const float *, const float *, const int *, const float *, const int *, const float *, float *, const int *)
control_box_rst
Author(s): Christoph Rösmann 
autogenerated on Wed Mar 2 2022 00:06:10