Loading [MathJax]/extensions/tex2jax.js
ATLAS Offline Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Public Member Functions | Private Member Functions | Private Attributes | List of all members
DerivationFramework::Select_onia2mumu Class Reference

#include <Select_onia2mumu.h>

Inheritance diagram for DerivationFramework::Select_onia2mumu:
Collaboration diagram for DerivationFramework::Select_onia2mumu:

Public Member Functions

 Select_onia2mumu (const std::string &t, const std::string &n, const IInterface *p)
 
StatusCode initialize () override
 inirialization and finalization More...
 
virtual StatusCode addBranches () const override
 : augmentation and selection Retrieved vertices are augmented with usual information. More...
 

Private Member Functions

void ProcessVertex (xAOD::BPhysHypoHelper &, xAOD::BPhysHelper::pv_type) const
 

Private Attributes

ToolHandle< Trk::V0Toolsm_v0Tools
 tools More...
 
std::string m_hypoName
 job options More...
 
SG::ReadHandleKey< xAOD::VertexContainerm_inputVtxContainerName
 name of the input container name More...
 
std::vector< double > m_trkMasses
 track mass hypotheses More...
 
double m_massHypo
 vertex mass hypothesis More...
 
double m_massMax
 invariant mass range More...
 
double m_massMin
 invariant mass range More...
 
double m_chi2Max
 max chi2 cut More...
 
double m_lxyMin
 min lxy cut More...
 
int m_DoVertexType
 Allows user to skip certain vertexes - bitwise test 7==all(111) More...
 
bool m_do3d
 

Detailed Description

Definition at line 32 of file Select_onia2mumu.h.

Constructor & Destructor Documentation

◆ Select_onia2mumu()

DerivationFramework::Select_onia2mumu::Select_onia2mumu ( const std::string &  t,
const std::string &  n,
const IInterface *  p 
)

Definition at line 24 of file Select_onia2mumu.cxx.

26  :
27  base_class(t,n,p),
28  m_v0Tools("Trk::V0Tools")
29  {
30 
31  // Declare tools
32  declareProperty("V0Tools", m_v0Tools);
33 
34  // Declare user-defined properties
35 
36  declareProperty("HypothesisName" , m_hypoName = "A");
37  declareProperty("InputVtxContainerName", m_inputVtxContainerName = "JpsiCandidates");
38  declareProperty("TrkMasses" , m_trkMasses = std::vector<double>(2, 105.658) );
39  declareProperty("VtxMassHypo" , m_massHypo = 3096.916 );
40  declareProperty("MassMax" , m_massMax = 6000);
41  declareProperty("MassMin" , m_massMin = 2000);
42  declareProperty("Chi2Max" , m_chi2Max = 200);
43  declareProperty("DoVertexType" , m_DoVertexType = 7);
44  declareProperty("LxyMin" , m_lxyMin = std::numeric_limits<double>::lowest());
45  declareProperty("Do3d" , m_do3d = false);
46 
47  }

Member Function Documentation

◆ addBranches()

StatusCode DerivationFramework::Select_onia2mumu::addBranches ( ) const
overridevirtual

: augmentation and selection Retrieved vertices are augmented with usual information.

Selection is performed and each candidate is decorated with the Char_t flag named "passed_"+name() to indicate whether if the candidate passed the selection. This flag is then used by the event selection tool and by the vertex thinning tool.

Definition at line 130 of file Select_onia2mumu.cxx.

