Electrons¶
Introduction¶
Electrons are measured in the CMS experiment combining the information from the inner tracker and the electromagnetic calorimeter as summarized on an introductory page on Finding electrons and photons. The signals from these systems are processed with CMSSW through subsequent steps to form electron candidates which are then available in the electron collection of the data files.
Electron 4-vector and track information¶
An example of an EDAnalyzer accessing electron information is available in the ElectronAnalyzer of the Physics Object Extractor Tool (POET). The following header files needed for accessing electron information are included:
//classes to extract electron information
#include "DataFormats/EgammaCandidates/interface/GsfElectron.h"
#include "DataFormats/EgammaCandidates/interface/GsfElectronFwd.h"
#include "DataFormats/GsfTrackReco/interface/GsfTrack.h"
#include "RecoEgamma/EgammaTools/interface/ConversionTools.h"
#include "DataFormats/VertexReco/interface/Vertex.h"
#include "DataFormats/VertexReco/interface/VertexFwd.h"
In ElectronAnalyzer.cc, the electron four-vector elements are accessed as shown below.
Handle<reco::GsfElectronCollection> myelectrons;
iEvent.getByLabel(electronInput, myelectrons);
[...]
for (reco::GsfElectronCollection::const_iterator itElec=myelectrons->begin(); itElec!=myelectrons->end(); ++itElec){
  [...]
  electron_e.push_back(itElec->energy());
  electron_pt.push_back(itElec->pt());
  electron_px.push_back(itElec->px());
  electron_py.push_back(itElec->py());
  electron_pz.push_back(itElec->pz());
  electron_eta.push_back(itElec->eta());
  electron_phi.push_back(itElec->phi());
  [...]
}
Most charged physics objects are also connected to tracks from the CMS tracking detectors. The charge of the object can be queried directly:
  electron_ch.push_back(itElec->charge());
Information from tracks provides other kinematic quantities. Often, the most pertinent information about an object to access from its associated track is its impact parameter with respect to the primary interaction vertex. The access to the vertex collection is gained through the getByLabel method and the first elemement of the vertex collection gives the best estimate of the interaction point ("primary vertex" - pv):
  Handle<reco::VertexCollection> vertices;
  iEvent.getByLabel(InputTag("offlinePrimaryVertices"), vertices);
  math::XYZPoint pv(vertices->begin()->position());
The access to the track is provided through
  auto trk = itElec->gsfTrack();
for each electron in the electron loop, and the impact parameter information is obtained with
  electron_dxy.push_back(trk->dxy(pv));
  electron_dz.push_back(trk->dz(pv));
  electron_dxyError.push_back(trk->d0Error());
  electron_dzError.push_back(trk->dzError());
An example of an EDAnalyzer accessing electron information is available in the ElectronAnalyzer of the Physics Object Extractor Tool (POET). The following header files needed for accessing electron information are included:
//classes to extract electron information
#include "DataFormats/PatCandidates/interface/Electron.h"
#include "DataFormats/VertexReco/interface/VertexFwd.h"
#include "DataFormats/VertexReco/interface/Vertex.h"
In ElectronAnalyzer.cc, the electron four-vector elements are accessed from the pat::Electron collection as shown below.
Handle<pat::ElectronCollection> electrons;
iEvent.getByToken(electronToken_, electrons);
[...]
for (const pat::Electron &el : *electrons)
{
  electron_e.push_back(el.energy());
  electron_pt.push_back(el.pt());
  electron_px.push_back(el.px());
  electron_py.push_back(el.py());
  electron_pz.push_back(el.pz());
  electron_eta.push_back(el.eta());
  electron_phi.push_back(el.phi());
  [...]
}
with electronToken_ defined as a member of the ElectronAnalyzer class and its value read from the configuration file.
Most charged physics objects are also connected to tracks from the CMS tracking detectors. The charge of the object can be queried directly:
  electron_ch.push_back(el.charge());
Information from tracks provides other kinematic quantities. Often, the most pertinent information about an object to access from its associated track is its impact parameter with respect to the primary interaction vertex. The access to the vertex collection is gained through the getByToken method and the first elemement of the vertex collection gives the best estimate of the interaction point ("primary vertex" - pv):
  Handle<reco::VertexCollection> vertices;
  iEvent.getByToken(vtxToken_, vertices);
  math::XYZPoint pv(vertices->begin()->position());
again with vtxToken_ defined as a member of the ElectronAnalyzer class and its value read from the configuration file.
The access to the track is provided through member function gsfTrack, and for each electron in the electron loop, and the impact parameter information is obtained with
  electron_dxy.push_back(el.gsfTrack()->dxy(pv));
  electron_dz.push_back(el.gsfTrack()->dz(pv));
  electron_dxyError.push_back(el.gsfTrack()->d0Error());
  electron_dzError.push_back(el.gsfTrack()->dzError());
