CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Attributes
PointSeededTrackingRegionsProducer Class Reference

#include <PointSeededTrackingRegionsProducer.h>

Inheritance diagram for PointSeededTrackingRegionsProducer:
TrackingRegionProducer

Public Types

enum  Mode { BEAM_SPOT_FIXED, BEAM_SPOT_SIGMA, VERTICES_FIXED, VERTICES_SIGMA }
 

Public Member Functions

 PointSeededTrackingRegionsProducer (const edm::ParameterSet &conf, edm::ConsumesCollector &&iC)
 
virtual std::vector< std::unique_ptr< TrackingRegion > > regions (const edm::Event &e, const edm::EventSetup &es) const override
 
virtual ~PointSeededTrackingRegionsProducer ()
 
- Public Member Functions inherited from TrackingRegionProducer
virtual ~TrackingRegionProducer ()
 

Private Attributes

double eta_input
 
float m_deltaEta
 
float m_deltaPhi
 
int m_maxNRegions
 
int m_maxNVertices
 
Mode m_mode
 
float m_nSigmaZBeamSpot
 
float m_nSigmaZVertex
 
float m_originRadius
 
bool m_precise
 
float m_ptMin
 
bool m_searchOpt
 
RectangularEtaPhiTrackingRegion::UseMeasurementTracker m_whereToUseMeasurementTracker
 
float m_zErrorBeamSpot
 
float m_zErrorVetex
 
double phi_input
 
edm::EDGetTokenT< reco::BeamSpottoken_beamSpot
 
edm::EDGetTokenT< MeasurementTrackerEventtoken_measurementTracker
 
edm::EDGetTokenT< reco::VertexCollectiontoken_vertex
 

Detailed Description

class PointSeededTrackingRegionsProducer

eta-phi TrackingRegions producer in directions defined by Point-based objects of interest from the "input" parameters.

Four operational modes are supported ("mode" parameter):

BeamSpotFixed: origin is defined by the beam spot z-half-length is defined by a fixed zErrorBeamSpot parameter BeamSpotSigma: origin is defined by the beam spot z-half-length is defined by nSigmaZBeamSpot * beamSpot.sigmaZ VerticesFixed: origins are defined by vertices from VertexCollection (use maximum MaxNVertices of them) z-half-length is defined by a fixed zErrorVetex parameter VerticesSigma: origins are defined by vertices from VertexCollection (use maximum MaxNVertices of them) z-half-length is defined by nSigmaZVertex * vetex.zError

If, while using one of the "Vertices" modes, there's no vertices in an event, we fall back into either BeamSpotSigma or BeamSpotFixed mode, depending on the positiveness of nSigmaZBeamSpot.

Definition at line 46 of file PointSeededTrackingRegionsProducer.h.

Member Enumeration Documentation

Constructor & Destructor Documentation

PointSeededTrackingRegionsProducer::PointSeededTrackingRegionsProducer ( const edm::ParameterSet conf,
edm::ConsumesCollector &&  iC 
)
inlineexplicit

Definition at line 52 of file PointSeededTrackingRegionsProducer.h.

References BEAM_SPOT_FIXED, BEAM_SPOT_SIGMA, eta_input, edm::ParameterSet::exists(), edm::ParameterSet::getParameter(), RectangularEtaPhiTrackingRegion::kNever, m_deltaEta, m_deltaPhi, m_maxNRegions, m_maxNVertices, m_mode, m_nSigmaZBeamSpot, m_nSigmaZVertex, m_originRadius, m_precise, m_ptMin, m_searchOpt, m_whereToUseMeasurementTracker, m_zErrorBeamSpot, m_zErrorVetex, phi_input, AlCaHLTBitMon_QueryRunRegistry::string, RectangularEtaPhiTrackingRegion::stringToUseMeasurementTracker(), token_beamSpot, token_measurementTracker, token_vertex, VERTICES_FIXED, and VERTICES_SIGMA.

