Belle II Software  release-08-01-10
AnalysisConfigurationModule.cc
1 /**************************************************************************
2  * basf2 (Belle II Analysis Software Framework) *
3  * Author: The Belle II Collaboration *
4  * *
5  * See git log for contributors and copyright holders. *
6  * This file is licensed under LGPL-3.0, see LICENSE.md. *
7  **************************************************************************/
8 
9 #include <string>
10 #include <set>
11 #include <analysis/modules/AnalysisConfiguration/AnalysisConfigurationModule.h>
12 #include <analysis/utility/AnalysisConfiguration.h>
13 
14 using namespace std;
15 using namespace Belle2;
16 
17 
18 
20 
21 AnalysisConfigurationModule::AnalysisConfigurationModule() : Module()
22 {
23  setDescription("This is a supplementary module designed to configure other modules");
24  addParam("tupleStyle", m_tupleStyle, R"DOCSTRING(This parameter defines style of variables written by all other ntuples tools. \n
25  Possible styles on example of PX variable of pi0 from D in decay B->(D->pi0 pi) pi0:\n
26  'default': B_D_pi0_PX\n
27  'semilaconic': D_pi0_PX\n
28  'laconic': pi01_PX\n)DOCSTRING", std::string("default"));
29 
30  addParam("mcMatchingVersion", m_mcMatchingVersion, "Specifies what version of mc matching algorithm is going to be used. \n"
31  "Possibilities are: BelleII (default) and Belle. The latter should be used when analysing Belle MC.\n"
32  "The difference between the algorithms is only in the treatment (identification) of FSR photons. In Belle II MC \n"
33  "it is possible to identify FSR photons via special flag set by the generator, while in case of Belle MC such\n"
34  "information is not available.", std::string("BelleII"));
35 }
36 
38 {
39  if (m_styles.find(m_tupleStyle) == m_styles.end()) {
40  B2WARNING("Chosen tuple style '" << m_tupleStyle << "' is not defined. Using default tuple style.");
41  }
43 
44  if (m_mcMatchingVersion == "BelleII")
46  else if (m_mcMatchingVersion == "Belle")
48  else
49  B2ERROR("Invalid mcMatchingVersion specified to AnalysisConfiguration: " << m_mcMatchingVersion << "\n"
50  "Please choose between BelleII or Belle depending whether you are analysing Belle II or Belle MC.");
51 }
virtual void initialize() override
Initialize the module.
std::set< std::string > m_styles
List of possible styles of variables in nTuple Possible styles on example of PX variable of pi0 from ...
std::string m_mcMatchingVersion
specifies the version of MC matching algorithm to be used
std::string m_tupleStyle
Style of naming of variables in nTuple configured by user.
Singleton class keeping configurables of analysis components.
void setTupleStyle(const std::string &v)
Configurable-specific function to set value.
void useLegacyMCMatching(const bool flag)
Determines whether to use the legacy MCMatching algorithm (true) or not (false).
static AnalysisConfiguration * instance()
Returns a pointer to the singleton instance.
Base class for Modules.
Definition: Module.h:72
void setDescription(const std::string &description)
Sets the description of the module.
Definition: Module.cc:214
void addParam(const std::string &name, T &paramVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
Definition: Module.h:560
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Definition: Module.h:650
Abstract base class for different kinds of events.