CMS 3D CMS Logo

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

#include <PFNuclearProducer.h>

Inheritance diagram for PFNuclearProducer:
edm::stream::EDProducer<>

Public Member Functions

 PFNuclearProducer (const edm::ParameterSet &)
 Constructor. More...
 
 ~PFNuclearProducer () override
 Destructor. More...
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginProcessBlocks () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndProcessBlocks () const final
 
bool hasAbilityToProduceInEndRuns () const final
 

Private Member Functions

void beginRun (const edm::Run &, const edm::EventSetup &) override
 
void endRun (const edm::Run &, const edm::EventSetup &) override
 
void produce (edm::Event &, const edm::EventSetup &) override
 Produce the PFRecTrack collection. More...
 

Private Attributes

double likelihoodCut_
 
std::vector< edm::EDGetTokenT< reco::NuclearInteractionCollection > > nuclearContainers_
 
PFTrackTransformerpfTransformer_
 PFTrackTransformer. More...
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDProducer<>
typedef CacheContexts< T... > CacheTypes
 
typedef CacheTypes::GlobalCache GlobalCache
 
typedef AbilityChecker< T... > HasAbility
 
typedef CacheTypes::LuminosityBlockCache LuminosityBlockCache
 
typedef LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCacheLuminosityBlockContext
 
typedef CacheTypes::LuminosityBlockSummaryCache LuminosityBlockSummaryCache
 
typedef CacheTypes::RunCache RunCache
 
typedef RunContextT< RunCache, GlobalCacheRunContext
 
typedef CacheTypes::RunSummaryCache RunSummaryCache
 

Detailed Description

Definition at line 12 of file PFNuclearProducer.h.

Constructor & Destructor Documentation

◆ PFNuclearProducer()

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

Constructor.

Definition at line 10 of file PFNuclearProducer.cc.

10  : pfTransformer_(nullptr) {
11  produces<reco::PFRecTrackCollection>();
12  produces<reco::PFNuclearInteractionCollection>();
13 
14  std::vector<edm::InputTag> tags = iConfig.getParameter<vector<InputTag> >("nuclearColList");
15 
16  for (unsigned int i = 0; i < tags.size(); ++i)
17  nuclearContainers_.push_back(consumes<reco::NuclearInteractionCollection>(tags[i]));
18 
19  likelihoodCut_ = iConfig.getParameter<double>("likelihoodCut");
20 }

References edm::ParameterSet::getParameter(), mps_fire::i, likelihoodCut_, nuclearContainers_, and triggerMatcherToHLTDebug_cfi::tags.

◆ ~PFNuclearProducer()

PFNuclearProducer::~PFNuclearProducer ( )
override

Destructor.

Definition at line 22 of file PFNuclearProducer.cc.

22 { delete pfTransformer_; }

References pfTransformer_.

Member Function Documentation

◆ beginRun()

void PFNuclearProducer::beginRun ( const edm::Run run,
const edm::EventSetup iSetup 
)
overrideprivate

◆ endRun()

void PFNuclearProducer::endRun ( const edm::Run run,
const edm::EventSetup iSetup 
)
overrideprivate

Definition at line 76 of file PFNuclearProducer.cc.

76  {
77  delete pfTransformer_;
78  pfTransformer_ = nullptr;
79 }

References pfTransformer_.

◆ produce()

void PFNuclearProducer::produce ( edm::Event iEvent,
const edm::EventSetup iSetup 
)
overrideprivate

Produce the PFRecTrack collection.

Definition at line 24 of file PFNuclearProducer.cc.

24  {
25  typedef reco::NuclearInteraction::trackRef_iterator trackRef_iterator;
26 
27  //create the empty collections
28  auto pfNuclearColl = std::make_unique<reco::PFNuclearInteractionCollection>();
29  auto pfNuclearRecTrackColl = std::make_unique<reco::PFRecTrackCollection>();
30 
31  reco::PFRecTrackRefProd pfTrackRefProd = iEvent.getRefBeforePut<reco::PFRecTrackCollection>();
32  int hid = 0;
33 
34  // loop on the nuclear interaction collections
35  for (unsigned int istr = 0; istr < nuclearContainers_.size(); istr++) {
37  iEvent.getByToken(nuclearContainers_[istr], nuclCollH);
38  const reco::NuclearInteractionCollection& nuclColl = *(nuclCollH.product());
39 
40  // loop on all NuclearInteraction
41  for (unsigned int icoll = 0; icoll < nuclColl.size(); icoll++) {
42  if (nuclColl[icoll].likelihood() < likelihoodCut_)
43  continue;
44 
45  reco::PFRecTrackRefVector pfRecTkcoll;
46 
47  // convert the secondary tracks
48  for (trackRef_iterator it = nuclColl[icoll].secondaryTracks_begin(); it != nuclColl[icoll].secondaryTracks_end();
49  it++) {
50  reco::PFRecTrack pftrack(
51  (*it)->charge(), reco::PFRecTrack::KF, it->key(), (reco::TrackRef)((*it).castTo<reco::TrackRef>()));
52  Trajectory FakeTraj;
53  bool valid = pfTransformer_->addPoints(pftrack, **it, FakeTraj);
54  if (valid) {
55  pfRecTkcoll.push_back(reco::PFRecTrackRef(pfTrackRefProd, hid++));
56  pfNuclearRecTrackColl->push_back(pftrack);
57  }
58  }
59  reco::NuclearInteractionRef niRef(nuclCollH, icoll);
60  pfNuclearColl->push_back(reco::PFNuclearInteraction(niRef, pfRecTkcoll));
61  }
62  }
63  iEvent.put(std::move(pfNuclearRecTrackColl));
64  iEvent.put(std::move(pfNuclearColl));
65 }

