ATLAS Offline Software
Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Types | Private Member Functions | Private Attributes | List of all members
DerivationFramework::PsiPlusPsiSingleVertex Class Reference

#include <PsiPlusPsiSingleVertex.h>

Inheritance diagram for DerivationFramework::PsiPlusPsiSingleVertex:
Collaboration diagram for DerivationFramework::PsiPlusPsiSingleVertex:

Public Member Functions

 PsiPlusPsiSingleVertex (const std::string &t, const std::string &n, const IInterface *p)
 
virtual ~PsiPlusPsiSingleVertex ()=default
 
virtual StatusCode initialize () override
 
virtual StatusCode addBranches () const override
 Pass the thinning service
More...
 
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & evtStore () const
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. More...
 
virtual StatusCode sysInitialize () override
 Perform system initialization for an algorithm. More...
 
virtual StatusCode sysStart () override
 Handle START transition. More...
 
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles. More...
 
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles. More...
 
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T > &t)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc="none")
 Declare a new Gaudi property. More...
 
void updateVHKA (Gaudi::Details::PropertyBase &)
 
MsgStream & msg () const
 
MsgStream & msg (const MSG::Level lvl) const
 
bool msgLvl (const MSG::Level lvl) const
 

Static Public Member Functions

static const InterfaceID & interfaceID ()
 

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution More...
 
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
 
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed. More...
 

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
 

Private Member Functions

Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &)
 specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &)
 specialization for handling Gaudi::Property<SG::VarHandleBase> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &)
 specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
 

Private Attributes

SG::ReadHandleKey< xAOD::VertexContainerm_vertexPsi1ContainerKey
 
SG::ReadHandleKey< xAOD::VertexContainerm_vertexPsi2ContainerKey
 
std::vector< std::string > m_vertexPsi1HypoNames
 
std::vector< std::string > m_vertexPsi2HypoNames
 
SG::WriteHandleKeyArray< xAOD::VertexContainerm_outputsKeys
 
SG::ReadHandleKey< xAOD::VertexContainerm_VxPrimaryCandidateName
 Name of primary vertex container. More...
 
SG::ReadHandleKey< xAOD::TrackParticleContainerm_trackContainerName
 
SG::ReadHandleKey< xAOD::EventInfom_eventInfo_key
 
double m_jpsi1MassLower
 
double m_jpsi1MassUpper
 
double m_diTrack1MassLower
 
double m_diTrack1MassUpper
 
double m_psi1MassLower
 
double m_psi1MassUpper
 
double m_jpsi2MassLower
 
double m_jpsi2MassUpper
 
double m_diTrack2MassLower
 
double m_diTrack2MassUpper
 
double m_psi2MassLower
 
double m_psi2MassUpper
 
double m_MassLower
 
double m_MassUpper
 
int m_vtx1Daug_num
 
double m_vtx1Daug1MassHypo
 
double m_vtx1Daug2MassHypo
 
double m_vtx1Daug3MassHypo
 
double m_vtx1Daug4MassHypo
 
int m_vtx2Daug_num
 
double m_vtx2Daug1MassHypo
 
double m_vtx2Daug2MassHypo
 
double m_vtx2Daug3MassHypo
 
double m_vtx2Daug4MassHypo
 
unsigned int m_maxCandidates
 
double m_mass_jpsi1
 
double m_mass_diTrk1
 
double m_mass_psi1
 
double m_mass_jpsi2
 
double m_mass_diTrk2
 
double m_mass_psi2
 
bool m_constrJpsi1
 
bool m_constrDiTrk1
 
bool m_constrPsi1
 
bool m_constrJpsi2
 
bool m_constrDiTrk2
 
bool m_constrPsi2
 
double m_chi2cut
 
ToolHandle< Trk::TrkVKalVrtFitterm_iVertexFitter
 
ToolHandle< Analysis::PrimaryVertexRefitterm_pvRefitter
 
ToolHandle< Trk::V0Toolsm_V0Tools
 
ServiceHandle< IPartPropSvc > m_partPropSvc {this, "PartPropSvc", "PartPropSvc"}
 
bool m_refitPV
 
SG::WriteHandleKey< xAOD::VertexContainerm_refPVContainerName
 
std::string m_hypoName
 
int m_PV_max
 
int m_DoVertexType
 
size_t m_PV_minNTracks
 
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default) More...
 
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default) More...
 
std::vector< SG::VarHandleKeyArray * > m_vhka
 
bool m_varHandleArraysDeclared
 

Detailed Description

Definition at line 26 of file PsiPlusPsiSingleVertex.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< AlgTool > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ PsiPlusPsiSingleVertex()

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

Definition at line 25 of file PsiPlusPsiSingleVertex.cxx.

28  m_outputsKeys({"Psi1Vtx", "Psi2Vtx", "MainVtx"}),
29  m_VxPrimaryCandidateName("PrimaryVertices"),
30  m_trackContainerName("InDetTrackParticles"),
31  m_eventInfo_key("EventInfo"),
32  m_jpsi1MassLower(0.0),
33  m_jpsi1MassUpper(20000.0),
34  m_diTrack1MassLower(-1.0),
35  m_diTrack1MassUpper(-1.0),
36  m_psi1MassLower(0.0),
37  m_psi1MassUpper(25000.0),
38  m_jpsi2MassLower(0.0),
39  m_jpsi2MassUpper(20000.0),
40  m_diTrack2MassLower(-1.0),
41  m_diTrack2MassUpper(-1.0),
42  m_psi2MassLower(0.0),
43  m_psi2MassUpper(25000.0),
44  m_MassLower(0.0),
45  m_MassUpper(31000.0),
46  m_vtx1Daug_num(4),
51  m_vtx2Daug_num(4),
56  m_maxCandidates(0),
57  m_mass_jpsi1(-1),
58  m_mass_diTrk1(-1),
59  m_mass_psi1(-1),
60  m_mass_jpsi2(-1),
61  m_mass_diTrk2(-1),
62  m_mass_psi2(-1),
63  m_constrJpsi1(false),
64  m_constrDiTrk1(false),
65  m_constrPsi1(false),
66  m_constrJpsi2(false),
67  m_constrDiTrk2(false),
68  m_constrPsi2(false),
69  m_chi2cut(-1.0),
70  m_iVertexFitter("Trk::TrkVKalVrtFitter"),
71  m_pvRefitter("Analysis::PrimaryVertexRefitter", this),
72  m_V0Tools("Trk::V0Tools")
73  {
76  declareProperty("Psi1VtxHypoNames", m_vertexPsi1HypoNames);
77  declareProperty("Psi2VtxHypoNames", m_vertexPsi2HypoNames);
78  declareProperty("VxPrimaryCandidateName", m_VxPrimaryCandidateName);
79  declareProperty("TrackContainerName", m_trackContainerName);
80  declareProperty("RefPVContainerName", m_refPVContainerName = "RefittedPrimaryVertices");
81  declareProperty("Jpsi1MassLowerCut", m_jpsi1MassLower);
82  declareProperty("Jpsi1MassUpperCut", m_jpsi1MassUpper);
83  declareProperty("DiTrack1MassLower", m_diTrack1MassLower); // only effective when m_vtx1Daug_num=4
84  declareProperty("DiTrack1MassUpper", m_diTrack1MassUpper); // only effective when m_vtx1Daug_num=4
85  declareProperty("Psi1MassLowerCut", m_psi1MassLower);
86  declareProperty("Psi1MassUpperCut", m_psi1MassUpper);
87  declareProperty("Jpsi2MassLowerCut", m_jpsi2MassLower);
88  declareProperty("Jpsi2MassUpperCut", m_jpsi2MassUpper);
89  declareProperty("DiTrack2MassLower", m_diTrack2MassLower); // only effective when m_vtx2Daug_num=4
90  declareProperty("DiTrack2MassUpper", m_diTrack2MassUpper); // only effective when m_vtx2Daug_num=4
91  declareProperty("Psi2MassLowerCut", m_psi2MassLower);
92  declareProperty("Psi2MassUpperCut", m_psi2MassUpper);
93  declareProperty("MassLowerCut", m_MassLower);
94  declareProperty("MassUpperCut", m_MassUpper);
95  declareProperty("HypothesisName", m_hypoName = "TQ");
96  declareProperty("NumberOfPsi1Daughters", m_vtx1Daug_num);
97  declareProperty("Vtx1Daug1MassHypo", m_vtx1Daug1MassHypo);
98  declareProperty("Vtx1Daug2MassHypo", m_vtx1Daug2MassHypo);
99  declareProperty("Vtx1Daug3MassHypo", m_vtx1Daug3MassHypo);
100  declareProperty("Vtx1Daug4MassHypo", m_vtx1Daug4MassHypo);
101  declareProperty("NumberOfPsi2Daughters", m_vtx2Daug_num);
102  declareProperty("Vtx2Daug1MassHypo", m_vtx2Daug1MassHypo);
103  declareProperty("Vtx2Daug2MassHypo", m_vtx2Daug2MassHypo);
104  declareProperty("Vtx2Daug3MassHypo", m_vtx2Daug3MassHypo);
105  declareProperty("Vtx2Daug4MassHypo", m_vtx2Daug4MassHypo);
106  declareProperty("MaxCandidates", m_maxCandidates);
107  declareProperty("Jpsi1Mass", m_mass_jpsi1);
108  declareProperty("DiTrack1Mass", m_mass_diTrk1);
109  declareProperty("Psi1Mass", m_mass_psi1);
110  declareProperty("Jpsi2Mass", m_mass_jpsi2);
111  declareProperty("DiTrack2Mass", m_mass_diTrk2);
112  declareProperty("Psi2Mass", m_mass_psi2);
113  declareProperty("ApplyJpsi1MassConstraint", m_constrJpsi1);
114  declareProperty("ApplyDiTrk1MassConstraint", m_constrDiTrk1); // only effective when m_vtx1Daug_num=4
115  declareProperty("ApplyPsi1MassConstraint", m_constrPsi1);
116  declareProperty("ApplyJpsi2MassConstraint", m_constrJpsi2);
117  declareProperty("ApplyDiTrk2MassConstraint", m_constrDiTrk2); // only effective when m_vtx2Daug_num=4
118  declareProperty("ApplyPsi2MassConstraint", m_constrPsi2);
119  declareProperty("Chi2Cut", m_chi2cut);
120  declareProperty("RefitPV", m_refitPV = true);
121  declareProperty("MaxnPV", m_PV_max = 1000);
122  declareProperty("MinNTracksInPV", m_PV_minNTracks = 0);
123  declareProperty("DoVertexType", m_DoVertexType = 7);
124  declareProperty("TrkVertexFitterTool", m_iVertexFitter);
125  declareProperty("PVRefitter", m_pvRefitter);
126  declareProperty("V0Tools", m_V0Tools);
127  declareProperty("OutputVertexCollections", m_outputsKeys);
128  }