54  {
55  edm::ParameterSet regPSet = conf.getParameter<edm::ParameterSet>("RegionPSet");
56 
57  // operation mode
58  std::string modeString = regPSet.getParameter<std::string>("mode");
59  if (modeString == "BeamSpotFixed") m_mode = BEAM_SPOT_FIXED;
60  else if (modeString == "BeamSpotSigma") m_mode = BEAM_SPOT_SIGMA;
61  else if (modeString == "VerticesFixed") m_mode = VERTICES_FIXED;
62  else if (modeString == "VerticesSigma") m_mode = VERTICES_SIGMA;
63  else edm::LogError ("PointSeededTrackingRegionsProducer")<<"Unknown mode string: "<<modeString;
64 
65  // basic inputs
66  edm::ParameterSet point_input = regPSet.getParameter<edm::ParameterSet>("point_input");
67  eta_input = point_input.getParameter<double>("eta");
68  phi_input = point_input.getParameter<double>("phi");
69  m_maxNRegions = regPSet.getParameter<int>("maxNRegions");
71  m_maxNVertices = 1;
73  {
74  token_vertex = iC.consumes<reco::VertexCollection>(regPSet.getParameter<edm::InputTag>("vertexCollection"));
75  m_maxNVertices = regPSet.getParameter<int>("maxNVertices");
76  }
77 
78  // RectangularEtaPhiTrackingRegion parameters:
79  m_ptMin = regPSet.getParameter<double>("ptMin");
80  m_originRadius = regPSet.getParameter<double>("originRadius");
81  m_zErrorBeamSpot = regPSet.getParameter<double>("zErrorBeamSpot");
82  m_deltaEta = regPSet.getParameter<double>("deltaEta");
83  m_deltaPhi = regPSet.getParameter<double>("deltaPhi");
84  m_precise = regPSet.getParameter<bool>("precise");
86  if(m_whereToUseMeasurementTracker != RectangularEtaPhiTrackingRegion::UseMeasurementTracker::kNever) {
88  }
89  m_searchOpt = false;
90  if (regPSet.exists("searchOpt")) m_searchOpt = regPSet.getParameter<bool>("searchOpt");
91 
92  // mode-dependent z-halflength of tracking regions
93  if (m_mode == VERTICES_SIGMA) m_nSigmaZVertex = regPSet.getParameter<double>("nSigmaZVertex");
94  if (m_mode == VERTICES_FIXED) m_zErrorVetex = regPSet.getParameter<double>("zErrorVetex");
95  m_nSigmaZBeamSpot = -1.;
96  if (m_mode == BEAM_SPOT_SIGMA)
97  {
98  m_nSigmaZBeamSpot = regPSet.getParameter<double>("nSigmaZBeamSpot");
99  if (m_nSigmaZBeamSpot < 0.)
100  edm::LogError ("PointSeededTrackingRegionsProducer")<<"nSigmaZBeamSpot must be positive for BeamSpotSigma mode!";
101  }
102  }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
T getParameter(std::string const &) const
edm::EDGetTokenT< reco::BeamSpot > token_beamSpot
bool exists(std::string const &parameterName) const
checks if a parameter exists
std::vector< Vertex > VertexCollection
collection of Vertex objects
Definition: VertexFwd.h:9
static UseMeasurementTracker stringToUseMeasurementTracker(const std::string &name)
edm::EDGetTokenT< MeasurementTrackerEvent > token_measurementTracker
RectangularEtaPhiTrackingRegion::UseMeasurementTracker m_whereToUseMeasurementTracker
edm::EDGetTokenT< reco::VertexCollection > token_vertex
virtual PointSeededTrackingRegionsProducer::~PointSeededTrackingRegionsProducer ( )
inlinevirtual

Definition at line 104 of file PointSeededTrackingRegionsProducer.h.

104 {}

Member Function Documentation

virtual std::vector<std::unique_ptr<TrackingRegion> > PointSeededTrackingRegionsProducer::regions ( const edm::Event e,
const edm::EventSetup es 
) const
inlineoverridevirtual

Implements TrackingRegionProducer.

Definition at line 107 of file PointSeededTrackingRegionsProducer.h.

References BEAM_SPOT_FIXED, BEAM_SPOT_SIGMA, eta_input, ev, plotBeamSpotDB::first, edm::Event::getByToken(), i, edm::EDGetTokenT< T >::isUninitialized(), edm::HandleBase::isValid(), j, m_deltaEta, m_deltaPhi, m_maxNRegions, m_maxNVertices, m_mode, m_nSigmaZBeamSpot, m_nSigmaZVertex, m_originRadius, m_precise, m_ptMin, m_searchOpt, m_whereToUseMeasurementTracker, m_zErrorBeamSpot, m_zErrorVetex, MeasurementTrackerEventProducer_cfi::measurementTracker, phi_input, edm::Handle< T >::product(), mps_fire::result, edm::second(), reco::BeamSpot::sigmaZ(), theta(), token_beamSpot, token_measurementTracker, token_vertex, primaryVertexAssociation_cfi::vertices, VERTICES_FIXED, VERTICES_SIGMA, x, reco::BeamSpot::x0(), y, reco::BeamSpot::y0(), z, reco::BeamSpot::z0(), and reco::BeamSpot::z0Error().

