54 using namespace std::literals::string_literals;
61 std::shared_ptr<const Acts::TrackingGeometry> trackingGeometry
69 Acts::Navigator navigator( Acts::Navigator::Config{ trackingGeometry },
70 logger().cloneWithSuffix(
"Navigator"));
72 auto bField = std::make_shared<ATLASMagneticFieldWrapper>();
73 auto stepper = Acts::EigenStepper<>(bField);
74 m_propagator = std::make_shared<Propagator>(std::move(stepper),
76 logger().cloneWithSuffix(
"Prop"));
79 Acts::ImpactPointEstimator::Config ipEstCfg(bField,
m_propagator);
82 Acts::ImpactPointEstimator ipEst(ipEstCfg,
83 logger().cloneWithSuffix(
"ImpactPointEstimator"));
85 Acts::AnnealingUtility::Config annealingConfig;
88 Acts::AnnealingUtility annealingUtility(annealingConfig);
91 TrackLinearizer::Config ltConfig;
92 ltConfig.bField = bField;
97 VertexFitter::Config fitterCfg(ipEst);
98 fitterCfg.annealingTool = annealingUtility;
105 fitterCfg.trackLinearizer.connect<&TrackLinearizer::linearizeTrack>(&*
m_linearizer);
110 if (seederType ==
"Grid") {
111 Acts::GaussianGridTrackDensity::Config trackDensityConfig;
115 Acts::GaussianGridTrackDensity trackDensity(trackDensityConfig);
117 Acts::GridDensityVertexFinder::Config gridSeedFinderConfig(trackDensity);
122 Acts::GridDensityVertexFinder gridSeedFinder(gridSeedFinderConfig);
124 VertexFinder::Config finderConfig(
126 std::make_shared<Acts::GridDensityVertexFinder>(gridSeedFinder),
133 else if (seederType ==
"Gaussian") {
134 Acts::GaussianTrackDensity::Config trackDensityConfig;
139 Acts::GaussianTrackDensity trackDensity(trackDensityConfig);
140 VertexSeedFinder::Config seedFinderConfig(trackDensity);
141 auto seedFinder = std::make_shared<VertexSeedFinder>(seedFinderConfig);
143 VertexFinder::Config finderConfig(
154 return StatusCode::FAILURE;
157 ATH_MSG_INFO(
"ACTS AMVF tool successfully initialized");
158 return StatusCode::SUCCESS;
265 const std::vector<std::unique_ptr<Trk::ITrackLink>>& trackVector)
const
267 using namespace Acts::UnitLiterals;
270 const Acts::Vector3& beamSpotPos = beamSpotHandle->beamVtx().position();
271 Acts::Vertex beamSpotConstraintVtx(beamSpotPos);
272 beamSpotConstraintVtx.setCovariance(beamSpotHandle->beamVtx().covariancePosition());
275 Acts::MagneticFieldContext magFieldContext =
m_extrapolationTool->getMagneticFieldContext(ctx);
282 theVertexContainer->setStore(theVertexAuxContainer);
284 if(trackVector.empty()){
286 theVertexContainer->
push_back(dummyxAODVertex);
287 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
291 return std::make_pair(theVertexContainer, theVertexAuxContainer);
294 std::shared_ptr<Acts::PerigeeSurface> perigeeSurface =
295 Acts::Surface::makeShared<Acts::PerigeeSurface>((trackVector[0])->parameters()->associatedSurface().transform());
298 std::vector<TrackWrapper> allTracks;
300 for (
const auto& trk : trackVector) {
301 const auto& trkParams = trk->parameters();
302 const auto& params = trkParams->parameters();
304 Acts::BoundVector actsParams;
305 actsParams << params(0), params(1), params(2), params(3), params(4)*1./(1_MeV), 0.;
307 if(trkParams->covariance() ==
nullptr){
311 auto cov = *(trkParams->covariance());
316 Acts::BoundMatrix covMat;
317 covMat << cov(0,0) , cov(0,1) , cov(0,2) , cov(0,3) , cov(0,4) *1./(1_MeV), 0
318 , cov(1,0) , cov(1,1) , cov(1,2) , cov(1,3) , cov(1,4) *1./(1_MeV) , 0
319 , cov(2,0) , cov(2,1) , cov(2,2) , cov(2,3) , cov(2,4) *1./(1_MeV) , 0
320 , cov(3,0) , cov(3,1) , cov(3,2) , cov(3,3) , cov(3,4) *1./(1_MeV) , 0
321 , 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
322 , 0. , 0. , 0. , 0., 0., 1.;
324 allTracks.emplace_back(trk.get(),Acts::BoundTrackParameters(perigeeSurface, actsParams, covMat, Acts::ParticleHypothesis::pion()));
327 std::vector<Acts::InputTrack> allTrackPtrs;
328 allTrackPtrs.reserve(allTracks.size());
330 for(
const auto& trk : allTracks){
331 allTrackPtrs.emplace_back(&trk);
334 Acts::VertexingOptions vertexingOptions( geoContext, magFieldContext );
337 beamSpotConstraintVtx.setPosition(Acts::Vector3::Zero());
339 looseConstraintCovariance.setIdentity();
340 looseConstraintCovariance = looseConstraintCovariance * 1e+8;
341 beamSpotConstraintVtx.setCovariance(looseConstraintCovariance);
345 vertexingOptions.constraint = beamSpotConstraintVtx;
349 auto findResult =
m_vertexFinder->find(allTrackPtrs, vertexingOptions, finderState);
351 if(!findResult.ok()){
353 theVertexContainer->
push_back(dummyxAODVertex);
354 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
357 return std::make_pair(theVertexContainer, theVertexAuxContainer);
360 std::vector<Acts::Vertex> allVertices = *findResult;
362 std::vector<VertexAndSignalComp> vtxList;
365 vtxList.reserve(allVertices.size());
367 for(
const auto& vtx : allVertices){
369 if(vtx.covariance()(0,0)<0||vtx.covariance()(1,1)<0||vtx.covariance()(2,2)<0)
372 xAODVtx->makePrivateStore();
375 xAODVtx->
setFitQuality(vtx.fitQuality().first, vtx.fitQuality().second);
377 const auto& tracks = vtx.tracks();
378 std::vector<Trk::VxTrackAtVertex>* trkAtVtxVec = &(xAODVtx->
vxTrackAtVertex());
379 for(
const auto& trk : tracks){
389 const TrackWrapper* originalParams = trk.originalParams.template as<TrackWrapper>();
397 trkAtVtxVec->push_back(trkAtVtx);
408 VertexAndSignalComp vertexAndSig(xAODVtx, sigComp);
409 auto it = std::lower_bound( vtxList.begin(), vtxList.end(), vertexAndSig );
410 vtxList.insert( it, vertexAndSig );
413 for(
unsigned int i = 0; i < vtxList.size(); i++){
414 auto vtx = vtxList[i].first;
426 theVertexContainer->
push_back(dummyxAODVertex);
428 if(!vtxList.empty()){
436 dummyxAODVertex->
setPosition(beamSpotHandle->beamVtx().position());
441 return std::make_pair(theVertexContainer, theVertexAuxContainer);