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

#include <dirac_quda.h>

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

Public Member Functions

 DiracClover (const DiracParam &param)
 
 DiracClover (const DiracClover &dirac)
 
virtual ~DiracClover ()
 
DiracCloveroperator= (const DiracClover &dirac)
 
void Clover (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity) const
 
virtual void DslashXpay (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity, const ColorSpinorField &x, const double &k) const
 
virtual void M (ColorSpinorField &out, const ColorSpinorField &in) const
 
virtual void MdagM (ColorSpinorField &out, const ColorSpinorField &in) const
 
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
 
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 clover operator. 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)
 
virtual void Dslash (ColorSpinorField &out, const ColorSpinorField &in, const QudaParity parity) const
 
- 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 void checkFullSpinor (const ColorSpinorField &, const ColorSpinorField &) const
 
void checkSpinorAlias (const ColorSpinorField &, const ColorSpinorField &) const
 
void Mdag (ColorSpinorField &out, const ColorSpinorField &in) const
 
void MMdag (ColorSpinorField &out, const ColorSpinorField &in) const
 
void setMass (double mass)
 
double Kappa () const
 
virtual double Mu () const
 
virtual double MuFactor () const
 
unsigned long long Flops () const
 
QudaMatPCType getMatPCType () const
 
int getStencilSteps () const
 
void Dagger (QudaDagType dag) const
 
void flipDagger () const
 
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
 
void initConstants ()
 
- 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

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)
 
- 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 266 of file dirac_quda.h.

Constructor & Destructor Documentation

◆ DiracClover() [1/2]

quda::DiracClover::DiracClover ( const DiracParam param)

Definition at line 10 of file dirac_clover.cpp.

◆ DiracClover() [2/2]

quda::DiracClover::DiracClover ( const DiracClover dirac)

Definition at line 12 of file dirac_clover.cpp.

◆ ~DiracClover()

quda::DiracClover::~DiracClover ( )
virtual

Definition at line 14 of file dirac_clover.cpp.

Member Function Documentation

◆ checkParitySpinor()

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

Reimplemented from quda::Dirac.

Definition at line 25 of file dirac_clover.cpp.

References quda::Dirac::checkParitySpinor(), clover, errorQuda, quda::ColorSpinorField::Volume(), and quda::LatticeField::VolumeCB().

Referenced by Clover(), quda::DiracCloverPC::CloverInv(), quda::DiracCloverPC::Dslash(), DslashXpay(), and quda::DiracCloverPC::DslashXpay().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ Clover()

void quda::DiracClover::Clover ( ColorSpinorField out,
const ColorSpinorField in,
const QudaParity  parity 
) const

Definition at line 48 of file dirac_clover.cpp.

References quda::ApplyClover(), checkParitySpinor(), clover, quda::Dirac::flops, and quda::ColorSpinorField::Volume().

Referenced by cloverQuda().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ createCoarseOp()

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

Create the coarse clover operator.

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 (hard coded to 0 when CoarseOp is called)

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 93 of file dirac_clover.cpp.

References clover, quda::CoarseOp(), quda::Dirac::gauge, QUDA_CLOVER_DIRAC, QUDA_MATPC_INVALID, quda::ColorSpinorField::TwistFlavor(), and quda::Transfer::Vectors().

Here is the call graph for this function:

◆ DslashXpay()

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

Applies the operator (A + k D)

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 36 of file dirac_clover.cpp.

References quda::ApplyWilsonClover(), checkParitySpinor(), quda::Dirac::checkSpinorAlias(), clover, quda::Dirac::commDim, quda::Dirac::dagger, quda::Dirac::flops, quda::Dirac::gauge, quda::Dirac::profile, and quda::ColorSpinorField::Volume().

Referenced by quda::DiracCloverPC::M().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ initConstants()

void quda::DiracClover::initConstants ( )
protected

◆ M()

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

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 56 of file dirac_clover.cpp.

References quda::ApplyWilsonClover(), clover, quda::Dirac::commDim, quda::Dirac::dagger, quda::Dirac::flops, quda::Dirac::gauge, quda::Dirac::kappa, quda::Dirac::profile, QUDA_INVALID_PARITY, and quda::ColorSpinorField::Volume().

Referenced by MdagM().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ MdagM()

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

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 62 of file dirac_clover.cpp.

References quda::Dirac::checkFullSpinor(), quda::Dirac::deleteTmp(), M(), quda::Dirac::Mdag(), quda::Dirac::newTmp(), and quda::Dirac::tmp1.

Here is the call graph for this function:

◆ operator=()

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

Definition at line 16 of file dirac_clover.cpp.

References clover, and quda::DiracWilson::operator=().

Referenced by quda::DiracCloverPC::operator=().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ prepare()

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

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 75 of file dirac_clover.cpp.

References errorQuda, QUDA_MATPC_SOLUTION, and QUDA_MATPCDAG_MATPC_SOLUTION.

◆ reconstruct()

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

Reimplemented from quda::DiracWilson.

Reimplemented in quda::DiracCloverPC.

Definition at line 87 of file dirac_clover.cpp.

Member Data Documentation

◆ clover

cudaCloverField& quda::DiracClover::clover
protected

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