diff --git a/Grid/qcd/smearing/HISQSmearing.h b/Grid/qcd/smearing/HISQSmearing.h index 53480f25..95187d48 100644 --- a/Grid/qcd/smearing/HISQSmearing.h +++ b/Grid/qcd/smearing/HISQSmearing.h @@ -51,25 +51,21 @@ template void gpermute(vobj & inout,int perm) { } -/*! @brief 3-link smearing of link variable. */ -//template -//class Smear_HISQ_3link : public Smear { -class Smear_HISQ_3link { -// TODO: I'm not using Gimpl so I don't know how to inherit + +/*! @brief create fat links from link variables. */ +class Smear_HISQ_fat { private: -// std::vector _linkTreatment; - GridBase* const _grid; + GridCartesian* const _grid; public: -// INHERIT_GIMPL_TYPES(Gimpl) // Eventually this will take, e.g., coefficients as argument - Smear_HISQ_3link(GridBase* grid) : _grid(grid) { + Smear_HISQ_fat(GridCartesian* grid) : _grid(grid) { assert(Nc == 3 && "HISQ smearing currently implemented only for Nc==3"); } - ~Smear_HISQ_3link() {} + ~Smear_HISQ_fat() {} void smear(LatticeGaugeField& u_smr, const LatticeGaugeField& U) const { @@ -83,7 +79,7 @@ public: LatticeComplex gplaq(GhostGrid); // This is where the 3-link constructs will be stored - LatticeGaugeField Ughost_3link(Ughost.Grid()); + LatticeGaugeField Ughost_fat(Ughost.Grid()); // Create 3-link stencil (class will build its own stencils) // writing your own stencil, you're hard-coding the periodic BCs, so you don't need @@ -110,11 +106,11 @@ public: } GeneralLocalStencil gStencil(GhostGrid,shifts); - Ughost_3link=Zero(); + Ughost_fat=Zero(); - // Create the accessors, here U_v and U_3link_v + // Create the accessors, here U_v and U_fat_v autoView(U_v , Ughost , CpuRead); - autoView(U_3link_v, Ughost_3link, CpuWrite); + autoView(U_fat_v, Ughost_fat, CpuWrite); // This is a loop over local sites. for(int ss=0;ss_grid); + LatticeGaugeField Ughost = Ghost.Exchange(u_smr); + + GridBase *GhostGrid = Ughost.Grid(); + LatticeComplex gplaq(GhostGrid); + + LatticeGaugeField Ughost_naik(Ughost.Grid()); + + std::vector shifts; + for(int mu=0;mu_offset; + int o1 = SE1->_offset; + int o2 = SE2->_offset; + int o3 = SE3->_offset; + int o4 = SE4->_offset; + int o5 = SE5->_offset; + + auto U0 = U_v[o0](nu); + auto U1 = adj(U_v[o1](mu)); + auto U2 = adj(U_v[o2](nu)); + + gpermute(U0,SE0->_permute); + gpermute(U1,SE1->_permute); + gpermute(U2,SE2->_permute); + + auto U3 = adj(U_v[o3](nu)); + auto U4 = adj(U_v[o4](mu)); + auto U5 = U_v[o5](nu); + + gpermute(U3,SE3->_permute); + gpermute(U4,SE4->_permute); + gpermute(U5,SE5->_permute); + + // Forward contribution from this orientation + auto W = U0*U1*U2; + U_naik_v[ss](mu) = U_naik_v[ss](mu) + W; + + // Backward contribution from this orientation + W = U3*U4*U5; + U_naik_v[ss](mu) = U_naik_v[ss](mu) + W; + + s=s+6; + } + } + } + + // Here is my understanding of this part: The padded cell has its own periodic BCs, so + // if I take a step to the right at the right-most side of the cell, I end up on the + // left-most side. This means that the plaquettes in the padding are wrong. Luckily + // all we care about are the plaquettes in the cell, which we obtain from Extract. + u_smr = Ghost.Extract(Ughost_naik); }; // void derivative(const GaugeField& Gauge) const { // }; }; + NAMESPACE_END(Grid); diff --git a/tests/smearing/Test_fatLinks.cc b/tests/smearing/Test_fatLinks.cc index 124cfac3..e87c48e0 100644 --- a/tests/smearing/Test_fatLinks.cc +++ b/tests/smearing/Test_fatLinks.cc @@ -67,9 +67,9 @@ int main (int argc, char **argv) FieldMetaData header; NerscIO::readConfiguration(Umu, header, param.conf_in); - Smear_HISQ_3link hisq_3link(&GRID); + Smear_HISQ_fat hisq_fat(&GRID); - hisq_3link.smear(U_smr,Umu); + hisq_fat.smear(U_smr,Umu); NerscIO::writeConfiguration(U_smr,param.conf_out,"HISQ");