QUDA  v1.1.0
A library for QCD on GPUs
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
quda::DiracTwistedClover Class Reference

#include <dirac_quda.h>

+ Inheritance diagram for quda::DiracTwistedClover:

Public Member Functions

 DiracTwistedClover (const DiracTwistedClover &dirac)
 
 DiracTwistedClover (const DiracParam &param, const int nDim)
 
virtual ~DiracTwistedClover ()
 
DiracTwistedCloveroperator= (const DiracTwistedClover &dirac)
 
void TwistClover (ColorSpinorField &out, const ColorSpinorField &in, const int parity) const
 
virtual void Dslash (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity) const
 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
 Xpay version of Dslash. More...
 
virtual void M (ColorSpinorField &out, const ColorSpinorField &in) const
 Apply M for the dirac op. E.g. the Schur Complement operator. More...
 
virtual void MdagM (ColorSpinorField &out, const ColorSpinorField &in) const
 Apply MdagM operator which may be optimized. More...
 
virtual void prepare (ColorSpinorField *&src, ColorSpinorField *&sol, ColorSpinorField &x, ColorSpinorField &b, const QudaSolutionType) const
 
virtual void reconstruct (ColorSpinorField &x, const ColorSpinorField &b, const QudaSolutionType) const
 
virtual QudaDiracType getDiracType () const
 returns the Dirac type More...
 
double Mu () const
 accessor for twist parameter – overrride can return better value 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...
 
void createCoarseOp (GaugeField &Y, GaugeField &X, const Transfer &T, double kappa, double mass, double mu, double mu_factor=0.) const
 Create the coarse twisted-clover operator. More...
 
virtual void prefetch (QudaFieldLocation mem_space, qudaStream_t stream=0) const
 If managed memory and prefetch is enabled, prefetch all relevant memory fields (gauge, clover, temporary spinors) to the CPU or GPU as requested. More...
 
- Public Member Functions inherited from quda::DiracWilson
 DiracWilson (const DiracParam &param)
 
 DiracWilson (const DiracWilson &dirac)
 
 DiracWilson (const DiracParam &param, const int nDims)
 
virtual ~DiracWilson ()
 
DiracWilsonoperator= (const DiracWilson &dirac)
 
- Public Member Functions inherited from quda::Dirac
 Dirac (const DiracParam &param)
 
 Dirac (const Dirac &dirac)
 
virtual ~Dirac ()
 
Diracoperator= (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 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 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 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 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...
 
QudaPrecision HaloPrecision () const
 
void setHaloPrecision (QudaPrecision halo_precision_) const
 
- Public Member Functions inherited from quda::Object
 Object ()
 
virtual ~Object ()
 

Protected Member Functions

void checkParitySpinor (const ColorSpinorField &, const ColorSpinorField &) const
 Check parity spinors are usable (check geometry ?) More...
 
void twistedCloverApply (ColorSpinorField &out, const ColorSpinorField &in, const QudaTwistGamma5Type twistType, const int parity) const
 
- Protected Member Functions inherited from quda::DiracWilson
void initConstants ()
 
- Protected Member Functions inherited from quda::Dirac
bool newTmp (ColorSpinorField **, const ColorSpinorField &) const
 
void deleteTmp (ColorSpinorField **, const bool &reset) const
 

Protected Attributes

double mu
 
double epsilon
 
cudaCloverFieldclover
 
- Protected Attributes inherited from quda::Dirac
cudaGaugeFieldgauge
 
double kappa
 
double mass
 
int laplace3D
 
QudaMatPCType matpcType
 
QudaDagType dagger
 
unsigned long long flops
 
ColorSpinorFieldtmp1
 
ColorSpinorFieldtmp2
 
QudaDiracType type
 
QudaPrecision halo_precision
 
int commDim [QUDA_MAX_DIM]
 
TimeProfile profile
 

Additional Inherited Members

- Static Public Member Functions inherited from quda::Dirac
static Diraccreate (const DiracParam &param)
 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)
 

Detailed Description

Definition at line 1044 of file dirac_quda.h.

Constructor & Destructor Documentation

◆ DiracTwistedClover() [1/2]

quda::DiracTwistedClover::DiracTwistedClover ( const DiracTwistedClover dirac)

Definition at line 18 of file dirac_twisted_clover.cpp.

◆ DiracTwistedClover() [2/2]

quda::DiracTwistedClover::DiracTwistedClover ( const DiracParam param,
const int  nDim 
)

Definition at line 10 of file dirac_twisted_clover.cpp.

◆ ~DiracTwistedClover()

quda::DiracTwistedClover::~DiracTwistedClover ( )
virtual

Definition at line 26 of file dirac_twisted_clover.cpp.

Member Function Documentation

◆ checkParitySpinor()

void quda::DiracTwistedClover::checkParitySpinor ( const ColorSpinorField out,
const ColorSpinorField in 
) const
protectedvirtual

Check parity spinors are usable (check geometry ?)

Reimplemented from quda::Dirac.

Definition at line 39 of file dirac_twisted_clover.cpp.

◆ createCoarseOp()

