14 #ifndef FOPR_CLOVER_GENERAL_INCLUDED
15 #define FOPR_CLOVER_GENERAL_INCLUDED
20 #ifdef USE_PARAMETERS_FACTORY
94 double nu_s,
double r_s,
95 double cSW_s,
double cSW_t,
126 }
else if (m_mode ==
"Ddag") {
128 }
else if (m_mode ==
"DdagD") {
130 }
else if (m_mode ==
"DDdag") {
132 }
else if (m_mode ==
"H") {
135 vout.
crucial(
m_vl,
"%s: undefined mode = %s.\n", class_name.c_str(), m_mode.c_str());
144 }
else if (m_mode ==
"DdagD") {
146 }
else if (m_mode ==
"Ddag") {
148 }
else if (m_mode ==
"H") {
151 vout.
crucial(
m_vl,
"%s: undefined mode = %s.\n", class_name.c_str(), m_mode.c_str());
178 const int mu,
const int nu);
189 void init(std::string repr);
void DDdag(Field &, const Field &)
double flop_count()
this returns the number of floating point operations.
void H(Field &, const Field &)
Fopr_CloverTerm_General * m_fopr_csw
Clover term operator.
int m_NinF
internal parameters
static const std::string class_name
double m_cSW_s
spatial clover coefficient
Clover general fermion operator.
void set_config(Field *U)
setting pointer to the gauge configuration.
Container of Field-type object.
void set_config(unique_ptr< Field_G > &U)
int field_nvol()
returns the volume for which the fermion operator is defined.
void mult_up(int mu, Field &v, const Field &w)
nearest neighbor hopping term: temporary entry [H.Matsufuru]
double m_kappa_s
spatial hopping parameter
void D(Field &, const Field &)
void set_mode(std::string mode)
setting the mode of multiplication if necessary. Default implementation here is just to avoid irrelev...
Parameters_Fopr_Clover_General()
void mult_dag(Field &v, const Field &f)
hermitian conjugate of mult(Field&, const Field&).
double m_nu_s
spatial anisotopy parameter
void mult(Field &v, const Field &f)
multiplies fermion operator to a given field (2nd argument)
std::string m_repr
gamma matrix representation
void mult_gm5(Field &v, const Field &w)
std::string m_mode
mode of multiplication
Wilson-type fermion field.
double m_cSW_t
temporal clover coefficient
void set_parameters(const Parameters ¶ms)
Fopr_Wilson_General * m_fopr_w
Wilson fermion kernel.
void mult_dn(int mu, Field &w, const Field &v)
const Field_G * m_U
gauge configuration (pointer)
Bridge::VerboseLevel m_vl
void mult_dn(int mu, Field &v, const Field &w)
void mult_up(int mu, Field &w, const Field &v)
adding the hopping to nearest neighbor site in mu-th direction.
void set_config(Field *U)
setting pointer to the gauge configuration.
double m_kappa_t
temporal hopping parameter
void mult_gm5(Field &w, const Field &v)
void crucial(const char *format,...)
void set_config(Field *U)
setting pointer to the gauge configuration.
Fopr_Clover_General(std::string repr)
void DdagD(Field &, const Field &)
int field_nex()
returns the external d.o.f. for which the fermion operator is defined.
double m_r_s
spatial Wilson parameter
void init(std::string repr)
void mult_isigma(Field_F &, const Field_F &, const int mu, const int nu)
int field_nin()
returns the on-site d.o.f. for which the fermion operator is defined.
Base class of fermion operator family.
std::vector< int > m_boundary
boundary conditions
std::string get_mode() const
only for Fopr_Overlap
void Ddag(Field &, const Field &)