/************************************************************************************* Grid physics library, www.github.com/paboyle/Grid Source file: ./tests/Test_cayley_even_odd.cc Copyright (C) 2015 Author: Peter Boyle This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. See the full license in the file "LICENSE" in the top level distribution directory *************************************************************************************/ /* END LEGAL */ #include using namespace std; using namespace Grid; using namespace Grid::QCD; template struct scal { d internal; }; Gamma::GammaMatrix Gmu [] = { Gamma::GammaX, Gamma::GammaY, Gamma::GammaZ, Gamma::GammaT }; typedef DomainWallFermion DomainWallVecFermionR; typedef ZMobiusFermion ZMobiusVecFermionR; typedef MobiusFermion MobiusVecFermionR; typedef MobiusZolotarevFermion MobiusZolotarevVecFermionR; typedef ScaledShamirFermion ScaledShamirVecFermionR; typedef ShamirZolotarevFermion ShamirZolotarevVecFermionR; typedef OverlapWilsonCayleyTanhFermion OverlapWilsonCayleyTanhVecFermionR; typedef OverlapWilsonCayleyZolotarevFermion OverlapWilsonCayleyZolotarevVecFermionR; template void TestWhat(What & Ddwf, GridCartesian * FGrid, GridRedBlackCartesian * FrbGrid, GridCartesian * UGrid, RealD mass, RealD M5, GridParallelRNG *RNG4, GridParallelRNG *RNG5); template void TestMoo(This & Dw, That &sDw); int main (int argc, char ** argv) { Grid_init(&argc,&argv); int threads = GridThread::GetThreads(); std::cout< latt4 =GridDefaultLatt(); GridCartesian * UGrid = SpaceTimeGrid::makeFourDimGrid(latt4, GridDefaultSimd(Nd,vComplex::Nsimd()),GridDefaultMpi()); GridRedBlackCartesian * UrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(UGrid); GridCartesian * FGrid = SpaceTimeGrid::makeFiveDimGrid(Ls,UGrid); GridRedBlackCartesian * FrbGrid = SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,UGrid); GridCartesian * sUGrid = SpaceTimeGrid::makeFourDimDWFGrid(latt4,GridDefaultMpi()); GridRedBlackCartesian * sUrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(sUGrid); GridCartesian * sFGrid = SpaceTimeGrid::makeFiveDimDWFGrid(Ls,UGrid); GridRedBlackCartesian * sFrbGrid = SpaceTimeGrid::makeFiveDimDWFRedBlackGrid(Ls,UGrid); std::vector seeds4({1,2,3,4}); std::vector seeds5({5,6,7,8}); GridParallelRNG RNG4(UGrid); RNG4.SeedFixedIntegers(seeds4); GridParallelRNG RNG5(FGrid); RNG5.SeedFixedIntegers(seeds5); GridParallelRNG sRNG4(sUGrid); sRNG4.SeedFixedIntegers(seeds4); GridParallelRNG sRNG5(sFGrid); sRNG5.SeedFixedIntegers(seeds5); LatticeGaugeField Umu(UGrid); random(RNG4,Umu); RealD mass=0.1; RealD M5 =1.8; std::cout<(Ddwf,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDdwf,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); RealD b=1.5;// Scale factor b+c=2, b-c=1 RealD c=0.5; std::cout<(Dmob,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDmob,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout< gamma(Ls,std::complex(1.0,0.0)); ZMobiusFermionR zDmob(Umu,*FGrid,*FrbGrid,*UGrid,*UrbGrid,mass,M5,gamma,b,c); ZMobiusVecFermionR szDmob(Umu,*sFGrid,*sFrbGrid,*sUGrid,*sUrbGrid,mass,M5,gamma,b,c); TestMoo(zDmob,szDmob); TestWhat(zDmob,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(szDmob,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout<(Dzolo,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDzolo,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout<(Dsham,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDsham,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout<(Dshamz,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDshamz,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout<(Dov,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDov,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout<(Dovz,FGrid,FrbGrid,UGrid,mass,M5,&RNG4,&RNG5); TestWhat(sDovz,sFGrid,sFrbGrid,sUGrid,mass,M5,&sRNG4,&sRNG5); std::cout< void TestWhat(What & Ddwf, GridCartesian * FGrid, GridRedBlackCartesian * FrbGrid, GridCartesian * UGrid, RealD mass, RealD M5, GridParallelRNG *RNG4, GridParallelRNG *RNG5) { LatticeFermion src (FGrid); random(*RNG5,src); LatticeFermion phi (FGrid); random(*RNG5,phi); LatticeFermion chi (FGrid); random(*RNG5,chi); LatticeFermion result(FGrid); result=zero; LatticeFermion ref(FGrid); ref=zero; LatticeFermion tmp(FGrid); tmp=zero; LatticeFermion err(FGrid); tmp=zero; LatticeFermion src_e (FrbGrid); LatticeFermion src_o (FrbGrid); LatticeFermion r_e (FrbGrid); LatticeFermion r_o (FrbGrid); LatticeFermion r_eo (FGrid); LatticeFermion r_eeoo(FGrid); std::cout< * = < chi | Deo^dag| phi> "< void TestMoo(This & Dw, That &sDw) { GridBase *sgrid= sDw.FermionGrid(); GridBase *ngrid= Dw.FermionGrid(); int Ls = Dw.Ls; LatticeFermion ssrc(sgrid); LatticeFermion nsrc(ngrid); LatticeFermion zz(ngrid); zz=zero; LatticeFermion sres(sgrid); LatticeFermion nres(ngrid); LatticeFermion ndiff(ngrid); LatticeFermion sdiff(sgrid); Gamma g5( Gamma::Gamma5 ); std::vector seeds({1,2,3,4,5,7,8}); GridParallelRNG RNG5(ngrid); RNG5.SeedFixedIntegers(seeds); random(RNG5,nsrc); // nsrc = nsrc + g5*nsrc; // Lattice > coor(ngrid); // LatticeCoordinate(coor,0);//scoor // nsrc = where(coor==(Integer)0,zz,nsrc); std::vector latt4(4); for(int d=0;d<4;d++){ latt4[d] = ngrid->_fdimensions[d+1]; } for(int x=0;x site({s,x,y,z,t}); SpinColourVector tmp; peekSite(tmp,nsrc,site); pokeSite(tmp,ssrc,site); }}}}} sDw.Mooee(ssrc,sres); Dw.Mooee(nsrc,nres); sDw.MooeeInternal(ssrc,sdiff,DaggerNo,InverseNo); for(int x=0;x site({s,x,y,z,t}); SpinColourVector stmp; SpinColourVector itmp; SpinColourVector dtmp; peekSite(stmp,sres,site); peekSite(itmp,sdiff,site); dtmp=itmp-stmp; if ( norm2(dtmp)>1.0e-6) { std::cout< site({s,x,y,z,t}); SpinColourVector tmp; peekSite(tmp,sres,site); pokeSite(tmp,ndiff,site); }}}}} ndiff=ndiff-nres; std::cout< site({s,x,y,z,t}); SpinColourVector tmp; peekSite(tmp,sres,site); pokeSite(tmp,ndiff,site); }}}}} ndiff=ndiff-nres; std::cout< site({s,x,y,z,t}); SpinColourVector tmp; peekSite(tmp,sres,site); pokeSite(tmp,ndiff,site); }}}}} ndiff=ndiff-nres; std::cout< site({s,x,y,z,t}); SpinColourVector tmp; peekSite(tmp,sres,site); pokeSite(tmp,ndiff,site); }}}}} ndiff=ndiff-nres; std::cout<