◆ ~PsiPlusPsiSingleVertex()

virtual DerivationFramework::PsiPlusPsiSingleVertex::~PsiPlusPsiSingleVertex ( )
virtualdefault

Member Function Documentation

◆ addBranches()

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

Pass the thinning service

Implements DerivationFramework::IAugmentationTool.

Definition at line 170 of file PsiPlusPsiSingleVertex.cxx.

170  {
171  if (m_vtx1Daug_num < 2 || m_vtx1Daug_num > 4 || m_vtx2Daug_num < 2 || m_vtx2Daug_num > 4) {
172  ATH_MSG_FATAL("Incorrect number of Psi daughters");
173  return StatusCode::FAILURE;
174  }
175 
176  constexpr int topoN = 3;
177  if(m_outputsKeys.size() != topoN) {
178  ATH_MSG_FATAL("Incorrect number of VtxContainers");
179  return StatusCode::FAILURE;
180  }
181  std::array<SG::WriteHandle<xAOD::VertexContainer>, topoN> VtxWriteHandles; int ikey(0);
183  VtxWriteHandles[ikey] = SG::WriteHandle<xAOD::VertexContainer>(key);
184  ATH_CHECK( VtxWriteHandles[ikey].record(std::make_unique<xAOD::VertexContainer>(), std::make_unique<xAOD::VertexAuxContainer>()) );
185  ikey++;
186  }
187 
188  //----------------------------------------------------
189  // retrieve primary vertices
190  //----------------------------------------------------
192  ATH_CHECK( pvContainer.isValid() );
193  if (pvContainer.cptr()->size()==0) {
194  ATH_MSG_WARNING("You have no primary vertices: " << pvContainer.cptr()->size());
195  return StatusCode::RECOVERABLE;
196  }
197 
198  // Get TrackParticle container (for setting links to the original tracks)
200  ATH_CHECK( trackContainer.isValid() );
201 
202  std::vector<const xAOD::TrackParticle*> tracksJpsi1;
203  std::vector<const xAOD::TrackParticle*> tracksDiTrk1;
204  std::vector<const xAOD::TrackParticle*> tracksPsi1;
205  std::vector<const xAOD::TrackParticle*> tracksJpsi2;
206  std::vector<const xAOD::TrackParticle*> tracksDiTrk2;
207  std::vector<const xAOD::TrackParticle*> tracksPsi2;
208  std::vector<const xAOD::TrackParticle*> inputTracks;
209  std::vector<double> massesPsi1;
210  massesPsi1.push_back(m_vtx1Daug1MassHypo);
211  massesPsi1.push_back(m_vtx1Daug2MassHypo);
212  if(m_vtx1Daug_num>=3) massesPsi1.push_back(m_vtx1Daug3MassHypo);
213  if(m_vtx1Daug_num==4) massesPsi1.push_back(m_vtx1Daug4MassHypo);
214  std::vector<double> massesPsi2;
215  massesPsi2.push_back(m_vtx2Daug1MassHypo);
216  massesPsi2.push_back(m_vtx2Daug2MassHypo);
217  if(m_vtx2Daug_num>=3) massesPsi2.push_back(m_vtx2Daug3MassHypo);
218  if(m_vtx2Daug_num==4) massesPsi2.push_back(m_vtx2Daug4MassHypo);
219  std::vector<double> massesInputTracks;
220  massesInputTracks.reserve(massesPsi1.size() + massesPsi2.size());
221  for(auto mass : massesPsi1) massesInputTracks.push_back(mass);
222  for(auto mass : massesPsi2) massesInputTracks.push_back(mass);
223 
224  // Get Psi1 container
226  ATH_CHECK( psi1Container.isValid() );
228  ATH_CHECK( psi2Container.isValid() );
229 
230  // Select the psi1 candidates before calling fit
231  std::vector<const xAOD::Vertex*> selectedPsi1Candidates;
232  for(auto vxcItr=psi1Container->cbegin(); vxcItr!=psi1Container->cend(); ++vxcItr) {
233  // Check the passed flag first
234  const xAOD::Vertex* vtx = *vxcItr;
235  bool passed = false;
236  for(size_t i=0; i<m_vertexPsi1HypoNames.size(); i++) {
238  if(flagAcc.isAvailable(*vtx) && flagAcc(*vtx)) {
239  passed = true;
240  }
241  }
242  if(m_vertexPsi1HypoNames.size() && !passed) continue;
243 
244  // Check psi1 candidate invariant mass and skip if need be
245  if(m_vtx1Daug_num>2) {
246  double mass_psi1 = m_V0Tools->invariantMass(*vxcItr, massesPsi1);
247  if (mass_psi1 < m_psi1MassLower || mass_psi1 > m_psi1MassUpper) continue;
248  }
249 
250  TLorentzVector p4_mu1, p4_mu2;
251  p4_mu1.SetPtEtaPhiM( (*vxcItr)->trackParticle(0)->pt(),
252  (*vxcItr)->trackParticle(0)->eta(),
253  (*vxcItr)->trackParticle(0)->phi(), m_vtx1Daug1MassHypo);
254  p4_mu2.SetPtEtaPhiM( (*vxcItr)->trackParticle(1)->pt(),
255  (*vxcItr)->trackParticle(1)->eta(),
256  (*vxcItr)->trackParticle(1)->phi(), m_vtx1Daug2MassHypo);
257  double mass_jpsi1 = (p4_mu1 + p4_mu2).M();
258  if (mass_jpsi1 < m_jpsi1MassLower || mass_jpsi1 > m_jpsi1MassUpper) continue;
259 
261  TLorentzVector p4_trk1, p4_trk2;
262  p4_trk1.SetPtEtaPhiM( (*vxcItr)->trackParticle(2)->pt(),
263  (*vxcItr)->trackParticle(2)->eta(),
264  (*vxcItr)->trackParticle(2)->phi(), m_vtx1Daug3MassHypo);
265  p4_trk2.SetPtEtaPhiM( (*vxcItr)->trackParticle(3)->pt(),
266  (*vxcItr)->trackParticle(3)->eta(),
267  (*vxcItr)->trackParticle(3)->phi(), m_vtx1Daug4MassHypo);
268  double mass_diTrk1 = (p4_trk1 + p4_trk2).M();
269  if (mass_diTrk1 < m_diTrack1MassLower || mass_diTrk1 > m_diTrack1MassUpper) continue;
270  }
271 
272  selectedPsi1Candidates.push_back(*vxcItr);
273  }
274 
275  // Select the psi2 candidates before calling fit
276  std::vector<const xAOD::Vertex*> selectedPsi2Candidates;
277  for(auto vxcItr=psi2Container->cbegin(); vxcItr!=psi2Container->cend(); ++vxcItr) {
278  // Check the passed flag first
279  const xAOD::Vertex* vtx = *vxcItr;
280  bool passed = false;
281  for(size_t i=0; i<m_vertexPsi2HypoNames.size(); i++) {
283  if(flagAcc.isAvailable(*vtx) && flagAcc(*vtx)) {
284  passed = true;
285  }
286  }
287  if(m_vertexPsi2HypoNames.size() && !passed) continue;
288 
289  // Check psi2 candidate invariant mass and skip if need be
290  if(m_vtx2Daug_num>2) {
291  double mass_psi2 = m_V0Tools->invariantMass(*vxcItr,massesPsi2);
292  if(mass_psi2 < m_psi2MassLower || mass_psi2 > m_psi2MassUpper) continue;
293  }
294 
295  TLorentzVector p4_mu1, p4_mu2;
296  p4_mu1.SetPtEtaPhiM( (*vxcItr)->trackParticle(0)->pt(),
297  (*vxcItr)->trackParticle(0)->eta(),
298  (*vxcItr)->trackParticle(0)->phi(), m_vtx2Daug1MassHypo);
299  p4_mu2.SetPtEtaPhiM( (*vxcItr)->trackParticle(1)->pt(),
300  (*vxcItr)->trackParticle(1)->eta(),
301  (*vxcItr)->trackParticle(1)->phi(), m_vtx2Daug2MassHypo);
302  double mass_jpsi2 = (p4_mu1 + p4_mu2).M();
303  if (mass_jpsi2 < m_jpsi2MassLower || mass_jpsi2 > m_jpsi2MassUpper) continue;
304 
306  TLorentzVector p4_trk1, p4_trk2;
307  p4_trk1.SetPtEtaPhiM( (*vxcItr)->trackParticle(2)->pt(),
308  (*vxcItr)->trackParticle(2)->eta(),
309  (*vxcItr)->trackParticle(2)->phi(), m_vtx2Daug3MassHypo);
310  p4_trk2.SetPtEtaPhiM( (*vxcItr)->trackParticle(3)->pt(),
311  (*vxcItr)->trackParticle(3)->eta(),
312  (*vxcItr)->trackParticle(3)->phi(), m_vtx2Daug4MassHypo);
313  double mass_diTrk2 = (p4_trk1 + p4_trk2).M();
314  if (mass_diTrk2 < m_diTrack2MassLower || mass_diTrk2 > m_diTrack2MassUpper) continue;
315  }
316  selectedPsi2Candidates.push_back(*vxcItr);
317  }
318 
319  std::vector<std::pair<const xAOD::Vertex*, const xAOD::Vertex*> > candidatePairs;
320  for(auto psi1Itr=selectedPsi1Candidates.cbegin(); psi1Itr!=selectedPsi1Candidates.cend(); ++psi1Itr) {
321  tracksPsi1.clear();
322  tracksPsi1.reserve((*psi1Itr)->nTrackParticles());
323  for(size_t i=0; i<(*psi1Itr)->nTrackParticles(); i++) tracksPsi1.push_back((*psi1Itr)->trackParticle(i));
324  for(auto psi2Itr=selectedPsi2Candidates.cbegin(); psi2Itr!=selectedPsi2Candidates.cend(); ++psi2Itr) {
325  bool skip = false;
326  for(size_t j=0; j<(*psi2Itr)->nTrackParticles(); j++) {
327  if(std::find(tracksPsi1.cbegin(), tracksPsi1.cend(), (*psi2Itr)->trackParticle(j)) != tracksPsi1.cend()) { skip = true; break; }
328  }
329  if(skip) continue;
331  for(size_t ic=0; ic<candidatePairs.size(); ic++) {
332  const xAOD::Vertex* psi1Vertex = candidatePairs[ic].first;
333  const xAOD::Vertex* psi2Vertex = candidatePairs[ic].second;
334  if((psi1Vertex == *psi1Itr && psi2Vertex == *psi2Itr) || (psi1Vertex == *psi2Itr && psi2Vertex == *psi1Itr)) { skip = true; break; }
335  }
336  }
337  if(skip) continue;
338  candidatePairs.push_back(std::pair<const xAOD::Vertex*, const xAOD::Vertex*>(*psi1Itr,*psi2Itr));
339  }
340  }
341 
342  std::sort( candidatePairs.begin(), candidatePairs.end(), [](std::pair<const xAOD::Vertex*, const xAOD::Vertex*> a, std::pair<const xAOD::Vertex*, const xAOD::Vertex*> b) { return a.first->chiSquared()/a.first->numberDoF()+a.second->chiSquared()/a.second->numberDoF() < b.first->chiSquared()/b.first->numberDoF()+b.second->chiSquared()/b.second->numberDoF(); } );
343  if(m_maxCandidates>0 && candidatePairs.size()>m_maxCandidates) {
344  candidatePairs.erase(candidatePairs.begin()+m_maxCandidates, candidatePairs.end());
345  }
346 
347  for(size_t ic=0; ic<candidatePairs.size(); ic++) {
348  const xAOD::Vertex* psi1Vertex = candidatePairs[ic].first;
349  const xAOD::Vertex* psi2Vertex = candidatePairs[ic].second;
350 
351  tracksPsi1.clear();
352  tracksPsi1.reserve(psi1Vertex->nTrackParticles());
353  for(size_t it=0; it<psi1Vertex->nTrackParticles(); it++) tracksPsi1.push_back(psi1Vertex->trackParticle(it));
354  if (tracksPsi1.size() != massesPsi1.size()) {
355  ATH_MSG_ERROR("Problems with Psi1 input: number of tracks or track mass inputs is not correct!");
356  }
357  tracksPsi2.clear();
358  tracksPsi2.reserve(psi2Vertex->nTrackParticles());
359  for(size_t it=0; it<psi2Vertex->nTrackParticles(); it++) tracksPsi2.push_back(psi2Vertex->trackParticle(it));
360  if (tracksPsi2.size() != massesPsi2.size()) {
361  ATH_MSG_ERROR("Problems with Psi2 input: number of tracks or track mass inputs is not correct!");
362  }
363 
364  tracksJpsi1.clear();
365  tracksJpsi1.push_back(psi1Vertex->trackParticle(0));
366  tracksJpsi1.push_back(psi1Vertex->trackParticle(1));
367  tracksDiTrk1.clear();
368  if(m_vtx1Daug_num==4) {
369  tracksDiTrk1.push_back(psi1Vertex->trackParticle(2));
370  tracksDiTrk1.push_back(psi1Vertex->trackParticle(3));
371  }
372  tracksJpsi2.clear();
373  tracksJpsi2.push_back(psi2Vertex->trackParticle(0));
374  tracksJpsi2.push_back(psi2Vertex->trackParticle(1));
375  tracksDiTrk2.clear();
376  if(m_vtx2Daug_num==4) {
377  tracksDiTrk2.push_back(psi2Vertex->trackParticle(2));
378  tracksDiTrk2.push_back(psi2Vertex->trackParticle(3));
379  }
380 
381  TLorentzVector p4_moth;
382  TLorentzVector tmp;
383  for(size_t it=0; it<psi1Vertex->nTrackParticles(); it++) {
384  tmp.SetPtEtaPhiM(psi1Vertex->trackParticle(it)->pt(),psi1Vertex->trackParticle(it)->eta(),psi1Vertex->trackParticle(it)->phi(),massesPsi1[it]);
385  p4_moth += tmp;
386  }
387  for(size_t it=0; it<psi2Vertex->nTrackParticles(); it++) {
388  tmp.SetPtEtaPhiM(psi2Vertex->trackParticle(it)->pt(),psi2Vertex->trackParticle(it)->eta(),psi2Vertex->trackParticle(it)->phi(),massesPsi2[it]);
389  p4_moth += tmp;
390  }
391  if (p4_moth.M() < m_MassLower || p4_moth.M() > m_MassUpper) continue;
392 
393  inputTracks.clear();
394  inputTracks.push_back(psi1Vertex->trackParticle(0));
395  inputTracks.push_back(psi1Vertex->trackParticle(1));
396  if(m_vtx1Daug_num>=3) inputTracks.push_back(psi1Vertex->trackParticle(2));
397  if(m_vtx1Daug_num==4) inputTracks.push_back(psi1Vertex->trackParticle(3));
398  inputTracks.push_back(psi2Vertex->trackParticle(0));
399  inputTracks.push_back(psi2Vertex->trackParticle(1));
400  if(m_vtx2Daug_num>=3) inputTracks.push_back(psi2Vertex->trackParticle(2));
401  if(m_vtx2Daug_num==4) inputTracks.push_back(psi2Vertex->trackParticle(3));
402 
403  // start the fit
404  std::unique_ptr<Trk::IVKalState> state = m_iVertexFitter->makeState();
405  m_iVertexFitter->setMassInputParticles(massesInputTracks, *state);
406  if (m_constrJpsi1) {
407  m_iVertexFitter->setMassForConstraint(m_mass_jpsi1, std::array<int,2>{1,2}, *state);
408  }
409  if (m_constrPsi1 && m_vtx1Daug_num>=3) {
410  m_iVertexFitter->setMassForConstraint(m_mass_psi1, m_vtx1Daug_num==4 ? std::vector<int>{1,2,3,4} : std::vector<int>{1,2,3}, *state);
411  }
412  if (m_constrDiTrk1 && m_vtx1Daug_num==4) {
413  m_iVertexFitter->setMassForConstraint(m_mass_diTrk1, std::array<int,2>{3,4}, *state);
414  }
415  if (m_constrJpsi2) {
416  m_iVertexFitter->setMassForConstraint(m_mass_jpsi2, std::array<int,2>{m_vtx1Daug_num+1,m_vtx1Daug_num+2}, *state);
417  }
418  if (m_constrPsi2 && m_vtx2Daug_num>=3) {
419  m_iVertexFitter->setMassForConstraint(m_mass_psi2, m_vtx1Daug_num==4 ? std::vector<int>{m_vtx1Daug_num+1,m_vtx1Daug_num+2,m_vtx1Daug_num+3,m_vtx1Daug_num+4} : std::vector<int>{m_vtx1Daug_num+1,m_vtx1Daug_num+2,m_vtx1Daug_num+3}, *state);
420  }
421  if (m_constrDiTrk2 && m_vtx2Daug_num==4) {
422  m_iVertexFitter->setMassForConstraint(m_mass_diTrk2, std::array<int,2>{m_vtx1Daug_num+3,m_vtx1Daug_num+4}, *state);
423  }
424 
425  // Starting point
426  Amg::Vector3D startingPoint((psi1Vertex->x()+psi2Vertex->x())/2,(psi1Vertex->y()+psi2Vertex->y())/2,(psi1Vertex->z()+psi2Vertex->z())/2);
427 
428  // do the fit
429  std::unique_ptr<xAOD::Vertex> theResult( m_iVertexFitter->fit(inputTracks, startingPoint, *state) );
430 
431  if(theResult != nullptr){
432  // Chi2/DOF cut
433  double chi2DOF = theResult->chiSquared()/theResult->numberDoF();
434  bool chi2CutPassed = (m_chi2cut <= 0.0 || chi2DOF < m_chi2cut);
435  if(chi2CutPassed) {
436  TrackParticleLinkVector tpLinkVector;
437  for(size_t i=0; i<theResult->trackParticleLinks().size(); i++) {
438  TrackParticleLink mylink = theResult->trackParticleLinks()[i];
439  mylink.setStorableObject(*trackContainer.ptr(), true);
440  tpLinkVector.push_back( mylink );
441  }
442  theResult->clearTracks();
443  theResult->setTrackParticleLinks( tpLinkVector );
444 
445  xAOD::Vertex* psi1Vertex_ = new xAOD::Vertex(*psi1Vertex);
446  xAOD::BPhysHelper psi1_helper(psi1Vertex_);
447  psi1_helper.setRefTrks();
448  TrackParticleLinkVector tpLinkVector_psi1;
449  for(size_t i=0; i<psi1Vertex_->trackParticleLinks().size(); i++) {
450  TrackParticleLink mylink = psi1Vertex_->trackParticleLinks()[i];
451  mylink.setStorableObject(*trackContainer.ptr(), true);
452  tpLinkVector_psi1.push_back( mylink );
453  }
454  psi1Vertex_->clearTracks();
455  psi1Vertex_->setTrackParticleLinks( tpLinkVector_psi1 );
456 
457  xAOD::Vertex* psi2Vertex_ = new xAOD::Vertex(*psi2Vertex);
458  xAOD::BPhysHelper psi2_helper(psi2Vertex_);
459  psi2_helper.setRefTrks();
460  TrackParticleLinkVector tpLinkVector_psi2;
461  for(size_t i=0; i<psi2Vertex_->trackParticleLinks().size(); i++) {
462  TrackParticleLink mylink = psi2Vertex_->trackParticleLinks()[i];
463  mylink.setStorableObject(*trackContainer.ptr(), true);
464  tpLinkVector_psi2.push_back( mylink );
465  }
466  psi2Vertex_->clearTracks();
467  psi2Vertex_->setTrackParticleLinks( tpLinkVector_psi2 );
468 
469  VtxWriteHandles[0].ptr()->push_back(psi1Vertex_);
470  VtxWriteHandles[1].ptr()->push_back(psi2Vertex_);
471 
472  // Set links to preceding vertices
473  VertexLinkVector precedingVertexLinks;
474  VertexLink vertexLink1;
475  vertexLink1.setElement(psi1Vertex_);
476  vertexLink1.setStorableObject(*VtxWriteHandles[0].ptr());
477  if( vertexLink1.isValid() ) precedingVertexLinks.push_back( vertexLink1 );
478  VertexLink vertexLink2;
479  vertexLink2.setElement(psi2Vertex_);
480  vertexLink2.setStorableObject(*VtxWriteHandles[1].ptr());
481  if( vertexLink2.isValid() ) precedingVertexLinks.push_back( vertexLink2 );
482 
483  SG::AuxElement::Decorator<VertexLinkVector> PrecedingLinksDecor("PrecedingVertexLinks");
484  PrecedingLinksDecor(*theResult.get()) = precedingVertexLinks;
485 
486  xAOD::BPhysHypoHelper vtx(m_hypoName, theResult.get());
487  vtx.setRefTrks();
488  vtx.setPass(true);
489 
490  VtxWriteHandles[2].ptr()->push_back(theResult.release()); //ptr is released preventing deletion
491  }
492  }
493  } //Iterate over candidatePairs vertices
494 
496  ATH_CHECK( evt.isValid() );
497  BPhysPVTools helper(&(*m_V0Tools), evt.cptr());
498  helper.SetMinNTracksInPV(m_PV_minNTracks);
499 
500  if(m_refitPV) {
502  ATH_CHECK( refPvContainer.record(std::make_unique<xAOD::VertexContainer>(), std::make_unique<xAOD::VertexAuxContainer>()) );
503 
504  if(VtxWriteHandles[2]->size()>0) {
505  for(int i=0; i<topoN; i++) {
506  StatusCode SC = helper.FillCandwithRefittedVertices(VtxWriteHandles[i].ptr(), pvContainer.cptr(), refPvContainer.ptr(), &(*m_pvRefitter), m_PV_max, m_DoVertexType);
507  if(SC.isFailure()){
508  ATH_MSG_FATAL("FillCandwithRefittedVertices failed - check the vertices you passed");
509  return SC;
510  }
511  }
512  }
513  }
514  else {
515  if(VtxWriteHandles[2]->size()>0) {
516  for(int i=0; i<topoN; i++) {
517  StatusCode SC = helper.FillCandExistingVertices(VtxWriteHandles[i].ptr(), pvContainer.cptr(), m_DoVertexType);
518  if(SC.isFailure()){
519  ATH_MSG_FATAL("FillCandExistingVertices failed - check the vertices you passed");
520  return SC;
521  }
522  }
523  }
524  }
525 
526  return StatusCode::SUCCESS;
527  }

