QUDA  1.0.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
Public Member Functions | Private Attributes | List of all members
quda::CG Class Reference

Conjugate-Gradient Solver. More...

#include <invert_quda.h>

Inheritance diagram for quda::CG:
Inheritance graph
[legend]
Collaboration diagram for quda::CG:
Collaboration graph
[legend]

Public Member Functions

 CG (DiracMatrix &mat, DiracMatrix &matSloppy, SolverParam &param, TimeProfile &profile)
 
virtual ~CG ()
 
void operator() (ColorSpinorField &out, ColorSpinorField &in)
 Run CG. More...
 
void operator() (ColorSpinorField &out, ColorSpinorField &in, ColorSpinorField *p_init, double r2_old_init)
 Solve re-using an initial Krylov space defined by an initial r2_old_init and search direction p_init. More...
 
void blocksolve (ColorSpinorField &out, ColorSpinorField &in)
 
- Public Member Functions inherited from quda::Solver
 Solver (SolverParam &param, TimeProfile &profile)
 
virtual ~Solver ()
 
bool convergence (double r2, double hq2, double r2_tol, double hq_tol)
 
bool convergenceHQ (double r2, double hq2, double r2_tol, double hq_tol)
 Test for HQ solver convergence – ignore L2 residual. More...
 
bool convergenceL2 (double r2, double hq2, double r2_tol, double hq_tol)
 Test for L2 solver convergence – ignore HQ residual. More...
 
void PrintStats (const char *name, int k, double r2, double b2, double hq2)
 Prints out the running statistics of the solver (requires a verbosity of QUDA_VERBOSE) More...
 
void PrintSummary (const char *name, int k, double r2, double b2, double r2_tol, double hq_tol)
 Prints out the summary of the solver convergence (requires a verbosity of QUDA_SUMMARIZE). Assumes SolverParam.true_res and SolverParam.true_res_hq has been set. More...
 
void constructDeflationSpace (const ColorSpinorField &meta, const DiracMatrix &mat, bool svd)
 Constructs the deflation space. More...
 
virtual double flops () const
 

Private Attributes

const DiracMatrixmat
 
const DiracMatrixmatSloppy
 
ColorSpinorFieldyp
 
ColorSpinorFieldrp
 
ColorSpinorFieldrnewp
 
ColorSpinorFieldpp
 
ColorSpinorFieldApp
 
ColorSpinorFieldtmpp
 
ColorSpinorFieldtmp2p
 
ColorSpinorFieldtmp3p
 
ColorSpinorFieldrSloppyp
 
ColorSpinorFieldxSloppyp
 
std::vector< ColorSpinorField * > p
 
bool init
 

Additional Inherited Members

- Static Public Member Functions inherited from quda::Solver
static Solvercreate (SolverParam &param, DiracMatrix &mat, DiracMatrix &matSloppy, DiracMatrix &matPrecon, TimeProfile &profile)
 
static double stopping (double tol, double b2, QudaResidualType residual_type)
 Set the solver L2 stopping condition. More...
 
- Public Attributes inherited from quda::Solver
EigenSolvereig_solve
 
bool deflate_init = false
 
std::vector< ColorSpinorField * > defl_tmp1
 
std::vector< ColorSpinorField * > defl_tmp2
 
- Protected Attributes inherited from quda::Solver
SolverParamparam
 
TimeProfileprofile
 
int node_parity
 

Detailed Description

Conjugate-Gradient Solver.

Definition at line 570 of file invert_quda.h.

Constructor & Destructor Documentation

◆ CG()

quda::CG::CG ( DiracMatrix mat,
DiracMatrix matSloppy,
SolverParam param,
TimeProfile profile 
)

Definition at line 22 of file inv_cg_quda.cpp.

◆ ~CG()

quda::CG::~CG ( )
virtual

Member Function Documentation

◆ blocksolve()

void quda::CG::blocksolve ( ColorSpinorField out,
ColorSpinorField in 
)
virtual

Reimplemented from quda::Solver.

Definition at line 754 of file inv_cg_quda.cpp.

References App, quda::blas::ax(), quda::blas::axpy(), quda::blas::caxpy(), quda::blas::cDotProduct(), checkLocation, quda::ColorSpinorField::Component(), quda::conj(), conj(), quda::Solver::convergence(), quda::Solver::convergenceHQ(), quda::Solver::convergenceL2(), quda::blas::copy(), quda::ColorSpinorParam::create, quda::ColorSpinorField::Create(), csParam, quda::SolverParam::delta, errorQuda, quda::blas::flops, quda::DiracMatrix::flops(), getVerbosity(), quda::SolverParam::gflops, quda::SolverParam::heavy_quark_check, quda::blas::HeavyQuarkResidualNorm(), quda::CGNR::init, quda::DiracMatrix::isStaggered(), quda::SolverParam::iter, quda::TimeProfile::Last(), mat, matSloppy, quda::SolverParam::max_res_increase, quda::SolverParam::max_res_increase_total, quda::SolverParam::maxiter, quda::blas::norm2(), quda::SolverParam::num_src, p, quda::Solver::param, quda::SolverParam::pipeline, pp, quda::SolverParam::precision, quda::SolverParam::precision_sloppy, printfQuda, quda::Solver::PrintStats(), quda::Solver::PrintSummary(), quda::Solver::profile, QUDA_CUDA_FIELD_LOCATION, QUDA_HEAVY_QUARK_RESIDUAL, QUDA_MAX_MULTI_SHIFT, quda::QUDA_PROFILE_COMPUTE, quda::QUDA_PROFILE_EPILOGUE, quda::QUDA_PROFILE_FREE, quda::QUDA_PROFILE_INIT, quda::QUDA_PROFILE_PREAMBLE, QUDA_VERBOSE, QUDA_ZERO_FIELD_CREATE, quda::blas::reDotProduct(), quda::SolverParam::residual_type, rnewp, rp, rSloppyp, quda::SolverParam::secs, quda::ColorSpinorParam::setPrecision(), quda::sqrt(), quda::Solver::stopping(), tmp, tmp2, tmp2p, tmp3p, tmpp, quda::SolverParam::tol, quda::SolverParam::tol_hq, quda::SolverParam::true_res, quda::SolverParam::true_res_hq, quda::SolverParam::true_res_hq_offset, quda::SolverParam::true_res_offset, updateR(), quda::SolverParam::use_sloppy_partial_accumulator, warningQuda, quda::blas::xmyNorm(), quda::blas::xpay(), quda::blas::xpy(), quda::blas::xpyHeavyQuarkResidualNorm(), xSloppyp, yp, and quda::blas::zero().

Here is the call graph for this function:

◆ operator()() [1/2]

void quda::CG::operator() ( ColorSpinorField out,
ColorSpinorField in 
)
inlinevirtual

Run CG.

Parameters
outSolution vector.
inRight-hand side.

Implements quda::Solver.

Reimplemented in quda::CGNR, and quda::CGNE.

Definition at line 588 of file invert_quda.h.

References in, and out.

Referenced by quda::CGNE::operator()(), and quda::CGNR::operator()().

Here is the caller graph for this function:

◆ operator()() [2/2]

void quda::CG::operator() ( ColorSpinorField out,
ColorSpinorField in,
ColorSpinorField p_init,
double  r2_old_init 
)

Solve re-using an initial Krylov space defined by an initial r2_old_init and search direction p_init.

This can be used when continuing a CG, e.g. as refinement step after a multi-shift solve.

Parameters
outSolution-vector.
inRight-hand side.
p_initInitial-search direction.
r2_old_init[description]

Definition at line 206 of file inv_cg_quda.cpp.

