CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros 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 {
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  auto_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(output);
47 
48 }
49 
T getParameter(std::string const &) const
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:462
#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
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:121
virtual 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
ConversionTrackRefFix(const edm::ParameterSet &)