CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
MuonReSeeder Class Reference
Inheritance diagram for MuonReSeeder:
edm::EDProducer edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 MuonReSeeder (const edm::ParameterSet &iConfig)
 
virtual void produce (edm::Event &iEvent, const edm::EventSetup &iSetup) override
 
virtual ~MuonReSeeder ()
 
- Public Member Functions inherited from edm::EDProducer
 EDProducer ()
 
virtual ~EDProducer ()
 
- Public Member Functions inherited from edm::ProducerBase
 ProducerBase ()
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription
const &)> 
registrationCallback () const
 used by the fwk to register list of products More...
 
virtual ~ProducerBase ()
 
- Public Member Functions inherited from edm::EDConsumerBase
 EDConsumerBase ()
 
ProductHolderIndex indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndex > &) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Private Attributes

bool debug_
 Dump deug information. More...
 
bool insideOut_
 Do inside-out. More...
 
int layersToKeep_
 How many hits to keep from the muon trajectory. More...
 
TrackTransformer refitter_
 Track Transformer. More...
 
StringCutObjectSelector
< reco::Muon
selector_
 Muon selection. More...
 
edm::InputTag src_
 Labels for input collections. More...
 

Additional Inherited Members

- Public Types inherited from edm::EDProducer
typedef EDProducer ModuleType
 
typedef WorkerT< EDProducerWorkerType
 
- Public Types inherited from edm::ProducerBase
typedef
ProductRegistryHelper::TypeLabelList 
TypeLabelList
 
- Static Public Member Functions inherited from edm::EDProducer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- Protected Member Functions inherited from edm::EDProducer
CurrentProcessingContext const * currentContext () const
 
- Protected Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 

Detailed Description

Definition at line 33 of file MuonReSeeder.cc.

Constructor & Destructor Documentation

MuonReSeeder::MuonReSeeder ( const edm::ParameterSet iConfig)
explicit

Definition at line 61 of file MuonReSeeder.cc.

61  :
62  src_(iConfig.getParameter<edm::InputTag>("src")),
63  selector_(iConfig.existsAs<std::string>("cut") ? iConfig.getParameter<std::string>("cut") : "", true),
64  layersToKeep_(iConfig.getParameter<int32_t>("layersToKeep")),
65  insideOut_(iConfig.getParameter<bool>("insideOut")),
66  debug_(iConfig.getUntrackedParameter<bool>("debug",false)),
67  refitter_(iConfig)
68 {
69  produces<std::vector<TrajectorySeed> >();
70 }
T getParameter(std::string const &) const
T getUntrackedParameter(std::string const &, T const &) const
bool existsAs(std::string const &parameterName, bool trackiness=true) const
checks if a parameter exists as a given type
Definition: ParameterSet.h:187
TrackTransformer refitter_
Track Transformer.
Definition: MuonReSeeder.cc:57
StringCutObjectSelector< reco::Muon > selector_
Muon selection.
Definition: MuonReSeeder.cc:45
edm::InputTag src_
Labels for input collections.
Definition: MuonReSeeder.cc:42
bool debug_
Dump deug information.
Definition: MuonReSeeder.cc:54
int layersToKeep_
How many hits to keep from the muon trajectory.
Definition: MuonReSeeder.cc:48
bool insideOut_
Do inside-out.
Definition: MuonReSeeder.cc:51
virtual MuonReSeeder::~MuonReSeeder ( )
inlinevirtual

Definition at line 36 of file MuonReSeeder.cc.

36 { }

Member Function Documentation

void MuonReSeeder::produce ( edm::Event iEvent,
const edm::EventSetup iSetup 
)
overridevirtual

Implements edm::EDProducer.

Definition at line 73 of file MuonReSeeder.cc.

