Belle II Software  release-08-01-10
BackgroundInfo Class Reference

This class stores the information about what background was mixed or overlayed. More...

#include <BackgroundInfo.h>

Inheritance diagram for BackgroundInfo:
Collaboration diagram for BackgroundInfo:

Classes

struct  BackgroundDescr
 Structure for background description. More...
 

Public Types

enum  EMethod {
  c_Unknown = 0 ,
  c_Mixing = 1 ,
  c_Overlay = 2
}
 enum for methods used to add BG More...
 

Public Member Functions

 BELLE2_DEFINE_EXCEPTION (BackgroundInfoNotMergeable, "BackgroundInfo: objects cannot be merged")
 Exception definition.
 
 BackgroundInfo ()
 Default constructor.
 
 ~BackgroundInfo ()
 Destructor.
 
void setMethod (EMethod method)
 Set method that is used to add BG. More...
 
unsigned appendBackgroundDescr (const BackgroundDescr &bgDescr)
 Append background description of a sample. More...
 
void setComponents (const std::vector< std::string > &components)
 Set components included. More...
 
void setMinTime (double minTime)
 Set lower edge of the narrow time window. More...
 
void setMaxTime (double maxTime)
 Set upper edge of the narrow time window. More...
 
void setMinTimeECL (double minTimeECL)
 Set lower edge of ECL time window. More...
 
void setMaxTimeECL (double maxTimeECL)
 Set upper edge of ECL time window. More...
 
void setMinTimePXD (double minTimePXD)
 Set lower edge of PXD time window. More...
 
void setMaxTimePXD (double maxTimePXD)
 Set upper edge of PXD time window. More...
 
void setWrapAround (bool wrapAround)
 Set wrap-around flag. More...
 
void setMaxEdepECL (double maxEdepECL)
 Set maximal alowed energy deposited in ECL to use BG events. More...
 
void setExtensionName (const std::string &name)
 Set name that is added to default branch names of background collections Used primarily to pass this name from BGOverlayInput to BGOverlayExecutor module. More...
 
void incrementReusedCounter (unsigned index)
 Increments sample reused counter. More...
 
EMethod getMethod () const
 Returns method enum used to add BG. More...
 
const std::vector< BackgroundDescr > & getBackgrounds () const
 Returns background descriptions. More...
 
const std::vector< std::string > & getComponents () const
 Returns included components. More...
 
double getMinTime () const
 Returns lower edge of the narrow time window. More...
 
double getMaxTime () const
 Returns upper edge of the narrow time window. More...
 
double getMinTimeECL () const
 Returns lower edge of ECL time window. More...
 
double getMaxTimeECL () const
 Returns upper edge of ECL time window. More...
 
double getMinTimePXD () const
 Returns lower edge of PXD time window. More...
 
double getMaxTimePXD () const
 Returns upper edge of PXD time window. More...
 
bool getWrapAround () const
 Returns wrap-around flag. More...
 
double getMaxEdepECL () const
 Returns maximal alowed energy deposited in ECL to use BG events. More...
 
const std::string & getExtensionName () const
 Returns name added to default branch names of background collections Used primarily to pass this name from BGOverlayInput to BGOverlayExecutor module. More...
 
virtual void merge (const Mergeable *other) override
 Implementation of abstract class function.
 
virtual void clear () override
 Implementation of abstract class function.
 
void print () const
 Print the info.
 
virtual void removeSideEffects ()
 An ugly little method that is called before event() for input and worker processes. More...
 
virtual Long64_t Merge (TCollection *hlist)
 Allow merging using TFileMerger if saved directly to a file. More...
 
virtual void Reset ()
 Root-like Reset function for "template compatibility" with ROOT objects. More...
 
virtual void SetDirectory (TDirectory *)
 Root-like SetDirectory function for "template compatibility" with ROOT objects. More...
 

Private Member Functions

bool canBeMerged (const BackgroundInfo *other)
 Checks if other object can be merged with this object. More...
 
