mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-11-04 14:04:32 +00:00 
			
		
		
		
	Hadrons: scalar SU(N) EMT
This commit is contained in:
		@@ -63,6 +63,7 @@ See the full license in the file "LICENSE" in the top level distribution directo
 | 
			
		||||
#include <Grid/Hadrons/Modules/MAction/ZMobiusDWF.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/Div.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/TrMag.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/EMT.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/TwoPoint.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/TrPhi.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/Utils.hpp>
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										150
									
								
								extras/Hadrons/Modules/MScalarSUN/EMT.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								extras/Hadrons/Modules/MScalarSUN/EMT.hpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,150 @@
 | 
			
		||||
#ifndef Hadrons_MScalarSUN_EMT_hpp_
 | 
			
		||||
#define Hadrons_MScalarSUN_EMT_hpp_
 | 
			
		||||
 | 
			
		||||
#include <Grid/Hadrons/Global.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Module.hpp>
 | 
			
		||||
#include <Grid/Hadrons/ModuleFactory.hpp>
 | 
			
		||||
#include <Grid/Hadrons/Modules/MScalarSUN/Utils.hpp>
 | 
			
		||||
 | 
			
		||||
BEGIN_HADRONS_NAMESPACE
 | 
			
		||||
 | 
			
		||||
/******************************************************************************
 | 
			
		||||
 *                         Energy-momentum tensor                             *
 | 
			
		||||
 ******************************************************************************/
 | 
			
		||||
BEGIN_MODULE_NAMESPACE(MScalarSUN)
 | 
			
		||||
 | 
			
		||||
class EMTPar: Serializable
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
    GRID_SERIALIZABLE_CLASS_MEMBERS(EMTPar,
 | 
			
		||||
                                    std::string, kinetic,
 | 
			
		||||
                                    std::string, phiPow,
 | 
			
		||||
                                    std::string, improvement,
 | 
			
		||||
                                    double     , m2,
 | 
			
		||||
                                    double     , lambda,
 | 
			
		||||
                                    double     , g,
 | 
			
		||||
                                    double     , xi,
 | 
			
		||||
                                    std::string, output);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
class TEMT: public Module<EMTPar>
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
    typedef typename SImpl::Field        Field;
 | 
			
		||||
    typedef typename SImpl::ComplexField ComplexField;
 | 
			
		||||
public:
 | 
			
		||||
    // constructor
 | 
			
		||||
    TEMT(const std::string name);
 | 
			
		||||
    // destructor
 | 
			
		||||
    virtual ~TEMT(void) = default;
 | 
			
		||||
    // dependency relation
 | 
			
		||||
    virtual std::vector<std::string> getInput(void);
 | 
			
		||||
    virtual std::vector<std::string> getOutput(void);
 | 
			
		||||
    // setup
 | 
			
		||||
    virtual void setup(void);
 | 
			
		||||
    // execution
 | 
			
		||||
    virtual void execute(void);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
MODULE_REGISTER_NS(EMTSU2, TEMT<ScalarNxNAdjImplR<2>>, MScalarSUN);
 | 
			
		||||
MODULE_REGISTER_NS(EMTSU3, TEMT<ScalarNxNAdjImplR<3>>, MScalarSUN);
 | 
			
		||||
MODULE_REGISTER_NS(EMTSU4, TEMT<ScalarNxNAdjImplR<4>>, MScalarSUN);
 | 
			
		||||
MODULE_REGISTER_NS(EMTSU5, TEMT<ScalarNxNAdjImplR<5>>, MScalarSUN);
 | 
			
		||||
MODULE_REGISTER_NS(EMTSU6, TEMT<ScalarNxNAdjImplR<6>>, MScalarSUN);
 | 
			
		||||
 | 
			
		||||
/******************************************************************************
 | 
			
		||||
 *                           TEMT implementation                              *
 | 
			
		||||
 ******************************************************************************/
 | 
			
		||||
// constructor /////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
TEMT<SImpl>::TEMT(const std::string name)
 | 
			
		||||
: Module<EMTPar>(name)
 | 
			
		||||
{}
 | 
			
		||||
 | 
			
		||||
