48 using namespace std::literals::string_literals;
55 ATH_MSG_INFO(
"Initializing ACTS Iterative Vertex Finder tool");
57 std::shared_ptr<const Acts::TrackingGeometry> trackingGeometry
62 Acts::Navigator navigator( Acts::Navigator::Config{ trackingGeometry },
63 logger().cloneWithSuffix(
"Navigator"));
65 m_bField = std::make_shared<ATLASMagneticFieldWrapper>();
66 auto stepper = Acts::EigenStepper<>(
m_bField);
67 m_propagator = std::make_shared<Propagator>(std::move(stepper),
69 logger().cloneWithSuffix(
"Prop"));
74 Acts::ImpactPointEstimator ipEst(ipEstCfg,
75 logger().cloneWithSuffix(
"ImpactPointEstimator"));
78 TrackLinearizer::Config ltConfig;
84 VertexFitter::Config fitterCfg;
87 fitterCfg.trackLinearizer.connect<&TrackLinearizer::linearizeTrack>(&*
m_linearizer);
93 Acts::GaussianTrackDensity::Config trackDensityConfig;
97 Acts::GaussianTrackDensity trackDensity(trackDensityConfig);
100 VertexSeedFinder::Config seedFinderConfig{trackDensity};
101 auto seedFinder = std::make_shared<VertexSeedFinder>(seedFinderConfig);
104 VertexFinder::Config finderConfig(std::move(fitter),
105 std::move(seedFinder),
117 finderConfig.trackLinearizer.connect<&TrackLinearizer::linearizeTrack>(&*
m_linearizer);
118 m_vertexFinder = std::make_shared<VertexFinder>(std::move(finderConfig),
logger().cloneWithSuffix(
"Finder"));
120 ATH_MSG_INFO(
"ACTS Iterative Vertex Finder tool successfully initialized");
121 return StatusCode::SUCCESS;
202 const std::vector<std::unique_ptr<Trk::ITrackLink>>& trackVector)
const
205 using namespace Acts::UnitLiterals;
213 theVertexContainer->setStore(theVertexAuxContainer);
219 <<
"), skipping vertexing and returning only dummy...");
223 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
225 beamSpotHandle->beamVtx().covariancePosition());
226 dummyxAODVertex->
vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
228 return std::make_pair(theVertexContainer, theVertexAuxContainer);
231 const Acts::Vector3& beamSpotPos = beamSpotHandle->beamVtx().position();
232 Acts::Vertex beamSpotConstraintVtx(beamSpotPos);
233 beamSpotConstraintVtx.setCovariance(beamSpotHandle->beamVtx().covariancePosition());
235 std::shared_ptr<Acts::PerigeeSurface> perigeeSurface =
236 Acts::Surface::makeShared<Acts::PerigeeSurface>((trackVector[0])->parameters()->associatedSurface().transform());
239 Acts::MagneticFieldContext magFieldContext =
m_extrapolationTool->getMagneticFieldContext(ctx);
241 const auto& geoContext
245 std::vector<TrackWrapper> allTracks;
247 for (
const auto& trk : trackVector) {
249 const auto& trkParams = trk->parameters();
250 const auto& params = trkParams->parameters();
252 Acts::BoundVector actsParams;
253 actsParams << params(0), params(1), params(2), params(3), params(4)*1./(1_MeV), 0.;
255 if(trkParams->covariance() ==
nullptr){
258 auto cov = *(trkParams->covariance());
263 Acts::BoundMatrix covMat;
264 covMat << cov(0,0) , cov(0,1) , cov(0,2) , cov(0,3) , cov(0,4) *1./(1_MeV), 0
265 , cov(1,0) , cov(1,1) , cov(1,2) , cov(1,3) , cov(1,4) *1./(1_MeV) , 0
266 , cov(2,0) , cov(2,1) , cov(2,2) , cov(2,3) , cov(2,4) *1./(1_MeV) , 0
267 , cov(3,0) , cov(3,1) , cov(3,2) , cov(3,3) , cov(3,4) *1./(1_MeV) , 0
268 , cov(4,0) *1./(1_MeV) , cov(4,1) *1./(1_MeV) , cov(4,2) *1./(1_MeV) , cov(4,3) *1./(1_MeV) , cov(4,4) *1./(1_MeV*1_MeV), 0
269 , 0. , 0. , 0. , 0., 0., 1.;
271 allTracks.emplace_back(trk.get(),Acts::BoundTrackParameters(perigeeSurface, actsParams, covMat, Acts::ParticleHypothesis::pion()));
274 std::vector<Acts::InputTrack> allTrackPtrs;
275 allTrackPtrs.reserve(allTracks.size());
277for(
const auto& trk : allTracks){
278 allTrackPtrs.emplace_back(&trk);
281 Acts::VertexingOptions vertexingOptions(geoContext,
285 beamSpotConstraintVtx.setPosition(Acts::Vector3::Zero());
286 beamSpotConstraintVtx.setCovariance(Acts::SquareMatrix<3>::Zero());
291 Acts::Vector4 vtxConstraintPos;
292 Acts::SquareMatrix4 vtxConstraintCov;
294 auto beamSpotCov = beamSpotHandle->beamVtx().covariancePosition();
296 vtxConstraintPos << beamSpotPos(0), beamSpotPos(1), beamSpotPos(2), 0.;
297 vtxConstraintCov << beamSpotCov(0,0), beamSpotCov(0,1), beamSpotCov(0,2), 0.
298 , beamSpotCov(1,0), beamSpotCov(1,1), beamSpotCov(1,2), 0.
299 , beamSpotCov(2,0), beamSpotCov(2,1), beamSpotCov(2,2), 0.
302 vertexingOptions.constraint.setFullPosition(vtxConstraintPos);
303 vertexingOptions.constraint.setFullCovariance(vtxConstraintCov);
307 auto findResult =
m_vertexFinder->find(allTrackPtrs, vertexingOptions, finderState);
309 if(!findResult.ok()){
311 theVertexContainer->
push_back(dummyxAODVertex);
312 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
314 dummyxAODVertex->
vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
317 return std::make_pair(theVertexContainer, theVertexAuxContainer);
320 std::vector<Acts::Vertex> allVertices = *findResult;
322 for(
const auto& vtx : allVertices){
324 xAODVtx->makePrivateStore();
327 xAODVtx->
setFitQuality(vtx.fitQuality().first, vtx.fitQuality().second);
329 const auto& tracks = vtx.tracks();
330 std::vector<Trk::VxTrackAtVertex>* trkAtVtxVec = &(xAODVtx->
vxTrackAtVertex());
331 for(
const auto& trk : tracks){
335 const TrackWrapper* originalParams = trk.originalParams.template as<TrackWrapper>();
343 trkAtVtxVec->push_back(trkAtVtx);
356 if (!theVertexContainer->
empty()) {
361 theVertexContainer->
push_back(dummyxAODVertex);
364 dummyxAODVertex->
vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
371 theVertexContainer->
push_back(dummyxAODVertex);
372 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
374 dummyxAODVertex->
vxTrackAtVertex() = std::vector<Trk::VxTrackAtVertex>();
380 for (
unsigned int i = 0; i < theVertexContainer->
size() - 1; i++) {
383 " Vtx: " << i <<
" x= " << (*theVertexContainer)[i]->position().
x()
384 <<
" y= " << (*theVertexContainer)[i]->position().
y() <<
" z= "
385 << (*theVertexContainer)[i]->position().
z() <<
" ntracks= "
386 << (*theVertexContainer)[i]->vxTrackAtVertex().
size()
387 <<
" chi2= " << (*theVertexContainer)[i]->chiSquared()
388 <<
" ndf = " << (*theVertexContainer)[i]->numberDoF());
395 return std::make_pair(theVertexContainer, theVertexAuxContainer);