void printForMixing () const
 Print info when BG mixing is used.
 
void printForOverlay () const
 Print info when BG overlay is used.
 
 ClassDefOverride (BackgroundInfo, 4)
 Class definition.
 
 ClassDef (Mergeable, 0)
 Abstract base class for objects that can be merged.
 

Private Attributes

EMethod m_method = c_Unknown
 method
 
std::vector< BackgroundDescrm_backgrounds
 background descriptions
 
std::vector< std::string > m_components
 detector components included
 
double m_minTime = 0
 minimal time shift of background event
 
double m_maxTime = 0
 maximal time shift of background event
 
double m_minTimeECL = 0
 minimal time shift of background event for ECL
 
double m_maxTimeECL = 0
 maximal time shift of background event for ECL
 
double m_minTimePXD = 0
 minimal time shift of background event for PXD
 
double m_maxTimePXD = 0
 maximal time shift of background event for PXD
 
bool m_wrapAround = false
 wrap around events in the tail after maxTime
 
double m_maxEdepECL = 0
 maximal allowed deposited energy in ECL
 
std::string m_extensionName
 name added to default branch names of background
 

Detailed Description

This class stores the information about what background was mixed or overlayed.

Definition at line 26 of file BackgroundInfo.h.

Member Enumeration Documentation

◆ EMethod

enum EMethod

enum for methods used to add BG

Enumerator
c_Unknown 

unknown

c_Mixing 

BG mixing.

c_Overlay 

BG overlay.

Definition at line 39 of file BackgroundInfo.h.

39  {c_Unknown = 0,
40  c_Mixing = 1,
41  c_Overlay = 2
42  };

Member Function Documentation

◆ appendBackgroundDescr()

unsigned appendBackgroundDescr ( const BackgroundDescr bgDescr)
inline

Append background description of a sample.

Parameters
bgDescrdescription
Returns
index of appended element in std::vector

Definition at line 81 of file BackgroundInfo.h.

◆ canBeMerged()

bool canBeMerged ( const BackgroundInfo other)
private

Checks if other object can be merged with this object.

Parameters
otherobject to be merged with this object
Returns
true, if can be merged

Definition at line 18 of file BackgroundInfo.cc.

19 {
20 
21  if (otherObj->getMethod() != m_method) {
22  B2ERROR("BackgroundInfo: objects cannot be merged (different method)");
23  return false;
24  }
25 
26  std::unordered_set<int> bgThis;
27  for (const auto& bg : m_backgrounds) {
28  int key = bg.tag * 16 + bg.fileType;
29  bgThis.emplace(key);
30  }
31  std::unordered_set<int> bgOther;
32  for (const auto& bg : otherObj->getBackgrounds()) {
33  int key = bg.tag * 16 + bg.fileType;
34  bgOther.emplace(key);
35  }
36  if (bgOther != bgThis) {
37  B2ERROR("BackgroundInfo: objects cannot be merged (different backgrounds)");
38  return false;
39  }
40 
41  auto compThis = m_components;
42  std::sort(compThis.begin(), compThis.end());
43  auto compOther = otherObj->getComponents();
44  std::sort(compOther.begin(), compOther.end());
45  if (compOther != compThis) {
46  B2ERROR("BackgroundInfo: objects cannot be merged (different components)");
47  return false;
48  }
49 
50  if (otherObj->getMinTime() != m_minTime) {
51  B2ERROR("BackgroundInfo: objects cannot be merged (different minTime)");
52  return false;
53  }
54 
55  if (otherObj->getMaxTime() != m_maxTime) {
56  B2ERROR("BackgroundInfo: objects cannot be merged (different maxTime)");
57  return false;
58  }
59 
60  if (otherObj->getMinTimeECL() != m_minTimeECL) {
61  B2ERROR("BackgroundInfo: objects cannot be merged (different minTimeECL)");
62  return false;
63  }
64 
65  if (otherObj->getMaxTimeECL() != m_maxTimeECL) {
66  B2ERROR("BackgroundInfo: objects cannot be merged (different maxTimeECL)");
67  return false;
68  }
69 
70  if (otherObj->getMinTimePXD() != m_minTimePXD) {
71  B2ERROR("BackgroundInfo: objects cannot be merged (different minTimePXD)");
72  return false;
73  }
74 
75  if (otherObj->getMaxTimePXD() != m_maxTimePXD) {
76  B2ERROR("BackgroundInfo: objects cannot be merged (different maxTimePXD)");
77  return false;
78  }
79 
80  if (otherObj->getWrapAround() != m_wrapAround) {
81  B2ERROR("BackgroundInfo: objects cannot be merged (different wrapAround)");
82  return false;
83  }
84 
85  if (otherObj->getMaxEdepECL() != m_maxEdepECL) {
86  B2ERROR("BackgroundInfo: objects cannot be merged (different maxEdepECL)");
87  return false;
88  }
89 
90  return true;
91 }
double m_maxEdepECL
maximal allowed deposited energy in ECL
double m_maxTimeECL
maximal time shift of background event for ECL
std::vector< std::string > m_components
detector components included
double m_minTimePXD
minimal time shift of background event for PXD
std::vector< BackgroundDescr > m_backgrounds
background descriptions
double m_maxTime
maximal time shift of background event
double m_minTime
minimal time shift of background event
bool m_wrapAround
wrap around events in the tail after maxTime
double m_maxTimePXD
maximal time shift of background event for PXD
double m_minTimeECL
minimal time shift of background event for ECL