References alternative_reliable, App, quda::blas::axpy(), quda::blas::axpyCGNorm(), quda::blas::axpyNorm(), quda::blas::axpyZpbx(), quda::blas::caxpy(), quda::blas::cDotProduct(), quda::blas::cDotProductNormA(), checkLocation, checkPrecision, quda::SolverParam::compute_null_vector, quda::SolverParam::compute_true_res, quda::Solver::constructDeflationSpace(), quda::Solver::convergence(), quda::Solver::convergenceHQ(), quda::Solver::convergenceL2(), quda::blas::copy(), quda::ColorSpinorParam::create, quda::ColorSpinorField::Create(), csParam, quda::Solver::defl_tmp1, quda::SolverParam::deflate, quda::EigenSolver::deflate(), quda::Solver::deflate_init, quda::SolverParam::delta, quda::Solver::eig_solve, epsilon, errorQuda, quda::SolverParam::evals, quda::SolverParam::evecs, quda::blas::flops, quda::DiracMatrix::flops(), getVerbosity(), quda::SolverParam::gflops, quda::SolverParam::heavy_quark_check, quda::blas::HeavyQuarkResidualNorm(), quda::CGNR::init, quda::DiracMatrix::isStaggered(), quda::SolverParam::iter, quda::TimeProfile::Last(), mat, matSloppy, quda::SolverParam::max_hq_res_increase, quda::SolverParam::max_hq_res_restart_total, quda::SolverParam::max_res_increase, quda::SolverParam::max_res_increase_total, quda::SolverParam::maxiter, quda::blas::norm2(), quda::SolverParam::Nsteps, p, quda::Solver::param, quda::SolverParam::pipeline, quda::pow(), quda::SolverParam::precision, quda::LatticeField::Precision(), quda::SolverParam::precision_sloppy, printfQuda, quda::Solver::PrintStats(), quda::Solver::PrintSummary(), quda::Solver::profile, quda::blas::quadrupleCGReduction(), QUDA_COMPUTE_NULL_VECTOR_NO, QUDA_COPY_FIELD_CREATE, QUDA_CUDA_FIELD_LOCATION, QUDA_DEBUG_VERBOSE, QUDA_HEAVY_QUARK_RESIDUAL, QUDA_NULL_FIELD_CREATE, quda::QUDA_PROFILE_COMPUTE, quda::QUDA_PROFILE_EPILOGUE, quda::QUDA_PROFILE_INIT, quda::QUDA_PROFILE_PREAMBLE, QUDA_USE_INIT_GUESS_NO, QUDA_USE_INIT_GUESS_YES, QUDA_VERBOSE, quda::ColorSpinorField::RealLength(), quda::blas::reDotProduct(), quda::SolverParam::residual_type, rp, rSloppyp, quda::SolverParam::secs, quda::ColorSpinorParam::setPrecision(), quda::SolverParam::solution_accumulator_pipeline, quda::sqrt(), quda::Solver::stopping(), tmp, tmp2, tmp2p, tmp3p, tmpp, quda::SolverParam::tol, quda::SolverParam::tol_hq, quda::blas::tripleCGReduction(), quda::blas::tripleCGUpdate(), quda::SolverParam::true_res, quda::SolverParam::true_res_hq, updateR(), quda::SolverParam::use_alternative_reliable, quda::SolverParam::use_init_guess, quda::SolverParam::use_sloppy_partial_accumulator, warningQuda, quda::blas::xmyNorm(), quda::blas::xpayz(), quda::blas::xpy(), quda::blas::xpyHeavyQuarkResidualNorm(), xSloppyp, yp, and quda::blas::zero().

Here is the call graph for this function:

Member Data Documentation

◆ App

ColorSpinorField * quda::CG::App
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ init

bool quda::CG::init
private

Definition at line 578 of file invert_quda.h.

Referenced by ~CG().

◆ mat

const DiracMatrix& quda::CG::mat
private

Definition at line 573 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ matSloppy

const DiracMatrix& quda::CG::matSloppy
private

Definition at line 574 of file invert_quda.h.

Referenced by blocksolve(), and operator()().

◆ p

std::vector<ColorSpinorField*> quda::CG::p
private

Definition at line 577 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ pp

ColorSpinorField * quda::CG::pp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), and ~CG().

◆ rnewp

ColorSpinorField * quda::CG::rnewp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), and ~CG().

◆ rp

ColorSpinorField * quda::CG::rp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ rSloppyp

ColorSpinorField * quda::CG::rSloppyp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ tmp2p

ColorSpinorField * quda::CG::tmp2p
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ tmp3p

ColorSpinorField * quda::CG::tmp3p
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ tmpp

ColorSpinorField * quda::CG::tmpp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ xSloppyp

ColorSpinorField * quda::CG::xSloppyp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().

◆ yp

ColorSpinorField* quda::CG::yp
private

Definition at line 576 of file invert_quda.h.

Referenced by blocksolve(), operator()(), and ~CG().


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