From 077aa728b9e876324082127836ae5434c8d64e60 Mon Sep 17 00:00:00 2001 From: paboyle Date: Thu, 30 Mar 2017 13:42:09 +0900 Subject: [PATCH] Fix the ZMobius (I think) --- lib/qcd/action/fermion/CayleyFermion5D.cc | 31 ++++++++++++++--------- 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/lib/qcd/action/fermion/CayleyFermion5D.cc b/lib/qcd/action/fermion/CayleyFermion5D.cc index 90614295..51677522 100644 --- a/lib/qcd/action/fermion/CayleyFermion5D.cc +++ b/lib/qcd/action/fermion/CayleyFermion5D.cc @@ -170,7 +170,6 @@ void CayleyFermion5D::Mooee (const FermionField &psi, FermionField & lower[0] =-mass*lower[0]; M5D(psi,psi,chi,lower,diag,upper); } - template void CayleyFermion5D::MooeeDag (const FermionField &psi, FermionField &chi) { @@ -192,7 +191,7 @@ void CayleyFermion5D::MooeeDag (const FermionField &psi, FermionField & lower[s]=-cee[s-1]; } } - // Conjugate the terms ? + // Conjugate the terms for (int s=0;s::MeooeDag5D (const FermionField &psi, FermionField int Ls=this->Ls; std::vector diag =bs; std::vector upper=cs; - std::vector lower=cs; - upper[Ls-1]=-mass*upper[Ls-1]; - lower[0] =-mass*lower[0]; - // Conjugate the terms ? + std::vector lower=cs; + for (int s=0;s::MDeriv (GaugeField &mat,const FermionField &U,const this->DhopDeriv(mat,U,Din,dag); } else { // U d/du [D_w D5]^dag V = U D5^dag d/du DW^dag Y // implicit adj on U in call - Meooe5D(U,Din); + MeooeDag5D(U,Din); this->DhopDeriv(mat,Din,V,dag); } }; @@ -328,7 +335,7 @@ void CayleyFermion5D::MoeDeriv(GaugeField &mat,const FermionField &U,const this->DhopDerivOE(mat,U,Din,dag); } else { // U d/du [D_w D5]^dag V = U D5^dag d/du DW^dag Y // implicit adj on U in call - Meooe5D(U,Din); + MeooeDag5D(U,Din); this->DhopDerivOE(mat,Din,V,dag); } }; @@ -343,7 +350,7 @@ void CayleyFermion5D::MeoDeriv(GaugeField &mat,const FermionField &U,const this->DhopDerivEO(mat,U,Din,dag); } else { // U d/du [D_w D5]^dag V = U D5^dag d/du DW^dag Y // implicit adj on U in call - Meooe5D(U,Din); + MeooeDag5D(U,Din); this->DhopDerivEO(mat,Din,V,dag); } };