◆ getBackgrounds()

const std::vector<BackgroundDescr>& getBackgrounds ( ) const
inline

Returns background descriptions.

Returns
descriptions

Definition at line 170 of file BackgroundInfo.h.

◆ getComponents()

const std::vector<std::string>& getComponents ( ) const
inline

Returns included components.

Returns
vector of component names

Definition at line 176 of file BackgroundInfo.h.

◆ getExtensionName()

const std::string& getExtensionName ( ) const
inline

Returns name added to default branch names of background collections Used primarily to pass this name from BGOverlayInput to BGOverlayExecutor module.

Returns
extension name

Definition at line 231 of file BackgroundInfo.h.

◆ getMaxEdepECL()

double getMaxEdepECL ( ) const
inline

Returns maximal alowed energy deposited in ECL to use BG events.

Returns
energy cut [GeV]

Definition at line 224 of file BackgroundInfo.h.

◆ getMaxTime()

double getMaxTime ( ) const
inline

Returns upper edge of the narrow time window.

Returns
upper edge

Definition at line 188 of file BackgroundInfo.h.

◆ getMaxTimeECL()

double getMaxTimeECL ( ) const
inline

Returns upper edge of ECL time window.

Returns
upper edge

Definition at line 200 of file BackgroundInfo.h.

◆ getMaxTimePXD()

double getMaxTimePXD ( ) const
inline

Returns upper edge of PXD time window.

Returns
upper edge

Definition at line 212 of file BackgroundInfo.h.

◆ getMethod()

EMethod getMethod ( ) const
inline

Returns method enum used to add BG.

Returns
method

Definition at line 164 of file BackgroundInfo.h.

◆ getMinTime()

double getMinTime ( ) const
inline

Returns lower edge of the narrow time window.

Returns
lower edge

Definition at line 182 of file BackgroundInfo.h.

◆ getMinTimeECL()

double getMinTimeECL ( ) const
inline

Returns lower edge of ECL time window.

Returns
lower edge

Definition at line 194 of file BackgroundInfo.h.

◆ getMinTimePXD()

double getMinTimePXD ( ) const
inline

Returns lower edge of PXD time window.

Returns
lower edge

Definition at line 206 of file BackgroundInfo.h.

◆ getWrapAround()

bool getWrapAround ( ) const
inline

