From 18f4b3525a33cc182a249ee09321972ba4069b08 Mon Sep 17 00:00:00 2001 From: Matti Kortelainen Date: Wed, 21 Nov 2018 11:04:48 -0600 Subject: [PATCH 1/5] Add check for the key ProductID as well in ClusterTPAssociation --- SimTracker/TrackerHitAssociation/BuildFile.xml | 1 + .../interface/ClusterTPAssociation.h | 10 ++++++++++ .../src/ClusterTPAssociation.cc | 15 +++++++++++++++ 3 files changed, 26 insertions(+) diff --git a/SimTracker/TrackerHitAssociation/BuildFile.xml b/SimTracker/TrackerHitAssociation/BuildFile.xml index b63d354eec25b..48e91f5cbee07 100644 --- a/SimTracker/TrackerHitAssociation/BuildFile.xml +++ b/SimTracker/TrackerHitAssociation/BuildFile.xml @@ -1,5 +1,6 @@ + diff --git a/SimTracker/TrackerHitAssociation/interface/ClusterTPAssociation.h b/SimTracker/TrackerHitAssociation/interface/ClusterTPAssociation.h index 41bfb42bead5e..e4fcde1f03f70 100644 --- a/SimTracker/TrackerHitAssociation/interface/ClusterTPAssociation.h +++ b/SimTracker/TrackerHitAssociation/interface/ClusterTPAssociation.h @@ -4,6 +4,7 @@ #include "DataFormats/Provenance/interface/ProductID.h" #include "DataFormats/Common/interface/HandleBase.h" #include "DataFormats/TrackerRecHit2D/interface/OmniClusterRef.h" +#include "FWCore/Utilities/interface/VecArray.h" #include "SimDataFormats/TrackingAnalysis/interface/TrackingParticle.h" #include "SimDataFormats/TrackingAnalysis/interface/TrackingParticleFwd.h" @@ -32,6 +33,10 @@ class ClusterTPAssociation { void emplace_back(const OmniClusterRef& cluster, const TrackingParticleRef& tp) { checkMappedProductID(tp); + auto foundKeyID = std::find(std::begin(keyProductIDs_), std::end(keyProductIDs_), cluster.id()); + if(foundKeyID == std::end(keyProductIDs_)) { + keyProductIDs_.emplace_back(cluster.id()); + } map_.emplace_back(cluster, tp); } void sortAndUnique() { @@ -54,11 +59,15 @@ class ClusterTPAssociation { const_iterator cend() const { return map_.end(); } range equal_range(const OmniClusterRef& key) const { + checkKeyProductID(key); return std::equal_range(map_.begin(), map_.end(), value_type(key, TrackingParticleRef()), compare); } const map_type& map() const { return map_; } + void checkKeyProductID(const OmniClusterRef& key) const { checkKeyProductID(key.id()); } + void checkKeyProductID(const edm::ProductID& id) const; + void checkMappedProductID(const edm::HandleBase& mappedHandle) const { checkMappedProductID(mappedHandle.id()); } void checkMappedProductID(const TrackingParticleRef& tp) const { checkMappedProductID(tp.id()); } void checkMappedProductID(const edm::ProductID& id) const; @@ -75,6 +84,7 @@ class ClusterTPAssociation { } map_type map_; + edm::VecArray keyProductIDs_; edm::ProductID mappedProductId_; }; diff --git a/SimTracker/TrackerHitAssociation/src/ClusterTPAssociation.cc b/SimTracker/TrackerHitAssociation/src/ClusterTPAssociation.cc index fd66cb18c2cc4..9ee06286e9dd7 100644 --- a/SimTracker/TrackerHitAssociation/src/ClusterTPAssociation.cc +++ b/SimTracker/TrackerHitAssociation/src/ClusterTPAssociation.cc @@ -1,6 +1,21 @@ #include "SimTracker/TrackerHitAssociation/interface/ClusterTPAssociation.h" #include "FWCore/Utilities/interface/Exception.h" +void ClusterTPAssociation::checkKeyProductID(const edm::ProductID& id) const { + if(std::find(std::begin(keyProductIDs_), std::end(keyProductIDs_), id) == std::end(keyProductIDs_)) { + auto e = cms::Exception("InvalidReference"); + e << "ClusterTPAssociation has OmniClusterRefs with ProductIDs "; + for(size_t i=0; i Date: Wed, 21 Nov 2018 11:35:32 -0600 Subject: [PATCH 2/5] Add dictionary for VecArray --- DataFormats/Provenance/src/classes.h | 1 + DataFormats/Provenance/src/classes_def.xml | 1 + 2 files changed, 2 insertions(+) diff --git a/DataFormats/Provenance/src/classes.h b/DataFormats/Provenance/src/classes.h index e87580521fddc..6630f6f044166 100644 --- a/DataFormats/Provenance/src/classes.h +++ b/DataFormats/Provenance/src/classes.h @@ -35,6 +35,7 @@ #include "DataFormats/Provenance/interface/ESRecordAuxiliary.h" #include "DataFormats/Provenance/interface/ViewTypeChecker.h" #include "FWCore/Utilities/interface/typedefs.h" +#include "FWCore/Utilities/interface/VecArray.h" #include #include #include diff --git a/DataFormats/Provenance/src/classes_def.xml b/DataFormats/Provenance/src/classes_def.xml index 500022fac5cb1..2a521b82b6b2c 100644 --- a/DataFormats/Provenance/src/classes_def.xml +++ b/DataFormats/Provenance/src/classes_def.xml @@ -61,6 +61,7 @@ + From c573124bd15a997cf47ee834428d1439fb0e239b Mon Sep 17 00:00:00 2001 From: Matti Kortelainen Date: Wed, 21 Nov 2018 13:13:34 -0600 Subject: [PATCH 3/5] Migrate TrackValidation_cff to tasks --- .../RecoTrack/python/TrackValidation_cff.py | 190 +++++++++--------- .../RecoVertex/python/VertexValidation_cff.py | 8 +- 2 files changed, 99 insertions(+), 99 deletions(-) diff --git a/Validation/RecoTrack/python/TrackValidation_cff.py b/Validation/RecoTrack/python/TrackValidation_cff.py index d08aeb27072ba..cc0a69c28b9ef 100644 --- a/Validation/RecoTrack/python/TrackValidation_cff.py +++ b/Validation/RecoTrack/python/TrackValidation_cff.py @@ -61,7 +61,7 @@ def _algoToSelector(algo): def _addSelectorsByAlgo(algos, modDict): names = [] - seq = cms.Sequence() + task = cms.Task() for algo in algos: if algo == "generalTracks": continue @@ -72,10 +72,10 @@ def _addSelectorsByAlgo(algos, modDict): else: mod = modDict[modName] names.append(modName) - seq += mod - return (names, seq) + task.add(mod) + return (names, task) def _addSelectorsByHp(algos, modDict): - seq = cms.Sequence() + task = cms.Task() names = [] for algo in algos: modName = _algoToSelector(algo) @@ -89,10 +89,10 @@ def _addSelectorsByHp(algos, modDict): else: mod = modDict[modNameHp] names.append(modNameHp) - seq += mod - return (names, seq) + task.add(mod) + return (names, task) def _addSelectorsBySrc(modules, midfix, src, modDict): - seq = cms.Sequence() + task = cms.Task() names = [] for modName in modules: modNameNew = modName.replace("cutsRecoTracks", "cutsRecoTracks"+midfix) @@ -102,10 +102,10 @@ def _addSelectorsBySrc(modules, midfix, src, modDict): else: mod = modDict[modNameNew] names.append(modNameNew) - seq += mod - return (names, seq) + task.add(mod) + return (names, task) def _addSelectorsByOriginalAlgoMask(modules, midfix, algoParam,modDict): - seq = cms.Sequence() + task = cms.Task() names = [] for modName in modules: if modName[-2:] == "Hp": @@ -120,11 +120,11 @@ def _addSelectorsByOriginalAlgoMask(modules, midfix, algoParam,modDict): else: mod = modDict[modNameNew] names.append(modNameNew) - seq += mod - return (names, seq) + task.add(mod) + return (names, task) def _addSeedToTrackProducers(seedProducers,modDict): names = [] - seq = cms.Sequence() + task = cms.Task() for seed in seedProducers: modName = "seedTracks"+seed if modName not in modDict: @@ -133,8 +133,8 @@ def _addSeedToTrackProducers(seedProducers,modDict): else: mod = modDict[modName] names.append(modName) - seq += mod - return (names, seq) + task.add(mod) + return (names, task) _relevantEras = _cfg.allEras() _relevantErasAndFastSim = _relevantEras + [("fastSim", "_fastSim", fastSim)] @@ -146,9 +146,9 @@ def _translateArgs(args, postfix, modDict): else: ret.append(modDict[arg+postfix]) return ret -def _sequenceForEachEra(function, args, names, sequence, modDict, plainArgs=[], modifySequence=None, includeFastSim=False): - if sequence[0] != "_": - raise Exception("Sequence name is expected to begin with _") +def _taskForEachEra(function, args, names, task, modDict, plainArgs=[], modifyTask=None, includeFastSim=False): + if task[0] != "_": + raise Exception("Task name is expected to begin with _") _eras = _relevantErasAndFastSim if includeFastSim else _relevantEras for eraName, postfix, _era in _eras: @@ -156,23 +156,23 @@ def _sequenceForEachEra(function, args, names, sequence, modDict, plainArgs=[], _args.extend(plainArgs) ret = function(*_args, modDict=modDict) if len(ret) != 2: - raise Exception("_sequenceForEachEra is expected to return 2 values, but function returned %d" % len(ret)) + raise Exception("_taskForEachEra is expected to return 2 values, but function returned %d" % len(ret)) modDict[names+postfix] = ret[0] - modDict[sequence+postfix] = ret[1] + modDict[task+postfix] = ret[1] - # The sequence of the first era will be the default one - defaultSequenceName = sequence+_eras[0][0] - defaultSequence = modDict[defaultSequenceName] - modDict[defaultSequenceName[1:]] = defaultSequence # remove leading underscore + # The task of the first era will be the default one + defaultTaskName = task+_eras[0][0] + defaultTask = modDict[defaultTaskName] + modDict[defaultTaskName[1:]] = defaultTask # remove leading underscore - # Optionally modify sequences before applying the era - if modifySequence is not None: + # Optionally modify task before applying the era + if modifyTask is not None: for eraName, postfix, _era in _eras: - modifySequence(modDict[sequence+postfix]) + modifyTask(modDict[task+postfix]) # Apply eras for _eraName, _postfix, _era in _eras[1:]: - _era.toReplaceWith(defaultSequence, modDict[sequence+_postfix]) + _era.toReplaceWith(defaultTask, modDict[task+_postfix]) def _setForEra(module, eraName, era, **kwargs): if eraName == "": for key, value in six.iteritems(kwargs): @@ -242,10 +242,10 @@ def _getMVASelectors(postfix): locals()["_mvaSelectors"+_postfix] = _getMVASelectors(_postfix) # Validation iterative steps -_sequenceForEachEra(_addSelectorsByAlgo, args=["_algos"], names="_selectorsByAlgo", sequence="_tracksValidationSelectorsByAlgo", modDict=globals()) +_taskForEachEra(_addSelectorsByAlgo, args=["_algos"], names="_selectorsByAlgo", task="_tracksValidationSelectorsByAlgo", modDict=globals()) # high purity -_sequenceForEachEra(_addSelectorsByHp, args=["_algos"], names="_selectorsByAlgoHp", sequence="_tracksValidationSelectorsByAlgoHp", modDict=globals()) +_taskForEachEra(_addSelectorsByHp, args=["_algos"], names="_selectorsByAlgoHp", task="_tracksValidationSelectorsByAlgoHp", modDict=globals()) # by originalAlgo for _eraName, _postfix, _era in _relevantEras: @@ -254,9 +254,9 @@ def _getMVASelectors(postfix): locals()["_selectorsByAlgoAndHpNoGenTk"+_postfix] = [n for n in locals()["_selectorsByAlgoAndHp"+_postfix] if n not in ["generalTracks", "cutsRecoTracksHp"]] # For ByOriginalAlgo locals()["_selectorsByAlgoAndHpNoGenTkDupMerge"+_postfix] = [n for n in locals()["_selectorsByAlgoAndHpNoGenTk"+_postfix] if n not in ["cutsRecoTracksDuplicateMerge", "cutsRecoTracksDuplicateMergeHp"]] -_sequenceForEachEra(_addSelectorsByOriginalAlgoMask, modDict = globals(), +_taskForEachEra(_addSelectorsByOriginalAlgoMask, modDict = globals(), args = ["_selectorsByAlgoAndHpNoGenTkDupMerge"], plainArgs = ["ByOriginalAlgo", "originalAlgorithm"], - names = "_selectorsByOriginalAlgo", sequence = "_tracksValidationSelectorsByOriginalAlgo") + names = "_selectorsByOriginalAlgo", task = "_tracksValidationSelectorsByOriginalAlgo") for _eraName, _postfix, _era in _relevantEras: @@ -296,11 +296,11 @@ def _getMVASelectors(postfix): # select tracks with pT > 0.9 GeV (for upgrade fake rates) generalTracksPt09 = cutsRecoTracks_cfi.cutsRecoTracks.clone(ptMin=0.9) # and then the selectors -_sequenceForEachEra(_addSelectorsBySrc, modDict=globals(), - args=[["_generalTracksHp"]], - plainArgs=["Pt09", "generalTracksPt09"], - names="_selectorsPt09", sequence="_tracksValidationSelectorsPt09", - modifySequence=lambda seq:seq.insert(0, generalTracksPt09)) +_taskForEachEra(_addSelectorsBySrc, modDict=globals(), + args=[["_generalTracksHp"]], + plainArgs=["Pt09", "generalTracksPt09"], + names="_selectorsPt09", task="_tracksValidationSelectorsPt09", + modifyTask=lambda task:task.add(generalTracksPt09)) # select tracks from the PV from CommonTools.RecoAlgos.TrackWithVertexRefSelector_cfi import trackWithVertexRefSelector as _trackWithVertexRefSelector @@ -317,20 +317,20 @@ def _getMVASelectors(postfix): rhoVtx = 1e10, # intentionally no dxy cut ) # and then the selectors -_sequenceForEachEra(_addSelectorsBySrc, modDict=globals(), +_taskForEachEra(_addSelectorsBySrc, modDict=globals(), args=[["_generalTracksHp"]], plainArgs=["FromPV", "generalTracksFromPV"], - names="_selectorsFromPV", sequence="_tracksValidationSelectorsFromPV", - modifySequence=lambda seq: seq.insert(0, generalTracksFromPV)) + names="_selectorsFromPV", task="_tracksValidationSelectorsFromPV", + modifyTask=lambda task: task.add(generalTracksFromPV)) # select tracks with pT > 0.9 GeV from the PV generalTracksFromPVPt09 = generalTracksPt09.clone(src="generalTracksFromPV") # and then the selectors -_sequenceForEachEra(_addSelectorsBySrc, modDict=globals(), - args=[["_generalTracksHp"]], - plainArgs=["FromPVPt09", "generalTracksFromPVPt09"], - names="_selectorsFromPVPt09", sequence="_tracksValidationSelectorsFromPVPt09", - modifySequence=lambda seq: seq.insert(0, generalTracksFromPVPt09)) +_taskForEachEra(_addSelectorsBySrc, modDict=globals(), + args=[["_generalTracksHp"]], + plainArgs=["FromPVPt09", "generalTracksFromPVPt09"], + names="_selectorsFromPVPt09", task="_tracksValidationSelectorsFromPVPt09", + modifyTask=lambda task: task.add(generalTracksFromPVPt09)) ## Select conversion TrackingParticles, and define the corresponding associator trackingParticlesConversion = _trackingParticleConversionRefSelector.clone() @@ -534,31 +534,31 @@ def _uniqueFirstLayers(layerList): # the track selectors -tracksValidationSelectors = cms.Sequence( - tracksValidationSelectorsByAlgo + - tracksValidationSelectorsByAlgoHp + - tracksValidationSelectorsByOriginalAlgo + - cutsRecoTracksBtvLike + - ak4JetTracksAssociatorExplicitAll + +tracksValidationSelectors = cms.Task( + tracksValidationSelectorsByAlgo, + tracksValidationSelectorsByAlgoHp, + tracksValidationSelectorsByOriginalAlgo, + cutsRecoTracksBtvLike, + ak4JetTracksAssociatorExplicitAll, cutsRecoTracksAK4PFJets ) -tracksValidationTruth = cms.Sequence( - tpClusterProducer + - quickTrackAssociatorByHits + - trackingParticleRecoTrackAsssociation + - VertexAssociatorByPositionAndTracks + +tracksValidationTruth = cms.Task( + tpClusterProducer, + quickTrackAssociatorByHits, + trackingParticleRecoTrackAsssociation, + VertexAssociatorByPositionAndTracks, trackingParticleNumberOfLayersProducer ) fastSim.toModify(tracksValidationTruth, lambda x: x.remove(tpClusterProducer)) -tracksPreValidation = cms.Sequence( - tracksValidationSelectors + - tracksValidationSelectorsPt09 + - tracksValidationSelectorsFromPV + - tracksValidationSelectorsFromPVPt09 + - tracksValidationTruth + - cms.ignore(trackingParticlesSignal) + - cms.ignore(trackingParticlesElectron) + +tracksPreValidation = cms.Task( + tracksValidationSelectors, + tracksValidationSelectorsPt09, + tracksValidationSelectorsFromPV, + tracksValidationSelectorsFromPVPt09, + tracksValidationTruth, + trackingParticlesSignal, + trackingParticlesElectron, trackingParticlesConversion ) fastSim.toReplaceWith(tracksPreValidation, tracksPreValidation.copyAndExclude([ @@ -567,7 +567,6 @@ def _uniqueFirstLayers(layerList): ])) tracksValidation = cms.Sequence( - tracksPreValidation + trackValidator + trackValidatorTPPtLess09 + trackValidatorFromPV + @@ -575,7 +574,8 @@ def _uniqueFirstLayers(layerList): trackValidatorAllTPEffic + trackValidatorBuilding + trackValidatorConversion + - trackValidatorGsfTracks + trackValidatorGsfTracks, + tracksPreValidation ) fastSim.toReplaceWith(tracksValidation, tracksValidation.copyAndExclude([ trackValidatorConversion, @@ -585,27 +585,27 @@ def _uniqueFirstLayers(layerList): ### Then define stuff for standalone mode (i.e. MTV with RECO+DIGI input) # Select by originalAlgo and algoMask -_sequenceForEachEra(_addSelectorsByOriginalAlgoMask, modDict = globals(), - args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["ByAlgoMask", "algorithmMaskContains"], - names = "_selectorsByAlgoMask", sequence = "_tracksValidationSelectorsByAlgoMaskStandalone") +_taskForEachEra(_addSelectorsByOriginalAlgoMask, modDict = globals(), + args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["ByAlgoMask", "algorithmMaskContains"], + names = "_selectorsByAlgoMask", task = "_tracksValidationSelectorsByAlgoMaskStandalone") # Select pT>0.9 by iteration # Need to avoid generalTracks+HP because those are already included in the standard validator -_sequenceForEachEra(_addSelectorsBySrc, modDict = globals(), - args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["Pt09", "generalTracksPt09"], - names = "_selectorsPt09Standalone", sequence = "_tracksValidationSelectorsPt09Standalone") +_taskForEachEra(_addSelectorsBySrc, modDict = globals(), + args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["Pt09", "generalTracksPt09"], + names = "_selectorsPt09Standalone", task = "_tracksValidationSelectorsPt09Standalone") # Select fromPV by iteration # Need to avoid generalTracks+HP because those are already included in the standard validator -_sequenceForEachEra(_addSelectorsBySrc, modDict = globals(), - args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["FromPV", "generalTracksFromPV"], - names = "_selectorsFromPVStandalone", sequence = "_tracksValidationSelectorsFromPVStandalone") +_taskForEachEra(_addSelectorsBySrc, modDict = globals(), + args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["FromPV", "generalTracksFromPV"], + names = "_selectorsFromPVStandalone", task = "_tracksValidationSelectorsFromPVStandalone") # Select pt>0.9 and fromPV by iteration # Need to avoid generalTracks+HP because those are already included in the standard validator -_sequenceForEachEra(_addSelectorsBySrc, modDict = globals(), - args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["FromPVPt09", "generalTracksFromPVPt09"], - names = "_selectorsFromPVPt09Standalone", sequence = "_tracksValidationSelectorsFromPVPt09Standalone") +_taskForEachEra(_addSelectorsBySrc, modDict = globals(), + args = ["_selectorsByAlgoAndHpNoGenTk"], plainArgs = ["FromPVPt09", "generalTracksFromPVPt09"], + names = "_selectorsFromPVPt09Standalone", task = "_tracksValidationSelectorsFromPVPt09Standalone") # MTV instances trackValidatorStandalone = trackValidator.clone() @@ -632,13 +632,13 @@ def _uniqueFirstLayers(layerList): # sequences tracksPreValidationStandalone = tracksPreValidation.copy() -tracksPreValidationStandalone += trackingParticlesBHadron +tracksPreValidationStandalone.add(trackingParticlesBHadron) fastSim.toReplaceWith(tracksPreValidationStandalone, tracksPreValidation) -tracksValidationSelectorsStandalone = cms.Sequence( - tracksValidationSelectorsByAlgoMaskStandalone + - tracksValidationSelectorsPt09Standalone + - tracksValidationSelectorsFromPVStandalone + +tracksValidationSelectorsStandalone = cms.Task( + tracksValidationSelectorsByAlgoMaskStandalone, + tracksValidationSelectorsPt09Standalone, + tracksValidationSelectorsFromPVStandalone, tracksValidationSelectorsFromPVPt09Standalone ) @@ -659,16 +659,16 @@ def _uniqueFirstLayers(layerList): tracksValidationStandalone = cms.Sequence( ak4PFL1FastL2L3CorrectorChain + - tracksPreValidationStandalone + - tracksValidationSelectorsStandalone + - trackValidatorsStandalone + trackValidatorsStandalone, + tracksPreValidationStandalone, + tracksValidationSelectorsStandalone ) ### TrackingOnly mode (i.e. MTV with DIGI input + tracking-only reconstruction) # selectors tracksValidationSelectorsTrackingOnly = tracksValidationSelectors.copyAndExclude([ak4JetTracksAssociatorExplicitAll,cutsRecoTracksAK4PFJets]) # selectors using track information only (i.e. no PF) -_sequenceForEachEra(_addSeedToTrackProducers, args=["_seedProducers"], names="_seedSelectors", sequence="_tracksValidationSeedSelectorsTrackingOnly", includeFastSim=True, modDict=globals()) +_taskForEachEra(_addSeedToTrackProducers, args=["_seedProducers"], names="_seedSelectors", task="_tracksValidationSeedSelectorsTrackingOnly", includeFastSim=True, modDict=globals()) # MTV instances trackValidatorTrackingOnly = trackValidatorStandalone.clone(label = [ x for x in trackValidatorStandalone.label if x != "cutsRecoTracksAK4PFJets"] ) @@ -702,10 +702,10 @@ def _uniqueFirstLayers(layerList): tracksValidationTrackingOnly = cms.Sequence( - tracksPreValidationTrackingOnly + - tracksValidationSelectorsStandalone + - tracksValidationSeedSelectorsTrackingOnly + - trackValidatorsTrackingOnly + trackValidatorsTrackingOnly, + tracksPreValidationTrackingOnly, + tracksValidationSelectorsStandalone, + tracksValidationSeedSelectorsTrackingOnly ) @@ -741,8 +741,8 @@ def _uniqueFirstLayers(layerList): tracksValidationTruthPixelTrackingOnly.replace(trackingParticleRecoTrackAsssociation, trackingParticlePixelTrackAsssociation) tracksValidationTruthPixelTrackingOnly.replace(VertexAssociatorByPositionAndTracks, PixelVertexAssociatorByPositionAndTracks) tracksValidationPixelTrackingOnly = cms.Sequence( - tracksValidationTruthPixelTrackingOnly + - trackValidatorPixelTrackingOnly + trackValidatorPixelTrackingOnly, + tracksValidationTruthPixelTrackingOnly ) @@ -752,8 +752,8 @@ def _uniqueFirstLayers(layerList): ) tracksValidationLite = cms.Sequence( cutsRecoTracksHp + - tracksValidationTruth + - trackValidatorLite + trackValidatorLite, + tracksValidationTruth ) ## customization for timing diff --git a/Validation/RecoVertex/python/VertexValidation_cff.py b/Validation/RecoVertex/python/VertexValidation_cff.py index 3b7a1aef78ea4..91a6c35d2ddbb 100644 --- a/Validation/RecoVertex/python/VertexValidation_cff.py +++ b/Validation/RecoVertex/python/VertexValidation_cff.py @@ -10,17 +10,17 @@ from Validation.RecoTrack.TrackValidation_cff import tracksValidationTruth, tracksValidationTruthPixelTrackingOnly vertexValidationStandalone = cms.Sequence( + vertexValidation, tracksValidationTruth - * vertexValidation ) vertexValidationTrackingOnly = cms.Sequence( + v0Validator + + vertexAnalysisSequenceTrackingOnly, tracksValidationTruth - + v0Validator - + vertexAnalysisSequenceTrackingOnly ) vertexValidationPixelTrackingOnly = cms.Sequence( + vertexAnalysisSequencePixelTrackingOnly, tracksValidationTruthPixelTrackingOnly - + vertexAnalysisSequencePixelTrackingOnly ) From f76bb629c5dd816405fe3cbdbbdfa90a2b32d0fb Mon Sep 17 00:00:00 2001 From: Matti Kortelainen Date: Wed, 21 Nov 2018 11:59:41 -0600 Subject: [PATCH 4/5] Fix the validation of initialStepPreSplitting to use the correct clusters in TP matching --- .../RecoTrack/plugins/MultiTrackValidator.cc | 14 ++++++ .../RecoTrack/python/TrackValidation_cff.py | 48 ++++++++++++++----- 2 files changed, 49 insertions(+), 13 deletions(-) diff --git a/Validation/RecoTrack/plugins/MultiTrackValidator.cc b/Validation/RecoTrack/plugins/MultiTrackValidator.cc index b4e2a31714e3e..f5bdacca1851e 100644 --- a/Validation/RecoTrack/plugins/MultiTrackValidator.cc +++ b/Validation/RecoTrack/plugins/MultiTrackValidator.cc @@ -68,6 +68,11 @@ MultiTrackValidator::MultiTrackValidator(const edm::ParameterSet& pset): doMVAPlots_(pset.getUntrackedParameter("doMVAPlots")), simPVMaxZ_(pset.getUntrackedParameter("simPVMaxZ")) { + if(label.empty()) { + // Disable prefetching of everything if there are no track collections + return; + } + const edm::InputTag& label_tp_effic_tag = pset.getParameter< edm::InputTag >("label_tp_effic"); const edm::InputTag& label_tp_fake_tag = pset.getParameter< edm::InputTag >("label_tp_fake"); @@ -211,6 +216,10 @@ MultiTrackValidator::~MultiTrackValidator() {} void MultiTrackValidator::bookHistograms(DQMStore::ConcurrentBooker& ibook, edm::Run const&, edm::EventSetup const& setup, Histograms& histograms) const { + if(label.empty()) { + // Disable histogram booking if there are no track collections + return; + } const auto minColl = -0.5; const auto maxColl = label.size()-0.5; @@ -481,6 +490,11 @@ void MultiTrackValidator::trackDR(const edm::View& trackCollection, void MultiTrackValidator::dqmAnalyze(const edm::Event& event, const edm::EventSetup& setup, const Histograms& histograms) const { + if(label.empty()) { + // Disable if there are no track collections + return; + } + using namespace reco; LogDebug("TrackValidator") << "\n====================================================" << "\n" diff --git a/Validation/RecoTrack/python/TrackValidation_cff.py b/Validation/RecoTrack/python/TrackValidation_cff.py index cc0a69c28b9ef..8b3bb4cb88ab8 100644 --- a/Validation/RecoTrack/python/TrackValidation_cff.py +++ b/Validation/RecoTrack/python/TrackValidation_cff.py @@ -33,8 +33,10 @@ _trackProd = [] locals()["_algos"+_postfix] = ["generalTracks"] + _cfg.iterationAlgos(_postfix) + ["duplicateMerge"] - locals()["_seedProducers"+_postfix] = _seedProd + _cfg.seedProducers(_postfix) - locals()["_trackProducers"+_postfix] = _trackProd + _cfg.trackProducers(_postfix) + locals()["_seedProducersPreSplitting"+_postfix] = _seedProd + locals()["_trackProducersPreSplitting"+_postfix] = _trackProd + locals()["_seedProducers"+_postfix] = _cfg.seedProducers(_postfix) + locals()["_trackProducers"+_postfix] = _cfg.trackProducers(_postfix) if _eraName != "trackingPhase2PU140": locals()["_electronSeedProducers"+_postfix] = ["tripletElectronSeeds", "pixelPairElectronSeeds", "stripPairElectronSeeds"] @@ -447,6 +449,8 @@ def _getMVASelectors(postfix): _setForEra(trackValidatorAllTPEffic, _eraName, _era, label = ["generalTracks", locals()["_generalTracksHp"+_postfix]]) # Built tracks, in the standard sequence mainly for monitoring the track selection MVA +tpClusterProducerPreSplitting = tpClusterProducer.clone(pixelClusterSrc = "siPixelClustersPreSplitting") +quickTrackAssociatorByHitsPreSplitting = quickTrackAssociatorByHits.clone(cluster2TPSrc = "tpClusterProducerPreSplitting") _trackValidatorSeedingBuilding = trackValidator.clone( # common for built tracks and seeds (in trackingOnly) associators = ["quickTrackAssociatorByHits"], UseAssociators = True, @@ -459,11 +463,17 @@ def _getMVASelectors(postfix): dirName = "Tracking/TrackBuilding/", doMVAPlots = True, ) +trackValidatorBuildingPreSplitting = trackValidatorBuilding.clone( + associators = ["quickTrackAssociatorByHitsPreSplitting"], + doMVAPlots = False, + doSummaryPlots = False, +) for _eraName, _postfix, _era in _relevantErasAndFastSim: _setForEra(trackValidatorBuilding, _eraName, _era, label = locals()["_trackProducers"+_postfix]) fastSim.toModify(trackValidatorBuilding, doMVAPlots=False) for _eraName, _postfix, _era in _relevantEras: _setForEra(trackValidatorBuilding, _eraName, _era, mvaLabels = locals()["_mvaSelectors"+_postfix]) + _setForEra(trackValidatorBuildingPreSplitting, _eraName, _era, label = locals()["_trackProducersPreSplitting"+_postfix]) # For conversions @@ -544,7 +554,9 @@ def _uniqueFirstLayers(layerList): ) tracksValidationTruth = cms.Task( tpClusterProducer, + tpClusterProducerPreSplitting, quickTrackAssociatorByHits, + quickTrackAssociatorByHitsPreSplitting, trackingParticleRecoTrackAsssociation, VertexAssociatorByPositionAndTracks, trackingParticleNumberOfLayersProducer @@ -573,11 +585,13 @@ def _uniqueFirstLayers(layerList): trackValidatorFromPVAllTP + trackValidatorAllTPEffic + trackValidatorBuilding + + trackValidatorBuildingPreSplitting + trackValidatorConversion + trackValidatorGsfTracks, tracksPreValidation ) fastSim.toReplaceWith(tracksValidation, tracksValidation.copyAndExclude([ + trackValidatorBuildingPreSplitting, trackValidatorConversion, trackValidatorGsfTracks, ])) @@ -669,6 +683,8 @@ def _uniqueFirstLayers(layerList): # selectors tracksValidationSelectorsTrackingOnly = tracksValidationSelectors.copyAndExclude([ak4JetTracksAssociatorExplicitAll,cutsRecoTracksAK4PFJets]) # selectors using track information only (i.e. no PF) _taskForEachEra(_addSeedToTrackProducers, args=["_seedProducers"], names="_seedSelectors", task="_tracksValidationSeedSelectorsTrackingOnly", includeFastSim=True, modDict=globals()) +_taskForEachEra(_addSeedToTrackProducers, args=["_seedProducersPreSplitting"], names="_seedSelectorsPreSplitting", task="_tracksValidationSeedSelectorsPreSplittingTrackingOnly", modDict=globals()) +tracksValidationSeedSelectorsTrackingOnly.add(tracksValidationSeedSelectorsPreSplittingTrackingOnly) # MTV instances trackValidatorTrackingOnly = trackValidatorStandalone.clone(label = [ x for x in trackValidatorStandalone.label if x != "cutsRecoTracksAK4PFJets"] ) @@ -678,8 +694,16 @@ def _uniqueFirstLayers(layerList): label = _seedSelectors, doSeedPlots = True, ) +trackValidatorSeedingPreSplittingTrackingOnly = trackValidatorSeedingTrackingOnly.clone( + associators = ["quickTrackAssociatorByHitsPreSplitting"], + label = _seedSelectorsPreSplitting, + doSummaryPlots = False, + +) for _eraName, _postfix, _era in _relevantErasAndFastSim: _setForEra(trackValidatorSeedingTrackingOnly, _eraName, _era, label = locals()["_seedSelectors"+_postfix]) +for _eraName, _postfix, _era in _relevantEras: + _setForEra(trackValidatorSeedingPreSplittingTrackingOnly, _eraName, _era, label = locals()["_seedSelectorsPreSplitting"+_postfix]) trackValidatorConversionTrackingOnly = trackValidatorConversion.clone(label = [x for x in trackValidatorConversion.label if x not in ["ckfInOutTracksFromConversions", "ckfOutInTracksFromConversions"]]) @@ -693,12 +717,18 @@ def _uniqueFirstLayers(layerList): trackValidatorsTrackingOnly = _trackValidatorsBase.copy() trackValidatorsTrackingOnly.replace(trackValidatorStandalone, trackValidatorTrackingOnly) trackValidatorsTrackingOnly += trackValidatorSeedingTrackingOnly +trackValidatorsTrackingOnly += trackValidatorSeedingPreSplittingTrackingOnly trackValidatorsTrackingOnly += trackValidatorBuilding +trackValidatorsTrackingOnly += trackValidatorBuildingPreSplitting trackValidatorsTrackingOnly.replace(trackValidatorConversionStandalone, trackValidatorConversionTrackingOnly) trackValidatorsTrackingOnly.remove(trackValidatorGsfTracks) trackValidatorsTrackingOnly.replace(trackValidatorBHadronStandalone, trackValidatorBHadronTrackingOnly) -fastSim.toModify(trackValidatorsTrackingOnly, lambda x: x.remove(trackValidatorConversionTrackingOnly)) -fastSim.toModify(trackValidatorsTrackingOnly, lambda x: x.remove(trackValidatorBHadronTrackingOnly)) +fastSim.toReplaceWith(trackValidatorsTrackingOnly, trackValidatorsTrackingOnly.copyAndExclude([ + trackValidatorBuildingPreSplitting, + trackValidatorSeedingPreSplittingTrackingOnly, + trackValidatorConversionTrackingOnly, + trackValidatorBHadronTrackingOnly +])) tracksValidationTrackingOnly = cms.Sequence( @@ -710,15 +740,9 @@ def _uniqueFirstLayers(layerList): ### Pixel tracking only mode (placeholder for now) -tpClusterProducerPixelTrackingOnly = tpClusterProducer.clone( - pixelClusterSrc = "siPixelClustersPreSplitting" -) -quickTrackAssociatorByHitsPixelTrackingOnly = quickTrackAssociatorByHits.clone( - cluster2TPSrc = "tpClusterProducerPixelTrackingOnly" -) trackingParticlePixelTrackAsssociation = trackingParticleRecoTrackAsssociation.clone( label_tr = "pixelTracks", - associator = "quickTrackAssociatorByHitsPixelTrackingOnly", + associator = "quickTrackAssociatorByHitsPreSplitting", ) PixelVertexAssociatorByPositionAndTracks = VertexAssociatorByPositionAndTracks.clone( trackAssociation = "trackingParticlePixelTrackAsssociation" @@ -736,8 +760,6 @@ def _uniqueFirstLayers(layerList): ) tracksValidationTruthPixelTrackingOnly = tracksValidationTruth.copy() -tracksValidationTruthPixelTrackingOnly.replace(tpClusterProducer, tpClusterProducerPixelTrackingOnly) -tracksValidationTruthPixelTrackingOnly.replace(quickTrackAssociatorByHits, quickTrackAssociatorByHitsPixelTrackingOnly) tracksValidationTruthPixelTrackingOnly.replace(trackingParticleRecoTrackAsssociation, trackingParticlePixelTrackAsssociation) tracksValidationTruthPixelTrackingOnly.replace(VertexAssociatorByPositionAndTracks, PixelVertexAssociatorByPositionAndTracks) tracksValidationPixelTrackingOnly = cms.Sequence( From ec9462dd6e25371f00a5856e6a825f0b0d4186a0 Mon Sep 17 00:00:00 2001 From: Matti Kortelainen Date: Wed, 21 Nov 2018 15:53:16 -0600 Subject: [PATCH 5/5] Add fallback to plotting --- Validation/RecoTrack/python/plotting/trackingPlots.py | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Validation/RecoTrack/python/plotting/trackingPlots.py b/Validation/RecoTrack/python/plotting/trackingPlots.py index bd8235cb3371a..84079e9a62a92 100644 --- a/Validation/RecoTrack/python/plotting/trackingPlots.py +++ b/Validation/RecoTrack/python/plotting/trackingPlots.py @@ -572,6 +572,8 @@ def _trackingSubFoldersFallbackFromPV(subfolder): return subfolder.replace("trackingParticleRecoAsssociation", "trackingParticleRecoAsssociationSignal") def _trackingSubFoldersFallbackConversion(subfolder): return subfolder.replace("quickAssociatorByHits", "quickAssociatorByHitsConversion") +def _trackingSubFoldersFallbackPreSplitting(subfolder): + return subfolder.replace("quickAssociatorByHits", "quickAssociatorByHitsPreSplitting") # Additional "quality" flags than highPurity. In a separate list to # allow customization. @@ -1294,7 +1296,8 @@ def _appendTrackingPlots(lastDirName, name, algoPlots, onlyForPileup=False, only ], **limiters) common = dict(fallbackDqmSubFolders=[ _trackingSubFoldersFallbackSLHC_Phase1PU140, - _trackingSubFoldersFallbackFromPV, _trackingSubFoldersFallbackConversion]) + _trackingSubFoldersFallbackFromPV, _trackingSubFoldersFallbackConversion, + _trackingSubFoldersFallbackPreSplitting]) plotter.append(name, folders, TrackingPlotFolder(*algoPlots, **commonForTPF), **common) extendedPlots = [] if building: