mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-11-04 05:54:32 +00:00 
			
		
		
		
	Hadrons: A2A vectors I/O
This commit is contained in:
		
							
								
								
									
										7
									
								
								Hadrons/Modules/MIO/LoadA2AVectors.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								Hadrons/Modules/MIO/LoadA2AVectors.cc
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,7 @@
 | 
			
		||||
#include <Hadrons/Modules/MIO/LoadA2AVectors.hpp>
 | 
			
		||||
 | 
			
		||||
using namespace Grid;
 | 
			
		||||
using namespace Hadrons;
 | 
			
		||||
using namespace MIO;
 | 
			
		||||
 | 
			
		||||
template class Grid::Hadrons::MIO::TLoadA2AVectors<FIMPL>;
 | 
			
		||||
							
								
								
									
										93
									
								
								Hadrons/Modules/MIO/LoadA2AVectors.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								Hadrons/Modules/MIO/LoadA2AVectors.hpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,93 @@
 | 
			
		||||
#ifndef Hadrons_MIO_LoadA2AVectors_hpp_
 | 
			
		||||
#define Hadrons_MIO_LoadA2AVectors_hpp_
 | 
			
		||||
 | 
			
		||||
#include <Hadrons/Global.hpp>
 | 
			
		||||
#include <Hadrons/Module.hpp>
 | 
			
		||||
#include <Hadrons/ModuleFactory.hpp>
 | 
			
		||||
#include <Hadrons/A2AVectors.hpp>
 | 
			
		||||
 | 
			
		||||
BEGIN_HADRONS_NAMESPACE
 | 
			
		||||
 | 
			
		||||
/******************************************************************************
 | 
			
		||||
 *                    Module to load all-to-all vectors                       *
 | 
			
		||||
 ******************************************************************************/
 | 
			
		||||
BEGIN_MODULE_NAMESPACE(MIO)
 | 
			
		||||
 | 
			
		||||
class LoadA2AVectorsPar: Serializable
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
    GRID_SERIALIZABLE_CLASS_MEMBERS(LoadA2AVectorsPar,
 | 
			
		||||
                                    std::string,  filestem,
 | 
			
		||||
                                    bool,         multiFile,
 | 
			
		||||
                                    unsigned int, size);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
class TLoadA2AVectors: public Module<LoadA2AVectorsPar>
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
    FERM_TYPE_ALIASES(FImpl,);
 | 
			
		||||
public:
 | 
			
		||||
    // constructor
 | 
			
		||||
    TLoadA2AVectors(const std::string name);
 | 
			
		||||
    // destructor
 | 
			
		||||
    virtual ~TLoadA2AVectors(void) {};
 | 
			
		||||
    // 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_TMP(LoadA2AVectors, TLoadA2AVectors<FIMPL>, MIO);
 | 
			
		||||
 | 
			
		||||
/******************************************************************************
 | 
			
		||||
 *                      TLoadA2AVectors implementation                        *
 | 
			
		||||
 ******************************************************************************/
 | 
			
		||||
// constructor /////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
TLoadA2AVectors<FImpl>::TLoadA2AVectors(const std::string name)
 | 
			
		||||
: Module<LoadA2AVectorsPar>(name)
 | 
			
		||||
{}
 | 
			
		||||
 | 
			
		||||
// dependencies/products ///////////////////////////////////////////////////////
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
std::vector<std::string> TLoadA2AVectors<FImpl>::getInput(void)
 | 
			
		||||
{
 | 
			
		||||
    std::vector<std::string> in;
 | 
			
		||||
    
 | 
			
		||||
    return in;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
std::vector<std::string> TLoadA2AVectors<FImpl>::getOutput(void)
 | 
			
		||||
{
 | 
			
		||||
    std::vector<std::string> out = {getName()};
 | 
			
		||||
    
 | 
			
		||||
    return out;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// setup ///////////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
void TLoadA2AVectors<FImpl>::setup(void)
 | 
			
		||||
{
 | 
			
		||||
    envCreate(std::vector<FermionField>, getName(), 1, par().size, 
 | 
			
		||||
              envGetGrid(FermionField));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// execution ///////////////////////////////////////////////////////////////////
 | 
			
		||||
template <typename FImpl>
 | 
			
		||||
void TLoadA2AVectors<FImpl>::execute(void)
 | 
			
		||||
{
 | 
			
		||||
    auto &vec = envGet(std::vector<FermionField>, getName());
 | 
			
		||||
 | 
			
		||||
    A2AVectorsIo::read(vec, par().filestem, par().multiFile, vm().getTrajectory());
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
END_MODULE_NAMESPACE
 | 
			
		||||
 | 
			
		||||
END_HADRONS_NAMESPACE
 | 
			
		||||
 | 
			
		||||
#endif // Hadrons_MIO_LoadA2AVectors_hpp_
 | 
			
		||||
@@ -51,7 +51,9 @@ public:
 | 
			
		||||
                                  std::string, noise,
 | 
			
		||||
                                  std::string, action,
 | 
			
		||||
                                  std::string, eigenPack,
 | 
			
		||||
                                  std::string, solver);
 | 
			
		||||
                                  std::string, solver,
 | 
			
		||||
                                  std::string, output,
 | 
			
		||||
                                  bool,        multiFile);
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
template <typename FImpl, typename Pack>
 | 
			
		||||
@@ -236,6 +238,13 @@ void TA2AVectors<FImpl, Pack>::execute(void)
 | 
			
		||||
        }
 | 
			
		||||
        stopTimer("W high mode");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // I/O if necessary
 | 
			
		||||
    if (!par().output.empty())
 | 
			
		||||
    {
 | 
			
		||||
        A2AVectorsIo::write(par().output + "_w", w, par().multiFile, vm().getTrajectory());
 | 
			
		||||
        A2AVectorsIo::write(par().output + "_v", v, par().multiFile, vm().getTrajectory());
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
END_MODULE_NAMESPACE
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user