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);
 
   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));
 
 
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
Sort the numbers in D in increasing order (if ID = 'I') or in decreasing order (if ID = 'D' ).
Definition arrayTraits.hpp:15
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
constexpr real_type< T > real(const T &x) noexcept
Extends std::real() to real datatypes.
Definition utils.hpp:71
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
@ Upper
0 <= i <= j, 0 <= j <= n.
@ Lower
0 <= i <= m, 0 <= j <= i.