131  {
132 
134  SG::auxid_set_t decor_auxids;
135 
136  bool doPt = (m_DoVertexType & 1) != 0;
137  bool doA0 = (m_DoVertexType & 2) != 0;
138  bool doZ0 = (m_DoVertexType & 4) != 0;
139  bool doZ0BA = (m_DoVertexType & 8) != 0;
140  // loop over onia candidates and perform selection and augmentation
141  xAOD::VertexContainer::const_iterator oniaItr = oniaContainer->begin();
142  for(; oniaItr!=oniaContainer->end(); ++oniaItr) {
143  // create BPhysHypoHelper
144  xAOD::BPhysHypoHelper onia(m_hypoName, *oniaItr, &decor_auxids);
145  if((*oniaItr)->nTrackParticles() != m_trkMasses.size())
146  ATH_MSG_WARNING("Vertex has " << (*oniaItr)->nTrackParticles() << " while provided masses " << m_trkMasses.size());
147  //----------------------------------------------------
148  // decorate the vertex
149  //----------------------------------------------------
150  // a) invariant mass and error
151  if( !onia.setMass(m_trkMasses) ) ATH_MSG_WARNING("Decoration onia.setMass failed");
152 
153  double massErr = m_v0Tools->invariantMassError(onia.vtx(), m_trkMasses);
154  if( !onia.setMassErr(massErr) ) ATH_MSG_WARNING("Decoration onia.setMassErr failed");
155 
156  // b) proper decay time and error:
157  // retrieve the refitted PV (or the original one, if the PV refitting was turned off)
162 
163  //----------------------------------------------------
164  // perform the selection (i.e. flag the vertex)
165  //----------------------------------------------------
166  // flag the vertex indicating that it is selected by this selector
167  onia.setPass(true);
168 
169  // now we check othe cuts. if one of them didn't pass, set the flag to 0
170  // and continue to the next candidate:
171 
172  // 1) invariant mass cut
173  if( onia.mass() < m_massMin || onia.mass() > m_massMax) {
174  onia.setPass(false); // flag as failed
175  continue;
176  }
177 
178  // 2) chi2 cut
179  if( onia.vtx()->chiSquared() > m_chi2Max) {
180  onia.setPass(false);; // flag as failed
181  continue;
182  }
183  // 3) lxy cut
185  onia.setPass(false);; // flag as failed
186  continue;
187  }
188 
189  } // end of loop over onia candidates
190 
191  // Lock the decorations we just produced.
193  const_cast<xAOD::VertexContainer*> (oniaContainer.cptr());
194  for (SG::auxid_t auxid : decor_auxids) {
195  onia_nc->lockDecoration (auxid);
196  }
197 
198  // all OK
199  return StatusCode::SUCCESS;
200  }

◆ initialize()

StatusCode DerivationFramework::Select_onia2mumu::initialize ( )
override

inirialization and finalization

Definition at line 51 of file Select_onia2mumu.cxx.

52  {
53 
54  ATH_MSG_DEBUG("in initialize()");
55 
56  // retrieve V0 tools
57  CHECK( m_v0Tools.retrieve() );
58  ATH_CHECK(m_inputVtxContainerName.initialize());
59 
60  return StatusCode::SUCCESS;
61 
62  }

◆ ProcessVertex()

void DerivationFramework::Select_onia2mumu::ProcessVertex ( xAOD::BPhysHypoHelper onia,
xAOD::BPhysHelper::pv_type  pv_t 
) const
private

Definition at line 66 of file Select_onia2mumu.cxx.

