1
0
mirror of https://github.com/paboyle/Grid.git synced 2025-10-24 01:34:47 +01:00

Change CayleyFermion5D::SetCoefficientsInternal to virtual to allow overriding in derived EOFA classes

This commit is contained in:
David Murphy
2017-08-15 14:18:51 -04:00
parent 202a7fe900
commit b7f93aeb4d

View File

@@ -1,6 +1,6 @@
/************************************************************************************* /*************************************************************************************
Grid physics library, www.github.com/paboyle/Grid Grid physics library, www.github.com/paboyle/Grid
Source file: ./lib/qcd/action/fermion/CayleyFermion5D.h Source file: ./lib/qcd/action/fermion/CayleyFermion5D.h
@@ -35,24 +35,24 @@ namespace Grid {
namespace QCD { namespace QCD {
template<typename T> struct switcheroo { template<typename T> struct switcheroo {
static inline int iscomplex() { return 0; } static inline int iscomplex() { return 0; }
template<class vec> template<class vec>
static inline vec mult(vec a, vec b) { static inline vec mult(vec a, vec b) {
return real_mult(a,b); return real_mult(a,b);
} }
}; };
template<> struct switcheroo<ComplexD> { template<> struct switcheroo<ComplexD> {
static inline int iscomplex() { return 1; } static inline int iscomplex() { return 1; }
template<class vec> template<class vec>
static inline vec mult(vec a, vec b) { static inline vec mult(vec a, vec b) {
return a*b; return a*b;
} }
}; };
template<> struct switcheroo<ComplexF> { template<> struct switcheroo<ComplexF> {
static inline int iscomplex() { return 1; } static inline int iscomplex() { return 1; }
template<class vec> template<class vec>
static inline vec mult(vec a, vec b) { static inline vec mult(vec a, vec b) {
return a*b; return a*b;
@@ -90,14 +90,14 @@ namespace Grid {
// Instantiate different versions depending on Impl // Instantiate different versions depending on Impl
///////////////////////////////////////////////////// /////////////////////////////////////////////////////
void M5D(const FermionField &psi, void M5D(const FermionField &psi,
const FermionField &phi, const FermionField &phi,
FermionField &chi, FermionField &chi,
std::vector<Coeff_t> &lower, std::vector<Coeff_t> &lower,
std::vector<Coeff_t> &diag, std::vector<Coeff_t> &diag,
std::vector<Coeff_t> &upper); std::vector<Coeff_t> &upper);
void M5Ddag(const FermionField &psi, void M5Ddag(const FermionField &psi,
const FermionField &phi, const FermionField &phi,
FermionField &chi, FermionField &chi,
std::vector<Coeff_t> &lower, std::vector<Coeff_t> &lower,
std::vector<Coeff_t> &diag, std::vector<Coeff_t> &diag,
@@ -125,7 +125,7 @@ namespace Grid {
// Efficient support for multigrid coarsening // Efficient support for multigrid coarsening
virtual void Mdir (const FermionField &in, FermionField &out,int dir,int disp); virtual void Mdir (const FermionField &in, FermionField &out,int dir,int disp);
void Meooe5D (const FermionField &in, FermionField &out); void Meooe5D (const FermionField &in, FermionField &out);
void MeooeDag5D (const FermionField &in, FermionField &out); void MeooeDag5D (const FermionField &in, FermionField &out);
@@ -133,23 +133,23 @@ namespace Grid {
RealD mass; RealD mass;
// Cayley form Moebius (tanh and zolotarev) // Cayley form Moebius (tanh and zolotarev)
std::vector<Coeff_t> omega; std::vector<Coeff_t> omega;
std::vector<Coeff_t> bs; // S dependent coeffs std::vector<Coeff_t> bs; // S dependent coeffs
std::vector<Coeff_t> cs; std::vector<Coeff_t> cs;
std::vector<Coeff_t> as; std::vector<Coeff_t> as;
// For preconditioning Cayley form // For preconditioning Cayley form
std::vector<Coeff_t> bee; std::vector<Coeff_t> bee;
std::vector<Coeff_t> cee; std::vector<Coeff_t> cee;
std::vector<Coeff_t> aee; std::vector<Coeff_t> aee;
std::vector<Coeff_t> beo; std::vector<Coeff_t> beo;
std::vector<Coeff_t> ceo; std::vector<Coeff_t> ceo;
std::vector<Coeff_t> aeo; std::vector<Coeff_t> aeo;
// LDU factorisation of the eeoo matrix // LDU factorisation of the eeoo matrix
std::vector<Coeff_t> lee; std::vector<Coeff_t> lee;
std::vector<Coeff_t> leem; std::vector<Coeff_t> leem;
std::vector<Coeff_t> uee; std::vector<Coeff_t> uee;
std::vector<Coeff_t> ueem; std::vector<Coeff_t> ueem;
std::vector<Coeff_t> dee; std::vector<Coeff_t> dee;
// Matrices of 5d ee inverse params // Matrices of 5d ee inverse params
Vector<iSinglet<Simd> > MatpInv; Vector<iSinglet<Simd> > MatpInv;
@@ -165,7 +165,7 @@ namespace Grid {
GridRedBlackCartesian &FourDimRedBlackGrid, GridRedBlackCartesian &FourDimRedBlackGrid,
RealD _mass,RealD _M5,const ImplParams &p= ImplParams()); RealD _mass,RealD _M5,const ImplParams &p= ImplParams());
void CayleyReport(void); void CayleyReport(void);
void CayleyZeroCounters(void); void CayleyZeroCounters(void);
@@ -179,9 +179,9 @@ namespace Grid {
double MooeeInvTime; double MooeeInvTime;
protected: protected:
void SetCoefficientsZolotarev(RealD zolohi,Approx::zolotarev_data *zdata,RealD b,RealD c); virtual void SetCoefficientsZolotarev(RealD zolohi,Approx::zolotarev_data *zdata,RealD b,RealD c);
void SetCoefficientsTanh(Approx::zolotarev_data *zdata,RealD b,RealD c); virtual void SetCoefficientsTanh(Approx::zolotarev_data *zdata,RealD b,RealD c);
void SetCoefficientsInternal(RealD zolo_hi,std::vector<Coeff_t> & gamma,RealD b,RealD c); virtual void SetCoefficientsInternal(RealD zolo_hi,std::vector<Coeff_t> & gamma,RealD b,RealD c);
}; };
} }