diff --git a/extras/Hadrons/Modules.hpp b/extras/Hadrons/Modules.hpp index e8cdf2af..b98d5625 100644 --- a/extras/Hadrons/Modules.hpp +++ b/extras/Hadrons/Modules.hpp @@ -29,6 +29,7 @@ See the full license in the file "LICENSE" in the top level distribution directo #include #include #include +#include #include #include #include diff --git a/extras/Hadrons/Modules/MContraction/Gamma3pt.hpp b/extras/Hadrons/Modules/MContraction/Gamma3pt.hpp new file mode 100644 index 00000000..e5e73fa6 --- /dev/null +++ b/extras/Hadrons/Modules/MContraction/Gamma3pt.hpp @@ -0,0 +1,170 @@ +/************************************************************************************* + +Grid physics library, www.github.com/paboyle/Grid + +Source file: extras/Hadrons/Modules/MContraction/Gamma3pt.hpp + +Copyright (C) 2017 + +Author: Andrew Lawson + +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 */ + +#ifndef Hadrons_Gamma3pt_hpp_ +#define Hadrons_Gamma3pt_hpp_ + +#include +#include +#include + +BEGIN_HADRONS_NAMESPACE + +/* + * 3pt contraction with gamma matrix insertion. + * + * Schematic: + * + * q2 q3 + * /----<------*------<----¬ + * / gamma \ + * / \ + * i * * f + * \ / + * \ / + * \----------->----------/ + * q1 + * + * trace(g5*q1*adj(q2)*g5*gamma*q3) + */ + +/****************************************************************************** + * Gamma3pt * + ******************************************************************************/ +BEGIN_MODULE_NAMESPACE(MContraction) + +class Gamma3ptPar: Serializable +{ +public: + GRID_SERIALIZABLE_CLASS_MEMBERS(Gamma3ptPar, + std::string, q1, + std::string, q2, + std::string, q3, + Gamma::Algebra, gamma, + std::string, output); +}; + +template +class TGamma3pt: public Module +{ + TYPE_ALIASES(FImpl1, 1); + TYPE_ALIASES(FImpl2, 2); + TYPE_ALIASES(FImpl3, 3); + class Result: Serializable + { + public: + GRID_SERIALIZABLE_CLASS_MEMBERS(Result, + Gamma::Algebra, gamma, + std::vector, corr); + }; +public: + // constructor + TGamma3pt(const std::string name); + // destructor + virtual ~TGamma3pt(void) = default; + // dependency relation + virtual std::vector getInput(void); + virtual std::vector getOutput(void); + // setup + virtual void setup(void); + // execution + virtual void execute(void); +}; + +MODULE_REGISTER_NS(Gamma3pt, ARG(TGamma3pt), MContraction); + +/****************************************************************************** + * TGamma3pt implementation * + ******************************************************************************/ +// constructor ///////////////////////////////////////////////////////////////// +template +TGamma3pt::TGamma3pt(const std::string name) +: Module(name) +{} + +// dependencies/products /////////////////////////////////////////////////////// +template +std::vector TGamma3pt::getInput(void) +{ + std::vector in = {par().q1, par().q2, par().q3}; + + return in; +} + +template +std::vector TGamma3pt::getOutput(void) +{ + std::vector out = {getName()}; + + return out; +} + +// setup /////////////////////////////////////////////////////////////////////// +template +void TGamma3pt::setup(void) +{ + +} + +// execution /////////////////////////////////////////////////////////////////// +template +void TGamma3pt::execute(void) +{ + LOG(Message) << "Computing 3pt contractions '" << getName() << "' using" + << " quarks '" << par().q1 << "', '" << par().q2 << "' and '" + << par().q3 << "', with " << par().gamma << " insertion." + << std::endl; + + CorrWriter writer(par().output); + PropagatorField1 &q1 = *env().template getObject(par().q1); + PropagatorField2 &q2 = *env().template getObject(par().q2); + PropagatorField3 &q3 = *env().template getObject(par().q3); + LatticeComplex c(env().getGrid()); + Gamma g5(Gamma::Algebra::Gamma5); + Gamma gamma(par().gamma); + std::vector buf; + Result result; + + c = trace(g5*q1*adj(q2)*(g5*gamma)*q3); + sliceSum(c, buf, Tp); + + result.gamma = par().gamma; + result.corr.resize(buf.size()); + for (unsigned int t = 0; t < buf.size(); ++t) + { + result.corr[t] = TensorRemove(buf[t]); + } + + write(writer, "gamma3pt", result); +} + +END_MODULE_NAMESPACE + +END_HADRONS_NAMESPACE + +#endif // Hadrons_Gamma3pt_hpp_ diff --git a/extras/Hadrons/modules.inc b/extras/Hadrons/modules.inc index 3e2f1020..0a142626 100644 --- a/extras/Hadrons/modules.inc +++ b/extras/Hadrons/modules.inc @@ -9,6 +9,7 @@ modules_hpp =\ Modules/MAction/DWF.hpp \ Modules/MAction/Wilson.hpp \ Modules/MContraction/Baryon.hpp \ + Modules/MContraction/Gamma3pt.hpp \ Modules/MContraction/Meson.hpp \ Modules/MContraction/WeakHamiltonian.hpp \ Modules/MContraction/WeakHamiltonianEye.hpp \