mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-25 10:09:34 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef Hadrons_MSink_Point_hpp_
 | |
| #define Hadrons_MSink_Point_hpp_
 | |
| 
 | |
| #include <Grid/Hadrons/Global.hpp>
 | |
| #include <Grid/Hadrons/Module.hpp>
 | |
| #include <Grid/Hadrons/ModuleFactory.hpp>
 | |
| 
 | |
| BEGIN_HADRONS_NAMESPACE
 | |
| 
 | |
| /******************************************************************************
 | |
|  *                                   Point                                    *
 | |
|  ******************************************************************************/
 | |
| BEGIN_MODULE_NAMESPACE(MSink)
 | |
| 
 | |
| class PointPar: Serializable
 | |
| {
 | |
| public:
 | |
|     GRID_SERIALIZABLE_CLASS_MEMBERS(PointPar,
 | |
|                                     std::string, mom);
 | |
| };
 | |
| 
 | |
| template <typename FImpl>
 | |
| class TPoint: public Module<PointPar>
 | |
| {
 | |
| public:
 | |
|     FERM_TYPE_ALIASES(FImpl,);
 | |
|     SINK_TYPE_ALIASES();
 | |
| public:
 | |
|     // constructor
 | |
|     TPoint(const std::string name);
 | |
|     // destructor
 | |
|     virtual ~TPoint(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(Point,       TPoint<FIMPL>,        MSink);
 | |
| MODULE_REGISTER_NS(ScalarPoint, TPoint<ScalarImplCR>, MSink);
 | |
| 
 | |
| /******************************************************************************
 | |
|  *                          TPoint implementation                             *
 | |
|  ******************************************************************************/
 | |
| // constructor /////////////////////////////////////////////////////////////////
 | |
| template <typename FImpl>
 | |
| TPoint<FImpl>::TPoint(const std::string name)
 | |
| : Module<PointPar>(name)
 | |
| {}
 | |
| 
 | |
| // dependencies/products ///////////////////////////////////////////////////////
 | |
| template <typename FImpl>
 | |
| std::vector<std::string> TPoint<FImpl>::getInput(void)
 | |
| {
 | |
|     std::vector<std::string> in;
 | |
|     
 | |
|     return in;
 | |
| }
 | |
| 
 | |
| template <typename FImpl>
 | |
| std::vector<std::string> TPoint<FImpl>::getOutput(void)
 | |
| {
 | |
|     std::vector<std::string> out = {getName()};
 | |
|     
 | |
|     return out;
 | |
| }
 | |
| 
 | |
| // setup ///////////////////////////////////////////////////////////////////////
 | |
| template <typename FImpl>
 | |
| void TPoint<FImpl>::setup(void)
 | |
| {
 | |
|     unsigned int size;
 | |
|     
 | |
|     size = env().template lattice4dSize<LatticeComplex>();
 | |
|     env().registerObject(getName(), size);
 | |
| }
 | |
| 
 | |
| // execution ///////////////////////////////////////////////////////////////////
 | |
| template <typename FImpl>
 | |
| void TPoint<FImpl>::execute(void)
 | |
| {
 | |
|     std::vector<Real> p = strToVec<Real>(par().mom);
 | |
|     LatticeComplex    ph(env().getGrid()), coor(env().getGrid());
 | |
|     Complex           i(0.0,1.0);
 | |
|     
 | |
|     LOG(Message) << "Setting up point sink function for momentum ["
 | |
|                  << par().mom << "]" << std::endl;
 | |
|     ph = zero;
 | |
|     for(unsigned int mu = 0; mu < env().getNd(); mu++)
 | |
|     {
 | |
|         LatticeCoordinate(coor, mu);
 | |
|         ph = ph + (p[mu]/env().getGrid()->_fdimensions[mu])*coor;
 | |
|     }
 | |
|     ph = exp((Real)(2*M_PI)*i*ph);
 | |
|     auto sink = [ph](const PropagatorField &field)
 | |
|     {
 | |
|         SlicedPropagator res;
 | |
|         PropagatorField  tmp = ph*field;
 | |
|         
 | |
|         sliceSum(tmp, res, Tp);
 | |
|         
 | |
|         return res;
 | |
|     };
 | |
|     env().setObject(getName(), new SinkFn(sink));
 | |
| }
 | |
| 
 | |
| END_MODULE_NAMESPACE
 | |
| 
 | |
| END_HADRONS_NAMESPACE
 | |
| 
 | |
| #endif // Hadrons_MSink_Point_hpp_
 |