References PFTrackTransformer::addPoints(), icoll, iEvent, reco::PFRecTrack::KF, likelihood(), likelihoodCut_, eostools::move(), nuclearContainers_, pfTransformer_, edm::Handle< T >::product(), edm::RefVector< C, T, F >::push_back(), and RunInfoPI::valid.

Member Data Documentation

◆ likelihoodCut_

double PFNuclearProducer::likelihoodCut_
private

Definition at line 29 of file PFNuclearProducer.h.

Referenced by PFNuclearProducer(), and produce().

◆ nuclearContainers_

std::vector<edm::EDGetTokenT<reco::NuclearInteractionCollection> > PFNuclearProducer::nuclearContainers_
private

Definition at line 30 of file PFNuclearProducer.h.

Referenced by PFNuclearProducer(), and produce().

◆ pfTransformer_

PFTrackTransformer* PFNuclearProducer::pfTransformer_
private

PFTrackTransformer.

Definition at line 28 of file PFNuclearProducer.h.

Referenced by beginRun(), endRun(), produce(), and ~PFNuclearProducer().

edm::RefProd
Definition: EDProductfwd.h:25
mps_fire.i
i
Definition: mps_fire.py:428
edm::Handle::product
T const * product() const
Definition: Handle.h:70
reco::PFNuclearInteraction
Definition: PFNuclearInteraction.h:15
reco::PFRecTrack::KF
Definition: PFRecTrack.h:25
edm::RefVector< PFRecTrackCollection >
HLT_FULL_cff.magneticField
magneticField
Definition: HLT_FULL_cff.py:348
edm::Handle
Definition: AssociativeIterator.h:50
likelihood
void likelihood(int &npar, double *grad, double &fval, double *xval, int flag)
Definition: MuScleFitUtils.cc:1784
edm::Ref< TrackCollection >
IdealMagneticFieldRecord
Definition: IdealMagneticFieldRecord.h:11
PFTrackTransformer::addPoints
bool addPoints(reco::PFRecTrack &pftrack, const reco::Track &track, const Trajectory &traj, bool msgwarning=true) const
Add points to a PFTrack. return false if a TSOS is invalid.
Definition: PFTrackTransformer.cc:40
edm::EventSetup::get
T get() const
Definition: EventSetup.h:80
reco::NuclearInteractionCollection
std::vector< NuclearInteraction > NuclearInteractionCollection
collection of NuclearInteractions
Definition: NuclearInteractionFwd.h:8
edm::ESHandle< MagneticField >
PFNuclearProducer::nuclearContainers_
std::vector< edm::EDGetTokenT< reco::NuclearInteractionCollection > > nuclearContainers_
Definition: PFNuclearProducer.h:30
Point3DBase< float, GlobalTag >
reco::TrackRef
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
Definition: TrackFwd.h:20
reco::NuclearInteraction::trackRef_iterator
reco::Vertex::trackRef_iterator trackRef_iterator
Definition: NuclearInteraction.h:15
math::XYZVector
XYZVectorD XYZVector
spatial vector with cartesian internal representation
Definition: Vector3D.h:31
iEvent
int iEvent
Definition: GenABIO.cc:224
get
#define get
edm::RefVector::push_back
void push_back(value_type const &ref)
Add a Ref<C, T> to the RefVector.
Definition: RefVector.h:67
PFNuclearProducer::likelihoodCut_
double likelihoodCut_
Definition: PFNuclearProducer.h:29
eostools.move
def move(src, dest)
Definition: eostools.py:511
reco::PFRecTrack
reconstructed track used as an input to particle flow
Definition: PFRecTrack.h:20
Trajectory
Definition: Trajectory.h:38
PFTrackTransformer::OnlyProp
void OnlyProp()
Definition: PFTrackTransformer.h:54
icoll
int icoll
Definition: AMPTWrapper.h:146
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
triggerMatcherToHLTDebug_cfi.tags
tags
Definition: triggerMatcherToHLTDebug_cfi.py:9
reco::PFRecTrackCollection
std::vector< PFRecTrack > PFRecTrackCollection
collection of PFRecTrack objects
Definition: PFRecTrackFwd.h:9
RunInfoPI::valid
Definition: RunInfoPayloadInspectoHelper.h:16
PFTrackTransformer
Definition: PFTrackTransformer.h:34
PFNuclearProducer::pfTransformer_
PFTrackTransformer * pfTransformer_
PFTrackTransformer.
Definition: PFNuclearProducer.h:28