mirror of
https://github.com/paboyle/Grid.git
synced 2024-11-14 01:35:36 +00:00
Merge branch 'develop' of https://github.com/paboyle/Grid into develop
This commit is contained in:
commit
402523c62e
@ -358,7 +358,7 @@ public:
|
|||||||
autoView( in_v , in, AcceleratorRead);
|
autoView( in_v , in, AcceleratorRead);
|
||||||
autoView( out_v , out, AcceleratorWrite);
|
autoView( out_v , out, AcceleratorWrite);
|
||||||
autoView( Stencil_v , Stencil, AcceleratorRead);
|
autoView( Stencil_v , Stencil, AcceleratorRead);
|
||||||
auto& geom_v = geom;
|
int npoint = geom.npoint;
|
||||||
typedef LatticeView<Cobj> Aview;
|
typedef LatticeView<Cobj> Aview;
|
||||||
|
|
||||||
Vector<Aview> AcceleratorViewContainer;
|
Vector<Aview> AcceleratorViewContainer;
|
||||||
@ -380,7 +380,7 @@ public:
|
|||||||
int ptype;
|
int ptype;
|
||||||
StencilEntry *SE;
|
StencilEntry *SE;
|
||||||
|
|
||||||
for(int point=0;point<geom_v.npoint;point++){
|
for(int point=0;point<npoint;point++){
|
||||||
|
|
||||||
SE=Stencil_v.GetEntry(ptype,point,ss);
|
SE=Stencil_v.GetEntry(ptype,point,ss);
|
||||||
|
|
||||||
@ -424,7 +424,7 @@ public:
|
|||||||
autoView( in_v , in, AcceleratorRead);
|
autoView( in_v , in, AcceleratorRead);
|
||||||
autoView( out_v , out, AcceleratorWrite);
|
autoView( out_v , out, AcceleratorWrite);
|
||||||
autoView( Stencil_v , Stencil, AcceleratorRead);
|
autoView( Stencil_v , Stencil, AcceleratorRead);
|
||||||
auto& geom_v = geom;
|
int npoint = geom.npoint;
|
||||||
typedef LatticeView<Cobj> Aview;
|
typedef LatticeView<Cobj> Aview;
|
||||||
|
|
||||||
Vector<Aview> AcceleratorViewContainer;
|
Vector<Aview> AcceleratorViewContainer;
|
||||||
@ -454,7 +454,7 @@ public:
|
|||||||
int ptype;
|
int ptype;
|
||||||
StencilEntry *SE;
|
StencilEntry *SE;
|
||||||
|
|
||||||
for(int p=0;p<geom_v.npoint;p++){
|
for(int p=0;p<npoint;p++){
|
||||||
int point = points_p[p];
|
int point = points_p[p];
|
||||||
|
|
||||||
SE=Stencil_v.GetEntry(ptype,point,ss);
|
SE=Stencil_v.GetEntry(ptype,point,ss);
|
||||||
|
@ -508,7 +508,7 @@ class SchurStaggeredOperator : public SchurOperatorBase<Field> {
|
|||||||
virtual void MpcDag (const Field &in, Field &out){
|
virtual void MpcDag (const Field &in, Field &out){
|
||||||
Mpc(in,out);
|
Mpc(in,out);
|
||||||
}
|
}
|
||||||
virtual void MpcDagMpc(const Field &in, Field &out,RealD &ni,RealD &no) {
|
virtual void MpcDagMpc(const Field &in, Field &out) {
|
||||||
assert(0);// Never need with staggered
|
assert(0);// Never need with staggered
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -586,6 +586,7 @@ class HermOpOperatorFunction : public OperatorFunction<Field> {
|
|||||||
template<typename Field>
|
template<typename Field>
|
||||||
class PlainHermOp : public LinearFunction<Field> {
|
class PlainHermOp : public LinearFunction<Field> {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
LinearOperatorBase<Field> &_Linop;
|
LinearOperatorBase<Field> &_Linop;
|
||||||
|
|
||||||
PlainHermOp(LinearOperatorBase<Field>& linop) : _Linop(linop)
|
PlainHermOp(LinearOperatorBase<Field>& linop) : _Linop(linop)
|
||||||
@ -599,6 +600,7 @@ public:
|
|||||||
template<typename Field>
|
template<typename Field>
|
||||||
class FunctionHermOp : public LinearFunction<Field> {
|
class FunctionHermOp : public LinearFunction<Field> {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
OperatorFunction<Field> & _poly;
|
OperatorFunction<Field> & _poly;
|
||||||
LinearOperatorBase<Field> &_Linop;
|
LinearOperatorBase<Field> &_Linop;
|
||||||
|
|
||||||
|
@ -30,13 +30,19 @@ Author: Azusa Yamaguchi <ayamaguc@staffmail.ed.ac.uk>
|
|||||||
|
|
||||||
NAMESPACE_BEGIN(Grid);
|
NAMESPACE_BEGIN(Grid);
|
||||||
|
|
||||||
|
template<class Field> using Preconditioner = LinearFunction<Field> ;
|
||||||
|
|
||||||
|
/*
|
||||||
template<class Field> class Preconditioner : public LinearFunction<Field> {
|
template<class Field> class Preconditioner : public LinearFunction<Field> {
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
virtual void operator()(const Field &src, Field & psi)=0;
|
virtual void operator()(const Field &src, Field & psi)=0;
|
||||||
};
|
};
|
||||||
|
*/
|
||||||
|
|
||||||
template<class Field> class TrivialPrecon : public Preconditioner<Field> {
|
template<class Field> class TrivialPrecon : public Preconditioner<Field> {
|
||||||
public:
|
public:
|
||||||
void operator()(const Field &src, Field & psi){
|
using Preconditioner<Field>::operator();
|
||||||
|
virtual void operator()(const Field &src, Field & psi){
|
||||||
psi = src;
|
psi = src;
|
||||||
}
|
}
|
||||||
TrivialPrecon(void){};
|
TrivialPrecon(void){};
|
||||||
|
@ -37,6 +37,7 @@ template<class FieldD, class FieldF, typename std::enable_if< getPrecision<Field
|
|||||||
class MixedPrecisionBiCGSTAB : public LinearFunction<FieldD>
|
class MixedPrecisionBiCGSTAB : public LinearFunction<FieldD>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<FieldD>::operator();
|
||||||
RealD Tolerance;
|
RealD Tolerance;
|
||||||
RealD InnerTolerance; // Initial tolerance for inner CG. Defaults to Tolerance but can be changed
|
RealD InnerTolerance; // Initial tolerance for inner CG. Defaults to Tolerance but can be changed
|
||||||
Integer MaxInnerIterations;
|
Integer MaxInnerIterations;
|
||||||
|
@ -67,6 +67,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis>
|
template<class Fobj,class CComplex,int nbasis>
|
||||||
class ProjectedHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
class ProjectedHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<iVector<CComplex,nbasis > > >::operator();
|
||||||
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
||||||
typedef Lattice<CoarseSiteVector> CoarseField;
|
typedef Lattice<CoarseSiteVector> CoarseField;
|
||||||
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
||||||
@ -97,6 +98,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis>
|
template<class Fobj,class CComplex,int nbasis>
|
||||||
class ProjectedFunctionHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
class ProjectedFunctionHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<iVector<CComplex,nbasis > > >::operator();
|
||||||
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
||||||
typedef Lattice<CoarseSiteVector> CoarseField;
|
typedef Lattice<CoarseSiteVector> CoarseField;
|
||||||
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
||||||
|
@ -43,7 +43,7 @@ NAMESPACE_BEGIN(Grid);
|
|||||||
template<class Field>
|
template<class Field>
|
||||||
class PrecGeneralisedConjugateResidual : public LinearFunction<Field> {
|
class PrecGeneralisedConjugateResidual : public LinearFunction<Field> {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
RealD Tolerance;
|
RealD Tolerance;
|
||||||
Integer MaxIterations;
|
Integer MaxIterations;
|
||||||
int verbose;
|
int verbose;
|
||||||
|
@ -43,7 +43,7 @@ NAMESPACE_BEGIN(Grid);
|
|||||||
template<class Field>
|
template<class Field>
|
||||||
class PrecGeneralisedConjugateResidualNonHermitian : public LinearFunction<Field> {
|
class PrecGeneralisedConjugateResidualNonHermitian : public LinearFunction<Field> {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
RealD Tolerance;
|
RealD Tolerance;
|
||||||
Integer MaxIterations;
|
Integer MaxIterations;
|
||||||
int verbose;
|
int verbose;
|
||||||
@ -119,7 +119,8 @@ public:
|
|||||||
RealD GCRnStep(const Field &src, Field &psi,RealD rsq){
|
RealD GCRnStep(const Field &src, Field &psi,RealD rsq){
|
||||||
|
|
||||||
RealD cp;
|
RealD cp;
|
||||||
ComplexD a, b, zAz;
|
ComplexD a, b;
|
||||||
|
// ComplexD zAz;
|
||||||
RealD zAAz;
|
RealD zAAz;
|
||||||
ComplexD rq;
|
ComplexD rq;
|
||||||
|
|
||||||
@ -146,7 +147,7 @@ public:
|
|||||||
//////////////////////////////////
|
//////////////////////////////////
|
||||||
MatTimer.Start();
|
MatTimer.Start();
|
||||||
Linop.Op(psi,Az);
|
Linop.Op(psi,Az);
|
||||||
zAz = innerProduct(Az,psi);
|
// zAz = innerProduct(Az,psi);
|
||||||
zAAz= norm2(Az);
|
zAAz= norm2(Az);
|
||||||
MatTimer.Stop();
|
MatTimer.Stop();
|
||||||
|
|
||||||
@ -170,7 +171,7 @@ public:
|
|||||||
|
|
||||||
LinalgTimer.Start();
|
LinalgTimer.Start();
|
||||||
|
|
||||||
zAz = innerProduct(Az,psi);
|
// zAz = innerProduct(Az,psi);
|
||||||
zAAz= norm2(Az);
|
zAAz= norm2(Az);
|
||||||
|
|
||||||
//p[0],q[0],qq[0]
|
//p[0],q[0],qq[0]
|
||||||
@ -212,7 +213,7 @@ public:
|
|||||||
MatTimer.Start();
|
MatTimer.Start();
|
||||||
Linop.Op(z,Az);
|
Linop.Op(z,Az);
|
||||||
MatTimer.Stop();
|
MatTimer.Stop();
|
||||||
zAz = innerProduct(Az,psi);
|
// zAz = innerProduct(Az,psi);
|
||||||
zAAz= norm2(Az);
|
zAAz= norm2(Az);
|
||||||
|
|
||||||
LinalgTimer.Start();
|
LinalgTimer.Start();
|
||||||
|
@ -576,7 +576,8 @@ class ScidacReader : public GridLimeReader {
|
|||||||
std::string rec_name(ILDG_BINARY_DATA);
|
std::string rec_name(ILDG_BINARY_DATA);
|
||||||
while ( limeReaderNextRecord(LimeR) == LIME_SUCCESS ) {
|
while ( limeReaderNextRecord(LimeR) == LIME_SUCCESS ) {
|
||||||
if ( !strncmp(limeReaderType(LimeR), rec_name.c_str(),strlen(rec_name.c_str()) ) ) {
|
if ( !strncmp(limeReaderType(LimeR), rec_name.c_str(),strlen(rec_name.c_str()) ) ) {
|
||||||
skipPastObjectRecord(std::string(GRID_FIELD_NORM));
|
// in principle should do the line below, but that breaks backard compatibility with old data
|
||||||
|
// skipPastObjectRecord(std::string(GRID_FIELD_NORM));
|
||||||
skipPastObjectRecord(std::string(SCIDAC_CHECKSUM));
|
skipPastObjectRecord(std::string(SCIDAC_CHECKSUM));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -828,6 +828,7 @@ void CayleyFermion5D<Impl>::SeqConservedCurrent(PropagatorField &q_in,
|
|||||||
|
|
||||||
#if (!defined(GRID_HIP))
|
#if (!defined(GRID_HIP))
|
||||||
int tshift = (mu == Nd-1) ? 1 : 0;
|
int tshift = (mu == Nd-1) ? 1 : 0;
|
||||||
|
unsigned int LLt = GridDefaultLatt()[Tp];
|
||||||
////////////////////////////////////////////////
|
////////////////////////////////////////////////
|
||||||
// GENERAL CAYLEY CASE
|
// GENERAL CAYLEY CASE
|
||||||
////////////////////////////////////////////////
|
////////////////////////////////////////////////
|
||||||
@ -880,7 +881,7 @@ void CayleyFermion5D<Impl>::SeqConservedCurrent(PropagatorField &q_in,
|
|||||||
}
|
}
|
||||||
|
|
||||||
std::vector<RealD> G_s(Ls,1.0);
|
std::vector<RealD> G_s(Ls,1.0);
|
||||||
RealD sign = 1; // sign flip for vector/tadpole
|
RealD sign = 1.0; // sign flip for vector/tadpole
|
||||||
if ( curr_type == Current::Axial ) {
|
if ( curr_type == Current::Axial ) {
|
||||||
for(int s=0;s<Ls/2;s++){
|
for(int s=0;s<Ls/2;s++){
|
||||||
G_s[s] = -1.0;
|
G_s[s] = -1.0;
|
||||||
@ -890,7 +891,7 @@ void CayleyFermion5D<Impl>::SeqConservedCurrent(PropagatorField &q_in,
|
|||||||
auto b=this->_b;
|
auto b=this->_b;
|
||||||
auto c=this->_c;
|
auto c=this->_c;
|
||||||
if ( b == 1 && c == 0 ) {
|
if ( b == 1 && c == 0 ) {
|
||||||
sign = -1;
|
sign = -1.0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
std::cerr << "Error: Tadpole implementation currently unavailable for non-Shamir actions." << std::endl;
|
std::cerr << "Error: Tadpole implementation currently unavailable for non-Shamir actions." << std::endl;
|
||||||
@ -934,7 +935,13 @@ void CayleyFermion5D<Impl>::SeqConservedCurrent(PropagatorField &q_in,
|
|||||||
tmp = Cshift(tmp,mu,-1);
|
tmp = Cshift(tmp,mu,-1);
|
||||||
Impl::multLinkField(Utmp,this->Umu,tmp,mu+Nd); // Adjoint link
|
Impl::multLinkField(Utmp,this->Umu,tmp,mu+Nd); // Adjoint link
|
||||||
tmp = -G_s[s]*( Utmp + gmu*Utmp );
|
tmp = -G_s[s]*( Utmp + gmu*Utmp );
|
||||||
tmp = where((lcoor>=tmin+tshift),tmp,zz); // Mask the time
|
// Mask the time
|
||||||
|
if (tmax == LLt - 1 && tshift == 1){ // quick fix to include timeslice 0 if tmax + tshift is over the last timeslice
|
||||||
|
unsigned int t0 = 0;
|
||||||
|
tmp = where(((lcoor==t0) || (lcoor>=tmin+tshift)),tmp,zz);
|
||||||
|
} else {
|
||||||
|
tmp = where((lcoor>=tmin+tshift),tmp,zz);
|
||||||
|
}
|
||||||
L_Q += where((lcoor<=tmax+tshift),tmp,zz); // Position of current complicated
|
L_Q += where((lcoor<=tmax+tshift),tmp,zz); // Position of current complicated
|
||||||
|
|
||||||
InsertSlice(L_Q, q_out, s , 0);
|
InsertSlice(L_Q, q_out, s , 0);
|
||||||
|
@ -47,20 +47,20 @@ NAMESPACE_BEGIN(Grid);
|
|||||||
class TypePair {
|
class TypePair {
|
||||||
public:
|
public:
|
||||||
T _internal[2];
|
T _internal[2];
|
||||||
TypePair<T>& operator=(const Grid::Zero& o) {
|
accelerator TypePair<T>& operator=(const Grid::Zero& o) {
|
||||||
_internal[0] = Zero();
|
_internal[0] = Zero();
|
||||||
_internal[1] = Zero();
|
_internal[1] = Zero();
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
TypePair<T> operator+(const TypePair<T>& o) const {
|
accelerator TypePair<T> operator+(const TypePair<T>& o) const {
|
||||||
TypePair<T> r;
|
TypePair<T> r;
|
||||||
r._internal[0] = _internal[0] + o._internal[0];
|
r._internal[0] = _internal[0] + o._internal[0];
|
||||||
r._internal[1] = _internal[1] + o._internal[1];
|
r._internal[1] = _internal[1] + o._internal[1];
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
TypePair<T>& operator+=(const TypePair<T>& o) {
|
accelerator TypePair<T>& operator+=(const TypePair<T>& o) {
|
||||||
_internal[0] += o._internal[0];
|
_internal[0] += o._internal[0];
|
||||||
_internal[1] += o._internal[1];
|
_internal[1] += o._internal[1];
|
||||||
return *this;
|
return *this;
|
||||||
|
@ -88,7 +88,7 @@ public:
|
|||||||
// Coordinate class, maxdims = 8 for now.
|
// Coordinate class, maxdims = 8 for now.
|
||||||
////////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////////
|
||||||
#define GRID_MAX_LATTICE_DIMENSION (8)
|
#define GRID_MAX_LATTICE_DIMENSION (8)
|
||||||
#define GRID_MAX_SIMD (16)
|
#define GRID_MAX_SIMD (32)
|
||||||
|
|
||||||
static constexpr int MaxDims = GRID_MAX_LATTICE_DIMENSION;
|
static constexpr int MaxDims = GRID_MAX_LATTICE_DIMENSION;
|
||||||
|
|
||||||
|
@ -4,7 +4,7 @@ using namespace Grid;
|
|||||||
template<class Field>
|
template<class Field>
|
||||||
void SimpleConjugateGradient(LinearOperatorBase<Field> &HPDop,const Field &b, Field &x)
|
void SimpleConjugateGradient(LinearOperatorBase<Field> &HPDop,const Field &b, Field &x)
|
||||||
{
|
{
|
||||||
RealD cp, c, alpha, d, beta, ssq, qq;
|
RealD cp, c, alpha, d, beta, ssq;
|
||||||
RealD Tolerance=1.0e-10;
|
RealD Tolerance=1.0e-10;
|
||||||
int MaxIterations=10000;
|
int MaxIterations=10000;
|
||||||
|
|
||||||
|
539
examples/Example_wall_wall_3pt.cc
Normal file
539
examples/Example_wall_wall_3pt.cc
Normal file
@ -0,0 +1,539 @@
|
|||||||
|
/*
|
||||||
|
* Warning: This code illustrative only: not well tested, and not meant for production use
|
||||||
|
* without regression / tests being applied
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <Grid/Grid.h>
|
||||||
|
|
||||||
|
using namespace std;
|
||||||
|
using namespace Grid;
|
||||||
|
typedef SpinColourMatrix Propagator;
|
||||||
|
typedef SpinColourVector Fermion;
|
||||||
|
typedef PeriodicGimplR GimplR;
|
||||||
|
|
||||||
|
template<class Gimpl,class Field> class CovariantLaplacianCshift : public SparseMatrixBase<Field>
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
INHERIT_GIMPL_TYPES(Gimpl);
|
||||||
|
|
||||||
|
GridBase *grid;
|
||||||
|
GaugeField U;
|
||||||
|
|
||||||
|
CovariantLaplacianCshift(GaugeField &_U) :
|
||||||
|
grid(_U.Grid()),
|
||||||
|
U(_U) { };
|
||||||
|
|
||||||
|
virtual GridBase *Grid(void) { return grid; };
|
||||||
|
|
||||||
|
virtual void M (const Field &in, Field &out)
|
||||||
|
{
|
||||||
|
out=Zero();
|
||||||
|
for(int mu=0;mu<Nd-1;mu++) {
|
||||||
|
GaugeLinkField Umu = PeekIndex<LorentzIndex>(U, mu); // NB: Inefficent
|
||||||
|
out = out - Gimpl::CovShiftForward(Umu,mu,in);
|
||||||
|
out = out - Gimpl::CovShiftBackward(Umu,mu,in);
|
||||||
|
out = out + 2.0*in;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
virtual void Mdag (const Field &in, Field &out) { M(in,out);}; // Laplacian is hermitian
|
||||||
|
virtual void Mdiag (const Field &in, Field &out) {assert(0);}; // Unimplemented need only for multigrid
|
||||||
|
virtual void Mdir (const Field &in, Field &out,int dir, int disp){assert(0);}; // Unimplemented need only for multigrid
|
||||||
|
virtual void MdirAll (const Field &in, std::vector<Field> &out) {assert(0);}; // Unimplemented need only for multigrid
|
||||||
|
};
|
||||||
|
|
||||||
|
void MakePhase(Coordinate mom,LatticeComplex &phase)
|
||||||
|
{
|
||||||
|
GridBase *grid = phase.Grid();
|
||||||
|
auto latt_size = grid->GlobalDimensions();
|
||||||
|
ComplexD ci(0.0,1.0);
|
||||||
|
phase=Zero();
|
||||||
|
|
||||||
|
LatticeComplex coor(phase.Grid());
|
||||||
|
for(int mu=0;mu<Nd;mu++){
|
||||||
|
RealD TwoPiL = M_PI * 2.0/ latt_size[mu];
|
||||||
|
LatticeCoordinate(coor,mu);
|
||||||
|
phase = phase + (TwoPiL * mom[mu]) * coor;
|
||||||
|
}
|
||||||
|
phase = exp(phase*ci);
|
||||||
|
}
|
||||||
|
void LinkSmear(int nstep, RealD rho,LatticeGaugeField &Uin,LatticeGaugeField &Usmr)
|
||||||
|
{
|
||||||
|
Smear_Stout<GimplR> Stout(rho);
|
||||||
|
LatticeGaugeField Utmp(Uin.Grid());
|
||||||
|
Utmp = Uin;
|
||||||
|
for(int i=0;i<nstep;i++){
|
||||||
|
Stout.smear(Usmr,Utmp);
|
||||||
|
Utmp = Usmr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void PointSource(Coordinate &coor,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
// Coordinate coor({0,0,0,0});
|
||||||
|
source=Zero();
|
||||||
|
SpinColourMatrix kronecker; kronecker=1.0;
|
||||||
|
pokeSite(kronecker,source,coor);
|
||||||
|
}
|
||||||
|
void GFWallSource(int tslice,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
GridBase *grid = source.Grid();
|
||||||
|
LatticeComplex one(grid); one = ComplexD(1.0,0.0);
|
||||||
|
LatticeComplex zz(grid); zz=Zero();
|
||||||
|
LatticeInteger t(grid);
|
||||||
|
LatticeCoordinate(t,Tdir);
|
||||||
|
one = where(t==Integer(tslice), one, zz);
|
||||||
|
source = 1.0;
|
||||||
|
source = source * one;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Z2WallSource(GridParallelRNG &RNG,int tslice,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
GridBase *grid = source.Grid();
|
||||||
|
LatticeComplex noise(grid);
|
||||||
|
LatticeComplex zz(grid); zz=Zero();
|
||||||
|
LatticeInteger t(grid);
|
||||||
|
|
||||||
|
RealD nrm=1.0/sqrt(2);
|
||||||
|
bernoulli(RNG, noise); // 0,1 50:50
|
||||||
|
|
||||||
|
noise = (2.*noise - Complex(1,1))*nrm;
|
||||||
|
|
||||||
|
LatticeCoordinate(t,Tdir);
|
||||||
|
noise = where(t==Integer(tslice), noise, zz);
|
||||||
|
|
||||||
|
source = 1.0;
|
||||||
|
source = source*noise;
|
||||||
|
std::cout << " Z2 wall " << norm2(source) << std::endl;
|
||||||
|
}
|
||||||
|
void GaugeFix(LatticeGaugeField &U,LatticeGaugeField &Ufix)
|
||||||
|
{
|
||||||
|
Real alpha=0.05;
|
||||||
|
|
||||||
|
Real plaq=WilsonLoops<GimplR>::avgPlaquette(U);
|
||||||
|
|
||||||
|
std::cout << " Initial plaquette "<<plaq << std::endl;
|
||||||
|
|
||||||
|
LatticeColourMatrix xform(U.Grid());
|
||||||
|
Ufix = U;
|
||||||
|
int orthog=Nd-1;
|
||||||
|
FourierAcceleratedGaugeFixer<GimplR>::SteepestDescentGaugeFix(Ufix,xform,alpha,100000,1.0e-14, 1.0e-14,true,orthog);
|
||||||
|
|
||||||
|
plaq=WilsonLoops<GimplR>::avgPlaquette(Ufix);
|
||||||
|
|
||||||
|
std::cout << " Final plaquette "<<plaq << std::endl;
|
||||||
|
}
|
||||||
|
template<class Field>
|
||||||
|
void GaussianSmear(LatticeGaugeField &U,Field &unsmeared,Field &smeared)
|
||||||
|
{
|
||||||
|
typedef CovariantLaplacianCshift <GimplR,Field> Laplacian_t;
|
||||||
|
Laplacian_t Laplacian(U);
|
||||||
|
|
||||||
|
Integer Iterations = 40;
|
||||||
|
Real width = 2.0;
|
||||||
|
Real coeff = (width*width) / Real(4*Iterations);
|
||||||
|
|
||||||
|
Field tmp(U.Grid());
|
||||||
|
smeared=unsmeared;
|
||||||
|
// chi = (1-p^2/2N)^N kronecker
|
||||||
|
for(int n = 0; n < Iterations; ++n) {
|
||||||
|
Laplacian.M(smeared,tmp);
|
||||||
|
smeared = smeared - coeff*tmp;
|
||||||
|
std::cout << " smear iter " << n<<" " <<norm2(smeared)<<std::endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void GaussianSource(Coordinate &site,LatticeGaugeField &U,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
LatticePropagator tmp(source.Grid());
|
||||||
|
PointSource(site,source);
|
||||||
|
std::cout << " GaussianSource Kronecker "<< norm2(source)<<std::endl;
|
||||||
|
tmp = source;
|
||||||
|
GaussianSmear(U,tmp,source);
|
||||||
|
std::cout << " GaussianSource Smeared "<< norm2(source)<<std::endl;
|
||||||
|
}
|
||||||
|
void GaussianWallSource(GridParallelRNG &RNG,int tslice,LatticeGaugeField &U,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
Z2WallSource(RNG,tslice,source);
|
||||||
|
auto tmp = source;
|
||||||
|
GaussianSmear(U,tmp,source);
|
||||||
|
}
|
||||||
|
void SequentialSource(int tslice,Coordinate &mom,LatticePropagator &spectator,LatticePropagator &source)
|
||||||
|
{
|
||||||
|
assert(mom.size()==Nd);
|
||||||
|
assert(mom[Tdir] == 0);
|
||||||
|
|
||||||
|
GridBase * grid = spectator.Grid();
|
||||||
|
|
||||||
|
LatticeInteger ts(grid);
|
||||||
|
LatticeCoordinate(ts,Tdir);
|
||||||
|
source = Zero();
|
||||||
|
source = where(ts==Integer(tslice),spectator,source); // Stick in a slice of the spectator, zero everywhere else
|
||||||
|
|
||||||
|
LatticeComplex phase(grid);
|
||||||
|
MakePhase(mom,phase);
|
||||||
|
|
||||||
|
source = source *phase;
|
||||||
|
}
|
||||||
|
template<class Action>
|
||||||
|
void Solve(Action &D,LatticePropagator &source,LatticePropagator &propagator)
|
||||||
|
{
|
||||||
|
GridBase *UGrid = D.GaugeGrid();
|
||||||
|
GridBase *FGrid = D.FermionGrid();
|
||||||
|
|
||||||
|
LatticeFermion src4 (UGrid);
|
||||||
|
LatticeFermion src5 (FGrid);
|
||||||
|
LatticeFermion result5(FGrid);
|
||||||
|
LatticeFermion result4(UGrid);
|
||||||
|
|
||||||
|
ConjugateGradient<LatticeFermion> CG(1.0e-12,100000);
|
||||||
|
SchurRedBlackDiagTwoSolve<LatticeFermion> schur(CG);
|
||||||
|
ZeroGuesser<LatticeFermion> ZG; // Could be a DeflatedGuesser if have eigenvectors
|
||||||
|
for(int s=0;s<Nd;s++){
|
||||||
|
for(int c=0;c<Nc;c++){
|
||||||
|
PropToFerm<Action>(src4,source,s,c);
|
||||||
|
|
||||||
|
D.ImportPhysicalFermionSource(src4,src5);
|
||||||
|
|
||||||
|
result5=Zero();
|
||||||
|
schur(D,src5,result5,ZG);
|
||||||
|
std::cout<<GridLogMessage
|
||||||
|
<<"spin "<<s<<" color "<<c
|
||||||
|
<<" norm2(src5d) " <<norm2(src5)
|
||||||
|
<<" norm2(result5d) "<<norm2(result5)<<std::endl;
|
||||||
|
|
||||||
|
D.ExportPhysicalFermionSolution(result5,result4);
|
||||||
|
|
||||||
|
FermToProp<Action>(propagator,result4,s,c);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class MesonFile: Serializable {
|
||||||
|
public:
|
||||||
|
GRID_SERIALIZABLE_CLASS_MEMBERS(MesonFile, std::vector<std::vector<Complex> >, data);
|
||||||
|
};
|
||||||
|
|
||||||
|
void MesonTrace(std::string file,LatticePropagator &q1,LatticePropagator &q2,LatticeComplex &phase)
|
||||||
|
{
|
||||||
|
const int nchannel=4;
|
||||||
|
Gamma::Algebra Gammas[nchannel][2] = {
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::Gamma5},
|
||||||
|
{Gamma::Algebra::GammaTGamma5,Gamma::Algebra::GammaTGamma5},
|
||||||
|
{Gamma::Algebra::GammaTGamma5,Gamma::Algebra::Gamma5},
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaTGamma5}
|
||||||
|
};
|
||||||
|
|
||||||
|
Gamma G5(Gamma::Algebra::Gamma5);
|
||||||
|
|
||||||
|
LatticeComplex meson_CF(q1.Grid());
|
||||||
|
MesonFile MF;
|
||||||
|
|
||||||
|
for(int ch=0;ch<nchannel;ch++){
|
||||||
|
|
||||||
|
Gamma Gsrc(Gammas[ch][0]);
|
||||||
|
Gamma Gsnk(Gammas[ch][1]);
|
||||||
|
|
||||||
|
meson_CF = trace(G5*adj(q1)*G5*Gsnk*q2*adj(Gsrc));
|
||||||
|
|
||||||
|
std::vector<TComplex> meson_T;
|
||||||
|
sliceSum(meson_CF,meson_T, Tdir);
|
||||||
|
|
||||||
|
int nt=meson_T.size();
|
||||||
|
|
||||||
|
std::vector<Complex> corr(nt);
|
||||||
|
for(int t=0;t<nt;t++){
|
||||||
|
corr[t] = TensorRemove(meson_T[t]); // Yes this is ugly, not figured a work around
|
||||||
|
std::cout << " channel "<<ch<<" t "<<t<<" " <<corr[t]<<std::endl;
|
||||||
|
}
|
||||||
|
MF.data.push_back(corr);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
XmlWriter WR(file);
|
||||||
|
write(WR,"MesonFile",MF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Meson3pt(std::string file,LatticePropagator &q1,LatticePropagator &q2,LatticeComplex &phase)
|
||||||
|
{
|
||||||
|
const int nchannel=4;
|
||||||
|
Gamma::Algebra Gammas[nchannel][2] = {
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaX},
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaY},
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaZ},
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaT}
|
||||||
|
};
|
||||||
|
|
||||||
|
Gamma G5(Gamma::Algebra::Gamma5);
|
||||||
|
|
||||||
|
LatticeComplex meson_CF(q1.Grid());
|
||||||
|
MesonFile MF;
|
||||||
|
|
||||||
|
for(int ch=0;ch<nchannel;ch++){
|
||||||
|
|
||||||
|
Gamma Gsrc(Gammas[ch][0]);
|
||||||
|
Gamma Gsnk(Gammas[ch][1]);
|
||||||
|
|
||||||
|
meson_CF = trace(G5*adj(q1)*G5*Gsnk*q2*adj(Gsrc));
|
||||||
|
|
||||||
|
std::vector<TComplex> meson_T;
|
||||||
|
sliceSum(meson_CF,meson_T, Tdir);
|
||||||
|
|
||||||
|
int nt=meson_T.size();
|
||||||
|
|
||||||
|
std::vector<Complex> corr(nt);
|
||||||
|
for(int t=0;t<nt;t++){
|
||||||
|
corr[t] = TensorRemove(meson_T[t]); // Yes this is ugly, not figured a work around
|
||||||
|
std::cout << " channel "<<ch<<" t "<<t<<" " <<corr[t]<<std::endl;
|
||||||
|
}
|
||||||
|
MF.data.push_back(corr);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
XmlWriter WR(file);
|
||||||
|
write(WR,"MesonFile",MF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void WallSinkMesonTrace(std::string file,std::vector<Propagator> &q1,std::vector<Propagator> &q2)
|
||||||
|
{
|
||||||
|
const int nchannel=4;
|
||||||
|
Gamma::Algebra Gammas[nchannel][2] = {
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::Gamma5},
|
||||||
|
{Gamma::Algebra::GammaTGamma5,Gamma::Algebra::GammaTGamma5},
|
||||||
|
{Gamma::Algebra::GammaTGamma5,Gamma::Algebra::Gamma5},
|
||||||
|
{Gamma::Algebra::Gamma5 ,Gamma::Algebra::GammaTGamma5}
|
||||||
|
};
|
||||||
|
|
||||||
|
Gamma G5(Gamma::Algebra::Gamma5);
|
||||||
|
int nt=q1.size();
|
||||||
|
std::vector<Complex> meson_CF(nt);
|
||||||
|
MesonFile MF;
|
||||||
|
|
||||||
|
for(int ch=0;ch<nchannel;ch++){
|
||||||
|
|
||||||
|
Gamma Gsrc(Gammas[ch][0]);
|
||||||
|
Gamma Gsnk(Gammas[ch][1]);
|
||||||
|
|
||||||
|
std::vector<Complex> corr(nt);
|
||||||
|
for(int t=0;t<nt;t++){
|
||||||
|
meson_CF[t] = trace(G5*adj(q1[t])*G5*Gsnk*q2[t]*adj(Gsrc));
|
||||||
|
corr[t] = TensorRemove(meson_CF[t]); // Yes this is ugly, not figured a work around
|
||||||
|
std::cout << " channel "<<ch<<" t "<<t<<" " <<corr[t]<<std::endl;
|
||||||
|
}
|
||||||
|
MF.data.push_back(corr);
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
XmlWriter WR(file);
|
||||||
|
write(WR,"MesonFile",MF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
int make_idx(int p, int m,int nmom)
|
||||||
|
{
|
||||||
|
if (m==0) return p;
|
||||||
|
assert(p==0);
|
||||||
|
return nmom + m - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main (int argc, char ** argv)
|
||||||
|
{
|
||||||
|
Grid_init(&argc,&argv);
|
||||||
|
|
||||||
|
// Double precision grids
|
||||||
|
auto latt = GridDefaultLatt();
|
||||||
|
GridCartesian * UGrid = SpaceTimeGrid::makeFourDimGrid(GridDefaultLatt(),
|
||||||
|
GridDefaultSimd(Nd,vComplex::Nsimd()),
|
||||||
|
GridDefaultMpi());
|
||||||
|
GridRedBlackCartesian * UrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(UGrid);
|
||||||
|
|
||||||
|
|
||||||
|
LatticeGaugeField Umu(UGrid);
|
||||||
|
LatticeGaugeField Utmp(UGrid);
|
||||||
|
LatticeGaugeField Usmr(UGrid);
|
||||||
|
std::string config;
|
||||||
|
if( argc > 1 && argv[1][0] != '-' )
|
||||||
|
{
|
||||||
|
std::cout<<GridLogMessage <<"Loading configuration from "<<argv[1]<<std::endl;
|
||||||
|
FieldMetaData header;
|
||||||
|
NerscIO::readConfiguration(Umu, header, argv[1]);
|
||||||
|
config=argv[1];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
std::cout<<GridLogMessage <<"Using hot configuration"<<std::endl;
|
||||||
|
SU<Nc>::ColdConfiguration(Umu);
|
||||||
|
config="ColdConfig";
|
||||||
|
}
|
||||||
|
// GaugeFix(Umu,Utmp);
|
||||||
|
// Umu=Utmp;
|
||||||
|
|
||||||
|
int nsmr=3;
|
||||||
|
RealD rho=0.1;
|
||||||
|
LinkSmear(nsmr,rho,Umu,Usmr);
|
||||||
|
|
||||||
|
|
||||||
|
std::vector<int> smeared_link({ 0,0,1} );
|
||||||
|
std::vector<RealD> masses({ 0.004,0.02477,0.447} ); // u/d, s, c ??
|
||||||
|
std::vector<RealD> M5s ({ 1.8,1.8,1.0} );
|
||||||
|
std::vector<RealD> bs ({ 1.0,1.0,1.5} ); // DDM
|
||||||
|
std::vector<RealD> cs ({ 0.0,0.0,0.5} ); // DDM
|
||||||
|
std::vector<int> Ls_s ({ 16,16,12} );
|
||||||
|
std::vector<GridCartesian *> FGrids;
|
||||||
|
std::vector<GridRedBlackCartesian *> FrbGrids;
|
||||||
|
|
||||||
|
std::vector<Coordinate> momenta;
|
||||||
|
momenta.push_back(Coordinate({0,0,0,0}));
|
||||||
|
momenta.push_back(Coordinate({1,0,0,0}));
|
||||||
|
momenta.push_back(Coordinate({2,0,0,0}));
|
||||||
|
|
||||||
|
int nmass = masses.size();
|
||||||
|
int nmom = momenta.size();
|
||||||
|
|
||||||
|
std::vector<MobiusFermionR *> FermActs;
|
||||||
|
|
||||||
|
std::cout<<GridLogMessage <<"======================"<<std::endl;
|
||||||
|
std::cout<<GridLogMessage <<"MobiusFermion action as Scaled Shamir kernel"<<std::endl;
|
||||||
|
std::cout<<GridLogMessage <<"======================"<<std::endl;
|
||||||
|
|
||||||
|
std::vector<Complex> boundary = {1,1,1,-1};
|
||||||
|
typedef MobiusFermionR FermionAction;
|
||||||
|
FermionAction::ImplParams Params(boundary);
|
||||||
|
|
||||||
|
for(int m=0;m<masses.size();m++) {
|
||||||
|
|
||||||
|
RealD mass = masses[m];
|
||||||
|
RealD M5 = M5s[m];
|
||||||
|
RealD b = bs[m];
|
||||||
|
RealD c = cs[m];
|
||||||
|
int Ls = Ls_s[m];
|
||||||
|
|
||||||
|
if ( smeared_link[m] ) Utmp = Usmr;
|
||||||
|
else Utmp = Umu;
|
||||||
|
|
||||||
|
FGrids.push_back(SpaceTimeGrid::makeFiveDimGrid(Ls,UGrid));
|
||||||
|
FrbGrids.push_back(SpaceTimeGrid::makeFiveDimRedBlackGrid(Ls,UGrid));
|
||||||
|
|
||||||
|
FermActs.push_back(new MobiusFermionR(Utmp,*FGrids[m],*FrbGrids[m],*UGrid,*UrbGrid,mass,M5,b,c,Params));
|
||||||
|
}
|
||||||
|
|
||||||
|
LatticePropagator z2wall_source(UGrid);
|
||||||
|
LatticePropagator gfwall_source(UGrid);
|
||||||
|
LatticePropagator phased_prop(UGrid);
|
||||||
|
|
||||||
|
int tslice = 0;
|
||||||
|
int tseq=(tslice+16)%latt[Nd-1];
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
// RNG seeded for Z2 wall
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
// You can manage seeds however you like.
|
||||||
|
// Recommend SeedUniqueString.
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
GridParallelRNG RNG4(UGrid); RNG4.SeedUniqueString("Study2-Source_Z2_p_0_0_0_t_0-880");
|
||||||
|
Z2WallSource (RNG4,tslice,z2wall_source);
|
||||||
|
GFWallSource (tslice,gfwall_source);
|
||||||
|
|
||||||
|
std::vector<LatticeComplex> phase(nmom,UGrid);
|
||||||
|
for(int m=0;m<nmom;m++){
|
||||||
|
MakePhase(momenta[m],phase[m]);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<LatticePropagator> Z2Props (nmom+nmass-1,UGrid);
|
||||||
|
std::vector<LatticePropagator> GFProps (nmom+nmass-1,UGrid);
|
||||||
|
for(int p=0;p<nmom;p++) {
|
||||||
|
int m=0;
|
||||||
|
int idx = make_idx(p,m,nmom);
|
||||||
|
phased_prop = z2wall_source * phase[p];
|
||||||
|
Solve(*FermActs[m],phased_prop ,Z2Props[idx]);
|
||||||
|
|
||||||
|
phased_prop = gfwall_source * phase[p];
|
||||||
|
Solve(*FermActs[m],phased_prop ,GFProps[idx]);
|
||||||
|
}
|
||||||
|
for(int m=1;m<nmass;m++) {
|
||||||
|
int p=0;
|
||||||
|
int idx = make_idx(p,m,nmom);
|
||||||
|
phased_prop = z2wall_source;
|
||||||
|
Solve(*FermActs[m],phased_prop ,Z2Props[idx]);
|
||||||
|
|
||||||
|
phased_prop = gfwall_source;
|
||||||
|
Solve(*FermActs[m],phased_prop ,GFProps[idx]);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<std::vector<Propagator> > wsnk_z2Props(nmom+nmass-1);
|
||||||
|
std::vector<std::vector<Propagator> > wsnk_gfProps(nmom+nmass-1);
|
||||||
|
|
||||||
|
// Non-zero kaon and point and D two point
|
||||||
|
// WW stick momentum on m1 (lighter)
|
||||||
|
// zero momentum on m2
|
||||||
|
for(int m1=0;m1<nmass;m1++) {
|
||||||
|
for(int m2=m1;m2<nmass;m2++) {
|
||||||
|
int pmax = (m1==0)? nmom:1;
|
||||||
|
for(int p=0;p<pmax;p++){
|
||||||
|
|
||||||
|
std::stringstream ssg,ssz;
|
||||||
|
std::stringstream wssg,wssz;
|
||||||
|
|
||||||
|
int idx1 = make_idx(p,m1,nmom);
|
||||||
|
int idx2 = make_idx(0,m2,nmom);
|
||||||
|
|
||||||
|
/// Point sinks
|
||||||
|
ssg<<config<<"_p"<<p<< "_m" << m1 << "_m"<< m2 << "_p_gf_meson.xml";
|
||||||
|
ssz<<config<<"_p"<<p<< "_m" << m1 << "_m"<< m2 << "_p_z2_meson.xml";
|
||||||
|
MesonTrace(ssz.str(),Z2Props[idx1],Z2Props[idx2],phase[p]); // Q1 is conjugated
|
||||||
|
MesonTrace(ssg.str(),GFProps[idx1],GFProps[idx2],phase[p]);
|
||||||
|
|
||||||
|
/// Wall sinks
|
||||||
|
wssg<<config<<"_p"<<p<< "_m" << m1 << "_m"<< m2 << "_w_gf_meson.xml";
|
||||||
|
wssz<<config<<"_p"<<p<< "_m" << m1 << "_m"<< m2 << "_w_z2_meson.xml";
|
||||||
|
|
||||||
|
phased_prop = GFProps[m2] * phase[p];
|
||||||
|
sliceSum(phased_prop,wsnk_gfProps[m1],Tdir);
|
||||||
|
sliceSum(GFProps[m1],wsnk_gfProps[m2],Tdir);
|
||||||
|
WallSinkMesonTrace(wssg.str(),wsnk_gfProps[m1],wsnk_gfProps[m2]);
|
||||||
|
|
||||||
|
phased_prop = Z2Props[m2] * phase[p];
|
||||||
|
sliceSum(phased_prop,wsnk_gfProps[m1],Tdir);
|
||||||
|
sliceSum(Z2Props[m1],wsnk_gfProps[m2],Tdir);
|
||||||
|
WallSinkMesonTrace(wssz.str(),wsnk_z2Props[m1],wsnk_z2Props[m2]);
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////
|
||||||
|
// Sequential solves
|
||||||
|
/////////////////////////////////////
|
||||||
|
LatticePropagator seq_wsnk_z2src(UGrid);
|
||||||
|
LatticePropagator seq_wsnk_gfsrc(UGrid);
|
||||||
|
LatticePropagator seq_psnk_z2src(UGrid);
|
||||||
|
LatticePropagator seq_psnk_gfsrc(UGrid);
|
||||||
|
LatticePropagator source(UGrid);
|
||||||
|
for(int m=0;m<nmass-1;m++){
|
||||||
|
int spect_idx = make_idx(0,m,nmom);
|
||||||
|
int charm=nmass-1;
|
||||||
|
|
||||||
|
SequentialSource(tseq,momenta[0],GFProps[spect_idx],source);
|
||||||
|
Solve(*FermActs[charm],source,seq_psnk_gfsrc);
|
||||||
|
|
||||||
|
SequentialSource(tseq,momenta[0],Z2Props[spect_idx],source);
|
||||||
|
Solve(*FermActs[charm],source,seq_psnk_z2src);
|
||||||
|
|
||||||
|
// Todo need wall sequential solve
|
||||||
|
for(int p=0;p<nmom;p++){
|
||||||
|
int active_idx = make_idx(p,0,nmom);
|
||||||
|
std::stringstream seq_3pt_p_z2;
|
||||||
|
std::stringstream seq_3pt_p_gf;
|
||||||
|
std::stringstream seq_3pt_w_z2;
|
||||||
|
std::stringstream seq_3pt_w_gf;
|
||||||
|
seq_3pt_p_z2 <<config<<"_3pt_p"<<p<< "_m" << m << "_p_z2_meson.xml";
|
||||||
|
seq_3pt_p_gf <<config<<"_3pt_p"<<p<< "_m" << m << "_p_gf_meson.xml";
|
||||||
|
seq_3pt_w_z2 <<config<<"_3pt_p"<<p<< "_m" << m << "_w_z2_meson.xml";
|
||||||
|
seq_3pt_w_gf <<config<<"_3pt_p"<<p<< "_m" << m << "_w_gf_meson.xml";
|
||||||
|
Meson3pt(seq_3pt_p_gf.str(),GFProps[active_idx],seq_psnk_gfsrc,phase[p]);
|
||||||
|
Meson3pt(seq_3pt_p_z2.str(),Z2Props[active_idx],seq_psnk_z2src,phase[p]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Grid_finalize();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -235,7 +235,6 @@ void TestWhat(What & Ddwf,
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<What,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<What,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
|
@ -215,7 +215,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd , chi_o, chi);
|
pickCheckerboard(Odd , chi_o, chi);
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd , phi_o, phi);
|
pickCheckerboard(Odd , phi_o, phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<DomainWallEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<DomainWallEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
||||||
|
@ -212,8 +212,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<DomainWallFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<DomainWallFermionR,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
|
@ -181,8 +181,8 @@ void checkAdj(const Gamma::Algebra a)
|
|||||||
|
|
||||||
void checkProject(GridSerialRNG &rng)
|
void checkProject(GridSerialRNG &rng)
|
||||||
{
|
{
|
||||||
SpinVector rv, recon, full;
|
SpinVector rv, recon;
|
||||||
HalfSpinVector hsp, hsm;
|
HalfSpinVector hsm;
|
||||||
|
|
||||||
random(rng, rv);
|
random(rng, rv);
|
||||||
|
|
||||||
|
@ -198,7 +198,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<GparityWilsonFermionR,FermionField> HermOpEO(Dw);
|
SchurDiagMooeeOperator<GparityWilsonFermionR,FermionField> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
|
@ -364,14 +364,12 @@ int main(int argc, char **argv) {
|
|||||||
|
|
||||||
{ // Peek-ology and Poke-ology, with a little app-ology
|
{ // Peek-ology and Poke-ology, with a little app-ology
|
||||||
Complex c;
|
Complex c;
|
||||||
ColourMatrix c_m;
|
ColourMatrix c_m = Zero();
|
||||||
SpinMatrix s_m;
|
SpinMatrix s_m = Zero();
|
||||||
SpinColourMatrix sc_m;
|
SpinColourMatrix sc_m = Zero();
|
||||||
|
|
||||||
s_m = TensorIndexRecursion<ColourIndex>::traceIndex(
|
s_m = TensorIndexRecursion<ColourIndex>::traceIndex(sc_m); // Map to traceColour
|
||||||
sc_m); // Map to traceColour
|
c_m = TensorIndexRecursion<SpinIndex>::traceIndex(sc_m); // map to traceSpin
|
||||||
c_m = TensorIndexRecursion<SpinIndex>::traceIndex(
|
|
||||||
sc_m); // map to traceSpin
|
|
||||||
|
|
||||||
c = TensorIndexRecursion<SpinIndex>::traceIndex(s_m);
|
c = TensorIndexRecursion<SpinIndex>::traceIndex(s_m);
|
||||||
c = TensorIndexRecursion<ColourIndex>::traceIndex(c_m);
|
c = TensorIndexRecursion<ColourIndex>::traceIndex(c_m);
|
||||||
|
@ -217,7 +217,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd , chi_o, chi);
|
pickCheckerboard(Odd , chi_o, chi);
|
||||||
pickCheckerboard(Even, phi_e, phi);
|
pickCheckerboard(Even, phi_e, phi);
|
||||||
pickCheckerboard(Odd , phi_o, phi);
|
pickCheckerboard(Odd , phi_o, phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<MobiusEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<MobiusEOFAFermionR,LatticeFermion> HermOpEO(Ddwf);
|
||||||
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
HermOpEO.MpcDagMpc(chi_e, dchi_e);
|
||||||
|
@ -262,7 +262,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<MobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<MobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
||||||
|
@ -144,7 +144,7 @@ int main (int argc, char ** argv)
|
|||||||
Ds.Dhop(src,result,0);
|
Ds.Dhop(src,result,0);
|
||||||
}
|
}
|
||||||
double t1=usecond();
|
double t1=usecond();
|
||||||
double t2;
|
|
||||||
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
||||||
|
|
||||||
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
||||||
|
@ -162,7 +162,6 @@ int main (int argc, char ** argv)
|
|||||||
}
|
}
|
||||||
double t1=usecond();
|
double t1=usecond();
|
||||||
|
|
||||||
double t2;
|
|
||||||
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
||||||
|
|
||||||
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
||||||
|
@ -30,7 +30,6 @@ Author: paboyle <paboyle@ph.ed.ac.uk>
|
|||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace Grid;
|
using namespace Grid;
|
||||||
;
|
|
||||||
|
|
||||||
int main (int argc, char ** argv)
|
int main (int argc, char ** argv)
|
||||||
{
|
{
|
||||||
@ -135,7 +134,6 @@ int main (int argc, char ** argv)
|
|||||||
Ds.Dhop(src,result,0);
|
Ds.Dhop(src,result,0);
|
||||||
}
|
}
|
||||||
double t1=usecond();
|
double t1=usecond();
|
||||||
double t2;
|
|
||||||
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
double flops=(16*(3*(6+8+8)) + 15*3*2)*volume*ncall; // == 66*16 + == 1146
|
||||||
|
|
||||||
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
std::cout<<GridLogMessage << "Called Ds"<<std::endl;
|
||||||
|
@ -204,7 +204,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<WilsonFermionR,LatticeFermion> HermOpEO(Dw);
|
SchurDiagMooeeOperator<WilsonFermionR,LatticeFermion> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
|
@ -205,7 +205,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<WilsonTMFermionR,LatticeFermion> HermOpEO(Dw);
|
SchurDiagMooeeOperator<WilsonTMFermionR,LatticeFermion> HermOpEO(Dw);
|
||||||
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
HermOpEO.MpcDagMpc(chi_e,dchi_e);
|
||||||
|
@ -276,7 +276,6 @@ int main (int argc, char ** argv)
|
|||||||
pickCheckerboard(Odd ,chi_o,chi);
|
pickCheckerboard(Odd ,chi_o,chi);
|
||||||
pickCheckerboard(Even,phi_e,phi);
|
pickCheckerboard(Even,phi_e,phi);
|
||||||
pickCheckerboard(Odd ,phi_o,phi);
|
pickCheckerboard(Odd ,phi_o,phi);
|
||||||
RealD t1,t2;
|
|
||||||
|
|
||||||
|
|
||||||
SchurDiagMooeeOperator<ZMobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
SchurDiagMooeeOperator<ZMobiusFermionR,LatticeFermion> HermOpEO(Ddwf);
|
||||||
|
@ -57,7 +57,6 @@ int main (int argc, char ** argv)
|
|||||||
SU<Nc>::HotConfiguration(pRNG,U);
|
SU<Nc>::HotConfiguration(pRNG,U);
|
||||||
|
|
||||||
double beta = 1.0;
|
double beta = 1.0;
|
||||||
double c1 = -0.331;
|
|
||||||
|
|
||||||
IwasakiGaugeActionR Action(beta);
|
IwasakiGaugeActionR Action(beta);
|
||||||
// PlaqPlusRectangleActionR Action(beta,c1);
|
// PlaqPlusRectangleActionR Action(beta,c1);
|
||||||
|
@ -40,6 +40,7 @@ using namespace Grid;
|
|||||||
template<class Fobj,class CComplex,int nbasis>
|
template<class Fobj,class CComplex,int nbasis>
|
||||||
class ProjectedHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
class ProjectedHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<iVector<CComplex,nbasis > > >::operator();
|
||||||
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
||||||
typedef Lattice<CoarseSiteVector> CoarseField;
|
typedef Lattice<CoarseSiteVector> CoarseField;
|
||||||
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
||||||
@ -67,6 +68,8 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis>
|
template<class Fobj,class CComplex,int nbasis>
|
||||||
class ProjectedFunctionHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
class ProjectedFunctionHermOp : public LinearFunction<Lattice<iVector<CComplex,nbasis > > > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<iVector<CComplex,nbasis > > >::operator ();
|
||||||
|
|
||||||
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
typedef iVector<CComplex,nbasis > CoarseSiteVector;
|
||||||
typedef Lattice<CoarseSiteVector> CoarseField;
|
typedef Lattice<CoarseSiteVector> CoarseField;
|
||||||
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
typedef Lattice<CComplex> CoarseScalar; // used for inner products on fine field
|
||||||
|
@ -55,6 +55,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -78,6 +79,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -108,6 +110,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
|
@ -57,7 +57,7 @@ private:
|
|||||||
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
||||||
SchurRedBlackBase<Field> & _Solver;
|
SchurRedBlackBase<Field> & _Solver;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
@ -75,6 +75,7 @@ public:
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -98,6 +99,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -128,6 +130,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
|
@ -55,6 +55,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -78,6 +79,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -109,6 +111,8 @@ template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, clas
|
|||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
||||||
|
@ -56,6 +56,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -79,6 +80,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -108,6 +110,7 @@ public:
|
|||||||
template<class Field,class Matrix> class RedBlackSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class RedBlackSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
RealD tol;
|
RealD tol;
|
||||||
@ -134,6 +137,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
@ -241,7 +245,7 @@ int main (int argc, char ** argv)
|
|||||||
Grid_init(&argc,&argv);
|
Grid_init(&argc,&argv);
|
||||||
|
|
||||||
const int Ls=16;
|
const int Ls=16;
|
||||||
const int rLs=8;
|
// const int rLs=8;
|
||||||
|
|
||||||
GridCartesian * UGrid = SpaceTimeGrid::makeFourDimGrid(GridDefaultLatt(), GridDefaultSimd(Nd,vComplex::Nsimd()),GridDefaultMpi());
|
GridCartesian * UGrid = SpaceTimeGrid::makeFourDimGrid(GridDefaultLatt(), GridDefaultSimd(Nd,vComplex::Nsimd()),GridDefaultMpi());
|
||||||
GridRedBlackCartesian * UrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(UGrid);
|
GridRedBlackCartesian * UrbGrid = SpaceTimeGrid::makeFourDimRedBlackGrid(UGrid);
|
||||||
@ -388,7 +392,7 @@ int main (int argc, char ** argv)
|
|||||||
// RedBlackSmoother<LatticeFermion,DomainWallFermionR> FineRBSmoother(0.00,0.001,100,Ddwf);
|
// RedBlackSmoother<LatticeFermion,DomainWallFermionR> FineRBSmoother(0.00,0.001,100,Ddwf);
|
||||||
|
|
||||||
// Wrap the 2nd level solver in a MultiGrid preconditioner acting on the fine space
|
// Wrap the 2nd level solver in a MultiGrid preconditioner acting on the fine space
|
||||||
ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
// ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
||||||
TwoLevelMG TwoLevelPrecon(Aggregates, LDOp,
|
TwoLevelMG TwoLevelPrecon(Aggregates, LDOp,
|
||||||
HermIndefOp,Ddwf,
|
HermIndefOp,Ddwf,
|
||||||
FineSmoother,
|
FineSmoother,
|
||||||
|
@ -57,7 +57,7 @@ private:
|
|||||||
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
||||||
SchurRedBlackBase<Field> & _Solver;
|
SchurRedBlackBase<Field> & _Solver;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
@ -75,6 +75,7 @@ public:
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -98,6 +99,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -128,6 +130,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
|
@ -55,6 +55,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -78,6 +79,7 @@ public:
|
|||||||
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class MirsSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & SmootherMatrix;
|
Matrix & SmootherMatrix;
|
||||||
FineOperator & SmootherOperator;
|
FineOperator & SmootherOperator;
|
||||||
@ -108,6 +110,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class Matrix, class Guesser, class CoarseSolver>
|
||||||
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MultiGridPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
|
@ -57,6 +57,7 @@ private:
|
|||||||
OperatorFunction<Field> & _Solver;
|
OperatorFunction<Field> & _Solver;
|
||||||
LinearFunction<Field> & _Guess;
|
LinearFunction<Field> & _Guess;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
|
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
@ -118,6 +119,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -174,6 +176,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
||||||
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
typedef CoarsenedMatrix<Fobj,CComplex,nbasis> CoarseOperator;
|
||||||
|
@ -456,8 +456,8 @@ public:
|
|||||||
|
|
||||||
siteVector *CBp=Stencil.CommBuf();
|
siteVector *CBp=Stencil.CommBuf();
|
||||||
|
|
||||||
int ptype;
|
// int ptype;
|
||||||
int nb2=nbasis/2;
|
// int nb2=nbasis/2;
|
||||||
|
|
||||||
autoView(in_v , in, AcceleratorRead);
|
autoView(in_v , in, AcceleratorRead);
|
||||||
autoView(st, Stencil, AcceleratorRead);
|
autoView(st, Stencil, AcceleratorRead);
|
||||||
@ -471,7 +471,7 @@ public:
|
|||||||
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
||||||
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
||||||
int sU = sF/Ls;
|
int sU = sF/Ls;
|
||||||
int s = sF%Ls;
|
// int s = sF%Ls;
|
||||||
|
|
||||||
calcComplex res = Zero();
|
calcComplex res = Zero();
|
||||||
calcVector nbr;
|
calcVector nbr;
|
||||||
@ -517,14 +517,14 @@ public:
|
|||||||
autoView(st, Stencil, AcceleratorRead);
|
autoView(st, Stencil, AcceleratorRead);
|
||||||
siteVector *CBp=Stencil.CommBuf();
|
siteVector *CBp=Stencil.CommBuf();
|
||||||
|
|
||||||
int ptype;
|
// int ptype;
|
||||||
int nb2=nbasis/2;
|
// int nb2=nbasis/2;
|
||||||
accelerator_for2d(sF, Coarse5D->oSites(), b, nbasis, Nsimd, {
|
accelerator_for2d(sF, Coarse5D->oSites(), b, nbasis, Nsimd, {
|
||||||
|
|
||||||
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
||||||
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
||||||
int sU = sF/Ls;
|
int sU = sF/Ls;
|
||||||
int s = sF%Ls;
|
// int s = sF%Ls;
|
||||||
|
|
||||||
calcComplex res = Zero();
|
calcComplex res = Zero();
|
||||||
|
|
||||||
@ -650,7 +650,7 @@ private:
|
|||||||
OperatorFunction<Field> & _Solver;
|
OperatorFunction<Field> & _Solver;
|
||||||
LinearFunction<Field> & _Guess;
|
LinearFunction<Field> & _Guess;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
@ -712,6 +712,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -735,6 +736,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
||||||
class MGPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MGPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
||||||
@ -831,6 +833,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
||||||
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
||||||
@ -1174,18 +1177,18 @@ int main (int argc, char ** argv)
|
|||||||
PlainHermOp<CoarseCoarseVector> IRLOpL2 (IRLHermOpL2);
|
PlainHermOp<CoarseCoarseVector> IRLOpL2 (IRLHermOpL2);
|
||||||
ImplicitlyRestartedLanczos<CoarseCoarseVector> IRLL2(IRLOpChebyL2,IRLOpL2,cNstop,cNk,cNm,1.0e-3,20);
|
ImplicitlyRestartedLanczos<CoarseCoarseVector> IRLL2(IRLOpChebyL2,IRLOpL2,cNstop,cNk,cNm,1.0e-3,20);
|
||||||
|
|
||||||
int cNconv;
|
|
||||||
cNm=0;
|
cNm=0;
|
||||||
std::vector<RealD> eval2(cNm);
|
std::vector<RealD> eval2(cNm);
|
||||||
std::vector<CoarseCoarseVector> evec2(cNm,CoarseCoarse5d);
|
std::vector<CoarseCoarseVector> evec2(cNm,CoarseCoarse5d);
|
||||||
cc_src=1.0;
|
cc_src=1.0;
|
||||||
|
// int cNconv;
|
||||||
// IRLL2.calc(eval2,evec2,cc_src,cNconv);
|
// IRLL2.calc(eval2,evec2,cc_src,cNconv);
|
||||||
|
|
||||||
ConjugateGradient<CoarseCoarseVector> CoarseCoarseCG(0.02,10000);
|
ConjugateGradient<CoarseCoarseVector> CoarseCoarseCG(0.02,10000);
|
||||||
DeflatedGuesser<CoarseCoarseVector> DeflCoarseCoarseGuesser(evec2,eval2);
|
DeflatedGuesser<CoarseCoarseVector> DeflCoarseCoarseGuesser(evec2,eval2);
|
||||||
NormalEquations<CoarseCoarseVector> DeflCoarseCoarseCGNE(cc_Dwf,CoarseCoarseCG,DeflCoarseCoarseGuesser);
|
NormalEquations<CoarseCoarseVector> DeflCoarseCoarseCGNE(cc_Dwf,CoarseCoarseCG,DeflCoarseCoarseGuesser);
|
||||||
|
|
||||||
ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
// ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
||||||
ZeroGuesser<CoarseCoarseVector> CoarseCoarseZeroGuesser;
|
ZeroGuesser<CoarseCoarseVector> CoarseCoarseZeroGuesser;
|
||||||
|
|
||||||
std::cout<<GridLogMessage << "**************************************************"<< std::endl;
|
std::cout<<GridLogMessage << "**************************************************"<< std::endl;
|
||||||
|
@ -456,8 +456,8 @@ public:
|
|||||||
|
|
||||||
siteVector *CBp=Stencil.CommBuf();
|
siteVector *CBp=Stencil.CommBuf();
|
||||||
|
|
||||||
int ptype;
|
//int ptype;
|
||||||
int nb2=nbasis/2;
|
// int nb2=nbasis/2;
|
||||||
|
|
||||||
autoView(in_v , in, AcceleratorRead);
|
autoView(in_v , in, AcceleratorRead);
|
||||||
autoView(st, Stencil, AcceleratorRead);
|
autoView(st, Stencil, AcceleratorRead);
|
||||||
@ -471,7 +471,7 @@ public:
|
|||||||
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
||||||
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
||||||
int sU = sF/Ls;
|
int sU = sF/Ls;
|
||||||
int s = sF%Ls;
|
// int s = sF%Ls;
|
||||||
|
|
||||||
calcComplex res = Zero();
|
calcComplex res = Zero();
|
||||||
calcVector nbr;
|
calcVector nbr;
|
||||||
@ -517,14 +517,14 @@ public:
|
|||||||
autoView(st, Stencil, AcceleratorRead);
|
autoView(st, Stencil, AcceleratorRead);
|
||||||
siteVector *CBp=Stencil.CommBuf();
|
siteVector *CBp=Stencil.CommBuf();
|
||||||
|
|
||||||
int ptype;
|
// int ptype;
|
||||||
int nb2=nbasis/2;
|
// int nb2=nbasis/2;
|
||||||
accelerator_for2d(sF, Coarse5D->oSites(), b, nbasis, Nsimd, {
|
accelerator_for2d(sF, Coarse5D->oSites(), b, nbasis, Nsimd, {
|
||||||
|
|
||||||
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
typedef decltype(coalescedRead(in_v[0])) calcVector;
|
||||||
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
typedef decltype(coalescedRead(in_v[0](0))) calcComplex;
|
||||||
int sU = sF/Ls;
|
int sU = sF/Ls;
|
||||||
int s = sF%Ls;
|
// int s = sF%Ls;
|
||||||
|
|
||||||
calcComplex res = Zero();
|
calcComplex res = Zero();
|
||||||
|
|
||||||
@ -648,7 +648,7 @@ private:
|
|||||||
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
CheckerBoardedSparseMatrixBase<Field> & _Matrix;
|
||||||
SchurRedBlackBase<Field> & _Solver;
|
SchurRedBlackBase<Field> & _Solver;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
@ -669,6 +669,7 @@ private:
|
|||||||
OperatorFunction<Field> & _Solver;
|
OperatorFunction<Field> & _Solver;
|
||||||
LinearFunction<Field> & _Guess;
|
LinearFunction<Field> & _Guess;
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
|
|
||||||
/////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////
|
||||||
// Wrap the usual normal equations trick
|
// Wrap the usual normal equations trick
|
||||||
@ -731,6 +732,7 @@ RealD InverseApproximation(RealD x){
|
|||||||
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
template<class Field,class Matrix> class ChebyshevSmoother : public LinearFunction<Field>
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
typedef LinearOperatorBase<Field> FineOperator;
|
typedef LinearOperatorBase<Field> FineOperator;
|
||||||
Matrix & _SmootherMatrix;
|
Matrix & _SmootherMatrix;
|
||||||
FineOperator & _SmootherOperator;
|
FineOperator & _SmootherOperator;
|
||||||
@ -754,6 +756,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
||||||
class MGPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class MGPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
||||||
@ -850,6 +853,7 @@ public:
|
|||||||
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
template<class Fobj,class CComplex,int nbasis, class CoarseSolver>
|
||||||
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
class HDCRPreconditioner : public LinearFunction< Lattice<Fobj> > {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Lattice<Fobj> >::operator();
|
||||||
|
|
||||||
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
typedef Aggregation<Fobj,CComplex,nbasis> Aggregates;
|
||||||
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
typedef typename Aggregation<Fobj,CComplex,nbasis>::CoarseVector CoarseVector;
|
||||||
@ -1194,11 +1198,11 @@ int main (int argc, char ** argv)
|
|||||||
PlainHermOp<CoarseCoarseVector> IRLOpL2 (IRLHermOpL2);
|
PlainHermOp<CoarseCoarseVector> IRLOpL2 (IRLHermOpL2);
|
||||||
ImplicitlyRestartedLanczos<CoarseCoarseVector> IRLL2(IRLOpChebyL2,IRLOpL2,cNstop,cNk,cNm,1.0e-3,20);
|
ImplicitlyRestartedLanczos<CoarseCoarseVector> IRLL2(IRLOpChebyL2,IRLOpL2,cNstop,cNk,cNm,1.0e-3,20);
|
||||||
|
|
||||||
int cNconv;
|
|
||||||
cNm=0;
|
cNm=0;
|
||||||
std::vector<RealD> eval2(cNm);
|
std::vector<RealD> eval2(cNm);
|
||||||
std::vector<CoarseCoarseVector> evec2(cNm,CoarseCoarse5d);
|
std::vector<CoarseCoarseVector> evec2(cNm,CoarseCoarse5d);
|
||||||
cc_src=1.0;
|
cc_src=1.0;
|
||||||
|
// int cNconv;
|
||||||
// IRLL2.calc(eval2,evec2,cc_src,cNconv);
|
// IRLL2.calc(eval2,evec2,cc_src,cNconv);
|
||||||
|
|
||||||
std::vector<RealD> tols ({0.005,0.001});
|
std::vector<RealD> tols ({0.005,0.001});
|
||||||
@ -1218,10 +1222,10 @@ int main (int argc, char ** argv)
|
|||||||
for(auto c_hi : c_his ) {
|
for(auto c_hi : c_his ) {
|
||||||
for(auto f_lo : f_los ) {
|
for(auto f_lo : f_los ) {
|
||||||
for(auto f_hi : f_his ) {
|
for(auto f_hi : f_his ) {
|
||||||
ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
// ZeroGuesser<CoarseVector> CoarseZeroGuesser;
|
||||||
ZeroGuesser<CoarseCoarseVector> CoarseCoarseZeroGuesser;
|
// ZeroGuesser<CoarseCoarseVector> CoarseCoarseZeroGuesser;
|
||||||
ConjugateGradient<CoarseCoarseVector> CoarseCoarseCG(tol,10000);
|
ConjugateGradient<CoarseCoarseVector> CoarseCoarseCG(tol,10000);
|
||||||
ZeroGuesser<CoarseCoarseVector> CoarseCoarseGuesser;
|
// ZeroGuesser<CoarseCoarseVector> CoarseCoarseGuesser;
|
||||||
SchurRedBlackDiagMooeeSolve<CoarseCoarseVector> CoarseCoarseRBCG(CoarseCoarseCG);
|
SchurRedBlackDiagMooeeSolve<CoarseCoarseVector> CoarseCoarseRBCG(CoarseCoarseCG);
|
||||||
SchurSolverWrapper<CoarseCoarseVector> CoarseCoarseSolver(cc_Dwf,CoarseCoarseRBCG);
|
SchurSolverWrapper<CoarseCoarseVector> CoarseCoarseSolver(cc_Dwf,CoarseCoarseRBCG);
|
||||||
|
|
||||||
|
@ -143,6 +143,7 @@ public:
|
|||||||
|
|
||||||
template<class Field> class MultiGridPreconditionerBase : public LinearFunction<Field> {
|
template<class Field> class MultiGridPreconditionerBase : public LinearFunction<Field> {
|
||||||
public:
|
public:
|
||||||
|
using LinearFunction<Field>::operator();
|
||||||
virtual ~MultiGridPreconditionerBase() = default;
|
virtual ~MultiGridPreconditionerBase() = default;
|
||||||
virtual void setup() = 0;
|
virtual void setup() = 0;
|
||||||
virtual void operator()(Field const &in, Field &out) = 0;
|
virtual void operator()(Field const &in, Field &out) = 0;
|
||||||
@ -156,6 +157,7 @@ public:
|
|||||||
/////////////////////////////////////////////
|
/////////////////////////////////////////////
|
||||||
// Type Definitions
|
// Type Definitions
|
||||||
/////////////////////////////////////////////
|
/////////////////////////////////////////////
|
||||||
|
using MultiGridPreconditionerBase<Lattice<Fobj>>::operator();
|
||||||
|
|
||||||
// clang-format off
|
// clang-format off
|
||||||
typedef Aggregation<Fobj, CComplex, nBasis> Aggregates;
|
typedef Aggregation<Fobj, CComplex, nBasis> Aggregates;
|
||||||
@ -568,6 +570,7 @@ public:
|
|||||||
/////////////////////////////////////////////
|
/////////////////////////////////////////////
|
||||||
// Type Definitions
|
// Type Definitions
|
||||||
/////////////////////////////////////////////
|
/////////////////////////////////////////////
|
||||||
|
using MultiGridPreconditionerBase<Lattice<Fobj>>::operator();
|
||||||
|
|
||||||
typedef Matrix FineDiracMatrix;
|
typedef Matrix FineDiracMatrix;
|
||||||
typedef Lattice<Fobj> FineVector;
|
typedef Lattice<Fobj> FineVector;
|
||||||
|
@ -56,7 +56,6 @@ int main (int argc, char ** argv)
|
|||||||
QuasiMinimalResidual<LatticeFermion> QMR(1.0e-8,10000);
|
QuasiMinimalResidual<LatticeFermion> QMR(1.0e-8,10000);
|
||||||
|
|
||||||
RealD mass=0.0;
|
RealD mass=0.0;
|
||||||
RealD M5=1.8;
|
|
||||||
WilsonFermionR Dw(Umu,*Grid,*rbGrid,mass);
|
WilsonFermionR Dw(Umu,*Grid,*rbGrid,mass);
|
||||||
|
|
||||||
NonHermitianLinearOperator<WilsonFermionR,LatticeFermion> NonHermOp(Dw);
|
NonHermitianLinearOperator<WilsonFermionR,LatticeFermion> NonHermOp(Dw);
|
||||||
|
Loading…
Reference in New Issue
Block a user