66  {
67  constexpr float errConst = -9999999;
68  const xAOD::Vertex* pv = onia.pv(pv_t);
69  if(pv) {
70  // decorate the vertex.
71  // Proper decay time assuming constant mass hypothesis m_massHypo
72  BPHYS_CHECK( onia.setTau( m_v0Tools->tau(onia.vtx(), pv, m_massHypo),
73  pv_t,
75  // Proper decay time assuming error constant mass hypothesis m_massHypo
76  BPHYS_CHECK( onia.setTauErr( m_v0Tools->tauError(onia.vtx(), pv, m_massHypo),
77  pv_t,
79 
80  BPHYS_CHECK( onia.setTau( m_v0Tools->tau(onia.vtx(), pv, m_trkMasses),
81  pv_t,
83 
84  BPHYS_CHECK( onia.setTauErr( m_v0Tools->tauError(onia.vtx(), pv, m_trkMasses),
85  pv_t,
87 
88  //enum pv_type {PV_MAX_SUM_PT2, PV_MIN_A0, PV_MIN_Z0, PV_MIN_Z0_BA};
89  }else{
90 
91 
92  BPHYS_CHECK( onia.setTau(errConst, pv_t,
94  // Proper decay time assuming error constant mass hypothesis m_massHypo
95  BPHYS_CHECK( onia.setTauErr( errConst,
96  pv_t,
98 
99  BPHYS_CHECK( onia.setTau( errConst,
100  pv_t,
102 
103  BPHYS_CHECK( onia.setTauErr( errConst,
104  pv_t,
106  }
107 
108  if(m_do3d){
109  BPHYS_CHECK( onia.setTau3d( pv ? m_v0Tools->tau3D(onia.vtx(), pv, m_massHypo) : errConst,
110  pv_t,
112  // Proper decay time assuming error constant mass hypothesis m_massHypo
113  BPHYS_CHECK( onia.setTau3dErr( pv ? m_v0Tools->tau3DError(onia.vtx(), pv, m_massHypo) : errConst,
114  pv_t,
116 
117  BPHYS_CHECK( onia.setTau3d( pv ? m_v0Tools->tau3D(onia.vtx(), pv, m_trkMasses) : errConst,
118  pv_t,
120 
121  BPHYS_CHECK( onia.setTau3dErr( pv ? m_v0Tools->tau3DError(onia.vtx(), pv, m_trkMasses) : errConst,
122  pv_t,
124 
125  }
126 
127  }

Member Data Documentation

◆ m_chi2Max

double DerivationFramework::Select_onia2mumu::m_chi2Max
private

max chi2 cut

Definition at line 63 of file Select_onia2mumu.h.

◆ m_do3d

bool DerivationFramework::Select_onia2mumu::m_do3d
private

Definition at line 66 of file Select_onia2mumu.h.

◆ m_DoVertexType

int DerivationFramework::Select_onia2mumu::m_DoVertexType
private

Allows user to skip certain vertexes - bitwise test 7==all(111)

Definition at line 65 of file Select_onia2mumu.h.

◆ m_hypoName

std::string DerivationFramework::Select_onia2mumu::m_hypoName
private

job options

name of the mass hypothesis. E.g. Jpis, Upsi, etc. Will be used as a prefix for decorations

Definition at line 57 of file Select_onia2mumu.h.

◆ m_inputVtxContainerName

SG::ReadHandleKey<xAOD::VertexContainer> DerivationFramework::Select_onia2mumu::m_inputVtxContainerName
private

name of the input container name

Definition at line 58 of file Select_onia2mumu.h.

◆ m_lxyMin

double DerivationFramework::Select_onia2mumu::m_lxyMin
private

min lxy cut

Definition at line 64 of file Select_onia2mumu.h.

◆ m_massHypo

double DerivationFramework::Select_onia2mumu::m_massHypo
private

vertex mass hypothesis

Definition at line 60 of file Select_onia2mumu.h.

◆ m_massMax

double DerivationFramework::Select_onia2mumu::m_massMax
private

invariant mass range

Definition at line 61 of file Select_onia2mumu.h.

◆ m_massMin

double DerivationFramework::Select_onia2mumu::m_massMin
private

invariant mass range

Definition at line 62 of file Select_onia2mumu.h.

◆ m_trkMasses

std::vector<double> DerivationFramework::Select_onia2mumu::m_trkMasses
private

track mass hypotheses

Definition at line 59 of file Select_onia2mumu.h.

◆ m_v0Tools

ToolHandle<Trk::V0Tools> DerivationFramework::Select_onia2mumu::m_v0Tools
private

tools

Definition at line 53 of file Select_onia2mumu.h.


The documentation for this class was generated from the following files:
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
xAOD::BPhysHypoHelper::setTau3dErr
bool setTau3dErr(const float val, const pv_type vertexType=BPhysHelper::PV_MIN_A0, const tau_type tauType=BPhysHypoHelper::TAU_CONST_MASS)
proper decay time error
Definition: BPhysHypoHelper.cxx:322
xAOD::BPhysHypoHelper::setTauErr
bool setTauErr(const float val, const pv_type vertexType=BPhysHelper::PV_MIN_A0, const tau_type tauType=BPhysHypoHelper::TAU_CONST_MASS)
proper decay time error
Definition: BPhysHypoHelper.cxx:179
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:67
DerivationFramework::Select_onia2mumu::ProcessVertex
void ProcessVertex(xAOD::BPhysHypoHelper &, xAOD::BPhysHelper::pv_type) const
Definition: Select_onia2mumu.cxx:66
DerivationFramework::Select_onia2mumu::m_chi2Max
double m_chi2Max
max chi2 cut
Definition: Select_onia2mumu.h:63
DerivationFramework::Select_onia2mumu::m_trkMasses
std::vector< double > m_trkMasses
track mass hypotheses
Definition: Select_onia2mumu.h:59
DerivationFramework::Select_onia2mumu::m_v0Tools
ToolHandle< Trk::V0Tools > m_v0Tools
tools
Definition: Select_onia2mumu.h:53
DerivationFramework::Select_onia2mumu::m_massMax
double m_massMax
invariant mass range
Definition: Select_onia2mumu.h:61
xAOD::BPhysHelper::PV_MIN_Z0
@ PV_MIN_Z0
Definition: BPhysHelper.h:475
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
xAOD::BPhysHypoHelper::TAU_INV_MASS
@ TAU_INV_MASS
Definition: BPhysHypoHelper.h:140
DerivationFramework::Select_onia2mumu::m_massHypo
double m_massHypo
vertex mass hypothesis
Definition: Select_onia2mumu.h:60
SG::auxid_t
size_t auxid_t
Identifier for a particular aux data item.
Definition: AuxTypes.h:27
xAOD::BPhysHypoHelper
Definition: BPhysHypoHelper.h:73
BPHYS_CHECK
#define BPHYS_CHECK(EXP)
Useful CHECK macro.
Definition: BPhysHelper.h:738
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
beamspotman.n
n
Definition: beamspotman.py:731
DerivationFramework::Select_onia2mumu::m_hypoName
std::string m_hypoName
job options
Definition: Select_onia2mumu.h:57
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
xAOD::BPhysHelper::PV_MIN_A0
@ PV_MIN_A0
Definition: BPhysHelper.h:475
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
CHECK
#define CHECK(...)
Evaluate an expression and check for errors.
Definition: Control/AthenaKernel/AthenaKernel/errorcheck.h:422
xAOD::BPhysHypoHelper::TAU_CONST_MASS
@ TAU_CONST_MASS
Definition: BPhysHypoHelper.h:140
DataVector
Derived DataVector<T>.
Definition: DataVector.h:794
DerivationFramework::Select_onia2mumu::m_inputVtxContainerName
SG::ReadHandleKey< xAOD::VertexContainer > m_inputVtxContainerName
name of the input container name
Definition: Select_onia2mumu.h:58
DerivationFramework::Select_onia2mumu::m_do3d
bool m_do3d
Definition: Select_onia2mumu.h:66
DerivationFramework::Select_onia2mumu::m_massMin
double m_massMin
invariant mass range
Definition: Select_onia2mumu.h:62
xAOD::BPhysHypoHelper::setTau3d
bool setTau3d(const float val, const pv_type vertexType=BPhysHelper::PV_MIN_A0, const tau_type tauType=BPhysHypoHelper::TAU_CONST_MASS)
proper decay time
Definition: BPhysHypoHelper.cxx:286
xAOD::BPhysHelper::vtx
const xAOD::Vertex * vtx() const
Getter method for the cached xAOD::Vertex.
Definition: BPhysHelper.h:108
xAOD::BPhysHelper::PV_MAX_SUM_PT2
@ PV_MAX_SUM_PT2
Definition: BPhysHelper.h:475
xAOD::Vertex_v1
Class describing a Vertex.
Definition: Vertex_v1.h:42
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
python.changerun.pv
pv
Definition: changerun.py:81
xAOD::BPhysHelper::pv
const xAOD::Vertex * pv(const pv_type vertexType=BPhysHelper::PV_MIN_A0)
Get the refitted collision vertex of type pv_type.
Definition: BPhysHelper.cxx:796
DerivationFramework::Select_onia2mumu::m_DoVertexType
int m_DoVertexType
Allows user to skip certain vertexes - bitwise test 7==all(111)
Definition: Select_onia2mumu.h:65
DerivationFramework::Select_onia2mumu::m_lxyMin
double m_lxyMin
min lxy cut
Definition: Select_onia2mumu.h:64
SG::auxid_set_t
A set of aux data identifiers.
Definition: AuxTypes.h:47
ATLAS_THREAD_SAFE
#define ATLAS_THREAD_SAFE
Definition: checker_macros.h:211
xAOD::BPhysHypoHelper::setTau
bool setTau(const float val, const pv_type vertexType=BPhysHelper::PV_MIN_A0, const tau_type tauType=BPhysHypoHelper::TAU_CONST_MASS)
: Set the proper decay time and error.
Definition: BPhysHypoHelper.cxx:143
xAOD::BPhysHelper::PV_MIN_Z0_BA
@ PV_MIN_Z0_BA
Definition: BPhysHelper.h:475