Bridge++
Ver. 2.0.2
|
BiCGStab(L) algorithm. More...
#include <solver_BiCGStab_L_Cmplx.h>
Public Member Functions | |
Solver_BiCGStab_L_Cmplx (Fopr *fopr) | |
Solver_BiCGStab_L_Cmplx (Fopr *fopr, const Parameters ¶ms) | |
~Solver_BiCGStab_L_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_BiCGStab_series (const double Omega_tolerance) |
DEPRECATED void | set_parameters_L (const int N_L) |
void | set_parameters (const int Niter, const int Nrestart, const double Stop_cond, const bool use_init_guess, const double Omega_tolerance, const int N_L) |
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_BiCGStab_L_Cmplx" |
Private Member Functions | |
void | reset_field (const Field &) |
void | solve_init (const Field &, double &) |
void | solve_step (double &) |
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 |
double | m_Omega_tolerance |
int | m_N_L |
double | m_Tol_L |
dcomplex | m_rho_prev |
dcomplex | m_alpha_prev |
std::vector< Field > | m_u |
std::vector< Field > | m_r |
Field | m_s |
Field | m_x |
Field | m_r_init |
Field | m_v |
int | m_Nrestart_count |
int | m_Nconv_count |
BiCGStab(L) algorithm.
This class implements BiCGStab(L) algorithm for a nonhermitian matrix. The product of vectors is treated in complex. See G.L.G.Sleijpen and D.R.Fokkema, Elec.Trans.Numer.Anal. 1 (1993) 11. 22 Jan 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] Add a prescription to improve stability of BiCGStab, recommended by Kanamori-san. See G.L.G.Sleijpen and H.A.van der Vorst, Numerical Algorithms 10(1995)203-22. [26 Apr 2018 Y.Namekawa]
Definition at line 44 of file solver_BiCGStab_L_Cmplx.h.
|
inline |
Definition at line 73 of file solver_BiCGStab_L_Cmplx.h.
|
inline |
Definition at line 83 of file solver_BiCGStab_L_Cmplx.h.
|
inline |
Definition at line 96 of file solver_BiCGStab_L_Cmplx.h.
|
virtual |
Implements Solver.
Definition at line 486 of file solver_BiCGStab_L_Cmplx.cpp.
|
inlinevirtual |
Implements Solver.
Definition at line 114 of file solver_BiCGStab_L_Cmplx.h.
|
virtual |
Implements Solver.
Definition at line 60 of file solver_BiCGStab_L_Cmplx.cpp.
|
inlineprivate |
Definition at line 124 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 306 of file solver_BiCGStab_L_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 74 of file solver_BiCGStab_L_Cmplx.cpp.
void Solver_BiCGStab_L_Cmplx::set_parameters | ( | const int | Niter, |
const int | Nrestart, | ||
const double | Stop_cond, | ||
const bool | use_init_guess | ||
) |
Definition at line 103 of file solver_BiCGStab_L_Cmplx.cpp.
void Solver_BiCGStab_L_Cmplx::set_parameters | ( | const int | Niter, |
const int | Nrestart, | ||
const double | Stop_cond, | ||
const bool | use_init_guess, | ||
const double | Omega_tolerance, | ||
const int | N_L | ||
) |
Definition at line 170 of file solver_BiCGStab_L_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 25 of file solver_BiCGStab_L_Cmplx.cpp.
void Solver_BiCGStab_L_Cmplx::set_parameters_BiCGStab_series | ( | const double | Omega_tolerance | ) |
Definition at line 134 of file solver_BiCGStab_L_Cmplx.cpp.
void Solver_BiCGStab_L_Cmplx::set_parameters_L | ( | const int | N_L | ) |
Definition at line 150 of file solver_BiCGStab_L_Cmplx.cpp.
|
virtual |
Implements Solver.
Definition at line 218 of file solver_BiCGStab_L_Cmplx.cpp.
|
private |
Definition at line 339 of file solver_BiCGStab_L_Cmplx.cpp.
|
private |
Definition at line 369 of file solver_BiCGStab_L_Cmplx.cpp.
|
static |
Definition at line 47 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 64 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 52 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 60 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 70 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 54 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 54 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 69 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 58 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 66 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 67 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 64 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 67 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 55 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 61 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 66 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 56 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 67 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 50 of file solver_BiCGStab_L_Cmplx.h.
|
private |
Definition at line 67 of file solver_BiCGStab_L_Cmplx.h.