CMS 3D CMS Logo

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 {
13  InputTag conversionTracksTag = iConfig.getParameter<InputTag>("src");
14  InputTag newTracksTag = iConfig.getParameter<InputTag>("newTrackCollection");
15 
16  produces<ConversionTrackCollection>();
17 
18  conversionTracksToken = consumes<ConversionTrackCollection>(conversionTracksTag);
19  newTracksToken = consumes<TrackCollection>(newTracksTag);
20 }
21 
23 
24 
25 void
27 {
28  Handle<ConversionTrackCollection> conversionTracks;
29  iEvent.getByToken(conversionTracksToken,conversionTracks);
30 
31  Handle<TrackCollection> newTracks;
32  iEvent.getByToken(newTracksToken,newTracks);
33 
34  unique_ptr<ConversionTrackCollection> output(new ConversionTrackCollection);
35 
36  for(const ConversionTrack & conversion : *(conversionTracks.product())){
37  size_t trackIndex = conversion.trackRef().key();
38  output->push_back(ConversionTrack(TrackBaseRef(TrackRef(newTracks,trackIndex))));
39  output->back().setTrajRef(conversion.trajRef());
40  output->back().setIsTrackerOnly(conversion.isTrackerOnly());
41  output->back().setIsArbitratedEcalSeeded(conversion.isArbitratedEcalSeeded());
42  output->back().setIsArbitratedMerged(conversion.isArbitratedMerged());
43  output->back().setIsArbitratedMergedEcalGeneral(conversion.isArbitratedMergedEcalGeneral());
44  }
45 
46  iEvent.put(std::move(output));
47 
48 }
49 
T getParameter(std::string const &) const
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:137
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:579
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:17
std::vector< ConversionTrack > ConversionTrackCollection
collection of ConversionTracks
int iEvent
Definition: GenABIO.cc:230
edm::RefToBase< reco::Track > TrackBaseRef
persistent reference to a Track, using views
Definition: TrackFwd.h:32
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:81
edm::Ref< TrackCollection > TrackRef
persistent reference to a Track
Definition: TrackFwd.h:20
fixed size matrix
HLT enums.
ConversionTrackRefFix(const edm::ParameterSet &)
def move(src, dest)
Definition: eostools.py:510