// dependencies/products ///////////////////////////////////////////////////////
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
std::vector<std::string> TEMT<SImpl>::getInput(void)
 | 
			
		||||
{
 | 
			
		||||
    std::vector<std::string> in;
 | 
			
		||||
    
 | 
			
		||||
    for (unsigned int mu = 0; mu < env().getNd(); ++mu)
 | 
			
		||||
    for (unsigned int nu = mu; nu < env().getNd(); ++nu)
 | 
			
		||||
    {
 | 
			
		||||
        in.push_back(varName(par().kinetic, mu, nu));
 | 
			
		||||
        in.push_back(varName(par().improvement, mu, nu));
 | 
			
		||||
    }
 | 
			
		||||
    in.push_back(varName(par().phiPow, 2));
 | 
			
		||||
    in.push_back(varName(par().phiPow, 4));
 | 
			
		||||
 | 
			
		||||
    return in;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
std::vector<std::string> TEMT<SImpl>::getOutput(void)
 | 
			
		||||
{
 | 
			
		||||
    std::vector<std::string> out = {getName()};
 | 
			
		||||
    
 | 
			
		||||
    for (unsigned int mu = 0; mu < env().getNd(); ++mu)
 | 
			
		||||
    for (unsigned int nu = mu; nu < env().getNd(); ++nu)
 | 
			
		||||
    {
 | 
			
		||||
        out.push_back(varName(getName(), mu, nu));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return out;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// setup ///////////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
void TEMT<SImpl>::setup(void)
 | 
			
		||||
{
 | 
			
		||||
    envCreateLat(ComplexField, getName());
 | 
			
		||||
    envTmpLat(ComplexField, "sumkin");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// execution ///////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename SImpl>
 | 
			
		||||
void TEMT<SImpl>::execute(void)
 | 
			
		||||
{
 | 
			
		||||
    LOG(Message) << "Computing energy-momentum tensor" << std::endl;
 | 
			
		||||
    LOG(Message) << "  kinetic terms: '" << par().kinetic << "'" << std::endl;
 | 
			
		||||
    LOG(Message) << "      tr(phi^n): '" << par().phiPow << "'" << std::endl;
 | 
			
		||||
    LOG(Message) << "    improvement: '" << par().improvement << "'" << std::endl;
 | 
			
		||||
    LOG(Message) << "            m^2= " << par().m2 << std::endl;
 | 
			
		||||
    LOG(Message) << "         lambda= " << par().lambda << std::endl;
 | 
			
		||||
    LOG(Message) << "              g= " << par().g << std::endl;
 | 
			
		||||
    LOG(Message) << "             xi= " << par().xi << std::endl;
 | 
			
		||||
 | 
			
		||||
    const unsigned int N       = SImpl::Group::Dimension;
 | 
			
		||||
    auto               &trphi2 = envGet(ComplexField, varName(par().phiPow, 2));
 | 
			
		||||
    auto               &trphi4 = envGet(ComplexField, varName(par().phiPow, 4));
 | 
			
		||||
 | 
			
		||||
    envGetTmp(ComplexField, sumkin);
 | 
			
		||||
    sumkin = zero;
 | 
			
		||||
    for (unsigned int mu = 0; mu < env().getNd(); ++mu)
 | 
			
		||||
    {
 | 
			
		||||
        auto &trkin = envGet(ComplexField, varName(par().kinetic, mu, mu));
 | 
			
		||||
 | 
			
		||||
        sumkin += trkin;
 | 
			
		||||
    }
 | 
			
		||||
    for (unsigned int mu = 0; mu < env().getNd(); ++mu)
 | 
			
		||||
    for (unsigned int nu = mu; nu < env().getNd(); ++nu)
 | 
			
		||||
    {
 | 
			
		||||
        auto &out   = envGet(ComplexField, varName(getName(), mu, nu));
 | 
			
		||||
        auto &trkin = envGet(ComplexField, varName(par().kinetic, mu, nu));
 | 
			
		||||
        auto &imp   = envGet(ComplexField, varName(par().improvement, mu, nu));
 | 
			
		||||
 | 
			
		||||
        out = 2.*trkin + par().xi*imp;
 | 
			
		||||
        if (mu == nu)
 | 
			
		||||
        {
 | 
			
		||||
            out -= sumkin + par().m2*trphi2 + par().lambda*trphi4;
 | 
			
		||||
        }
 | 
			
		||||
        out *= N/par().g;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
END_MODULE_NAMESPACE
 | 
			
		||||
 | 
			
		||||
END_HADRONS_NAMESPACE
 | 
			
		||||
 | 
			
		||||
#endif // Hadrons_MScalarSUN_EMT_hpp_
 | 
			
		||||
@@ -46,6 +46,7 @@ modules_hpp =\
 | 
			
		||||
  Modules/MAction/ZMobiusDWF.hpp \
 | 
			
		||||
  Modules/MScalarSUN/Div.hpp \
 | 
			
		||||
  Modules/MScalarSUN/TrMag.hpp \
 | 
			
		||||
  Modules/MScalarSUN/EMT.hpp \
 | 
			
		||||
  Modules/MScalarSUN/TwoPoint.hpp \
 | 
			
		||||
  Modules/MScalarSUN/TrPhi.hpp \
 | 
			
		||||
  Modules/MScalarSUN/Utils.hpp \
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user