#include "Grid.h" using namespace std; using namespace Grid; using namespace Grid::QCD; namespace Grid { namespace QCD { class HmcRunner : public ConjugateNerscHmcRunner { public: void BuildTheAction (int argc, char **argv) { typedef GparityWilsonImplR ImplPolicy; typedef GparityDomainWallFermionR FermionAction; typedef typename FermionAction::FermionField FermionField; const int Ls = 8; UGrid = SpaceTimeGrid::makeFourDimGrid(GridDefaultLatt(), GridDefaultSimd(Nd,vComplex::Nsimd()),GridDefaultMpi()); UrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(UGrid); FGrid = SpaceTimeGrid::makeFiveDimGrid(Ls,UGrid); FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,UGrid); // temporarily need a gauge field LatticeGaugeField U(UGrid); // Gauge action ConjugateWilsonGaugeActionR Waction(5.6); // Fermion action const int nu = 3; std::vector twists(Nd,0); twists[nu] = 1; FermionAction::ImplParams params; params.twists = twists; Real mass=0.04; Real pv =1.0; RealD M5=1.5; FermionAction DenOp(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,params); FermionAction NumOp(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,pv,M5,params); ConjugateGradient CG(1.0e-8,10000); TwoFlavourEvenOddRatioPseudoFermionAction Nf2(NumOp, DenOp,CG,CG); //Collect actions ActionLevel Level1; Level1.push_back(&Nf2); Level1.push_back(&Waction); TheAction.push_back(Level1); Run(argc,argv); }; }; }} int main (int argc, char ** argv) { Grid_init(&argc,&argv); int threads = GridThread::GetThreads(); std::cout<