Electron identification¶
As explained in the Physics Object page, a mandatory task in the physics analysis is to identify electrons, i.e. to separate “real” objects from “fakes”. The criteria depend on the type of analysis.
The selection is based on cuts on a small number of variables. Different thresholds are used for electrons found in the ECAL barrel and the ECAL endcap. Selection variables may be categorized in three groups:
- electron ID variables (shower shape, track cluster matching etc)
- isolation variables
- conversion rejection variables.
The standard identification and isolation algorithm results can be accessed from the electron object class and the recommended working points are documented in the the public data page for electron for 2010 and 2011. The values implemented in the example code ElectronAnalyzer.cc are those recommended for 2012.
Three levels of identification criteria are defined
bool isLoose = false, isMedium = false, isTight = false;
For electrons in the electromagnetic calorimeter barrel area, they are determined as follows:
if ( abs(itElec->eta()) <= 1.479 ) {   
  if ( abs(itElec->deltaEtaSuperClusterTrackAtVtx())<.007 && 
        abs(itElec->deltaPhiSuperClusterTrackAtVtx())<.15 && 
        itElec->sigmaIetaIeta()<.01 && itElec->hadronicOverEm()<.12 && 
        abs(trk->dxy(pv))<.02 && abs(trk->dz(pv))<.2 && 
        missing_hits<=1 && passelectronveto==true &&
        abs(1/itElec->ecalEnergy()-1/(itElec->ecalEnergy()/itElec->eSuperClusterOverP()))<.05 
        && el_pfIso<.15){
    isLoose = true;
    if ( abs(itElec->deltaEtaSuperClusterTrackAtVtx())<.004 && 
          abs(itElec->deltaPhiSuperClusterTrackAtVtx())<.06 && 
          abs(trk->dz(pv))<.1 ){
      isMedium = true;
      if (abs(itElec->deltaPhiSuperClusterTrackAtVtx())<.03 && 
          missing_hits<=0 && el_pfIso<.10 ){
        isTight = true;
      }
    }
  }
}
where
- deltaEta...and- deltaPhi...indicate how the electron's trajectory varies between the track and the ECAL cluster, with smaller variations preferred for the "tightest" quality levels.
- sigmaIetaIetadescribes the variance of the ECAL cluster in psuedorapidity ("ieta" is an integer index for this angle).
- hadronicOverEmdescribes the ratio of HCAL to ECAL energy deposits, which should be small for good quality electrons.
- The impact parameters dxyanddzshould also be small for good quality electrons produced in the initial collision.
- Missing hits are gaps in the trajectory through the inner tracker (shouldn't be any!)
- The conversion veto is an algorithm that rejects electrons coming from photon conversions in the tracker, which should instead be reconstructed as part of the photon.
- The criterion using ecalEnergyandeSuperClusterOverPcompares the differences between the electron's energy and momentum measurements, which should be very similar to each other for good electrons.
- el_pfIsorepresents how much energy, relative to the electron's, within a cone around the electron comes from other particle-flow candidates. If this value is small the electron is likely "isolated" in the local region.
The isolation variable el_pfIso, based on a cone size of 0.3 around the electron, is defined with
if (itElec->passingPflowPreselection()) {
  double rho = 0;
  if(rhoHandle.isValid()) rho = *(rhoHandle.product());
  double Aeff = effectiveArea0p3cone(itElec->eta());
  auto iso03 = itElec->pfIsolationVariables();
  el_pfIso = (iso03.chargedHadronIso + std::max(0.0,iso03.neutralHadronIso + iso03.photonIso - rho*Aeff))/itElec->pt();
} 
In the endcap part of the electromagnetic calorimeter, the procedure is similar with different values.
To do
- The isolation snippet needs more explanation
- Check if the PR fixing the problem with missing hits affects the identification code snippet.
The standard identification and isolation algorithm results can be accessed from the pat electron object class. Three levels of identification criteria are defined: loose, medium, and tight. An example selection is implemented in ElectronAnalyzer.cc:
  electron_isLoose.push_back(el.electronID("cutBasedElectronID-PHYS14-PU20bx25-V2-standalone-loose"));
  electron_isMedium.push_back(el.electronID("cutBasedElectronID-PHYS14-PU20bx25-V2-standalone-medium"));
  electron_isTight.push_back(el.electronID("cutBasedElectronID-PHYS14-PU20bx25-V2-standalone-tight"));
Warning
The choice of recommended electron ID criteria for 2015 data needs to be verified. In addition to PHYS14_PU20bx25_V2 other sets, for example Spring15_25ns_V1, are available.
Isolation computed from PF Clusters, is available through the methods ecalPFClusterIso and hcalPFClusterIso:
  electron_iso.push_back(el.ecalPFClusterIso());
To do
- More information is needed for particle flow (PF) clusters
- More information is needed for the values returned by ecalPFClusterIsoand if the description in the class header still holds.