Bridge++  Ver. 2.0.2
Solver_GMRES_m_Cmplx Class Reference

GMRES(m) algorithm with complex variables. More...

#include <solver_GMRES_m_Cmplx.h>

Inheritance diagram for Solver_GMRES_m_Cmplx:
Solver

Public Member Functions

 Solver_GMRES_m_Cmplx (Fopr *fopr)
 
 Solver_GMRES_m_Cmplx (Fopr *fopr, const Parameters &params)
 
 ~Solver_GMRES_m_Cmplx ()
 
void set_parameters (const Parameters &params)
 
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 &params) const
 
void solve (Field &solution, const Field &source, int &Nconv, double &diff)
 
Foprget_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
 
Foprm_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< Fieldm_v
 
Field m_s
 
Field m_r
 
Field m_x
 
Field m_v_tmp
 
int m_Nrestart_count
 
int m_Nconv_count
 

Detailed Description

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.

Constructor & Destructor Documentation

◆ Solver_GMRES_m_Cmplx() [1/2]

Solver_GMRES_m_Cmplx::Solver_GMRES_m_Cmplx ( Fopr fopr)
inline

Definition at line 68 of file solver_GMRES_m_Cmplx.h.

◆ Solver_GMRES_m_Cmplx() [2/2]

Solver_GMRES_m_Cmplx::Solver_GMRES_m_Cmplx ( Fopr fopr,
const Parameters params 
)
inline

Definition at line 76 of file solver_GMRES_m_Cmplx.h.

◆ ~Solver_GMRES_m_Cmplx()

Solver_GMRES_m_Cmplx::~Solver_GMRES_m_Cmplx ( )
inline

Definition at line 86 of file solver_GMRES_m_Cmplx.h.

Member Function Documentation

◆ flop_count()

double Solver_GMRES_m_Cmplx::flop_count ( )
virtual

Implements Solver.

Definition at line 439 of file solver_GMRES_m_Cmplx.cpp.

◆ get_fopr()

Fopr* Solver_GMRES_m_Cmplx::get_fopr ( )
inlinevirtual

Implements Solver.

Definition at line 102 of file solver_GMRES_m_Cmplx.h.

◆ get_parameters()

void Solver_GMRES_m_Cmplx::get_parameters ( Parameters params) const
virtual

Implements Solver.

Definition at line 56 of file solver_GMRES_m_Cmplx.cpp.

◆ index_ij()

int Solver_GMRES_m_Cmplx::index_ij ( const int  i,
const int  j 
)
inlineprivate

Definition at line 118 of file solver_GMRES_m_Cmplx.h.

◆ innerprod_c()

void Solver_GMRES_m_Cmplx::innerprod_c ( double &  prod_r,
double &  prod_i,
const Field v,
const Field w 
)
private

◆ min_J()

void Solver_GMRES_m_Cmplx::min_J ( std::valarray< dcomplex > &  y,
std::valarray< dcomplex > &  h 
)
private

Definition at line 385 of file solver_GMRES_m_Cmplx.cpp.

◆ reset_field()

void Solver_GMRES_m_Cmplx::reset_field ( const Field b)
private

Definition at line 278 of file solver_GMRES_m_Cmplx.cpp.

◆ set_parameters() [1/4]

void Solver_GMRES_m_Cmplx::set_parameters ( const int  Niter,
const int  Nrestart,
const double  Stop_cond 
)
virtual

Implements Solver.

Definition at line 69 of file solver_GMRES_m_Cmplx.cpp.

◆ set_parameters() [2/4]

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.

◆ set_parameters() [3/4]

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.

◆ set_parameters() [4/4]

void Solver_GMRES_m_Cmplx::set_parameters ( const Parameters params)
virtual

Implements Solver.

Definition at line 25 of file solver_GMRES_m_Cmplx.cpp.

◆ set_parameters_GMRES_m()

void Solver_GMRES_m_Cmplx::set_parameters_GMRES_m ( const int  N_M)

Definition at line 129 of file solver_GMRES_m_Cmplx.cpp.

◆ solve()

void Solver_GMRES_m_Cmplx::solve ( Field solution,
const Field source,
int &  Nconv,
double &  diff 
)
virtual

Implements Solver.

Definition at line 190 of file solver_GMRES_m_Cmplx.cpp.

◆ solve_init()

void Solver_GMRES_m_Cmplx::solve_init ( const Field b,
double &  rr 
)
private

Definition at line 308 of file solver_GMRES_m_Cmplx.cpp.

◆ solve_step()

void Solver_GMRES_m_Cmplx::solve_step ( const Field b,
double &  rr 
)
private

Definition at line 335 of file solver_GMRES_m_Cmplx.cpp.

Member Data Documentation

◆ class_name

const std::string Solver_GMRES_m_Cmplx::class_name = "Solver_GMRES_m_Cmplx"
static

Definition at line 44 of file solver_GMRES_m_Cmplx.h.

◆ m_beta_prev

double Solver_GMRES_m_Cmplx::m_beta_prev
private

Definition at line 59 of file solver_GMRES_m_Cmplx.h.

◆ m_fopr

Fopr* Solver_GMRES_m_Cmplx::m_fopr
private

Definition at line 49 of file solver_GMRES_m_Cmplx.h.

◆ m_N_M

int Solver_GMRES_m_Cmplx::m_N_M
private

Definition at line 56 of file solver_GMRES_m_Cmplx.h.

◆ m_Nconv_count

int Solver_GMRES_m_Cmplx::m_Nconv_count
private

Definition at line 65 of file solver_GMRES_m_Cmplx.h.

◆ m_Niter

int Solver_GMRES_m_Cmplx::m_Niter
private

Definition at line 51 of file solver_GMRES_m_Cmplx.h.

◆ m_Nrestart

int Solver_GMRES_m_Cmplx::m_Nrestart
private

Definition at line 52 of file solver_GMRES_m_Cmplx.h.

◆ m_Nrestart_count

int Solver_GMRES_m_Cmplx::m_Nrestart_count
private

Definition at line 64 of file solver_GMRES_m_Cmplx.h.

◆ m_r

Field Solver_GMRES_m_Cmplx::m_r
private

Definition at line 62 of file solver_GMRES_m_Cmplx.h.

◆ m_s

Field Solver_GMRES_m_Cmplx::m_s
private

Definition at line 62 of file solver_GMRES_m_Cmplx.h.

◆ m_Stop_cond

double Solver_GMRES_m_Cmplx::m_Stop_cond
private

Definition at line 53 of file solver_GMRES_m_Cmplx.h.

◆ m_use_init_guess

bool Solver_GMRES_m_Cmplx::m_use_init_guess
private

Definition at line 54 of file solver_GMRES_m_Cmplx.h.

◆ m_v

std::vector<Field> Solver_GMRES_m_Cmplx::m_v
private

Definition at line 61 of file solver_GMRES_m_Cmplx.h.

◆ m_v_tmp

Field Solver_GMRES_m_Cmplx::m_v_tmp
private

Definition at line 62 of file solver_GMRES_m_Cmplx.h.

◆ m_vl

Bridge::VerboseLevel Solver_GMRES_m_Cmplx::m_vl
private

Definition at line 47 of file solver_GMRES_m_Cmplx.h.

◆ m_x

Field Solver_GMRES_m_Cmplx::m_x
private

Definition at line 62 of file solver_GMRES_m_Cmplx.h.


The documentation for this class was generated from the following files: