CMS 3D CMS Logo

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

#include <FamosProducer.h>

Inheritance diagram for FamosProducer:
edm::stream::EDProducer<> edm::stream::EDProducerBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

void beginRun (edm::Run const &run, const edm::EventSetup &es) override
 
 FamosProducer (edm::ParameterSet const &p)
 
void produce (edm::Event &e, const edm::EventSetup &c) override
 
 ~FamosProducer () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
- Public Member Functions inherited from edm::stream::EDProducerBase
 EDProducerBase ()
 
ModuleDescription const & moduleDescription () const
 
 ~EDProducerBase () override
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
std::vector< edm::ProductResolverIndex > const & putTokenIndexToProductResolverIndex () const
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
virtual ~ProducerBase () noexcept(false)
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
virtual ~EDConsumerBase () noexcept(false)
 

Private Attributes

HepMC::GenEvent * evt_
 
FamosManagerfamosManager_
 
bool simulateMuons
 
edm::EDGetTokenT< edm::HepMCProductsourceToken
 

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
 
- Public Types inherited from edm::stream::EDProducerBase
typedef EDProducerAdaptorBase ModuleType
 
- Public Types inherited from edm::ProducerBase
using ModuleToResolverIndicies = std::unordered_multimap< std::string, std::tuple< edm::TypeID const *, const char *, edm::ProductResolverIndex >>
 
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::stream::EDProducerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- 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 17 of file FamosProducer.h.

Constructor & Destructor Documentation

FamosProducer::FamosProducer ( edm::ParameterSet const &  p)
explicit

Definition at line 31 of file FamosProducer.cc.

References famosManager_, edm::ParameterSet::getParameter(), simulateMuons, and sourceToken.

32 {
33 
34  produces<edm::SimTrackContainer>();
35  produces<edm::SimVertexContainer>();
36  produces<FSimVertexTypeCollection>("VertexTypes");
37  produces<edm::PSimHitContainer>("TrackerHits");
38  produces<edm::PCaloHitContainer>("EcalHitsEB");
39  produces<edm::PCaloHitContainer>("EcalHitsEE");
40  produces<edm::PCaloHitContainer>("EcalHitsES");
41  produces<edm::PCaloHitContainer>("HcalHits");
42  // Temporary facility to allow for the crossing frame to work...
43  simulateMuons = p.getParameter<bool>("SimulateMuons");
44  if ( simulateMuons ) produces<edm::SimTrackContainer>("MuonSimTracks");
45 
46  // hepmc event from signal event
47  edm::InputTag sourceLabel = p.getParameter<edm::InputTag>("SourceLabel");
48  sourceToken = consumes<edm::HepMCProduct>(sourceLabel);
49 
50  // famos manager
52 }
FamosManager * famosManager_
Definition: FamosProducer.h:29
edm::EDGetTokenT< edm::HepMCProduct > sourceToken
Definition: FamosProducer.h:35
FamosProducer::~FamosProducer ( )
override

Definition at line 54 of file FamosProducer.cc.

References famosManager_.

55 { if ( famosManager_ ) delete famosManager_; }
FamosManager * famosManager_
Definition: FamosProducer.h:29

Member Function Documentation

void FamosProducer::beginRun ( edm::Run const &  run,
const edm::EventSetup es 
)
override

Definition at line 58 of file FamosProducer.cc.

References famosManager_, and FamosManager::setupGeometryAndField().

58  {
60 }
FamosManager * famosManager_
Definition: FamosProducer.h:29
void setupGeometryAndField(edm::Run const &run, const edm::EventSetup &es)
Get information from the Event Setup.
Definition: FamosManager.cc:85
void FamosProducer::produce ( edm::Event e,
const edm::EventSetup c 
)
override

Definition at line 62 of file FamosProducer.cc.

References FamosManager::calorimetryManager(), DEFINE_FWK_MODULE, famosManager_, edm::EventSetup::get(), edm::Event::getByToken(), edm::HepMCProduct::GetEvent(), FSimEvent::load(), CalorimetryManager::loadFromEcalBarrel(), CalorimetryManager::loadFromEcalEndcap(), CalorimetryManager::loadFromHcal(), CalorimetryManager::loadFromPreshower(), CalorimetryManager::loadMuonSimTracks(), TrajectoryManager::loadSimHits(), eostools::move(), p1, p2, p3, p4, edm::Event::put(), random, FamosManager::reconstruct(), FamosManager::simEvent(), simulateMuons, sourceToken, edm::Event::streamID(), FBaseSimEvent::theTable(), mixOne_simraw_on_sim_cfi::tracker, and FamosManager::trackerManager().

Referenced by JSONExport.JsonExport::export(), HTMLExport.HTMLExport::export(), and HTMLExport.HTMLExportStatic::export().

63 {
65  using namespace edm;
66 
68 
69  //Retrieve tracker topology from geometry
71  es.get<TrackerTopologyRcd>().get(tTopoHand);
72  const TrackerTopology *tTopo=tTopoHand.product();
73 
74  // get the signal event
75  Handle<HepMCProduct> theHepMCProduct;
76  iEvent.getByToken(sourceToken,theHepMCProduct);
77  const HepMC::GenEvent * myGenEvent = theHepMCProduct->GetEvent();
78 
79  // do the simulation
80  famosManager_->reconstruct(myGenEvent,tTopo, &random);
81 
82  // get the hits, simtracks and simvertices and put in the event
85 
86  std::unique_ptr<edm::SimTrackContainer> p1(new edm::SimTrackContainer);
87  std::unique_ptr<edm::SimTrackContainer> m1(new edm::SimTrackContainer);
88  std::unique_ptr<edm::SimVertexContainer> p2(new edm::SimVertexContainer);
89  std::unique_ptr<FSimVertexTypeCollection> v1(new FSimVertexTypeCollection);
90  std::unique_ptr<edm::PSimHitContainer> p3(new edm::PSimHitContainer);
91  std::unique_ptr<edm::PCaloHitContainer> p4(new edm::PCaloHitContainer);
92  std::unique_ptr<edm::PCaloHitContainer> p5(new edm::PCaloHitContainer);
93  std::unique_ptr<edm::PCaloHitContainer> p6(new edm::PCaloHitContainer);
94  std::unique_ptr<edm::PCaloHitContainer> p7(new edm::PCaloHitContainer);
95 
96  FSimEvent* fevt = famosManager_->simEvent();
97  fevt->load(*p1,*m1);
98  fevt->load(*p2);
99  fevt->load(*v1);
100  tracker->loadSimHits(*p3);
101 
102 
103  if ( calo ) {
104  calo->loadFromEcalBarrel(*p4);
105  calo->loadFromEcalEndcap(*p5);
106  calo->loadFromPreshower(*p6);
107  calo->loadFromHcal(*p7);
108  calo->loadMuonSimTracks(*m1);
109  }
110 
111  if ( simulateMuons ) iEvent.put(std::move(m1),"MuonSimTracks");
112  iEvent.put(std::move(p1));
113  iEvent.put(std::move(p2));
114  iEvent.put(std::move(p3),"TrackerHits");
115  iEvent.put(std::move(v1),"VertexTypes");
116  iEvent.put(std::move(p4),"EcalHitsEB");
117  iEvent.put(std::move(p5),"EcalHitsEE");
118  iEvent.put(std::move(p6),"EcalHitsES");
119  iEvent.put(std::move(p7),"HcalHits");
120 
121 }
void reconstruct(const HepMC::GenEvent *evt, const TrackerTopology *tTopo, RandomEngineAndDistribution const *)
The real thing is done here.
std::vector< PCaloHit > PCaloHitContainer
void load(edm::SimTrackContainer &c, edm::SimTrackContainer &m) const
Load containers of tracks (and muons) and vertices for the edm::Event.
Definition: FSimEvent.cc:51
const HepPDT::ParticleDataTable * theTable() const
Get the pointer to the particle data table.
Definition: FBaseSimEvent.h:57
void loadFromPreshower(edm::PCaloHitContainer &c) const
TRandom random
Definition: MVATrainer.cc:138
FamosManager * famosManager_
Definition: FamosProducer.h:29
int iEvent
Definition: GenABIO.cc:230
double p4[4]
Definition: TauolaWrapper.h:92
void loadFromEcalEndcap(edm::PCaloHitContainer &c) const
std::vector< FSimVertexType > FSimVertexTypeCollection
collection of FSimVertexType objects
void loadMuonSimTracks(edm::SimTrackContainer &m) const
double p2[4]
Definition: TauolaWrapper.h:90
void loadFromHcal(edm::PCaloHitContainer &c) const
CalorimetryManager * calorimetryManager() const
The calorimeter.
Definition: FamosManager.h:56
edm::EDGetTokenT< edm::HepMCProduct > sourceToken
Definition: FamosProducer.h:35
const HepMC::GenEvent * GetEvent() const
Definition: HepMCProduct.h:38
void loadSimHits(edm::PSimHitContainer &c) const
std::vector< SimVertex > SimVertexContainer
HLT enums.
double p1[4]
Definition: TauolaWrapper.h:89
std::vector< PSimHit > PSimHitContainer
TrajectoryManager * trackerManager() const
The tracker.
Definition: FamosManager.h:53
FSimEvent * simEvent() const
The simulated event.
Definition: FamosManager.h:45
std::vector< SimTrack > SimTrackContainer
def move(src, dest)
Definition: eostools.py:510
double p3[4]
Definition: TauolaWrapper.h:91
void loadFromEcalBarrel(edm::PCaloHitContainer &c) const

Member Data Documentation

HepMC::GenEvent* FamosProducer::evt_
private

Definition at line 30 of file FamosProducer.h.

FamosManager* FamosProducer::famosManager_
private

Definition at line 29 of file FamosProducer.h.

Referenced by beginRun(), FamosProducer(), produce(), and ~FamosProducer().

bool FamosProducer::simulateMuons
private

Definition at line 31 of file FamosProducer.h.

Referenced by FamosProducer(), and produce().

edm::EDGetTokenT<edm::HepMCProduct> FamosProducer::sourceToken
private

Definition at line 35 of file FamosProducer.h.

Referenced by FamosProducer(), and produce().