diff --git a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.cxx b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.cxx index 5fea906cee21d67b5361eb169314bafc1621a2a9..606d4d63d14120c88f7aea6291a591af3cd64d76 100644 --- a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.cxx +++ b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.cxx @@ -41,6 +41,7 @@ namespace MuonCombined { if( !m_trackExtrapolationTool.empty() ) ATH_CHECK(m_trackExtrapolationTool.retrieve()); else m_trackExtrapolationTool.disable(); ATH_CHECK(m_ambiguityProcessor.retrieve()); + ATH_CHECK( m_trackSummaryTool.retrieve() ); ATH_CHECK(m_idHelperSvc.retrieve()); ATH_CHECK(m_beamSpotKey.initialize()); return StatusCode::SUCCESS; @@ -111,7 +112,14 @@ namespace MuonCombined { //If these are not successfully extrapolated, they are too low quality to be useful //So only make candidates from un-extrapolated tracks if they are not EM-only bool skipTrack=true; - for(auto& chs : msTrack.trackSummary()->muonTrackSummary()->chamberHitSummary()){ + const Trk::MuonTrackSummary* msMuonTrackSummary=nullptr; + //If reading from an ESD, the track will not have a track summary yet + if(!msTrack.trackSummary()){ + std::unique_ptr<Trk::TrackSummary> msTrackSummary=m_trackSummaryTool->summary(msTrack, nullptr); + msMuonTrackSummary=msTrackSummary->muonTrackSummary(); + } + else msMuonTrackSummary=msTrack.trackSummary()->muonTrackSummary(); + for(auto& chs : msMuonTrackSummary->chamberHitSummary()){ if(chs.isMdt() && m_idHelperSvc->stationIndex(chs.chamberId())!=Muon::MuonStationIndex::EM){ skipTrack=false; break; diff --git a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.h b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.h index 5313474c3a7b405a227db21aee4c6ecc838373e4..883a051c4c2218612770102252bdfc615296d0e7 100644 --- a/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.h +++ b/Reconstruction/MuonIdentification/MuonCombinedBaseTools/src/MuonCandidateTool.h @@ -17,6 +17,7 @@ #include "MuonRecHelperTools/MuonEDMPrinterTool.h" #include "MuonRecToolInterfaces/IMuonTrackExtrapolationTool.h" #include "MuonIdHelpers/IMuonIdHelperSvc.h" +#include "TrkToolInterfaces/IExtendedTrackSummaryTool.h" namespace MuonCombined { @@ -38,6 +39,7 @@ namespace MuonCombined { ToolHandle<Rec::ICombinedMuonTrackBuilder> m_trackBuilder; ToolHandle<Muon::IMuonTrackExtrapolationTool> m_trackExtrapolationTool; ToolHandle<Trk::ITrackAmbiguityProcessorTool> m_ambiguityProcessor; + ToolHandle<Trk::IExtendedTrackSummaryTool> m_trackSummaryTool {this, "TrackSummaryTool", "MuonTrackSummaryTool"}; ServiceHandle<Muon::IMuonIdHelperSvc> m_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}; SG::ReadCondHandleKey<InDet::BeamSpotData> m_beamSpotKey { this, "BeamSpotKey", "BeamSpotData", "SG key for beam spot" }; diff --git a/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py b/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py index 5212352b1eb157ef66e0fde454a4f26a0c0fd4a4..a6c669de7e7e4db2e779dfb8f19d24191c4c994a 100644 --- a/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py +++ b/Reconstruction/MuonIdentification/MuonCombinedConfig/python/MuonCombinedRecToolsConfig.py @@ -256,6 +256,13 @@ def MuonCandidateToolCfg(flags, name="MuonCandidateTool",**kwargs): kwargs.setdefault("AmbiguityProcessor", ambiguityprocessor ) result.merge(acc) + from MuonConfig.MuonRecToolsConfig import MuonTrackSummaryToolCfg + acc = MuonTrackSummaryToolCfg(flags) + track_summary = acc.getPrimary() + result.merge(acc) + kwargs.setdefault("TrackSummaryTool", track_summary) + + if flags.Beam.Type=="cosmics": kwargs.setdefault("ExtrapolationStrategy", 1 ) tool = CompFactory.MuonCombined.MuonCandidateTool(name,**kwargs) diff --git a/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_mt1_build.ref b/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_mt1_build.ref index fd6407b6b3dd812953941a1a62f9fadc455d4629..c05895523842d734d919df0e820f1c6d6f4a4e39 100644 --- a/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_mt1_build.ref +++ b/Trigger/TrigValidation/TrigAnalysisTest/share/ref_RDOtoRDOTrig_mt1_build.ref @@ -389,8 +389,8 @@ TrigSignatureMoniMT INFO HLT_mu6_mu4_L12MU4 #1713 TrigSignatureMoniMT INFO -- #1713982776 Events 4 4 4 4 4 4 - - 4 TrigSignatureMoniMT INFO -- #1713982776 Features 8 8 12 18 - - TrigSignatureMoniMT INFO HLT_mu6_mu6noL1_L1MU6 #451489897 -TrigSignatureMoniMT INFO -- #451489897 Events 10 10 10 10 10 10 6 4 4 -TrigSignatureMoniMT INFO -- #451489897 Features 14 13 16 21 9 7 +TrigSignatureMoniMT INFO -- #451489897 Events 10 10 10 10 10 10 5 4 4 +TrigSignatureMoniMT INFO -- #451489897 Features 14 13 16 21 8 7 TrigSignatureMoniMT INFO HLT_mu6fast_L1MU6 #3518031697 TrigSignatureMoniMT INFO -- #3518031697 Events 10 10 10 - - - - - 10 TrigSignatureMoniMT INFO -- #3518031697 Features 14 - - - - -