Belle II Software  light-2205-abys
ChargedPidMVAModule.h
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 #pragma once
10 
11 // FRAMEWORK
12 #include <framework/core/Module.h>
13 #include <framework/dataobjects/EventMetaData.h>
14 #include <framework/database/DBObjPtr.h>
15 #include <analysis/DecayDescriptor/DecayDescriptor.h>
16 #include <framework/datastore/StoreArray.h>
17 
18 // MVA
19 #include <mva/interface/Expert.h>
20 #include <mva/interface/Dataset.h>
21 
22 // ANALYSIS
23 #include <analysis/VariableManager/Manager.h>
24 #include <analysis/dbobjects/ChargedPidMVAWeights.h>
25 
26 namespace Belle2 {
44  class ChargedPidMVAModule : public Module {
45 
46  typedef std::vector<std::unique_ptr<MVA::Expert> > ExpertsList;
47  typedef std::vector<std::unique_ptr<MVA::SingleDataset> > DatasetsList;
48  typedef std::vector< std::vector<const Variable::Manager::Var*> > VariablesLists;
50  public:
51 
56 
61 
68  virtual void initialize() override;
69 
75  virtual void beginRun() override;
76 
82  virtual void event() override;
83 
84  private:
85 
91  void initializeMVA();
92 
93  private:
102 
110  std::vector<std::string> m_decayStrings;
114  std::string m_payload_name;
115 
120 
125 
129  std::string m_score_varname;
130 
135 
141  std::unique_ptr<DBObjPtr<ChargedPidMVAWeights>> m_weightfiles_representation;
142 
148 
154 
160 
166 
167  };
169 }
This module evaluates the response of an MVA trained for binary charged particle identification betwe...
StoreObjPtr< EventMetaData > m_event_metadata
The event information.
int m_bkg_pdg
The input background mass hypothesis' pdgId.
std::vector< std::string > m_decayStrings
The input list of decay strings to which MVA weights will be applied.
bool m_ecl_only
Flag to specify if we use an ECL-only based training.
std::string m_score_varname
The lookup name of the MVA score variable, given the input S, B mass hypotheses for the algorithm.
std::unique_ptr< DBObjPtr< ChargedPidMVAWeights > > m_weightfiles_representation
Interface to get the database payload with the MVA weight files.
std::vector< std::unique_ptr< MVA::SingleDataset > > DatasetsList
Typedef.
StoreArray< Particle > m_particles
StoreArray of Particles.
DatasetsList m_datasets
List of MVA::SingleDataset objects.
bool m_charge_independent
Flag to specify if we use a charge-independent training.
virtual void event() override
Called once for each event.
virtual void initialize() override
Use this to initialize resources or memory your module needs.
int m_sig_pdg
The input signal mass hypothesis' pdgId.
virtual void beginRun() override
Called once before a new run begins.
VariablesLists m_variables
List of lists of feature variables.
std::vector< std::vector< const Variable::Manager::Var * > > VariablesLists
Typedef.
ChargedPidMVAModule()
Constructor, for setting module description and parameters.
VariablesLists m_spectators
List of lists of spectator variables.
virtual ~ChargedPidMVAModule()
Destructor, use this to clean up anything you created in the constructor.
std::vector< std::unique_ptr< MVA::Expert > > ExpertsList
Typedef.
ExpertsList m_experts
List of MVA::Expert objects.
std::string m_payload_name
The name of the database payload object with the MVA weights.
Base class for Modules.
Definition: Module.h:72
Accessor to arrays stored in the data store.
Definition: StoreArray.h:113
Type-safe access to single objects in the data store.
Definition: StoreObjPtr.h:95
Abstract base class for different kinds of events.
Definition: ClusterUtils.h:23