From fb71b737e40d7154364ea180fe57a90692b0d925 Mon Sep 17 00:00:00 2001 From: Gael Guennebaud Date: Tue, 16 Nov 2010 19:19:33 +0100 Subject: update blas lib wrt recent change of general_matrix_matrix_triangular_product --- blas/level3_impl.h | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) (limited to 'blas/level3_impl.h') diff --git a/blas/level3_impl.h b/blas/level3_impl.h index a8ef5236e..5b28a1d52 100644 --- a/blas/level3_impl.h +++ b/blas/level3_impl.h @@ -308,7 +308,7 @@ int EIGEN_BLAS_FUNC(symm)(char *side, char *uplo, int *m, int *n, RealScalar *pa int EIGEN_BLAS_FUNC(syrk)(char *uplo, char *op, int *n, int *k, RealScalar *palpha, RealScalar *pa, int *lda, RealScalar *pbeta, RealScalar *pc, int *ldc) { // std::cerr << "in syrk " << *uplo << " " << *op << " " << *n << " " << *k << " " << *palpha << " " << *lda << " " << *pbeta << " " << *ldc << "\n"; - typedef void (*functype)(DenseIndex, DenseIndex, const Scalar *, DenseIndex, Scalar *, DenseIndex, Scalar); + typedef void (*functype)(DenseIndex, DenseIndex, const Scalar *, DenseIndex, const Scalar *, DenseIndex, Scalar *, DenseIndex, Scalar); static functype func[8]; static bool init = false; @@ -317,13 +317,13 @@ int EIGEN_BLAS_FUNC(syrk)(char *uplo, char *op, int *n, int *k, RealScalar *palp for(int k=0; k<8; ++k) func[k] = 0; - func[NOTR | (UP << 2)] = (internal::selfadjoint_product::run); - func[TR | (UP << 2)] = (internal::selfadjoint_product::run); - func[ADJ | (UP << 2)] = (internal::selfadjoint_product::run); + func[NOTR | (UP << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[TR | (UP << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[ADJ | (UP << 2)] = (internal::general_matrix_matrix_triangular_product::run); - func[NOTR | (LO << 2)] = (internal::selfadjoint_product::run); - func[TR | (LO << 2)] = (internal::selfadjoint_product::run); - func[ADJ | (LO << 2)] = (internal::selfadjoint_product::run); + func[NOTR | (LO << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[TR | (LO << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[ADJ | (LO << 2)] = (internal::general_matrix_matrix_triangular_product::run); init = true; } @@ -368,7 +368,7 @@ int EIGEN_BLAS_FUNC(syrk)(char *uplo, char *op, int *n, int *k, RealScalar *palp matrix(c, *n, *n, *ldc).triangularView() += alpha * matrix(a,*k,*n,*lda).transpose() * matrix(a,*k,*n,*lda); } #else - func[code](*n, *k, a, *lda, c, *ldc, alpha); + func[code](*n, *k, a, *lda, a, *lda, c, *ldc, alpha); #endif return 0; @@ -496,7 +496,7 @@ int EIGEN_BLAS_FUNC(hemm)(char *side, char *uplo, int *m, int *n, RealScalar *pa // c = alpha*conj(a')*a + beta*c for op = 'C'or'c' int EIGEN_BLAS_FUNC(herk)(char *uplo, char *op, int *n, int *k, RealScalar *palpha, RealScalar *pa, int *lda, RealScalar *pbeta, RealScalar *pc, int *ldc) { - typedef void (*functype)(DenseIndex, DenseIndex, const Scalar *, DenseIndex, Scalar *, DenseIndex, Scalar); + typedef void (*functype)(DenseIndex, DenseIndex, const Scalar *, DenseIndex, const Scalar *, DenseIndex, Scalar *, DenseIndex, Scalar); static functype func[8]; static bool init = false; @@ -505,11 +505,11 @@ int EIGEN_BLAS_FUNC(herk)(char *uplo, char *op, int *n, int *k, RealScalar *palp for(int k=0; k<8; ++k) func[k] = 0; - func[NOTR | (UP << 2)] = (internal::selfadjoint_product::run); - func[ADJ | (UP << 2)] = (internal::selfadjoint_product::run); + func[NOTR | (UP << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[ADJ | (UP << 2)] = (internal::general_matrix_matrix_triangular_product::run); - func[NOTR | (LO << 2)] = (internal::selfadjoint_product::run); - func[ADJ | (LO << 2)] = (internal::selfadjoint_product::run); + func[NOTR | (LO << 2)] = (internal::general_matrix_matrix_triangular_product::run); + func[ADJ | (LO << 2)] = (internal::general_matrix_matrix_triangular_product::run); init = true; } @@ -544,7 +544,7 @@ int EIGEN_BLAS_FUNC(herk)(char *uplo, char *op, int *n, int *k, RealScalar *palp if(*k>0 && alpha!=RealScalar(0)) { - func[code](*n, *k, a, *lda, c, *ldc, alpha); + func[code](*n, *k, a, *lda, a, *lda, c, *ldc, alpha); matrix(c, *n, *n, *ldc).diagonal().imag().setZero(); } return 0; -- cgit v1.2.3