67 {
68 std::vector<Trk::VxCascadeInfo*> cascadeinfoContainer;
69 constexpr int topoN = 2;
70 std::array<xAOD::VertexContainer*, topoN> Vtxwritehandles;
71 std::array<xAOD::VertexAuxContainer*, topoN> Vtxwritehandlesaux;
73
74 for(
int i =0;
i<topoN;
i++){
77 Vtxwritehandles[
i]->setStore(Vtxwritehandlesaux[i]);
80 }
81
82
83
84
89
90 if (pvContainer->
size()==0){
92 return StatusCode::RECOVERABLE;
93 } else {
94 primaryVertex = (*pvContainer)[0];
95 }
96
97
98
99
104
107 } else {
108
111 refPvContainer->setStore(refPvAuxContainer);
114 }
115 }
116
118
123
124
128 SG::AuxElement::Decorator<float> chi2_decor("ChiSquared");
129 SG::AuxElement::Decorator<float> ndof_decor("NumberDoF");
130 SG::AuxElement::Decorator<float> Pt_decor("Pt");
131 SG::AuxElement::Decorator<float> PtErr_decor("PtErr");
132 SG::AuxElement::Decorator<float> Mass_svdecor("Dx_mass");
133 SG::AuxElement::Decorator<float> MassErr_svdecor("Dx_massErr");
134 SG::AuxElement::Decorator<float> Pt_svdecor("Dx_Pt");
135 SG::AuxElement::Decorator<float> PtErr_svdecor("Dx_PtErr");
136 SG::AuxElement::Decorator<float> Lxy_svdecor("Dx_Lxy");
137 SG::AuxElement::Decorator<float> LxyErr_svdecor("Dx_LxyErr");
138 SG::AuxElement::Decorator<float> Tau_svdecor("Dx_Tau");
139 SG::AuxElement::Decorator<float> TauErr_svdecor("Dx_TauErr");
140
141 SG::AuxElement::Decorator<float> MassMumu_decor("Mumu_mass");
142 SG::AuxElement::Decorator<float> MassKX_svdecor("KX_mass");
143 SG::AuxElement::Decorator<float> MassKXpi_svdecor("KXpi_mass");
144
145 ATH_MSG_DEBUG(
"cascadeinfoContainer size " << cascadeinfoContainer.size());
146
147
152
153 for (Trk::VxCascadeInfo*
x : cascadeinfoContainer) {
156
157 return StatusCode::FAILURE;
158 }
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178 const std::vector<xAOD::Vertex*> &cascadeVertices =
x->vertices();
179 if(cascadeVertices.size()!=topoN)
181 if(cascadeVertices[0] ==
nullptr || cascadeVertices[1] ==
nullptr)
ATH_MSG_ERROR(
"Error null vertex");
182
183 for(
int i =0;
i<topoN;
i++) Vtxwritehandles[i]->push_back(cascadeVertices[i]);
184
185 x->setSVOwnership(
false);
186 const auto mainVertex = cascadeVertices[1];
187 const std::vector< std::vector<TLorentzVector> > &moms =
x->getParticleMoms();
188
189
190 std::vector<const xAOD::Vertex*> verticestoLink;
191 verticestoLink.push_back(cascadeVertices[0]);
192 if(Vtxwritehandles[1] ==
nullptr)
ATH_MSG_ERROR(
"Vtxwritehandles[1] is null");
195
196
198 ATH_MSG_DEBUG(
"1 pt Jpsi tracks " << cascadeVertices[1]->trackParticle(0)->
pt() <<
", " << cascadeVertices[1]->trackParticle(1)->
pt());
200
201
203 ATH_MSG_DEBUG(
"1 pt D_(s)+ tracks " << cascadeVertices[0]->trackParticle(0)->
pt() <<
", " << cascadeVertices[0]->trackParticle(1)->
pt() <<
", " << cascadeVertices[0]->trackParticle(2)->
pt());
205
206
207 std::vector<const xAOD::Vertex*> jpsiVerticestoLink;
208 if (jpsiVertex) jpsiVerticestoLink.push_back(jpsiVertex);
212
213 std::vector<const xAOD::Vertex*> dxVerticestoLink;
214 if (dxVertex) dxVerticestoLink.push_back(dxVertex);
218
219 bool tagDp(true);
220 if (dxVertex) {
222 }
223
226 std::vector<double> massesJpsi;
229 std::vector<double> massesDx;
230 if(tagDp){
233 }else{
236 }
238 std::vector<double> Masses;
242
243
244
245
246
247
248 xAOD::BPhysHypoHelper vtx(
m_hypoName, mainVertex);
249
250
252
253
254
255
258
260 PtErr_decor(*mainVertex) =
m_CascadeTools->pTError(moms[1],
x->getCovariance()[1]);
261
262 chi2_decor(*mainVertex) =
x->fitChi2();
263 ndof_decor(*mainVertex) =
x->nDoF();
264
265 float massMumu = 0.;
266 if (jpsiVertex) {
267 TLorentzVector p4_mu1, p4_mu2;
274 massMumu = (p4_mu1 + p4_mu2).M();
275 }
276 MassMumu_decor(*mainVertex) = massMumu;
277
278 float massKX = 0., massKXpi = 0.;
279 if (dxVertex) {
280 TLorentzVector p4_h1, p4_h2, p4_h3;
281 if(tagDp){
288 }else{
295 }
299 massKX = (p4_h1 + p4_h2).M();
300 massKXpi = (p4_h1 + p4_h2 + p4_h3).M();
301 }
302 MassKX_svdecor(*mainVertex) = massKX;
303 MassKXpi_svdecor(*mainVertex) = massKXpi;
304
307
308
309
310
311 Mass_svdecor(*mainVertex) =
m_CascadeTools->invariantMass(moms[0]);
312 MassErr_svdecor(*mainVertex) =
m_CascadeTools->invariantMassError(moms[0],
x->getCovariance()[0]);
314 PtErr_svdecor(*mainVertex) =
m_CascadeTools->pTError(moms[0],
x->getCovariance()[0]);
315 Lxy_svdecor(*mainVertex) =
m_CascadeTools->lxy(moms[0],cascadeVertices[0],cascadeVertices[1]);
316 LxyErr_svdecor(*mainVertex) =
m_CascadeTools->lxyError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1]);
317 Tau_svdecor(*mainVertex) =
m_CascadeTools->tau(moms[0],cascadeVertices[0],cascadeVertices[1]);
318 TauErr_svdecor(*mainVertex) =
m_CascadeTools->tauError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1]);
319
320
322 <<
" chi2_1 " <<
m_V0Tools->chisq(cascadeVertices[0])
323 <<
" chi2_2 " <<
m_V0Tools->chisq(cascadeVertices[1])
327 <<
" error " <<
m_V0Tools->invariantMassError(cascadeVertices[0],massesDx)
328 <<
" mass_J " <<
m_V0Tools->invariantMass(cascadeVertices[1],massesJpsi)
329 <<
" error " <<
m_V0Tools->invariantMassError(cascadeVertices[1],massesJpsi));
330
333 double Mass_B_err =
m_CascadeTools->invariantMassError(moms[1],
x->getCovariance()[1]);
334 double Mass_D_err =
m_CascadeTools->invariantMassError(moms[0],
x->getCovariance()[0]);
336 ATH_MSG_DEBUG(
"Mass_B_err " << Mass_B_err <<
" Mass_D_err " << Mass_D_err);
337 double mprob_B =
m_CascadeTools->massProbability(mass_b,Mass_B,Mass_B_err);
338 double mprob_D =
m_CascadeTools->massProbability(mass_d,Mass_D,Mass_D_err);
339 ATH_MSG_DEBUG(
"mprob_B " << mprob_B <<
" mprob_D " << mprob_D);
340
342 <<
" Mass_d " <<
m_CascadeTools->invariantMass(moms[0],massesDx));
344 <<
" Mass_d_err " <<
m_CascadeTools->invariantMassError(moms[0],
x->getCovariance()[0],massesDx));
347 <<
" pt_dp " <<
m_V0Tools->pT(cascadeVertices[0]));
349 <<
" ptErr_d " <<
m_CascadeTools->pTError(moms[0],
x->getCovariance()[0])
350 <<
" ptErr_dp " <<
m_V0Tools->pTError(cascadeVertices[0]));
354 <<
" lxyErr_d " <<
m_CascadeTools->lxyError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1])
355 <<
" lxyErr_dp " <<
m_V0Tools->lxyError(cascadeVertices[0],cascadeVertices[1]));
357 <<
" tau_dp " <<
m_V0Tools->tau(cascadeVertices[0],cascadeVertices[1],massesDx));
359 <<
" tau_d " <<
m_CascadeTools->tau(moms[0],cascadeVertices[0],cascadeVertices[1])
360 <<
" tau_D " <<
m_CascadeTools->tau(moms[0],cascadeVertices[0],cascadeVertices[1],mass_d));
362 <<
" tauErr_d " <<
m_CascadeTools->tauError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1])
363 <<
" tauErr_dp " <<
m_V0Tools->tauError(cascadeVertices[0],cascadeVertices[1],massesDx));
365 <<
" TauErr_d " <<
m_CascadeTools->tauError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1],mass_d)
366 <<
" TauErr_dp " <<
m_V0Tools->tauError(cascadeVertices[0],cascadeVertices[1],massesDx,mass_d));
367
368 ATH_MSG_DEBUG(
"CascadeTools main vert wrt PV " <<
" CascadeTools SV " <<
" V0Tools SV");
370 <<
", " <<
m_CascadeTools->a0z(moms[0],cascadeVertices[0],cascadeVertices[1])
371 <<
", " <<
m_V0Tools->a0z(cascadeVertices[0],cascadeVertices[1]));
373 <<
", " <<
m_CascadeTools->a0zError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1])
374 <<
", " <<
m_V0Tools->a0zError(cascadeVertices[0],cascadeVertices[1]));
376 <<
", " <<
m_CascadeTools->a0xy(moms[0],cascadeVertices[0],cascadeVertices[1])
377 <<
", " <<
m_V0Tools->a0xy(cascadeVertices[0],cascadeVertices[1]));
379 <<
", " <<
m_CascadeTools->a0xyError(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1])
380 <<
", " <<
m_V0Tools->a0xyError(cascadeVertices[0],cascadeVertices[1]));
382 <<
", " <<
m_CascadeTools->a0(moms[0],cascadeVertices[0],cascadeVertices[1])
383 <<
", " <<
m_V0Tools->a0(cascadeVertices[0],cascadeVertices[1]));
385 <<
", " <<
m_CascadeTools->a0Error(moms[0],
x->getCovariance()[0],cascadeVertices[0],cascadeVertices[1])
386 <<
", " <<
m_V0Tools->a0Error(cascadeVertices[0],cascadeVertices[1]));
389 ATH_MSG_DEBUG(
"X0 " << primaryVertex->
x() <<
" Y0 " << primaryVertex->
y() <<
" Z0 " << primaryVertex->
z());
392 ATH_MSG_DEBUG(
"Rxy0 wrt PV " <<
m_V0Tools->rxy(cascadeVertices[0],primaryVertex) <<
" RxyErr0 wrt PV " <<
m_V0Tools->rxyError(cascadeVertices[0],primaryVertex));
393 ATH_MSG_DEBUG(
"Rxy1 wrt PV " <<
m_V0Tools->rxy(cascadeVertices[1],primaryVertex) <<
" RxyErr1 wrt PV " <<
m_V0Tools->rxyError(cascadeVertices[1],primaryVertex));
394 ATH_MSG_DEBUG(
"number of covariance matrices " << (
x->getCovariance()).size());
395 }
396
397
398
399 for (
auto x : cascadeinfoContainer)
delete x;
400
401 return StatusCode::SUCCESS;
402 }
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_WARNING(x)
#define BPHYS_CHECK(EXP)
Useful CHECK macro.
size_type size() const noexcept
Returns the number of elements in the collection.
StatusCode performSearch(std::vector< Trk::VxCascadeInfo * > *cascadeinfoContainer, const EventContext &ctx) const
SG::ReadHandleKey< xAOD::EventInfo > m_eventInfo_key
SG::Decorator< T, ALLOC > Decorator
virtual double phi() const override final
The azimuthal angle ( ) of the particle (has range to .)
virtual double pt() const override final
The transverse momentum ( ) of the particle.
virtual double eta() const override final
The pseudorapidity ( ) of the particle.
float charge() const
Returns the charge.
float z() const
Returns the z position.
const TrackParticle * trackParticle(size_t i) const
Get the pointer to a given track that was used in vertex reco.
float y() const
Returns the y position.
float x() const
Returns the x position.
bool contains(const std::string &s, const std::string ®x)
does a string contain the substring
retrieve(aClass, aKey=None)
VertexAuxContainer_v1 VertexAuxContainer
Definition of the current jet auxiliary container.
VertexContainer_v1 VertexContainer
Definition of the current "Vertex container version".
Vertex_v1 Vertex
Define the latest version of the vertex class.