Returns wrap-around flag.

Returns
flag

Definition at line 218 of file BackgroundInfo.h.

◆ incrementReusedCounter()

void incrementReusedCounter ( unsigned  index)
inline

Increments sample reused counter.

Parameters
indexelement index in std::vector

Definition at line 155 of file BackgroundInfo.h.

◆ Merge()

Long64_t Merge ( TCollection *  hlist)
virtualinherited

Allow merging using TFileMerger if saved directly to a file.

Note
dictionaries containing your Mergeable class need to be loaded, so 'hadd' will not work currently.

Definition at line 14 of file Mergeable.cc.

◆ removeSideEffects()

virtual void removeSideEffects ( )
inlinevirtualinherited

An ugly little method that is called before event() for input and worker processes.

Main use case is to detach any attached TFile from this object. In the output process, it can stay attached (and grow as much as it likes).

Reimplemented in RootMergeable< T >.

Definition at line 58 of file Mergeable.h.

◆ Reset()

virtual void Reset ( )
inlinevirtualinherited

Root-like Reset function for "template compatibility" with ROOT objects.

Alias for clear().

Definition at line 66 of file Mergeable.h.

◆ setComponents()

void setComponents ( const std::vector< std::string > &  components)
inline

Set components included.

Parameters
componentsvector of component names

Definition at line 91 of file BackgroundInfo.h.

◆ SetDirectory()

virtual void SetDirectory ( TDirectory *  )
inlinevirtualinherited

Root-like SetDirectory function for "template compatibility" with ROOT objects.

Does nothing.

Definition at line 68 of file Mergeable.h.

◆ setExtensionName()

void setExtensionName ( const std::string &  name)
inline

Set name that is added to default branch names of background collections Used primarily to pass this name from BGOverlayInput to BGOverlayExecutor module.

Parameters
nameextension name

Definition at line 149 of file BackgroundInfo.h.

◆ setMaxEdepECL()

void setMaxEdepECL ( double  maxEdepECL)
inline

Set maximal alowed energy deposited in ECL to use BG events.

Parameters
maxEdepECLenergy cut [GeV]

Definition at line 142 of file BackgroundInfo.h.

◆ setMaxTime()

void setMaxTime ( double  maxTime)
inline

Set upper edge of the narrow time window.

Parameters
maxTimeupper edge

Definition at line 106 of file BackgroundInfo.h.

◆ setMaxTimeECL()

void setMaxTimeECL ( double  maxTimeECL)
inline

Set upper edge of ECL time window.

Parameters
maxTimeECLupper edge

Definition at line 118 of file BackgroundInfo.h.

◆ setMaxTimePXD()

void setMaxTimePXD ( double  maxTimePXD)
inline

Set upper edge of PXD time window.

Parameters
maxTimePXDupper edge

Definition at line 130 of file BackgroundInfo.h.

◆ setMethod()

void setMethod ( EMethod  method)
inline

Set method that is used to add BG.

Parameters
methodenum for method

Definition at line 74 of file BackgroundInfo.h.

◆ setMinTime()

void setMinTime ( double  minTime)
inline

Set lower edge of the narrow time window.

Parameters
minTimelower edge

Definition at line 100 of file BackgroundInfo.h.

◆ setMinTimeECL()

void setMinTimeECL ( double  minTimeECL)
inline

Set lower edge of ECL time window.

Parameters
minTimeECLlower edge

Definition at line 112 of file BackgroundInfo.h.

◆ setMinTimePXD()

void setMinTimePXD ( double  minTimePXD)
inline

Set lower edge of PXD time window.

Parameters
minTimePXDlower edge

Definition at line 124 of file BackgroundInfo.h.

◆ setWrapAround()

void setWrapAround ( bool  wrapAround)
inline

Set wrap-around flag.

Parameters
wrapAroundflag

Definition at line 136 of file BackgroundInfo.h.


The documentation for this class was generated from the following files: