QUDA
v1.1.0
A library for QCD on GPUs
|
#include <dirac_quda.h>
Public Member Functions | |
Dirac (const DiracParam ¶m) | |
Dirac (const Dirac &dirac) | |
virtual | ~Dirac () |
Dirac & | operator= (const Dirac &dirac) |
void | setCommDim (const int commDim_[QUDA_MAX_DIM]) const |
Enable / disable communications for the Dirac operator. More... | |
virtual bool | isCoarse () const |
Whether the Dirac object is the DiracCoarse. More... | |
virtual void | checkParitySpinor (const ColorSpinorField &, const ColorSpinorField &) const |
Check parity spinors are usable (check geometry ?) More... | |
virtual void | checkFullSpinor (const ColorSpinorField &, const ColorSpinorField &) const |
check full spinors are compatible (check geometry ?) More... | |
void | checkSpinorAlias (const ColorSpinorField &, const ColorSpinorField &) const |
check spinors do not alias More... | |
virtual bool | hasDslash () const |
Whether or not the operator has a single-parity Dslash. More... | |
virtual void | Dslash (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity) const =0 |
apply 'dslash' operator for the DiracOp. This may be e.g. AD More... | |
virtual void | DslashXpay (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity, const ColorSpinorField &x, const double &k) const =0 |
Xpay version of Dslash. More... | |
virtual void | M (ColorSpinorField &out, const ColorSpinorField &in) const =0 |
Apply M for the dirac op. E.g. the Schur Complement operator. More... | |
virtual void | MdagM (ColorSpinorField &out, const ColorSpinorField &in) const =0 |
Apply MdagM operator which may be optimized. More... | |
virtual void | MdagMLocal (ColorSpinorField &out, const ColorSpinorField &in) const |
Apply the local MdagM operator: equivalent to applying zero Dirichlet boundary condition to MdagM on each rank. Depending on the number of stencil steps of the fermion type, this may require additional effort to include the terms that hop out of the boundary and then hop back. More... | |
virtual void | Dslash4 (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity) const |
Apply the local MdagM operator: equivalent to applying zero Dirichlet boundary condition to MdagM on each rank. Depending on the number of stencil steps of the fermion type, this may require additional effort to include the terms that hop out of the boundary and then hop back. More... | |
void | Mdag (ColorSpinorField &out, const ColorSpinorField &in) const |
Apply Mdag (daggered operator of M. More... | |
void | MMdag (ColorSpinorField &out, const ColorSpinorField &in) const |
Apply Normal Operator. More... | |
virtual void | prepare (ColorSpinorField *&src, ColorSpinorField *&sol, ColorSpinorField &x, ColorSpinorField &b, const QudaSolutionType solType) const =0 |
virtual void | reconstruct (ColorSpinorField &x, const ColorSpinorField &b, const QudaSolutionType solType) const =0 |
virtual void | prepareSpecialMG (ColorSpinorField *&src, ColorSpinorField *&sol, ColorSpinorField &x, ColorSpinorField &b, const QudaSolutionType solType) const |
virtual void | reconstructSpecialMG (ColorSpinorField &x, const ColorSpinorField &b, const QudaSolutionType solType) const |
virtual bool | hasSpecialMG () const |
specifies whether or not there's a specialized prepare/reconstruct used before/after transfering to/from the coarse level in MG More... | |
void | setMass (double mass) |
double | Kappa () const |
accessor for Kappa (mass parameter) More... | |
virtual double | Mass () const |
accessor for Mass (in case of a factor of 2 for staggered) More... | |
virtual double | Mu () const |
accessor for twist parameter – overrride can return better value More... | |
virtual double | MuFactor () const |
accessor for mu factoo for MG/ – override can return a better value More... | |
unsigned long long | Flops () const |
returns and then zeroes flopcount More... | |
QudaMatPCType | getMatPCType () const |
returns preconditioning type More... | |
int | getStencilSteps () const |
I have no idea what this does. More... | |
void | Dagger (QudaDagType dag) const |
sets whether operator is daggered or not More... | |
void | flipDagger () const |
Flips value of daggered. More... | |
virtual bool | hermitian () const |
is operator hermitian More... | |
virtual QudaDiracType | getDiracType () const =0 |
returns the Dirac type More... | |
virtual void | updateFields (cudaGaugeField *gauge_in, cudaGaugeField *fat_gauge_in, cudaGaugeField *long_gauge_in, cudaCloverField *clover_in) |
Update the internal gauge, fat gauge, long gauge, clover field pointer as appropriate. These are pointers as opposed to references to support passing in nullptr . More... | |
virtual void | createCoarseOp (GaugeField &Y, GaugeField &X, const Transfer &T, double kappa, double mass=0., double mu=0., double mu_factor=0.) const |
Create the coarse operator (virtual parent) More... | |
QudaPrecision | HaloPrecision () const |
void | setHaloPrecision (QudaPrecision halo_precision_) const |
virtual void | prefetch (QudaFieldLocation mem_space, qudaStream_t stream=0) const |
If managed memory and prefetch is enabled, prefetch the gauge field and temporary spinors to the CPU or GPU as requested. Overloads may also grab a clover term. More... | |
Public Member Functions inherited from quda::Object | |
Object () | |
virtual | ~Object () |
Static Public Member Functions | |
static Dirac * | create (const DiracParam ¶m) |
Creates a subclass from parameters. More... | |
Static Public Member Functions inherited from quda::Object | |
static void * | operator new (std::size_t size) |
static void | operator delete (void *p) |
static void * | operator new[] (std::size_t size) |
static void | operator delete[] (void *p) |
Protected Member Functions | |
bool | newTmp (ColorSpinorField **, const ColorSpinorField &) const |
void | deleteTmp (ColorSpinorField **, const bool &reset) const |
Protected Attributes | |
cudaGaugeField * | gauge |
double | kappa |
double | mass |
int | laplace3D |
QudaMatPCType | matpcType |
QudaDagType | dagger |
unsigned long long | flops |
ColorSpinorField * | tmp1 |
ColorSpinorField * | tmp2 |
QudaDiracType | type |
QudaPrecision | halo_precision |
int | commDim [QUDA_MAX_DIM] |
TimeProfile | profile |
Friends | |
class | DiracMatrix |
class | DiracM |
class | DiracMdagM |
class | DiracMdagMLocal |
class | DiracMMdag |
class | DiracMdag |
class | DiracG5M |
Definition at line 133 of file dirac_quda.h.
quda::Dirac::Dirac | ( | const DiracParam & | param | ) |
|
virtual |
|
virtual |
Check parity spinors are usable (check geometry ?)
Reimplemented in quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggered, quda::DiracTwistedClover, and quda::DiracClover.
void quda::Dirac::checkSpinorAlias | ( | const ColorSpinorField & | a, |
const ColorSpinorField & | b | ||
) | const |
|
static |
|
inlinevirtual |
Create the coarse operator (virtual parent)
Y[out] | Coarse link field |
X[out] | Coarse clover field |
T[in] | Transfer operator defining the coarse grid |
kappa | Kappa parameter for the coarse operator |
mass | Mass parameter for the coarse operator (gets explicitly built into clover, hard coded to zero for non-staggered ops) |
mu | TM mu parameter for the coarse operator |
mu_factor | multiplicative factor for the mu parameter |
Reimplemented in quda::DiracCloverHasenbuschTwistPC, quda::DiracCloverHasenbuschTwist, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilson, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggered, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, and quda::DiracTwistedMass.
Definition at line 377 of file dirac_quda.h.
|
inline |
sets whether operator is daggered or not
Definition at line 333 of file dirac_quda.h.
|
protected |
|
pure virtual |
apply 'dslash' operator for the DiracOp. This may be e.g. AD
Implemented in quda::DiracTwistedMass, quda::GaugeCovDev, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracDomainWall, quda::DiracCloverPC, and quda::DiracWilson.
|
inlinevirtual |
Apply the local MdagM operator: equivalent to applying zero Dirichlet boundary condition to MdagM on each rank. Depending on the number of stencil steps of the fermion type, this may require additional effort to include the terms that hop out of the boundary and then hop back.
Reimplemented in quda::DiracMobius, and quda::DiracDomainWall4D.
Definition at line 243 of file dirac_quda.h.
|
pure virtual |
Xpay version of Dslash.
Implemented in quda::DiracTwistedMass, quda::GaugeCovDev, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracDomainWall, quda::DiracCloverPC, quda::DiracClover, and quda::DiracWilson.
|
inline |
Flips value of daggered.
Definition at line 338 of file dirac_quda.h.
|
inline |
returns and then zeroes flopcount
Definition at line 313 of file dirac_quda.h.
|
pure virtual |
returns the Dirac type
Implemented in quda::GaugeCovDev, quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggeredPC, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggeredPC, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracTwistedMass, quda::DiracMobiusEofaPC, quda::DiracMobiusEofa, quda::DiracMobiusPC, quda::DiracMobius, quda::DiracDomainWall4DPC, quda::DiracDomainWall4D, quda::DiracDomainWallPC, quda::DiracDomainWall, quda::DiracCloverHasenbuschTwistPC, quda::DiracCloverHasenbuschTwist, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilsonPC, and quda::DiracWilson.
|
inline |
returns preconditioning type
Definition at line 323 of file dirac_quda.h.
int quda::Dirac::getStencilSteps | ( | ) | const |
|
inline |
Definition at line 381 of file dirac_quda.h.
|
inlinevirtual |
Whether or not the operator has a single-parity Dslash.
Reimplemented in quda::DiracImprovedStaggeredKD, and quda::DiracStaggeredKD.
Definition at line 201 of file dirac_quda.h.
|
inlinevirtual |
specifies whether or not there's a specialized prepare/reconstruct used before/after transfering to/from the coarse level in MG
Reimplemented in quda::DiracImprovedStaggeredKD, and quda::DiracStaggeredKD.
Definition at line 280 of file dirac_quda.h.
|
inlinevirtual |
is operator hermitian
Reimplemented in quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracImprovedStaggeredPC, and quda::DiracStaggeredPC.
Definition at line 343 of file dirac_quda.h.
|
inlinevirtual |
Whether the Dirac object is the DiracCoarse.
Reimplemented in quda::DiracCoarse.
Definition at line 181 of file dirac_quda.h.
|
inline |
accessor for Kappa (mass parameter)
Definition at line 293 of file dirac_quda.h.
|
pure virtual |
Apply M for the dirac op. E.g. the Schur Complement operator.
Implemented in quda::GaugeCovDev, quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggeredPC, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggeredPC, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracTwistedMass, quda::DiracMobiusEofaPC, quda::DiracMobiusEofa, quda::DiracMobiusPC, quda::DiracMobius, quda::DiracDomainWall4DPC, quda::DiracDomainWall4D, quda::DiracDomainWallPC, quda::DiracDomainWall, quda::DiracCloverHasenbuschTwistPC, quda::DiracCloverHasenbuschTwist, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilsonPC, and quda::DiracWilson.
|
inlinevirtual |
accessor for Mass (in case of a factor of 2 for staggered)
Reimplemented in quda::DiracCoarse.
Definition at line 298 of file dirac_quda.h.
void quda::Dirac::Mdag | ( | ColorSpinorField & | out, |
const ColorSpinorField & | in | ||
) | const |
|
pure virtual |
Apply MdagM operator which may be optimized.
Implemented in quda::GaugeCovDev, quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggeredPC, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggeredPC, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracTwistedMass, quda::DiracMobiusEofaPC, quda::DiracMobiusEofa, quda::DiracMobiusPC, quda::DiracMobius, quda::DiracDomainWall4DPC, quda::DiracDomainWall4D, quda::DiracDomainWallPC, quda::DiracDomainWall, quda::DiracCloverHasenbuschTwistPC, quda::DiracCloverHasenbuschTwist, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilsonPC, and quda::DiracWilson.
|
inlinevirtual |
Apply the local MdagM operator: equivalent to applying zero Dirichlet boundary condition to MdagM on each rank. Depending on the number of stencil steps of the fermion type, this may require additional effort to include the terms that hop out of the boundary and then hop back.
Reimplemented in quda::DiracMobiusPC.
Definition at line 232 of file dirac_quda.h.
void quda::Dirac::MMdag | ( | ColorSpinorField & | out, |
const ColorSpinorField & | in | ||
) | const |
|
inlinevirtual |
accessor for twist parameter – overrride can return better value
Reimplemented in quda::DiracCoarse, quda::DiracTwistedClover, and quda::DiracTwistedMass.
Definition at line 303 of file dirac_quda.h.
|
inlinevirtual |
accessor for mu factoo for MG/ – override can return a better value
Reimplemented in quda::DiracCoarse.
Definition at line 308 of file dirac_quda.h.
|
protected |
|
virtual |
If managed memory and prefetch is enabled, prefetch the gauge field and temporary spinors to the CPU or GPU as requested. Overloads may also grab a clover term.
[in] | mem_space | Memory space we are prefetching to |
[in] | stream | Which stream to run the prefetch in (default 0) |
Reimplemented in quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracCloverPC, and quda::DiracClover.
|
pure virtual |
Implemented in quda::GaugeCovDev, quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggeredPC, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggeredPC, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracTwistedMass, quda::DiracMobiusEofaPC, quda::DiracMobiusEofa, quda::DiracMobiusPC, quda::DiracMobius, quda::DiracDomainWall4DPC, quda::DiracDomainWall4D, quda::DiracDomainWallPC, quda::DiracDomainWall, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilsonPC, and quda::DiracWilson.
|
inlinevirtual |
Reimplemented in quda::DiracImprovedStaggeredKD, and quda::DiracStaggeredKD.
Definition at line 264 of file dirac_quda.h.
|
pure virtual |
Implemented in quda::GaugeCovDev, quda::GaugeLaplacePC, quda::GaugeLaplace, quda::DiracCoarsePC, quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggeredPC, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracStaggeredPC, quda::DiracStaggered, quda::DiracTwistedCloverPC, quda::DiracTwistedClover, quda::DiracTwistedMassPC, quda::DiracTwistedMass, quda::DiracMobiusEofaPC, quda::DiracMobiusEofa, quda::DiracMobiusPC, quda::DiracMobius, quda::DiracDomainWall4DPC, quda::DiracDomainWall4D, quda::DiracDomainWallPC, quda::DiracDomainWall, quda::DiracCloverPC, quda::DiracClover, quda::DiracWilsonPC, and quda::DiracWilson.
|
inlinevirtual |
Reimplemented in quda::DiracImprovedStaggeredKD, and quda::DiracStaggeredKD.
Definition at line 269 of file dirac_quda.h.
|
inline |
Enable / disable communications for the Dirac operator.
[in] | commDim_ | Array of booleans which determines whether communications are enabled |
Definition at line 174 of file dirac_quda.h.
|
inline |
Definition at line 382 of file dirac_quda.h.
|
inline |
Definition at line 282 of file dirac_quda.h.
|
inlinevirtual |
Update the internal gauge, fat gauge, long gauge, clover field pointer as appropriate. These are pointers as opposed to references to support passing in nullptr
.
gauge_in | Updated gauge field |
fat_gauge_in | Updated fat links |
long_gauge_in | Updated long links |
clover_in | Updated clover field |
Reimplemented in quda::DiracCoarse, quda::DiracImprovedStaggeredKD, quda::DiracImprovedStaggered, quda::DiracStaggeredKD, quda::DiracTwistedClover, and quda::DiracClover.
Definition at line 360 of file dirac_quda.h.
|
friend |
Definition at line 141 of file dirac_quda.h.
|
friend |
Definition at line 136 of file dirac_quda.h.
|
friend |
Definition at line 135 of file dirac_quda.h.
|
friend |
Definition at line 140 of file dirac_quda.h.
|
friend |
Definition at line 137 of file dirac_quda.h.
|
friend |
Definition at line 138 of file dirac_quda.h.
|
friend |
Definition at line 139 of file dirac_quda.h.
|
mutableprotected |
Definition at line 159 of file dirac_quda.h.
|
mutableprotected |
Definition at line 149 of file dirac_quda.h.
|
mutableprotected |
Definition at line 150 of file dirac_quda.h.
|
protected |
Definition at line 144 of file dirac_quda.h.
|
mutableprotected |
Definition at line 154 of file dirac_quda.h.
|
protected |
Definition at line 145 of file dirac_quda.h.
|
protected |
Definition at line 147 of file dirac_quda.h.
|
protected |
Definition at line 146 of file dirac_quda.h.
|
protected |
Definition at line 148 of file dirac_quda.h.
|
mutableprotected |
Definition at line 161 of file dirac_quda.h.
|
mutableprotected |
Definition at line 151 of file dirac_quda.h.
|
mutableprotected |
Definition at line 152 of file dirac_quda.h.
|
protected |
Definition at line 153 of file dirac_quda.h.