73 std::vector<const xAOD::Vertex*> BVertices;
74 std::vector<const xAOD::TrackParticle*> BVertexTracks;
80 conversionContainer->setStore(conversionAuxContainer.get());
84 ATH_MSG_DEBUG(
"Track particle container size " << inputTrackParticles->size() );
86 std::vector<const xAOD::TrackParticle*> trackPair(2);
93 if (!BVtxContainer.isValid()) {
94 ATH_MSG_ERROR(
"Failed to retrieve VertexContainer " << BVtxContainer.key());
95 return StatusCode::FAILURE;
98 ATH_MSG_DEBUG(
"Vertex Container (" << BVtxContainer.key() <<
") contains " << BVtxContainer->size() <<
" vertices" );
102 auto &vect = BGammaLinks(*vertex) = std::vector< VertexLink >();
104 bool passedHypothesis =
false;
105 BVertexTracks.clear();
107 for (
const auto &flag : flaghandles) {
108 bool pass = flag(*vertex);
109 if (pass) passedHypothesis =
true;
112 if (!passedHypothesis)
continue;
116 std::vector<const xAOD::Vertex*> precedingVertices(1, vertex);
119 for (
size_t i = 0; i < vertex->nTrackParticles(); ++i) BVertexTracks.push_back(vertex->trackParticle(i));
124 trackPair[0] = *tpIt1;
126 auto itr1 = std::find(BVertexTracks.begin(), BVertexTracks.end(), trackPair[0]);
127 if (itr1 != BVertexTracks.end())
continue;
129 const Trk::Perigee& trackPerigee1 = trackPair[0]->perigeeParameters();
133 trackPair[1] = *tpIt2;
134 if (trackPair[0] == trackPair[1])
continue;
136 auto itr2 = std::find(BVertexTracks.begin(), BVertexTracks.end(), trackPair[1]);
137 if (itr2 != BVertexTracks.end())
continue;
139 const Trk::Perigee& trackPerigee2 = trackPair[1]->perigeeParameters();
142 TLorentzVector e1, e2, gamma_m, BcStar;
143 e1.SetPtEtaPhiM(trackPair[0]->pt(), trackPair[0]->
eta(), trackPair[0]->
phi(),
Trk::electron);
144 e2.SetPtEtaPhiM(trackPair[1]->pt(), trackPair[1]->
eta(), trackPair[1]->
phi(),
Trk::electron);
153 BcStar = mu1 + mu2 + mu3 + e1 + e2;
161 if (errorcode != 0) startingPoint = Amg::Vector3D::Zero(3);
163 std::vector<float> RefTrackPx, RefTrackPy, RefTrackPz, RefTrackE;
164 std::vector<float> OrigTrackPx, OrigTrackPy, OrigTrackPz, OrigTrackE;
168 auto convVertexCandidate =
m_vertexFitter->fit(ctx, trackPair, startingPoint);
171 if (convVertexCandidate) {
172 if (convVertexCandidate->chiSquared() / convVertexCandidate->numberDoF() >
m_Chi2Cut)
continue;
176 Photon.setPrecedingVertices(precedingVertices, BVtxContainer.cptr());
179 convVertexCandidate->clearTracks();
186 convVertexCandidate->addTrackAtVertex(newLink1);
187 convVertexCandidate->addTrackAtVertex(newLink2);
189 std::vector<Amg::Vector3D> positionList;
194 TLorentzVector photon, electron1, electron2, ph;
197 photon = electron1 + electron2;
198 ph.SetXYZM(momentum.x(), momentum.y(), momentum.z(), 0.);
204 std::vector<float> B_Px = RefTrackPxAcc(*vertex);
205 std::vector<float> B_Py = RefTrackPyAcc(*vertex);
206 std::vector<float> B_Pz = RefTrackPzAcc(*vertex);
208 TLorentzVector muon1, muon2, muon3;
209 muon1.SetXYZM(B_Px.at(0), B_Py.at(0), B_Pz.at(0),
Trk::muon);
210 muon2.SetXYZM(B_Px.at(1), B_Py.at(1), B_Pz.at(1),
Trk::muon);
211 muon3.SetXYZM(B_Px.at(2), B_Py.at(2), B_Pz.at(2),
Trk::muon);
213 TLorentzVector B_m = muon1 + muon2 + muon3;
216 const double mass = photon.M();
218 RefTrackPx.push_back(
trackMomentum(*convVertexCandidate, 0).Px());
219 RefTrackPx.push_back(
trackMomentum(*convVertexCandidate, 1).Px());
221 RefTrackPy.push_back(
trackMomentum(*convVertexCandidate, 0).Py());
222 RefTrackPy.push_back(
trackMomentum(*convVertexCandidate, 1).Py());
224 RefTrackPz.push_back(
trackMomentum(*convVertexCandidate, 0).Pz());
225 RefTrackPz.push_back(
trackMomentum(*convVertexCandidate, 1).Pz());
227 for (
size_t i = 0; i < B_Px.size(); i++) {
228 RefTrackPx.push_back(B_Px.at(i));
229 RefTrackPy.push_back(B_Py.at(i));
230 RefTrackPz.push_back(B_Pz.at(i));
233 RefTrackE.push_back(electron1.E());
234 RefTrackE.push_back(electron2.E());
235 RefTrackE.push_back(muon1.E());
236 RefTrackE.push_back(muon2.E());
237 RefTrackE.push_back(muon3.E());
239 OrigTrackPx.push_back(e1.Px());
240 OrigTrackPx.push_back(e2.Px());
242 OrigTrackPy.push_back(e1.Py());
243 OrigTrackPy.push_back(e2.Py());
245 OrigTrackPz.push_back(e1.Pz());
246 OrigTrackPz.push_back(e2.Pz());
248 OrigTrackE.push_back(e1.E());
249 OrigTrackE.push_back(e2.E());
252 ATH_MSG_DEBUG(
"pt = " << photon.Pt() <<
" ph " << ph.Pt() <<
" mass " << photon.M() <<
" px size " << RefTrackPx.size() );
253 ATH_MSG_DEBUG(
"Candidate DeltaM = " << (B_m + photon).M() <<
" MeV DiMuon " <<
" ( Mass = " << B_m.M() <<
" MeV )");
261 pxAcc(*convVertexCandidate) = momentum.x();
262 pyAcc(*convVertexCandidate) = momentum.y();
263 pzAcc(*convVertexCandidate) = momentum.z();
268 deltaQAcc(*convVertexCandidate) = deltaQ;
269 gamma_massAcc(*convVertexCandidate) = mass;
270 RefTrackPxAcc(*convVertexCandidate) = RefTrackPx;
271 RefTrackPyAcc(*convVertexCandidate) = RefTrackPy;
272 RefTrackPzAcc(*convVertexCandidate) = RefTrackPz;
273 RefTrackEAcc(*convVertexCandidate) = RefTrackE;
279 OrigTrackPxAcc(*convVertexCandidate) = OrigTrackPx;
280 OrigTrackPyAcc(*convVertexCandidate) = OrigTrackPy;
281 OrigTrackPzAcc(*convVertexCandidate) = OrigTrackPz;
282 OrigTrackEAcc(*convVertexCandidate) = OrigTrackE;
285 passed_GammaAcc(*convVertexCandidate) =
true;
290 BGammaLink.
setElement(convVertexCandidate.get());
292 conversionContainer->push_back( std::move(convVertexCandidate) );
293 vect.push_back(std::move(BGammaLink));
307 ATH_CHECK( wh.record(std::move(conversionContainer), std::move(conversionAuxContainer)) );
309 return StatusCode::SUCCESS;