12#ifndef TLAPACK_HETD2_HH
13#define TLAPACK_HETD2_HH
46template <TLAPACK_SMATRIX A_t, TLAPACK_SVECTOR tau_t,
class uplo_t>
55 const idx_t n = ncols(
A);
68 if (
uplo == Uplo::Upper) {
74 A(n - 1, n - 1) =
real(
A(n - 1, n - 1));
76 for (idx_t i = n - 2; i != idx_t(-1); --i) {
78 auto v = slice(
A, pair{0, i + 1}, i + 1);
87 auto C = slice(
A, pair{0, i + 1}, pair{0, i + 1});
88 auto w = slice(
tau, pair{0, i + 1});
91 auto beta =
A(i, i + 1);
123 for (idx_t i = 0; i < n - 1; ++i) {
125 auto v = slice(
A, pair{i + 1, n}, i);
134 auto C = slice(
A, pair{i + 1, n}, pair{i + 1, n});
135 auto w = slice(
tau, pair{i, n - 1});
138 auto beta =
A(i + 1, i);
156 A(i + 1, i + 1) =
real(
A(i + 1, i + 1));
constexpr internal::LowerTriangle LOWER_TRIANGLE
Lower Triangle access.
Definition types.hpp:188
constexpr internal::UpperTriangle UPPER_TRIANGLE
Upper Triangle access.
Definition types.hpp:186
constexpr internal::Backward BACKWARD
Backward direction.
Definition types.hpp:383
constexpr internal::Forward FORWARD
Forward direction.
Definition types.hpp:381
constexpr internal::ColumnwiseStorage COLUMNWISE_STORAGE
Columnwise storage.
Definition types.hpp:414
constexpr real_type< T > real(const T &x) noexcept
Extends std::real() to real datatypes.
Definition utils.hpp:71
void larfg(storage_t storeMode, type_t< vector_t > &alpha, vector_t &x, type_t< vector_t > &tau)
Generates a elementary Householder reflection.
Definition larfg.hpp:73
auto dot(const vectorX_t &x, const vectorY_t &y)
Definition dot.hpp:32
void axpy(const alpha_t &alpha, const vectorX_t &x, vectorY_t &y)
Add scaled vector, .
Definition axpy.hpp:34
void her2(Uplo uplo, const alpha_t &alpha, const vectorX_t &x, const vectorY_t &y, matrixA_t &A)
Hermitian matrix rank-2 update:
Definition her2.hpp:50
void hemv(Uplo uplo, const alpha_t &alpha, const matrixA_t &A, const vectorX_t &x, const beta_t &beta, vectorY_t &y)
Hermitian matrix-vector multiply:
Definition hemv.hpp:53
int hetd2(uplo_t uplo, A_t &A, tau_t &tau)
Reduce a hermitian matrix to real symmetric tridiagonal form by a unitary similarity transformation: ...
Definition hetd2.hpp:47
#define tlapack_check(cond)
Throw an error if cond is false.
Definition exceptionHandling.hpp:98
#define tlapack_check_false(cond)
Throw an error if cond is true.
Definition exceptionHandling.hpp:113
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