mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-26 01:29:34 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			174 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			174 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*************************************************************************************
 | |
| 
 | |
| Grid physics library, www.github.com/paboyle/Grid
 | |
| 
 | |
| Source file: ./lib/qcd/hmc/GenericHmcRunner.h
 | |
| 
 | |
| Copyright (C) 2015
 | |
| 
 | |
| Author: paboyle <paboyle@ph.ed.ac.uk>
 | |
| 
 | |
| 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 GENERIC_HMC_RUNNER
 | |
| #define GENERIC_HMC_RUNNER
 | |
| 
 | |
| namespace Grid {
 | |
| namespace QCD {
 | |
| 
 | |
| // Virtual Class for HMC specific for gauge theories
 | |
| // implement a specific theory by defining the BuildTheAction
 | |
| template <class Implementation, class RepresentationsPolicy = NoHirep>
 | |
| class BinaryHmcRunnerTemplate {
 | |
|  public:
 | |
|   INHERIT_FIELD_TYPES(Implementation);
 | |
| 
 | |
|   enum StartType_t { ColdStart, HotStart, TepidStart, CheckpointStart };
 | |
| 
 | |
|   ActionSet<Field, RepresentationsPolicy> TheAction;
 | |
|   // Add here a vector of HmcObservable 
 | |
|   // that can be injected from outside  
 | |
| 
 | |
|   GridCartesian *UGrid;
 | |
|   GridCartesian *FGrid;
 | |
|   GridRedBlackCartesian *UrbGrid;
 | |
|   GridRedBlackCartesian *FrbGrid;
 | |
| 
 | |
|   virtual void BuildTheAction(int argc, char **argv) = 0;  // necessary?
 | |
| 
 | |
|   void Run(int argc, char **argv) {
 | |
|     StartType_t StartType = HotStart;
 | |
| 
 | |
|     std::string arg;
 | |
| 
 | |
|     if (GridCmdOptionExists(argv, argv + argc, "--StartType")) {
 | |
|       arg = GridCmdOptionPayload(argv, argv + argc, "--StartType");
 | |
|       if (arg == "HotStart") {
 | |
|         StartType = HotStart;
 | |
|       } else if (arg == "ColdStart") {
 | |
|         StartType = ColdStart;
 | |
|       } else if (arg == "TepidStart") {
 | |
|         StartType = TepidStart;
 | |
|       } else if (arg == "CheckpointStart") {
 | |
|         StartType = CheckpointStart;
 | |
|       } else {
 | |
|         std::cout << GridLogError << "Unrecognized option in --StartType\n";
 | |
|         std::cout
 | |
|             << GridLogError
 | |
|             << "Valid [HotStart, ColdStart, TepidStart, CheckpointStart]\n";
 | |
|         assert(0);
 | |
|       }
 | |
|     }
 | |
| 
 | |
|     int StartTraj = 0;
 | |
|     if (GridCmdOptionExists(argv, argv + argc, "--StartTrajectory")) {
 | |
|       arg = GridCmdOptionPayload(argv, argv + argc, "--StartTrajectory");
 | |
|       std::vector<int> ivec(0);
 | |
|       GridCmdOptionIntVector(arg, ivec);
 | |
|       StartTraj = ivec[0];
 | |
|     }
 | |
| 
 | |
|     int NumTraj = 1;
 | |
|     if (GridCmdOptionExists(argv, argv + argc, "--Trajectories")) {
 | |
|       arg = GridCmdOptionPayload(argv, argv + argc, "--Trajectories");
 | |
|       std::vector<int> ivec(0);
 | |
|       GridCmdOptionIntVector(arg, ivec);
 | |
|       NumTraj = ivec[0];
 | |
|     }
 | |
| 
 | |
|     int NumThermalizations = 10;
 | |
|     if (GridCmdOptionExists(argv, argv + argc, "--Thermalizations")) {
 | |
|       arg = GridCmdOptionPayload(argv, argv + argc, "--Thermalizations");
 | |
|       std::vector<int> ivec(0);
 | |
|       GridCmdOptionIntVector(arg, ivec);
 | |
|       NumThermalizations = ivec[0];
 | |
|     }
 | |
| 
 | |
|     GridSerialRNG sRNG;
 | |
|     GridParallelRNG pRNG(UGrid);
 | |
|     Field U(UGrid);
 | |
| 
 | |
|     std::vector<int> SerSeed({1, 2, 3, 4, 5});
 | |
|     std::vector<int> ParSeed({6, 7, 8, 9, 10});
 | |
| 
 | |
|     NoSmearing<Implementation> SmearingPolicy;
 | |
|     typedef MinimumNorm2<Implementation, NoSmearing<Implementation>,
 | |
|                          RepresentationsPolicy>
 | |
|         IntegratorType;  // change here to change the algorithm
 | |
|     IntegratorParameters MDpar(20, 1.0);
 | |
|     IntegratorType MDynamics(UGrid, MDpar, TheAction, SmearingPolicy);
 | |
| 
 | |
|     // Checkpoint strategy
 | |
|     int SaveInterval = 1;
 | |
|     std::string format = std::string("IEEE64BIG");
 | |
|     std::string conf_prefix = std::string("ckpoint_lat");
 | |
|     std::string rng_prefix = std::string("ckpoint_rng");
 | |
|     BinaryHmcCheckpointer<Implementation> Checkpoint(conf_prefix, rng_prefix,
 | |
|                                                      SaveInterval, format);
 | |
| 
 | |
|     HMCparameters HMCpar;
 | |
|     HMCpar.StartTrajectory = StartTraj;
 | |
|     HMCpar.Trajectories = NumTraj;
 | |
|     HMCpar.NoMetropolisUntil = NumThermalizations;
 | |
| 
 | |
|     if (StartType == HotStart) {
 | |
|       // Hot start
 | |
|       HMCpar.MetropolisTest = true;
 | |
|       sRNG.SeedFixedIntegers(SerSeed);
 | |
|       pRNG.SeedFixedIntegers(ParSeed);
 | |
|       Implementation::HotConfiguration(pRNG, U);
 | |
|     } else if (StartType == ColdStart) {
 | |
|       // Cold start
 | |
|       HMCpar.MetropolisTest = true;
 | |
|       sRNG.SeedFixedIntegers(SerSeed);
 | |
|       pRNG.SeedFixedIntegers(ParSeed);
 | |
|       Implementation::ColdConfiguration(pRNG, U);
 | |
|     } else if (StartType == TepidStart) {
 | |
|       // Tepid start
 | |
|       HMCpar.MetropolisTest = true;
 | |
|       sRNG.SeedFixedIntegers(SerSeed);
 | |
|       pRNG.SeedFixedIntegers(ParSeed);
 | |
|       Implementation::TepidConfiguration(pRNG, U);
 | |
|     } else if (StartType == CheckpointStart) {
 | |
|       HMCpar.MetropolisTest = true;
 | |
|       // CheckpointRestart
 | |
|       Checkpoint.CheckpointRestore(StartTraj, U, sRNG, pRNG);
 | |
|     }
 | |
| 
 | |
|     SmearingPolicy.set_Field(U);
 | |
| 
 | |
|     HybridMonteCarlo<IntegratorType> HMC(HMCpar, MDynamics, sRNG, pRNG, U);
 | |
|     HMC.AddObservable(&Checkpoint);
 | |
| 
 | |
|     // Run it
 | |
|     HMC.evolve();
 | |
|   }
 | |
| };
 | |
| 
 | |
| typedef BinaryHmcRunnerTemplate<PeriodicGimplR> BinaryHmcRunner;
 | |
| typedef BinaryHmcRunnerTemplate<PeriodicGimplF> BinaryHmcRunnerF;
 | |
| typedef BinaryHmcRunnerTemplate<PeriodicGimplD> BinaryHmcRunnerD;
 | |
| 
 | |
| template <class RepresentationsPolicy>
 | |
| using BinaryHmcRunnerTemplateHirep =
 | |
|     BinaryHmcRunnerTemplate<PeriodicGimplR, RepresentationsPolicy>;
 | |
| }
 | |
| }
 | |
| #endif
 |