108  {
109  std::vector<std::unique_ptr<TrackingRegion> > result;
110 
111  // always need the beam spot (as a fall back strategy for vertex modes)
113  e.getByToken( token_beamSpot, bs );
114  if( !bs.isValid() ) return result;
115 
116  // this is a default origin for all modes
117  GlobalPoint default_origin( bs->x0(), bs->y0(), bs->z0() );
118 
119  // vector of origin & halfLength pairs:
120  std::vector< std::pair< GlobalPoint, float > > origins;
121 
122  // fill the origins and halfLengths depending on the mode
124  origins.push_back( std::make_pair( default_origin,
126  ));
127  } else if (m_mode == VERTICES_FIXED || m_mode == VERTICES_SIGMA) {
129  e.getByToken( token_vertex, vertices );
130  int n_vert = 0;
131  for (reco::VertexCollection::const_iterator iv = vertices->begin(), ev = vertices->end();
132  iv != ev && n_vert < m_maxNVertices; ++iv) {
133  if ( iv->isFake() || !iv->isValid() ) continue;
134 
135  origins.push_back( std::make_pair( GlobalPoint( iv->x(), iv->y(), iv->z() ),
136  (m_mode == VERTICES_FIXED) ? m_zErrorVetex : m_nSigmaZVertex*iv->zError()
137  ));
138  ++n_vert;
139  }
140  // no-vertex fall-back case:
141  if ( origins.empty() ) {
142  origins.push_back( std::make_pair( default_origin,
144  ));
145  }
146  }
147 
152  measurementTracker = hmte.product();
153  }
154 
155  // create tracking regions (maximum MaxNRegions of them) in directions of the
156  // points of interest
157  size_t n_points = 1;
158  int n_regions = 0;
159  for(size_t i = 0; i < n_points && n_regions < m_maxNRegions; ++i ) {
160 
161  double x = TMath::Cos(phi_input);
162  double y = TMath::Sin(phi_input);
163  double theta = 2*TMath::ATan(TMath::Exp(-eta_input));
164  double z = (x*x+y*y)/TMath::Tan(theta);
165 
166  GlobalVector direction( x,y,z );
167 
168  for (size_t j=0; j<origins.size() && n_regions < m_maxNRegions; ++j) {
169 
170  result.push_back( std::make_unique<RectangularEtaPhiTrackingRegion>(
171  direction, // GlobalVector
172  origins[j].first, // GlobalPoint
173  m_ptMin,
175  origins[j].second,
176  m_deltaEta,
177  m_deltaPhi,
179  m_precise,
180  measurementTracker,
182  ));
183  ++n_regions;
184  }
185  }
186  //std::cout<<"n_seeded_regions = "<<n_regions<<std::endl;
187  edm::LogInfo ("PointSeededTrackingRegionsProducer") << "produced "<<n_regions<<" regions";
188 
189  return result;
190  }
double z0() const
z coordinate
Definition: BeamSpot.h:68
int i
Definition: DBlmapReader.cc:9
edm::EDGetTokenT< reco::BeamSpot > token_beamSpot
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:457
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
Geom::Theta< T > theta() const
bool ev
edm::EDGetTokenT< MeasurementTrackerEvent > token_measurementTracker
RectangularEtaPhiTrackingRegion::UseMeasurementTracker m_whereToUseMeasurementTracker
U second(std::pair< T, U > const &p)
int j
Definition: DBlmapReader.cc:9
edm::EDGetTokenT< reco::VertexCollection > token_vertex
bool isValid() const
Definition: HandleBase.h:75
double z0Error() const
error on z
Definition: BeamSpot.h:94
T const * product() const
Definition: Handle.h:81
double sigmaZ() const
sigma z
Definition: BeamSpot.h:80
double y0() const
y coordinate
Definition: BeamSpot.h:66
bool isUninitialized() const
Definition: EDGetToken.h:73
double x0() const
x coordinate
Definition: BeamSpot.h:64

Member Data Documentation

double PointSeededTrackingRegionsProducer::eta_input
private
float PointSeededTrackingRegionsProducer::m_deltaEta
private
float PointSeededTrackingRegionsProducer::m_deltaPhi
private
int PointSeededTrackingRegionsProducer::m_maxNRegions
private
int PointSeededTrackingRegionsProducer::m_maxNVertices
private
Mode PointSeededTrackingRegionsProducer::m_mode
private
float PointSeededTrackingRegionsProducer::m_nSigmaZBeamSpot
private
float PointSeededTrackingRegionsProducer::m_nSigmaZVertex
private
float PointSeededTrackingRegionsProducer::m_originRadius
private
bool PointSeededTrackingRegionsProducer::m_precise
private
float PointSeededTrackingRegionsProducer::m_ptMin
private
bool PointSeededTrackingRegionsProducer::m_searchOpt
private
RectangularEtaPhiTrackingRegion::UseMeasurementTracker PointSeededTrackingRegionsProducer::m_whereToUseMeasurementTracker
private
float PointSeededTrackingRegionsProducer::m_zErrorBeamSpot
private
float PointSeededTrackingRegionsProducer::m_zErrorVetex
private
double PointSeededTrackingRegionsProducer::phi_input
private
edm::EDGetTokenT<reco::BeamSpot> PointSeededTrackingRegionsProducer::token_beamSpot
private
edm::EDGetTokenT<MeasurementTrackerEvent> PointSeededTrackingRegionsProducer::token_measurementTracker
private
edm::EDGetTokenT<reco::VertexCollection> PointSeededTrackingRegionsProducer::token_vertex
private