11#ifndef TLAPACK_BLAS_SYRK_HH
12#define TLAPACK_BLAS_SYRK_HH
54 class T = type_t<matrixC_t>,
55 disable_if_allow_optblas_t<pair<matrixA_t, T>,
58 pair<beta_t, T> > = 0>
71 const idx_t n = (
trans == Op::NoTrans) ? nrows(
A) : ncols(
A);
72 const idx_t
k = (
trans == Op::NoTrans) ? ncols(
A) : nrows(
A);
76 uplo != Uplo::General);
81 if (
trans == Op::NoTrans) {
82 if (
uplo != Uplo::Lower) {
84 for (idx_t j = 0; j < n; ++j) {
85 for (idx_t i = 0; i <= j; ++i)
88 for (idx_t
l = 0;
l <
k; ++
l) {
90 for (idx_t i = 0; i <= j; ++i)
96 for (idx_t j = 0; j < n; ++j) {
97 for (idx_t i = j; i < n; ++i)
100 for (idx_t
l = 0;
l <
k; ++
l) {
102 for (idx_t i = j; i < n; ++i)
109 if (
uplo != Uplo::Lower) {
111 for (idx_t j = 0; j < n; ++j) {
112 for (idx_t i = 0; i <= j; ++i) {
114 for (idx_t
l = 0;
l <
k; ++
l)
121 for (idx_t j = 0; j < n; ++j) {
122 for (idx_t i = j; i < n; ++i) {
124 for (idx_t
l = 0;
l <
k; ++
l)
132 if (
uplo == Uplo::General) {
133 for (idx_t j = 0; j < n; ++j) {
134 for (idx_t i = j + 1; i < n; ++i)
140#ifdef TLAPACK_USE_LAPACKPP
159 class T = type_t<matrixC_t>,
160 enable_if_allow_optblas_t<pair<matrixA_t, T>,
163 pair<beta_t, T> > = 0>
172 auto A_ = legacy_matrix(A);
173 auto C_ = legacy_matrix(C);
176 constexpr Layout L = layout<matrixC_t>;
177 const auto& n = C_.n;
178 const auto& k = (trans == Op::NoTrans) ? A_.n : A_.m;
181 if (alpha == alpha_t(0))
183 "Infs and NaNs in A will not propagate to C on output");
184 if (beta == beta_t(0) && !is_same_v<beta_t, StrongZero>)
187 "Infs and NaNs in C on input will not propagate to C on output");
189 return ::blas::syrk((::blas::Layout)L, (::blas::Uplo)uplo,
190 (::blas::Op)trans, n, k, alpha, A_.ptr, A_.ldim,
191 (T)beta, C_.ptr, C_.ldim);
Op
Definition types.hpp:227
Uplo
Definition types.hpp:50
#define TLAPACK_SCALAR
Macro for tlapack::concepts::Scalar compatible with C++17.
Definition concepts.hpp:915
#define TLAPACK_LEGACY_MATRIX
Macro for tlapack::concepts::LegacyMatrix compatible with C++17.
Definition concepts.hpp:951
#define TLAPACK_MATRIX
Macro for tlapack::concepts::Matrix compatible with C++17.
Definition concepts.hpp:896
void syrk(Uplo uplo, Op trans, const alpha_t &alpha, const matrixA_t &A, const beta_t &beta, matrixC_t &C)
Symmetric rank-k update:
Definition syrk.hpp:59
#define tlapack_check_false(cond)
Throw an error if cond is true.
Definition exceptionHandling.hpp:113
#define tlapack_warning(info, detailedInfo)
Warning handler.
Definition exceptionHandling.hpp:156
Concept for types that represent tlapack::Op.
Concept for types that represent tlapack::Uplo.
typename traits::real_type_traits< Types..., int >::type real_type
The common real type of the list of types.
Definition scalar_type_traits.hpp:113
Strong zero type.
Definition StrongZero.hpp:43