Bridge++
Ver. 2.0.2
|
GMRES(m) algorithm with complex variables. More...
#include <solver_GMRES_m_Cmplx.h>
Public Member Functions | |
Solver_GMRES_m_Cmplx (Fopr *fopr) | |
Solver_GMRES_m_Cmplx (Fopr *fopr, const Parameters ¶ms) | |
~Solver_GMRES_m_Cmplx () | |
void | set_parameters (const Parameters ¶ms) |
void | set_parameters (const int Niter, const int Nrestart, const double Stop_cond) |
DEPRECATED void | set_parameters (const int Niter, const int Nrestart, const double Stop_cond, const bool use_init_guess) |
DEPRECATED void | set_parameters_GMRES_m (const int N_M) |
void | set_parameters (const int Niter, const int Nrestart, const double Stop_cond, const bool use_init_guess, const int N_M) |
void | get_parameters (Parameters ¶ms) const |
void | solve (Field &solution, const Field &source, int &Nconv, double &diff) |
Fopr * | get_fopr () |
double | flop_count () |
Public Member Functions inherited from Solver | |
Solver () | |
virtual | ~Solver () |
Static Public Attributes | |
static const std::string | class_name = "Solver_GMRES_m_Cmplx" |
Private Member Functions | |
void | reset_field (const Field &) |
void | solve_init (const Field &, double &) |
void | solve_step (const Field &, double &) |
void | innerprod_c (double &prod_r, double &prod_i, const Field &v, const Field &w) |
void | min_J (std::valarray< dcomplex > &y, std::valarray< dcomplex > &h) |
int | index_ij (const int i, const int j) |
Private Attributes | |
Bridge::VerboseLevel | m_vl |
Fopr * | m_fopr |
int | m_Niter |
int | m_Nrestart |
double | m_Stop_cond |
bool | m_use_init_guess |
int | m_N_M |
double | m_beta_prev |
std::vector< Field > | m_v |
Field | m_s |
Field | m_r |
Field | m_x |
Field | m_v_tmp |
int | m_Nrestart_count |
int | m_Nconv_count |
GMRES(m) algorithm with complex variables.
This class implements GMRES(m) algorithm for nonhermitian matrix. The product of vectors is treated in complex. See Y.Saad and M.H.Schultz, SIAM J.Sci.Stat.Comput. 7 (1986) 856. 8 Aug 2012 Y.Namekawa YAML is implemented. [14 Nov 2012 Y.Namekawa] Multi-threaded. [17 Jul 2014 Y.Namekawa] Introduce unique_ptr to avoid memory leaks. [21 Mar 2015 Y.Namekawa] Add restart. [22 Feb 2016 Y.Namekawa] Add flop_count. [ 8 Aug 2016 Y.Namekawa] Add use_init_guess. [ 7 Jul 2017 Y.Namekawa] Fix a bug of h[ij], which is kindly reported by Ji-Chong Yang. [ 7 Mar 2019 Y.Namekawa]
Definition at line 41 of file solver_GMRES_m_Cmplx.h.
|
inline |
Definition at line 68 of file solver_GMRES_m_Cmplx.h.
|
inline |
Definition at line 76 of file solver_GMRES_m_Cmplx.h.
|
inline |
Definition at line 86 of file solver_GMRES_m_Cmplx.h.
|
virtual |
Implements Solver.
Definition at line 439 of file solver_GMRES_m_Cmplx.cpp.
|
inlinevirtual |
Implements Solver.
Definition at line 102 of file solver_GMRES_m_Cmplx.h.
|
virtual |
Implements Solver.
Definition at line 56 of file solver_GMRES_m_Cmplx.cpp.
|
inlineprivate |
Definition at line 118 of file solver_GMRES_m_Cmplx.h.
|
private |
|
private |
Definition at line 385 of file solver_GMRES_m_Cmplx.cpp.
|
private |
Definition at line 278 of file solver_GMRES_m_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 69 of file solver_GMRES_m_Cmplx.cpp.
void Solver_GMRES_m_Cmplx::set_parameters | ( | const int | Niter, |
const int | Nrestart, | ||
const double | Stop_cond, | ||
const bool | use_init_guess | ||
) |
Definition at line 98 of file solver_GMRES_m_Cmplx.cpp.
void Solver_GMRES_m_Cmplx::set_parameters | ( | const int | Niter, |
const int | Nrestart, | ||
const double | Stop_cond, | ||
const bool | use_init_guess, | ||
const int | N_M | ||
) |
Definition at line 149 of file solver_GMRES_m_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 25 of file solver_GMRES_m_Cmplx.cpp.
void Solver_GMRES_m_Cmplx::set_parameters_GMRES_m | ( | const int | N_M | ) |
Definition at line 129 of file solver_GMRES_m_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 190 of file solver_GMRES_m_Cmplx.cpp.
|
private |
Definition at line 308 of file solver_GMRES_m_Cmplx.cpp.
|
private |
Definition at line 335 of file solver_GMRES_m_Cmplx.cpp.
|
static |
Definition at line 44 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 59 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 49 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 56 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 65 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 51 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 52 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 64 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 62 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 62 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 53 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 54 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 61 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 62 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 47 of file solver_GMRES_m_Cmplx.h.
|
private |
Definition at line 62 of file solver_GMRES_m_Cmplx.h.