mirror of
				https://github.com/paboyle/Grid.git
				synced 2025-10-31 12:04:33 +00:00 
			
		
		
		
	Merge branch 'feature/clover' into develop
This commit is contained in:
		
							
								
								
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -123,3 +123,9 @@ make-bin-BUCK.sh | |||||||
| ##################### | ##################### | ||||||
| lib/qcd/spin/gamma-gen/*.h | lib/qcd/spin/gamma-gen/*.h | ||||||
| lib/qcd/spin/gamma-gen/*.cc | lib/qcd/spin/gamma-gen/*.cc | ||||||
|  |  | ||||||
|  | # vs code editor files # | ||||||
|  | ######################## | ||||||
|  | .vscode/ | ||||||
|  | .vscode/settings.json | ||||||
|  | settings.json | ||||||
|   | |||||||
| @@ -44,3 +44,4 @@ script: | |||||||
|     - make -j4 |     - make -j4 | ||||||
|     - ./benchmarks/Benchmark_dwf --threads 1 --debug-signals |     - ./benchmarks/Benchmark_dwf --threads 1 --debug-signals | ||||||
|     - make check |     - make check | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Application.cc | Source file: extras/Hadrons/Application.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| @@ -43,6 +42,7 @@ using namespace Hadrons; | |||||||
| // constructors //////////////////////////////////////////////////////////////// | // constructors //////////////////////////////////////////////////////////////// | ||||||
| Application::Application(void) | Application::Application(void) | ||||||
| { | { | ||||||
|  |     initLogger(); | ||||||
|     LOG(Message) << "Modules available:" << std::endl; |     LOG(Message) << "Modules available:" << std::endl; | ||||||
|     auto list = ModuleFactory::getInstance().getBuilderList(); |     auto list = ModuleFactory::getInstance().getBuilderList(); | ||||||
|     for (auto &m: list) |     for (auto &m: list) | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Application.hpp | Source file: extras/Hadrons/Application.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Environment.cc | Source file: extras/Hadrons/Environment.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Environment.hpp | Source file: extras/Hadrons/Environment.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Exceptions.cc | Source file: extras/Hadrons/Exceptions.cc | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| @@ -54,4 +54,4 @@ CONST_EXC(Io, Runtime("IO error: " + msg, loc)) | |||||||
| CONST_EXC(Memory, Runtime("memory error: " + msg, loc)) | CONST_EXC(Memory, Runtime("memory error: " + msg, loc)) | ||||||
| CONST_EXC(Parsing, Runtime("parsing error: " + msg, loc)) | CONST_EXC(Parsing, Runtime("parsing error: " + msg, loc)) | ||||||
| CONST_EXC(Program, Runtime("program error: " + msg, loc)) | CONST_EXC(Program, Runtime("program error: " + msg, loc)) | ||||||
| CONST_EXC(System, Runtime("system error: " + msg, loc)) | CONST_EXC(System, Runtime("system error: " + msg, loc)) | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Exceptions.hpp | Source file: extras/Hadrons/Exceptions.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Factory.hpp | Source file: extras/Hadrons/Factory.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/GeneticScheduler.hpp | Source file: extras/Hadrons/GeneticScheduler.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Global.cc | Source file: extras/Hadrons/Global.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| @@ -39,6 +38,21 @@ HadronsLogger Hadrons::HadronsLogMessage(1,"Message"); | |||||||
| HadronsLogger Hadrons::HadronsLogIterative(1,"Iterative"); | HadronsLogger Hadrons::HadronsLogIterative(1,"Iterative"); | ||||||
| HadronsLogger Hadrons::HadronsLogDebug(1,"Debug"); | HadronsLogger Hadrons::HadronsLogDebug(1,"Debug"); | ||||||
|  |  | ||||||
|  | void Hadrons::initLogger(void) | ||||||
|  | { | ||||||
|  |     auto w = std::string("Hadrons").length(); | ||||||
|  |     GridLogError.setTopWidth(w); | ||||||
|  |     GridLogWarning.setTopWidth(w); | ||||||
|  |     GridLogMessage.setTopWidth(w); | ||||||
|  |     GridLogIterative.setTopWidth(w); | ||||||
|  |     GridLogDebug.setTopWidth(w); | ||||||
|  |     HadronsLogError.Active(GridLogError.isActive()); | ||||||
|  |     HadronsLogWarning.Active(GridLogWarning.isActive()); | ||||||
|  |     HadronsLogMessage.Active(GridLogMessage.isActive()); | ||||||
|  |     HadronsLogIterative.Active(GridLogIterative.isActive()); | ||||||
|  |     HadronsLogDebug.Active(GridLogDebug.isActive()); | ||||||
|  | } | ||||||
|  |  | ||||||
| // type utilities ////////////////////////////////////////////////////////////// | // type utilities ////////////////////////////////////////////////////////////// | ||||||
| constexpr unsigned int maxNameSize = 1024u; | constexpr unsigned int maxNameSize = 1024u; | ||||||
|  |  | ||||||
| @@ -53,3 +67,10 @@ std::string Hadrons::typeName(const std::type_info *info) | |||||||
|      |      | ||||||
|     return name; |     return name; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // default writers/readers ///////////////////////////////////////////////////// | ||||||
|  | #ifdef HAVE_HDF5 | ||||||
|  | const std::string Hadrons::resultFileExt = "h5"; | ||||||
|  | #else | ||||||
|  | const std::string Hadrons::resultFileExt = "xml"; | ||||||
|  | #endif | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Global.hpp | Source file: extras/Hadrons/Global.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -61,6 +61,9 @@ using Grid::operator<<; | |||||||
| #ifndef SIMPL | #ifndef SIMPL | ||||||
| #define SIMPL ScalarImplCR | #define SIMPL ScalarImplCR | ||||||
| #endif | #endif | ||||||
|  | #ifndef GIMPL | ||||||
|  | #define GIMPL GimplTypesR | ||||||
|  | #endif | ||||||
|  |  | ||||||
| BEGIN_HADRONS_NAMESPACE | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
| @@ -84,7 +87,8 @@ typedef std::function<void(FermionField##suffix &,\ | |||||||
|                       const FermionField##suffix &)> SolverFn##suffix; |                       const FermionField##suffix &)> SolverFn##suffix; | ||||||
|  |  | ||||||
| #define SINK_TYPE_ALIASES(suffix)\ | #define SINK_TYPE_ALIASES(suffix)\ | ||||||
| typedef std::function<SlicedPropagator##suffix(const PropagatorField##suffix &)> SinkFn##suffix; | typedef std::function<SlicedPropagator##suffix\ | ||||||
|  |                       (const PropagatorField##suffix &)> SinkFn##suffix; | ||||||
|  |  | ||||||
| #define FGS_TYPE_ALIASES(FImpl, suffix)\ | #define FGS_TYPE_ALIASES(FImpl, suffix)\ | ||||||
| FERM_TYPE_ALIASES(FImpl, suffix)\ | FERM_TYPE_ALIASES(FImpl, suffix)\ | ||||||
| @@ -108,6 +112,8 @@ extern HadronsLogger HadronsLogMessage; | |||||||
| extern HadronsLogger HadronsLogIterative; | extern HadronsLogger HadronsLogIterative; | ||||||
| extern HadronsLogger HadronsLogDebug; | extern HadronsLogger HadronsLogDebug; | ||||||
|  |  | ||||||
|  | void initLogger(void); | ||||||
|  |  | ||||||
| // singleton pattern | // singleton pattern | ||||||
| #define SINGLETON(name)\ | #define SINGLETON(name)\ | ||||||
| public:\ | public:\ | ||||||
| @@ -161,14 +167,19 @@ std::string typeName(void) | |||||||
| } | } | ||||||
|  |  | ||||||
| // default writers/readers | // default writers/readers | ||||||
|  | extern const std::string resultFileExt; | ||||||
|  |  | ||||||
| #ifdef HAVE_HDF5 | #ifdef HAVE_HDF5 | ||||||
| typedef Hdf5Reader CorrReader; | typedef Hdf5Reader ResultReader; | ||||||
| typedef Hdf5Writer CorrWriter; | typedef Hdf5Writer ResultWriter; | ||||||
| #else | #else | ||||||
| typedef XmlReader CorrReader; | typedef XmlReader ResultReader; | ||||||
| typedef XmlWriter CorrWriter; | typedef XmlWriter ResultWriter; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define RESULT_FILE_NAME(name) \ | ||||||
|  | name + "." + std::to_string(vm().getTrajectory()) + "." + resultFileExt | ||||||
|  |  | ||||||
| END_HADRONS_NAMESPACE | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
| #include <Grid/Hadrons/Exceptions.hpp> | #include <Grid/Hadrons/Exceptions.hpp> | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Graph.hpp | Source file: extras/Hadrons/Graph.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/HadronsXmlRun.cc | Source file: extras/Hadrons/HadronsXmlRun.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| @@ -55,12 +54,6 @@ int main(int argc, char *argv[]) | |||||||
|      |      | ||||||
|     // initialization |     // initialization | ||||||
|     Grid_init(&argc, &argv); |     Grid_init(&argc, &argv); | ||||||
|     HadronsLogError.Active(GridLogError.isActive()); |  | ||||||
|     HadronsLogWarning.Active(GridLogWarning.isActive()); |  | ||||||
|     HadronsLogMessage.Active(GridLogMessage.isActive()); |  | ||||||
|     HadronsLogIterative.Active(GridLogIterative.isActive()); |  | ||||||
|     HadronsLogDebug.Active(GridLogDebug.isActive()); |  | ||||||
|     LOG(Message) << "Grid initialized" << std::endl; |  | ||||||
|      |      | ||||||
|     // execution |     // execution | ||||||
|     Application application(parameterFileName); |     Application application(parameterFileName); | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/HadronsXmlSchedule.cc | Source file: extras/Hadrons/HadronsXmlSchedule.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| @@ -49,12 +48,6 @@ int main(int argc, char *argv[]) | |||||||
|      |      | ||||||
|     // initialization |     // initialization | ||||||
|     Grid_init(&argc, &argv); |     Grid_init(&argc, &argv); | ||||||
|     HadronsLogError.Active(GridLogError.isActive()); |  | ||||||
|     HadronsLogWarning.Active(GridLogWarning.isActive()); |  | ||||||
|     HadronsLogMessage.Active(GridLogMessage.isActive()); |  | ||||||
|     HadronsLogIterative.Active(GridLogIterative.isActive()); |  | ||||||
|     HadronsLogDebug.Active(GridLogDebug.isActive()); |  | ||||||
|     LOG(Message) << "Grid initialized" << std::endl; |  | ||||||
|      |      | ||||||
|     // execution |     // execution | ||||||
|     Application application; |     Application application; | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Module.cc | Source file: extras/Hadrons/Module.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Module.hpp | Source file: extras/Hadrons/Module.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/ModuleFactory.hpp | Source file: extras/Hadrons/ModuleFactory.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,11 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules.hpp | Source file: extras/Hadrons/Modules.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| Copyright (C) 2017 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -27,7 +26,6 @@ with this program; if not, write to the Free Software Foundation, Inc., | |||||||
| See the full license in the file "LICENSE" in the top level distribution directory | See the full license in the file "LICENSE" in the top level distribution directory | ||||||
| *************************************************************************************/ | *************************************************************************************/ | ||||||
| /*  END LEGAL */ | /*  END LEGAL */ | ||||||
|  |  | ||||||
| #include <Grid/Hadrons/Modules/MContraction/Baryon.hpp> | #include <Grid/Hadrons/Modules/MContraction/Baryon.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MContraction/Meson.hpp> | #include <Grid/Hadrons/Modules/MContraction/Meson.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MContraction/WeakHamiltonian.hpp> | #include <Grid/Hadrons/Modules/MContraction/WeakHamiltonian.hpp> | ||||||
| @@ -46,10 +44,10 @@ See the full license in the file "LICENSE" in the top level distribution directo | |||||||
| #include <Grid/Hadrons/Modules/MSink/Smear.hpp> | #include <Grid/Hadrons/Modules/MSink/Smear.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MSink/Point.hpp> | #include <Grid/Hadrons/Modules/MSink/Point.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MSolver/RBPrecCG.hpp> | #include <Grid/Hadrons/Modules/MSolver/RBPrecCG.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MGauge/Load.hpp> |  | ||||||
| #include <Grid/Hadrons/Modules/MGauge/Unit.hpp> | #include <Grid/Hadrons/Modules/MGauge/Unit.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MGauge/Random.hpp> | #include <Grid/Hadrons/Modules/MGauge/Random.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MGauge/StochEm.hpp> | #include <Grid/Hadrons/Modules/MGauge/StochEm.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MGauge/FundtoHirep.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MUtilities/TestSeqGamma.hpp> | #include <Grid/Hadrons/Modules/MUtilities/TestSeqGamma.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MUtilities/TestSeqConserved.hpp> | #include <Grid/Hadrons/Modules/MUtilities/TestSeqConserved.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MLoop/NoiseLoop.hpp> | #include <Grid/Hadrons/Modules/MLoop/NoiseLoop.hpp> | ||||||
| @@ -58,3 +56,9 @@ See the full license in the file "LICENSE" in the top level distribution directo | |||||||
| #include <Grid/Hadrons/Modules/MScalar/ChargedProp.hpp> | #include <Grid/Hadrons/Modules/MScalar/ChargedProp.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MAction/DWF.hpp> | #include <Grid/Hadrons/Modules/MAction/DWF.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MAction/Wilson.hpp> | #include <Grid/Hadrons/Modules/MAction/Wilson.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MAction/WilsonClover.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MScalarSUN/TrMag.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MScalarSUN/TwoPoint.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MScalarSUN/TrPhi.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MIO/LoadNersc.hpp> | ||||||
|  | #include <Grid/Hadrons/Modules/MIO/LoadBinary.hpp> | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MAction/DWF.hpp | Source file: extras/Hadrons/Modules/MAction/DWF.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MAction/Wilson.hpp | Source file: extras/Hadrons/Modules/MAction/Wilson.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
							
								
								
									
										153
									
								
								extras/Hadrons/Modules/MAction/WilsonClover.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								extras/Hadrons/Modules/MAction/WilsonClover.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MAction/Wilson.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015 | ||||||