References abs, alongMomentum, gather_cfg::cout, debug_, end, reco::LeafCandidate::eta(), edm::OwnVector< T, P >::front(), TrackingRecHit::geographicalId(), edm::EventSetup::get(), edm::Event::getByLabel(), TrajectoryStateOnSurface::globalPosition(), i, insideOut_, edm::Ref< C, T, F >::isNull(), TrackingRecHit::isValid(), TrajectoryStateOnSurface::isValid(), layersToKeep_, RPCpg::mu, oppositeToMomentum, dbtoconf::out, PV3DBase< T, PVType, FrameType >::perp(), trajectoryStateTransform::persistentState(), reco::LeafCandidate::phi(), reco::LeafCandidate::pt(), edm::OwnVector< T, P >::push_back(), edm::Event::put(), DetId::rawId(), TrajectoryMeasurement::recHit(), refitter_, selector_, TrackTransformer::setServices(), alcazmumu_cfi::src, src_, relval_parameters_module::step, DetId::subdetId(), reco::Muon::track(), TrackTransformer::transform(), TrajectoryMeasurement::updatedState(), and PV3DBase< T, PVType, FrameType >::z().

73  {
74  using namespace edm;
75  using namespace std;
76 
77  refitter_.setServices(iSetup);
78 
80  iEvent.getByLabel(src_, src);
81 
82  //Retrieve tracker topology from geometry
84  iSetup.get<IdealGeometryRecord>().get(tTopo);
85 
86  auto_ptr<vector<TrajectorySeed> > out(new vector<TrajectorySeed>());
87  unsigned int nsrc = src->size();
88  out->reserve(nsrc);
89 
90  for (View<reco::Muon>::const_iterator it = src->begin(), ed = src->end(); it != ed; ++it) {
91  const reco::Muon &mu = *it;
92  if (mu.track().isNull() || !selector_(mu)) continue;
93  std::vector<Trajectory> traj = refitter_.transform(*mu.track());
94  if (traj.size() != 1) continue;
96  const std::vector<TrajectoryMeasurement> & tms = traj.front().measurements();
98  bool fromInside = (insideOut_ == (traj.front().direction() == alongMomentum));
99  if (debug_) {
100  std::cout << "Considering muon of pt " << mu.pt() << ", eta = " << mu.eta() << ", phi = " << mu.phi() << std::endl;
101  std::cout << "Trajectory is " << (traj.front().direction() == alongMomentum ? "along" : "opposite") << " to momentum, so will start from " << (fromInside ? "inside" : "outside") << std::endl;
102  }
103  const TrajectoryMeasurement & tin = (fromInside ? tms.front() : tms.back());
104  const TrajectoryMeasurement & tou = (fromInside ? tms.front() : tms.back());
105  if (debug_) {
106  std::cout << "IN state: subdetector = " << tin.recHit()->geographicalId().subdetId() << std::endl;
107  std::cout << " global pos Rho " << tin.updatedState().globalPosition().perp() << ", Z " << tin.updatedState().globalPosition().z() << std::endl;
108  std::cout << "OU state: subdetector = " << tou.recHit()->geographicalId().subdetId() << std::endl;
109  std::cout << " global pos Rho " << tou.updatedState().globalPosition().perp() << ", Z " << tou.updatedState().globalPosition().z() << std::endl;
110  }
111  int lastSubdet = 0, lastLayer = -1;
112  for (int i = (fromInside ? 0 : tms.size()-1),
113  end = (fromInside ? tms.size() : -1),
114  step = (fromInside ? +1 : -1),
115  taken = 0; (end-i)*step > 0; i += step) {
116  const TrackingRecHit *lastHit = hit;
117  hit = tms[i].recHit()->hit();
118  if (debug_) std::cout << " considering hit " << i << ": rechit on " << (hit ? hit->geographicalId().rawId() : -1) << std::endl;
119  if (!hit) continue;
120  int subdet = hit->geographicalId().subdetId();
121  int lay = tTopo->layer(hit->geographicalId());
122  if (subdet != lastSubdet || lay != lastLayer) {
123  // I'm on a new layer
124  if (lastHit != 0 && taken == layersToKeep_) {
125  // I've had enough layers, I can stop here
126  hit = lastHit;
127  break;
128  }
129  lastSubdet = subdet; lastLayer = lay;
130  taken++;
131  }
132  seedHits.push_back(*hit);
133  tsos = tms[i].updatedState().isValid() ? tms[i].updatedState() :
134  (abs(i-end) < abs(i) ? tms[i].forwardPredictedState() : tms[i].backwardPredictedState());
135  if (debug_) {
136  std::cout << " hit : subdetector = " << tms[i].recHit()->geographicalId().subdetId() << std::endl;
137  if (hit->isValid()) {
138  std::cout << " global pos Rho " << tms[i].recHit()->globalPosition().perp() << ", Z " << tms[i].recHit()->globalPosition().z() << std::endl;
139  } else {
140  std::cout << " invalid tracking rec hit, so no global position" << std::endl;
141  }
142  std::cout << " state: global pos Rho " << tsos.globalPosition().perp() << ", Z " << tsos.globalPosition().z() << std::endl;
143  }
144  }
145  if (!tsos.isValid()) continue;
147  TrajectorySeed seed(PTraj,std::move(seedHits),insideOut_ ? alongMomentum : oppositeToMomentum);
148  out->push_back(seed);
149  }
150 
151  iEvent.put(out);
152 }
int i
Definition: DBlmapReader.cc:9
boost::indirect_iterator< typename seq_t::const_iterator > const_iterator
Definition: View.h:81
TrackTransformer refitter_
Track Transformer.
Definition: MuonReSeeder.cc:57
T perp() const
Definition: PV3DBase.h:72
ConstRecHitPointer const & recHit() const
StringCutObjectSelector< reco::Muon > selector_
Muon selection.
Definition: MuonReSeeder.cc:45
PTrajectoryStateOnDet persistentState(const TrajectoryStateOnSurface &ts, unsigned int detid)
edm::InputTag src_
Labels for input collections.
Definition: MuonReSeeder.cc:42
virtual TrackRef track() const
reference to a Track
Definition: Muon.h:50
#define abs(x)
Definition: mlp_lapack.h:159
GlobalPoint globalPosition() const
bool debug_
Dump deug information.
Definition: MuonReSeeder.cc:54
int layersToKeep_
How many hits to keep from the muon trajectory.
Definition: MuonReSeeder.cc:48
uint32_t rawId() const
get the raw id
Definition: DetId.h:45
void push_back(D *&d)
Definition: OwnVector.h:273
virtual float phi() const GCC11_FINAL
momentum azimuthal angle
bool isNull() const
Checks for null.
Definition: Ref.h:247
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:94
T z() const
Definition: PV3DBase.h:64
const int mu
Definition: Constants.h:23
#define end
Definition: vmac.h:38
bool insideOut_
Do inside-out.
Definition: MuonReSeeder.cc:51
virtual void setServices(const edm::EventSetup &)
set the services needed by the TrackTransformer
int subdetId() const
get the contents of the subdetector field (not cast into any detector&#39;s numbering enum) ...
Definition: DetId.h:39
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:361
virtual float eta() const GCC11_FINAL
momentum pseudorapidity
tuple out
Definition: dbtoconf.py:99
const T & get() const
Definition: EventSetup.h:55
bool isValid() const
virtual std::vector< Trajectory > transform(const reco::Track &) const
Convert a reco::Track into Trajectory.
tuple cout
Definition: gather_cfg.py:121
TrajectoryStateOnSurface const & updatedState() const
DetId geographicalId() const
virtual float pt() const GCC11_FINAL
transverse momentum
reference front()
Definition: OwnVector.h:348

Member Data Documentation

bool MuonReSeeder::debug_
private

Dump deug information.

Definition at line 54 of file MuonReSeeder.cc.

Referenced by produce().

bool MuonReSeeder::insideOut_
private

Do inside-out.

Definition at line 51 of file MuonReSeeder.cc.

Referenced by produce().

int MuonReSeeder::layersToKeep_
private

How many hits to keep from the muon trajectory.

Definition at line 48 of file MuonReSeeder.cc.

Referenced by produce().

TrackTransformer MuonReSeeder::refitter_
private

Track Transformer.

Definition at line 57 of file MuonReSeeder.cc.

Referenced by produce().

StringCutObjectSelector<reco::Muon> MuonReSeeder::selector_
private

Muon selection.

Definition at line 45 of file MuonReSeeder.cc.

Referenced by produce().

edm::InputTag MuonReSeeder::src_
private

Labels for input collections.

Definition at line 42 of file MuonReSeeder.cc.

Referenced by produce().