◆ declareGaudiProperty() [1/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyArrayType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKeyArray>

Definition at line 170 of file AthCommonDataStore.h.

172  {
173  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
174  hndl.value(),
175  hndl.documentation());
176 
177  }

◆ declareGaudiProperty() [2/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleKeyType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158  {
159  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
160  hndl.value(),
161  hndl.documentation());
162 
163  }

◆ declareGaudiProperty() [3/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  hndl,
const SG::VarHandleType  
)
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleBase>

Definition at line 184 of file AthCommonDataStore.h.

186  {
187  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
188  hndl.value(),
189  hndl.documentation());
190  }

◆ declareGaudiProperty() [4/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareGaudiProperty ( Gaudi::Property< T > &  t,
const SG::NotHandleType  
)
inlineprivateinherited

specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>

Definition at line 199 of file AthCommonDataStore.h.

200  {
201  return PBASE::declareProperty(t);
202  }

◆ declareProperty() [1/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleBase hndl,
const std::string &  doc,
const SG::VarHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 245 of file AthCommonDataStore.h.

249  {
250  this->declare(hndl.vhKey());
251  hndl.vhKey().setOwner(this);
252 
253  return PBASE::declareProperty(name,hndl,doc);
254  }

◆ declareProperty() [2/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKey hndl,
const std::string &  doc,
const SG::VarHandleKeyType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 221 of file AthCommonDataStore.h.

225  {
226  this->declare(hndl);
227  hndl.setOwner(this);
228 
229  return PBASE::declareProperty(name,hndl,doc);
230  }

◆ declareProperty() [3/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
SG::VarHandleKeyArray hndArr,
const std::string &  doc,
const SG::VarHandleKeyArrayType  
)
inlineinherited

Definition at line 259 of file AthCommonDataStore.h.

263  {
264 
265  // std::ostringstream ost;
266  // ost << Algorithm::name() << " VHKA declareProp: " << name
267  // << " size: " << hndArr.keys().size()
268  // << " mode: " << hndArr.mode()
269  // << " vhka size: " << m_vhka.size()
270  // << "\n";
271  // debug() << ost.str() << endmsg;
272 
273  hndArr.setOwner(this);
274  m_vhka.push_back(&hndArr);
275 
276  Gaudi::Details::PropertyBase* p = PBASE::declareProperty(name, hndArr, doc);
277  if (p != 0) {
278  p->declareUpdateHandler(&AthCommonDataStore<PBASE>::updateVHKA, this);
279  } else {
280  ATH_MSG_ERROR("unable to call declareProperty on VarHandleKeyArray "
281  << name);
282  }
283 
284  return p;
285 
286  }

◆ declareProperty() [4/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc,
const SG::NotHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty.

Definition at line 333 of file AthCommonDataStore.h.

337  {
338  return PBASE::declareProperty(name, property, doc);
339  }

◆ declareProperty() [5/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc = "none" 
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray.

Definition at line 352 of file AthCommonDataStore.h.

355  {
356  typedef typename SG::HandleClassifier<T>::type htype;
357  return declareProperty (name, property, doc, htype());
358  }

◆ declareProperty() [6/6]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty ( Gaudi::Property< T > &  t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145  {
146  typedef typename SG::HandleClassifier<T>::type htype;
148  }

◆ detStore()

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

95 { return m_detStore; }

◆ evtStore() [1/2]

ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

85 { return m_evtStore; }

◆ evtStore() [2/2]

const ServiceHandle<StoreGateSvc>& AthCommonDataStore< AthCommonMsg< AlgTool > >::evtStore ( ) const
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 90 of file AthCommonDataStore.h.

90 { return m_evtStore; }

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase &  ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ initialize()

StatusCode DerivationFramework::PsiPlusPsiSingleVertex::initialize ( )
overridevirtual

Definition at line 130 of file PsiPlusPsiSingleVertex.cxx.

130  {
131  // retrieving vertex Fitter
132  ATH_CHECK( m_iVertexFitter.retrieve() );
133 
134  // retrieve PV refitter
135  ATH_CHECK( m_pvRefitter.retrieve() );
136 
137  // retrieving the V0 tools
138  ATH_CHECK( m_V0Tools.retrieve() );
139 
140  ATH_CHECK( m_vertexPsi1ContainerKey.initialize() );
141  ATH_CHECK( m_vertexPsi2ContainerKey.initialize() );
142  ATH_CHECK( m_VxPrimaryCandidateName.initialize() );
144  ATH_CHECK( m_refPVContainerName.initialize() );
145  ATH_CHECK( m_outputsKeys.initialize() );
147 
148  ATH_CHECK( m_partPropSvc.retrieve() );
149  auto pdt = m_partPropSvc->PDT();
150 
151  // retrieve particle masses
152  // https://gitlab.cern.ch/atlas/athena/-/blob/main/Generators/TruthUtils/TruthUtils/AtlasPID.h
157 
166 
167  return StatusCode::SUCCESS;
168  }

◆ inputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ interfaceID()

static const InterfaceID& DerivationFramework::PsiPlusPsiSingleVertex::interfaceID ( )
inlinestatic

Definition at line 29 of file PsiPlusPsiSingleVertex.h.

29 { return IID_PsiPlusPsiSingleVertex;}

◆ msg() [1/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24  {
25  return this->msgStream();
26  }

◆ msg() [2/2]

MsgStream& AthCommonMsg< AlgTool >::msg ( const MSG::Level  lvl) const
inlineinherited

Definition at line 27 of file AthCommonMsg.h.

27  {
28  return this->msgStream(lvl);
29  }

◆ msgLvl()

bool AthCommonMsg< AlgTool >::msgLvl ( const MSG::Level  lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30  {
31  return this->msgLevel(lvl);
32  }

◆ outputHandles()

virtual std::vector<Gaudi::DataHandle*> AthCommonDataStore< AthCommonMsg< AlgTool > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ renounce()

std::enable_if_t<std::is_void_v<std::result_of_t<decltype(&T::renounce)(T)> > && !std::is_base_of_v<SG::VarHandleKeyArray, T> && std::is_base_of_v<Gaudi::DataHandle, T>, void> AthCommonDataStore< AthCommonMsg< AlgTool > >::renounce ( T &  h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381  {
382  h.renounce();
383  PBASE::renounce (h);
384  }

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::renounceArray ( SG::VarHandleKeyArray handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364  {
365  handlesArray.renounce();
366  }

◆ sysInitialize()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysInitialize ( )
overridevirtualinherited

Perform system initialization for an algorithm.

We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.

Reimplemented in DerivationFramework::CfAthAlgTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and asg::AsgMetadataTool.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< AlgTool > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< AlgTool > >::updateVHKA ( Gaudi::Details::PropertyBase &  )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308  {
309  // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310  // << " size: " << m_vhka.size() << endmsg;
311  for (auto &a : m_vhka) {
312  std::vector<SG::VarHandleKey*> keys = a->keys();
313  for (auto k : keys) {
314  k->setOwner(this);
315  }
316  }
317  }

Member Data Documentation

◆ m_chi2cut

double DerivationFramework::PsiPlusPsiSingleVertex::m_chi2cut
private

Definition at line 83 of file PsiPlusPsiSingleVertex.h.

◆ m_constrDiTrk1

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrDiTrk1
private

Definition at line 78 of file PsiPlusPsiSingleVertex.h.

◆ m_constrDiTrk2

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrDiTrk2
private

Definition at line 81 of file PsiPlusPsiSingleVertex.h.

◆ m_constrJpsi1

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrJpsi1
private

Definition at line 77 of file PsiPlusPsiSingleVertex.h.

◆ m_constrJpsi2

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrJpsi2
private

Definition at line 80 of file PsiPlusPsiSingleVertex.h.

◆ m_constrPsi1

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrPsi1
private

Definition at line 79 of file PsiPlusPsiSingleVertex.h.

◆ m_constrPsi2

bool DerivationFramework::PsiPlusPsiSingleVertex::m_constrPsi2
private

Definition at line 82 of file PsiPlusPsiSingleVertex.h.

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default)

Definition at line 393 of file AthCommonDataStore.h.

◆ m_diTrack1MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack1MassLower
private

Definition at line 47 of file PsiPlusPsiSingleVertex.h.

◆ m_diTrack1MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack1MassUpper
private

Definition at line 48 of file PsiPlusPsiSingleVertex.h.

◆ m_diTrack2MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack2MassLower
private

Definition at line 53 of file PsiPlusPsiSingleVertex.h.

◆ m_diTrack2MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack2MassUpper
private

Definition at line 54 of file PsiPlusPsiSingleVertex.h.

◆ m_DoVertexType

int DerivationFramework::PsiPlusPsiSingleVertex::m_DoVertexType
private

Definition at line 94 of file PsiPlusPsiSingleVertex.h.

◆ m_eventInfo_key

SG::ReadHandleKey<xAOD::EventInfo> DerivationFramework::PsiPlusPsiSingleVertex::m_eventInfo_key
private

Definition at line 43 of file PsiPlusPsiSingleVertex.h.

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default)

Definition at line 390 of file AthCommonDataStore.h.

◆ m_hypoName

std::string DerivationFramework::PsiPlusPsiSingleVertex::m_hypoName
private

Definition at line 92 of file PsiPlusPsiSingleVertex.h.

◆ m_iVertexFitter

ToolHandle< Trk::TrkVKalVrtFitter > DerivationFramework::PsiPlusPsiSingleVertex::m_iVertexFitter
private

Definition at line 85 of file PsiPlusPsiSingleVertex.h.

◆ m_jpsi1MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi1MassLower
private

Definition at line 45 of file PsiPlusPsiSingleVertex.h.

◆ m_jpsi1MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi1MassUpper
private

Definition at line 46 of file PsiPlusPsiSingleVertex.h.

◆ m_jpsi2MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi2MassLower
private

Definition at line 51 of file PsiPlusPsiSingleVertex.h.

◆ m_jpsi2MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi2MassUpper
private

Definition at line 52 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_diTrk1

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_diTrk1
private

Definition at line 72 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_diTrk2

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_diTrk2
private

Definition at line 75 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_jpsi1

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_jpsi1
private

Definition at line 71 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_jpsi2

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_jpsi2
private

Definition at line 74 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_psi1

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_psi1
private

Definition at line 73 of file PsiPlusPsiSingleVertex.h.

◆ m_mass_psi2

double DerivationFramework::PsiPlusPsiSingleVertex::m_mass_psi2
private

Definition at line 76 of file PsiPlusPsiSingleVertex.h.

◆ m_MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_MassLower
private

Definition at line 57 of file PsiPlusPsiSingleVertex.h.

◆ m_MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_MassUpper
private

Definition at line 58 of file PsiPlusPsiSingleVertex.h.

◆ m_maxCandidates

unsigned int DerivationFramework::PsiPlusPsiSingleVertex::m_maxCandidates
private

Definition at line 69 of file PsiPlusPsiSingleVertex.h.

◆ m_outputsKeys

SG::WriteHandleKeyArray<xAOD::VertexContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_outputsKeys
private

Definition at line 40 of file PsiPlusPsiSingleVertex.h.

◆ m_partPropSvc

ServiceHandle<IPartPropSvc> DerivationFramework::PsiPlusPsiSingleVertex::m_partPropSvc {this, "PartPropSvc", "PartPropSvc"}
private

Definition at line 88 of file PsiPlusPsiSingleVertex.h.

◆ m_psi1MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_psi1MassLower
private

Definition at line 49 of file PsiPlusPsiSingleVertex.h.

◆ m_psi1MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_psi1MassUpper
private

Definition at line 50 of file PsiPlusPsiSingleVertex.h.

◆ m_psi2MassLower

double DerivationFramework::PsiPlusPsiSingleVertex::m_psi2MassLower
private

Definition at line 55 of file PsiPlusPsiSingleVertex.h.

◆ m_psi2MassUpper

double DerivationFramework::PsiPlusPsiSingleVertex::m_psi2MassUpper
private

Definition at line 56 of file PsiPlusPsiSingleVertex.h.

◆ m_PV_max

int DerivationFramework::PsiPlusPsiSingleVertex::m_PV_max
private

Definition at line 93 of file PsiPlusPsiSingleVertex.h.

◆ m_PV_minNTracks

size_t DerivationFramework::PsiPlusPsiSingleVertex::m_PV_minNTracks
private

Definition at line 95 of file PsiPlusPsiSingleVertex.h.

◆ m_pvRefitter

ToolHandle< Analysis::PrimaryVertexRefitter > DerivationFramework::PsiPlusPsiSingleVertex::m_pvRefitter
private

Definition at line 86 of file PsiPlusPsiSingleVertex.h.

◆ m_refitPV

bool DerivationFramework::PsiPlusPsiSingleVertex::m_refitPV
private

Definition at line 90 of file PsiPlusPsiSingleVertex.h.

◆ m_refPVContainerName

SG::WriteHandleKey<xAOD::VertexContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_refPVContainerName
private

Definition at line 91 of file PsiPlusPsiSingleVertex.h.

◆ m_trackContainerName

SG::ReadHandleKey<xAOD::TrackParticleContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_trackContainerName
private

Definition at line 42 of file PsiPlusPsiSingleVertex.h.

◆ m_V0Tools

ToolHandle< Trk::V0Tools > DerivationFramework::PsiPlusPsiSingleVertex::m_V0Tools
private

Definition at line 87 of file PsiPlusPsiSingleVertex.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< AlgTool > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vertexPsi1ContainerKey

SG::ReadHandleKey<xAOD::VertexContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi1ContainerKey
private

Definition at line 36 of file PsiPlusPsiSingleVertex.h.

◆ m_vertexPsi1HypoNames

std::vector<std::string> DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi1HypoNames
private

Definition at line 38 of file PsiPlusPsiSingleVertex.h.

◆ m_vertexPsi2ContainerKey

SG::ReadHandleKey<xAOD::VertexContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi2ContainerKey
private

Definition at line 37 of file PsiPlusPsiSingleVertex.h.

◆ m_vertexPsi2HypoNames

std::vector<std::string> DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi2HypoNames
private

Definition at line 39 of file PsiPlusPsiSingleVertex.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.

◆ m_vtx1Daug1MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug1MassHypo
private

Definition at line 60 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx1Daug2MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug2MassHypo
private

Definition at line 61 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx1Daug3MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug3MassHypo
private

Definition at line 62 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx1Daug4MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug4MassHypo
private

Definition at line 63 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx1Daug_num

int DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug_num
private

Definition at line 59 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx2Daug1MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug1MassHypo
private

Definition at line 65 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx2Daug2MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug2MassHypo
private

Definition at line 66 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx2Daug3MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug3MassHypo
private

Definition at line 67 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx2Daug4MassHypo

double DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug4MassHypo
private

Definition at line 68 of file PsiPlusPsiSingleVertex.h.

◆ m_vtx2Daug_num

int DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug_num
private

Definition at line 64 of file PsiPlusPsiSingleVertex.h.

◆ m_VxPrimaryCandidateName

SG::ReadHandleKey<xAOD::VertexContainer> DerivationFramework::PsiPlusPsiSingleVertex::m_VxPrimaryCandidateName
private

Name of primary vertex container.

Definition at line 41 of file PsiPlusPsiSingleVertex.h.


The documentation for this class was generated from the following files:
DerivationFramework::PsiPlusPsiSingleVertex::m_DoVertexType
int m_DoVertexType
Definition: PsiPlusPsiSingleVertex.h:94
xAOD::TrackParticle_v1::pt
virtual double pt() const override final
The transverse momentum ( ) of the particle.
Definition: TrackParticle_v1.cxx:73
xAOD::Vertex_v1::x
float x() const
Returns the x position.
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
DerivationFramework::PsiPlusPsiSingleVertex::m_PV_max
int m_PV_max
Definition: PsiPlusPsiSingleVertex.h:93
xAOD::Vertex_v1::nTrackParticles
size_t nTrackParticles() const
Get the number of tracks associated with this vertex.
Definition: Vertex_v1.cxx:270
xAOD::BPhysHelper
Definition: BPhysHelper.h:71
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug2MassHypo
double m_vtx1Daug2MassHypo
Definition: PsiPlusPsiSingleVertex.h:61
xAOD::Vertex
Vertex_v1 Vertex
Define the latest version of the vertex class.
Definition: Event/xAOD/xAODTracking/xAODTracking/Vertex.h:16
TrigCompositeUtils::passed
bool passed(DecisionID id, const DecisionIDContainer &idSet)
checks if required decision ID is in the set of IDs in the container
Definition: TrigCompositeUtilsRoot.cxx:117
find
std::string find(const std::string &s)
return a remapped string
Definition: hcg.cxx:135
DerivationFramework::PsiPlusPsiSingleVertex::m_maxCandidates
unsigned int m_maxCandidates
Definition: PsiPlusPsiSingleVertex.h:69
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug3MassHypo
double m_vtx2Daug3MassHypo
Definition: PsiPlusPsiSingleVertex.h:67
Base_Fragment.mass
mass
Definition: Sherpa_i/share/common/Base_Fragment.py:59
DerivationFramework::PsiPlusPsiSingleVertex::m_partPropSvc
ServiceHandle< IPartPropSvc > m_partPropSvc
Definition: PsiPlusPsiSingleVertex.h:88
SG::Accessor
Helper class to provide type-safe access to aux data.
Definition: Control/AthContainers/AthContainers/Accessor.h:68
DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi2HypoNames
std::vector< std::string > m_vertexPsi2HypoNames
Definition: PsiPlusPsiSingleVertex.h:39
SG::ReadHandle
Definition: StoreGate/StoreGate/ReadHandle.h:70
DerivationFramework::PsiPlusPsiSingleVertex::m_constrDiTrk2
bool m_constrDiTrk2
Definition: PsiPlusPsiSingleVertex.h:81
AthCommonDataStore< AthCommonMsg< AlgTool > >::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
xAOD::TrackParticle_v1::eta
virtual double eta() const override final
The pseudorapidity ( ) of the particle.
Definition: TrackParticle_v1.cxx:77
DerivationFramework::PsiPlusPsiSingleVertex::m_constrDiTrk1
bool m_constrDiTrk1
Definition: PsiPlusPsiSingleVertex.h:78
DerivationFramework::BPhysPVCascadeTools::getParticleMass
static double getParticleMass(const HepPDT::ParticleDataTable *pdt, int pdg)
Definition: BPhysPVCascadeTools.cxx:491
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_psi2
double m_mass_psi2
Definition: PsiPlusPsiSingleVertex.h:76
xAOD::Vertex_v1::trackParticleLinks
const TrackParticleLinks_t & trackParticleLinks() const
Get all the particles associated with the vertex.
DerivationFramework::PsiPlusPsiSingleVertex::m_psi1MassUpper
double m_psi1MassUpper
Definition: PsiPlusPsiSingleVertex.h:50
skel.it
it
Definition: skel.GENtoEVGEN.py:396
DerivationFramework::TrackParticleLinkVector
std::vector< TrackParticleLink > TrackParticleLinkVector
Definition: PsiPlusPsiSingleVertex.cxx:23
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_evtStore
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
Definition: AthCommonDataStore.h:390
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_vhka
std::vector< SG::VarHandleKeyArray * > m_vhka
Definition: AthCommonDataStore.h:398
DerivationFramework::PsiPlusPsiSingleVertex::m_refitPV
bool m_refitPV
Definition: PsiPlusPsiSingleVertex.h:90
LArG4FSStartPointFilter.evt
evt
Definition: LArG4FSStartPointFilter.py:42
DerivationFramework::PsiPlusPsiSingleVertex::m_psi2MassLower
double m_psi2MassLower
Definition: PsiPlusPsiSingleVertex.h:55
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
dbg::ptr
void * ptr(T *p)
Definition: SGImplSvc.cxx:74
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug_num
int m_vtx1Daug_num
Definition: PsiPlusPsiSingleVertex.h:59
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_psi1
double m_mass_psi1
Definition: PsiPlusPsiSingleVertex.h:73
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug4MassHypo
double m_vtx1Daug4MassHypo
Definition: PsiPlusPsiSingleVertex.h:63
DerivationFramework::PsiPlusPsiSingleVertex::m_psi2MassUpper
double m_psi2MassUpper
Definition: PsiPlusPsiSingleVertex.h:56
VertexLinkVector
std::vector< VertexLink > VertexLinkVector
Definition: BPhysHelper.cxx:20
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
DerivationFramework::PsiPlusPsiSingleVertex::m_psi1MassLower
double m_psi1MassLower
Definition: PsiPlusPsiSingleVertex.h:49
DerivationFramework::PsiPlusPsiSingleVertex::m_chi2cut
double m_chi2cut
Definition: PsiPlusPsiSingleVertex.h:83
IDTPMcnv.htype
htype
Definition: IDTPMcnv.py:27
runBeamSpotCalibration.helper
helper
Definition: runBeamSpotCalibration.py:112
python.setupRTTAlg.size
int size
Definition: setupRTTAlg.py:39
xAOD::BPhysHypoHelper
Definition: BPhysHypoHelper.h:73
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:210
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_diTrk2
double m_mass_diTrk2
Definition: PsiPlusPsiSingleVertex.h:75
AthCommonDataStore
Definition: AthCommonDataStore.h:52
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
SG::WriteHandleKey
Property holding a SG store/key/clid from which a WriteHandle is made.
Definition: StoreGate/StoreGate/WriteHandleKey.h:40
DerivationFramework::PsiPlusPsiSingleVertex::m_constrJpsi1
bool m_constrJpsi1
Definition: PsiPlusPsiSingleVertex.h:77
DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi1ContainerKey
SG::ReadHandleKey< xAOD::VertexContainer > m_vertexPsi1ContainerKey
Definition: PsiPlusPsiSingleVertex.h:36
SG::Decorator
Helper class to provide type-safe access to aux data.
Definition: Decorator.h:59
python.TrigInDetConfig.inputTracks
inputTracks
Definition: TrigInDetConfig.py:183
lumiFormat.i
int i
Definition: lumiFormat.py:85
DerivationFramework::PsiPlusPsiSingleVertex::m_eventInfo_key
SG::ReadHandleKey< xAOD::EventInfo > m_eventInfo_key
Definition: PsiPlusPsiSingleVertex.h:43
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_diTrk1
double m_mass_diTrk1
Definition: PsiPlusPsiSingleVertex.h:72
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_jpsi1
double m_mass_jpsi1
Definition: PsiPlusPsiSingleVertex.h:71
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
DerivationFramework::PsiPlusPsiSingleVertex::m_MassLower
double m_MassLower
Definition: PsiPlusPsiSingleVertex.h:57
DerivationFramework::PsiPlusPsiSingleVertex::m_trackContainerName
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_trackContainerName
Definition: PsiPlusPsiSingleVertex.h:42
DerivationFramework::PsiPlusPsiSingleVertex::m_mass_jpsi2
double m_mass_jpsi2
Definition: PsiPlusPsiSingleVertex.h:74
xAOD::Vertex_v1::setTrackParticleLinks
void setTrackParticleLinks(const TrackParticleLinks_t &trackParticles)
Set all track particle links at once.
DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack2MassLower
double m_diTrack2MassLower
Definition: PsiPlusPsiSingleVertex.h:53
DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack2MassUpper
double m_diTrack2MassUpper
Definition: PsiPlusPsiSingleVertex.h:54
test_pyathena.parent
parent
Definition: test_pyathena.py:15
DerivationFramework::PsiPlusPsiSingleVertex::m_pvRefitter
ToolHandle< Analysis::PrimaryVertexRefitter > m_pvRefitter
Definition: PsiPlusPsiSingleVertex.h:86
DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi1MassLower
double m_jpsi1MassLower
Definition: PsiPlusPsiSingleVertex.h:45
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
TRT_PAI_gasdata::SC
const float SC[NC]
Cross sections for Carbon.
Definition: TRT_PAI_gasdata.h:255
DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi2MassLower
double m_jpsi2MassLower
Definition: PsiPlusPsiSingleVertex.h:51
xAOD::Vertex_v1::trackParticle
const TrackParticle * trackParticle(size_t i) const
Get the pointer to a given track that was used in vertex reco.
Definition: Vertex_v1.cxx:249
AthCommonDataStore< AthCommonMsg< AlgTool > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
xAOD::Vertex_v1::clearTracks
void clearTracks()
Remove all tracks from the vertex.
Definition: Vertex_v1.cxx:331
DerivationFramework::PsiPlusPsiSingleVertex::m_PV_minNTracks
size_t m_PV_minNTracks
Definition: PsiPlusPsiSingleVertex.h:95
xAOD::Vertex_v1::z
float z() const
Returns the z position.
SG::VarHandleKey::initialize
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:103
DerivationFramework::PsiPlusPsiSingleVertex::m_hypoName
std::string m_hypoName
Definition: PsiPlusPsiSingleVertex.h:92
DeMoUpdate.tmp
string tmp
Definition: DeMoUpdate.py:1167
AthAlgTool::AthAlgTool
AthAlgTool()
Default constructor:
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
grepfile.ic
int ic
Definition: grepfile.py:33
DerivationFramework::PsiPlusPsiSingleVertex::m_MassUpper
double m_MassUpper
Definition: PsiPlusPsiSingleVertex.h:58
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
DerivationFramework::PsiPlusPsiSingleVertex::m_outputsKeys
SG::WriteHandleKeyArray< xAOD::VertexContainer > m_outputsKeys
Definition: PsiPlusPsiSingleVertex.h:40
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug3MassHypo
double m_vtx1Daug3MassHypo
Definition: PsiPlusPsiSingleVertex.h:62
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug_num
int m_vtx2Daug_num
Definition: PsiPlusPsiSingleVertex.h:64
plotBeamSpotMon.b
b
Definition: plotBeamSpotMon.py:77
DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi1MassUpper
double m_jpsi1MassUpper
Definition: PsiPlusPsiSingleVertex.h:46
DerivationFramework::PsiPlusPsiSingleVertex::m_V0Tools
ToolHandle< Trk::V0Tools > m_V0Tools
Definition: PsiPlusPsiSingleVertex.h:87
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
DerivationFramework::PsiPlusPsiSingleVertex::m_constrPsi2
bool m_constrPsi2
Definition: PsiPlusPsiSingleVertex.h:82
DerivationFramework::PsiPlusPsiSingleVertex::m_VxPrimaryCandidateName
SG::ReadHandleKey< xAOD::VertexContainer > m_VxPrimaryCandidateName
Name of primary vertex container.
Definition: PsiPlusPsiSingleVertex.h:41
DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack1MassLower
double m_diTrack1MassLower
Definition: PsiPlusPsiSingleVertex.h:47
SG::WriteHandle
Definition: StoreGate/StoreGate/WriteHandle.h:76
DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi2ContainerKey
SG::ReadHandleKey< xAOD::VertexContainer > m_vertexPsi2ContainerKey
Definition: PsiPlusPsiSingleVertex.h:37
a
TList * a
Definition: liststreamerinfos.cxx:10
h
xAOD::Vertex_v1
Class describing a Vertex.
Definition: Vertex_v1.h:42
DerivationFramework::PsiPlusPsiSingleVertex::m_refPVContainerName
SG::WriteHandleKey< xAOD::VertexContainer > m_refPVContainerName
Definition: PsiPlusPsiSingleVertex.h:91
std::sort
void sort(typename std::reverse_iterator< DataModel_detail::iterator< DVL > > beg, typename std::reverse_iterator< DataModel_detail::iterator< DVL > > end, const Compare &comp)
Specialization of sort for DataVector/List.
Definition: DVL_algorithms.h:623
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
DerivationFramework::PsiPlusPsiSingleVertex::m_vertexPsi1HypoNames
std::vector< std::string > m_vertexPsi1HypoNames
Definition: PsiPlusPsiSingleVertex.h:38
python.CaloScaleNoiseConfig.type
type
Definition: CaloScaleNoiseConfig.py:78
DerivationFramework::PsiPlusPsiSingleVertex::m_diTrack1MassUpper
double m_diTrack1MassUpper
Definition: PsiPlusPsiSingleVertex.h:48
DerivationFramework::PsiPlusPsiSingleVertex::m_constrJpsi2
bool m_constrJpsi2
Definition: PsiPlusPsiSingleVertex.h:80
xAOD::Vertex_v1::y
float y() const
Returns the y position.
DerivationFramework::PsiPlusPsiSingleVertex::m_jpsi2MassUpper
double m_jpsi2MassUpper
Definition: PsiPlusPsiSingleVertex.h:52
DerivationFramework::PsiPlusPsiSingleVertex::m_iVertexFitter
ToolHandle< Trk::TrkVKalVrtFitter > m_iVertexFitter
Definition: PsiPlusPsiSingleVertex.h:85
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:623
DerivationFramework::TrackParticleLink
ElementLink< xAOD::TrackParticleContainer > TrackParticleLink
Definition: PsiPlusPsiSingleVertex.cxx:22
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx1Daug1MassHypo
double m_vtx1Daug1MassHypo
Definition: PsiPlusPsiSingleVertex.h:60
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug4MassHypo
double m_vtx2Daug4MassHypo
Definition: PsiPlusPsiSingleVertex.h:68
skip
bool skip
Definition: TrigGlobEffCorrValidation.cxx:190
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug1MassHypo
double m_vtx2Daug1MassHypo
Definition: PsiPlusPsiSingleVertex.h:65
DerivationFramework::PsiPlusPsiSingleVertex::m_vtx2Daug2MassHypo
double m_vtx2Daug2MassHypo
Definition: PsiPlusPsiSingleVertex.h:66
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
xAOD::TrackParticle_v1::phi
virtual double phi() const override final
The azimuthal angle ( ) of the particle (has range to .)
fitman.k
k
Definition: fitman.py:528
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37
DerivationFramework::PsiPlusPsiSingleVertex::m_constrPsi1
bool m_constrPsi1
Definition: PsiPlusPsiSingleVertex.h:79