1
0
mirror of https://github.com/paboyle/Grid.git synced 2025-04-04 19:25:56 +01:00

Debugged finally. A silly mistake in permute cost me a day of debug.

This commit is contained in:
Peter Boyle 2015-06-09 22:37:21 +01:00
parent eeeaac7147
commit 2e6986892a

View File

@ -11,7 +11,6 @@ namespace Grid {
int npoint; int npoint;
std::vector<int> directions ; std::vector<int> directions ;
std::vector<int> displacements; std::vector<int> displacements;
std::vector<int> opdirs;
// FIXME -- don't like xposing the operator directions // FIXME -- don't like xposing the operator directions
// as different to the geometrical dirs // as different to the geometrical dirs
@ -26,18 +25,22 @@ namespace Grid {
npoint = 2*_d+1; npoint = 2*_d+1;
directions.resize(npoint); directions.resize(npoint);
displacements.resize(npoint); displacements.resize(npoint);
opdirs.resize(npoint);
for(int d=0;d<_d;d++){ for(int d=0;d<_d;d++){
directions[2*d ] = d+base; directions[2*d ] = d+base;
directions[2*d+1] = d+base; directions[2*d+1] = d+base;
opdirs[2*d ] = d;
opdirs[2*d+1] = d;
displacements[2*d ] = +1; displacements[2*d ] = +1;
displacements[2*d+1] = -1; displacements[2*d+1] = -1;
} }
directions [2*_d]=0; directions [2*_d]=0;
displacements[2*_d]=0; displacements[2*_d]=0;
opdirs [2*_d]=0;
//// report back
std::cout<<"directions :";
for(int d=0;d<npoint;d++) std::cout<< directions[d]<< " ";
std::cout <<std::endl;
std::cout<<"displacements :";
for(int d=0;d<npoint;d++) std::cout<< displacements[d]<< " ";
std::cout <<std::endl;
} }
/* /*
@ -64,12 +67,12 @@ namespace Grid {
// Fine Object == (per site) type of fine field // Fine Object == (per site) type of fine field
// nbasis == number of deflation vectors // nbasis == number of deflation vectors
template<class Fobj,class CComplex,int nbasis> template<class Fobj,class CComplex,int nbasis>
class CoarsenedMatrix : public SparseMatrixBase<Lattice<iVector<vComplex,nbasis > > > { class CoarsenedMatrix : public SparseMatrixBase<Lattice<iVector<CComplex,nbasis > > > {
public: public:
typedef iVector<vComplex,nbasis > siteVector; typedef iVector<CComplex,nbasis > siteVector;
typedef Lattice<iVector<vComplex,nbasis > > CoarseVector; typedef Lattice<siteVector> CoarseVector;
typedef Lattice<iMatrix<vComplex,nbasis > > CoarseMatrix; typedef Lattice<iMatrix<CComplex,nbasis > > CoarseMatrix;
typedef Lattice< CComplex > CoarseScalar; // used for inner products on fine field typedef Lattice< CComplex > CoarseScalar; // used for inner products on fine field
typedef Lattice<Fobj > FineField; typedef Lattice<Fobj > FineField;
@ -82,7 +85,6 @@ namespace Grid {
CartesianStencil Stencil; CartesianStencil Stencil;
std::vector<CoarseMatrix> A; std::vector<CoarseMatrix> A;
std::vector<CoarseMatrix> Aslow;
std::vector<siteVector,alignedAllocator<siteVector> > comm_buf; std::vector<siteVector,alignedAllocator<siteVector> > comm_buf;
@ -91,25 +93,28 @@ namespace Grid {
/////////////////////// ///////////////////////
GridBase * Grid(void) { return _grid; }; // this is all the linalg routines need to know GridBase * Grid(void) { return _grid; }; // this is all the linalg routines need to know
RealD M (const CoarseVector &in, CoarseVector &out){ RealD M (const CoarseVector &in, CoarseVector &out){
conformable(_grid,in._grid);
conformable(in._grid,out._grid);
SimpleCompressor<siteVector> compressor; SimpleCompressor<siteVector> compressor;
Stencil.HaloExchange(in,comm_buf,compressor); Stencil.HaloExchange(in,comm_buf,compressor);
PARALLEL_FOR_LOOP //PARALLEL_FOR_LOOP
for(int ss=0;ss<Grid()->oSites();ss++){ for(int ss=0;ss<Grid()->oSites();ss++){
siteVector res = zero; siteVector res = zero;
siteVector tmp;
siteVector nbr; siteVector nbr;
int offset,local,perm,ptype;
int offset,local,perm;
for(int point=0;point<geom.npoint;point++){ for(int point=0;point<geom.npoint;point++){
offset = Stencil._offsets [point][ss]; offset = Stencil._offsets [point][ss];
local = Stencil._is_local[point][ss]; local = Stencil._is_local[point][ss];
perm = Stencil._permute[point][ss]; perm = Stencil._permute [point][ss];
ptype = Stencil._permute_type[point];
if(local&&perm) { if(local&&perm) {
permute(nbr,in._odata[offset],perm); permute(nbr,in._odata[offset],ptype);
} else if(local) { } else if(local) {
nbr = in._odata[offset]; nbr = in._odata[offset];
} else { } else {
@ -125,6 +130,7 @@ PARALLEL_FOR_LOOP
RealD Mdag (const CoarseVector &in, CoarseVector &out){ RealD Mdag (const CoarseVector &in, CoarseVector &out){
return M(in,out); return M(in,out);
}; };
// Defer support for further coarsening for now // Defer support for further coarsening for now
void Mdiag (const CoarseVector &in, CoarseVector &out){}; void Mdiag (const CoarseVector &in, CoarseVector &out){};
void Mdir (const CoarseVector &in, CoarseVector &out,int dir, int disp){}; void Mdir (const CoarseVector &in, CoarseVector &out,int dir, int disp){};
@ -134,8 +140,7 @@ PARALLEL_FOR_LOOP
_grid(&CoarseGrid), _grid(&CoarseGrid),
geom(CoarseGrid._ndimension), geom(CoarseGrid._ndimension),
Stencil(&CoarseGrid,geom.npoint,Even,geom.directions,geom.displacements), Stencil(&CoarseGrid,geom.npoint,Even,geom.directions,geom.displacements),
A(geom.npoint,&CoarseGrid), A(geom.npoint,&CoarseGrid)
Aslow(geom.npoint,&CoarseGrid)
{ {
comm_buf.resize(Stencil._unified_buffer_size); comm_buf.resize(Stencil._unified_buffer_size);
}; };
@ -176,8 +181,7 @@ PARALLEL_FOR_LOOP
for(int p=0;p<geom.npoint;p++){ for(int p=0;p<geom.npoint;p++){
int dir = geom.directions[p]; int dir = geom.directions[p];
int opdir = geom.opdirs[p]; int disp = geom.displacements[p];
int disp= geom.displacements[p];
int block=(FineGrid->_rdimensions[dir])/(Grid()->_rdimensions[dir]); int block=(FineGrid->_rdimensions[dir])/(Grid()->_rdimensions[dir]);
@ -187,7 +191,7 @@ PARALLEL_FOR_LOOP
linop.OpDiag(phi,Mphi); linop.OpDiag(phi,Mphi);
} }
else { else {
linop.OpDir(phi,Mphi,opdir,disp); linop.OpDir(phi,Mphi,dir,disp);
} }
//////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////
@ -240,6 +244,62 @@ PARALLEL_FOR_LOOP
std::cout<< iProj <<std::endl; std::cout<< iProj <<std::endl;
std::cout<<"Computed Coarse Operator"<<std::endl; std::cout<<"Computed Coarse Operator"<<std::endl;
#endif #endif
AssertHermitian();
// ForceHermitian();
// ForceDiagonal();
}
void ForceDiagonal(void) {
std::cout<<"**************************************************"<<std::endl;
std::cout<<"**** Forcing coarse operator to be diagonal ****"<<std::endl;
std::cout<<"**************************************************"<<std::endl;
for(int p=0;p<8;p++){
A[p]=zero;
}
GridParallelRNG RNG(Grid()); RNG.SeedRandomDevice();
Lattice<iScalar<CComplex> > val(Grid()); random(RNG,val);
Complex one(1.0);
iMatrix<Complex,nbasis> ident; ident=one;
val = val*adj(val);
val = val + 1.0;
A[8] = val*ident;
// for(int s=0;s<Grid()->oSites();s++) {
// A[8]._odata[s]=val._odata[s];
// }
}
void ForceHermitian(void) {
for(int d=0;d<4;d++){
int dd=d+1;
A[2*d] = adj(Cshift(A[2*d+1],dd,1));
}
A[8] = 0.5*(A[8] + adj(A[8]));
}
void AssertHermitian(void) {
CoarseMatrix AA (Grid());
CoarseMatrix AAc (Grid());
CoarseMatrix Diff (Grid());
for(int d=0;d<4;d++){
int dd=d+1;
AAc = Cshift(A[2*d+1],dd,1);
AA = A[2*d];
Diff = AA - adj(AAc);
std::cout<<"Norm diff dim "<<d<<" "<< norm2(Diff)<<std::endl;
std::cout<<"Norm dim "<<d<<" "<< norm2(AA)<<std::endl;
}
Diff = A[8] - adj(A[8]);
std::cout<<"Norm diff local "<< norm2(Diff)<<std::endl;
std::cout<<"Norm local "<< norm2(A[8])<<std::endl;
} }
}; };