|  | Copyright (C) 2016 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MAction_WilsonClover_hpp_ | ||||||
|  | #define Hadrons_MAction_WilsonClover_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                            TWilson quark action                            * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MAction) | ||||||
|  |  | ||||||
|  | class WilsonCloverPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(WilsonCloverPar, | ||||||
|  |                                     std::string, gauge, | ||||||
|  |                                     double     , mass, | ||||||
|  | 				                    double     , csw_r, | ||||||
|  | 				                    double     , csw_t, | ||||||
|  | 				                    WilsonAnisotropyCoefficients ,clover_anisotropy, | ||||||
|  |                                     std::string, boundary | ||||||
|  | 				    ); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <typename FImpl> | ||||||
|  | class TWilsonClover: public Module<WilsonCloverPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     FGS_TYPE_ALIASES(FImpl,); | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TWilsonClover(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TWilsonClover(void) = default; | ||||||
|  |     // dependencies/products | ||||||
|  |     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(WilsonClover, TWilsonClover<FIMPL>, MAction); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                     TWilsonClover template implementation                        * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <typename FImpl> | ||||||
|  | TWilsonClover<FImpl>::TWilsonClover(const std::string name) | ||||||
|  | : Module<WilsonCloverPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <typename FImpl> | ||||||
|  | std::vector<std::string> TWilsonClover<FImpl>::getInput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> in = {par().gauge}; | ||||||
|  |  | ||||||
|  |     return in; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <typename FImpl> | ||||||
|  | std::vector<std::string> TWilsonClover<FImpl>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out = {getName()}; | ||||||
|  |  | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename FImpl> | ||||||
|  | void TWilsonClover<FImpl>::setup(void) | ||||||
|  | { | ||||||
|  |     //unsigned int size; | ||||||
|  |  | ||||||
|  |     // size = 2*env().template lattice4dSize<typename FImpl::DoubledGaugeField>(); | ||||||
|  |     // env().registerObject(getName(), size); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     LOG(Message) << "Setting up TWilsonClover fermion matrix with m= " << par().mass | ||||||
|  |                  << " using gauge field '" << par().gauge << "'" << std::endl; | ||||||
|  |     LOG(Message) << "Fermion boundary conditions: " << par().boundary  | ||||||
|  |                  << std::endl; | ||||||
|  |     LOG(Message) << "Clover term csw_r: " << par().csw_r | ||||||
|  |                  << " csw_t: " << par().csw_t | ||||||
|  |                  << std::endl; | ||||||
|  |     auto &U      = envGet(LatticeGaugeField, par().gauge); | ||||||
|  |     auto &grid   = *env().getGrid(); | ||||||
|  |     auto &gridRb = *env().getRbGrid(); | ||||||
|  |     std::vector<Complex> boundary = strToVec<Complex>(par().boundary); | ||||||
|  |     typename WilsonCloverFermion<FImpl>::ImplParams implParams(boundary); | ||||||
|  |     envCreateDerived(FMat, WilsonCloverFermion<FImpl>, getName(), 1, U, grid, gridRb, par().mass, | ||||||
|  | 						  par().csw_r, | ||||||
|  | 						  par().csw_t, | ||||||
|  | 					      par().clover_anisotropy, | ||||||
|  | 						  implParams);  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     //FMat *fMatPt = new WilsonCloverFermion<FImpl>(U, grid, gridRb, par().mass, | ||||||
|  | 	//					  par().csw_r, | ||||||
|  | 	//					  par().csw_t, | ||||||
|  | 	//				      par().clover_anisotropy, | ||||||
|  | 	//					  implParams); | ||||||
|  |     //env().setObject(getName(), fMatPt); | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename FImpl> | ||||||
|  | void TWilsonClover<FImpl>::execute() | ||||||
|  | { | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_WilsonClover_hpp_ | ||||||
| @@ -4,10 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/Baryon.hpp | Source file: extras/Hadrons/Modules/MContraction/Baryon.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -122,7 +122,7 @@ void TBaryon<FImpl1, FImpl2, FImpl3>::execute(void) | |||||||
|                  << " quarks '" << par().q1 << "', '" << par().q2 << "', and '" |                  << " quarks '" << par().q1 << "', '" << par().q2 << "', and '" | ||||||
|                  << par().q3 << "'" << std::endl; |                  << par().q3 << "'" << std::endl; | ||||||
|      |      | ||||||
|     CorrWriter writer(par().output); |     ResultWriter writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto       &q1 = envGet(PropagatorField1, par().q1); |     auto       &q1 = envGet(PropagatorField1, par().q1); | ||||||
|     auto       &q2 = envGet(PropagatorField2, par().q2); |     auto       &q2 = envGet(PropagatorField2, par().q2); | ||||||
|     auto       &q3 = envGet(PropagatorField3, par().q2); |     auto       &q3 = envGet(PropagatorField3, par().q2); | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/DiscLoop.hpp | Source file: extras/Hadrons/Modules/MContraction/DiscLoop.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -118,7 +119,7 @@ void TDiscLoop<FImpl>::execute(void) | |||||||
|                  << "' using '" << par().q_loop << "' with " << par().gamma  |                  << "' using '" << par().q_loop << "' with " << par().gamma  | ||||||
|                  << " insertion." << std::endl; |                  << " insertion." << std::endl; | ||||||
|  |  | ||||||
|     CorrWriter            writer(par().output); |     ResultWriter          writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto                  &q_loop = envGet(PropagatorField, par().q_loop); |     auto                  &q_loop = envGet(PropagatorField, par().q_loop); | ||||||
|     Gamma                 gamma(par().gamma); |     Gamma                 gamma(par().gamma); | ||||||
|     std::vector<TComplex> buf; |     std::vector<TComplex> buf; | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/Gamma3pt.hpp | Source file: extras/Hadrons/Modules/MContraction/Gamma3pt.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -152,7 +153,7 @@ void TGamma3pt<FImpl1, FImpl2, FImpl3>::execute(void) | |||||||
|  |  | ||||||
|     // Initialise variables. q2 and q3 are normal propagators, q1 may be  |     // Initialise variables. q2 and q3 are normal propagators, q1 may be  | ||||||
|     // sink smeared. |     // sink smeared. | ||||||
|     CorrWriter            writer(par().output); |     ResultWriter          writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto                  &q1 = envGet(SlicedPropagator1, par().q1); |     auto                  &q1 = envGet(SlicedPropagator1, par().q1); | ||||||
|     auto                  &q2 = envGet(PropagatorField2, par().q2); |     auto                  &q2 = envGet(PropagatorField2, par().q2); | ||||||
|     auto                  &q3 = envGet(PropagatorField2, par().q3); |     auto                  &q3 = envGet(PropagatorField2, par().q3); | ||||||
|   | |||||||
| @@ -4,12 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/Meson.hpp | Source file: extras/Hadrons/Modules/MContraction/Meson.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| Copyright (C) 2017 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|         Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -173,8 +171,8 @@ void TMeson<FImpl1, FImpl2>::execute(void) | |||||||
|     LOG(Message) << "Computing meson contractions '" << getName() << "' using" |     LOG(Message) << "Computing meson contractions '" << getName() << "' using" | ||||||
|                  << " quarks '" << par().q1 << "' and '" << par().q2 << "'" |                  << " quarks '" << par().q1 << "' and '" << par().q2 << "'" | ||||||
|                  << std::endl; |                  << std::endl; | ||||||
|      |  | ||||||
|     CorrWriter             writer(par().output); |     ResultWriter           writer(RESULT_FILE_NAME(par().output)); | ||||||
|     std::vector<TComplex>  buf; |     std::vector<TComplex>  buf; | ||||||
|     std::vector<Result>    result; |     std::vector<Result>    result; | ||||||
|     Gamma                  g5(Gamma::Algebra::Gamma5); |     Gamma                  g5(Gamma::Algebra::Gamma5); | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WardIdentity.hpp | Source file: extras/Hadrons/Modules/MContraction/WardIdentity.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonian.hpp | Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonian.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianEye.cc | Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianEye.cc | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -103,7 +104,7 @@ void TWeakHamiltonianEye::execute(void) | |||||||
|                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  |                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  | ||||||
|                  << "'." << std::endl; |                  << "'." << std::endl; | ||||||
|  |  | ||||||
|     CorrWriter             writer(par().output); |     ResultWriter           writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto                   &q1 = envGet(SlicedPropagator, par().q1); |     auto                   &q1 = envGet(SlicedPropagator, par().q1); | ||||||
|     auto                   &q2 = envGet(PropagatorField, par().q2); |     auto                   &q2 = envGet(PropagatorField, par().q2); | ||||||
|     auto                   &q3 = envGet(PropagatorField, par().q3); |     auto                   &q3 = envGet(PropagatorField, par().q3); | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianEye.hpp | Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianEye.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianNonEye.cc | Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianNonEye.cc | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -103,7 +104,7 @@ void TWeakHamiltonianNonEye::execute(void) | |||||||
|                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  |                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  | ||||||
|                  << "'." << std::endl; |                  << "'." << std::endl; | ||||||
|      |      | ||||||
|     CorrWriter            writer(par().output); |     ResultWriter          writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto                  &q1 = envGet(PropagatorField, par().q1); |     auto                  &q1 = envGet(PropagatorField, par().q1); | ||||||
|     auto                  &q2 = envGet(PropagatorField, par().q2); |     auto                  &q2 = envGet(PropagatorField, par().q2); | ||||||
|     auto                  &q3 = envGet(PropagatorField, par().q3); |     auto                  &q3 = envGet(PropagatorField, par().q3); | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianNonEye.hpp | Source file: extras/Hadrons/Modules/MContraction/WeakHamiltonianNonEye.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakNeutral4ptDisc.cc | Source file: extras/Hadrons/Modules/MContraction/WeakNeutral4ptDisc.cc | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -103,7 +104,7 @@ void TWeakNeutral4ptDisc::execute(void) | |||||||
|                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  |                  << par().q2 << ", '" << par().q3 << "' and '" << par().q4  | ||||||
|                  << "'." << std::endl; |                  << "'." << std::endl; | ||||||
|  |  | ||||||
|     CorrWriter            writer(par().output); |     ResultWriter          writer(RESULT_FILE_NAME(par().output)); | ||||||
|     auto                  &q1 = envGet(PropagatorField, par().q1); |     auto                  &q1 = envGet(PropagatorField, par().q1); | ||||||
|     auto                  &q2 = envGet(PropagatorField, par().q2); |     auto                  &q2 = envGet(PropagatorField, par().q2); | ||||||
|     auto                  &q3 = envGet(PropagatorField, par().q3); |     auto                  &q3 = envGet(PropagatorField, par().q3); | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/WeakNeutral4ptDisc.hpp | Source file: extras/Hadrons/Modules/MContraction/WeakNeutral4ptDisc.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,12 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MFermion/GaugeProp.hpp | Source file: extras/Hadrons/Modules/MFermion/GaugeProp.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| Copyright (C) 2017 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|         Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
| @@ -96,7 +94,6 @@ private: | |||||||
| }; | }; | ||||||
|  |  | ||||||
| MODULE_REGISTER_NS(GaugeProp, TGaugeProp<FIMPL>, MFermion); | MODULE_REGISTER_NS(GaugeProp, TGaugeProp<FIMPL>, MFermion); | ||||||
|  |  | ||||||
| /****************************************************************************** | /****************************************************************************** | ||||||
|  *                      TGaugeProp implementation                             * |  *                      TGaugeProp implementation                             * | ||||||
|  ******************************************************************************/ |  ******************************************************************************/ | ||||||
| @@ -156,7 +153,7 @@ void TGaugeProp<FImpl>::execute(void) | |||||||
|     LOG(Message) << "Inverting using solver '" << par().solver |     LOG(Message) << "Inverting using solver '" << par().solver | ||||||
|                  << "' on source '" << par().source << "'" << std::endl; |                  << "' on source '" << par().source << "'" << std::endl; | ||||||
|     for (unsigned int s = 0; s < Ns; ++s) |     for (unsigned int s = 0; s < Ns; ++s) | ||||||
|     for (unsigned int c = 0; c < Nc; ++c) |       for (unsigned int c = 0; c < FImpl::Dimension; ++c) | ||||||
|     { |     { | ||||||
|         LOG(Message) << "Inversion for spin= " << s << ", color= " << c |         LOG(Message) << "Inversion for spin= " << s << ", color= " << c | ||||||
|                      << std::endl; |                      << std::endl; | ||||||
| @@ -165,11 +162,11 @@ void TGaugeProp<FImpl>::execute(void) | |||||||
|         { |         { | ||||||
|             if (Ls_ == 1) |             if (Ls_ == 1) | ||||||
|             { |             { | ||||||
|                 PropToFerm(source, fullSrc, s, c); |                PropToFerm<FImpl>(source, fullSrc, s, c); | ||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 PropToFerm(tmp, fullSrc, s, c); |                 PropToFerm<FImpl>(tmp, fullSrc, s, c); | ||||||
|                 make_5D(tmp, source, Ls_); |                 make_5D(tmp, source, Ls_); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @@ -182,18 +179,18 @@ void TGaugeProp<FImpl>::execute(void) | |||||||
|             } |             } | ||||||
|             else |             else | ||||||
|             { |             { | ||||||
|                 PropToFerm(source, fullSrc, s, c); |                 PropToFerm<FImpl>(source, fullSrc, s, c); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         sol = zero; |         sol = zero; | ||||||
|         solver(sol, source); |         solver(sol, source); | ||||||
|         FermToProp(prop, sol, s, c); |         FermToProp<FImpl>(prop, sol, s, c); | ||||||
|         // create 4D propagators from 5D one if necessary |         // create 4D propagators from 5D one if necessary | ||||||
|         if (Ls_ > 1) |         if (Ls_ > 1) | ||||||
|         { |         { | ||||||
|             PropagatorField &p4d = envGet(PropagatorField, getName()); |             PropagatorField &p4d = envGet(PropagatorField, getName()); | ||||||
|             make_4D(sol, tmp, Ls_); |             make_4D(sol, tmp, Ls_); | ||||||
|             FermToProp(p4d, tmp, s, c); |             FermToProp<FImpl>(p4d, tmp, s, c); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										75
									
								
								extras/Hadrons/Modules/MGauge/FundtoHirep.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								extras/Hadrons/Modules/MGauge/FundtoHirep.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MGauge/FundtoHirep.cc | ||||||
|  |  | ||||||
|  | Copyright (C) 2015 | ||||||
|  | Copyright (C) 2016 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 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 */ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Modules/MGauge/FundtoHirep.hpp> | ||||||
|  |  | ||||||
|  | using namespace Grid; | ||||||
|  | using namespace Hadrons; | ||||||
|  | using namespace MGauge; | ||||||
|  |  | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <class Rep> | ||||||
|  | TFundtoHirep<Rep>::TFundtoHirep(const std::string name) | ||||||
|  | : Module<FundtoHirepPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <class Rep> | ||||||
|  | std::vector<std::string> TFundtoHirep<Rep>::getInput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> in; | ||||||
|  |     return in; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Rep> | ||||||
|  | std::vector<std::string> TFundtoHirep<Rep>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out = {getName()}; | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename Rep> | ||||||
|  | void TFundtoHirep<Rep>::setup(void) | ||||||
|  | { | ||||||
|  |     env().template registerLattice<typename Rep::LatticeField>(getName()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <class Rep> | ||||||
|  | void TFundtoHirep<Rep>::execute(void) | ||||||
|  | { | ||||||
|  |     auto &U      = *env().template getObject<LatticeGaugeField>(par().gaugeconf); | ||||||
|  |     LOG(Message) << "Transforming Representation" << std::endl; | ||||||
|  |  | ||||||
|  |     Rep TargetRepresentation(U._grid); | ||||||
|  |     TargetRepresentation.update_representation(U); | ||||||
|  |  | ||||||
|  |    typename Rep::LatticeField &URep = *env().template createLattice<typename Rep::LatticeField>(getName()); | ||||||
|  |     URep = TargetRepresentation.U; | ||||||
|  | } | ||||||
							
								
								
									
										77
									
								
								extras/Hadrons/Modules/MGauge/FundtoHirep.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								extras/Hadrons/Modules/MGauge/FundtoHirep.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MGauge/FundtoHirep.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015 | ||||||
|  | Copyright (C) 2016 | ||||||
|  |  | ||||||
|  | Author: David Preti <david.preti@to.infn.it> | ||||||
|  | 	Guido Cossu <guido.cossu@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 Hadrons_MGauge_FundtoHirep_hpp_ | ||||||
|  | #define Hadrons_MGauge_FundtoHirep_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                         Load a NERSC configuration                         * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MGauge) | ||||||
|  |  | ||||||
|  | class FundtoHirepPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(FundtoHirepPar, | ||||||
|  |                                     std::string, gaugeconf); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <class Rep> | ||||||
|  | class TFundtoHirep: public Module<FundtoHirepPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TFundtoHirep(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TFundtoHirep(void) = default; | ||||||
|  |     // dependency relation | ||||||
|  |     virtual std::vector<std::string> getInput(void); | ||||||
|  |     virtual std::vector<std::string> getOutput(void); | ||||||
|  |     // setup | ||||||
|  |     void setup(void); | ||||||
|  |     // execution | ||||||
|  |     void execute(void); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | //MODULE_REGISTER_NS(FundtoAdjoint,   TFundtoHirep<AdjointRepresentation>, MGauge); | ||||||
|  | //MODULE_REGISTER_NS(FundtoTwoIndexSym, TFundtoHirep<TwoIndexSymmetricRepresentation>, MGauge); | ||||||
|  | //MODULE_REGISTER_NS(FundtoTwoIndexAsym, TFundtoHirep<TwoIndexAntiSymmetricRepresentation>, MGauge); | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_MGauge_FundtoHirep_hpp_ | ||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Random.cc | Source file: extras/Hadrons/Modules/MGauge/Random.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Random.hpp | Source file: extras/Hadrons/Modules/MGauge/Random.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,9 +4,9 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/StochEm.cc | Source file: extras/Hadrons/Modules/MGauge/StochEm.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,9 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/StochEm.hpp | Source file: extras/Hadrons/Modules/MGauge/StochEm.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Unit.cc | Source file: extras/Hadrons/Modules/MGauge/Unit.cc | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Unit.hpp | Source file: extras/Hadrons/Modules/MGauge/Unit.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										140
									
								
								extras/Hadrons/Modules/MIO/LoadBinary.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										140
									
								
								extras/Hadrons/Modules/MIO/LoadBinary.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,140 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MIO/LoadBinary.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MIO_LoadBinary_hpp_ | ||||||
|  | #define Hadrons_MIO_LoadBinary_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                       Load a binary configurations                         * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MIO) | ||||||
|  |  | ||||||
|  | class LoadBinaryPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(LoadBinaryPar, | ||||||
|  |                                     std::string, file, | ||||||
|  |                                     std::string, format); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <typename Impl> | ||||||
|  | class TLoadBinary: public Module<LoadBinaryPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef typename Impl::Field                  Field; | ||||||
|  |     typedef typename Impl::Simd                   Simd; | ||||||
|  |     typedef typename Field::vector_object         vobj; | ||||||
|  |     typedef typename vobj::scalar_object          sobj; | ||||||
|  |     typedef typename sobj::DoublePrecision        sobj_double; | ||||||
|  |     typedef BinarySimpleMunger<sobj_double, sobj> Munger; | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TLoadBinary(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TLoadBinary(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(LoadBinary, TLoadBinary<GIMPL>, MIO); | ||||||
|  | MODULE_REGISTER_NS(LoadBinaryScalarSU2, TLoadBinary<ScalarNxNAdjImplR<2>>, MIO); | ||||||
|  | MODULE_REGISTER_NS(LoadBinaryScalarSU3, TLoadBinary<ScalarNxNAdjImplR<3>>, MIO); | ||||||
|  | MODULE_REGISTER_NS(LoadBinaryScalarSU4, TLoadBinary<ScalarNxNAdjImplR<4>>, MIO); | ||||||
|  | MODULE_REGISTER_NS(LoadBinaryScalarSU5, TLoadBinary<ScalarNxNAdjImplR<5>>, MIO); | ||||||
|  | MODULE_REGISTER_NS(LoadBinaryScalarSU6, TLoadBinary<ScalarNxNAdjImplR<6>>, MIO); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                         TLoadBinary implementation                         * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <typename Impl> | ||||||
|  | TLoadBinary<Impl>::TLoadBinary(const std::string name) | ||||||
|  | : Module<LoadBinaryPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <typename Impl> | ||||||
|  | std::vector<std::string> TLoadBinary<Impl>::getInput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> in; | ||||||
|  |      | ||||||
|  |     return in; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <typename Impl> | ||||||
|  | std::vector<std::string> TLoadBinary<Impl>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out = {getName()}; | ||||||
|  |      | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename Impl> | ||||||
|  | void TLoadBinary<Impl>::setup(void) | ||||||
|  | { | ||||||
|  |     envCreateLat(Field, getName()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename Impl> | ||||||
|  | void TLoadBinary<Impl>::execute(void) | ||||||
|  | { | ||||||
|  |     Munger      munge; | ||||||
|  |     uint32_t    nersc_csum, scidac_csuma, scidac_csumb; | ||||||
|  |     auto        &U = envGet(Field, getName()); | ||||||
|  |     std::string filename = par().file + "." | ||||||
|  |                            + std::to_string(vm().getTrajectory()); | ||||||
|  |  | ||||||
|  |     LOG(Message) << "Loading " << par().format  | ||||||
|  |                  << " binary configuration from file '" << filename | ||||||
|  |                  << "'" << std::endl; | ||||||
|  |     BinaryIO::readLatticeObject<vobj, sobj_double>(U, filename, munge, 0,  | ||||||
|  |                                                    par().format, nersc_csum, | ||||||
|  |                                                    scidac_csuma, scidac_csumb); | ||||||
|  |     LOG(Message) << "Checksums:" << std::endl; | ||||||
|  |     LOG(Message) << "  NERSC    " << nersc_csum << std::endl; | ||||||
|  |     LOG(Message) << "  SciDAC A " << scidac_csuma << std::endl; | ||||||
|  |     LOG(Message) << "  SciDAC B " << scidac_csumb << std::endl; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_MIO_LoadBinary_hpp_ | ||||||
| @@ -2,10 +2,9 @@ | |||||||
| 
 | 
 | ||||||
| Grid physics library, www.github.com/paboyle/Grid  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
| 
 | 
 | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Load.cc | Source file: extras/Hadrons/Modules/MIO/LoadNersc.cc | ||||||
| 
 | 
 | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| 
 | 
 | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
| 
 | 
 | ||||||
| @@ -26,30 +25,29 @@ with this program; if not, write to the Free Software Foundation, Inc., | |||||||
| See the full license in the file "LICENSE" in the top level distribution directory | See the full license in the file "LICENSE" in the top level distribution directory | ||||||
| *************************************************************************************/ | *************************************************************************************/ | ||||||
| /*  END LEGAL */ | /*  END LEGAL */ | ||||||
| 
 | #include <Grid/Hadrons/Modules/MIO/LoadNersc.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MGauge/Load.hpp> |  | ||||||
| 
 | 
 | ||||||
| using namespace Grid; | using namespace Grid; | ||||||
| using namespace Hadrons; | using namespace Hadrons; | ||||||
| using namespace MGauge; | using namespace MIO; | ||||||
| 
 | 
 | ||||||
| /******************************************************************************
 | /******************************************************************************
 | ||||||
| *                           TLoad implementation                               * | *                       TLoadNersc implementation                             * | ||||||
| ******************************************************************************/ | ******************************************************************************/ | ||||||
| // constructor /////////////////////////////////////////////////////////////////
 | // constructor /////////////////////////////////////////////////////////////////
 | ||||||
| TLoad::TLoad(const std::string name) | TLoadNersc::TLoadNersc(const std::string name) | ||||||
| : Module<LoadPar>(name) | : Module<LoadNerscPar>(name) | ||||||
| {} | {} | ||||||
| 
 | 
 | ||||||
| // dependencies/products ///////////////////////////////////////////////////////
 | // dependencies/products ///////////////////////////////////////////////////////
 | ||||||
| std::vector<std::string> TLoad::getInput(void) | std::vector<std::string> TLoadNersc::getInput(void) | ||||||
| { | { | ||||||
|     std::vector<std::string> in; |     std::vector<std::string> in; | ||||||
|      |      | ||||||
|     return in; |     return in; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::vector<std::string> TLoad::getOutput(void) | std::vector<std::string> TLoadNersc::getOutput(void) | ||||||
| { | { | ||||||
|     std::vector<std::string> out = {getName()}; |     std::vector<std::string> out = {getName()}; | ||||||
|      |      | ||||||
| @@ -57,13 +55,13 @@ std::vector<std::string> TLoad::getOutput(void) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // setup ///////////////////////////////////////////////////////////////////////
 | // setup ///////////////////////////////////////////////////////////////////////
 | ||||||
| void TLoad::setup(void) | void TLoadNersc::setup(void) | ||||||
| { | { | ||||||
|     envCreateLat(LatticeGaugeField, getName()); |     envCreateLat(LatticeGaugeField, getName()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // execution ///////////////////////////////////////////////////////////////////
 | // execution ///////////////////////////////////////////////////////////////////
 | ||||||
| void TLoad::execute(void) | void TLoadNersc::execute(void) | ||||||
| { | { | ||||||
|     FieldMetaData header; |     FieldMetaData header; | ||||||
|     std::string   fileName = par().file + "." |     std::string   fileName = par().file + "." | ||||||
| @@ -2,10 +2,9 @@ | |||||||
| 
 | 
 | ||||||
| Grid physics library, www.github.com/paboyle/Grid  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
| 
 | 
 | ||||||
| Source file: extras/Hadrons/Modules/MGauge/Load.hpp | Source file: extras/Hadrons/Modules/MIO/LoadNersc.hpp | ||||||
| 
 | 
 | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| 
 | 
 | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
| 
 | 
 | ||||||
| @@ -26,9 +25,8 @@ with this program; if not, write to the Free Software Foundation, Inc., | |||||||
| See the full license in the file "LICENSE" in the top level distribution directory | See the full license in the file "LICENSE" in the top level distribution directory | ||||||
| *************************************************************************************/ | *************************************************************************************/ | ||||||
| /*  END LEGAL */ | /*  END LEGAL */ | ||||||
| 
 | #ifndef Hadrons_MIO_LoadNersc_hpp_ | ||||||
| #ifndef Hadrons_MGauge_Load_hpp_ | #define Hadrons_MIO_LoadNersc_hpp_ | ||||||
| #define Hadrons_MGauge_Load_hpp_ |  | ||||||
| 
 | 
 | ||||||
| #include <Grid/Hadrons/Global.hpp> | #include <Grid/Hadrons/Global.hpp> | ||||||
| #include <Grid/Hadrons/Module.hpp> | #include <Grid/Hadrons/Module.hpp> | ||||||
| @@ -37,38 +35,37 @@ See the full license in the file "LICENSE" in the top level distribution directo | |||||||
| BEGIN_HADRONS_NAMESPACE | BEGIN_HADRONS_NAMESPACE | ||||||
| 
 | 
 | ||||||
| /******************************************************************************
 | /******************************************************************************
 | ||||||
|  *                         Load a NERSC configuration                         * |  *                       Load a NERSC configuration                           * | ||||||
|  ******************************************************************************/ |  ******************************************************************************/ | ||||||
| BEGIN_MODULE_NAMESPACE(MGauge) | BEGIN_MODULE_NAMESPACE(MIO) | ||||||
| 
 | 
 | ||||||
| class LoadPar: Serializable | class LoadNerscPar: Serializable | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     GRID_SERIALIZABLE_CLASS_MEMBERS(LoadPar, |     GRID_SERIALIZABLE_CLASS_MEMBERS(LoadNerscPar, | ||||||
|                                     std::string, file); |                                     std::string, file); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class TLoad: public Module<LoadPar> | class TLoadNersc: public Module<LoadNerscPar> | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     // constructor
 |     // constructor
 | ||||||
|     TLoad(const std::string name); |     TLoadNersc(const std::string name); | ||||||
|     // destructor
 |     // destructor
 | ||||||
|     virtual ~TLoad(void) = default; |     virtual ~TLoadNersc(void) = default; | ||||||
|     // dependency relation
 |     // dependency relation
 | ||||||
|     virtual std::vector<std::string> getInput(void); |     virtual std::vector<std::string> getInput(void); | ||||||
|     virtual std::vector<std::string> getOutput(void); |     virtual std::vector<std::string> getOutput(void); | ||||||
| protected: |  | ||||||
|     // setup
 |     // setup
 | ||||||
|     virtual void setup(void); |     virtual void setup(void); | ||||||
|     // execution
 |     // execution
 | ||||||
|     virtual void execute(void); |     virtual void execute(void); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| MODULE_REGISTER_NS(Load, TLoad, MGauge); | MODULE_REGISTER_NS(LoadNersc, TLoadNersc, MIO); | ||||||
| 
 | 
 | ||||||
| END_MODULE_NAMESPACE | END_MODULE_NAMESPACE | ||||||
| 
 | 
 | ||||||
| END_HADRONS_NAMESPACE | END_HADRONS_NAMESPACE | ||||||
| 
 | 
 | ||||||
| #endif // Hadrons_MGauge_Load_hpp_
 | #endif // Hadrons_MIO_LoadNersc_hpp_
 | ||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MLoop/NoiseLoop.hpp | Source file: extras/Hadrons/Modules/MLoop/NoiseLoop.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2016 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -1,3 +1,31 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalar/ChargedProp.cc | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: James Harrison <jch1g10@soton.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 */ | ||||||
| #include <Grid/Hadrons/Modules/MScalar/ChargedProp.hpp> | #include <Grid/Hadrons/Modules/MScalar/ChargedProp.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MScalar/Scalar.hpp> | #include <Grid/Hadrons/Modules/MScalar/Scalar.hpp> | ||||||
|  |  | ||||||
| @@ -105,7 +133,7 @@ void TChargedProp::execute(void) | |||||||
|         LOG(Message) << "Saving zero-momentum projection to '" |         LOG(Message) << "Saving zero-momentum projection to '" | ||||||
|                      << filename << "'..." << std::endl; |                      << filename << "'..." << std::endl; | ||||||
|          |          | ||||||
|         CorrWriter            writer(filename); |         ResultWriter          writer(RESULT_FILE_NAME(par().output)); | ||||||
|         std::vector<TComplex> vecBuf; |         std::vector<TComplex> vecBuf; | ||||||
|         std::vector<Complex>  result; |         std::vector<Complex>  result; | ||||||
|          |          | ||||||
|   | |||||||
| @@ -1,3 +1,30 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalar/ChargedProp.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MScalar_ChargedProp_hpp_ | #ifndef Hadrons_MScalar_ChargedProp_hpp_ | ||||||
| #define Hadrons_MScalar_ChargedProp_hpp_ | #define Hadrons_MScalar_ChargedProp_hpp_ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,3 +1,30 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalar/FreeProp.cc | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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 */ | ||||||
| #include <Grid/Hadrons/Modules/MScalar/FreeProp.hpp> | #include <Grid/Hadrons/Modules/MScalar/FreeProp.hpp> | ||||||
| #include <Grid/Hadrons/Modules/MScalar/Scalar.hpp> | #include <Grid/Hadrons/Modules/MScalar/Scalar.hpp> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,3 +1,30 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalar/FreeProp.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MScalar_FreeProp_hpp_ | #ifndef Hadrons_MScalar_FreeProp_hpp_ | ||||||
| #define Hadrons_MScalar_FreeProp_hpp_ | #define Hadrons_MScalar_FreeProp_hpp_ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,3 +1,30 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalar/Scalar.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_Scalar_hpp_ | #ifndef Hadrons_Scalar_hpp_ | ||||||
| #define Hadrons_Scalar_hpp_ | #define Hadrons_Scalar_hpp_ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										146
									
								
								extras/Hadrons/Modules/MScalarSUN/TrMag.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										146
									
								
								extras/Hadrons/Modules/MScalarSUN/TrMag.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,146 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalarSUN/TrMag.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MScalarSUN_TrMag_hpp_ | ||||||
|  | #define Hadrons_MScalarSUN_TrMag_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                       Module to compute tr(mag^n)                          * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MScalarSUN) | ||||||
|  |  | ||||||
|  | class TrMagPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(TrMagPar, | ||||||
|  |                                     std::string,  field, | ||||||
|  |                                     unsigned int, maxPow, | ||||||
|  |                                     std::string,  output); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | class TTrMag: public Module<TrMagPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef typename SImpl::Field        Field; | ||||||
|  |     typedef typename SImpl::ComplexField ComplexField; | ||||||
|  |     class Result: Serializable | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |         GRID_SERIALIZABLE_CLASS_MEMBERS(Result, | ||||||
|  |                                         std::string, op, | ||||||
|  |                                         Real,        value); | ||||||
|  |     }; | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TTrMag(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TTrMag(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(TrMagSU2, TTrMag<ScalarNxNAdjImplR<2>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrMagSU3, TTrMag<ScalarNxNAdjImplR<3>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrMagSU4, TTrMag<ScalarNxNAdjImplR<4>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrMagSU5, TTrMag<ScalarNxNAdjImplR<5>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrMagSU6, TTrMag<ScalarNxNAdjImplR<6>>, MScalarSUN); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                         TTrMag implementation                              * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | TTrMag<SImpl>::TTrMag(const std::string name) | ||||||
|  | : Module<TrMagPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTrMag<SImpl>::getInput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> in = {par().field}; | ||||||
|  |      | ||||||
|  |     return in; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTrMag<SImpl>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out = {}; | ||||||
|  |      | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTrMag<SImpl>::setup(void) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTrMag<SImpl>::execute(void) | ||||||
|  | { | ||||||
|  |     LOG(Message) << "Computing tr(mag^n) for n even up to " << par().maxPow | ||||||
|  |                  << "..." << std::endl; | ||||||
|  |  | ||||||
|  |     std::vector<Result> result; | ||||||
|  |     ResultWriter        writer(RESULT_FILE_NAME(par().output)); | ||||||
|  |     auto                &phi = envGet(Field, par().field); | ||||||
|  |  | ||||||
|  |     auto m2 = sum(phi), mn = m2; | ||||||
|  |  | ||||||
|  |     m2 = -m2*m2; | ||||||
|  |     mn = 1.; | ||||||
|  |     for (unsigned int n = 2; n <= par().maxPow; n += 2) | ||||||
|  |     { | ||||||
|  |         Result r; | ||||||
|  |  | ||||||
|  |         mn = mn*m2; | ||||||
|  |         r.op    = "tr(mag^" + std::to_string(n) + ")"; | ||||||
|  |         r.value = TensorRemove(trace(mn)).real(); | ||||||
|  |         result.push_back(r); | ||||||
|  |     } | ||||||
|  |     write(writer, "trmag", result); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_MScalarSUN_TrMag_hpp_ | ||||||
							
								
								
									
										182
									
								
								extras/Hadrons/Modules/MScalarSUN/TrPhi.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										182
									
								
								extras/Hadrons/Modules/MScalarSUN/TrPhi.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,182 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalarSUN/TrPhi.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MScalarSUN_TrPhi_hpp_ | ||||||
|  | #define Hadrons_MScalarSUN_TrPhi_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                         Module to compute tr(phi^n)                        * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MScalarSUN) | ||||||
|  |  | ||||||
|  | class TrPhiPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(TrPhiPar, | ||||||
|  |                                     std::string,  field, | ||||||
|  |                                     unsigned int, maxPow, | ||||||
|  |                                     std::string,  output); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | class TTrPhi: public Module<TrPhiPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef typename SImpl::Field        Field; | ||||||
|  |     typedef typename SImpl::ComplexField ComplexField; | ||||||
|  |     class Result: Serializable | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |         GRID_SERIALIZABLE_CLASS_MEMBERS(Result, | ||||||
|  |                                         std::string, op, | ||||||
|  |                                         Real,        value); | ||||||
|  |     }; | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TTrPhi(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TTrPhi(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); | ||||||
|  | private: | ||||||
|  |     // output name generator | ||||||
|  |     std::string outName(const unsigned int n); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | MODULE_REGISTER_NS(TrPhiSU2, TTrPhi<ScalarNxNAdjImplR<2>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrPhiSU3, TTrPhi<ScalarNxNAdjImplR<3>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrPhiSU4, TTrPhi<ScalarNxNAdjImplR<4>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrPhiSU5, TTrPhi<ScalarNxNAdjImplR<5>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TrPhiSU6, TTrPhi<ScalarNxNAdjImplR<6>>, MScalarSUN); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                          TTrPhi implementation                             * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | TTrPhi<SImpl>::TTrPhi(const std::string name) | ||||||
|  | : Module<TrPhiPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTrPhi<SImpl>::getInput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> in = {par().field}; | ||||||
|  |      | ||||||
|  |     return in; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTrPhi<SImpl>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out; | ||||||
|  |  | ||||||
|  |     for (unsigned int n = 2; n <= par().maxPow; n += 2) | ||||||
|  |     { | ||||||
|  |         out.push_back(outName(n)); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTrPhi<SImpl>::setup(void) | ||||||
|  | { | ||||||
|  |     if (par().maxPow < 2) | ||||||
|  |     { | ||||||
|  |         HADRON_ERROR(Size, "'maxPow' should be at least equal to 2"); | ||||||
|  |     } | ||||||
|  |     envTmpLat(Field, "phi2"); | ||||||
|  |     envTmpLat(Field, "buf"); | ||||||
|  |     for (unsigned int n = 2; n <= par().maxPow; n += 2) | ||||||
|  |     { | ||||||
|  |         envCreateLat(ComplexField, outName(n)); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTrPhi<SImpl>::execute(void) | ||||||
|  | { | ||||||
|  |     LOG(Message) << "Computing tr(phi^n) for n even up to " << par().maxPow | ||||||
|  |                  << "..." << std::endl;  | ||||||
|  |  | ||||||
|  |     std::vector<Result> result; | ||||||
|  |     auto                &phi = envGet(Field, par().field); | ||||||
|  |  | ||||||
|  |     envGetTmp(Field, phi2); | ||||||
|  |     envGetTmp(Field, buf); | ||||||
|  |     buf  = 1.; | ||||||
|  |     phi2 = -phi*phi;  | ||||||
|  |     for (unsigned int n = 2; n <= par().maxPow; n += 2) | ||||||
|  |     { | ||||||
|  |         auto &phin = envGet(ComplexField, outName(n)); | ||||||
|  |  | ||||||
|  |         buf  = buf*phi2; | ||||||
|  |         phin = trace(buf); | ||||||
|  |         if (!par().output.empty()) | ||||||
|  |         { | ||||||
|  |             Result r; | ||||||
|  |  | ||||||
|  |             r.op    = "tr(phi^" + std::to_string(n) + ")"; | ||||||
|  |             r.value = TensorRemove(sum(phin)).real(); | ||||||
|  |             result.push_back(r); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     if (result.size() > 0) | ||||||
|  |     { | ||||||
|  |         ResultWriter writer(RESULT_FILE_NAME(par().output)); | ||||||
|  |  | ||||||
|  |         write(writer, "trphi", result); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // output name generator /////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | std::string TTrPhi<SImpl>::outName(const unsigned int n) | ||||||
|  | { | ||||||
|  |     return getName() + "_" + std::to_string(n); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_MScalarSUN_TrPhi_hpp_ | ||||||
							
								
								
									
										184
									
								
								extras/Hadrons/Modules/MScalarSUN/TwoPoint.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										184
									
								
								extras/Hadrons/Modules/MScalarSUN/TwoPoint.hpp
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,184 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  | Source file: extras/Hadrons/Modules/MScalarSUN/TwoPoint.hpp | ||||||
|  |  | ||||||
|  | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
|  | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|  | 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_MScalarSUN_TwoPoint_hpp_ | ||||||
|  | #define Hadrons_MScalarSUN_TwoPoint_hpp_ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Global.hpp> | ||||||
|  | #include <Grid/Hadrons/Module.hpp> | ||||||
|  | #include <Grid/Hadrons/ModuleFactory.hpp> | ||||||
|  |  | ||||||
|  | BEGIN_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                 2-pt functions for a given set of operators                * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | BEGIN_MODULE_NAMESPACE(MScalarSUN) | ||||||
|  |  | ||||||
|  | class TwoPointPar: Serializable | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     GRID_SERIALIZABLE_CLASS_MEMBERS(TwoPointPar, | ||||||
|  |                                     std::vector<std::string>, op, | ||||||
|  |                                     std::string,              output); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | class TTwoPoint: public Module<TwoPointPar> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |     typedef typename SImpl::Field        Field; | ||||||
|  |     typedef typename SImpl::ComplexField ComplexField; | ||||||
|  |     class Result: Serializable | ||||||
|  |     { | ||||||
|  |     public: | ||||||
|  |         GRID_SERIALIZABLE_CLASS_MEMBERS(Result, | ||||||
|  |                                         std::string, sink, | ||||||
|  |                                         std::string, source, | ||||||
|  |                                         std::vector<Complex>, data); | ||||||
|  |     }; | ||||||
|  | public: | ||||||
|  |     // constructor | ||||||
|  |     TTwoPoint(const std::string name); | ||||||
|  |     // destructor | ||||||
|  |     virtual ~TTwoPoint(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); | ||||||
|  | private: | ||||||
|  |     // make 2-pt function | ||||||
|  |     template <class SinkSite, class SourceSite> | ||||||
|  |     std::vector<Complex> makeTwoPoint(const std::vector<SinkSite>   &sink, | ||||||
|  |                                       const std::vector<SourceSite> &source); | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | MODULE_REGISTER_NS(TwoPointSU2, TTwoPoint<ScalarNxNAdjImplR<2>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TwoPointSU3, TTwoPoint<ScalarNxNAdjImplR<3>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TwoPointSU4, TTwoPoint<ScalarNxNAdjImplR<4>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TwoPointSU5, TTwoPoint<ScalarNxNAdjImplR<5>>, MScalarSUN); | ||||||
|  | MODULE_REGISTER_NS(TwoPointSU6, TTwoPoint<ScalarNxNAdjImplR<6>>, MScalarSUN); | ||||||
|  |  | ||||||
|  | /****************************************************************************** | ||||||
|  |  *                 TTwoPoint implementation                             * | ||||||
|  |  ******************************************************************************/ | ||||||
|  | // constructor ///////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | TTwoPoint<SImpl>::TTwoPoint(const std::string name) | ||||||
|  | : Module<TwoPointPar>(name) | ||||||
|  | {} | ||||||
|  |  | ||||||
|  | // dependencies/products /////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTwoPoint<SImpl>::getInput(void) | ||||||
|  | {    | ||||||
|  |     return par().op; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <typename SImpl> | ||||||
|  | std::vector<std::string> TTwoPoint<SImpl>::getOutput(void) | ||||||
|  | { | ||||||
|  |     std::vector<std::string> out = {}; | ||||||
|  |  | ||||||
|  |     return out; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // setup /////////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTwoPoint<SImpl>::setup(void) | ||||||
|  | { | ||||||
|  |     const unsigned int nt = env().getDim().back(); | ||||||
|  |     envTmp(std::vector<std::vector<TComplex>>, "slicedOp", 1, par().op.size(),  | ||||||
|  |            std::vector<TComplex>(nt)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // execution /////////////////////////////////////////////////////////////////// | ||||||
|  | template <typename SImpl> | ||||||
|  | void TTwoPoint<SImpl>::execute(void) | ||||||
|  | { | ||||||
|  |     LOG(Message) << "Computing 2-point functions for operators:" << std::endl; | ||||||
|  |     for (auto &o: par().op) | ||||||
|  |     { | ||||||
|  |         LOG(Message) << "  '" << o << "'" << std::endl; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     ResultWriter        writer(RESULT_FILE_NAME(par().output)); | ||||||
|  |     const unsigned int  nd = env().getDim().size(); | ||||||
|  |     std::vector<Result> result; | ||||||
|  |      | ||||||
|  |     envGetTmp(std::vector<std::vector<TComplex>>, slicedOp); | ||||||
|  |     for (unsigned int i = 0; i < par().op.size(); ++i) | ||||||
|  |     { | ||||||
|  |         auto &op = envGet(ComplexField, par().op[i]); | ||||||
|  |  | ||||||
|  |         sliceSum(op, slicedOp[i], nd - 1); | ||||||
|  |     } | ||||||
|  |     for (unsigned int i = 0; i < par().op.size(); ++i) | ||||||
|  |     for (unsigned int j = 0; j < par().op.size(); ++j) | ||||||
|  |     { | ||||||
|  |         Result r; | ||||||
|  |  | ||||||
|  |         r.sink   = par().op[i]; | ||||||
|  |         r.source = par().op[j]; | ||||||
|  |         r.data   = makeTwoPoint(slicedOp[i], slicedOp[j]); | ||||||
|  |         result.push_back(r); | ||||||
|  |     } | ||||||
|  |     write(writer, "twopt", result); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // make 2-pt function ////////////////////////////////////////////////////////// | ||||||
|  | template <class SImpl> | ||||||
|  | template <class SinkSite, class SourceSite> | ||||||
|  | std::vector<Complex> TTwoPoint<SImpl>::makeTwoPoint( | ||||||
|  |                                   const std::vector<SinkSite>   &sink, | ||||||
|  |                                   const std::vector<SourceSite> &source) | ||||||
|  | { | ||||||
|  |     assert(sink.size() == source.size()); | ||||||
|  |      | ||||||
|  |     unsigned int         nt = sink.size(); | ||||||
|  |     std::vector<Complex> res(nt, 0.); | ||||||
|  |      | ||||||
|  |     for (unsigned int dt = 0; dt < nt; ++dt) | ||||||
|  |     { | ||||||
|  |         for (unsigned int t  = 0; t < nt; ++t) | ||||||
|  |         { | ||||||
|  |             res[dt] += TensorRemove(trace(sink[(t+dt)%nt]*source[t])); | ||||||
|  |         } | ||||||
|  |         res[dt] *= 1./static_cast<double>(nt); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     return res; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | END_MODULE_NAMESPACE | ||||||
|  |  | ||||||
|  | END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  | #endif // Hadrons_MScalarSUN_TwoPoint_hpp_ | ||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSink/Point.hpp | Source file: extras/Hadrons/Modules/MSink/Point.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSink/Smear.hpp | Source file: extras/Hadrons/Modules/MSink/Smear.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSolver/RBPrecCG.hpp | Source file: extras/Hadrons/Modules/MSolver/RBPrecCG.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,10 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSource/Point.hpp | Source file: extras/Hadrons/Modules/MSource/Point.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -2,11 +2,12 @@ | |||||||
|  |  | ||||||
| Grid physics library, www.github.com/paboyle/Grid  | Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MContraction/SeqConserved.hpp | Source file: extras/Hadrons/Modules/MSource/SeqConserved.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,11 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSource/SeqGamma.hpp | Source file: extras/Hadrons/Modules/MSource/SeqGamma.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
| Copyright (C) 2017 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSource/Wall.hpp | Source file: extras/Hadrons/Modules/MSource/Wall.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,8 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MSource/Z2.hpp | Source file: extras/Hadrons/Modules/MSource/Z2.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MUtilities/TestSeqConserved.hpp | Source file: extras/Hadrons/Modules/MUtilities/TestSeqConserved.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,9 +4,10 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules/MUtilities/TestSeqGamma.hpp | Source file: extras/Hadrons/Modules/MUtilities/TestSeqGamma.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Andrew Lawson    <andrew.lawson1991@gmail.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  | Author: Lanny91 <andrew.lawson@gmail.com> | ||||||
|  |  | ||||||
| This program is free software; you can redistribute it and/or modify | 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 | it under the terms of the GNU General Public License as published by | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/VirtualMachine.cc | Source file: extras/Hadrons/VirtualMachine.cc | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -4,7 +4,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: extras/Hadrons/VirtualMachine.hpp | Source file: extras/Hadrons/VirtualMachine.hpp | ||||||
|  |  | ||||||
| Copyright (C) 2017 | Copyright (C) 2015-2018 | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> | Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,36 +7,6 @@ echo 'modules_hpp =\' >> modules.inc | |||||||
| find Modules -name '*.hpp' -type f -print | sed 's/^/  /;$q;s/$/ \\/' >> modules.inc | find Modules -name '*.hpp' -type f -print | sed 's/^/  /;$q;s/$/ \\/' >> modules.inc | ||||||
| echo '' >> modules.inc | echo '' >> modules.inc | ||||||
| rm -f Modules.hpp | rm -f Modules.hpp | ||||||
| echo "/************************************************************************************* |  | ||||||
|  |  | ||||||
| Grid physics library, www.github.com/paboyle/Grid  |  | ||||||
|  |  | ||||||
| Source file: extras/Hadrons/Modules.hpp |  | ||||||
|  |  | ||||||
| Copyright (C) 2015 |  | ||||||
| Copyright (C) 2016 |  | ||||||
| Copyright (C) 2017 |  | ||||||
|  |  | ||||||
| Author: Antonin Portelli <antonin.portelli@me.com> |  | ||||||
|  |  | ||||||
| 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 */ |  | ||||||
| " > Modules.hpp |  | ||||||
| for f in `find Modules -name '*.hpp'`; do | for f in `find Modules -name '*.hpp'`; do | ||||||
| 	echo "#include <Grid/Hadrons/${f}>" >> Modules.hpp | 	echo "#include <Grid/Hadrons/${f}>" >> Modules.hpp | ||||||
| done | done | ||||||
|   | |||||||
| @@ -1,13 +1,16 @@ | |||||||
| modules_cc =\ | modules_cc =\ | ||||||
|  |   Modules/MScalar/ChargedProp.cc \ | ||||||
|  |   Modules/MScalar/FreeProp.cc \ | ||||||
|   Modules/MContraction/WeakHamiltonianEye.cc \ |   Modules/MContraction/WeakHamiltonianEye.cc \ | ||||||
|   Modules/MContraction/WeakNeutral4ptDisc.cc \ |   Modules/MContraction/WeakNeutral4ptDisc.cc \ | ||||||
|   Modules/MContraction/WeakHamiltonianNonEye.cc \ |   Modules/MContraction/WeakHamiltonianNonEye.cc \ | ||||||
|   Modules/MGauge/Load.cc \ |  | ||||||
|   Modules/MGauge/Unit.cc \ |   Modules/MGauge/Unit.cc \ | ||||||
|   Modules/MGauge/StochEm.cc \ |   Modules/MGauge/StochEm.cc \ | ||||||
|   Modules/MGauge/Random.cc \ |   Modules/MGauge/Random.cc \ | ||||||
|  |   Modules/MGauge/FundtoHirep.cc \ | ||||||
|   Modules/MScalar/FreeProp.cc \ |   Modules/MScalar/FreeProp.cc \ | ||||||
|   Modules/MScalar/ChargedProp.cc |   Modules/MScalar/ChargedProp.cc \ | ||||||
|  |   Modules/MIO/LoadNersc.cc | ||||||
|  |  | ||||||
| modules_hpp =\ | modules_hpp =\ | ||||||
|   Modules/MContraction/Baryon.hpp \ |   Modules/MContraction/Baryon.hpp \ | ||||||
| @@ -28,10 +31,10 @@ modules_hpp =\ | |||||||
|   Modules/MSink/Smear.hpp \ |   Modules/MSink/Smear.hpp \ | ||||||
|   Modules/MSink/Point.hpp \ |   Modules/MSink/Point.hpp \ | ||||||
|   Modules/MSolver/RBPrecCG.hpp \ |   Modules/MSolver/RBPrecCG.hpp \ | ||||||
|   Modules/MGauge/Load.hpp \ |  | ||||||
|   Modules/MGauge/Unit.hpp \ |   Modules/MGauge/Unit.hpp \ | ||||||
|   Modules/MGauge/Random.hpp \ |   Modules/MGauge/Random.hpp \ | ||||||
|   Modules/MGauge/StochEm.hpp \ |   Modules/MGauge/StochEm.hpp \ | ||||||
|  |   Modules/MGauge/FundtoHirep.hpp \ | ||||||
|   Modules/MUtilities/TestSeqGamma.hpp \ |   Modules/MUtilities/TestSeqGamma.hpp \ | ||||||
|   Modules/MUtilities/TestSeqConserved.hpp \ |   Modules/MUtilities/TestSeqConserved.hpp \ | ||||||
|   Modules/MLoop/NoiseLoop.hpp \ |   Modules/MLoop/NoiseLoop.hpp \ | ||||||
| @@ -39,5 +42,11 @@ modules_hpp =\ | |||||||
|   Modules/MScalar/Scalar.hpp \ |   Modules/MScalar/Scalar.hpp \ | ||||||
|   Modules/MScalar/ChargedProp.hpp \ |   Modules/MScalar/ChargedProp.hpp \ | ||||||
|   Modules/MAction/DWF.hpp \ |   Modules/MAction/DWF.hpp \ | ||||||
|   Modules/MAction/Wilson.hpp |   Modules/MAction/Wilson.hpp \ | ||||||
|  |   Modules/MAction/WilsonClover.hpp \ | ||||||
|  |   Modules/MScalarSUN/TrMag.hpp \ | ||||||
|  |   Modules/MScalarSUN/TwoPoint.hpp \ | ||||||
|  |   Modules/MScalarSUN/TrPhi.hpp \ | ||||||
|  |   Modules/MIO/LoadNersc.hpp \ | ||||||
|  |   Modules/MIO/LoadBinary.hpp | ||||||
|  |  | ||||||
|   | |||||||
| @@ -183,11 +183,13 @@ namespace Grid { | |||||||
|       virtual  RealD Mpc      (const Field &in, Field &out) =0; |       virtual  RealD Mpc      (const Field &in, Field &out) =0; | ||||||
|       virtual  RealD MpcDag   (const Field &in, Field &out) =0; |       virtual  RealD MpcDag   (const Field &in, Field &out) =0; | ||||||
|       virtual void MpcDagMpc(const Field &in, Field &out,RealD &ni,RealD &no) { |       virtual void MpcDagMpc(const Field &in, Field &out,RealD &ni,RealD &no) { | ||||||
| 	Field tmp(in._grid); |       Field tmp(in._grid); | ||||||
|  |       tmp.checkerboard = in.checkerboard; | ||||||
| 	ni=Mpc(in,tmp); | 	ni=Mpc(in,tmp); | ||||||
| 	no=MpcDag(tmp,out); | 	no=MpcDag(tmp,out); | ||||||
|       } |       } | ||||||
|       virtual void HermOpAndNorm(const Field &in, Field &out,RealD &n1,RealD &n2){ |       virtual void HermOpAndNorm(const Field &in, Field &out,RealD &n1,RealD &n2){ | ||||||
|  |       out.checkerboard = in.checkerboard; | ||||||
| 	MpcDagMpc(in,out,n1,n2); | 	MpcDagMpc(in,out,n1,n2); | ||||||
|       } |       } | ||||||
|       virtual void HermOp(const Field &in, Field &out){ |       virtual void HermOp(const Field &in, Field &out){ | ||||||
| @@ -215,13 +217,15 @@ namespace Grid { | |||||||
|     public: |     public: | ||||||
|       SchurDiagMooeeOperator (Matrix &Mat): _Mat(Mat){}; |       SchurDiagMooeeOperator (Matrix &Mat): _Mat(Mat){}; | ||||||
|       virtual  RealD Mpc      (const Field &in, Field &out) { |       virtual  RealD Mpc      (const Field &in, Field &out) { | ||||||
| 	Field tmp(in._grid); |       Field tmp(in._grid); | ||||||
| //	std::cout <<"grid pointers: in._grid="<< in._grid << " out._grid=" << out._grid << "  _Mat.Grid=" << _Mat.Grid() << " _Mat.RedBlackGrid=" << _Mat.RedBlackGrid() << std::endl; |       tmp.checkerboard = !in.checkerboard; | ||||||
|  | 	//std::cout <<"grid pointers: in._grid="<< in._grid << " out._grid=" << out._grid << "  _Mat.Grid=" << _Mat.Grid() << " _Mat.RedBlackGrid=" << _Mat.RedBlackGrid() << std::endl; | ||||||
|  |  | ||||||
| 	_Mat.Meooe(in,tmp); | 	_Mat.Meooe(in,tmp); | ||||||
| 	_Mat.MooeeInv(tmp,out); | 	_Mat.MooeeInv(tmp,out); | ||||||
| 	_Mat.Meooe(out,tmp); | 	_Mat.Meooe(out,tmp); | ||||||
|  |  | ||||||
|  |       //std::cout << "cb in " << in.checkerboard << "  cb out " << out.checkerboard << std::endl; | ||||||
| 	_Mat.Mooee(in,out); | 	_Mat.Mooee(in,out); | ||||||
| 	return axpy_norm(out,-1.0,tmp,out); | 	return axpy_norm(out,-1.0,tmp,out); | ||||||
|       } |       } | ||||||
|   | |||||||
| @@ -59,6 +59,7 @@ public: | |||||||
|  |  | ||||||
|     virtual ~GridBase() = default; |     virtual ~GridBase() = default; | ||||||
|  |  | ||||||
|  |  | ||||||
|     // Physics Grid information. |     // Physics Grid information. | ||||||
|     std::vector<int> _simd_layout;// Which dimensions get relayed out over simd lanes. |     std::vector<int> _simd_layout;// Which dimensions get relayed out over simd lanes. | ||||||
|     std::vector<int> _fdimensions;// (full) Global dimensions of array prior to cb removal |     std::vector<int> _fdimensions;// (full) Global dimensions of array prior to cb removal | ||||||
| @@ -78,6 +79,8 @@ public: | |||||||
|     std::vector<int> _lstart;     // local start of array in gcoors _processor_coor[d]*_ldimensions[d] |     std::vector<int> _lstart;     // local start of array in gcoors _processor_coor[d]*_ldimensions[d] | ||||||
|     std::vector<int> _lend  ;     // local end of array in gcoors   _processor_coor[d]*_ldimensions[d]+_ldimensions_[d]-1 |     std::vector<int> _lend  ;     // local end of array in gcoors   _processor_coor[d]*_ldimensions[d]+_ldimensions_[d]-1 | ||||||
|  |  | ||||||
|  |     bool _isCheckerBoarded;  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|  |  | ||||||
|     //////////////////////////////////////////////////////////////// |     //////////////////////////////////////////////////////////////// | ||||||
|   | |||||||
| @@ -97,6 +97,7 @@ public: | |||||||
|       /////////////////////// |       /////////////////////// | ||||||
|       // Grid information |       // Grid information | ||||||
|       /////////////////////// |       /////////////////////// | ||||||
|  |       _isCheckerBoarded = false; | ||||||
|       _ndimension = dimensions.size(); |       _ndimension = dimensions.size(); | ||||||
|  |  | ||||||
|       _fdimensions.resize(_ndimension); |       _fdimensions.resize(_ndimension); | ||||||
| @@ -122,6 +123,7 @@ public: | |||||||
|  |  | ||||||
|         // Use a reduced simd grid |         // Use a reduced simd grid | ||||||
|         _ldimensions[d] = _gdimensions[d] / _processors[d]; //local dimensions |         _ldimensions[d] = _gdimensions[d] / _processors[d]; //local dimensions | ||||||
|  |         //std::cout << _ldimensions[d] << "  " << _gdimensions[d] << "  " << _processors[d] << std::endl; | ||||||
|         assert(_ldimensions[d] * _processors[d] == _gdimensions[d]); |         assert(_ldimensions[d] * _processors[d] == _gdimensions[d]); | ||||||
|  |  | ||||||
|         _rdimensions[d] = _ldimensions[d] / _simd_layout[d]; //overdecomposition |         _rdimensions[d] = _ldimensions[d] / _simd_layout[d]; //overdecomposition | ||||||
| @@ -166,6 +168,7 @@ public: | |||||||
|         block = block * _rdimensions[d]; |         block = block * _rdimensions[d]; | ||||||
|       } |       } | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
| }; | }; | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -171,9 +171,8 @@ public: | |||||||
|               const std::vector<int> &checker_dim_mask, |               const std::vector<int> &checker_dim_mask, | ||||||
|               int checker_dim) |               int checker_dim) | ||||||
|     { |     { | ||||||
|       /////////////////////// |  | ||||||
|       // Grid information |       _isCheckerBoarded = true; | ||||||
|       /////////////////////// |  | ||||||
|       _checker_dim = checker_dim; |       _checker_dim = checker_dim; | ||||||
|       assert(checker_dim_mask[checker_dim] == 1); |       assert(checker_dim_mask[checker_dim] == 1); | ||||||
|       _ndimension = dimensions.size(); |       _ndimension = dimensions.size(); | ||||||
|   | |||||||
| @@ -82,6 +82,7 @@ public: | |||||||
|   void InitFromMPICommunicator(const std::vector<int> &processors, Grid_MPI_Comm communicator_base); |   void InitFromMPICommunicator(const std::vector<int> &processors, Grid_MPI_Comm communicator_base); | ||||||
|  |  | ||||||
|  public: |  public: | ||||||
|  |  | ||||||
|    |    | ||||||
|   //////////////////////////////////////////////////////////////////////////////////////// |   //////////////////////////////////////////////////////////////////////////////////////// | ||||||
|   // Wraps MPI_Cart routines, or implements equivalent on other impls |   // Wraps MPI_Cart routines, or implements equivalent on other impls | ||||||
|   | |||||||
| @@ -86,6 +86,7 @@ protected: | |||||||
|   Colours &Painter; |   Colours &Painter; | ||||||
|   int active; |   int active; | ||||||
|   int timing_mode; |   int timing_mode; | ||||||
|  |   int topWidth{-1}; | ||||||
|   static int timestamp; |   static int timestamp; | ||||||
|   std::string name, topName; |   std::string name, topName; | ||||||
|   std::string COLOUR; |   std::string COLOUR; | ||||||
| @@ -124,11 +125,17 @@ public: | |||||||
|       Reset();  |       Reset();  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   void setTopWidth(const int w) {topWidth = w;} | ||||||
|  |  | ||||||
|   friend std::ostream& operator<< (std::ostream& stream, Logger& log){ |   friend std::ostream& operator<< (std::ostream& stream, Logger& log){ | ||||||
|  |  | ||||||
|     if ( log.active ) { |     if ( log.active ) { | ||||||
|       stream << log.background()<<  std::left << log.topName << log.background()<< " : "; |       stream << log.background()<<  std::left; | ||||||
|  |       if (log.topWidth > 0) | ||||||
|  |       { | ||||||
|  |         stream << std::setw(log.topWidth); | ||||||
|  |       } | ||||||
|  |       stream << log.topName << log.background()<< " : "; | ||||||
|       stream << log.colour() <<  std::left << log.name << log.background() << " : "; |       stream << log.colour() <<  std::left << log.name << log.background() << " : "; | ||||||
|       if ( log.timestamp ) { |       if ( log.timestamp ) { | ||||||
| 	log.StopWatch->Stop(); | 	log.StopWatch->Stop(); | ||||||
|   | |||||||
| @@ -39,6 +39,7 @@ namespace QCD { | |||||||
|     static const int Zdir = 2; |     static const int Zdir = 2; | ||||||
|     static const int Tdir = 3; |     static const int Tdir = 3; | ||||||
|  |  | ||||||
|  |    | ||||||
|     static const int Xp = 0; |     static const int Xp = 0; | ||||||
|     static const int Yp = 1; |     static const int Yp = 1; | ||||||
|     static const int Zp = 2; |     static const int Zp = 2; | ||||||
| @@ -420,15 +421,16 @@ namespace QCD { | |||||||
|     ////////////////////////////////////////////// |     ////////////////////////////////////////////// | ||||||
|     // Fermion <-> propagator assignements |     // Fermion <-> propagator assignements | ||||||
|     ////////////////////////////////////////////// |     ////////////////////////////////////////////// | ||||||
|     template <class Prop, class Ferm> |     //template <class Prop, class Ferm> | ||||||
|     void FermToProp(Prop &p, const Ferm &f, const int s, const int c) |     template <class Fimpl> | ||||||
|  |       void FermToProp(typename Fimpl::PropagatorField &p, const typename Fimpl::FermionField &f, const int s, const int c) | ||||||
|     { |     { | ||||||
|         for(int j = 0; j < Ns; ++j) |       for(int j = 0; j < Ns; ++j) | ||||||
|         { |         { | ||||||
|             auto pjs = peekSpin(p, j, s); |             auto pjs = peekSpin(p, j, s); | ||||||
|             auto fj  = peekSpin(f, j); |             auto fj  = peekSpin(f, j); | ||||||
|              |              | ||||||
|             for(int i = 0; i < Nc; ++i) |             for(int i = 0; i < Fimpl::Dimension; ++i) | ||||||
|             { |             { | ||||||
|                 pokeColour(pjs, peekColour(fj, i), i, c); |                 pokeColour(pjs, peekColour(fj, i), i, c); | ||||||
|             } |             } | ||||||
| @@ -436,15 +438,16 @@ namespace QCD { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     template <class Prop, class Ferm> |     //template <class Prop, class Ferm> | ||||||
|     void PropToFerm(Ferm &f, const Prop &p, const int s, const int c) |     template <class Fimpl> | ||||||
|  |       void PropToFerm(typename Fimpl::FermionField &f, const typename Fimpl::PropagatorField &p, const int s, const int c) | ||||||
|     { |     { | ||||||
|         for(int j = 0; j < Ns; ++j) |         for(int j = 0; j < Ns; ++j) | ||||||
|         { |         { | ||||||
|             auto pjs = peekSpin(p, j, s); |             auto pjs = peekSpin(p, j, s); | ||||||
|             auto fj  = peekSpin(f, j); |             auto fj  = peekSpin(f, j); | ||||||
|              |              | ||||||
|             for(int i = 0; i < Nc; ++i) |             for(int i = 0; i < Fimpl::Dimension; ++i) | ||||||
|             { |             { | ||||||
|                 pokeColour(fj, peekColour(pjs, i, c), i); |                 pokeColour(fj, peekColour(pjs, i, c), i); | ||||||
|             } |             } | ||||||
| @@ -503,38 +506,6 @@ namespace QCD { | |||||||
| }   //namespace QCD | }   //namespace QCD | ||||||
| } // Grid | } // Grid | ||||||
|  |  | ||||||
| /* |  | ||||||
| <<<<<<< HEAD |  | ||||||
| #include <Grid/qcd/utils/SpaceTimeGrid.h> |  | ||||||
| #include <Grid/qcd/spin/Dirac.h> |  | ||||||
| #include <Grid/qcd/spin/TwoSpinor.h> |  | ||||||
| #include <Grid/qcd/utils/LinalgUtils.h> |  | ||||||
| #include <Grid/qcd/utils/CovariantCshift.h> |  | ||||||
|  |  | ||||||
| // Include representations   |  | ||||||
| #include <Grid/qcd/utils/SUn.h> |  | ||||||
| #include <Grid/qcd/utils/SUnAdjoint.h> |  | ||||||
| #include <Grid/qcd/utils/SUnTwoIndex.h> |  | ||||||
| #include <Grid/qcd/representations/hmc_types.h> |  | ||||||
|  |  | ||||||
| // Scalar field |  | ||||||
| #include <Grid/qcd/utils/ScalarObjs.h> |  | ||||||
|  |  | ||||||
| #include <Grid/qcd/action/Actions.h> |  | ||||||
|  |  | ||||||
| #include <Grid/qcd/smearing/Smearing.h> |  | ||||||
|  |  | ||||||
| #include <Grid/qcd/hmc/integrators/Integrator.h> |  | ||||||
| #include <Grid/qcd/hmc/integrators/Integrator_algorithm.h> |  | ||||||
| #include <Grid/qcd/observables/hmc_observable.h> |  | ||||||
| #include <Grid/qcd/hmc/HMC.h> |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //#include <Grid/qcd/modules/mods.h> |  | ||||||
| ======= |  | ||||||
|  |  | ||||||
| >>>>>>> develop |  | ||||||
| */ |  | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -50,11 +50,13 @@ Author: Peter Boyle <pabobyle@ph.ed.ac.uk> | |||||||
| //////////////////////////////////////////// | //////////////////////////////////////////// | ||||||
|  |  | ||||||
| #include <Grid/qcd/action/fermion/WilsonFermion.h>       // 4d wilson like | #include <Grid/qcd/action/fermion/WilsonFermion.h>       // 4d wilson like | ||||||
| #include <Grid/qcd/action/fermion/WilsonTMFermion.h>       // 4d wilson like | #include <Grid/qcd/action/fermion/WilsonTMFermion.h>     // 4d wilson like | ||||||
|  | #include <Grid/qcd/action/fermion/WilsonCloverFermion.h> // 4d wilson clover fermions | ||||||
| #include <Grid/qcd/action/fermion/WilsonFermion5D.h>     // 5d base used by all 5d overlap types | #include <Grid/qcd/action/fermion/WilsonFermion5D.h>     // 5d base used by all 5d overlap types | ||||||
| //#include <Grid/qcd/action/fermion/CloverFermion.h> |  | ||||||
| #include <Grid/qcd/action/fermion/ImprovedStaggeredFermion.h> | #include <Grid/qcd/action/fermion/ImprovedStaggeredFermion.h> | ||||||
| #include <Grid/qcd/action/fermion/ImprovedStaggeredFermion5D.h> | #include <Grid/qcd/action/fermion/ImprovedStaggeredFermion5D.h> | ||||||
|  |  | ||||||
| #include <Grid/qcd/action/fermion/CayleyFermion5D.h>     // Cayley types | #include <Grid/qcd/action/fermion/CayleyFermion5D.h>     // Cayley types | ||||||
| #include <Grid/qcd/action/fermion/DomainWallFermion.h> | #include <Grid/qcd/action/fermion/DomainWallFermion.h> | ||||||
| #include <Grid/qcd/action/fermion/DomainWallEOFAFermion.h> | #include <Grid/qcd/action/fermion/DomainWallEOFAFermion.h> | ||||||
| @@ -104,10 +106,33 @@ typedef WilsonFermion<WilsonTwoIndexSymmetricImplR> WilsonTwoIndexSymmetricFermi | |||||||
| typedef WilsonFermion<WilsonTwoIndexSymmetricImplF> WilsonTwoIndexSymmetricFermionF; | typedef WilsonFermion<WilsonTwoIndexSymmetricImplF> WilsonTwoIndexSymmetricFermionF; | ||||||
| typedef WilsonFermion<WilsonTwoIndexSymmetricImplD> WilsonTwoIndexSymmetricFermionD; | typedef WilsonFermion<WilsonTwoIndexSymmetricImplD> WilsonTwoIndexSymmetricFermionD; | ||||||
|  |  | ||||||
|  | typedef WilsonFermion<WilsonTwoIndexAntiSymmetricImplR> WilsonTwoIndexAntiSymmetricFermionR; | ||||||
|  | typedef WilsonFermion<WilsonTwoIndexAntiSymmetricImplF> WilsonTwoIndexAntiSymmetricFermionF; | ||||||
|  | typedef WilsonFermion<WilsonTwoIndexAntiSymmetricImplD> WilsonTwoIndexAntiSymmetricFermionD; | ||||||
|  |  | ||||||
|  | // Twisted mass fermion | ||||||
| typedef WilsonTMFermion<WilsonImplR> WilsonTMFermionR; | typedef WilsonTMFermion<WilsonImplR> WilsonTMFermionR; | ||||||
| typedef WilsonTMFermion<WilsonImplF> WilsonTMFermionF; | typedef WilsonTMFermion<WilsonImplF> WilsonTMFermionF; | ||||||
| typedef WilsonTMFermion<WilsonImplD> WilsonTMFermionD; | typedef WilsonTMFermion<WilsonImplD> WilsonTMFermionD; | ||||||
|  |  | ||||||
|  | // Clover fermions | ||||||
|  | typedef WilsonCloverFermion<WilsonImplR> WilsonCloverFermionR; | ||||||
|  | typedef WilsonCloverFermion<WilsonImplF> WilsonCloverFermionF; | ||||||
|  | typedef WilsonCloverFermion<WilsonImplD> WilsonCloverFermionD; | ||||||
|  |  | ||||||
|  | typedef WilsonCloverFermion<WilsonAdjImplR> WilsonCloverAdjFermionR; | ||||||
|  | typedef WilsonCloverFermion<WilsonAdjImplF> WilsonCloverAdjFermionF; | ||||||
|  | typedef WilsonCloverFermion<WilsonAdjImplD> WilsonCloverAdjFermionD; | ||||||
|  |  | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexSymmetricImplR> WilsonCloverTwoIndexSymmetricFermionR; | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexSymmetricImplF> WilsonCloverTwoIndexSymmetricFermionF; | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexSymmetricImplD> WilsonCloverTwoIndexSymmetricFermionD; | ||||||
|  |  | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexAntiSymmetricImplR> WilsonCloverTwoIndexAntiSymmetricFermionR; | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexAntiSymmetricImplF> WilsonCloverTwoIndexAntiSymmetricFermionF; | ||||||
|  | typedef WilsonCloverFermion<WilsonTwoIndexAntiSymmetricImplD> WilsonCloverTwoIndexAntiSymmetricFermionD; | ||||||
|  |  | ||||||
|  | // Domain Wall fermions | ||||||
| typedef DomainWallFermion<WilsonImplR> DomainWallFermionR; | typedef DomainWallFermion<WilsonImplR> DomainWallFermionR; | ||||||
| typedef DomainWallFermion<WilsonImplF> DomainWallFermionF; | typedef DomainWallFermion<WilsonImplF> DomainWallFermionF; | ||||||
| typedef DomainWallFermion<WilsonImplD> DomainWallFermionD; | typedef DomainWallFermion<WilsonImplD> DomainWallFermionD; | ||||||
|   | |||||||
| @@ -70,7 +70,9 @@ Author: Peter Boyle <pabobyle@ph.ed.ac.uk> | |||||||
|  |  | ||||||
| #define TwoIndexFermOpTemplateInstantiate(A) \ | #define TwoIndexFermOpTemplateInstantiate(A) \ | ||||||
|   template class A<WilsonTwoIndexSymmetricImplF>; \ |   template class A<WilsonTwoIndexSymmetricImplF>; \ | ||||||
|   template class A<WilsonTwoIndexSymmetricImplD>;  |   template class A<WilsonTwoIndexSymmetricImplD>; \ | ||||||
|  |   template class A<WilsonTwoIndexAntiSymmetricImplF>; \ | ||||||
|  |   template class A<WilsonTwoIndexAntiSymmetricImplD>; | ||||||
|  |  | ||||||
| #define FermOp5dVecTemplateInstantiate(A) \ | #define FermOp5dVecTemplateInstantiate(A) \ | ||||||
|   template class A<DomainWallVec5dImplF>;	\ |   template class A<DomainWallVec5dImplF>;	\ | ||||||
|   | |||||||
| @@ -261,8 +261,22 @@ namespace QCD { | |||||||
|       GaugeLinkField link(mat._grid); |       GaugeLinkField link(mat._grid); | ||||||
|       link = TraceIndex<SpinIndex>(outerProduct(Btilde,A));  |       link = TraceIndex<SpinIndex>(outerProduct(Btilde,A));  | ||||||
|       PokeIndex<LorentzIndex>(mat,link,mu); |       PokeIndex<LorentzIndex>(mat,link,mu); | ||||||
|     }    |     }   | ||||||
|  |      | ||||||
|  |     inline void outerProductImpl(PropagatorField &mat, const FermionField &B, const FermionField &A){ | ||||||
|  |       mat = outerProduct(B,A);  | ||||||
|  |     }   | ||||||
|  |  | ||||||
|  |     inline void TraceSpinImpl(GaugeLinkField &mat, PropagatorField&P) { | ||||||
|  |       mat = TraceIndex<SpinIndex>(P);  | ||||||
|  |     } | ||||||
|        |        | ||||||
|  |     inline void extractLinkField(std::vector<GaugeLinkField> &mat, DoubledGaugeField &Uds){ | ||||||
|  |       for (int mu = 0; mu < Nd; mu++) | ||||||
|  |       mat[mu] = PeekIndex<LorentzIndex>(Uds, mu); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã,int mu){ |     inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã,int mu){ | ||||||
|        |        | ||||||
|       int Ls=Btilde._grid->_fdimensions[0]; |       int Ls=Btilde._grid->_fdimensions[0]; | ||||||
| @@ -393,6 +407,19 @@ class DomainWallVec5dImpl :  public PeriodicGaugeImpl< GaugeImplTypes< S,Nrepres | |||||||
|     assert(0); |     assert(0); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   inline void outerProductImpl(PropagatorField &mat, const FermionField &Btilde, const FermionField &A){ | ||||||
|  |     assert(0); | ||||||
|  |   }  | ||||||
|  |  | ||||||
|  |   inline void TraceSpinImpl(GaugeLinkField &mat, PropagatorField&P) { | ||||||
|  |     assert(0); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   inline void extractLinkField(std::vector<GaugeLinkField> &mat, DoubledGaugeField &Uds){ | ||||||
|  |     assert(0); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|   inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã, int mu) { |   inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã, int mu) { | ||||||
|  |  | ||||||
|     assert(0); |     assert(0); | ||||||
| @@ -636,6 +663,25 @@ class GparityWilsonImpl : public ConjugateGaugeImpl<GaugeImplTypes<S, Nrepresent | |||||||
|    return; |    return; | ||||||
|  } |  } | ||||||
|        |        | ||||||
|  |  inline void outerProductImpl(PropagatorField &mat, const FermionField &Btilde, const FermionField &A){ | ||||||
|  |    //mat = outerProduct(Btilde, A); | ||||||
|  |    assert(0); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   inline void TraceSpinImpl(GaugeLinkField &mat, PropagatorField&P) { | ||||||
|  |     assert(0); | ||||||
|  |     /* | ||||||
|  |     auto tmp = TraceIndex<SpinIndex>(P); | ||||||
|  |     parallel_for(auto ss = tmp.begin(); ss < tmp.end(); ss++) { | ||||||
|  |       mat[ss]() = tmp[ss](0, 0) + conjugate(tmp[ss](1, 1)); | ||||||
|  |     } | ||||||
|  |     */ | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   inline void extractLinkField(std::vector<GaugeLinkField> &mat, DoubledGaugeField &Uds){ | ||||||
|  |     assert(0); | ||||||
|  |   } | ||||||
|  |    | ||||||
|  inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã, int mu) { |  inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã, int mu) { | ||||||
|  |  | ||||||
|    int Ls = Btilde._grid->_fdimensions[0]; |    int Ls = Btilde._grid->_fdimensions[0]; | ||||||
| @@ -776,8 +822,8 @@ class StaggeredImpl : public PeriodicGaugeImpl<GaugeImplTypes<S, Representation: | |||||||
|       GaugeLinkField link(mat._grid); |       GaugeLinkField link(mat._grid); | ||||||
|       link = TraceIndex<SpinIndex>(outerProduct(Btilde,A));  |       link = TraceIndex<SpinIndex>(outerProduct(Btilde,A));  | ||||||
|       PokeIndex<LorentzIndex>(mat,link,mu); |       PokeIndex<LorentzIndex>(mat,link,mu); | ||||||
|     }    |     }  | ||||||
|        |            | ||||||
|     inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã,int mu){ |     inline void InsertForce5D(GaugeField &mat, FermionField &Btilde, FermionField Ã,int mu){ | ||||||
|       assert (0);  |       assert (0);  | ||||||
|       // Must never hit |       // Must never hit | ||||||
| @@ -983,6 +1029,10 @@ typedef WilsonImpl<vComplex,  TwoIndexSymmetricRepresentation, CoeffReal > Wilso | |||||||
| typedef WilsonImpl<vComplexF, TwoIndexSymmetricRepresentation, CoeffReal > WilsonTwoIndexSymmetricImplF;  // Float | typedef WilsonImpl<vComplexF, TwoIndexSymmetricRepresentation, CoeffReal > WilsonTwoIndexSymmetricImplF;  // Float | ||||||
| typedef WilsonImpl<vComplexD, TwoIndexSymmetricRepresentation, CoeffReal > WilsonTwoIndexSymmetricImplD;  // Double | typedef WilsonImpl<vComplexD, TwoIndexSymmetricRepresentation, CoeffReal > WilsonTwoIndexSymmetricImplD;  // Double | ||||||
|   |   | ||||||
|  | typedef WilsonImpl<vComplex,  TwoIndexAntiSymmetricRepresentation, CoeffReal > WilsonTwoIndexAntiSymmetricImplR;   // Real.. whichever prec | ||||||
|  | typedef WilsonImpl<vComplexF, TwoIndexAntiSymmetricRepresentation, CoeffReal > WilsonTwoIndexAntiSymmetricImplF;  // Float | ||||||
|  | typedef WilsonImpl<vComplexD, TwoIndexAntiSymmetricRepresentation, CoeffReal > WilsonTwoIndexAntiSymmetricImplD;  // Double | ||||||
|  |  | ||||||
| typedef DomainWallVec5dImpl<vComplex ,Nc, CoeffReal> DomainWallVec5dImplR; // Real.. whichever prec | typedef DomainWallVec5dImpl<vComplex ,Nc, CoeffReal> DomainWallVec5dImplR; // Real.. whichever prec | ||||||
| typedef DomainWallVec5dImpl<vComplexF,Nc, CoeffReal> DomainWallVec5dImplF; // Float | typedef DomainWallVec5dImpl<vComplexF,Nc, CoeffReal> DomainWallVec5dImplF; // Float | ||||||
| typedef DomainWallVec5dImpl<vComplexD,Nc, CoeffReal> DomainWallVec5dImplD; // Double | typedef DomainWallVec5dImpl<vComplexD,Nc, CoeffReal> DomainWallVec5dImplD; // Double | ||||||
|   | |||||||
							
								
								
									
										243
									
								
								lib/qcd/action/fermion/WilsonCloverFermion.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										243
									
								
								lib/qcd/action/fermion/WilsonCloverFermion.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,243 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  |     Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |  | ||||||
|  |     Source file: ./lib/qcd/action/fermion/WilsonCloverFermion.cc | ||||||
|  |  | ||||||
|  |     Copyright (C) 2017 | ||||||
|  |  | ||||||
|  |     Author: paboyle <paboyle@ph.ed.ac.uk> | ||||||
|  |     Author: Guido Cossu <guido.cossu@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 */ | ||||||
|  | #include <Grid/Grid.h> | ||||||
|  | #include <Grid/Eigen/Dense> | ||||||
|  | #include <Grid/qcd/spin/Dirac.h> | ||||||
|  |  | ||||||
|  | namespace Grid | ||||||
|  | { | ||||||
|  | namespace QCD | ||||||
|  | { | ||||||
|  |  | ||||||
|  | // *NOT* EO | ||||||
|  | template <class Impl> | ||||||
|  | RealD WilsonCloverFermion<Impl>::M(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   FermionField temp(out._grid); | ||||||
|  |  | ||||||
|  |   // Wilson term | ||||||
|  |   out.checkerboard = in.checkerboard; | ||||||
|  |   this->Dhop(in, out, DaggerNo); | ||||||
|  |  | ||||||
|  |   // Clover term | ||||||
|  |   Mooee(in, temp); | ||||||
|  |  | ||||||
|  |   out += temp; | ||||||
|  |   return norm2(out); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | RealD WilsonCloverFermion<Impl>::Mdag(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   FermionField temp(out._grid); | ||||||
|  |  | ||||||
|  |   // Wilson term | ||||||
|  |   out.checkerboard = in.checkerboard; | ||||||
|  |   this->Dhop(in, out, DaggerYes); | ||||||
|  |  | ||||||
|  |   // Clover term | ||||||
|  |   MooeeDag(in, temp); | ||||||
|  |  | ||||||
|  |   out += temp; | ||||||
|  |   return norm2(out); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::ImportGauge(const GaugeField &_Umu) | ||||||
|  | { | ||||||
|  |   WilsonFermion<Impl>::ImportGauge(_Umu); | ||||||
|  |   GridBase *grid = _Umu._grid; | ||||||
|  |   typename Impl::GaugeLinkField Bx(grid), By(grid), Bz(grid), Ex(grid), Ey(grid), Ez(grid); | ||||||
|  |  | ||||||
|  |   // Compute the field strength terms mu>nu | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(Bx, _Umu, Zdir, Ydir); | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(By, _Umu, Zdir, Xdir); | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(Bz, _Umu, Ydir, Xdir); | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(Ex, _Umu, Tdir, Xdir); | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(Ey, _Umu, Tdir, Ydir); | ||||||
|  |   WilsonLoops<Impl>::FieldStrength(Ez, _Umu, Tdir, Zdir); | ||||||
|  |  | ||||||
|  |   // Compute the Clover Operator acting on Colour and Spin | ||||||
|  |   // multiply here by the clover coefficients for the anisotropy | ||||||
|  |   CloverTerm  = fillCloverYZ(Bx) * csw_r; | ||||||
|  |   CloverTerm += fillCloverXZ(By) * csw_r; | ||||||
|  |   CloverTerm += fillCloverXY(Bz) * csw_r; | ||||||
|  |   CloverTerm += fillCloverXT(Ex) * csw_t; | ||||||
|  |   CloverTerm += fillCloverYT(Ey) * csw_t; | ||||||
|  |   CloverTerm += fillCloverZT(Ez) * csw_t; | ||||||
|  |   CloverTerm += diag_mass; | ||||||
|  |  | ||||||
|  |   int lvol = _Umu._grid->lSites(); | ||||||
|  |   int DimRep = Impl::Dimension; | ||||||
|  |  | ||||||
|  |   Eigen::MatrixXcd EigenCloverOp = Eigen::MatrixXcd::Zero(Ns * DimRep, Ns * DimRep); | ||||||
|  |   Eigen::MatrixXcd EigenInvCloverOp = Eigen::MatrixXcd::Zero(Ns * DimRep, Ns * DimRep); | ||||||
|  |  | ||||||
|  |   std::vector<int> lcoor; | ||||||
|  |   typename SiteCloverType::scalar_object Qx = zero, Qxinv = zero; | ||||||
|  |  | ||||||
|  |   for (int site = 0; site < lvol; site++) | ||||||
|  |   { | ||||||
|  |     grid->LocalIndexToLocalCoor(site, lcoor); | ||||||
|  |     EigenCloverOp = Eigen::MatrixXcd::Zero(Ns * DimRep, Ns * DimRep); | ||||||
|  |     peekLocalSite(Qx, CloverTerm, lcoor); | ||||||
|  |     Qxinv = zero; | ||||||
|  |     //if (csw!=0){ | ||||||
|  |     for (int j = 0; j < Ns; j++) | ||||||
|  |       for (int k = 0; k < Ns; k++) | ||||||
|  |         for (int a = 0; a < DimRep; a++) | ||||||
|  |           for (int b = 0; b < DimRep; b++) | ||||||
|  |             EigenCloverOp(a + j * DimRep, b + k * DimRep) = Qx()(j, k)(a, b); | ||||||
|  |     //   if (site==0) std::cout << "site =" << site << "\n" << EigenCloverOp << std::endl; | ||||||
|  |  | ||||||
|  |     EigenInvCloverOp = EigenCloverOp.inverse(); | ||||||
|  |     //std::cout << EigenInvCloverOp << std::endl; | ||||||
|  |     for (int j = 0; j < Ns; j++) | ||||||
|  |       for (int k = 0; k < Ns; k++) | ||||||
|  |         for (int a = 0; a < DimRep; a++) | ||||||
|  |           for (int b = 0; b < DimRep; b++) | ||||||
|  |             Qxinv()(j, k)(a, b) = EigenInvCloverOp(a + j * DimRep, b + k * DimRep); | ||||||
|  |     //    if (site==0) std::cout << "site =" << site << "\n" << EigenInvCloverOp << std::endl; | ||||||
|  |     //  } | ||||||
|  |     pokeLocalSite(Qxinv, CloverTermInv, lcoor); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // Separate the even and odd parts | ||||||
|  |   pickCheckerboard(Even, CloverTermEven, CloverTerm); | ||||||
|  |   pickCheckerboard(Odd, CloverTermOdd, CloverTerm); | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, CloverTermDagEven, adj(CloverTerm)); | ||||||
|  |   pickCheckerboard(Odd, CloverTermDagOdd, adj(CloverTerm)); | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, CloverTermInvEven, CloverTermInv); | ||||||
|  |   pickCheckerboard(Odd, CloverTermInvOdd, CloverTermInv); | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, CloverTermInvDagEven, adj(CloverTermInv)); | ||||||
|  |   pickCheckerboard(Odd, CloverTermInvDagOdd, adj(CloverTermInv)); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::Mooee(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   this->MooeeInternal(in, out, DaggerNo, InverseNo); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MooeeDag(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   this->MooeeInternal(in, out, DaggerYes, InverseNo); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MooeeInv(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   this->MooeeInternal(in, out, DaggerNo, InverseYes); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MooeeInvDag(const FermionField &in, FermionField &out) | ||||||
|  | { | ||||||
|  |   this->MooeeInternal(in, out, DaggerYes, InverseYes); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MooeeInternal(const FermionField &in, FermionField &out, int dag, int inv) | ||||||
|  | { | ||||||
|  |   out.checkerboard = in.checkerboard; | ||||||
|  |   CloverFieldType *Clover; | ||||||
|  |   assert(in.checkerboard == Odd || in.checkerboard == Even); | ||||||
|  |  | ||||||
|  |   if (dag) | ||||||
|  |   { | ||||||
|  |     if (in._grid->_isCheckerBoarded) | ||||||
|  |     { | ||||||
|  |       if (in.checkerboard == Odd) | ||||||
|  |       { | ||||||
|  |         Clover = (inv) ? &CloverTermInvDagOdd : &CloverTermDagOdd; | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         Clover = (inv) ? &CloverTermInvDagEven : &CloverTermDagEven; | ||||||
|  |       } | ||||||
|  |       out = *Clover * in; | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |       Clover = (inv) ? &CloverTermInv : &CloverTerm; | ||||||
|  |       out = adj(*Clover) * in; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     if (in._grid->_isCheckerBoarded) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |       if (in.checkerboard == Odd) | ||||||
|  |       { | ||||||
|  |         //  std::cout << "Calling clover term Odd" << std::endl; | ||||||
|  |         Clover = (inv) ? &CloverTermInvOdd : &CloverTermOdd; | ||||||
|  |       } | ||||||
|  |       else | ||||||
|  |       { | ||||||
|  |         //  std::cout << "Calling clover term Even" << std::endl; | ||||||
|  |         Clover = (inv) ? &CloverTermInvEven : &CloverTermEven; | ||||||
|  |       } | ||||||
|  |       out = *Clover * in; | ||||||
|  |       //  std::cout << GridLogMessage << "*Clover.checkerboard "  << (*Clover).checkerboard << std::endl; | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |       Clover = (inv) ? &CloverTermInv : &CloverTerm; | ||||||
|  |       out = *Clover * in; | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | } // MooeeInternal | ||||||
|  |  | ||||||
|  |  | ||||||
|  | // Derivative parts | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MooDeriv(GaugeField &mat, const FermionField &X, const FermionField &Y, int dag) | ||||||
|  | { | ||||||
|  |   assert(0); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // Derivative parts | ||||||
|  | template <class Impl> | ||||||
|  | void WilsonCloverFermion<Impl>::MeeDeriv(GaugeField &mat, const FermionField &U, const FermionField &V, int dag) | ||||||
|  | { | ||||||
|  |   assert(0); // not implemented yet | ||||||
|  | } | ||||||
|  |  | ||||||
|  | FermOpTemplateInstantiate(WilsonCloverFermion); | ||||||
|  | AdjointFermOpTemplateInstantiate(WilsonCloverFermion); | ||||||
|  | TwoIndexFermOpTemplateInstantiate(WilsonCloverFermion); | ||||||
|  | //GparityFermOpTemplateInstantiate(WilsonCloverFermion); | ||||||
|  | } | ||||||
|  | } | ||||||
							
								
								
									
										366
									
								
								lib/qcd/action/fermion/WilsonCloverFermion.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										366
									
								
								lib/qcd/action/fermion/WilsonCloverFermion.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,366 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  |     Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |  | ||||||
|  |     Source file: ./lib/qcd/action/fermion/WilsonCloverFermion.h | ||||||
|  |  | ||||||
|  |     Copyright (C) 2017 | ||||||
|  |  | ||||||
|  |     Author: Guido Cossu <guido.cossu@ed.ac.uk> | ||||||
|  |     Author: David Preti <> | ||||||
|  |  | ||||||
|  |     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 GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
|  | #define GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
|  |  | ||||||
|  | #include <Grid/Grid.h> | ||||||
|  |  | ||||||
|  | namespace Grid | ||||||
|  | { | ||||||
|  | namespace QCD | ||||||
|  | { | ||||||
|  |  | ||||||
|  | /////////////////////////////////////////////////////////////////// | ||||||
|  | // Wilson Clover | ||||||
|  | // | ||||||
|  | // Operator ( with anisotropy coefficients): | ||||||
|  | // | ||||||
|  | // Q =   1 + (Nd-1)/xi_0 + m | ||||||
|  | //     + W_t + (nu/xi_0) * W_s | ||||||
|  | //     - 1/2*[ csw_t * sum_s (sigma_ts F_ts) + (csw_s/xi_0) * sum_ss (sigma_ss F_ss)  ] | ||||||
|  | // | ||||||
|  | // s spatial, t temporal directions. | ||||||
|  | // where W_t and W_s are the temporal and spatial components of the | ||||||
|  | // Wilson Dirac operator | ||||||
|  | // | ||||||
|  | // csw_r = csw_t to recover the isotropic version | ||||||
|  | ////////////////////////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  | template <class Impl> | ||||||
|  | class WilsonCloverFermion : public WilsonFermion<Impl> | ||||||
|  | { | ||||||
|  | public: | ||||||
|  |   // Types definitions | ||||||
|  |   INHERIT_IMPL_TYPES(Impl); | ||||||
|  |   template <typename vtype> | ||||||
|  |   using iImplClover = iScalar<iMatrix<iMatrix<vtype, Impl::Dimension>, Ns>>; | ||||||
|  |   typedef iImplClover<Simd> SiteCloverType; | ||||||
|  |   typedef Lattice<SiteCloverType> CloverFieldType; | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |   typedef WilsonFermion<Impl> WilsonBase; | ||||||
|  |  | ||||||
|  |   virtual void Instantiatable(void){}; | ||||||
|  |   // Constructors | ||||||
|  |   WilsonCloverFermion(GaugeField &_Umu, GridCartesian &Fgrid, | ||||||
|  |                       GridRedBlackCartesian &Hgrid, | ||||||
|  |                       const RealD _mass, | ||||||
|  |                       const RealD _csw_r = 0.0, | ||||||
|  |                       const RealD _csw_t = 0.0, | ||||||
|  |                       const WilsonAnisotropyCoefficients &clover_anisotropy = WilsonAnisotropyCoefficients(), | ||||||
|  |                       const ImplParams &impl_p = ImplParams()) : WilsonFermion<Impl>(_Umu, | ||||||
|  |                                                                                      Fgrid, | ||||||
|  |                                                                                      Hgrid, | ||||||
|  |                                                                                      _mass, impl_p, clover_anisotropy), | ||||||
|  |                                                                  CloverTerm(&Fgrid), | ||||||
|  |                                                                  CloverTermInv(&Fgrid), | ||||||
|  |                                                                  CloverTermEven(&Hgrid), | ||||||
|  |                                                                  CloverTermOdd(&Hgrid), | ||||||
|  |                                                                  CloverTermInvEven(&Hgrid), | ||||||
|  |                                                                  CloverTermInvOdd(&Hgrid), | ||||||
|  |                                                                  CloverTermDagEven(&Hgrid), | ||||||
|  |                                                                  CloverTermDagOdd(&Hgrid), | ||||||
|  |                                                                  CloverTermInvDagEven(&Hgrid), | ||||||
|  |                                                                  CloverTermInvDagOdd(&Hgrid) | ||||||
|  |   { | ||||||
|  |     assert(Nd == 4); // require 4 dimensions | ||||||
|  |  | ||||||
|  |     if (clover_anisotropy.isAnisotropic) | ||||||
|  |     { | ||||||
|  |       csw_r = _csw_r * 0.5 / clover_anisotropy.xi_0; | ||||||
|  |       diag_mass = _mass + 1.0 + (Nd - 1) * (clover_anisotropy.nu / clover_anisotropy.xi_0); | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |       csw_r = _csw_r * 0.5; | ||||||
|  |       diag_mass = 4.0 + _mass; | ||||||
|  |     } | ||||||
|  |     csw_t = _csw_t * 0.5; | ||||||
|  |  | ||||||
|  |     if (csw_r == 0) | ||||||
|  |       std::cout << GridLogWarning << "Initializing WilsonCloverFermion with csw_r = 0" << std::endl; | ||||||
|  |     if (csw_t == 0) | ||||||
|  |       std::cout << GridLogWarning << "Initializing WilsonCloverFermion with csw_t = 0" << std::endl; | ||||||
|  |  | ||||||
|  |     ImportGauge(_Umu); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   virtual RealD M(const FermionField &in, FermionField &out); | ||||||
|  |   virtual RealD Mdag(const FermionField &in, FermionField &out); | ||||||
|  |  | ||||||
|  |   virtual void Mooee(const FermionField &in, FermionField &out); | ||||||
|  |   virtual void MooeeDag(const FermionField &in, FermionField &out); | ||||||
|  |   virtual void MooeeInv(const FermionField &in, FermionField &out); | ||||||
|  |   virtual void MooeeInvDag(const FermionField &in, FermionField &out); | ||||||
|  |   virtual void MooeeInternal(const FermionField &in, FermionField &out, int dag, int inv); | ||||||
|  |  | ||||||
|  |   //virtual void MDeriv(GaugeField &mat, const FermionField &U, const FermionField &V, int dag); | ||||||
|  |   virtual void MooDeriv(GaugeField &mat, const FermionField &U, const FermionField &V, int dag); | ||||||
|  |   virtual void MeeDeriv(GaugeField &mat, const FermionField &U, const FermionField &V, int dag); | ||||||
|  |  | ||||||
|  |   void ImportGauge(const GaugeField &_Umu); | ||||||
|  |  | ||||||
|  |   // Derivative parts unpreconditioned pseudofermions | ||||||
|  |   void MDeriv(GaugeField &force, const FermionField &X, const FermionField &Y, int dag) | ||||||
|  |   { | ||||||
|  |     conformable(X._grid, Y._grid); | ||||||
|  |     conformable(X._grid, force._grid); | ||||||
|  |     GaugeLinkField force_mu(force._grid), lambda(force._grid); | ||||||
|  |     GaugeField clover_force(force._grid); | ||||||
|  |     PropagatorField Lambda(force._grid); | ||||||
|  |  | ||||||
|  |     // Guido: Here we are hitting some performance issues: | ||||||
|  |     // need to extract the components of the DoubledGaugeField | ||||||
|  |     // for each call | ||||||
|  |     // Possible solution | ||||||
|  |     // Create a vector object to store them? (cons: wasting space) | ||||||
|  |     std::vector<GaugeLinkField> U(Nd, this->Umu._grid); | ||||||
|  |  | ||||||
|  |     Impl::extractLinkField(U, this->Umu); | ||||||
|  |  | ||||||
|  |     force = zero; | ||||||
|  |     // Derivative of the Wilson hopping term | ||||||
|  |     this->DhopDeriv(force, X, Y, dag); | ||||||
|  |  | ||||||
|  |     /////////////////////////////////////////////////////////// | ||||||
|  |     // Clover term derivative | ||||||
|  |     /////////////////////////////////////////////////////////// | ||||||
|  |     Impl::outerProductImpl(Lambda, X, Y); | ||||||
|  |     //std::cout << "Lambda:" << Lambda << std::endl; | ||||||
|  |  | ||||||
|  |     Gamma::Algebra sigma[] = { | ||||||
|  |         Gamma::Algebra::SigmaXY, | ||||||
|  |         Gamma::Algebra::SigmaXZ, | ||||||
|  |         Gamma::Algebra::SigmaXT, | ||||||
|  |         Gamma::Algebra::MinusSigmaXY, | ||||||
|  |         Gamma::Algebra::SigmaYZ, | ||||||
|  |         Gamma::Algebra::SigmaYT, | ||||||
|  |         Gamma::Algebra::MinusSigmaXZ, | ||||||
|  |         Gamma::Algebra::MinusSigmaYZ, | ||||||
|  |         Gamma::Algebra::SigmaZT, | ||||||
|  |         Gamma::Algebra::MinusSigmaXT, | ||||||
|  |         Gamma::Algebra::MinusSigmaYT, | ||||||
|  |         Gamma::Algebra::MinusSigmaZT}; | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |       sigma_{\mu \nu}= | ||||||
|  |       | 0         sigma[0]  sigma[1]  sigma[2] | | ||||||
|  |       | sigma[3]    0       sigma[4]  sigma[5] | | ||||||
|  |       | sigma[6]  sigma[7]     0      sigma[8] | | ||||||
|  |       | sigma[9]  sigma[10] sigma[11]   0      | | ||||||
|  |     */ | ||||||
|  |  | ||||||
|  |     int count = 0; | ||||||
|  |     clover_force = zero; | ||||||
|  |     for (int mu = 0; mu < 4; mu++) | ||||||
|  |     { | ||||||
|  |       force_mu = zero; | ||||||
|  |       for (int nu = 0; nu < 4; nu++) | ||||||
|  |       { | ||||||
|  |         if (mu == nu) | ||||||
|  |         continue; | ||||||
|  |          | ||||||
|  |         RealD factor; | ||||||
|  |         if (nu == 4 || mu == 4) | ||||||
|  |         { | ||||||
|  |           factor = 2.0 * csw_t; | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |           factor = 2.0 * csw_r; | ||||||
|  |         } | ||||||
|  |         PropagatorField Slambda = Gamma(sigma[count]) * Lambda; // sigma checked | ||||||
|  |         Impl::TraceSpinImpl(lambda, Slambda);                   // traceSpin ok | ||||||
|  |         force_mu -= factor*Cmunu(U, lambda, mu, nu);                   // checked | ||||||
|  |         count++; | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       pokeLorentz(clover_force, U[mu] * force_mu, mu); | ||||||
|  |     } | ||||||
|  |     //clover_force *= csw; | ||||||
|  |     force += clover_force; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   // Computing C_{\mu \nu}(x) as in Eq.(B.39) in Zbigniew Sroczynski's PhD thesis | ||||||
|  |   GaugeLinkField Cmunu(std::vector<GaugeLinkField> &U, GaugeLinkField &lambda, int mu, int nu) | ||||||
|  |   { | ||||||
|  |     conformable(lambda._grid, U[0]._grid); | ||||||
|  |     GaugeLinkField out(lambda._grid), tmp(lambda._grid); | ||||||
|  |     // insertion in upper staple | ||||||
|  |     // please check redundancy of shift operations | ||||||
|  |  | ||||||
|  |     // C1+ | ||||||
|  |     tmp = lambda * U[nu]; | ||||||
|  |     out = Impl::ShiftStaple(Impl::CovShiftForward(tmp, nu, Impl::CovShiftBackward(U[mu], mu, Impl::CovShiftIdentityBackward(U[nu], nu))), mu); | ||||||
|  |  | ||||||
|  |     // C2+ | ||||||
|  |     tmp = U[mu] * Impl::ShiftStaple(adj(lambda), mu); | ||||||
|  |     out += Impl::ShiftStaple(Impl::CovShiftForward(U[nu], nu, Impl::CovShiftBackward(tmp, mu, Impl::CovShiftIdentityBackward(U[nu], nu))), mu); | ||||||
|  |  | ||||||
|  |     // C3+ | ||||||
|  |     tmp = U[nu] * Impl::ShiftStaple(adj(lambda), nu); | ||||||
|  |     out += Impl::ShiftStaple(Impl::CovShiftForward(U[nu], nu, Impl::CovShiftBackward(U[mu], mu, Impl::CovShiftIdentityBackward(tmp, nu))), mu); | ||||||
|  |  | ||||||
|  |     // C4+ | ||||||
|  |     out += Impl::ShiftStaple(Impl::CovShiftForward(U[nu], nu, Impl::CovShiftBackward(U[mu], mu, Impl::CovShiftIdentityBackward(U[nu], nu))), mu) * lambda; | ||||||
|  |  | ||||||
|  |     // insertion in lower staple | ||||||
|  |     // C1- | ||||||
|  |     out -= Impl::ShiftStaple(lambda, mu) * Impl::ShiftStaple(Impl::CovShiftBackward(U[nu], nu, Impl::CovShiftBackward(U[mu], mu, U[nu])), mu); | ||||||
|  |  | ||||||
|  |     // C2- | ||||||
|  |     tmp = adj(lambda) * U[nu]; | ||||||
|  |     out -= Impl::ShiftStaple(Impl::CovShiftBackward(tmp, nu, Impl::CovShiftBackward(U[mu], mu, U[nu])), mu); | ||||||
|  |  | ||||||
|  |     // C3- | ||||||
|  |     tmp = lambda * U[nu]; | ||||||
|  |     out -= Impl::ShiftStaple(Impl::CovShiftBackward(U[nu], nu, Impl::CovShiftBackward(U[mu], mu, tmp)), mu); | ||||||
|  |  | ||||||
|  |     // C4- | ||||||
|  |     out -= Impl::ShiftStaple(Impl::CovShiftBackward(U[nu], nu, Impl::CovShiftBackward(U[mu], mu, U[nu])), mu) * lambda; | ||||||
|  |  | ||||||
|  |     return out; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  | private: | ||||||
|  |   // here fixing the 4 dimensions, make it more general? | ||||||
|  |  | ||||||
|  |   RealD csw_r;                                               // Clover coefficient - spatial | ||||||
|  |   RealD csw_t;                                               // Clover coefficient - temporal | ||||||
|  |   RealD diag_mass;                                           // Mass term | ||||||
|  |   CloverFieldType CloverTerm, CloverTermInv;                 // Clover term | ||||||
|  |   CloverFieldType CloverTermEven, CloverTermOdd;             // Clover term EO | ||||||
|  |   CloverFieldType CloverTermInvEven, CloverTermInvOdd;       // Clover term Inv EO | ||||||
|  |   CloverFieldType CloverTermDagEven, CloverTermDagOdd;       // Clover term Dag EO | ||||||
|  |   CloverFieldType CloverTermInvDagEven, CloverTermInvDagOdd; // Clover term Inv Dag EO | ||||||
|  |  | ||||||
|  |   // eventually these can be compressed into 6x6 blocks instead of the 12x12 | ||||||
|  |   // using the DeGrand-Rossi basis for the gamma matrices | ||||||
|  |   CloverFieldType fillCloverYZ(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |       T._odata[i]()(0, 1) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(1, 0) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(2, 3) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(3, 2) = timesMinusI(F._odata[i]()()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CloverFieldType fillCloverXZ(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |       T._odata[i]()(0, 1) = -F._odata[i]()(); | ||||||
|  |       T._odata[i]()(1, 0) = F._odata[i]()(); | ||||||
|  |       T._odata[i]()(2, 3) = -F._odata[i]()(); | ||||||
|  |       T._odata[i]()(3, 2) = F._odata[i]()(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CloverFieldType fillCloverXY(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  |       T._odata[i]()(0, 0) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(1, 1) = timesI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(2, 2) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(3, 3) = timesI(F._odata[i]()()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CloverFieldType fillCloverXT(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |       T._odata[i]()(0, 1) = timesI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(1, 0) = timesI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(2, 3) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(3, 2) = timesMinusI(F._odata[i]()()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CloverFieldType fillCloverYT(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |       T._odata[i]()(0, 1) = -(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(1, 0) = (F._odata[i]()()); | ||||||
|  |       T._odata[i]()(2, 3) = (F._odata[i]()()); | ||||||
|  |       T._odata[i]()(3, 2) = -(F._odata[i]()()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   CloverFieldType fillCloverZT(const GaugeLinkField &F) | ||||||
|  |   { | ||||||
|  |     CloverFieldType T(F._grid); | ||||||
|  |     T = zero; | ||||||
|  |     PARALLEL_FOR_LOOP | ||||||
|  |     for (int i = 0; i < CloverTerm._grid->oSites(); i++) | ||||||
|  |     { | ||||||
|  |       T._odata[i]()(0, 0) = timesI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(1, 1) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(2, 2) = timesMinusI(F._odata[i]()()); | ||||||
|  |       T._odata[i]()(3, 3) = timesI(F._odata[i]()()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return T; | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  | } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #endif // GRID_QCD_WILSON_CLOVER_FERMION_H | ||||||
| @@ -47,7 +47,8 @@ int WilsonFermionStatic::HandOptDslash; | |||||||
| template <class Impl> | template <class Impl> | ||||||
| WilsonFermion<Impl>::WilsonFermion(GaugeField &_Umu, GridCartesian &Fgrid, | WilsonFermion<Impl>::WilsonFermion(GaugeField &_Umu, GridCartesian &Fgrid, | ||||||
|                                    GridRedBlackCartesian &Hgrid, RealD _mass, |                                    GridRedBlackCartesian &Hgrid, RealD _mass, | ||||||
|                                    const ImplParams &p) |                                    const ImplParams &p, | ||||||
|  |                                    const WilsonAnisotropyCoefficients &anis) | ||||||
|     : Kernels(p), |     : Kernels(p), | ||||||
|       _grid(&Fgrid), |       _grid(&Fgrid), | ||||||
|       _cbgrid(&Hgrid), |       _cbgrid(&Hgrid), | ||||||
| @@ -60,16 +61,41 @@ WilsonFermion<Impl>::WilsonFermion(GaugeField &_Umu, GridCartesian &Fgrid, | |||||||
|       Umu(&Fgrid), |       Umu(&Fgrid), | ||||||
|       UmuEven(&Hgrid), |       UmuEven(&Hgrid), | ||||||
|       UmuOdd(&Hgrid), |       UmuOdd(&Hgrid), | ||||||
|       _tmp(&Hgrid) |       _tmp(&Hgrid), | ||||||
|  |       anisotropyCoeff(anis) | ||||||
| { | { | ||||||
|   // Allocate the required comms buffer |   // Allocate the required comms buffer | ||||||
|   ImportGauge(_Umu); |   ImportGauge(_Umu); | ||||||
|  |   if  (anisotropyCoeff.isAnisotropic){ | ||||||
|  |     diag_mass = mass + 1.0 + (Nd-1)*(anisotropyCoeff.nu / anisotropyCoeff.xi_0); | ||||||
|  |   } else { | ||||||
|  |     diag_mass = 4.0 + mass; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class Impl> | template <class Impl> | ||||||
| void WilsonFermion<Impl>::ImportGauge(const GaugeField &_Umu) { | void WilsonFermion<Impl>::ImportGauge(const GaugeField &_Umu) { | ||||||
|   GaugeField HUmu(_Umu._grid); |   GaugeField HUmu(_Umu._grid); | ||||||
|   HUmu = _Umu * (-0.5); |  | ||||||
|  |   //Here multiply the anisotropy coefficients | ||||||
|  |   if (anisotropyCoeff.isAnisotropic) | ||||||
|  |   { | ||||||
|  |  | ||||||
|  |     for (int mu = 0; mu < Nd; mu++) | ||||||
|  |     { | ||||||
|  |       GaugeLinkField U_dir = (-0.5)*PeekIndex<LorentzIndex>(_Umu, mu); | ||||||
|  |       if (mu != anisotropyCoeff.t_direction) | ||||||
|  |         U_dir *= (anisotropyCoeff.nu / anisotropyCoeff.xi_0); | ||||||
|  |  | ||||||
|  |       PokeIndex<LorentzIndex>(HUmu, U_dir, mu); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   else | ||||||
|  |   { | ||||||
|  |     HUmu = _Umu * (-0.5); | ||||||
|  |   } | ||||||
|   Impl::DoubleStore(GaugeGrid(), Umu, HUmu); |   Impl::DoubleStore(GaugeGrid(), Umu, HUmu); | ||||||
|   pickCheckerboard(Even, UmuEven, Umu); |   pickCheckerboard(Even, UmuEven, Umu); | ||||||
|   pickCheckerboard(Odd, UmuOdd, Umu); |   pickCheckerboard(Odd, UmuOdd, Umu); | ||||||
| @@ -83,14 +109,14 @@ template <class Impl> | |||||||
| RealD WilsonFermion<Impl>::M(const FermionField &in, FermionField &out) { | RealD WilsonFermion<Impl>::M(const FermionField &in, FermionField &out) { | ||||||
|   out.checkerboard = in.checkerboard; |   out.checkerboard = in.checkerboard; | ||||||
|   Dhop(in, out, DaggerNo); |   Dhop(in, out, DaggerNo); | ||||||
|   return axpy_norm(out, 4 + mass, in, out); |   return axpy_norm(out, diag_mass, in, out); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class Impl> | template <class Impl> | ||||||
| RealD WilsonFermion<Impl>::Mdag(const FermionField &in, FermionField &out) { | RealD WilsonFermion<Impl>::Mdag(const FermionField &in, FermionField &out) { | ||||||
|   out.checkerboard = in.checkerboard; |   out.checkerboard = in.checkerboard; | ||||||
|   Dhop(in, out, DaggerYes); |   Dhop(in, out, DaggerYes); | ||||||
|   return axpy_norm(out, 4 + mass, in, out); |   return axpy_norm(out, diag_mass, in, out); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <class Impl> | template <class Impl> | ||||||
| @@ -114,7 +140,7 @@ void WilsonFermion<Impl>::MeooeDag(const FermionField &in, FermionField &out) { | |||||||
| template <class Impl> | template <class Impl> | ||||||
| void WilsonFermion<Impl>::Mooee(const FermionField &in, FermionField &out) { | void WilsonFermion<Impl>::Mooee(const FermionField &in, FermionField &out) { | ||||||
|   out.checkerboard = in.checkerboard; |   out.checkerboard = in.checkerboard; | ||||||
|   typename FermionField::scalar_type scal(4.0 + mass); |   typename FermionField::scalar_type scal(diag_mass); | ||||||
|   out = scal * in; |   out = scal * in; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -127,7 +153,7 @@ void WilsonFermion<Impl>::MooeeDag(const FermionField &in, FermionField &out) { | |||||||
| template<class Impl> | template<class Impl> | ||||||
| void WilsonFermion<Impl>::MooeeInv(const FermionField &in, FermionField &out) { | void WilsonFermion<Impl>::MooeeInv(const FermionField &in, FermionField &out) { | ||||||
|   out.checkerboard = in.checkerboard; |   out.checkerboard = in.checkerboard; | ||||||
|   out = (1.0/(4.0+mass))*in; |   out = (1.0/(diag_mass))*in; | ||||||
| } | } | ||||||
|    |    | ||||||
| template<class Impl> | template<class Impl> | ||||||
| @@ -204,7 +230,7 @@ void WilsonFermion<Impl>::DerivInternal(StencilImpl &st, DoubledGaugeField &U, | |||||||
|  |  | ||||||
|   FermionField Btilde(B._grid); |   FermionField Btilde(B._grid); | ||||||
|   FermionField Atilde(B._grid); |   FermionField Atilde(B._grid); | ||||||
|   Atilde = A; |   Atilde = A;//redundant | ||||||
|  |  | ||||||
|   st.HaloExchange(B, compressor); |   st.HaloExchange(B, compressor); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -44,6 +44,21 @@ class WilsonFermionStatic { | |||||||
|   static const int npoint = 8; |   static const int npoint = 8; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  struct WilsonAnisotropyCoefficients: Serializable | ||||||
|  |  { | ||||||
|  |   GRID_SERIALIZABLE_CLASS_MEMBERS(WilsonAnisotropyCoefficients, | ||||||
|  |   bool, isAnisotropic, | ||||||
|  |   int, t_direction, | ||||||
|  |   double, xi_0, | ||||||
|  |   double, nu); | ||||||
|  |  | ||||||
|  |   WilsonAnisotropyCoefficients(): | ||||||
|  |     isAnisotropic(false),  | ||||||
|  |     t_direction(Nd-1),  | ||||||
|  |     xi_0(1.0),  | ||||||
|  |     nu(1.0){} | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <class Impl> | template <class Impl> | ||||||
| class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | ||||||
|  public: |  public: | ||||||
| @@ -65,8 +80,8 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | |||||||
|   // override multiply; cut number routines if pass dagger argument |   // override multiply; cut number routines if pass dagger argument | ||||||
|   // and also make interface more uniformly consistent |   // and also make interface more uniformly consistent | ||||||
|   ////////////////////////////////////////////////////////////////// |   ////////////////////////////////////////////////////////////////// | ||||||
|   RealD M(const FermionField &in, FermionField &out); |   virtual RealD M(const FermionField &in, FermionField &out); | ||||||
|   RealD Mdag(const FermionField &in, FermionField &out); |   virtual RealD Mdag(const FermionField &in, FermionField &out); | ||||||
|  |  | ||||||
|   ///////////////////////////////////////////////////////// |   ///////////////////////////////////////////////////////// | ||||||
|   // half checkerboard operations |   // half checkerboard operations | ||||||
| @@ -117,8 +132,9 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | |||||||
|  |  | ||||||
|   // Constructor |   // Constructor | ||||||
|   WilsonFermion(GaugeField &_Umu, GridCartesian &Fgrid, |   WilsonFermion(GaugeField &_Umu, GridCartesian &Fgrid, | ||||||
|                 GridRedBlackCartesian &Hgrid, RealD _mass, |                 GridRedBlackCartesian &Hgrid, RealD _mass,  | ||||||
|                 const ImplParams &p = ImplParams()); |                 const ImplParams &p = ImplParams(),  | ||||||
|  |                 const WilsonAnisotropyCoefficients &anis = WilsonAnisotropyCoefficients() ); | ||||||
|  |  | ||||||
|   // DoubleStore impl dependent |   // DoubleStore impl dependent | ||||||
|   void ImportGauge(const GaugeField &_Umu); |   void ImportGauge(const GaugeField &_Umu); | ||||||
| @@ -130,6 +146,7 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | |||||||
|   //    protected: |   //    protected: | ||||||
|  public: |  public: | ||||||
|   RealD mass; |   RealD mass; | ||||||
|  |   RealD diag_mass; | ||||||
|  |  | ||||||
|   GridBase *_grid; |   GridBase *_grid; | ||||||
|   GridBase *_cbgrid; |   GridBase *_cbgrid; | ||||||
| @@ -146,6 +163,8 @@ class WilsonFermion : public WilsonKernels<Impl>, public WilsonFermionStatic { | |||||||
|  |  | ||||||
|   LebesgueOrder Lebesgue; |   LebesgueOrder Lebesgue; | ||||||
|   LebesgueOrder LebesgueEvenOdd; |   LebesgueOrder LebesgueEvenOdd; | ||||||
|  |  | ||||||
|  |   WilsonAnisotropyCoefficients anisotropyCoeff; | ||||||
|    |    | ||||||
|   /////////////////////////////////////////////////////////////// |   /////////////////////////////////////////////////////////////// | ||||||
|   // Conserved current utilities |   // Conserved current utilities | ||||||
|   | |||||||
| @@ -946,5 +946,6 @@ INSTANTIATE_THEM(DomainWallVec5dImplFH); | |||||||
| INSTANTIATE_THEM(DomainWallVec5dImplDF); | INSTANTIATE_THEM(DomainWallVec5dImplDF); | ||||||
| INSTANTIATE_THEM(ZDomainWallVec5dImplFH); | INSTANTIATE_THEM(ZDomainWallVec5dImplFH); | ||||||
| INSTANTIATE_THEM(ZDomainWallVec5dImplDF); | INSTANTIATE_THEM(ZDomainWallVec5dImplDF); | ||||||
|  | INSTANTIATE_THEM(WilsonTwoIndexAntiSymmetricImplF); | ||||||
|  | INSTANTIATE_THEM(WilsonTwoIndexAntiSymmetricImplD); | ||||||
| }} | }} | ||||||
|   | |||||||
| @@ -16,12 +16,12 @@ class ScalarImplTypes { | |||||||
|     typedef iImplField<Simd> SiteField; |     typedef iImplField<Simd> SiteField; | ||||||
|     typedef SiteField        SitePropagator; |     typedef SiteField        SitePropagator; | ||||||
|     typedef SiteField        SiteComplex; |     typedef SiteField        SiteComplex; | ||||||
|      |  | ||||||
|     typedef Lattice<SiteField> Field; |     typedef Lattice<SiteField> Field; | ||||||
|     typedef Field              ComplexField; |     typedef Field              ComplexField; | ||||||
|     typedef Field              FermionField; |     typedef Field              FermionField; | ||||||
|     typedef Field              PropagatorField; |     typedef Field              PropagatorField; | ||||||
|      |  | ||||||
|     static inline void generate_momenta(Field& P, GridParallelRNG& pRNG){ |     static inline void generate_momenta(Field& P, GridParallelRNG& pRNG){ | ||||||
|       gaussian(pRNG, P); |       gaussian(pRNG, P); | ||||||
|     } |     } | ||||||
| @@ -47,54 +47,60 @@ class ScalarImplTypes { | |||||||
|     static inline void ColdConfiguration(GridParallelRNG &pRNG, Field &U) { |     static inline void ColdConfiguration(GridParallelRNG &pRNG, Field &U) { | ||||||
|       U = 1.0; |       U = 1.0; | ||||||
|     } |     } | ||||||
|      |  | ||||||
|     static void MomentumSpacePropagator(Field &out, RealD m) |     static void MomentumSpacePropagator(Field &out, RealD m) | ||||||
|     { |     { | ||||||
|       GridBase           *grid = out._grid; |       GridBase           *grid = out._grid; | ||||||
|       Field              kmu(grid), one(grid); |       Field              kmu(grid), one(grid); | ||||||
|       const unsigned int nd    = grid->_ndimension; |       const unsigned int nd    = grid->_ndimension; | ||||||
|       std::vector<int>   &l    = grid->_fdimensions; |       std::vector<int>   &l    = grid->_fdimensions; | ||||||
|        |  | ||||||
|       one = Complex(1.0,0.0); |       one = Complex(1.0,0.0); | ||||||
|       out = m*m; |       out = m*m; | ||||||
|       for(int mu = 0; mu < nd; mu++) |       for(int mu = 0; mu < nd; mu++) | ||||||
|       { |       { | ||||||
|         Real twoPiL = M_PI*2./l[mu]; |         Real twoPiL = M_PI*2./l[mu]; | ||||||
|          |  | ||||||
|         LatticeCoordinate(kmu,mu); |         LatticeCoordinate(kmu,mu); | ||||||
|         kmu = 2.*sin(.5*twoPiL*kmu); |         kmu = 2.*sin(.5*twoPiL*kmu); | ||||||
|         out = out + kmu*kmu; |         out = out + kmu*kmu; | ||||||
|       } |       } | ||||||
|       out = one/out; |       out = one/out; | ||||||
|     } |     } | ||||||
|      |  | ||||||
|     static void FreePropagator(const Field &in, Field &out, |     static void FreePropagator(const Field &in, Field &out, | ||||||
|                                const Field &momKernel) |                                const Field &momKernel) | ||||||
|     { |     { | ||||||
|       FFT   fft((GridCartesian *)in._grid); |       FFT   fft((GridCartesian *)in._grid); | ||||||
|       Field inFT(in._grid); |       Field inFT(in._grid); | ||||||
|        |  | ||||||
|       fft.FFT_all_dim(inFT, in, FFT::forward); |       fft.FFT_all_dim(inFT, in, FFT::forward); | ||||||
|       inFT = inFT*momKernel; |       inFT = inFT*momKernel; | ||||||
|       fft.FFT_all_dim(out, inFT, FFT::backward); |       fft.FFT_all_dim(out, inFT, FFT::backward); | ||||||
|     } |     } | ||||||
|      |  | ||||||
|     static void FreePropagator(const Field &in, Field &out, RealD m) |     static void FreePropagator(const Field &in, Field &out, RealD m) | ||||||
|     { |     { | ||||||
|       Field momKernel(in._grid); |       Field momKernel(in._grid); | ||||||
|        |  | ||||||
|       MomentumSpacePropagator(momKernel, m); |       MomentumSpacePropagator(momKernel, m); | ||||||
|       FreePropagator(in, out, momKernel); |       FreePropagator(in, out, momKernel); | ||||||
|     } |     } | ||||||
|      |  | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|  |   #ifdef  USE_FFT_ACCELERATION | ||||||
|  |   #ifndef FFT_MASS | ||||||
|  |   #error  "USE_FFT_ACCELERATION is defined but not FFT_MASS" | ||||||
|  |   #endif | ||||||
|  |   #endif | ||||||
|  |    | ||||||
|   template <class S, unsigned int N> |   template <class S, unsigned int N> | ||||||
|   class ScalarAdjMatrixImplTypes { |   class ScalarAdjMatrixImplTypes { | ||||||
|   public: |   public: | ||||||
|     typedef S Simd; |     typedef S Simd; | ||||||
|     typedef QCD::SU<N> Group; |     typedef QCD::SU<N> Group; | ||||||
|      |  | ||||||
|     template <typename vtype> |     template <typename vtype> | ||||||
|     using iImplField   = iScalar<iScalar<iMatrix<vtype, N>>>; |     using iImplField   = iScalar<iScalar<iMatrix<vtype, N>>>; | ||||||
|     template <typename vtype> |     template <typename vtype> | ||||||
| @@ -103,24 +109,119 @@ class ScalarImplTypes { | |||||||
|     typedef iImplField<Simd>   SiteField; |     typedef iImplField<Simd>   SiteField; | ||||||
|     typedef SiteField          SitePropagator; |     typedef SiteField          SitePropagator; | ||||||
|     typedef iImplComplex<Simd> SiteComplex; |     typedef iImplComplex<Simd> SiteComplex; | ||||||
|      |  | ||||||
|     typedef Lattice<SiteField>   Field; |     typedef Lattice<SiteField>   Field; | ||||||
|     typedef Lattice<SiteComplex> ComplexField; |     typedef Lattice<SiteComplex> ComplexField; | ||||||
|     typedef Field                FermionField; |     typedef Field                FermionField; | ||||||
|     typedef Field                PropagatorField; |     typedef Field                PropagatorField; | ||||||
|  |  | ||||||
|     static inline void generate_momenta(Field& P, GridParallelRNG& pRNG) { |     static void MomentaSquare(ComplexField &out) | ||||||
|  |     { | ||||||
|  |       GridBase *grid = out._grid; | ||||||
|  |       const std::vector<int> &l = grid->FullDimensions(); | ||||||
|  |       ComplexField kmu(grid); | ||||||
|  |  | ||||||
|  |       for (int mu = 0; mu < grid->Nd(); mu++) | ||||||
|  |       { | ||||||
|  |         Real twoPiL = M_PI * 2.0 / l[mu]; | ||||||
|  |         LatticeCoordinate(kmu, mu); | ||||||
|  |         kmu = 2.0 * sin(0.5 * twoPiL * kmu); | ||||||
|  |         out += kmu * kmu; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     static void MomentumSpacePropagator(ComplexField &out, RealD m) | ||||||
|  |     { | ||||||
|  |       GridBase *grid = out._grid; | ||||||
|  |       ComplexField one(grid); | ||||||
|  |       one = Complex(1.0, 0.0); | ||||||
|  |       out = m * m; | ||||||
|  |       MomentaSquare(out); | ||||||
|  |       out = one / out; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     static inline void generate_momenta(Field &P, GridParallelRNG &pRNG) | ||||||
|  |     { | ||||||
|  | #ifndef USE_FFT_ACCELERATION | ||||||
|       Group::GaussianFundamentalLieAlgebraMatrix(pRNG, P); |       Group::GaussianFundamentalLieAlgebraMatrix(pRNG, P); | ||||||
|  | #else | ||||||
|  |  | ||||||
|  |       Field Pgaussian(P._grid), Pp(P._grid); | ||||||
|  |       ComplexField p2(P._grid); p2 = zero; | ||||||
|  |       RealD M = FFT_MASS; | ||||||
|  |        | ||||||
|  |       Group::GaussianFundamentalLieAlgebraMatrix(pRNG, Pgaussian); | ||||||
|  |  | ||||||
|  |       FFT theFFT((GridCartesian*)P._grid); | ||||||
|  |       theFFT.FFT_all_dim(Pp, Pgaussian, FFT::forward); | ||||||
|  |       MomentaSquare(p2); | ||||||
|  |       p2 += M * M; | ||||||
|  |       p2 = sqrt(p2); | ||||||
|  |       Pp *= p2; | ||||||
|  |       theFFT.FFT_all_dim(P, Pp, FFT::backward); | ||||||
|  |  | ||||||
|  | #endif //USE_FFT_ACCELERATION | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     static inline Field projectForce(Field& P) {return P;} |     static inline Field projectForce(Field& P) {return P;} | ||||||
|  |  | ||||||
|     static inline void update_field(Field& P, Field& U, double ep) { |     static inline void update_field(Field &P, Field &U, double ep) | ||||||
|       U += P*ep; |     { | ||||||
|  | #ifndef USE_FFT_ACCELERATION | ||||||
|  |       double t0=usecond();  | ||||||
|  |       U += P * ep; | ||||||
|  |       double t1=usecond(); | ||||||
|  |       double total_time = (t1-t0)/1e6; | ||||||
|  |       std::cout << GridLogIntegrator << "Total time for updating field (s)       : " << total_time << std::endl;  | ||||||
|  | #else | ||||||
|  |       // FFT transform P(x) -> P(p) | ||||||
|  |       // divide by (M^2+p^2)  M external parameter (how to pass?) | ||||||
|  |       // P'(p) = P(p)/(M^2+p^2) | ||||||
|  |       // Transform back -> P'(x) | ||||||
|  |       // U += P'(x)*ep | ||||||
|  |  | ||||||
|  |       Field Pp(U._grid), P_FFT(U._grid);      | ||||||
|  |       static ComplexField p2(U._grid); | ||||||
|  |       RealD M = FFT_MASS; | ||||||
|  |        | ||||||
|  |       FFT theFFT((GridCartesian*)U._grid); | ||||||
|  |       theFFT.FFT_all_dim(Pp, P, FFT::forward); | ||||||
|  |  | ||||||
|  |       static bool first_call = true; | ||||||
|  |       if (first_call) | ||||||
|  |       { | ||||||
|  |         // avoid recomputing | ||||||
|  |         MomentumSpacePropagator(p2, M); | ||||||
|  |         first_call = false; | ||||||
|  |       } | ||||||
|  |       Pp *= p2; | ||||||
|  |       theFFT.FFT_all_dim(P_FFT, Pp, FFT::backward); | ||||||
|  |       U += P_FFT * ep; | ||||||
|  |  | ||||||
|  | #endif //USE_FFT_ACCELERATION | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     static inline RealD FieldSquareNorm(Field& U) { |     static inline RealD FieldSquareNorm(Field &U) | ||||||
|       return (TensorRemove(sum(trace(U*U))).real()); |     { | ||||||
|  | #ifndef USE_FFT_ACCELERATION | ||||||
|  |       return (TensorRemove(sum(trace(U * U))).real()); | ||||||
|  | #else | ||||||
|  |       // In case of Fourier acceleration we have to: | ||||||
|  |       // compute U(p)*U(p)/(M^2+p^2))   Parseval theorem | ||||||
|  |       // 1 FFT needed U(x) -> U(p) | ||||||
|  |       // M to be passed | ||||||
|  |  | ||||||
|  |       FFT theFFT((GridCartesian*)U._grid); | ||||||
|  |       Field Up(U._grid); | ||||||
|  |  | ||||||
|  |       theFFT.FFT_all_dim(Up, U, FFT::forward); | ||||||
|  |       RealD M = FFT_MASS; | ||||||
|  |       ComplexField p2(U._grid); | ||||||
|  |       MomentumSpacePropagator(p2, M); | ||||||
|  |       Field Up2 = Up * p2; | ||||||
|  |       // from the definition of the DFT we need to divide by the volume | ||||||
|  |       return (-TensorRemove(sum(trace(adj(Up) * Up2))).real() / U._grid->gSites()); | ||||||
|  | #endif //USE_FFT_ACCELERATION | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     static inline void HotConfiguration(GridParallelRNG &pRNG, Field &U) { |     static inline void HotConfiguration(GridParallelRNG &pRNG, Field &U) { | ||||||
| @@ -146,7 +247,7 @@ class ScalarImplTypes { | |||||||
|   typedef ScalarImplTypes<vComplex> ScalarImplCR; |   typedef ScalarImplTypes<vComplex> ScalarImplCR; | ||||||
|   typedef ScalarImplTypes<vComplexF> ScalarImplCF; |   typedef ScalarImplTypes<vComplexF> ScalarImplCF; | ||||||
|   typedef ScalarImplTypes<vComplexD> ScalarImplCD; |   typedef ScalarImplTypes<vComplexD> ScalarImplCD; | ||||||
|      |  | ||||||
|   // Hardcoding here the size of the matrices |   // Hardcoding here the size of the matrices | ||||||
|   typedef ScalarAdjMatrixImplTypes<vComplex,  QCD::Nc> ScalarAdjImplR; |   typedef ScalarAdjMatrixImplTypes<vComplex,  QCD::Nc> ScalarAdjImplR; | ||||||
|   typedef ScalarAdjMatrixImplTypes<vComplexF, QCD::Nc> ScalarAdjImplF; |   typedef ScalarAdjMatrixImplTypes<vComplexF, QCD::Nc> ScalarAdjImplF; | ||||||
| @@ -155,7 +256,7 @@ class ScalarImplTypes { | |||||||
|   template <int Colours > using ScalarNxNAdjImplR = ScalarAdjMatrixImplTypes<vComplex,   Colours >; |   template <int Colours > using ScalarNxNAdjImplR = ScalarAdjMatrixImplTypes<vComplex,   Colours >; | ||||||
|   template <int Colours > using ScalarNxNAdjImplF = ScalarAdjMatrixImplTypes<vComplexF,  Colours >; |   template <int Colours > using ScalarNxNAdjImplF = ScalarAdjMatrixImplTypes<vComplexF,  Colours >; | ||||||
|   template <int Colours > using ScalarNxNAdjImplD = ScalarAdjMatrixImplTypes<vComplexD,  Colours >; |   template <int Colours > using ScalarNxNAdjImplD = ScalarAdjMatrixImplTypes<vComplexD,  Colours >; | ||||||
|    |  | ||||||
|   //} |   //} | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -30,119 +30,179 @@ directory | |||||||
| #ifndef SCALAR_INT_ACTION_H | #ifndef SCALAR_INT_ACTION_H | ||||||
| #define SCALAR_INT_ACTION_H | #define SCALAR_INT_ACTION_H | ||||||
|  |  | ||||||
|  |  | ||||||
| // Note: this action can completely absorb the ScalarAction for real float fields | // Note: this action can completely absorb the ScalarAction for real float fields | ||||||
| // use the scalarObjs to generalise the structure | // use the scalarObjs to generalise the structure | ||||||
|  |  | ||||||
| namespace Grid { | namespace Grid | ||||||
|   // FIXME drop the QCD namespace everywhere here | { | ||||||
|  | // FIXME drop the QCD namespace everywhere here | ||||||
|  |  | ||||||
|   template <class Impl, int Ndim > | template <class Impl, int Ndim> | ||||||
|   class ScalarInteractionAction : public QCD::Action<typename Impl::Field> { | class ScalarInteractionAction : public QCD::Action<typename Impl::Field> | ||||||
|   public: | { | ||||||
|     INHERIT_FIELD_TYPES(Impl); | public: | ||||||
|   private: |   INHERIT_FIELD_TYPES(Impl); | ||||||
|     RealD mass_square; |  | ||||||
|     RealD lambda; |  | ||||||
|  |  | ||||||
|  | private: | ||||||
|  |   RealD mass_square; | ||||||
|  |   RealD lambda; | ||||||
|  |   RealD g; | ||||||
|  |   const unsigned int N = Impl::Group::Dimension; | ||||||
|  |  | ||||||
|     typedef typename Field::vector_object vobj; |   typedef typename Field::vector_object vobj; | ||||||
|     typedef CartesianStencil<vobj,vobj> Stencil; |   typedef CartesianStencil<vobj, vobj> Stencil; | ||||||
|  |  | ||||||
|     SimpleCompressor<vobj> compressor; |   SimpleCompressor<vobj> compressor; | ||||||
|     int npoint = 2*Ndim; |   int npoint = 2 * Ndim; | ||||||
|     std::vector<int> directions;//    = {0,1,2,3,0,1,2,3};  // forcing 4 dimensions |   std::vector<int> directions;    // | ||||||
|     std::vector<int> displacements;//  = {1,1,1,1, -1,-1,-1,-1}; |   std::vector<int> displacements; // | ||||||
|  |  | ||||||
|  | public: | ||||||
|   public: |   ScalarInteractionAction(RealD ms, RealD l, RealD gval) : mass_square(ms), lambda(l), g(gval), displacements(2 * Ndim, 0), directions(2 * Ndim, 0) | ||||||
|  |   { | ||||||
|     ScalarInteractionAction(RealD ms, RealD l) : mass_square(ms), lambda(l), displacements(2*Ndim,0), directions(2*Ndim,0){ |     for (int mu = 0; mu < Ndim; mu++) | ||||||
|       for (int mu = 0 ; mu < Ndim; mu++){ |     { | ||||||
| 		directions[mu]         = mu; directions[mu+Ndim]    = mu; |       directions[mu] = mu; | ||||||
| 		displacements[mu]      =  1; displacements[mu+Ndim] = -1; |       directions[mu + Ndim] = mu; | ||||||
|       } |       displacements[mu] = 1; | ||||||
|  |       displacements[mu + Ndim] = -1; | ||||||
|     } |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|     virtual std::string LogParameters() { |   virtual std::string LogParameters() | ||||||
|       std::stringstream sstream; |   { | ||||||
|       sstream << GridLogMessage << "[ScalarAction] lambda      : " << lambda      << std::endl; |     std::stringstream sstream; | ||||||
|       sstream << GridLogMessage << "[ScalarAction] mass_square : " << mass_square << std::endl; |     sstream << GridLogMessage << "[ScalarAction] lambda      : " << lambda << std::endl; | ||||||
|       return sstream.str(); |     sstream << GridLogMessage << "[ScalarAction] mass_square : " << mass_square << std::endl; | ||||||
|     } |     sstream << GridLogMessage << "[ScalarAction] g           : " << g << std::endl; | ||||||
|  |     return sstream.str(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|     virtual std::string action_name() {return "ScalarAction";} |   virtual std::string action_name() { return "ScalarAction"; } | ||||||
|  |  | ||||||
|     virtual void refresh(const Field &U, GridParallelRNG &pRNG) {} |   virtual void refresh(const Field &U, GridParallelRNG &pRNG) {} | ||||||
|  |  | ||||||
|     virtual RealD S(const Field &p) { |   virtual RealD S(const Field &p) | ||||||
|       assert(p._grid->Nd() == Ndim); |   { | ||||||
|       static Stencil phiStencil(p._grid, npoint, 0, directions, displacements); |     assert(p._grid->Nd() == Ndim); | ||||||
|       phiStencil.HaloExchange(p, compressor); |     static Stencil phiStencil(p._grid, npoint, 0, directions, displacements); | ||||||
|       Field action(p._grid), pshift(p._grid), phisquared(p._grid); |     phiStencil.HaloExchange(p, compressor); | ||||||
|       phisquared = p*p; |     Field action(p._grid), pshift(p._grid), phisquared(p._grid); | ||||||
|       action = (2.0*Ndim + mass_square)*phisquared - lambda/24.*phisquared*phisquared; |     phisquared = p * p; | ||||||
|       for (int mu = 0; mu < Ndim; mu++) { |     action = (2.0 * Ndim + mass_square) * phisquared - lambda * phisquared * phisquared; | ||||||
| 	//  pshift = Cshift(p, mu, +1);  // not efficient, implement with stencils |     for (int mu = 0; mu < Ndim; mu++) | ||||||
| 	parallel_for (int i = 0; i < p._grid->oSites(); i++) { |     { | ||||||
| 	  int permute_type; |       //  pshift = Cshift(p, mu, +1);  // not efficient, implement with stencils | ||||||
| 	  StencilEntry *SE; |       parallel_for(int i = 0; i < p._grid->oSites(); i++) | ||||||
| 	  vobj temp2; |       { | ||||||
| 	  const vobj *temp, *t_p; |         int permute_type; | ||||||
| 	     |         StencilEntry *SE; | ||||||
| 	  SE = phiStencil.GetEntry(permute_type, mu, i); |         vobj temp2; | ||||||
| 	  t_p  = &p._odata[i]; |         const vobj *temp, *t_p; | ||||||
| 	  if ( SE->_is_local ) { |  | ||||||
| 	    temp = &p._odata[SE->_offset]; |         SE = phiStencil.GetEntry(permute_type, mu, i); | ||||||
| 	    if ( SE->_permute ) { |         t_p = &p._odata[i]; | ||||||
| 	      permute(temp2, *temp, permute_type); |         if (SE->_is_local) | ||||||
| 	      action._odata[i] -= temp2*(*t_p) + (*t_p)*temp2; |         { | ||||||
| 	    } else { |           temp = &p._odata[SE->_offset]; | ||||||
| 	      action._odata[i] -= (*temp)*(*t_p) + (*t_p)*(*temp); |           if (SE->_permute) | ||||||
| 	    } |           { | ||||||
| 	  } else { |             permute(temp2, *temp, permute_type); | ||||||
| 	    action._odata[i] -= phiStencil.CommBuf()[SE->_offset]*(*t_p) + (*t_p)*phiStencil.CommBuf()[SE->_offset]; |             action._odata[i] -= temp2 * (*t_p) + (*t_p) * temp2; | ||||||
| 	  } |           } | ||||||
| 	} |           else | ||||||
| 	//  action -= pshift*p + p*pshift; |           { | ||||||
|       } |             action._odata[i] -= (*temp) * (*t_p) + (*t_p) * (*temp); | ||||||
|       // NB the trace in the algebra is normalised to 1/2 |           } | ||||||
|       // minus sign coming from the antihermitian fields |         } | ||||||
|       return -(TensorRemove(sum(trace(action)))).real(); |         else | ||||||
|     }; |         { | ||||||
|  |           action._odata[i] -= phiStencil.CommBuf()[SE->_offset] * (*t_p) + (*t_p) * phiStencil.CommBuf()[SE->_offset]; | ||||||
|     virtual void deriv(const Field &p, Field &force) { |         } | ||||||
|       assert(p._grid->Nd() == Ndim); |  | ||||||
|       force = (2.0*Ndim + mass_square)*p - lambda/12.*p*p*p; |  | ||||||
|       // move this outside |  | ||||||
|       static Stencil phiStencil(p._grid, npoint, 0, directions, displacements); |  | ||||||
|       phiStencil.HaloExchange(p, compressor); |  | ||||||
|        |  | ||||||
|       //for (int mu = 0; mu < QCD::Nd; mu++) force -= Cshift(p, mu, -1) + Cshift(p, mu, 1); |  | ||||||
|       for (int point = 0; point < npoint; point++) { |  | ||||||
| 	parallel_for (int i = 0; i < p._grid->oSites(); i++) { |  | ||||||
| 	  const vobj *temp; |  | ||||||
| 	  vobj temp2; |  | ||||||
| 	  int permute_type; |  | ||||||
| 	  StencilEntry *SE; |  | ||||||
| 	  SE = phiStencil.GetEntry(permute_type, point, i); |  | ||||||
| 	   |  | ||||||
| 	  if ( SE->_is_local ) { |  | ||||||
| 	    temp = &p._odata[SE->_offset]; |  | ||||||
| 	    if ( SE->_permute ) { |  | ||||||
| 	      permute(temp2, *temp, permute_type); |  | ||||||
| 	      force._odata[i] -= temp2; |  | ||||||
| 	    } else { |  | ||||||
| 	      force._odata[i] -= *temp; |  | ||||||
| 	    } |  | ||||||
| 	  } else { |  | ||||||
| 	    force._odata[i] -= phiStencil.CommBuf()[SE->_offset]; |  | ||||||
| 	  } |  | ||||||
| 	} |  | ||||||
|       } |       } | ||||||
|  |       //  action -= pshift*p + p*pshift; | ||||||
|     } |     } | ||||||
|  |     // NB the trace in the algebra is normalised to 1/2 | ||||||
|  |     // minus sign coming from the antihermitian fields | ||||||
|  |     return -(TensorRemove(sum(trace(action)))).real() * N / g; | ||||||
|   }; |   }; | ||||||
|    |  | ||||||
| }  // namespace Grid |  | ||||||
|  |  | ||||||
| #endif  // SCALAR_INT_ACTION_H |   virtual void deriv(const Field &p, Field &force) | ||||||
|  |   { | ||||||
|  |     double t0 = usecond(); | ||||||
|  |     assert(p._grid->Nd() == Ndim); | ||||||
|  |     force = (2. * Ndim + mass_square) * p - 2. * lambda * p * p * p; | ||||||
|  |     double interm_t = usecond(); | ||||||
|  |  | ||||||
|  |     // move this outside | ||||||
|  |     static Stencil phiStencil(p._grid, npoint, 0, directions, displacements); | ||||||
|  |  | ||||||
|  |     phiStencil.HaloExchange(p, compressor); | ||||||
|  |     double halo_t = usecond(); | ||||||
|  |     int chunk = 128; | ||||||
|  |     //for (int mu = 0; mu < QCD::Nd; mu++) force -= Cshift(p, mu, -1) + Cshift(p, mu, 1); | ||||||
|  |  | ||||||
|  |     // inverting the order of the loops slows down the code(! g++ 7) | ||||||
|  |     // cannot try to reduce the number of  force writes by factor npoint... | ||||||
|  |     // use cache blocking | ||||||
|  |     for (int point = 0; point < npoint; point++) | ||||||
|  |     { | ||||||
|  |  | ||||||
|  | #pragma omp parallel  | ||||||
|  | { | ||||||
|  |         int permute_type; | ||||||
|  |         StencilEntry *SE; | ||||||
|  |         const vobj *temp; | ||||||
|  |  | ||||||
|  | #pragma omp for schedule(static, chunk) | ||||||
|  |       for (int i = 0; i < p._grid->oSites(); i++) | ||||||
|  |       { | ||||||
|  |         SE = phiStencil.GetEntry(permute_type, point, i); | ||||||
|  |         // prefetch next p? | ||||||
|  |  | ||||||
|  |         if (SE->_is_local) | ||||||
|  |         { | ||||||
|  |           temp = &p._odata[SE->_offset]; | ||||||
|  |        | ||||||
|  |           if (SE->_permute) | ||||||
|  |           { | ||||||
|  |             vobj temp2; | ||||||
|  |             permute(temp2, *temp, permute_type); | ||||||
|  |             force._odata[i] -= temp2; | ||||||
|  |           } | ||||||
|  |           else | ||||||
|  |           { | ||||||
|  |             force._odata[i] -= *temp; // slow part. Dominated by this read/write (BW) | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |           force._odata[i] -= phiStencil.CommBuf()[SE->_offset]; | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |   force *= N / g; | ||||||
|  |  | ||||||
|  |   double t1 = usecond(); | ||||||
|  |   double total_time = (t1 - t0) / 1e6; | ||||||
|  |   double interm_time = (interm_t - t0) / 1e6; | ||||||
|  |   double halo_time = (halo_t - interm_t) / 1e6; | ||||||
|  |   double stencil_time = (t1 - halo_t) / 1e6; | ||||||
|  |   std::cout << GridLogIntegrator << "Total time for force computation (s)       : " << total_time << std::endl; | ||||||
|  |   std::cout << GridLogIntegrator << "Intermediate time for force computation (s): " << interm_time << std::endl; | ||||||
|  |   std::cout << GridLogIntegrator << "Halo time in force computation (s)         : " << halo_time << std::endl; | ||||||
|  |   std::cout << GridLogIntegrator << "Stencil time in force computation (s)      : " << stencil_time << std::endl; | ||||||
|  |   double flops = p._grid->gSites() * (14 * N * N * N + 18 * N * N + 2); | ||||||
|  |   double flops_no_stencil = p._grid->gSites() * (14 * N * N * N + 6 * N * N + 2); | ||||||
|  |   double Gflops = flops / (total_time * 1e9); | ||||||
|  |   double Gflops_no_stencil = flops_no_stencil / (interm_time * 1e9); | ||||||
|  |   std::cout << GridLogIntegrator << "Flops: " << flops << "  - Gflop/s : " << Gflops << std::endl; | ||||||
|  |   std::cout << GridLogIntegrator << "Flops NS: " << flops_no_stencil << "  - Gflop/s NS: " << Gflops_no_stencil << std::endl; | ||||||
|  | } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | } // namespace Grid | ||||||
|  |  | ||||||
|  | #endif // SCALAR_INT_ACTION_H | ||||||
|   | |||||||
| @@ -211,7 +211,7 @@ typedef HMCWrapperTemplate<ScalarAdjImplR, MinimumNorm2, ScalarMatrixFields> | |||||||
|     ScalarAdjGenericHMCRunner; |     ScalarAdjGenericHMCRunner; | ||||||
|  |  | ||||||
| template <int Colours>  | template <int Colours>  | ||||||
| using ScalarNxNAdjGenericHMCRunner = HMCWrapperTemplate < ScalarNxNAdjImplR<Colours>, MinimumNorm2, ScalarNxNMatrixFields<Colours> >; | using ScalarNxNAdjGenericHMCRunner = HMCWrapperTemplate < ScalarNxNAdjImplR<Colours>, ForceGradient, ScalarNxNMatrixFields<Colours> >; | ||||||
|  |  | ||||||
| }  // namespace QCD | }  // namespace QCD | ||||||
| }  // namespace Grid | }  // namespace Grid | ||||||
|   | |||||||
| @@ -92,6 +92,19 @@ class PlaquetteMod: public ObservableModule<PlaquetteLogger<Impl>, NoParameters> | |||||||
|   PlaquetteMod(): ObsBase(NoParameters()){} |   PlaquetteMod(): ObsBase(NoParameters()){} | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | template < class Impl > | ||||||
|  | class PolyakovMod: public ObservableModule<PolyakovLogger<Impl>, NoParameters>{ | ||||||
|  |   typedef ObservableModule<PolyakovLogger<Impl>, NoParameters> ObsBase; | ||||||
|  |   using ObsBase::ObsBase; // for constructors | ||||||
|  |  | ||||||
|  |   // acquire resource | ||||||
|  |   virtual void initialize(){ | ||||||
|  |     this->ObservablePtr.reset(new PolyakovLogger<Impl>()); | ||||||
|  |   } | ||||||
|  |   public: | ||||||
|  |   PolyakovMod(): ObsBase(NoParameters()){} | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| template < class Impl > | template < class Impl > | ||||||
| class TopologicalChargeMod: public ObservableModule<TopologicalCharge<Impl>, TopologyObsParameters>{ | class TopologicalChargeMod: public ObservableModule<TopologicalCharge<Impl>, TopologyObsParameters>{ | ||||||
|   | |||||||
| @@ -45,5 +45,7 @@ class HmcObservable { | |||||||
|  |  | ||||||
| #include "plaquette.h" | #include "plaquette.h" | ||||||
| #include "topological_charge.h" | #include "topological_charge.h" | ||||||
|  | #include "polyakov_loop.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif  //  HMC_OBSERVABLE_H | #endif  //  HMC_OBSERVABLE_H | ||||||
|   | |||||||
							
								
								
									
										68
									
								
								lib/qcd/observables/polyakov_loop.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										68
									
								
								lib/qcd/observables/polyakov_loop.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,68 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |  | ||||||
|  | Source file: ./lib/qcd/modules/polyakov_line.h | ||||||
|  |  | ||||||
|  | Copyright (C) 2017 | ||||||
|  |  | ||||||
|  | Author: David Preti <david.preti@csic.es> | ||||||
|  |  | ||||||
|  | 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 HMC_POLYAKOV_H | ||||||
|  | #define HMC_POLYAKOV_H | ||||||
|  |  | ||||||
|  | namespace Grid { | ||||||
|  | namespace QCD { | ||||||
|  |  | ||||||
|  | // this is only defined for a gauge theory | ||||||
|  | template <class Impl> | ||||||
|  | class PolyakovLogger : public HmcObservable<typename Impl::Field> { | ||||||
|  |  public: | ||||||
|  |   // here forces the Impl to be of gauge fields | ||||||
|  |   // if not the compiler will complain | ||||||
|  |   INHERIT_GIMPL_TYPES(Impl); | ||||||
|  |  | ||||||
|  |   // necessary for HmcObservable compatibility | ||||||
|  |   typedef typename Impl::Field Field; | ||||||
|  |  | ||||||
|  |   void TrajectoryComplete(int traj, | ||||||
|  |                           Field &U, | ||||||
|  |                           GridSerialRNG &sRNG, | ||||||
|  |                           GridParallelRNG &pRNG) { | ||||||
|  |  | ||||||
|  |     ComplexD polyakov = WilsonLoops<Impl>::avgPolyakovLoop(U); | ||||||
|  |  | ||||||
|  |     int def_prec = std::cout.precision(); | ||||||
|  |  | ||||||
|  |     std::cout << GridLogMessage | ||||||
|  |         << std::setprecision(std::numeric_limits<Real>::digits10 + 1) | ||||||
|  |         << "Polyakov Loop: [ " << traj << " ] "<< polyakov << std::endl; | ||||||
|  |  | ||||||
|  |     std::cout.precision(def_prec); | ||||||
|  |  | ||||||
|  |   } | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | }  // namespace QCD | ||||||
|  | }  // namespace Grid | ||||||
|  |  | ||||||
|  | #endif  // HMC_POLYAKOV_H | ||||||
| @@ -123,6 +123,28 @@ public: | |||||||
|     return sumplaq / vol / faces / Nc; // Nd , Nc dependent... FIXME |     return sumplaq / vol / faces / Nc; // Nd , Nc dependent... FIXME | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   ////////////////////////////////////////////////// | ||||||
|  |   // average over all x,y,z the temporal loop | ||||||
|  |   ////////////////////////////////////////////////// | ||||||
|  |   static ComplexD avgPolyakovLoop(const GaugeField &Umu) {  //assume Nd=4 | ||||||
|  |     GaugeMat Ut(Umu._grid), P(Umu._grid); | ||||||
|  |     ComplexD out; | ||||||
|  |     int T = Umu._grid->GlobalDimensions()[3]; | ||||||
|  |     int X = Umu._grid->GlobalDimensions()[0]; | ||||||
|  |     int Y = Umu._grid->GlobalDimensions()[1]; | ||||||
|  |     int Z = Umu._grid->GlobalDimensions()[2]; | ||||||
|  |  | ||||||
|  |     Ut = peekLorentz(Umu,3); //Select temporal direction | ||||||
|  |     P = Ut; | ||||||
|  |     for (int t=1;t<T;t++){  | ||||||
|  |       P = Gimpl::CovShiftForward(Ut,3,P); | ||||||
|  |     } | ||||||
|  |    RealD norm = 1.0/(Nc*X*Y*Z*T); | ||||||
|  |    out = sum(trace(P))*norm; | ||||||
|  |    return out;    | ||||||
|  | } | ||||||
|  |  | ||||||
|   ////////////////////////////////////////////////// |   ////////////////////////////////////////////////// | ||||||
|   // average over traced single links |   // average over traced single links | ||||||
|   ////////////////////////////////////////////////// |   ////////////////////////////////////////////////// | ||||||
| @@ -291,9 +313,9 @@ static void StapleMult(GaugeMat &staple, const GaugeLorentz &Umu, int mu) { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   ////////////////////////////////////////////////// |   //////////////////////////////////////////////////////////////////////// | ||||||
|   // the sum over all staples on each site in direction mu,nu, lower part |   // the sum over all staples on each site in direction mu,nu, lower part | ||||||
|   ////////////////////////////////////////////////// |   //////////////////////////////////////////////////////////////////////// | ||||||
|   static void StapleLower(GaugeMat &staple, const GaugeLorentz &Umu, int mu, |   static void StapleLower(GaugeMat &staple, const GaugeLorentz &Umu, int mu, | ||||||
|                           int nu) { |                           int nu) { | ||||||
|     if (nu != mu) { |     if (nu != mu) { | ||||||
| @@ -315,7 +337,9 @@ static void StapleMult(GaugeMat &staple, const GaugeLorentz &Umu, int mu) { | |||||||
|       // |       // | ||||||
|       staple = Gimpl::ShiftStaple( |       staple = Gimpl::ShiftStaple( | ||||||
|           Gimpl::CovShiftBackward(U[nu], nu, |           Gimpl::CovShiftBackward(U[nu], nu, | ||||||
|                                   Gimpl::CovShiftBackward(U[mu], mu, U[nu])), mu); |                                   Gimpl::CovShiftBackward(U[mu], mu, U[nu])), | ||||||
|  |           mu); | ||||||
|  |  | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -325,7 +349,7 @@ static void StapleMult(GaugeMat &staple, const GaugeLorentz &Umu, int mu) { | |||||||
|   static void FieldStrength(GaugeMat &FS, const GaugeLorentz &Umu, int mu, int nu){ |   static void FieldStrength(GaugeMat &FS, const GaugeLorentz &Umu, int mu, int nu){ | ||||||
|       // Fmn +--<--+  Ut +--<--+ |       // Fmn +--<--+  Ut +--<--+ | ||||||
|       //     |     |     |     | |       //     |     |     |     | | ||||||
|       //  (x)+-->--+     +-->--+(x) |       //  (x)+-->--+     +-->--+(x)  - h.c. | ||||||
|       //     |     |     |     | |       //     |     |     |     | | ||||||
|       //     +--<--+     +--<--+ |       //     +--<--+     +--<--+ | ||||||
|  |  | ||||||
| @@ -335,7 +359,9 @@ static void StapleMult(GaugeMat &staple, const GaugeLorentz &Umu, int mu) { | |||||||
|       GaugeMat v = Vup - Vdn; |       GaugeMat v = Vup - Vdn; | ||||||
|       GaugeMat u = PeekIndex<LorentzIndex>(Umu, mu);  // some redundant copies |       GaugeMat u = PeekIndex<LorentzIndex>(Umu, mu);  // some redundant copies | ||||||
|       GaugeMat vu = v*u; |       GaugeMat vu = v*u; | ||||||
|       FS = 0.25*Ta(u*v + Cshift(vu, mu, -1)); |       //FS = 0.25*Ta(u*v + Cshift(vu, mu, -1)); | ||||||
|  |       FS = (u*v + Cshift(vu, mu, -1)); | ||||||
|  |       FS = 0.125*(FS - adj(FS)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   static Real TopologicalCharge(GaugeLorentz &U){ |   static Real TopologicalCharge(GaugeLorentz &U){ | ||||||
| @@ -360,6 +386,7 @@ static void StapleMult(GaugeMat &staple, const GaugeLorentz &Umu, int mu) { | |||||||
|     return TensorRemove(Tq).real(); |     return TensorRemove(Tq).real(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|   ////////////////////////////////////////////////////// |   ////////////////////////////////////////////////////// | ||||||
|   // Similar to above for rectangle is required |   // Similar to above for rectangle is required | ||||||
|   ////////////////////////////////////////////////////// |   ////////////////////////////////////////////////////// | ||||||
|   | |||||||
| @@ -11,8 +11,7 @@ Grid physics library, www.github.com/paboyle/Grid | |||||||
|  |  | ||||||
| Source file: $1 | Source file: $1 | ||||||
|  |  | ||||||
| Copyright (C) 2015 | Copyright (C) 2015-2018 | ||||||
| Copyright (C) 2016 |  | ||||||
|  |  | ||||||
| EOF | EOF | ||||||
|  |  | ||||||
| @@ -60,4 +59,4 @@ shift | |||||||
|  |  | ||||||
| done | done | ||||||
|  |  | ||||||
|  | rm message tmp.fil | ||||||
|   | |||||||
							
								
								
									
										357
									
								
								tests/core/Test_wilson_clover.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										357
									
								
								tests/core/Test_wilson_clover.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,357 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  |     Grid physics library, www.github.com/paboyle/Grid  | ||||||
|  |  | ||||||
|  |     Source file: ./benchmarks/Benchmark_wilson.cc | ||||||
|  |  | ||||||
|  |     Copyright (C) 2015 | ||||||
|  |  | ||||||
|  |     Author: Guido Cossu <guido.cossu@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 */ | ||||||
|  | #include <Grid/Grid.h> | ||||||
|  |  | ||||||
|  | using namespace std; | ||||||
|  | using namespace Grid; | ||||||
|  | using namespace Grid::QCD; | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   Grid_init(&argc, &argv); | ||||||
|  |  | ||||||
|  |   std::vector<int> latt_size = GridDefaultLatt(); | ||||||
|  |   std::vector<int> simd_layout = GridDefaultSimd(Nd, vComplex::Nsimd()); | ||||||
|  |   std::vector<int> mpi_layout = GridDefaultMpi(); | ||||||
|  |   GridCartesian Grid(latt_size, simd_layout, mpi_layout); | ||||||
|  |   GridRedBlackCartesian RBGrid(&Grid); | ||||||
|  |  | ||||||
|  |   int threads = GridThread::GetThreads(); | ||||||
|  |   std::cout << GridLogMessage << "Grid is setup to use " << threads << " threads" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "Grid floating point word size is REALF" << sizeof(RealF) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "Grid floating point word size is REALD" << sizeof(RealD) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "Grid floating point word size is REAL" << sizeof(Real) << std::endl; | ||||||
|  |  | ||||||
|  |   std::vector<int> seeds({1, 2, 3, 4}); | ||||||
|  |   GridParallelRNG pRNG(&Grid); | ||||||
|  |   pRNG.SeedFixedIntegers(seeds); | ||||||
|  |   //  pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9}); | ||||||
|  |  | ||||||
|  |   typedef typename WilsonCloverFermionR::FermionField FermionField; | ||||||
|  |   typename WilsonCloverFermionR::ImplParams params; | ||||||
|  |   WilsonAnisotropyCoefficients anis; | ||||||
|  |  | ||||||
|  |   FermionField src(&Grid); | ||||||
|  |   random(pRNG, src); | ||||||
|  |   FermionField result(&Grid); | ||||||
|  |   result = zero; | ||||||
|  |   FermionField result2(&Grid); | ||||||
|  |   result2 = zero; | ||||||
|  |   FermionField ref(&Grid); | ||||||
|  |   ref = zero; | ||||||
|  |   FermionField tmp(&Grid); | ||||||
|  |   tmp = zero; | ||||||
|  |   FermionField err(&Grid); | ||||||
|  |   err = zero; | ||||||
|  |   FermionField err2(&Grid); | ||||||
|  |   err2 = zero; | ||||||
|  |   FermionField phi(&Grid); | ||||||
|  |   random(pRNG, phi); | ||||||
|  |   FermionField chi(&Grid); | ||||||
|  |   random(pRNG, chi); | ||||||
|  |   LatticeGaugeField Umu(&Grid); | ||||||
|  |   SU3::HotConfiguration(pRNG, Umu); | ||||||
|  |   std::vector<LatticeColourMatrix> U(4, &Grid); | ||||||
|  |  | ||||||
|  |   double volume = 1; | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     volume = volume * latt_size[mu]; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   RealD mass = 0.1; | ||||||
|  |   RealD csw_r = 1.0; | ||||||
|  |   RealD csw_t = 1.0; | ||||||
|  |  | ||||||
|  |   WilsonCloverFermionR Dwc(Umu, Grid, RBGrid, mass, csw_r, csw_t, anis, params); | ||||||
|  |   //Dwc.ImportGauge(Umu); // not necessary, included in the constructor | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Testing that Deo + Doe = Dunprec " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   FermionField src_e(&RBGrid); | ||||||
|  |   FermionField src_o(&RBGrid); | ||||||
|  |   FermionField r_e(&RBGrid); | ||||||
|  |   FermionField r_o(&RBGrid); | ||||||
|  |   FermionField r_eo(&Grid); | ||||||
|  |   pickCheckerboard(Even, src_e, src); | ||||||
|  |   pickCheckerboard(Odd, src_o, src); | ||||||
|  |  | ||||||
|  |   Dwc.Meooe(src_e, r_o); | ||||||
|  |   std::cout << GridLogMessage << "Applied Meo" << std::endl; | ||||||
|  |   Dwc.Meooe(src_o, r_e); | ||||||
|  |   std::cout << GridLogMessage << "Applied Moe" << std::endl; | ||||||
|  |   Dwc.Dhop(src, ref, DaggerNo); | ||||||
|  |  | ||||||
|  |   setCheckerboard(r_eo, r_o); | ||||||
|  |   setCheckerboard(r_eo, r_e); | ||||||
|  |  | ||||||
|  |   err = ref - r_eo; | ||||||
|  |   std::cout << GridLogMessage << "EO norm diff   " << norm2(err) << " " << norm2(ref) << " " << norm2(r_eo) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Test Ddagger is the dagger of D by requiring                " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "=  < phi | Deo | chi > * = < chi | Deo^dag| phi>  " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   FermionField chi_e(&RBGrid); | ||||||
|  |   FermionField chi_o(&RBGrid); | ||||||
|  |  | ||||||
|  |   FermionField dchi_e(&RBGrid); | ||||||
|  |   FermionField dchi_o(&RBGrid); | ||||||
|  |  | ||||||
|  |   FermionField phi_e(&RBGrid); | ||||||
|  |   FermionField phi_o(&RBGrid); | ||||||
|  |  | ||||||
|  |   FermionField dphi_e(&RBGrid); | ||||||
|  |   FermionField dphi_o(&RBGrid); | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |   pickCheckerboard(Even, phi_e, phi); | ||||||
|  |   pickCheckerboard(Odd, phi_o, phi); | ||||||
|  |  | ||||||
|  |   Dwc.Meooe(chi_e, dchi_o); | ||||||
|  |   Dwc.Meooe(chi_o, dchi_e); | ||||||
|  |   Dwc.MeooeDag(phi_e, dphi_o); | ||||||
|  |   Dwc.MeooeDag(phi_o, dphi_e); | ||||||
|  |  | ||||||
|  |   ComplexD pDce = innerProduct(phi_e, dchi_e); | ||||||
|  |   ComplexD pDco = innerProduct(phi_o, dchi_o); | ||||||
|  |   ComplexD cDpe = innerProduct(chi_e, dphi_e); | ||||||
|  |   ComplexD cDpo = innerProduct(chi_o, dphi_o); | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "e " << pDce << " " << cDpe << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "o " << pDco << " " << cDpo << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "pDce - conj(cDpo) " << pDce - conj(cDpo) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "pDco - conj(cDpe) " << pDco - conj(cDpe) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Test MeeInv Mee = 1   (if csw!=0)                           " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |  | ||||||
|  |   Dwc.Mooee(chi_e, src_e); | ||||||
|  |   Dwc.MooeeInv(src_e, phi_e); | ||||||
|  |  | ||||||
|  |   Dwc.Mooee(chi_o, src_o); | ||||||
|  |   Dwc.MooeeInv(src_o, phi_o); | ||||||
|  |  | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |  | ||||||
|  |   err = phi - chi; | ||||||
|  |   std::cout << GridLogMessage << "norm diff   " << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Test MeeDag MeeInvDag = 1    (if csw!=0)                    " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |  | ||||||
|  |   Dwc.MooeeDag(chi_e, src_e); | ||||||
|  |   Dwc.MooeeInvDag(src_e, phi_e); | ||||||
|  |  | ||||||
|  |   Dwc.MooeeDag(chi_o, src_o); | ||||||
|  |   Dwc.MooeeInvDag(src_o, phi_o); | ||||||
|  |  | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |  | ||||||
|  |   err = phi - chi; | ||||||
|  |   std::cout << GridLogMessage << "norm diff   " << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Test MeeInv MeeDag = 1      (if csw!=0)                     " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==============================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |  | ||||||
|  |   Dwc.MooeeDag(chi_e, src_e); | ||||||
|  |   Dwc.MooeeInv(src_e, phi_e); | ||||||
|  |  | ||||||
|  |   Dwc.MooeeDag(chi_o, src_o); | ||||||
|  |   Dwc.MooeeInv(src_o, phi_o); | ||||||
|  |  | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |  | ||||||
|  |   err = phi - chi; | ||||||
|  |   std::cout << GridLogMessage << "norm diff   " << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "================================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Testing gauge covariance Clover term with EO preconditioning  " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "================================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   chi = zero; | ||||||
|  |   phi = zero; | ||||||
|  |   tmp = zero; | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |   pickCheckerboard(Even, phi_e, phi); | ||||||
|  |   pickCheckerboard(Odd, phi_o, phi); | ||||||
|  |  | ||||||
|  |   Dwc.Mooee(src_e, chi_e); | ||||||
|  |   Dwc.Mooee(src_o, chi_o); | ||||||
|  |   setCheckerboard(chi, chi_e); | ||||||
|  |   setCheckerboard(chi, chi_o); | ||||||
|  |   setCheckerboard(src, src_e); | ||||||
|  |   setCheckerboard(src, src_o); | ||||||
|  |  | ||||||
|  |   ////////////////////// Gauge Transformation | ||||||
|  |   std::vector<int> seeds2({5, 6, 7, 8}); | ||||||
|  |   GridParallelRNG pRNG2(&Grid); | ||||||
|  |   pRNG2.SeedFixedIntegers(seeds2); | ||||||
|  |   LatticeColourMatrix Omega(&Grid); | ||||||
|  |   LatticeColourMatrix ShiftedOmega(&Grid); | ||||||
|  |   LatticeGaugeField U_prime(&Grid); | ||||||
|  |   U_prime = zero; | ||||||
|  |   LatticeColourMatrix U_prime_mu(&Grid); | ||||||
|  |   U_prime_mu = zero; | ||||||
|  |   SU<Nc>::LieRandomize(pRNG2, Omega, 1.0); | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     U[mu] = peekLorentz(Umu, mu); | ||||||
|  |     ShiftedOmega = Cshift(Omega, mu, 1); | ||||||
|  |     U_prime_mu = Omega * U[mu] * adj(ShiftedOmega); | ||||||
|  |     pokeLorentz(U_prime, U_prime_mu, mu); | ||||||
|  |   } | ||||||
|  |   ///////////////// | ||||||
|  |  | ||||||
|  |   WilsonCloverFermionR Dwc_prime(U_prime, Grid, RBGrid, mass, csw_r, csw_t, anis, params); | ||||||
|  |   Dwc_prime.ImportGauge(U_prime); | ||||||
|  |  | ||||||
|  |   tmp = Omega * src; | ||||||
|  |   pickCheckerboard(Even, src_e, tmp); | ||||||
|  |   pickCheckerboard(Odd, src_o, tmp); | ||||||
|  |  | ||||||
|  |   Dwc_prime.Mooee(src_e, phi_e); | ||||||
|  |   Dwc_prime.Mooee(src_o, phi_o); | ||||||
|  |  | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |  | ||||||
|  |   err = chi - adj(Omega) * phi; | ||||||
|  |   std::cout << GridLogMessage << "norm diff   " << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "=================================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Testing gauge covariance Clover term w/o EO preconditioning  " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "================================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   chi = zero; | ||||||
|  |   phi = zero; | ||||||
|  |  | ||||||
|  |   WilsonFermionR Dw(Umu, Grid, RBGrid, mass, params); | ||||||
|  |   Dw.ImportGauge(Umu); | ||||||
|  |  | ||||||
|  |   Dw.M(src, result); | ||||||
|  |   Dwc.M(src, chi); | ||||||
|  |  | ||||||
|  |   Dwc_prime.M(Omega * src, phi); | ||||||
|  |  | ||||||
|  |   WilsonFermionR Dw_prime(U_prime, Grid, RBGrid, mass, params); | ||||||
|  |   Dw_prime.ImportGauge(U_prime); | ||||||
|  |   Dw_prime.M(Omega * src, result2); | ||||||
|  |  | ||||||
|  |   err = chi - adj(Omega) * phi; | ||||||
|  |   err2 = result - adj(Omega) * result2; | ||||||
|  |   std::cout << GridLogMessage << "norm diff Wilson   " << norm2(err) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "norm diff WilsonClover  " << norm2(err2) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Testing Mooee(csw=0) Clover to reproduce Mooee Wilson   " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   chi = zero; | ||||||
|  |   phi = zero; | ||||||
|  |   err = zero; | ||||||
|  |   WilsonCloverFermionR Dwc_csw0(Umu, Grid, RBGrid, mass, 0.0, 0.0, anis, params); //  <-- Notice: csw=0 | ||||||
|  |   Dwc_csw0.ImportGauge(Umu); | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, phi_e, phi); | ||||||
|  |   pickCheckerboard(Odd, phi_o, phi); | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |  | ||||||
|  |   Dw.Mooee(src_e, chi_e); | ||||||
|  |   Dw.Mooee(src_o, chi_o); | ||||||
|  |   Dwc_csw0.Mooee(src_e, phi_e); | ||||||
|  |   Dwc_csw0.Mooee(src_o, phi_o); | ||||||
|  |  | ||||||
|  |   setCheckerboard(chi, chi_e); | ||||||
|  |   setCheckerboard(chi, chi_o); | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |   setCheckerboard(src, src_e); | ||||||
|  |   setCheckerboard(src, src_o); | ||||||
|  |  | ||||||
|  |   err = chi - phi; | ||||||
|  |   std::cout << GridLogMessage << "norm diff  " << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "= Testing EO operator is equal to the unprec              " << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "==========================================================" << std::endl; | ||||||
|  |  | ||||||
|  |   chi = zero; | ||||||
|  |   phi = zero; | ||||||
|  |   err = zero; | ||||||
|  |  | ||||||
|  |   pickCheckerboard(Even, phi_e, phi); | ||||||
|  |   pickCheckerboard(Odd, phi_o, phi); | ||||||
|  |   pickCheckerboard(Even, chi_e, chi); | ||||||
|  |   pickCheckerboard(Odd, chi_o, chi); | ||||||
|  |  | ||||||
|  |   // M phi = (Mooee src_e + Meooe src_o , Meooe src_e + Mooee src_o) | ||||||
|  |  | ||||||
|  |   Dwc.M(src, ref); // Reference result from the unpreconditioned operator | ||||||
|  |  | ||||||
|  |   // EO matrix | ||||||
|  |   Dwc.Mooee(src_e, chi_e);  | ||||||
|  |   Dwc.Mooee(src_o, chi_o); | ||||||
|  |   Dwc.Meooe(src_o, phi_e); | ||||||
|  |   Dwc.Meooe(src_e, phi_o); | ||||||
|  |  | ||||||
|  |   phi_o += chi_o; | ||||||
|  |   phi_e += chi_e; | ||||||
|  |  | ||||||
|  |   setCheckerboard(phi, phi_e); | ||||||
|  |   setCheckerboard(phi, phi_o); | ||||||
|  |  | ||||||
|  |   err = ref - phi; | ||||||
|  |   std::cout << GridLogMessage << "ref (unpreconditioned operator) diff  :" << norm2(ref) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "phi (EO decomposition)          diff  :" << norm2(phi) << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "norm diff                             :" << norm2(err) << std::endl; | ||||||
|  |  | ||||||
|  |   Grid_finalize(); | ||||||
|  | } | ||||||
| @@ -50,7 +50,12 @@ int main (int argc, char ** argv) | |||||||
|   std::vector<int> seeds({1,2,3,4}); |   std::vector<int> seeds({1,2,3,4}); | ||||||
|  |  | ||||||
|   GridParallelRNG          pRNG(&Grid); |   GridParallelRNG          pRNG(&Grid); | ||||||
|   pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9})); |   std::vector<int> vrand(4); | ||||||
|  |   std::srand(std::time(0)); | ||||||
|  |   std::generate(vrand.begin(), vrand.end(), std::rand); | ||||||
|  |   std::cout << GridLogMessage << vrand << std::endl; | ||||||
|  |   pRNG.SeedFixedIntegers(vrand); | ||||||
|  |   //pRNG.SeedFixedIntegers(std::vector<int>({45,12,81,9})); | ||||||
|  |  | ||||||
|   LatticeFermion phi        (&Grid); gaussian(pRNG,phi); |   LatticeFermion phi        (&Grid); gaussian(pRNG,phi); | ||||||
|   LatticeFermion Mphi       (&Grid);  |   LatticeFermion Mphi       (&Grid);  | ||||||
|   | |||||||
							
								
								
									
										194
									
								
								tests/forces/Test_wilsonclover_force.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										194
									
								
								tests/forces/Test_wilsonclover_force.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,194 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  |     Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |  | ||||||
|  |     Source file: ./tests/Test_wilson_force.cc | ||||||
|  |  | ||||||
|  |     Copyright (C) 2015 | ||||||
|  |  | ||||||
|  | Author: Peter Boyle <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 */ | ||||||
|  | #include <Grid/Grid.h> | ||||||
|  |  | ||||||
|  | using namespace std; | ||||||
|  | using namespace Grid; | ||||||
|  | using namespace Grid::QCD; | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) | ||||||
|  | { | ||||||
|  |   Grid_init(&argc, &argv); | ||||||
|  |  | ||||||
|  |   std::vector<int> latt_size = GridDefaultLatt(); | ||||||
|  |   std::vector<int> simd_layout = GridDefaultSimd(Nd, vComplex::Nsimd()); | ||||||
|  |   std::vector<int> mpi_layout = GridDefaultMpi(); | ||||||
|  |  | ||||||
|  |   GridCartesian Grid(latt_size, simd_layout, mpi_layout); | ||||||
|  |   GridRedBlackCartesian RBGrid(&Grid); | ||||||
|  |  | ||||||
|  |   int threads = GridThread::GetThreads(); | ||||||
|  |   std::cout << GridLogMessage << "Grid is setup to use " << threads << " threads" << std::endl; | ||||||
|  |  | ||||||
|  |   std::vector<int> seeds({1, 2, 30, 50}); | ||||||
|  |  | ||||||
|  |   GridParallelRNG pRNG(&Grid); | ||||||
|  |  | ||||||
|  |   std::vector<int> vrand(4); | ||||||
|  |   std::srand(std::time(0)); | ||||||
|  |   std::generate(vrand.begin(), vrand.end(), std::rand); | ||||||
|  |   std::cout << GridLogMessage << vrand << std::endl; | ||||||
|  |   pRNG.SeedFixedIntegers(vrand); | ||||||
|  |   //pRNG.SeedFixedIntegers(seeds); | ||||||
|  |  | ||||||
|  |   LatticeFermion phi(&Grid); | ||||||
|  |   gaussian(pRNG, phi); | ||||||
|  |   LatticeFermion Mphi(&Grid); | ||||||
|  |   LatticeFermion MphiPrime(&Grid); | ||||||
|  |  | ||||||
|  |   LatticeGaugeField U(&Grid); | ||||||
|  |  | ||||||
|  |   std::vector<int> site = {0, 0, 0, 0}; | ||||||
|  |   SU3::HotConfiguration(pRNG, U); | ||||||
|  |   //SU3::ColdConfiguration(pRNG, U);// Clover term zero | ||||||
|  |  | ||||||
|  |   //////////////////////////////////// | ||||||
|  |   // Unmodified matrix element | ||||||
|  |   //////////////////////////////////// | ||||||
|  |   RealD mass = 0.1; | ||||||
|  |   Real csw = 1.0; | ||||||
|  |   WilsonCloverFermionR Dw(U, Grid, RBGrid, mass, csw, csw); | ||||||
|  |   Dw.ImportGauge(U); | ||||||
|  |   Dw.M(phi, Mphi); | ||||||
|  |   ComplexD S = innerProduct(Mphi, Mphi); // Action : pdag MdagM p | ||||||
|  |  | ||||||
|  |   // get the deriv of phidag MdagM phi with respect to "U" | ||||||
|  |   LatticeGaugeField UdSdU(&Grid); | ||||||
|  |   LatticeGaugeField tmp(&Grid); | ||||||
|  |  | ||||||
|  |   //////////////////////////////////////////// | ||||||
|  |   Dw.MDeriv(tmp, Mphi, phi, DaggerNo); | ||||||
|  |   UdSdU = tmp; | ||||||
|  |   Dw.MDeriv(tmp, phi, Mphi, DaggerYes); | ||||||
|  |   UdSdU += tmp; | ||||||
|  |   ///////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |   //////////////////////////////////// | ||||||
|  |   // Modify the gauge field a little | ||||||
|  |   //////////////////////////////////// | ||||||
|  |   RealD dt = 0.00005; | ||||||
|  |   RealD Hmom = 0.0; | ||||||
|  |   RealD Hmomprime = 0.0; | ||||||
|  |   RealD Hmompp = 0.0; | ||||||
|  |   LatticeColourMatrix mommu(&Grid); | ||||||
|  |   LatticeColourMatrix forcemu(&Grid); | ||||||
|  |   LatticeGaugeField mom(&Grid); | ||||||
|  |   LatticeGaugeField Uprime(&Grid); | ||||||
|  |  | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     // Traceless antihermitian momentum; gaussian in lie alg | ||||||
|  |     SU3::GaussianFundamentalLieAlgebraMatrix(pRNG, mommu); | ||||||
|  |     Hmom -= real(sum(trace(mommu * mommu))); | ||||||
|  |     PokeIndex<LorentzIndex>(mom, mommu, mu); | ||||||
|  |  | ||||||
|  |     parallel_for(int ss = 0; ss < mom._grid->oSites(); ss++) | ||||||
|  |     { | ||||||
|  |       Uprime[ss]._internal[mu] = ProjectOnGroup(Exponentiate(mom[ss]._internal[mu], dt, 12) * U[ss]._internal[mu]); | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "Initial mom hamiltonian is " << Hmom << std::endl; | ||||||
|  |  | ||||||
|  |   // New action | ||||||
|  |   Dw.ImportGauge(Uprime); | ||||||
|  |   Dw.M(phi, MphiPrime); | ||||||
|  |   ComplexD Sprime = innerProduct(MphiPrime, MphiPrime); | ||||||
|  |  | ||||||
|  |   ////////////////////////////////////////////// | ||||||
|  |   // Use derivative to estimate dS | ||||||
|  |   ////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |   LatticeComplex dS(&Grid); | ||||||
|  |   dS = zero; | ||||||
|  |   LatticeComplex dSmom(&Grid); | ||||||
|  |   dSmom = zero; | ||||||
|  |   LatticeComplex dSmom2(&Grid); | ||||||
|  |   dSmom2 = zero; | ||||||
|  |  | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     mommu = PeekIndex<LorentzIndex>(UdSdU, mu); // P_mu = | ||||||
|  |     mommu = Ta(mommu) * 2.0;                    // Mom = (P_mu - P_mu^dag) - trace(P_mu - P_mu^dag) | ||||||
|  |     PokeIndex<LorentzIndex>(UdSdU, mommu, mu);  // UdSdU_mu = Mom | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "Antihermiticity tests" << std::endl; | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     mommu = PeekIndex<LorentzIndex>(mom, mu); | ||||||
|  |     std::cout << GridLogMessage << " Mommu  " << norm2(mommu) << std::endl; | ||||||
|  |     mommu = mommu + adj(mommu); | ||||||
|  |     std::cout << GridLogMessage << " Mommu + Mommudag " << norm2(mommu) << std::endl; | ||||||
|  |     mommu = PeekIndex<LorentzIndex>(UdSdU, mu); | ||||||
|  |     std::cout << GridLogMessage << " dsdumu  " << norm2(mommu) << std::endl; | ||||||
|  |     mommu = mommu + adj(mommu); | ||||||
|  |     std::cout << GridLogMessage << " dsdumu + dag  " << norm2(mommu) << std::endl; | ||||||
|  |     std::cout << "" << std::endl; | ||||||
|  |   } | ||||||
|  |   ///////////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |   for (int mu = 0; mu < Nd; mu++) | ||||||
|  |   { | ||||||
|  |     forcemu = PeekIndex<LorentzIndex>(UdSdU, mu); | ||||||
|  |     mommu = PeekIndex<LorentzIndex>(mom, mu); | ||||||
|  |  | ||||||
|  |     // Update PF action density | ||||||
|  |     dS = dS + trace(mommu * forcemu) * dt; | ||||||
|  |  | ||||||
|  |     dSmom = dSmom - trace(mommu * forcemu) * dt; | ||||||
|  |     dSmom2 = dSmom2 - trace(forcemu * forcemu) * (0.25 * dt * dt); | ||||||
|  |  | ||||||
|  |     // Update mom action density | ||||||
|  |     mommu = mommu + forcemu * (dt * 0.5); | ||||||
|  |  | ||||||
|  |     Hmomprime -= real(sum(trace(mommu * mommu))); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   ComplexD dSpred = sum(dS); | ||||||
|  |   ComplexD dSm = sum(dSmom); | ||||||
|  |   ComplexD dSm2 = sum(dSmom2); | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "Initial mom hamiltonian is " << Hmom << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "Final   mom hamiltonian is " << Hmomprime << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "Delta   mom hamiltonian is " << Hmomprime - Hmom << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << " S      " << S << std::endl; | ||||||
|  |   std::cout << GridLogMessage << " Sprime " << Sprime << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "dS (S' - S)          :" << Sprime - S << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "predict dS (force)   :" << dSpred << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "dSm " << dSm << std::endl; | ||||||
|  |   std::cout << GridLogMessage << "dSm2" << dSm2 << std::endl; | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "Total dS    " << Hmomprime - Hmom + Sprime - S << std::endl; | ||||||
|  |  | ||||||
|  |   assert(fabs(real(Sprime - S - dSpred)) < 1.0); | ||||||
|  |  | ||||||
|  |   std::cout << GridLogMessage << "Done" << std::endl; | ||||||
|  |   Grid_finalize(); | ||||||
|  | } | ||||||
							
								
								
									
										168
									
								
								tests/hadrons/Test_hadrons_2AS_spectrum.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										168
									
								
								tests/hadrons/Test_hadrons_2AS_spectrum.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,168 @@ | |||||||
|  | /******************************************************************************* | ||||||
|  |  Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |   | ||||||
|  |  Source file: tests/hadrons/Test_hadrons_spectrum.cc | ||||||
|  |   | ||||||
|  |  Copyright (C) 2015 | ||||||
|  |   | ||||||
|  |  Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |   | ||||||
|  |  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. | ||||||
|  |  *******************************************************************************/ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Application.hpp> | ||||||
|  |  | ||||||
|  | using namespace Grid; | ||||||
|  | using namespace Hadrons; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     BEGIN_HADRONS_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MFermion) | ||||||
|  |     MODULE_REGISTER_NS(GaugeProp2AS, TGaugeProp<WilsonTwoIndexAntiSymmetricImplR>, MFermion); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MSource) | ||||||
|  |     MODULE_REGISTER_NS(Point2AS, TPoint<WilsonTwoIndexAntiSymmetricImplR>, MSource); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MContraction) | ||||||
|  |     MODULE_REGISTER_NS(Meson2AS, ARG(TMeson<WilsonTwoIndexAntiSymmetricImplR, WilsonTwoIndexAntiSymmetricImplR>), MContraction); | ||||||
|  | //    MODULE_REGISTER_NS(BaryonMultirep, ARG(TBaryon<FIMPL, FIMPL, FIMPL>), MContraction); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MSink) | ||||||
|  |     MODULE_REGISTER_NS(ScalarPoint2AS, TPoint<WilsonTwoIndexAntiSymmetricImplR>, MSink); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MSolver) | ||||||
|  |     MODULE_REGISTER_NS(RBPrecCG2AS, TRBPrecCG<WilsonTwoIndexAntiSymmetricImplR>, MSolver); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     BEGIN_MODULE_NAMESPACE(MAction) | ||||||
|  |     MODULE_REGISTER_NS(WilsonClover2AS, TWilsonClover<WilsonTwoIndexAntiSymmetricImplR>, MAction); | ||||||
|  |     END_MODULE_NAMESPACE | ||||||
|  |     END_HADRONS_NAMESPACE | ||||||
|  |  | ||||||
|  |  | ||||||
|  | int main(int argc, char *argv[]) | ||||||
|  | { | ||||||
|  |     // initialization ////////////////////////////////////////////////////////// | ||||||
|  |     Grid_init(&argc, &argv); | ||||||
|  |     HadronsLogError.Active(GridLogError.isActive()); | ||||||
|  |     HadronsLogWarning.Active(GridLogWarning.isActive()); | ||||||
|  |     HadronsLogMessage.Active(GridLogMessage.isActive()); | ||||||
|  |     HadronsLogIterative.Active(GridLogIterative.isActive()); | ||||||
|  |     HadronsLogDebug.Active(GridLogDebug.isActive()); | ||||||
|  |     LOG(Message) << "Grid initialized" << std::endl; | ||||||
|  |     // run setup /////////////////////////////////////////////////////////////// | ||||||
|  |     Application              application; | ||||||
|  |     std::vector<std::string> flavour = {"l", "s"}; | ||||||
|  |     std::vector<double>      mass    = {-0.01, -0.04}; | ||||||
|  |     double                   csw     = 1.0; | ||||||
|  |     // global parameters | ||||||
|  |     Application::GlobalPar globalPar; | ||||||
|  |     globalPar.trajCounter.start = 1500; | ||||||
|  |     globalPar.trajCounter.end   = 1520; | ||||||
|  |     globalPar.trajCounter.step  = 20; | ||||||
|  |     globalPar.seed              = "1 2 3 4"; | ||||||
|  |     application.setPar(globalPar); | ||||||
|  |     // gauge field | ||||||
|  |     application.createModule<MGauge::Unit>("gauge"); | ||||||
|  |     MSource::Point2AS::Par ptPar; | ||||||
|  |     ptPar.position = "0 0 0 0"; | ||||||
|  |     application.createModule<MSource::Point2AS>("pt", ptPar); | ||||||
|  |     // sink | ||||||
|  |     MSink::ScalarPoint2AS::Par sinkPar; | ||||||
|  |     sinkPar.mom = "0 0 0"; | ||||||
|  |     application.createModule<MSink::ScalarPoint2AS>("sink", sinkPar); | ||||||
|  |      | ||||||
|  |     // set fermion boundary conditions to be periodic space, antiperiodic time. | ||||||
|  |     std::string boundary = "1 1 1 -1"; | ||||||
|  |  | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     { | ||||||
|  |         // actions | ||||||
|  |         MAction::WilsonClover2AS::Par actionPar; | ||||||
|  |         actionPar.gauge = "gauge"; | ||||||
|  |         actionPar.mass  = mass[i]; | ||||||
|  |         actionPar.csw_r = csw; | ||||||
|  | 	    actionPar.csw_t = csw; | ||||||
|  |         actionPar.clover_anisotropy.isAnisotropic= false; | ||||||
|  |         actionPar.clover_anisotropy.t_direction  = Nd-1 ; | ||||||
|  |         actionPar.clover_anisotropy.xi_0         = 1.0  ; | ||||||
|  |         actionPar.clover_anisotropy.nu           = 1.0  ; | ||||||
|  | 	    actionPar.boundary = boundary; | ||||||
|  |         application.createModule<MAction::WilsonClover2AS>("WilsonClover2AS_" + flavour[i], actionPar); | ||||||
|  |          | ||||||
|  |         // solvers | ||||||
|  |         MSolver::RBPrecCG2AS::Par solverPar; | ||||||
|  |         solverPar.action   = "WilsonClover2AS_" + flavour[i]; | ||||||
|  |         solverPar.residual = 1.0e-8; | ||||||
|  |         application.createModule<MSolver::RBPrecCG2AS>("CG_" + flavour[i], | ||||||
|  |                                                     solverPar); | ||||||
|  |          | ||||||
|  |         // propagators | ||||||
|  |         MFermion::GaugeProp2AS::Par quarkPar; | ||||||
|  |         quarkPar.solver = "CG_" + flavour[i]; | ||||||
|  |         quarkPar.source = "pt"; | ||||||
|  |         application.createModule<MFermion::GaugeProp2AS>("Qpt_" + flavour[i], quarkPar); | ||||||
|  |         quarkPar.source = "z2"; | ||||||
|  |         application.createModule<MFermion::GaugeProp2AS>("QZ2_" + flavour[i], quarkPar); | ||||||
|  |     } | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     for (unsigned int j = i; j < flavour.size(); ++j) | ||||||
|  |     { | ||||||
|  |         MContraction::Meson2AS::Par mesPar; | ||||||
|  |          | ||||||
|  |         mesPar.output  = "mesons2AS/pt_" + flavour[i] + flavour[j]; | ||||||
|  |         mesPar.q1      = "Qpt_" + flavour[i]; | ||||||
|  |         mesPar.q2      = "Qpt_" + flavour[j]; | ||||||
|  |         mesPar.gammas  = "all"; | ||||||
|  |         mesPar.sink    = "sink"; | ||||||
|  |         application.createModule<MContraction::Meson2AS>("meson_pt_" | ||||||
|  |                                                       + flavour[i] + flavour[j], | ||||||
|  |                                                       mesPar); | ||||||
|  |       | ||||||
|  |      //   mesPar.output  = "mesons2AS/Z2_" + flavour[i] + flavour[j]; | ||||||
|  |      //   mesPar.q1      = "QZ2_" + flavour[i]; | ||||||
|  |      //   mesPar.q2      = "QZ2_" + flavour[j]; | ||||||
|  |      //   mesPar.gammas  = "all"; | ||||||
|  |      //   mesPar.sink    = "sink"; | ||||||
|  |      //   application.createModule<MContraction::Meson2AS>("meson_Z2_" | ||||||
|  |      //                                                 + flavour[i] + flavour[j], | ||||||
|  |      //                                                 mesPar); | ||||||
|  |     } | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     for (unsigned int j = i; j < flavour.size(); ++j) | ||||||
|  |     for (unsigned int k = j; k < flavour.size(); ++k) | ||||||
|  |     { | ||||||
|  |         MContraction::Baryon::Par barPar; | ||||||
|  |          | ||||||
|  |         barPar.output = "baryons/pt_" + flavour[i] + flavour[j] + flavour[k]; | ||||||
|  |         barPar.q1     = "Qpt_" + flavour[i]; | ||||||
|  |         barPar.q2     = "Qpt_" + flavour[j]; | ||||||
|  |         barPar.q3     = "Qpt_" + flavour[k]; | ||||||
|  |         application.createModule<MContraction::Baryon>( | ||||||
|  |             "baryon_pt_" + flavour[i] + flavour[j] + flavour[k], barPar); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // execution | ||||||
|  |     application.saveParameterFile("spectrum.xml"); | ||||||
|  |     application.run(); | ||||||
|  |      | ||||||
|  |     // epilogue | ||||||
|  |     LOG(Message) << "Grid is finalizing now" << std::endl; | ||||||
|  |     Grid_finalize(); | ||||||
|  |      | ||||||
|  |     return EXIT_SUCCESS; | ||||||
|  | } | ||||||
| @@ -130,8 +130,8 @@ int main(int argc, char **argv) | |||||||
|     for (int c = 0; c < Nc; ++c) |     for (int c = 0; c < Nc; ++c) | ||||||
|     { |     { | ||||||
|         ref = prop; |         ref = prop; | ||||||
|         PropToFerm(ferm, prop, s, c); |         PropToFerm<WilsonImplR>(ferm, prop, s, c); | ||||||
|         FermToProp(prop, ferm, s, c); |         FermToProp<WilsonImplR>(prop, ferm, s, c); | ||||||
|  |  | ||||||
|         std::cout << "Spin = " << s << ", Colour = " << c << std::endl; |         std::cout << "Spin = " << s << ", Colour = " << c << std::endl; | ||||||
|         ref -= prop; |         ref -= prop; | ||||||
|   | |||||||
							
								
								
									
										157
									
								
								tests/hadrons/Test_hadrons_wilsonFund.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								tests/hadrons/Test_hadrons_wilsonFund.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | |||||||
|  | /******************************************************************************* | ||||||
|  |  Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |   | ||||||
|  |  Source file: tests/hadrons/Test_hadrons_spectrum.cc | ||||||
|  |   | ||||||
|  |  Copyright (C) 2015 | ||||||
|  |   | ||||||
|  |  Author: Antonin Portelli <antonin.portelli@me.com> | ||||||
|  |   | ||||||
|  |  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. | ||||||
|  |  *******************************************************************************/ | ||||||
|  |  | ||||||
|  | #include <Grid/Hadrons/Application.hpp> | ||||||
|  |  | ||||||
|  | using namespace Grid; | ||||||
|  | using namespace Hadrons; | ||||||
|  |  | ||||||
|  | int main(int argc, char *argv[]) | ||||||
|  | { | ||||||
|  |     // initialization ////////////////////////////////////////////////////////// | ||||||
|  |     Grid_init(&argc, &argv); | ||||||
|  |     HadronsLogError.Active(GridLogError.isActive()); | ||||||
|  |     HadronsLogWarning.Active(GridLogWarning.isActive()); | ||||||
|  |     HadronsLogMessage.Active(GridLogMessage.isActive()); | ||||||
|  |     HadronsLogIterative.Active(GridLogIterative.isActive()); | ||||||
|  |     HadronsLogDebug.Active(GridLogDebug.isActive()); | ||||||
|  |     LOG(Message) << "Grid initialized" << std::endl; | ||||||
|  |      | ||||||
|  |     // run setup /////////////////////////////////////////////////////////////// | ||||||
|  |     Application              application; | ||||||
|  |     std::vector<std::string> flavour = {"l"}; | ||||||
|  |     std::vector<double>      mass    = {-0.1}; | ||||||
|  |     double                   csw     = 0.0; | ||||||
|  |      | ||||||
|  |     // global parameters | ||||||
|  |     Application::GlobalPar globalPar; | ||||||
|  |    | ||||||
|  |     globalPar.trajCounter.start = 309; | ||||||
|  |     globalPar.trajCounter.end   = 310; | ||||||
|  |     globalPar.trajCounter.step  = 1; | ||||||
|  |  | ||||||
|  |     globalPar.seed              = "1 2 3 4"; | ||||||
|  |  | ||||||
|  |     application.setPar(globalPar); | ||||||
|  |     // gauge field | ||||||
|  |     application.createModule<MIO::LoadNersc>("gauge"); | ||||||
|  |     | ||||||
|  |     // sources | ||||||
|  |     //MSource::Z2::Par z2Par; | ||||||
|  |     //z2Par.tA = 0; | ||||||
|  |     //z2Par.tB = 0; | ||||||
|  |     //application.createModule<MSource::Z2>("z2", z2Par); | ||||||
|  |     MSource::Point::Par ptPar; | ||||||
|  |     ptPar.position = "0 0 0 0"; | ||||||
|  |     application.createModule<MSource::Point>("pt", ptPar); | ||||||
|  |     // sink | ||||||
|  |     MSink::Point::Par sinkPar; | ||||||
|  |     sinkPar.mom = "0 0 0"; | ||||||
|  |     application.createModule<MSink::ScalarPoint>("sink", sinkPar); | ||||||
|  |      | ||||||
|  |     // set fermion boundary conditions to be periodic space, antiperiodic time. | ||||||
|  |     std::string boundary = "1 1 1 -1"; | ||||||
|  |  | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     { | ||||||
|  |         // actions | ||||||
|  |         MAction::WilsonClover::Par actionPar; | ||||||
|  |         actionPar.gauge = "gauge"; | ||||||
|  |         actionPar.mass  = mass[i]; | ||||||
|  |         actionPar.boundary = boundary; | ||||||
|  |         actionPar.csw_r = csw; | ||||||
|  |         actionPar.csw_t = csw; | ||||||
|  |  | ||||||
|  |         // !!!!! Check if Anisotropy works  !!!!! | ||||||
|  |         actionPar.clover_anisotropy.isAnisotropic= false; | ||||||
|  |         actionPar.clover_anisotropy.t_direction  = 3    ;   // Explicit for D=4 | ||||||
|  |         actionPar.clover_anisotropy.xi_0         = 1.0  ; | ||||||
|  |         actionPar.clover_anisotropy.nu           = 1.0  ; | ||||||
|  |  | ||||||
|  |         application.createModule<MAction::WilsonClover>("WilsonClover_" + flavour[i], actionPar); | ||||||
|  |          | ||||||
|  |         // solvers | ||||||
|  |         MSolver::RBPrecCG::Par solverPar; | ||||||
|  |         solverPar.action   = "WilsonClover_" + flavour[i]; | ||||||
|  |         solverPar.residual = 1.0e-8; | ||||||
|  |         application.createModule<MSolver::RBPrecCG>("CG_" + flavour[i], | ||||||
|  |                                                     solverPar); | ||||||
|  |          | ||||||
|  |         // propagators | ||||||
|  |         MFermion::GaugeProp::Par quarkPar; | ||||||
|  |         quarkPar.solver = "CG_" + flavour[i]; | ||||||
|  |         quarkPar.source = "pt"; | ||||||
|  |         application.createModule<MFermion::GaugeProp>("Qpt_" + flavour[i], quarkPar); | ||||||
|  |  //       quarkPar.source = "z2"; | ||||||
|  |  //       application.createModule<MFermion::GaugeProp>("QZ2_" + flavour[i], quarkPar); | ||||||
|  |     } | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     for (unsigned int j = i; j < flavour.size(); ++j) | ||||||
|  |     { | ||||||
|  |         MContraction::Meson::Par mesPar; | ||||||
|  |          | ||||||
|  |         mesPar.output  = "Fund_mesons/pt_" + flavour[i] + flavour[j]; | ||||||
|  |         mesPar.q1      = "Qpt_" + flavour[i]; | ||||||
|  |         mesPar.q2      = "Qpt_" + flavour[j]; | ||||||
|  |         mesPar.gammas  = "all"; | ||||||
|  |         mesPar.sink    = "sink"; | ||||||
|  |         application.createModule<MContraction::Meson>("meson_pt_" | ||||||
|  |                                                       + flavour[i] + flavour[j], | ||||||
|  |                                                       mesPar); | ||||||
|  |    //     mesPar.output  = "mesons/Z2_" + flavour[i] + flavour[j]; | ||||||
|  |    //     mesPar.q1      = "QZ2_" + flavour[i]; | ||||||
|  |    //     mesPar.q2      = "QZ2_" + flavour[j]; | ||||||
|  |    //     mesPar.gammas  = "all"; | ||||||
|  |    //     mesPar.sink    = "sink"; | ||||||
|  |    //     application.createModule<MContraction::Meson>("meson_Z2_" | ||||||
|  |    //                                                   + flavour[i] + flavour[j], | ||||||
|  |    //                                                   mesPar); | ||||||
|  |     } | ||||||
|  |     for (unsigned int i = 0; i < flavour.size(); ++i) | ||||||
|  |     for (unsigned int j = i; j < flavour.size(); ++j) | ||||||
|  |     for (unsigned int k = j; k < flavour.size(); ++k) | ||||||
|  |     { | ||||||
|  |         MContraction::Baryon::Par barPar; | ||||||
|  |          | ||||||
|  |         barPar.output = "Fund_baryons/pt_" + flavour[i] + flavour[j] + flavour[k]; | ||||||
|  |         barPar.q1     = "Qpt_" + flavour[i]; | ||||||
|  |         barPar.q2     = "Qpt_" + flavour[j]; | ||||||
|  |         barPar.q3     = "Qpt_" + flavour[k]; | ||||||
|  |         application.createModule<MContraction::Baryon>( | ||||||
|  |             "baryon_pt_" + flavour[i] + flavour[j] + flavour[k], barPar); | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     // execution | ||||||
|  |     application.saveParameterFile("WilsonClover_spectrum.xml"); | ||||||
|  |     application.run(); | ||||||
|  |      | ||||||
|  |     // epilogue | ||||||
|  |     LOG(Message) << "Grid is finalizing now" << std::endl; | ||||||
|  |     Grid_finalize(); | ||||||
|  |      | ||||||
|  |     return EXIT_SUCCESS; | ||||||
|  | } | ||||||
							
								
								
									
										139
									
								
								tests/hmc/Test_hmc_EOWilsonCloverFermionGauge.cc
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										139
									
								
								tests/hmc/Test_hmc_EOWilsonCloverFermionGauge.cc
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,139 @@ | |||||||
|  | /************************************************************************************* | ||||||
|  |  | ||||||
|  | Grid physics library, www.github.com/paboyle/Grid | ||||||
|  |  | ||||||
|  | Source file: ./tests/Test_hmc_WilsonFermionGauge.cc | ||||||
|  |  | ||||||
|  | Copyright (C) 2016 | ||||||
|  |  | ||||||
|  | Author: Guido Cossu <guido.cossu@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 */ | ||||||
|  | #include <Grid/Grid.h> | ||||||
|  |  | ||||||
|  | int main(int argc, char **argv) { | ||||||
|  |   using namespace Grid; | ||||||
|  |   using namespace Grid::QCD; | ||||||
|  |  | ||||||
|  |   Grid_init(&argc, &argv); | ||||||
|  |   int threads = GridThread::GetThreads(); | ||||||
|  |   // here make a routine to print all the relevant information on the run | ||||||
|  |   std::cout << GridLogMessage << "Grid is setup to use " << threads << " threads" << std::endl; | ||||||
|  |  | ||||||
|  |    // Typedefs to simplify notation | ||||||
|  |   typedef GenericHMCRunner<MinimumNorm2> HMCWrapper;  // Uses the default minimum norm | ||||||
|  |   typedef WilsonImplR FermionImplPolicy; | ||||||
|  |   typedef WilsonCloverFermionR FermionAction; | ||||||
|  |   typedef typename FermionAction::FermionField FermionField; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   //:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: | ||||||
|  |   HMCWrapper TheHMC; | ||||||
|  |  | ||||||
|  |   // Grid from the command line | ||||||
|  |   TheHMC.Resources.AddFourDimGrid("gauge"); | ||||||
|  |   // Possibile to create the module by hand  | ||||||
|  |   // hardcoding parameters or using a Reader | ||||||
|  |  | ||||||
|  |  | ||||||
|  |   // Checkpointer definition | ||||||
|  |   CheckpointerParameters CPparams;   | ||||||
|  |   CPparams.config_prefix = "ckpoint_lat"; | ||||||
|  |   CPparams.rng_prefix = "ckpoint_rng"; | ||||||
|  |   CPparams.saveInterval = 5; | ||||||
|  |   CPparams.format = "IEEE64BIG"; | ||||||
|  |    | ||||||
|  |   TheHMC.Resources.LoadNerscCheckpointer(CPparams); | ||||||
|  |  | ||||||
|  |   RNGModuleParameters RNGpar; | ||||||
|  |   RNGpar.serial_seeds = "1 2 3 4 5"; | ||||||
|  |   RNGpar.parallel_seeds = "6 7 8 9 10"; | ||||||
|  |   TheHMC.Resources.SetRNGSeeds(RNGpar); | ||||||
|  |  | ||||||
|  |   // Construct observables | ||||||
|  |   // here there is too much indirection  | ||||||
|  |   typedef PlaquetteMod<HMCWrapper::ImplPolicy> PlaqObs; | ||||||
|  |   TheHMC.Resources.AddObservable<PlaqObs>(); | ||||||
|  |   ////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |   ///////////////////////////////////////////////////////////// | ||||||
|  |   // Collect actions, here use more encapsulation | ||||||
|  |   // need wrappers of the fermionic classes  | ||||||
|  |   // that have a complex construction | ||||||
|  |   // standard | ||||||
|  |   RealD beta = 5.6 ; | ||||||
|  |   WilsonGaugeActionR Waction(beta); | ||||||
|  |    | ||||||
|  |   // temporarily need a gauge field | ||||||
|  |   auto GridPtr = TheHMC.Resources.GetCartesian(); | ||||||
|  |   auto GridRBPtr = TheHMC.Resources.GetRBCartesian(); | ||||||
|  |  | ||||||
|  |   LatticeGaugeField U(GridPtr); | ||||||
|  |  | ||||||
|  |   Real mass = 0.01; | ||||||
|  |   Real csw = 1.0; | ||||||
|  |  | ||||||
|  |   FermionAction FermOp(U, *GridPtr, *GridRBPtr, mass, csw); | ||||||
|  |  | ||||||
|  |   ConjugateGradient<FermionField> CG(1.0e-8, 2000); | ||||||
|  |  | ||||||
|  |   TwoFlavourEvenOddPseudoFermionAction<FermionImplPolicy> Nf2(FermOp, CG, CG); | ||||||
|  |  | ||||||
|  |     // Set smearing (true/false), default: false | ||||||
|  |   Nf2.is_smeared = false; | ||||||
|  |  | ||||||
|  |  | ||||||
|  |     // Collect actions | ||||||
|  |   ActionLevel<HMCWrapper::Field> Level1(1); | ||||||
|  |   Level1.push_back(&Nf2); | ||||||
|  |  | ||||||
|  |   ActionLevel<HMCWrapper::Field> Level2(4); | ||||||
|  |   Level2.push_back(&Waction); | ||||||
|  |  | ||||||
|  |   TheHMC.TheAction.push_back(Level1); | ||||||
|  |   TheHMC.TheAction.push_back(Level2); | ||||||
|  |   ///////////////////////////////////////////////////////////// | ||||||
|  |  | ||||||
|  |   /* | ||||||
|  |     double rho = 0.1;  // smearing parameter | ||||||
|  |     int Nsmear = 2;    // number of smearing levels | ||||||
|  |     Smear_Stout<HMCWrapper::ImplPolicy> Stout(rho); | ||||||
|  |     SmearedConfiguration<HMCWrapper::ImplPolicy> SmearingPolicy( | ||||||
|  |         UGrid, Nsmear, Stout); | ||||||
|  |   */ | ||||||
|  |  | ||||||
|  |   // HMC parameters are serialisable  | ||||||
|  |   TheHMC.Parameters.MD.MDsteps = 20; | ||||||
|  |   TheHMC.Parameters.MD.trajL   = 1.0; | ||||||
|  |  | ||||||
|  |   TheHMC.ReadCommandLine(argc, argv); // these can be parameters from file | ||||||
|  |   TheHMC.Run();  // no smearing | ||||||
|  |   // TheHMC.Run(SmearingPolicy); // for smearing | ||||||
|  |  | ||||||
|  |   Grid_finalize(); | ||||||
|  |  | ||||||
|  | } // main | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -31,7 +31,8 @@ class ScalarActionParameters : Serializable { | |||||||
|  public: |  public: | ||||||
|   GRID_SERIALIZABLE_CLASS_MEMBERS(ScalarActionParameters, |   GRID_SERIALIZABLE_CLASS_MEMBERS(ScalarActionParameters, | ||||||
|     double, mass_squared, |     double, mass_squared, | ||||||
|     double, lambda); |     double, lambda, | ||||||
|  |     double, g); | ||||||
|  |  | ||||||
|     template <class ReaderClass > |     template <class ReaderClass > | ||||||
|   ScalarActionParameters(Reader<ReaderClass>& Reader){ |   ScalarActionParameters(Reader<ReaderClass>& Reader){ | ||||||
| @@ -140,7 +141,7 @@ int main(int argc, char **argv) { | |||||||
|  |  | ||||||
|   // Scalar action in adjoint representation |   // Scalar action in adjoint representation | ||||||
|   ScalarActionParameters SPar(Reader); |   ScalarActionParameters SPar(Reader); | ||||||
|   ScalarAction Saction(SPar.mass_squared, SPar.lambda); |   ScalarAction Saction(SPar.mass_squared, SPar.lambda, SPar.g); | ||||||
|  |  | ||||||
|   // Collect actions |   // Collect actions | ||||||
|   ActionLevel<ScalarAction::Field, ScalarNxNMatrixFields<Ncolours>> Level1(1); |   ActionLevel<ScalarAction::Field, ScalarNxNMatrixFields<Ncolours>> Level1(1); | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user