74 std::vector<const xAOD::Vertex*> BVertices;
76 std::vector<const xAOD::TrackParticle*> BVertexTracks;
82 conversionContainer->setStore(conversionAuxContainer.get());
94 return StatusCode::SUCCESS;;
97 ATH_MSG_DEBUG(
"Low pT track particle container size " << lowPtTrackParticles->
size());
104 return StatusCode::FAILURE;
108 ATH_MSG_DEBUG(
"Using " << *itr <<
" as the source B vertex collection" );
117 ATH_MSG_DEBUG(
"Vertex Container (" << *itr <<
") contains " << BVtxContainer->
size() <<
" vertices" );
120 static const std::vector< VertexLink > vertexLinks;
123 BGammaLinks(*
vertex) = vertexLinks;
125 bool passedHypothesis =
false;
126 BVertexTracks.clear();
131 if (pass) passedHypothesis =
true;
134 if (!passedHypothesis)
continue;
138 std::vector<const xAOD::Vertex*> precedingVertices(1,
vertex);
141 for (
size_t i = 0;
i <
vertex->nTrackParticles(); ++
i) BVertexTracks.push_back(
vertex->trackParticle(
i));
148 auto itr1 =
std::find(BVertexTracks.begin(), BVertexTracks.end(), trackParticle1);
149 if (itr1 != BVertexTracks.end())
continue;
156 if (trackParticle1 == trackParticle2)
continue;
158 auto itr2 =
std::find(BVertexTracks.begin(), BVertexTracks.end(), trackParticle2);
159 if (itr2 != BVertexTracks.end())
continue;
164 TLorentzVector
e1,
e2, gamma_m, BcStar;
171 TLorentzVector mu1 = Bc.refTrk(0,
Trk::muon);
172 TLorentzVector mu2 = Bc.refTrk(1,
Trk::muon);
173 TLorentzVector mu3 = Bc.refTrk(2,
Trk::muon);
175 BcStar = mu1 + mu2 + mu3 +
e1 +
e2;
185 std::vector<float> RefTrackPx, RefTrackPy, RefTrackPz, RefTrackE;
186 std::vector<float> OrigTrackPx, OrigTrackPy, OrigTrackPz, OrigTrackE;
188 std::vector<const xAOD::TrackParticle*> trackPair;
190 trackPair.push_back(trackParticle1);
191 trackPair.push_back(trackParticle2);
197 if (convVertexCandidate) {
202 Photon.setPrecedingVertices(precedingVertices, BVtxContainer);
215 std::vector<Amg::Vector3D> positionList;
220 TLorentzVector
photon, electron1, electron2, ph;
223 photon = electron1 + electron2;
230 std::vector<float> B_Px = RefTrackPxAcc(*
vertex);
231 std::vector<float> B_Py = RefTrackPyAcc(*
vertex);
232 std::vector<float> B_Pz = RefTrackPzAcc(*
vertex);
234 TLorentzVector muon1, muon2, muon3;
235 muon1.SetXYZM(B_Px.at(0), B_Py.at(0), B_Pz.at(0),
Trk::muon);
236 muon2.SetXYZM(B_Px.at(1), B_Py.at(1), B_Pz.at(1),
Trk::muon);
237 muon3.SetXYZM(B_Px.at(2), B_Py.at(2), B_Pz.at(2),
Trk::muon);
239 TLorentzVector B_m = muon1 + muon2 + muon3;
244 RefTrackPx.push_back(
trackMomentum(convVertexCandidate, 0).Px());
245 RefTrackPx.push_back(
trackMomentum(convVertexCandidate, 1).Px());
247 RefTrackPy.push_back(
trackMomentum(convVertexCandidate, 0).Py());
248 RefTrackPy.push_back(
trackMomentum(convVertexCandidate, 1).Py());
250 RefTrackPz.push_back(
trackMomentum(convVertexCandidate, 0).Pz());
251 RefTrackPz.push_back(
trackMomentum(convVertexCandidate, 1).Pz());
253 for (
size_t i = 0;
i < B_Px.size();
i++) {
254 RefTrackPx.push_back(B_Px.at(
i));
255 RefTrackPy.push_back(B_Py.at(
i));
256 RefTrackPz.push_back(B_Pz.at(
i));
259 RefTrackE.push_back(electron1.E());
260 RefTrackE.push_back(electron2.E());
261 RefTrackE.push_back(muon1.E());
262 RefTrackE.push_back(muon2.E());
263 RefTrackE.push_back(muon3.E());
265 OrigTrackPx.push_back(
e1.Px());
266 OrigTrackPx.push_back(
e2.Px());
268 OrigTrackPy.push_back(
e1.Py());
269 OrigTrackPy.push_back(
e2.Py());
271 OrigTrackPz.push_back(
e1.Pz());
272 OrigTrackPz.push_back(
e2.Pz());
274 OrigTrackE.push_back(
e1.E());
275 OrigTrackE.push_back(
e2.E());
278 ATH_MSG_DEBUG(
"pt = " <<
photon.Pt() <<
" ph " << ph.Pt() <<
" mass " <<
photon.M() <<
" px size " << RefTrackPx.size() );
279 ATH_MSG_DEBUG(
"Candidate DeltaM = " << (B_m +
photon).M() <<
" MeV DiMuon " <<
" ( Mass = " << B_m.M() <<
" MeV )");
287 pxAcc(*convVertexCandidate) =
momentum.x();
288 pyAcc(*convVertexCandidate) =
momentum.y();
289 pzAcc(*convVertexCandidate) =
momentum.z();
294 deltaQAcc(*convVertexCandidate) = deltaQ;
295 gamma_massAcc(*convVertexCandidate) =
mass;
296 RefTrackPxAcc(*convVertexCandidate) = RefTrackPx;
297 RefTrackPyAcc(*convVertexCandidate) = RefTrackPy;
298 RefTrackPzAcc(*convVertexCandidate) = RefTrackPz;
299 RefTrackEAcc(*convVertexCandidate) = RefTrackE;
305 OrigTrackPxAcc(*convVertexCandidate) = OrigTrackPx;
306 OrigTrackPyAcc(*convVertexCandidate) = OrigTrackPy;
307 OrigTrackPzAcc(*convVertexCandidate) = OrigTrackPz;
308 OrigTrackEAcc(*convVertexCandidate) = OrigTrackE;
311 passed_GammaAcc(*convVertexCandidate) =
true;
313 conversionContainer->push_back( convVertexCandidate );
319 BGammaLinks(*vertex).push_back(std::move(BGammaLink));
336 return StatusCode::SUCCESS;