void quda::DiracTwistedClover::createCoarseOp ( GaugeField Y,
GaugeField X,
const Transfer T,
double  kappa,
double  mass,
double  mu,
double  mu_factor = 0. 
) const
virtual

Create the coarse twisted-clover operator.

Takes the multigrid transfer class, which knows about the coarse grid blocking, as well as having prolongate and restrict member functions, and returns color matrices Y[0..2*dim-1] corresponding to the coarse grid hopping terms and X corresponding to the coarse grid "clover" term.

Parameters
T[in]Transfer operator defining the coarse grid
Y[out]Coarse link field
X[out]Coarse clover field
kappaKappa parameter for the coarse operator
massMass parameter for the coarse operator (gets explicitly built into clover, hard coded to zero for non-staggered ops)
muTM mu parameter for the coarse operator
mu_factormultiplicative factor for the mu parameter

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 133 of file dirac_twisted_clover.cpp.

◆ Dslash()

void quda::DiracTwistedClover::Dslash ( ColorSpinorField out,
const ColorSpinorField in,
const QudaParity  parity 
) const
virtual

apply 'dslash' operator for the DiracOp. This may be e.g. AD

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 64 of file dirac_twisted_clover.cpp.

◆ DslashXpay()

void quda::DiracTwistedClover::DslashXpay ( ColorSpinorField out,
const ColorSpinorField in,
const QudaParity  parity,
const ColorSpinorField x,
const double &  k 
) const
virtual

Xpay version of Dslash.

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 70 of file dirac_twisted_clover.cpp.

◆ getDiracType()

virtual QudaDiracType quda::DiracTwistedClover::getDiracType ( ) const
inlinevirtual

returns the Dirac type

Returns
Dirac type

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 1075 of file dirac_quda.h.

◆ M()

void quda::DiracTwistedClover::M ( ColorSpinorField out,
const ColorSpinorField in 
) const
virtual

Apply M for the dirac op. E.g. the Schur Complement operator.

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 84 of file dirac_twisted_clover.cpp.

◆ MdagM()

void quda::DiracTwistedClover::MdagM ( ColorSpinorField out,
const ColorSpinorField in 
) const
virtual

Apply MdagM operator which may be optimized.

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 99 of file dirac_twisted_clover.cpp.

◆ Mu()

double quda::DiracTwistedClover::Mu ( ) const
inlinevirtual

accessor for twist parameter – overrride can return better value

Reimplemented from quda::Dirac.

Definition at line 1077 of file dirac_quda.h.

◆ operator=()

DiracTwistedClover & quda::DiracTwistedClover::operator= ( const DiracTwistedClover dirac)

Definition at line 28 of file dirac_twisted_clover.cpp.

◆ prefetch()

void quda::DiracTwistedClover::prefetch ( QudaFieldLocation  mem_space,
qudaStream_t  stream = 0 
) const
virtual

If managed memory and prefetch is enabled, prefetch all relevant memory fields (gauge, clover, temporary spinors) to the CPU or GPU as requested.

Parameters
[in]mem_spaceMemory space we are prefetching to
[in]streamWhich stream to run the prefetch in (default 0)

Reimplemented from quda::Dirac.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 127 of file dirac_twisted_clover.cpp.

◆ prepare()

void quda::DiracTwistedClover::prepare ( ColorSpinorField *&  src,
ColorSpinorField *&  sol,
ColorSpinorField x,
ColorSpinorField b,
const QudaSolutionType  solType 
) const
virtual

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 110 of file dirac_twisted_clover.cpp.

◆ reconstruct()

void quda::DiracTwistedClover::reconstruct ( ColorSpinorField x,
const ColorSpinorField b,
const QudaSolutionType  solType 
) const
virtual

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracTwistedCloverPC.

Definition at line 121 of file dirac_twisted_clover.cpp.

◆ TwistClover()

void quda::DiracTwistedClover::TwistClover ( ColorSpinorField out,
const ColorSpinorField in,
const int  parity 
) const

Definition at line 59 of file dirac_twisted_clover.cpp.

◆ twistedCloverApply()

void quda::DiracTwistedClover::twistedCloverApply ( ColorSpinorField out,
const ColorSpinorField in,
const QudaTwistGamma5Type  twistType,
const int  parity 
) const
protected

Definition at line 48 of file dirac_twisted_clover.cpp.

◆ updateFields()

virtual void quda::DiracTwistedClover::updateFields ( cudaGaugeField gauge_in,
cudaGaugeField fat_gauge_in,
cudaGaugeField long_gauge_in,
cudaCloverField clover_in 
)
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.

Parameters
gauge_inUpdated gauge field
fat_gauge_inUpdated fat links
long_gauge_inUpdated long links
clover_inUpdated clover field

Reimplemented from quda::Dirac.

Definition at line 1088 of file dirac_quda.h.

Member Data Documentation

◆ clover

cudaCloverField* quda::DiracTwistedClover::clover
protected

Definition at line 1049 of file dirac_quda.h.

◆ epsilon

double quda::DiracTwistedClover::epsilon
protected

Definition at line 1048 of file dirac_quda.h.

◆ mu

double quda::DiracTwistedClover::mu
protected

Definition at line 1047 of file dirac_quda.h.


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