Repository to host common ntuples developed and maintained by the CMS muon DPGs. Works with CMSSW 12. For crab submission use crab-dev
You may want to use a specific CMSSW version (from now on referred as CMSSW_XXXX) and global tag based on the data you are about to Ntuplize:
- For P5 data check Global Tags for Conditions Data
- For MC data check the production parameters
cmsrel CMSSW_XXXX
cd CMSSW_XXXX/src/
cmsenv
git clone [email protected]:gmilella12/MuonDPGNTuples.git MuDPGAnalysis/MuonDPGNtuples
scram b -j 5
- MC and MWGR Data use different globalTag and CMSSW Release. Edit config file accordingly!
cd MuDPGAnalysis/MuonDPGNtuples/test/
cmsRun muDpgNtuples_cfg.py isMC=False nEvents=-1 inputFolder=/eos/cms//store/express/Commissioning2021/ExpressCosmics/FEVT/Express-v1/000/341/112/00000/
the current commit, provided with these options, will analyze:
- The files in the folder
inputFolder
- It will assume it is NOT a MC datasample, so will NOT fill the SimHit branches
- Will analyze all the events in the file (nEvents = -1)
Change the settings above based on your intended use
-
You have to authenticate yourself by mean of the grid certificate ( check the Twiki )
-
Edit the file
./CRAB_SUB/crabConfig.py
specifying the Job input paramters (i.e. nEvents, isMC), the input dataset, where to store the output files -
Execute
crab submit -c ./CRAB_SUB/crabConfig.py
-
Enjoy the rest of the day
These ntuples are intended to consist mostly of flat collection of std::vectors<>
, with the exception for few TClonesArrays
which handle "vectors of vectors".
The class steering ntuple production is called MuNtupleProducer
. It runs a list of helper classes, called fillers inheriting from MuNtupleBaseFiller
.
Each filler must include the initialize()
, clear()
and fill()
functions, which are called within the MuNtupleProducer
beginJob()
and analyze()
functions to perform the ntuple filling logic.
Many fillers of the same type may exist, for example in the DT slice-test the same data format for phase-1 and phase-2 digis is used, implying that the same filler helper class can be reused to reduce code duplication. Different flavours of a filler are configured using labels and tags. A label specifies the initial part of the name of the branches that a filler writes into the output TTree
, for example dtDigi_time
versus ph2DtDigi_time
. A tag is used to configure the specific behaviour of a given filler, for example phase-1 and phase-2 digis from the DT slice-test are produced with different InputTags
, hence, in the DT digi filler case, the tag will specify what input collection should be used.
The fillers included in the ntuple are defined in the MuNtupleProducer
constructor with as in the following:
[...]
m_fillers.push_back(std::make_unique<MuNtupleDTDigiFiller>(consumesCollector(), m_config, m_tree, "dtDigi", MuNtupleDTDigiFiller::Tag::PH1));
m_fillers.push_back(std::make_unique<MuNtupleDTDigiFiller>(consumesCollector(), m_config, m_tree, "ph2DtDigi", MuNtupleDTDigiFiller::Tag::PH2));
[...]
dtDigi
or ph2DtDigi
are labels , and MuNtupleDTDigiFiller::Tag::PH1
or MuNtupleDTDigiFiller::Tag::PH1
are tags of the same filler base class.
A configuration helper class, called MuNtupleConfig
also exists.
It deals with: (i) the list of InputTags
used by all fillers, (ii) geometry, calibration and other EventSetup
quantities.
The configuration of the ntuple producer is available under python/muNtupleProducer_cfi.py
.
- Create one (or more) filler(s), which inherit from
src/MuNtupleBaseFiller.{h,cc}
under thesrc/
dircetory; - Add all relevant
InputTag
andEventSetup
quantities intosrc/MuNtupleConfig.{h,cc}
; - Include your filler into the
m_fillers
vector of theplugins/MuNtupleProducer.{h,cc}
steering class; - Include all the needed configuration parameters in `python/muNtupleProducer_cfi.py;
- Adjust
Buildfile.xml
as needed; - Compile, run
cmsRun test/muDpgNtuples_cfg.py
and check that the ntuple includes your new quantities.
NOTEs:
- a filler .h file is the best place where to document the quantities that are filled (e.g. mention units, ranges, etc), look
src/ MuNtupleDTDigiFiller.h
as an example; - the
MuNtupleBaseFiller
class includes placeholders for default values in the ntuple (e.g.DEFAULT_INT_VAL
), please use those (and not "magic" numbers) when filling with default values is needed; - the
MuNtupleBaseFiller
class includes aconditionalGet()
function that provides a default dump in case a collection is missing in the input file, please use it.
A complete example showing how to include phase-1 and phase-2 DT digis is available here.
muNtupleProducer (TDirectory)
MuDPGTree (TTree)
event_runNumber/I (TBranch)
event_lumiBlock/I (TBranch)
event_eventNumber/L (TBranch)
event_bunchCrossing/I (TBranch)
event_orbitNumber/I (TBranch)
event_1stLast_L1A/I (TBranch)
event_2ndLast_L1A/I (TBranch)
event_3rdLast_L1A/I (TBranch)
event_4thLast_L1A/I (TBranch)
gemDigi_nDigis/i (TBranch)
gemDigi_station (TBranchElement)
gemDigi_region (TBranchElement)
gemDigi_roll (TBranchElement)
gemDigi_bx (TBranchElement)
gemDigi_strip (TBranchElement)
gemDigi_pad (TBranchElement)
gemDigi_g_r (TBranchElement)
gemDigi_g_phi (TBranchElement)
gemDigig_eta (TBranchElement)
gemDigi_g_x (TBranchElement)
gemDigi_g_y (TBranchElement)
gemDigi_g_z (TBranchElement)
gemRecHit_nRecHits/i (TBranch)
gemRecHit_cluster_size (TBranchElement)
gemRecHit_firstClusterStrip (TBranchElement)
gemRecHit_bx (TBranchElement)
gemRecHit_region (TBranchElement)
gemRecHit_chamber (TBranchElement)
gemRecHit_layer (TBranchElement)
gemRecHit_etaPartition (TBranchElement)
gemRecHit_loc_r (TBranchElement)
gemRecHit_loc_phi (TBranchElement)
gemRecHit_loc_x (TBranchElement)
gemRecHit_loc_y (TBranchElement)
gemRecHit_loc_z (TBranchElement)
gemRecHit_loc_errX (TBranchElement)
gemRecHit_loc_errY (TBranchElement)
gemRecHit_g_r (TBranchElement)
gemRecHit_g_phi (TBranchElement)
gemRecHit_g_x (TBranchElement)
gemRecHit_g_y (TBranchElement)
gemRecHit_g_z (TBranchElement)
gemSegment_nSegments/i (TBranch)
gemSegment_region (TBranchElement)
gemSegment_ring (TBranchElement)
gemSegment_station (TBranchElement)
gemSegment_posLoc_x (TBranchElement)
gemSegment_posLoc_y (TBranchElement)
gemSegment_posLoc_z (TBranchElement)
gemSegment_dirLoc_x (TBranchElement)
gemSegment_dirLoc_y (TBranchElement)
gemSegment_dirLoc_z (TBranchElement)
gemSegment_posGlb_x (TBranchElement)
gemSegment_posGlb_y (TBranchElement)
gemSegment_posGlb_z (TBranchElement)
gemSegment_time (TBranchElement)
gemSegment_time_err (TBranchElement)
gemSegment_chi2 (TBranchElement)
gemSegment_posGlb_phi (TBranchElement)
gemSegment_posGlb_eta (TBranchElement)
gemSegment_dirGlb_phi (TBranchElement)
gemSegment_dirGlb_eta (TBranchElement)
mu_nMuons/i (TBranch)
mu_pt (TBranchElement)
mu_phi (TBranchElement)
mu_eta (TBranchElement)
mu_charge (TBranchElement)
mu_isGlobal (TBranchElement)
mu_isStandalone (TBranchElement)
mu_isTracker (TBranchElement)
mu_isGEM (TBranchElement)
mu_isCSC (TBranchElement)
mu_isME11 (TBranchElement)
mu_isLoose (TBranchElement)
mu_isMedium (TBranchElement)
mu_isTight (TBranchElement)
mu_propagated_isME11 (TBranchElement)
mu_propagated_TrackNormChi2 (TBranchElement)
mu_propagated_numberOfValidPixelHits (TBranchElement)
mu_propagated_innerTracker_ValidFraction (TBranchElement)
mu_propagated_numberOfValidTrackerHits (TBranchElement)
mu_path_length/F (TBranch)
mu_isinsideout (TBranchElement)
mu_isincoming (TBranchElement)
mu_propagated_region (TBranchElement)
mu_propagated_layer (TBranchElement)
mu_propagated_chamber (TBranchElement)
mu_propagated_etaP (TBranchElement)
mu_propagated_pt (TBranchElement)
mu_propagated_phi (TBranchElement)
mu_propagated_eta (TBranchElement)
mu_propagated_charge (TBranchElement)
mu_propagatedLoc_x (TBranchElement)
mu_propagatedLoc_y (TBranchElement)
mu_propagatedLoc_z (TBranchElement)
mu_propagatedLoc_r (TBranchElement)
mu_propagated_isGEM (TBranchElement)
mu_propagatedLoc_phi (TBranchElement)
mu_propagatedLoc_errX (TBranchElement)
mu_propagatedLoc_errY (TBranchElement)
mu_propagatedLoc_dirX (TBranchElement)
mu_propagatedLoc_dirY (TBranchElement)
mu_propagatedLoc_dirZ (TBranchElement)
mu_propagatedGlb_x (TBranchElement)
mu_propagatedGlb_y (TBranchElement)
mu_propagatedGlb_z (TBranchElement)
mu_propagatedGlb_r (TBranchElement)
mu_propagatedGlb_phi (TBranchElement)
mu_propagatedGlb_errX (TBranchElement)
mu_propagatedGlb_errY (TBranchElement)
mu_propagatedGlb_errR (TBranchElement)
mu_propagatedGlb_errPhi (TBranchElement)
mu_propagated_EtaPartition_centerX (TBranchElement)
mu_propagated_EtaPartition_centerY (TBranchElement)
mu_propagated_EtaPartition_rMax (TBranchElement)
mu_propagated_EtaPartition_rMin (TBranchElement)
mu_propagated_EtaPartition_phiMax (TBranchElement)
mu_propagated_EtaPartition_phiMin (TBranchElement)
mu_propagated_nME1hits (TBranchElement)
mu_propagated_nME2hits (TBranchElement)
mu_propagated_nME3hits (TBranchElement)
mu_propagated_nME4hits (TBranchElement)
mu_propagated_Innermost_x (TBranchElement)
mu_propagated_Innermost_y (TBranchElement)
mu_propagated_Innermost_z (TBranchElement)
mu_propagated_Outermost_x (TBranchElement)
mu_propagated_Outermost_y (TBranchElement)
mu_propagated_Outermost_z (TBranchElement)