CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ConversionTrackRefFix.cc
Go to the documentation of this file.
2 
6 
7 using namespace std;
8 using namespace reco;
9 using namespace edm;
10 
12  InputTag conversionTracksTag = iConfig.getParameter<InputTag>("src");
13  InputTag newTracksTag = iConfig.getParameter<InputTag>("newTrackCollection");
14 
15  produces<ConversionTrackCollection>();
16 
17  conversionTracksToken = consumes<ConversionTrackCollection>(conversionTracksTag);
18  newTracksToken = consumes<TrackCollection>(newTracksTag);
19 }
20 
22 
24  Handle<ConversionTrackCollection> conversionTracks;
25  iEvent.getByToken(conversionTracksToken, conversionTracks);
26 
27  Handle<TrackCollection> newTracks;
28  iEvent.getByToken(newTracksToken, newTracks);
29 
30  unique_ptr<ConversionTrackCollection> output(new ConversionTrackCollection);
31 
32  for (const ConversionTrack& conversion : *(conversionTracks.product())) {
33  size_t trackIndex = conversion.trackRef().key();
34  output->push_back(ConversionTrack(TrackBaseRef(TrackRef(newTracks, trackIndex))));
35  output->back().setTrajRef(conversion.trajRef());
36  output->back().setIsTrackerOnly(conversion.isTrackerOnly());
37  output->back().setIsArbitratedEcalSeeded(conversion.isArbitratedEcalSeeded());
38  output->back().setIsArbitratedMerged(conversion.isArbitratedMerged());
39  output->back().setIsArbitratedMergedEcalGeneral(conversion.isArbitratedMergedEcalGeneral());
40  }
41 
42  iEvent.put(std::move(output));
43 }
44 
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:133
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:539
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
std::vector< ConversionTrack > ConversionTrackCollection
collection of ConversionTracks
int iEvent
Definition: GenABIO.cc:224
edm::RefToBase< reco::Track > TrackBaseRef
persistent reference to a Track, using views
Definition: TrackFwd.h:35
def move
Definition: eostools.py:511
void produce(edm::Event &, const edm::EventSetup &) override
void conversion(EventAux const &from, EventAuxiliary &to)
Definition: EventAux.cc:9
T const * product() const
Definition: Handle.h:70
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
Definition: TrackFwd.h:20
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
ConversionTrackRefFix(const edm::ParameterSet &)