37template <base::concepts::sparse_matrix Matrix>
38class symmetric_successive_over_relaxation;
47template <base::concepts::sparse_matrix Matrix>
61template <base::concepts::sparse_matrix Matrix>
64 symmetric_successive_over_relaxation<Matrix>> {
65 static_assert(Matrix::IsRowMajor == 1,
"Row major matrix is required.");
67 "Complex matrices are not supported.");
102 "All diagonal elements of the coefficient matrix must not be "
114 template <base::concepts::dense_vector_of<scalar_type> Right,
115 base::concepts::dense_vector_of<scalar_type> Solution>
117 const auto& coeff_ref =
coeff();
120 "Coefficient matrix must be a square matrix.");
122 "Right-hand-side vector must have the number of elements same as "
123 "the size of the coefficient matrix.");
125 "Solution vector must have the number of elements same as the size "
126 "of the coefficient matrix.");
129 const scalar_type right_norm = right.squaredNorm();
132 iterate(coeff_ref, right, solution);
136 "symmetric_successive_over_relaxation.");
179 "Relaxation coefficient must be in the range (0, 2).");
194 template <base::concepts::dense_vector_of<scalar_type> Right,
195 base::concepts::dense_vector_of<scalar_type> Solution>
197 Solution& solution)
const {
206 for (
typename matrix_type::InnerIterator iter(coeff_ref, i); iter;
208 if (iter.index() < i) {
211 }
else if (iter.index() > i) {
212 numerator -= iter.value() * solution(iter.index());
218 prev_sol_coeff * solution(i);
219 residual_ += row_residual * row_residual;
225 for (
typename matrix_type::InnerIterator iter(coeff_ref, i); iter;
227 if (iter.index() < i) {
230 }
else if (iter.index() > i) {
231 numerator -= iter.value() * solution(iter.index());
Class of exception on failure in algorithm.
Base class of iterative solvers.
StorageIndex storage_index_type
auto coeff() const noexcept -> const matrix_type &
auto tolerance() const noexcept -> real_scalar_type
RealScalar real_scalar_type
auto compute(const matrix_type &coeff) -> symmetric_successive_over_relaxation< Matrix > &
auto max_iterations() const noexcept -> index_type
Class to solve linear equations using symmetric successive over-relaxation golub2013.
scalar_type relaxation_coeff_
Relaxation coefficient.
void solve_vector_in_place(const Right &right, Solution &solution) const
Iterate repeatedly until stop criterion is satisfied for a vector.
auto iterations() const noexcept -> index_type
Get the number of iterations.
vector_type inv_diag_
Inverse of diagonal coefficients.
scalar_type residual_
Last residual.
Eigen::VectorX< scalar_type > vector_type
Type of vectors.
void compute(const matrix_type &coeff)
Prepare to solve.
void iterate(const matrix_type &coeff_ref, const Right &right, Solution &solution) const
Iterate once.
vector_type diag_
Diagonal coefficients.
scalar_type residual_rate_
Rate of last residual.
symmetric_successive_over_relaxation()=default
Constructor.
auto relaxation_coeff(const scalar_type &val) -> symmetric_successive_over_relaxation &
Set the relaxation coefficient.
index_type iterations_
Number of iterations.
vector_type intermidiate_solution_
Intermidiate solution vector.
auto residual_rate() const noexcept -> index_type
Get the rate of the last residual.
Definition of dense_vector_of concept.
Definition of exceptions.
Definition of index_type type.
Definition of iterative_solver_base class.
Definition of macros for logging.
#define NUM_COLLECT_LOG_AND_THROW(EXCEPTION_TYPE,...)
Write an error log and throw an exception for an error.
std::ptrdiff_t index_type
Type of indices in this library.
Namespace of solvers of linear equations.
Definition of NUM_COLLECT_PRECONDITION macro.
#define NUM_COLLECT_PRECONDITION(CONDITION,...)
Check whether a precondition is satisfied and throw an exception if not.
Definition of real_scalar concept.
Definition of sparse_matrix concept.
Matrix matrix_type
Type of the matrix.
Traits of iterative solvers.