mirror of
https://github.com/paboyle/Grid.git
synced 2025-04-04 19:25:56 +01:00
Making tests compile
This commit is contained in:
parent
e2a938e7f7
commit
e51eaedc56
@ -35,6 +35,15 @@ directory
|
|||||||
NAMESPACE_BEGIN(Grid);
|
NAMESPACE_BEGIN(Grid);
|
||||||
|
|
||||||
// These can move into a params header and be given MacroMagic serialisation
|
// These can move into a params header and be given MacroMagic serialisation
|
||||||
|
struct DefaultImplParams {
|
||||||
|
Coordinate dirichlet; // Blocksize of dirichlet BCs
|
||||||
|
int partialDirichlet;
|
||||||
|
DefaultImplParams() {
|
||||||
|
dirichlet.resize(0);
|
||||||
|
partialDirichlet=0;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
struct GparityWilsonImplParams {
|
struct GparityWilsonImplParams {
|
||||||
Coordinate twists;
|
Coordinate twists;
|
||||||
//mu=Nd-1 is assumed to be the time direction and a twist value of 1 indicates antiperiodic BCs
|
//mu=Nd-1 is assumed to be the time direction and a twist value of 1 indicates antiperiodic BCs
|
||||||
|
@ -47,7 +47,7 @@ private:
|
|||||||
const unsigned int N = Impl::Group::Dimension;
|
const unsigned int N = Impl::Group::Dimension;
|
||||||
|
|
||||||
typedef typename Field::vector_object vobj;
|
typedef typename Field::vector_object vobj;
|
||||||
typedef CartesianStencil<vobj, vobj,int> Stencil;
|
typedef CartesianStencil<vobj, vobj,DefaultImplParams> Stencil;
|
||||||
|
|
||||||
SimpleCompressor<vobj> compressor;
|
SimpleCompressor<vobj> compressor;
|
||||||
int npoint = 2 * Ndim;
|
int npoint = 2 * Ndim;
|
||||||
@ -82,7 +82,7 @@ public:
|
|||||||
virtual RealD S(const Field &p)
|
virtual RealD S(const Field &p)
|
||||||
{
|
{
|
||||||
assert(p.Grid()->Nd() == Ndim);
|
assert(p.Grid()->Nd() == Ndim);
|
||||||
static Stencil phiStencil(p.Grid(), npoint, 0, directions, displacements,0);
|
static Stencil phiStencil(p.Grid(), npoint, 0, directions, displacements);
|
||||||
phiStencil.HaloExchange(p, compressor);
|
phiStencil.HaloExchange(p, compressor);
|
||||||
Field action(p.Grid()), pshift(p.Grid()), phisquared(p.Grid());
|
Field action(p.Grid()), pshift(p.Grid()), phisquared(p.Grid());
|
||||||
phisquared = p * p;
|
phisquared = p * p;
|
||||||
@ -133,7 +133,7 @@ public:
|
|||||||
double interm_t = usecond();
|
double interm_t = usecond();
|
||||||
|
|
||||||
// move this outside
|
// move this outside
|
||||||
static Stencil phiStencil(p.Grid(), npoint, 0, directions, displacements,0);
|
static Stencil phiStencil(p.Grid(), npoint, 0, directions, displacements);
|
||||||
|
|
||||||
phiStencil.HaloExchange(p, compressor);
|
phiStencil.HaloExchange(p, compressor);
|
||||||
double halo_t = usecond();
|
double halo_t = usecond();
|
||||||
|
@ -143,6 +143,7 @@ private:
|
|||||||
GridBase *Grid = U.Grid();
|
GridBase *Grid = U.Grid();
|
||||||
|
|
||||||
if(Params.PerformRandomShift){
|
if(Params.PerformRandomShift){
|
||||||
|
#if 0
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// Mainly for DDHMC perform a random translation of U modulo volume
|
// Mainly for DDHMC perform a random translation of U modulo volume
|
||||||
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -167,11 +168,11 @@ private:
|
|||||||
//shift all fields together in a way that respects the gauge BCs
|
//shift all fields together in a way that respects the gauge BCs
|
||||||
for(int mu=0; mu < Grid->Nd(); mu++)
|
for(int mu=0; mu < Grid->Nd(); mu++)
|
||||||
Umu[mu] = FieldImplementation::CshiftLink(Umu[mu],d,shift);
|
Umu[mu] = FieldImplementation::CshiftLink(Umu[mu],d,shift);
|
||||||
}
|
|
||||||
|
|
||||||
for(int mu=0;mu<Grid->Nd();mu++) PokeIndex<LorentzIndex>(U,Umu[mu],mu);
|
for(int mu=0;mu<Grid->Nd();mu++) PokeIndex<LorentzIndex>(U,Umu[mu],mu);
|
||||||
|
}
|
||||||
std::cout << GridLogMessage << "--------------------------------------------------\n";
|
std::cout << GridLogMessage << "--------------------------------------------------\n";
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
TheIntegrator.reset_timer();
|
TheIntegrator.reset_timer();
|
||||||
|
@ -78,13 +78,13 @@ static Registrar<OneFlavourRatioEOFModule<FermionImplementationPolicy>,
|
|||||||
// Now a specific registration with a fermion field
|
// Now a specific registration with a fermion field
|
||||||
// here must instantiate CG and CR for every new fermion field type (macro!!)
|
// here must instantiate CG and CR for every new fermion field type (macro!!)
|
||||||
|
|
||||||
static Registrar< ConjugateGradientModule<WilsonFermionR::FermionField>,
|
static Registrar< ConjugateGradientModule<WilsonFermionD::FermionField>,
|
||||||
HMC_SolverModuleFactory<solver_string, WilsonFermionR::FermionField, Serialiser> > __CGWFmodXMLInit("ConjugateGradient");
|
HMC_SolverModuleFactory<solver_string, WilsonFermionD::FermionField, Serialiser> > __CGWFmodXMLInit("ConjugateGradient");
|
||||||
|
|
||||||
static Registrar< BiCGSTABModule<WilsonFermionR::FermionField>,
|
static Registrar< BiCGSTABModule<WilsonFermionD::FermionField>,
|
||||||
HMC_SolverModuleFactory<solver_string, WilsonFermionR::FermionField, Serialiser> > __BiCGWFmodXMLInit("BiCGSTAB");
|
HMC_SolverModuleFactory<solver_string, WilsonFermionD::FermionField, Serialiser> > __BiCGWFmodXMLInit("BiCGSTAB");
|
||||||
static Registrar< ConjugateResidualModule<WilsonFermionR::FermionField>,
|
static Registrar< ConjugateResidualModule<WilsonFermionD::FermionField>,
|
||||||
HMC_SolverModuleFactory<solver_string, WilsonFermionR::FermionField, Serialiser> > __CRWFmodXMLInit("ConjugateResidual");
|
HMC_SolverModuleFactory<solver_string, WilsonFermionD::FermionField, Serialiser> > __CRWFmodXMLInit("ConjugateResidual");
|
||||||
|
|
||||||
// add the staggered, scalar versions here
|
// add the staggered, scalar versions here
|
||||||
|
|
||||||
|
@ -698,7 +698,7 @@ public:
|
|||||||
int checkerboard,
|
int checkerboard,
|
||||||
const std::vector<int> &directions,
|
const std::vector<int> &directions,
|
||||||
const std::vector<int> &distances,
|
const std::vector<int> &distances,
|
||||||
Parameters p)
|
Parameters p=Parameters())
|
||||||
{
|
{
|
||||||
face_table_computed=0;
|
face_table_computed=0;
|
||||||
_grid = grid;
|
_grid = grid;
|
||||||
|
@ -4,11 +4,10 @@
|
|||||||
--enable-accelerator=hip \
|
--enable-accelerator=hip \
|
||||||
--enable-gen-simd-width=64 \
|
--enable-gen-simd-width=64 \
|
||||||
--enable-simd=GPU \
|
--enable-simd=GPU \
|
||||||
--disable-fermion-reps \
|
|
||||||
--with-gmp=$OLCF_GMP_ROOT \
|
--with-gmp=$OLCF_GMP_ROOT \
|
||||||
--with-fftw=$FFTW_DIR/.. \
|
--with-fftw=$FFTW_DIR/.. \
|
||||||
--with-mpfr=/opt/cray/pe/gcc/mpfr/3.1.4/ \
|
--with-mpfr=/opt/cray/pe/gcc/mpfr/3.1.4/ \
|
||||||
--enable-gparity \
|
--disable-gparity \
|
||||||
CXX=hipcc MPICXX=mpicxx \
|
CXX=hipcc MPICXX=mpicxx \
|
||||||
CXXFLAGS="-fPIC -I{$ROCM_PATH}/include/ -std=c++14 -I${MPICH_DIR}/include -L/lib64 " \
|
CXXFLAGS="-fPIC -I{$ROCM_PATH}/include/ -std=c++14 -I${MPICH_DIR}/include -L/lib64 " \
|
||||||
LDFLAGS="-L/lib64 -L/opt/rocm-5.2.0/lib/ -L${MPICH_DIR}/lib -lmpi -L${CRAY_MPICH_ROOTDIR}/gtl/lib -lmpi_gtl_hsa -lamdhip64 "
|
LDFLAGS="-L/lib64 -L/opt/rocm-5.2.0/lib/ -L${MPICH_DIR}/lib -lmpi -L${CRAY_MPICH_ROOTDIR}/gtl/lib -lmpi_gtl_hsa -lamdhip64 "
|
||||||
|
@ -75,8 +75,8 @@ int main (int argc, char ** argv)
|
|||||||
RealD M5=1.8;
|
RealD M5=1.8;
|
||||||
|
|
||||||
{
|
{
|
||||||
OverlapWilsonContFracTanhFermionR Dcf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonContFracTanhFermionD Dcf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
HermitianLinearOperator<OverlapWilsonContFracTanhFermionR,LatticeFermion> HermIndefOp(Dcf);
|
HermitianLinearOperator<OverlapWilsonContFracTanhFermionD,LatticeFermion> HermIndefOp(Dcf);
|
||||||
|
|
||||||
HermIndefOp.Op(src,ref);
|
HermIndefOp.Op(src,ref);
|
||||||
HermIndefOp.OpDiag(src,result);
|
HermIndefOp.OpDiag(src,result);
|
||||||
@ -92,8 +92,8 @@ int main (int argc, char ** argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
OverlapWilsonPartialFractionTanhFermionR Dpf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonPartialFractionTanhFermionD Dpf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
HermitianLinearOperator<OverlapWilsonPartialFractionTanhFermionR,LatticeFermion> HermIndefOp(Dpf);
|
HermitianLinearOperator<OverlapWilsonPartialFractionTanhFermionD,LatticeFermion> HermIndefOp(Dpf);
|
||||||
|
|
||||||
HermIndefOp.Op(src,ref);
|
HermIndefOp.Op(src,ref);
|
||||||
HermIndefOp.OpDiag(src,result);
|
HermIndefOp.OpDiag(src,result);
|
||||||
|
@ -140,14 +140,14 @@ int main (int argc, char ** argv)
|
|||||||
|
|
||||||
// RealD mass=0.1;
|
// RealD mass=0.1;
|
||||||
// RealD M5=1.8;
|
// RealD M5=1.8;
|
||||||
// DomainWallFermionR Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
// DomainWallFermionD Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
||||||
|
|
||||||
// LatticeFermion src_o(FrbGrid);
|
// LatticeFermion src_o(FrbGrid);
|
||||||
// LatticeFermion result_o(FrbGrid);
|
// LatticeFermion result_o(FrbGrid);
|
||||||
// pickCheckerboard(Odd,src_o,src);
|
// pickCheckerboard(Odd,src_o,src);
|
||||||
// result_o=Zero();
|
// result_o=Zero();
|
||||||
|
|
||||||
// SchurDiagMooeeOperator<DomainWallFermionR,LatticeFermion> HermOpEO(Ddwf);
|
// SchurDiagMooeeOperator<DomainWallFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
// ConjugateGradient<LatticeFermion> CG(1.0e-8,10000);
|
// ConjugateGradient<LatticeFermion> CG(1.0e-8,10000);
|
||||||
// CG(HermOpEO,src_o,result_o);
|
// CG(HermOpEO,src_o,result_o);
|
||||||
|
|
||||||
|
@ -76,20 +76,20 @@ int main (int argc, char ** argv)
|
|||||||
RealD M5 =1.8;
|
RealD M5 =1.8;
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"OverlapWilsonContFracTanhFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"OverlapWilsonContFracTanhFermion test"<<std::endl;
|
||||||
OverlapWilsonContFracTanhFermionR Dcf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonContFracTanhFermionD Dcf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
TestWhat<OverlapWilsonContFracTanhFermionR>(Dcf,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
TestWhat<OverlapWilsonContFracTanhFermionD>(Dcf,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"OverlapWilsonContFracZolotarevFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"OverlapWilsonContFracZolotarevFermion test"<<std::endl;
|
||||||
OverlapWilsonContFracZolotarevFermionR Dcfz(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,0.1,6.0);
|
OverlapWilsonContFracZolotarevFermionD Dcfz(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,0.1,6.0);
|
||||||
TestWhat<OverlapWilsonContFracZolotarevFermionR>(Dcfz,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
TestWhat<OverlapWilsonContFracZolotarevFermionD>(Dcfz,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"OverlapWilsonPartialFractionTanhFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"OverlapWilsonPartialFractionTanhFermion test"<<std::endl;
|
||||||
OverlapWilsonPartialFractionTanhFermionR Dpf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonPartialFractionTanhFermionD Dpf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
TestWhat<OverlapWilsonPartialFractionTanhFermionR>(Dpf,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
TestWhat<OverlapWilsonPartialFractionTanhFermionD>(Dpf,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"OverlapWilsonPartialFractionZolotarevFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"OverlapWilsonPartialFractionZolotarevFermion test"<<std::endl;
|
||||||
OverlapWilsonPartialFractionZolotarevFermionR Dpfz(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,0.1,6.0);
|
OverlapWilsonPartialFractionZolotarevFermionD Dpfz(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,0.1,6.0);
|
||||||
TestWhat<OverlapWilsonPartialFractionZolotarevFermionR>(Dpfz,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
TestWhat<OverlapWilsonPartialFractionZolotarevFermionD>(Dpfz,FGrid,FrbGrid,UGrid,UrbGrid,mass,M5,&RNG4,&RNG5);
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
}
|
}
|
||||||
|
@ -90,7 +90,7 @@ int main (int argc, char ** argv)
|
|||||||
RealD shift = 0.1234;
|
RealD shift = 0.1234;
|
||||||
RealD M5 = 1.8;
|
RealD M5 = 1.8;
|
||||||
int pm = 1;
|
int pm = 1;
|
||||||
DomainWallEOFAFermionR Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mq1, mq2, mq3, shift, pm, M5);
|
DomainWallEOFAFermionD Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mq1, mq2, mq3, shift, pm, M5);
|
||||||
|
|
||||||
LatticeFermion src_e (FrbGrid);
|
LatticeFermion src_e (FrbGrid);
|
||||||
LatticeFermion src_o (FrbGrid);
|
LatticeFermion src_o (FrbGrid);
|
||||||
@ -216,7 +216,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd , phi_o, phi);
|
pickCheckerboard(Odd , phi_o, phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<DomainWallEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<DomainWallEOFAFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o, dchi_o);
|
HermOpEO.MpcDagMpc(chi_o, dchi_o);
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ int main (int argc, char ** argv)
|
|||||||
|
|
||||||
RealD mass=0.1;
|
RealD mass=0.1;
|
||||||
RealD M5 =1.8;
|
RealD M5 =1.8;
|
||||||
DomainWallFermionR Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
DomainWallFermionD Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
||||||
|
|
||||||
LatticeFermion src_e (FrbGrid);
|
LatticeFermion src_e (FrbGrid);
|
||||||
LatticeFermion src_o (FrbGrid);
|
LatticeFermion src_o (FrbGrid);
|
||||||
@ -213,7 +213,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<DomainWallFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<DomainWallFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -52,7 +52,7 @@ int main (int argc, char ** argv)
|
|||||||
// pRNG.SeedFixedIntegers(seeds);
|
// pRNG.SeedFixedIntegers(seeds);
|
||||||
pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9}));
|
pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9}));
|
||||||
|
|
||||||
typedef typename GparityWilsonFermionR::FermionField FermionField;
|
typedef typename GparityWilsonFermionD::FermionField FermionField;
|
||||||
|
|
||||||
FermionField src (&Grid); random(pRNG,src);
|
FermionField src (&Grid); random(pRNG,src);
|
||||||
FermionField phi (&Grid); random(pRNG,phi);
|
FermionField phi (&Grid); random(pRNG,phi);
|
||||||
@ -80,10 +80,10 @@ int main (int argc, char ** argv)
|
|||||||
|
|
||||||
RealD mass=0.1;
|
RealD mass=0.1;
|
||||||
|
|
||||||
GparityWilsonFermionR::ImplParams params;
|
GparityWilsonFermionD::ImplParams params;
|
||||||
std::vector<int> twists(Nd,0); twists[1] = 1;
|
std::vector<int> twists(Nd,0); twists[1] = 1;
|
||||||
params.twists = twists;
|
params.twists = twists;
|
||||||
GparityWilsonFermionR Dw(Umu,Grid,RBGrid,mass,params);
|
GparityWilsonFermionD Dw(Umu,Grid,RBGrid,mass,params);
|
||||||
|
|
||||||
FermionField src_e (&RBGrid);
|
FermionField src_e (&RBGrid);
|
||||||
FermionField src_o (&RBGrid);
|
FermionField src_o (&RBGrid);
|
||||||
@ -199,7 +199,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<GparityWilsonFermionR,FermionField> HermOpEO(Dw);
|
SchurDiagMooeeOperator<GparityWilsonFermionD,FermionField> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -92,7 +92,7 @@ int main (int argc, char ** argv)
|
|||||||
RealD shift = 0.1234;
|
RealD shift = 0.1234;
|
||||||
RealD M5 = 1.8;
|
RealD M5 = 1.8;
|
||||||
int pm = 1;
|
int pm = 1;
|
||||||
MobiusEOFAFermionR Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mq1, mq2, mq3, shift, pm, M5, b, c);
|
MobiusEOFAFermionD Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mq1, mq2, mq3, shift, pm, M5, b, c);
|
||||||
|
|
||||||
LatticeFermion src_e (FrbGrid);
|
LatticeFermion src_e (FrbGrid);
|
||||||
LatticeFermion src_o (FrbGrid);
|
LatticeFermion src_o (FrbGrid);
|
||||||
@ -218,7 +218,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd , phi_o, phi);
|
pickCheckerboard(Odd , phi_o, phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<MobiusEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<MobiusEOFAFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o, dchi_o);
|
HermOpEO.MpcDagMpc(chi_o, dchi_o);
|
||||||
|
|
||||||
|
@ -108,8 +108,8 @@ int main (int argc, char ** argv)
|
|||||||
omegas.push_back( std::complex<double>(0.0686324988446592,-0.0550658530827402) );
|
omegas.push_back( std::complex<double>(0.0686324988446592,-0.0550658530827402) );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
MobiusFermionR Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, 0.5,0.5);
|
MobiusFermionD Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, 0.5,0.5);
|
||||||
// DomainWallFermionR Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
// DomainWallFermionD Ddwf(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
||||||
|
|
||||||
LatticeFermion src_e (FrbGrid);
|
LatticeFermion src_e (FrbGrid);
|
||||||
LatticeFermion src_o (FrbGrid);
|
LatticeFermion src_o (FrbGrid);
|
||||||
@ -264,7 +264,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<MobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<MobiusFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -53,9 +53,9 @@ int main (int argc, char ** argv)
|
|||||||
pRNG.SeedFixedIntegers(seeds);
|
pRNG.SeedFixedIntegers(seeds);
|
||||||
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
||||||
|
|
||||||
typedef typename ImprovedStaggeredFermionR::FermionField FermionField;
|
typedef typename ImprovedStaggeredFermionD::FermionField FermionField;
|
||||||
typedef typename ImprovedStaggeredFermionR::ComplexField ComplexField;
|
typedef typename ImprovedStaggeredFermionD::ComplexField ComplexField;
|
||||||
typename ImprovedStaggeredFermionR::ImplParams params;
|
typename ImprovedStaggeredFermionD::ImplParams params;
|
||||||
|
|
||||||
FermionField src (&Grid); random(pRNG,src);
|
FermionField src (&Grid); random(pRNG,src);
|
||||||
FermionField result(&Grid); result=Zero();
|
FermionField result(&Grid); result=Zero();
|
||||||
@ -130,7 +130,7 @@ int main (int argc, char ** argv)
|
|||||||
// ref = ref + mass * src;
|
// ref = ref + mass * src;
|
||||||
}
|
}
|
||||||
|
|
||||||
ImprovedStaggeredFermionR Ds(Umu,Umu,Grid,RBGrid,mass,c1,c2,u0,params);
|
ImprovedStaggeredFermionD Ds(Umu,Umu,Grid,RBGrid,mass,c1,c2,u0,params);
|
||||||
|
|
||||||
|
|
||||||
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
||||||
@ -269,7 +269,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<ImprovedStaggeredFermionR,FermionField> HermOpEO(Ds);
|
SchurDiagMooeeOperator<ImprovedStaggeredFermionD,FermionField> HermOpEO(Ds);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -60,9 +60,9 @@ int main (int argc, char ** argv)
|
|||||||
pRNG4.SeedFixedIntegers(seeds);
|
pRNG4.SeedFixedIntegers(seeds);
|
||||||
pRNG5.SeedFixedIntegers(seeds);
|
pRNG5.SeedFixedIntegers(seeds);
|
||||||
|
|
||||||
typedef typename ImprovedStaggeredFermion5DR::FermionField FermionField;
|
typedef typename ImprovedStaggeredFermion5DD::FermionField FermionField;
|
||||||
typedef typename ImprovedStaggeredFermion5DR::ComplexField ComplexField;
|
typedef typename ImprovedStaggeredFermion5DD::ComplexField ComplexField;
|
||||||
typename ImprovedStaggeredFermion5DR::ImplParams params;
|
typename ImprovedStaggeredFermion5DD::ImplParams params;
|
||||||
|
|
||||||
FermionField src (FGrid);
|
FermionField src (FGrid);
|
||||||
|
|
||||||
@ -148,7 +148,7 @@ int main (int argc, char ** argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ImprovedStaggeredFermion5DR Ds(Umu,Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,c1,c2,u0,params);
|
ImprovedStaggeredFermion5DD Ds(Umu,Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,c1,c2,u0,params);
|
||||||
|
|
||||||
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage<<"= Testing Dhop against cshift implementation "<<std::endl;
|
std::cout<<GridLogMessage<<"= Testing Dhop against cshift implementation "<<std::endl;
|
||||||
@ -288,7 +288,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<ImprovedStaggeredFermion5DR,FermionField> HermOpEO(Ds);
|
SchurDiagMooeeOperator<ImprovedStaggeredFermion5DD,FermionField> HermOpEO(Ds);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -52,9 +52,9 @@ int main (int argc, char ** argv)
|
|||||||
pRNG.SeedFixedIntegers(seeds);
|
pRNG.SeedFixedIntegers(seeds);
|
||||||
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
||||||
|
|
||||||
typedef typename NaiveStaggeredFermionR::FermionField FermionField;
|
typedef typename NaiveStaggeredFermionD::FermionField FermionField;
|
||||||
typedef typename NaiveStaggeredFermionR::ComplexField ComplexField;
|
typedef typename NaiveStaggeredFermionD::ComplexField ComplexField;
|
||||||
typename NaiveStaggeredFermionR::ImplParams params;
|
typename NaiveStaggeredFermionD::ImplParams params;
|
||||||
|
|
||||||
FermionField src (&Grid); random(pRNG,src);
|
FermionField src (&Grid); random(pRNG,src);
|
||||||
FermionField result(&Grid); result=Zero();
|
FermionField result(&Grid); result=Zero();
|
||||||
@ -120,7 +120,7 @@ int main (int argc, char ** argv)
|
|||||||
// ref = ref + mass * src;
|
// ref = ref + mass * src;
|
||||||
}
|
}
|
||||||
|
|
||||||
NaiveStaggeredFermionR Ds(Umu,Grid,RBGrid,mass,c1,u0,params);
|
NaiveStaggeredFermionD Ds(Umu,Grid,RBGrid,mass,c1,u0,params);
|
||||||
|
|
||||||
|
|
||||||
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
std::cout<<GridLogMessage<<"=========================================================="<<std::endl;
|
||||||
@ -258,7 +258,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<NaiveStaggeredFermionR,FermionField> HermOpEO(Ds);
|
SchurDiagMooeeOperator<NaiveStaggeredFermionD,FermionField> HermOpEO(Ds);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -52,8 +52,8 @@ int main(int argc, char **argv)
|
|||||||
pRNG.SeedFixedIntegers(seeds);
|
pRNG.SeedFixedIntegers(seeds);
|
||||||
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
||||||
|
|
||||||
typedef typename WilsonCloverFermionR::FermionField FermionField;
|
typedef typename WilsonCloverFermionD::FermionField FermionField;
|
||||||
typename WilsonCloverFermionR::ImplParams params;
|
typename WilsonCloverFermionD::ImplParams params;
|
||||||
WilsonAnisotropyCoefficients anis;
|
WilsonAnisotropyCoefficients anis;
|
||||||
|
|
||||||
FermionField src(&Grid);
|
FermionField src(&Grid);
|
||||||
@ -88,8 +88,8 @@ int main(int argc, char **argv)
|
|||||||
RealD csw_r = 1.0;
|
RealD csw_r = 1.0;
|
||||||
RealD csw_t = 1.0;
|
RealD csw_t = 1.0;
|
||||||
|
|
||||||
WilsonCloverFermionR Dwc(Umu, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
WilsonCloverFermionD Dwc(Umu, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
||||||
CompactWilsonCloverFermionR Dwc_compact(Umu, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonCloverFermionD Dwc_compact(Umu, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
|
|
||||||
std::cout << GridLogMessage << "==========================================================" << std::endl;
|
std::cout << GridLogMessage << "==========================================================" << std::endl;
|
||||||
std::cout << GridLogMessage << "= Testing that Deo + Doe = Dunprec " << std::endl;
|
std::cout << GridLogMessage << "= Testing that Deo + Doe = Dunprec " << std::endl;
|
||||||
@ -324,8 +324,8 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
/////////////////
|
/////////////////
|
||||||
|
|
||||||
WilsonCloverFermionR Dwc_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
WilsonCloverFermionD Dwc_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
||||||
CompactWilsonCloverFermionR Dwc_compact_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonCloverFermionD Dwc_compact_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
|
|
||||||
tmp = Omega * src;
|
tmp = Omega * src;
|
||||||
pickCheckerboard(Even, src_e, tmp);
|
pickCheckerboard(Even, src_e, tmp);
|
||||||
@ -377,14 +377,14 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
|
|
||||||
WilsonFermionR Dw(Umu, Grid, RBGrid, mass, params);
|
WilsonFermionD Dw(Umu, Grid, RBGrid, mass, params);
|
||||||
|
|
||||||
Dw.M(src, result);
|
Dw.M(src, result);
|
||||||
Dwc.M(src, chi);
|
Dwc.M(src, chi);
|
||||||
|
|
||||||
Dwc_prime.M(Omega * src, phi);
|
Dwc_prime.M(Omega * src, phi);
|
||||||
|
|
||||||
WilsonFermionR Dw_prime(U_prime, Grid, RBGrid, mass, params);
|
WilsonFermionD Dw_prime(U_prime, Grid, RBGrid, mass, params);
|
||||||
Dw_prime.M(Omega * src, result2);
|
Dw_prime.M(Omega * src, result2);
|
||||||
|
|
||||||
err = result - adj(Omega) * result2;
|
err = result - adj(Omega) * result2;
|
||||||
@ -411,7 +411,7 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
err = Zero();
|
err = Zero();
|
||||||
WilsonCloverFermionR Dwc_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, anis, params); // <-- Notice: csw=0
|
WilsonCloverFermionD Dwc_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, anis, params); // <-- Notice: csw=0
|
||||||
|
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd, phi_o, phi);
|
pickCheckerboard(Odd, phi_o, phi);
|
||||||
@ -437,7 +437,7 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
err = Zero();
|
err = Zero();
|
||||||
CompactWilsonCloverFermionR Dwc_compact_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, 1.0, anis, params); // <-- Notice: csw=0
|
CompactWilsonCloverFermionD Dwc_compact_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, 1.0, anis, params); // <-- Notice: csw=0
|
||||||
|
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd, phi_o, phi);
|
pickCheckerboard(Odd, phi_o, phi);
|
||||||
|
@ -74,7 +74,7 @@ int main (int argc, char ** argv)
|
|||||||
SU<Nc>::HotConfiguration(RNG4,Umu);
|
SU<Nc>::HotConfiguration(RNG4,Umu);
|
||||||
}
|
}
|
||||||
|
|
||||||
typename WilsonCloverFermionR::ImplParams params;
|
typename WilsonCloverFermionD::ImplParams params;
|
||||||
WilsonAnisotropyCoefficients anis;
|
WilsonAnisotropyCoefficients anis;
|
||||||
RealD mass = 0.1;
|
RealD mass = 0.1;
|
||||||
RealD csw_r = 1.0;
|
RealD csw_r = 1.0;
|
||||||
@ -83,32 +83,32 @@ int main (int argc, char ** argv)
|
|||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"WilsonFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"WilsonFermion test"<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
WilsonFermionR Dw(Umu,*UGrid,*UrbGrid,mass,params);
|
WilsonFermionD Dw(Umu,*UGrid,*UrbGrid,mass,params);
|
||||||
TestConserved<WilsonFermionR>(Dw,Umu,UGrid,UrbGrid,&RNG4);
|
TestConserved<WilsonFermionD>(Dw,Umu,UGrid,UrbGrid,&RNG4);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"WilsonCloverFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"WilsonCloverFermion test"<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
WilsonCloverFermionR Dwc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, anis, params);
|
WilsonCloverFermionD Dwc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, anis, params);
|
||||||
TestConserved<WilsonCloverFermionR>(Dwc,Umu,UGrid,UrbGrid,&RNG4);
|
TestConserved<WilsonCloverFermionD>(Dwc,Umu,UGrid,UrbGrid,&RNG4);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"CompactWilsonCloverFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"CompactWilsonCloverFermion test"<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
CompactWilsonCloverFermionR Dwcc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonCloverFermionD Dwcc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
TestConserved<CompactWilsonCloverFermionR>(Dwcc,Umu,UGrid,UrbGrid,&RNG4);
|
TestConserved<CompactWilsonCloverFermionD>(Dwcc,Umu,UGrid,UrbGrid,&RNG4);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"WilsonExpCloverFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"WilsonExpCloverFermion test"<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
WilsonExpCloverFermionR Dewc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, anis, params);
|
WilsonExpCloverFermionD Dewc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, anis, params);
|
||||||
TestConserved<WilsonExpCloverFermionR>(Dewc,Umu,UGrid,UrbGrid,&RNG4);
|
TestConserved<WilsonExpCloverFermionD>(Dewc,Umu,UGrid,UrbGrid,&RNG4);
|
||||||
|
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"CompactWilsonExpCloverFermion test"<<std::endl;
|
std::cout<<GridLogMessage <<"CompactWilsonExpCloverFermion test"<<std::endl;
|
||||||
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
std::cout<<GridLogMessage <<"=================================="<<std::endl;
|
||||||
CompactWilsonExpCloverFermionR Dewcc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonExpCloverFermionD Dewcc(Umu, *UGrid, *UrbGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
TestConserved<CompactWilsonExpCloverFermionR>(Dewcc,Umu,UGrid,UrbGrid,&RNG4);
|
TestConserved<CompactWilsonExpCloverFermionD>(Dewcc,Umu,UGrid,UrbGrid,&RNG4);
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
}
|
}
|
||||||
|
@ -89,7 +89,7 @@ int main (int argc, char ** argv)
|
|||||||
|
|
||||||
RealD mass=0.1;
|
RealD mass=0.1;
|
||||||
|
|
||||||
WilsonFermionR Dw(Umu,Grid,RBGrid,mass);
|
WilsonFermionD Dw(Umu,Grid,RBGrid,mass);
|
||||||
|
|
||||||
LatticeFermion src_e (&RBGrid);
|
LatticeFermion src_e (&RBGrid);
|
||||||
LatticeFermion src_o (&RBGrid);
|
LatticeFermion src_o (&RBGrid);
|
||||||
@ -205,7 +205,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<WilsonFermionR,LatticeFermion> HermOpEO(Dw);
|
SchurDiagMooeeOperator<WilsonFermionD,LatticeFermion> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -52,8 +52,8 @@ int main(int argc, char **argv)
|
|||||||
pRNG.SeedFixedIntegers(seeds);
|
pRNG.SeedFixedIntegers(seeds);
|
||||||
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
// pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9});
|
||||||
|
|
||||||
typedef typename WilsonExpCloverFermionR::FermionField FermionField;
|
typedef typename WilsonExpCloverFermionD::FermionField FermionField;
|
||||||
typename WilsonExpCloverFermionR::ImplParams params;
|
typename WilsonExpCloverFermionD::ImplParams params;
|
||||||
WilsonAnisotropyCoefficients anis;
|
WilsonAnisotropyCoefficients anis;
|
||||||
|
|
||||||
FermionField src(&Grid);
|
FermionField src(&Grid);
|
||||||
@ -88,8 +88,8 @@ int main(int argc, char **argv)
|
|||||||
RealD csw_r = 1.0;
|
RealD csw_r = 1.0;
|
||||||
RealD csw_t = 1.0;
|
RealD csw_t = 1.0;
|
||||||
|
|
||||||
WilsonExpCloverFermionR Dwc(Umu, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
WilsonExpCloverFermionD Dwc(Umu, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
||||||
CompactWilsonExpCloverFermionR Dwc_compact(Umu, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonExpCloverFermionD Dwc_compact(Umu, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
|
|
||||||
std::cout << GridLogMessage << "==========================================================" << std::endl;
|
std::cout << GridLogMessage << "==========================================================" << std::endl;
|
||||||
std::cout << GridLogMessage << "= Testing that Deo + Doe = Dunprec " << std::endl;
|
std::cout << GridLogMessage << "= Testing that Deo + Doe = Dunprec " << std::endl;
|
||||||
@ -324,8 +324,8 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
/////////////////
|
/////////////////
|
||||||
|
|
||||||
WilsonExpCloverFermionR Dwc_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
WilsonExpCloverFermionD Dwc_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, anis, params);
|
||||||
CompactWilsonExpCloverFermionR Dwc_compact_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
CompactWilsonExpCloverFermionD Dwc_compact_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, 1.0, anis, params);
|
||||||
|
|
||||||
tmp = Omega * src;
|
tmp = Omega * src;
|
||||||
pickCheckerboard(Even, src_e, tmp);
|
pickCheckerboard(Even, src_e, tmp);
|
||||||
@ -377,14 +377,14 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
|
|
||||||
WilsonFermionR Dw(Umu, Grid, RBGrid, mass, params);
|
WilsonFermionD Dw(Umu, Grid, RBGrid, mass, params);
|
||||||
|
|
||||||
Dw.M(src, result);
|
Dw.M(src, result);
|
||||||
Dwc.M(src, chi);
|
Dwc.M(src, chi);
|
||||||
|
|
||||||
Dwc_prime.M(Omega * src, phi);
|
Dwc_prime.M(Omega * src, phi);
|
||||||
|
|
||||||
WilsonFermionR Dw_prime(U_prime, Grid, RBGrid, mass, params);
|
WilsonFermionD Dw_prime(U_prime, Grid, RBGrid, mass, params);
|
||||||
Dw_prime.M(Omega * src, result2);
|
Dw_prime.M(Omega * src, result2);
|
||||||
|
|
||||||
err = result - adj(Omega) * result2;
|
err = result - adj(Omega) * result2;
|
||||||
@ -411,7 +411,7 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
err = Zero();
|
err = Zero();
|
||||||
WilsonExpCloverFermionR Dwc_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, anis, params); // <-- Notice: csw=0
|
WilsonExpCloverFermionD Dwc_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, anis, params); // <-- Notice: csw=0
|
||||||
|
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd, phi_o, phi);
|
pickCheckerboard(Odd, phi_o, phi);
|
||||||
@ -437,7 +437,7 @@ int main(int argc, char **argv)
|
|||||||
chi = Zero();
|
chi = Zero();
|
||||||
phi = Zero();
|
phi = Zero();
|
||||||
err = Zero();
|
err = Zero();
|
||||||
CompactWilsonExpCloverFermionR Dwc_compact_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, 1.0, anis, params); // <-- Notice: csw=0
|
CompactWilsonExpCloverFermionD Dwc_compact_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, 1.0, anis, params); // <-- Notice: csw=0
|
||||||
|
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd, phi_o, phi);
|
pickCheckerboard(Odd, phi_o, phi);
|
||||||
|
@ -90,7 +90,7 @@ int main (int argc, char ** argv)
|
|||||||
|
|
||||||
RealD mass=0.1;
|
RealD mass=0.1;
|
||||||
RealD mu = 0.1;
|
RealD mu = 0.1;
|
||||||
WilsonTMFermionR Dw(Umu,Grid,RBGrid,mass,mu);
|
WilsonTMFermionD Dw(Umu,Grid,RBGrid,mass,mu);
|
||||||
|
|
||||||
LatticeFermion src_e (&RBGrid);
|
LatticeFermion src_e (&RBGrid);
|
||||||
LatticeFermion src_o (&RBGrid);
|
LatticeFermion src_o (&RBGrid);
|
||||||
@ -206,7 +206,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
SchurDiagMooeeOperator<WilsonTMFermionR,LatticeFermion> HermOpEO(Dw);
|
SchurDiagMooeeOperator<WilsonTMFermionD,LatticeFermion> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -123,7 +123,7 @@ int main (int argc, char ** argv)
|
|||||||
RealD _mass,RealD _M5,
|
RealD _mass,RealD _M5,
|
||||||
std::vector<ComplexD> &gamma, RealD b,RealD c,const ImplParams &p= ImplParams()) :
|
std::vector<ComplexD> &gamma, RealD b,RealD c,const ImplParams &p= ImplParams()) :
|
||||||
*/
|
*/
|
||||||
ZMobiusFermionR Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, omegas,RealD(1.),RealD(0.));
|
ZMobiusFermionD Ddwf(Umu, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, omegas,RealD(1.),RealD(0.));
|
||||||
|
|
||||||
LatticeFermion src_e (FrbGrid);
|
LatticeFermion src_e (FrbGrid);
|
||||||
LatticeFermion src_o (FrbGrid);
|
LatticeFermion src_o (FrbGrid);
|
||||||
@ -278,7 +278,7 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<ZMobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<ZMobiusFermionD,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
HermOpEO.MpcDagMpc(chi_o,dchi_o);
|
||||||
|
|
||||||
|
@ -66,7 +66,7 @@ int main (int argc, char ** argv)
|
|||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
RealD mass=0.01;
|
RealD mass=0.01;
|
||||||
RealD M5=1.8;
|
RealD M5=1.8;
|
||||||
OverlapWilsonContFracTanhFermionR Dcf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonContFracTanhFermionD Dcf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
Dcf.M (phi,Mphi);
|
Dcf.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -67,7 +67,7 @@ int main (int argc, char ** argv)
|
|||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
RealD mass=0.01;
|
RealD mass=0.01;
|
||||||
RealD M5=1.8;
|
RealD M5=1.8;
|
||||||
DomainWallFermionR Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
DomainWallFermionD Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5);
|
||||||
Ddwf.M (phi,Mphi);
|
Ddwf.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -80,8 +80,8 @@ int main (int argc, char** argv)
|
|||||||
RealD mf = 0.01;
|
RealD mf = 0.01;
|
||||||
RealD mb = 1.0;
|
RealD mb = 1.0;
|
||||||
RealD M5 = 1.8;
|
RealD M5 = 1.8;
|
||||||
DomainWallEOFAFermionR Lop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mf, mf, mb, 0.0, -1, M5);
|
DomainWallEOFAFermionD Lop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mf, mf, mb, 0.0, -1, M5);
|
||||||
DomainWallEOFAFermionR Rop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mb, mf, mb, -1.0, 1, M5);
|
DomainWallEOFAFermionD Rop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mb, mf, mb, -1.0, 1, M5);
|
||||||
OneFlavourRationalParams Params(0.95, 100.0, 5000, 1.0e-12, 12);
|
OneFlavourRationalParams Params(0.95, 100.0, 5000, 1.0e-12, 12);
|
||||||
ConjugateGradient<LatticeFermion> CG(1.0e-12, 5000);
|
ConjugateGradient<LatticeFermion> CG(1.0e-12, 5000);
|
||||||
ExactOneFlavourRatioPseudoFermionAction<WilsonImplR> Meofa(Lop, Rop, CG, CG, CG, CG, CG, Params, true);
|
ExactOneFlavourRatioPseudoFermionAction<WilsonImplR> Meofa(Lop, Rop, CG, CG, CG, CG, CG, Params, true);
|
||||||
|
@ -47,7 +47,7 @@ int main (int argc, char ** argv)
|
|||||||
GridCartesian * FGrid = SpaceTimeGrid::makeFiveDimGrid(Ls,UGrid);
|
GridCartesian * FGrid = SpaceTimeGrid::makeFiveDimGrid(Ls,UGrid);
|
||||||
GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,UGrid);
|
GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,UGrid);
|
||||||
|
|
||||||
typedef typename GparityDomainWallFermionR::FermionField FermionField;
|
typedef typename GparityDomainWallFermionD::FermionField FermionField;
|
||||||
|
|
||||||
int threads = GridThread::GetThreads();
|
int threads = GridThread::GetThreads();
|
||||||
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
||||||
@ -76,10 +76,10 @@ int main (int argc, char ** argv)
|
|||||||
std::vector<int> twists(Nd,0);
|
std::vector<int> twists(Nd,0);
|
||||||
twists[nu] = 1;
|
twists[nu] = 1;
|
||||||
twists[Nd-1] = 1; //antiperiodic in time
|
twists[Nd-1] = 1; //antiperiodic in time
|
||||||
GparityDomainWallFermionR::ImplParams params;
|
GparityDomainWallFermionD::ImplParams params;
|
||||||
params.twists = twists;
|
params.twists = twists;
|
||||||
|
|
||||||
GparityDomainWallFermionR Dw(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,params);
|
GparityDomainWallFermionD Dw(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,params);
|
||||||
|
|
||||||
Dw.M (phi,Mphi);
|
Dw.M (phi,Mphi);
|
||||||
|
|
||||||
|
@ -33,7 +33,7 @@ using namespace std;
|
|||||||
using namespace Grid;
|
using namespace Grid;
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy;
|
typedef GparityWilsonImplR FermionImplPolicy;
|
||||||
typedef GparityDomainWallEOFAFermionR FermionAction;
|
typedef GparityDomainWallEOFAFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
int main (int argc, char** argv)
|
int main (int argc, char** argv)
|
||||||
|
@ -56,7 +56,7 @@ int main (int argc, char ** argv)
|
|||||||
int threads = GridThread::GetThreads();
|
int threads = GridThread::GetThreads();
|
||||||
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
||||||
|
|
||||||
typedef typename GparityDomainWallFermionR::FermionField FermionField;
|
typedef typename GparityDomainWallFermionD::FermionField FermionField;
|
||||||
FermionField phi (FGrid); gaussian(RNG5,phi);
|
FermionField phi (FGrid); gaussian(RNG5,phi);
|
||||||
FermionField Mphi (FGrid);
|
FermionField Mphi (FGrid);
|
||||||
FermionField MphiPrime (FGrid);
|
FermionField MphiPrime (FGrid);
|
||||||
@ -75,8 +75,8 @@ int main (int argc, char ** argv)
|
|||||||
std::vector<int> twists(Nd,0);
|
std::vector<int> twists(Nd,0);
|
||||||
twists[nu] = 1;
|
twists[nu] = 1;
|
||||||
twists[3] = 1;
|
twists[3] = 1;
|
||||||
GparityDomainWallFermionR::ImplParams params; params.twists = twists;
|
GparityDomainWallFermionD::ImplParams params; params.twists = twists;
|
||||||
GparityDomainWallFermionR Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,params);
|
GparityDomainWallFermionD Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,params);
|
||||||
Ddwf.M (phi,Mphi);
|
Ddwf.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -70,8 +70,8 @@ void convertFermion1f_from_2f(FermionField1f &out_1f, const FermionField2f &in_2
|
|||||||
|
|
||||||
int nuoff = is_4d ? 0 : 1; //s in 0 direction
|
int nuoff = is_4d ? 0 : 1; //s in 0 direction
|
||||||
|
|
||||||
int L_2f = FGrid_2f->FullDimensions()[nu+nuoff];
|
Integer L_2f = FGrid_2f->FullDimensions()[nu+nuoff];
|
||||||
int L_1f = FGrid_1f->FullDimensions()[nu+nuoff];
|
Integer L_1f = FGrid_1f->FullDimensions()[nu+nuoff];
|
||||||
assert(L_1f == 2 * L_2f);
|
assert(L_1f == 2 * L_2f);
|
||||||
|
|
||||||
auto in_f0_2fgrid = PeekIndex<GparityFlavourIndex>(in_2f,0); //flavor 0 on 2f Grid
|
auto in_f0_2fgrid = PeekIndex<GparityFlavourIndex>(in_2f,0); //flavor 0 on 2f Grid
|
||||||
|
@ -50,7 +50,7 @@ int main (int argc, char ** argv)
|
|||||||
int threads = GridThread::GetThreads();
|
int threads = GridThread::GetThreads();
|
||||||
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
std::cout<<GridLogMessage << "Grid is setup to use "<<threads<<" threads"<<std::endl;
|
||||||
|
|
||||||
typedef typename GparityDomainWallFermionR::FermionField FermionField;
|
typedef typename GparityDomainWallFermionD::FermionField FermionField;
|
||||||
FermionField phi (FGrid); gaussian(RNG4,phi);
|
FermionField phi (FGrid); gaussian(RNG4,phi);
|
||||||
FermionField Mphi (FGrid);
|
FermionField Mphi (FGrid);
|
||||||
FermionField MphiPrime (FGrid);
|
FermionField MphiPrime (FGrid);
|
||||||
@ -70,8 +70,8 @@ int main (int argc, char ** argv)
|
|||||||
std::vector<int> twists(Nd,0);
|
std::vector<int> twists(Nd,0);
|
||||||
twists[nu] = 1;
|
twists[nu] = 1;
|
||||||
twists[3]=1;
|
twists[3]=1;
|
||||||
GparityWilsonFermionR::ImplParams params; params.twists = twists;
|
GparityWilsonFermionD::ImplParams params; params.twists = twists;
|
||||||
GparityWilsonFermionR Wil(U,*UGrid,*UrbGrid,mass,params);
|
GparityWilsonFermionD Wil(U,*UGrid,*UrbGrid,mass,params);
|
||||||
Wil.M (phi,Mphi);
|
Wil.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -76,7 +76,7 @@ int main (int argc, char ** argv)
|
|||||||
p.boundary_phases[2] = 1.0;
|
p.boundary_phases[2] = 1.0;
|
||||||
p.boundary_phases[3] =- 1.0;
|
p.boundary_phases[3] =- 1.0;
|
||||||
|
|
||||||
MobiusFermionR Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,b,c,p);
|
MobiusFermionD Ddwf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,b,c,p);
|
||||||
Ddwf.M (phi,Mphi);
|
Ddwf.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -82,8 +82,8 @@ int main (int argc, char** argv)
|
|||||||
RealD mf = 0.01;
|
RealD mf = 0.01;
|
||||||
RealD mb = 1.0;
|
RealD mb = 1.0;
|
||||||
RealD M5 = 1.8;
|
RealD M5 = 1.8;
|
||||||
MobiusEOFAFermionR Lop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mf, mf, mb, 0.0, -1, M5, b, c);
|
MobiusEOFAFermionD Lop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mf, mf, mb, 0.0, -1, M5, b, c);
|
||||||
MobiusEOFAFermionR Rop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mb, mf, mb, -1.0, 1, M5, b, c);
|
MobiusEOFAFermionD Rop(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mb, mf, mb, -1.0, 1, M5, b, c);
|
||||||
OneFlavourRationalParams Params(0.95, 100.0, 5000, 1.0e-12, 12);
|
OneFlavourRationalParams Params(0.95, 100.0, 5000, 1.0e-12, 12);
|
||||||
ConjugateGradient<LatticeFermion> CG(1.0e-12, 5000);
|
ConjugateGradient<LatticeFermion> CG(1.0e-12, 5000);
|
||||||
ExactOneFlavourRatioPseudoFermionAction<WilsonImplR> Meofa(Lop, Rop, CG, CG, CG, CG, CG, Params, false);
|
ExactOneFlavourRatioPseudoFermionAction<WilsonImplR> Meofa(Lop, Rop, CG, CG, CG, CG, CG, Params, false);
|
||||||
|
@ -34,7 +34,7 @@ using namespace Grid;
|
|||||||
;
|
;
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy;
|
typedef GparityWilsonImplR FermionImplPolicy;
|
||||||
typedef GparityMobiusEOFAFermionR FermionAction;
|
typedef GparityMobiusEOFAFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
int main (int argc, char** argv)
|
int main (int argc, char** argv)
|
||||||
|
@ -69,7 +69,7 @@ int main (int argc, char ** argv)
|
|||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
RealD mass=0.01;
|
RealD mass=0.01;
|
||||||
RealD M5=1.8;
|
RealD M5=1.8;
|
||||||
OverlapWilsonPartialFractionTanhFermionR Dpf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
OverlapWilsonPartialFractionTanhFermionD Dpf(U,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,1.0);
|
||||||
Dpf.M (phi,Mphi);
|
Dpf.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -67,7 +67,7 @@ int main (int argc, char ** argv)
|
|||||||
// Unmodified matrix element
|
// Unmodified matrix element
|
||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
RealD mass=-4.0; //kills the diagonal term
|
RealD mass=-4.0; //kills the diagonal term
|
||||||
WilsonFermionR Dw (U, Grid,RBGrid,mass);
|
WilsonFermionD Dw (U, Grid,RBGrid,mass);
|
||||||
Dw.M (phi,Mphi);
|
Dw.M (phi,Mphi);
|
||||||
|
|
||||||
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
ComplexD S = innerProduct(Mphi,Mphi); // pdag MdagM p
|
||||||
|
@ -70,7 +70,7 @@ int main(int argc, char **argv)
|
|||||||
////////////////////////////////////
|
////////////////////////////////////
|
||||||
RealD mass = 0.1;
|
RealD mass = 0.1;
|
||||||
Real csw = 1.0;
|
Real csw = 1.0;
|
||||||
WilsonCloverFermionR Dw(U, Grid, RBGrid, mass, csw, csw);
|
WilsonCloverFermionD Dw(U, Grid, RBGrid, mass, csw, csw);
|
||||||
Dw.ImportGauge(U);
|
Dw.ImportGauge(U);
|
||||||
Dw.M(phi, Mphi);
|
Dw.M(phi, Mphi);
|
||||||
ComplexD S = innerProduct(Mphi, Mphi); // Action : pdag MdagM p
|
ComplexD S = innerProduct(Mphi, Mphi); // Action : pdag MdagM p
|
||||||
|
@ -81,7 +81,7 @@ int main (int argc, char ** argv)
|
|||||||
omegas.push_back( std::complex<double>(0.0686324988446592,0.0550658530827402) );
|
omegas.push_back( std::complex<double>(0.0686324988446592,0.0550658530827402) );
|
||||||
omegas.push_back( std::complex<double>(0.0686324988446592,-0.0550658530827402) );
|
omegas.push_back( std::complex<double>(0.0686324988446592,-0.0550658530827402) );
|
||||||
|
|
||||||
ZMobiusFermionR Ddwf(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, omegas,b,c);
|
ZMobiusFermionD Ddwf(U, *FGrid, *FrbGrid, *UGrid, *UrbGrid, mass, M5, omegas,b,c);
|
||||||
|
|
||||||
Ddwf.M (phi,Mphi);
|
Ddwf.M (phi,Mphi);
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ void copy2fTo1fFermionField(FermionField1f &out, const FermionField2f &in, int g
|
|||||||
LatticeInteger xcoor_1f(out.Grid()); //5d lattice integer
|
LatticeInteger xcoor_1f(out.Grid()); //5d lattice integer
|
||||||
LatticeCoordinate(xcoor_1f,gpdir);
|
LatticeCoordinate(xcoor_1f,gpdir);
|
||||||
|
|
||||||
int L = dim_2f[gpdir];
|
Integer L = dim_2f[gpdir];
|
||||||
|
|
||||||
out = where(xcoor_1f < L, f0_fullgrid_dbl, f1_fullgrid_dbl);
|
out = where(xcoor_1f < L, f0_fullgrid_dbl, f1_fullgrid_dbl);
|
||||||
}
|
}
|
||||||
@ -76,7 +76,7 @@ void copy2fTo1fGaugeField(LatticeGaugeField &out, const LatticeGaugeField &in, i
|
|||||||
LatticeInteger xcoor_1f(out.Grid());
|
LatticeInteger xcoor_1f(out.Grid());
|
||||||
LatticeCoordinate(xcoor_1f,gpdir);
|
LatticeCoordinate(xcoor_1f,gpdir);
|
||||||
|
|
||||||
int L = dim_2f[gpdir];
|
Integer L = dim_2f[gpdir];
|
||||||
|
|
||||||
out = where(xcoor_1f < L, U_dbl, Uconj_dbl);
|
out = where(xcoor_1f < L, U_dbl, Uconj_dbl);
|
||||||
}
|
}
|
||||||
@ -140,11 +140,11 @@ int main(int argc, char **argv) {
|
|||||||
copy2fTo1fGaugeField(Umu_1f, Umu_2f, mu);
|
copy2fTo1fGaugeField(Umu_1f, Umu_2f, mu);
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy2f;
|
typedef GparityWilsonImplR FermionImplPolicy2f;
|
||||||
typedef GparityDomainWallFermionR FermionAction2f;
|
typedef GparityDomainWallFermionD FermionAction2f;
|
||||||
typedef typename FermionAction2f::FermionField FermionField2f;
|
typedef typename FermionAction2f::FermionField FermionField2f;
|
||||||
|
|
||||||
typedef WilsonImplR FermionImplPolicy1f;
|
typedef WilsonImplR FermionImplPolicy1f;
|
||||||
typedef DomainWallFermionR FermionAction1f;
|
typedef DomainWallFermionD FermionAction1f;
|
||||||
typedef typename FermionAction1f::FermionField FermionField1f;
|
typedef typename FermionAction1f::FermionField FermionField1f;
|
||||||
|
|
||||||
std::cout << "Generating eta 2f" << std::endl;
|
std::cout << "Generating eta 2f" << std::endl;
|
||||||
|
@ -43,7 +43,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef DomainWallFermionR FermionAction;
|
typedef DomainWallFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
@ -136,16 +136,9 @@ int main(int argc, char **argv) {
|
|||||||
TheHMC.ReadCommandLine(argc, argv); // these can be parameters from file
|
TheHMC.ReadCommandLine(argc, argv); // these can be parameters from file
|
||||||
|
|
||||||
// Reset performance counters
|
// Reset performance counters
|
||||||
NumOp.ZeroCounters();
|
|
||||||
DenOp.ZeroCounters();
|
|
||||||
TheHMC.Run(); // no smearing
|
TheHMC.Run(); // no smearing
|
||||||
// TheHMC.Run(SmearingPolicy); // for smearing
|
// TheHMC.Run(SmearingPolicy); // for smearing
|
||||||
|
|
||||||
std::cout << GridLogMessage << "Numerator report, Pauli-Villars term : " << std::endl;
|
|
||||||
NumOp.Report();
|
|
||||||
std::cout << GridLogMessage << "Denominator report, Dw(m) term (includes CG) : " << std::endl;
|
|
||||||
DenOp.Report();
|
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
|
|
||||||
} // main
|
} // main
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy;
|
typedef GparityWilsonImplR FermionImplPolicy;
|
||||||
typedef GparityDomainWallFermionR FermionAction;
|
typedef GparityDomainWallFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
@ -132,15 +132,9 @@ int main(int argc, char **argv) {
|
|||||||
TheHMC.ReadCommandLine(argc, argv); // these can be parameters from file
|
TheHMC.ReadCommandLine(argc, argv); // these can be parameters from file
|
||||||
|
|
||||||
// Reset performance counters
|
// Reset performance counters
|
||||||
NumOp.ZeroCounters();
|
|
||||||
DenOp.ZeroCounters();
|
|
||||||
TheHMC.Run(); // no smearing
|
TheHMC.Run(); // no smearing
|
||||||
// TheHMC.Run(SmearingPolicy); // for smearing
|
// TheHMC.Run(SmearingPolicy); // for smearing
|
||||||
|
|
||||||
std::cout << GridLogMessage << "Numerator report, Pauli-Villars term : " << std::endl;
|
|
||||||
NumOp.Report();
|
|
||||||
std::cout << GridLogMessage << "Denominator report, Dw(m) term (includes CG) : " << std::endl;
|
|
||||||
DenOp.Report();
|
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
|
|
||||||
|
@ -83,7 +83,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef MobiusFermionR FermionAction;
|
typedef MobiusFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
// Serialiser
|
// Serialiser
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
@ -211,8 +211,6 @@ int main(int argc, char **argv) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// Reset performance counters
|
// Reset performance counters
|
||||||
NumOp.ZeroCounters();
|
|
||||||
DenOp.ZeroCounters();
|
|
||||||
|
|
||||||
if (ApplySmearing){
|
if (ApplySmearing){
|
||||||
SmearingParameters SmPar(Reader);
|
SmearingParameters SmPar(Reader);
|
||||||
@ -225,11 +223,6 @@ int main(int argc, char **argv) {
|
|||||||
TheHMC.Run(); // no smearing
|
TheHMC.Run(); // no smearing
|
||||||
}
|
}
|
||||||
|
|
||||||
std::cout << GridLogMessage << "Numerator report, Pauli-Villars term : " << std::endl;
|
|
||||||
NumOp.Report();
|
|
||||||
std::cout << GridLogMessage << "Denominator report, Dw(m) term (includes CG) : " << std::endl;
|
|
||||||
DenOp.Report();
|
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
} // main
|
} // main
|
||||||
|
|
||||||
|
@ -89,7 +89,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef MobiusFermionR FermionAction;
|
typedef MobiusFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
// Serialiser
|
// Serialiser
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
@ -226,8 +226,6 @@ int main(int argc, char **argv) {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
// Reset performance counters
|
// Reset performance counters
|
||||||
NumOp.ZeroCounters();
|
|
||||||
DenOp.ZeroCounters();
|
|
||||||
|
|
||||||
if (ApplySmearing){
|
if (ApplySmearing){
|
||||||
SmearingParameters SmPar(Reader);
|
SmearingParameters SmPar(Reader);
|
||||||
@ -240,10 +238,6 @@ int main(int argc, char **argv) {
|
|||||||
TheHMC.Run(); // no smearing
|
TheHMC.Run(); // no smearing
|
||||||
}
|
}
|
||||||
|
|
||||||
std::cout << GridLogMessage << "Numerator report, Pauli-Villars term : " << std::endl;
|
|
||||||
NumOp.Report();
|
|
||||||
std::cout << GridLogMessage << "Denominator report, Dw(m) term (includes CG) : " << std::endl;
|
|
||||||
DenOp.Report();
|
|
||||||
|
|
||||||
Grid_finalize();
|
Grid_finalize();
|
||||||
} // main
|
} // main
|
||||||
|
@ -39,7 +39,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonCloverFermionR FermionAction;
|
typedef WilsonCloverFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ int main(int argc, char **argv) {
|
|||||||
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy;
|
typedef GparityWilsonImplR FermionImplPolicy;
|
||||||
typedef GparityDomainWallFermionR FermionAction;
|
typedef GparityDomainWallFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef ConjugateHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
|
|
||||||
typedef GparityWilsonImplR FermionImplPolicy;
|
typedef GparityWilsonImplR FermionImplPolicy;
|
||||||
typedef GparityDomainWallFermionR FermionAction;
|
typedef GparityDomainWallFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ int main(int argc, char **argv) {
|
|||||||
|
|
||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef MobiusFermionR FermionAction;
|
typedef MobiusFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
@ -148,14 +148,14 @@ int main(int argc, char **argv) {
|
|||||||
// Level1.push_back(&StrangePseudoFermion);
|
// Level1.push_back(&StrangePseudoFermion);
|
||||||
|
|
||||||
// DJM: setup for EOFA ratio (Shamir)
|
// DJM: setup for EOFA ratio (Shamir)
|
||||||
// DomainWallEOFAFermionR Strange_Op_L(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, strange_mass, strange_mass, pv_mass, 0.0, -1, M5);
|
// DomainWallEOFAFermionD Strange_Op_L(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, strange_mass, strange_mass, pv_mass, 0.0, -1, M5);
|
||||||
// DomainWallEOFAFermionR Strange_Op_R(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, pv_mass, strange_mass, pv_mass, -1.0, 1, M5);
|
// DomainWallEOFAFermionD Strange_Op_R(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, pv_mass, strange_mass, pv_mass, -1.0, 1, M5);
|
||||||
// ExactOneFlavourRatioPseudoFermionAction<FermionImplPolicy> EOFA(Strange_Op_L, Strange_Op_R, CG, OFRp, true);
|
// ExactOneFlavourRatioPseudoFermionAction<FermionImplPolicy> EOFA(Strange_Op_L, Strange_Op_R, CG, OFRp, true);
|
||||||
// Level1.push_back(&EOFA);
|
// Level1.push_back(&EOFA);
|
||||||
|
|
||||||
// DJM: setup for EOFA ratio (Mobius)
|
// DJM: setup for EOFA ratio (Mobius)
|
||||||
MobiusEOFAFermionR Strange_Op_L(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, strange_mass, strange_mass, pv_mass, 0.0, -1, M5, b, c);
|
MobiusEOFAFermionD Strange_Op_L(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, strange_mass, strange_mass, pv_mass, 0.0, -1, M5, b, c);
|
||||||
MobiusEOFAFermionR Strange_Op_R(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, pv_mass, strange_mass, pv_mass, -1.0, 1, M5, b, c);
|
MobiusEOFAFermionD Strange_Op_R(U, *FGrid, *FrbGrid, *GridPtr, *GridRBPtr, pv_mass, strange_mass, pv_mass, -1.0, 1, M5, b, c);
|
||||||
ExactOneFlavourRatioPseudoFermionAction<FermionImplPolicy> EOFA(Strange_Op_L, Strange_Op_R, CG, OFRp, true);
|
ExactOneFlavourRatioPseudoFermionAction<FermionImplPolicy> EOFA(Strange_Op_L, Strange_Op_R, CG, OFRp, true);
|
||||||
Level1.push_back(&EOFA);
|
Level1.push_back(&EOFA);
|
||||||
|
|
||||||
|
@ -34,7 +34,7 @@ class ScalarActionParameters : Serializable {
|
|||||||
double, lambda,
|
double, lambda,
|
||||||
double, g);
|
double, g);
|
||||||
|
|
||||||
ScalarActionParameters() = default;
|
ScalarActionParameters() {};
|
||||||
|
|
||||||
template <class ReaderClass >
|
template <class ReaderClass >
|
||||||
ScalarActionParameters(Reader<ReaderClass>& Reader){
|
ScalarActionParameters(Reader<ReaderClass>& Reader){
|
||||||
@ -45,7 +45,6 @@ class ScalarActionParameters : Serializable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
using namespace Grid;
|
using namespace Grid;
|
||||||
;
|
|
||||||
|
|
||||||
template <class Impl>
|
template <class Impl>
|
||||||
class MagMeas : public HmcObservable<typename Impl::Field> {
|
class MagMeas : public HmcObservable<typename Impl::Field> {
|
||||||
|
@ -80,7 +80,7 @@ int main(int argc, char **argv)
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonTwoIndexAntiSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonTwoIndexAntiSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonCloverTwoIndexAntiSymmetricFermionR FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonCloverTwoIndexAntiSymmetricFermionD FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
//typedef Grid::JSONReader Serialiser;
|
//typedef Grid::JSONReader Serialiser;
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
|
@ -81,7 +81,7 @@ int main(int argc, char **argv)
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonTwoIndexSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonTwoIndexSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonCloverTwoIndexSymmetricFermionR FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonCloverTwoIndexSymmetricFermionD FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
//typedef Grid::JSONReader Serialiser;
|
//typedef Grid::JSONReader Serialiser;
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
|
@ -79,7 +79,7 @@ int main(int argc, char **argv)
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonCloverFermionR FermionAction;
|
typedef WilsonCloverFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
|
|
||||||
|
@ -84,11 +84,11 @@ int main(int argc, char **argv) {
|
|||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
||||||
|
|
||||||
typedef WilsonImplR FundImplPolicy;
|
typedef WilsonImplR FundImplPolicy;
|
||||||
typedef WilsonCloverFermionR FundFermionAction;
|
typedef WilsonCloverFermionD FundFermionAction;
|
||||||
typedef typename FundFermionAction::FermionField FundFermionField;
|
typedef typename FundFermionAction::FermionField FundFermionField;
|
||||||
|
|
||||||
typedef WilsonTwoIndexAntiSymmetricImplR ASymmImplPolicy;
|
typedef WilsonTwoIndexAntiSymmetricImplR ASymmImplPolicy;
|
||||||
typedef WilsonCloverTwoIndexAntiSymmetricFermionR ASymmFermionAction;
|
typedef WilsonCloverTwoIndexAntiSymmetricFermionD ASymmFermionAction;
|
||||||
typedef typename ASymmFermionAction::FermionField ASymmFermionField;
|
typedef typename ASymmFermionAction::FermionField ASymmFermionField;
|
||||||
|
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
|
@ -81,7 +81,7 @@ int main(int argc, char **argv)
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonAdjImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonAdjImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonCloverAdjFermionR FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonCloverAdjFermionD FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
typedef Grid::XmlReader Serialiser;
|
typedef Grid::XmlReader Serialiser;
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
||||||
typedef WilsonAdjImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonAdjImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonAdjFermionR FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonAdjFermionD FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
||||||
|
@ -41,7 +41,7 @@ int main(int argc, char **argv)
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonCloverFermionR FermionAction;
|
typedef WilsonCloverFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -69,8 +69,10 @@ int main(int argc, char **argv)
|
|||||||
TopologyObsParameters TopParams;
|
TopologyObsParameters TopParams;
|
||||||
TopParams.interval = 5;
|
TopParams.interval = 5;
|
||||||
TopParams.do_smearing = true;
|
TopParams.do_smearing = true;
|
||||||
TopParams.Smearing.steps = 200;
|
TopParams.Smearing.init_step_size = 0.01;
|
||||||
TopParams.Smearing.step_size = 0.01;
|
TopParams.Smearing.tolerance = 1e-5;
|
||||||
|
// TopParams.Smearing.steps = 200;
|
||||||
|
// TopParams.Smearing.step_size = 0.01;
|
||||||
TopParams.Smearing.meas_interval = 50;
|
TopParams.Smearing.meas_interval = 50;
|
||||||
TopParams.Smearing.maxTau = 2.0;
|
TopParams.Smearing.maxTau = 2.0;
|
||||||
TheHMC.Resources.AddObservable<QObs>(TopParams);
|
TheHMC.Resources.AddObservable<QObs>(TopParams);
|
||||||
|
@ -51,9 +51,9 @@ int main(int argc, char **argv) {
|
|||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
||||||
|
|
||||||
typedef WilsonAdjImplR AdjImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonAdjImplR AdjImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonAdjFermionR AdjFermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonAdjFermionD AdjFermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef WilsonTwoIndexSymmetricImplR SymmImplPolicy;
|
typedef WilsonTwoIndexSymmetricImplR SymmImplPolicy;
|
||||||
typedef WilsonTwoIndexSymmetricFermionR SymmFermionAction;
|
typedef WilsonTwoIndexSymmetricFermionD SymmFermionAction;
|
||||||
|
|
||||||
|
|
||||||
typedef typename AdjFermionAction::FermionField AdjFermionField;
|
typedef typename AdjFermionAction::FermionField AdjFermionField;
|
||||||
|
@ -41,7 +41,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonTMFermionR FermionAction;
|
typedef WilsonTMFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ int main(int argc, char **argv) {
|
|||||||
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
typedef GenericHMCRunnerHirep<TheRepresentations, MinimumNorm2> HMCWrapper;
|
||||||
|
|
||||||
typedef WilsonTwoIndexSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
typedef WilsonTwoIndexSymmetricImplR FermionImplPolicy; // gauge field implemetation for the pseudofermions
|
||||||
typedef WilsonTwoIndexSymmetricFermionR FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
typedef WilsonTwoIndexSymmetricFermionD FermionAction; // type of lattice fermions (Wilson, DW, ...)
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
//::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::
|
||||||
|
@ -41,7 +41,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,7 +42,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
@ -41,7 +41,7 @@ int main(int argc, char **argv) {
|
|||||||
// Typedefs to simplify notation
|
// Typedefs to simplify notation
|
||||||
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
typedef GenericHMCRunner<MinimumNorm2> HMCWrapper; // Uses the default minimum norm
|
||||||
typedef WilsonImplR FermionImplPolicy;
|
typedef WilsonImplR FermionImplPolicy;
|
||||||
typedef WilsonFermionR FermionAction;
|
typedef WilsonFermionD FermionAction;
|
||||||
typedef typename FermionAction::FermionField FermionField;
|
typedef typename FermionAction::FermionField FermionField;
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user