iterative-solver 0.0
SubspaceSolverLinEig.h
1#ifndef LINEARALGEBRA_SRC_MOLPRO_LINALG_ITSOLV_SUBSPACE_SUBSPACESOLVERLINEIG_H
2#define LINEARALGEBRA_SRC_MOLPRO_LINALG_ITSOLV_SUBSPACE_SUBSPACESOLVERLINEIG_H
3#include <molpro/linalg/itsolv/subspace/ISubspaceSolver.h>
4#include <molpro/linalg/itsolv/subspace/IXSpace.h>
5#include <molpro/linalg/itsolv/subspace/Matrix.h>
6#include <molpro/linalg/itsolv/Logger.h>
7#include <molpro/linalg/itsolv/helper.h>
8
9#include <memory>
10
12
16template <class RT, class QT, class PT>
17class SubspaceSolverLinEig : public ISubspaceSolver<RT, QT, PT> {
18public:
24
25 explicit SubspaceSolverLinEig(std::shared_ptr<Logger> logger) : m_logger(std::move(logger)) {}
26
27 void solve(IXSpace<R, Q, P>& xspace, const size_t nroots_max) override {
28 m_logger->trace("SubspaceSolverLinEig::solve");
29 if (xspace.data.find(EqnData::rhs) == xspace.data.end() || xspace.data[EqnData::rhs].empty()) {
30 solve_eigenvalue(xspace, nroots_max);
31 } else {
33 }
34 }
35
36protected:
38 switch (verbosity) {
40 return 3;
42 return 2;
44 return 1;
46 return 0;
47 }
48
49 return 0;
50 }
51
52 void solve_eigenvalue(IXSpace<R, Q, P>& xspace, const size_t nroots_max) {
53 m_logger->trace("SubspaceSolverLinEig::solve_eigenvalue");
54 auto h = xspace.data[EqnData::H];
55 auto s = xspace.data[EqnData::S];
56 m_logger->data_dump("S = ", s);
57 m_logger->data_dump<15>("H = ", h);
58 auto dim = h.rows();
59 auto evec = std::vector<value_type>{};
60 int verbosity = convert_verbosity(m_logger->verbosity());
61 itsolv::eigenproblem(evec, m_eigenvalues, h.data(), s.data(), dim, m_hermitian, m_svd_solver_threshold, verbosity,
62 true);
63 size_t n_solutions = 0;
64 if (dim)
65 n_solutions = evec.size() / dim;
66 auto full_matrix = Matrix<value_type>{std::move(evec), {n_solutions, dim}};
67 auto nroots = std::min(nroots_max, n_solutions);
68 m_eigenvalues.resize(nroots);
69 m_solutions.resize({nroots, dim});
70 m_solutions.slice() = full_matrix.slice({0, 0}, {nroots, dim});
71 m_errors.assign(size(), std::numeric_limits<value_type_abs>::max());
72 m_logger->data_dump<10>("eigenvalues = ", m_eigenvalues);
73 m_logger->data_dump("eigenvectors = ", m_solutions);
74 }
75
77 m_logger->trace("SubspaceSolverLinEig::solve_linear_equations");
78 auto h = xspace.data[EqnData::H];
79 auto s = xspace.data[EqnData::S];
80 auto rhs = xspace.data[EqnData::rhs];
81 m_logger->data_dump<15>("S = ", s);
82 m_logger->data_dump<15>("H = ", h);
83 m_logger->data_dump<15>("rhs = ", rhs);
84 const auto dim = h.rows();
85 const auto n_solutions = rhs.cols();
86 auto solution = std::vector<value_type>{};
87 m_eigenvalues.assign(n_solutions, 0);
88 int verbosity = convert_verbosity(m_logger->verbosity());
89 itsolv::solve_LinearEquations(solution, m_eigenvalues, h.data(), s.data(), rhs.data(), dim, n_solutions,
91 m_solutions = Matrix<value_type>{std::move(solution), {n_solutions, dim}};
92 m_errors.assign(size(), std::numeric_limits<value_type_abs>::max());
93 m_logger->data_dump<10>("eigenvalues = ", m_eigenvalues);
94 m_logger->data_dump("solutions = ", m_solutions);
95 }
96
97public:
99 void set_error(int root, value_type_abs error) override { m_errors.at(root) = error; }
100 void set_error(const std::vector<int>& roots, const std::vector<value_type_abs>& errors) override {
101 for (size_t i = 0; i < roots.size(); ++i)
102 set_error(roots[i], errors[i]);
103 }
104
105 const Matrix<value_type>& solutions() const override { return m_solutions; }
106 const std::vector<value_type>& eigenvalues() const override { return m_eigenvalues; }
107 const std::vector<value_type_abs>& errors() const override { return m_errors; }
108
110 size_t size() const override { return m_solutions.rows(); }
111
112 void set_logger(std::shared_ptr<Logger> logger) override { m_logger = std::move(logger); }
113
114 // FIXME What difference does it make?
116 void set_hermiticity(bool hermitian) { m_hermitian = hermitian; }
117 bool get_hermiticity() { return m_hermitian; }
119 void set_augmented_hessian(double parameter) { m_augmented_hessian = parameter; }
121
122protected:
124 std::vector<value_type> m_eigenvalues;
125 std::vector<value_type_abs> m_errors;
126 std::shared_ptr<Logger> m_logger{};
127
128public:
130protected:
131 bool m_hermitian = false;
133};
134
135} // namespace molpro::linalg::itsolv::subspace
136
137#endif // LINEARALGEBRA_SRC_MOLPRO_LINALG_ITSOLV_SUBSPACE_SUBSPACESOLVERLINEIG_H
SubspaceData data
Equation data in the subspace.
Definition: IXSpace.h:28
Slice slice(coord_type upper_left, coord_type bottom_right)
Access a rectangular slice of the matrix.
Definition: Matrix.h:99
void resize(const coord_type &dims)
Resize the matrix. The old data is preserved and any new rows/cols are zeroed.
Definition: Matrix.h:128
index_type rows() const
Definition: Matrix.h:167
Solves subspace problem for linear eigenvalues and system of linear equations.
Definition: SubspaceSolverLinEig.h:17
std::vector< value_type_abs > m_errors
errors in subspace solutions
Definition: SubspaceSolverLinEig.h:125
typename ISubspaceSolver< RT, QT, PT >::value_type_abs value_type_abs
Definition: SubspaceSolverLinEig.h:20
void set_error(const std::vector< int > &roots, const std::vector< value_type_abs > &errors) override
Update errors for a group of roots.
Definition: SubspaceSolverLinEig.h:100
double get_augmented_hessian()
Definition: SubspaceSolverLinEig.h:120
void set_logger(std::shared_ptr< Logger > logger) override
Definition: SubspaceSolverLinEig.h:112
void set_error(int root, value_type_abs error) override
Set error value for solution root
Definition: SubspaceSolverLinEig.h:99
void solve_eigenvalue(IXSpace< R, Q, P > &xspace, const size_t nroots_max)
Definition: SubspaceSolverLinEig.h:52
value_type_abs m_svd_solver_threshold
threshold to select null space during SVD in eigenproblem
Definition: SubspaceSolverLinEig.h:129
std::vector< value_type > m_eigenvalues
eigenvalues
Definition: SubspaceSolverLinEig.h:124
bool get_hermiticity()
Definition: SubspaceSolverLinEig.h:117
Matrix< value_type > m_solutions
solution matrix with row vectors
Definition: SubspaceSolverLinEig.h:123
std::shared_ptr< Logger > m_logger
Definition: SubspaceSolverLinEig.h:126
const std::vector< value_type > & eigenvalues() const override
Access eigenvalues from the last solve() call.
Definition: SubspaceSolverLinEig.h:106
typename ISubspaceSolver< RT, QT, PT >::value_type value_type
Definition: SubspaceSolverLinEig.h:19
void set_augmented_hessian(double parameter)
Set value of augmented hessian parameter. If 0, than augmented Hessian is not used.
Definition: SubspaceSolverLinEig.h:119
void solve(IXSpace< R, Q, P > &xspace, const size_t nroots_max) override
Solve the subspace problem.
Definition: SubspaceSolverLinEig.h:27
void set_hermiticity(bool hermitian)
Set Hermiticity of the subspace.
Definition: SubspaceSolverLinEig.h:116
const std::vector< value_type_abs > & errors() const override
Access errors corresponding to each solution.
Definition: SubspaceSolverLinEig.h:107
int convert_verbosity(log::Verbosity verbosity)
Definition: SubspaceSolverLinEig.h:37
double m_augmented_hessian
value of augmented hessian parameter. If 0, than augmented Hessian is not used
Definition: SubspaceSolverLinEig.h:132
SubspaceSolverLinEig(std::shared_ptr< Logger > logger)
Definition: SubspaceSolverLinEig.h:25
void solve_linear_equations(IXSpace< R, Q, P > &xspace)
Definition: SubspaceSolverLinEig.h:76
const Matrix< value_type > & solutions() const override
Access solutions from the last solve() call.
Definition: SubspaceSolverLinEig.h:105
bool m_hermitian
flags the matrix as Hermitian
Definition: SubspaceSolverLinEig.h:131
size_t size() const override
Number of solutions.
Definition: SubspaceSolverLinEig.h:110
Verbosity
Different levels of logging.
Definition: Logger.h:29
Definition: PSpace.h:7
void solve_LinearEquations(std::vector< value_type > &solution, std::vector< value_type > &eigenvalues, const std::vector< value_type > &matrix, const std::vector< value_type > &metric, const std::vector< value_type > &rhs, size_t dimension, size_t nroot, double augmented_hessian, double svdThreshold, int verbosity)
Definition: helper-implementation.h:486
void eigenproblem(std::vector< value_type > &eigenvectors, std::vector< value_type > &eigenvalues, const std::vector< value_type > &matrix, const std::vector< value_type > &metric, size_t dimension, bool hermitian, double svdThreshold, int verbosity, bool condone_complex)
Definition: helper-implementation.h:316
Manages solution of the subspace problem and storage of those solutions.
Definition: ISubspaceSolver.h:21
typename array::ArrayHandler< R, R >::value_type value_type
Definition: ISubspaceSolver.h:25
typename array::ArrayHandler< R, R >::value_type_abs value_type_abs
Definition: ISubspaceSolver.h:26
PT P
Definition: ISubspaceSolver.h:24
QT Q
Definition: ISubspaceSolver.h:23
RT R
Definition: ISubspaceSolver.h:22