CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Static Public Member Functions | Private Attributes
GEMDigiProducer Class Reference
Inheritance diagram for GEMDigiProducer:
edm::stream::EDProducer<>

Public Types

typedef edm::DetSetVector< GEMDigiSimLinkGEMDigiSimLinks
 
- 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 Member Functions

void beginRun (const edm::Run &, const edm::EventSetup &) override
 
 GEMDigiProducer (const edm::ParameterSet &ps)
 
void produce (edm::Event &, const edm::EventSetup &) override
 
 ~GEMDigiProducer () override
 
- 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
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 

Private Attributes

edm::EDGetTokenT< CrossingFrame< PSimHit > > cf_token
 
std::unique_ptr< GEMDigiModulegemDigiModule_
 
edm::ESGetToken< GEMGeometry, MuonGeometryRecordgeom_token_
 
const GEMGeometrygeometry_
 

Detailed Description

Definition at line 38 of file GEMDigiProducer.cc.

Member Typedef Documentation

◆ GEMDigiSimLinks

Definition at line 40 of file GEMDigiProducer.cc.

Constructor & Destructor Documentation

◆ GEMDigiProducer()

GEMDigiProducer::GEMDigiProducer ( const edm::ParameterSet ps)
explicit

Definition at line 62 of file GEMDigiProducer.cc.

62  : gemDigiModule_(std::make_unique<GEMDigiModule>(ps)) {
63  produces<GEMDigiCollection>();
64  produces<GEMDigiSimLinks>("GEM");
65 
67  if (!rng.isAvailable()) {
68  throw cms::Exception("Configuration")
69  << "GEMDigiProducer::GEMDigiProducer() - RandomNumberGeneratorService is not present in configuration file.\n"
70  << "Add the service in the configuration file or remove the modules that require it.";
71  }
72 
73  std::string mix_(ps.getParameter<std::string>("mixLabel"));
74  std::string collection_(ps.getParameter<std::string>("inputCollection"));
75 
76  cf_token = consumes<CrossingFrame<PSimHit> >(edm::InputTag(mix_, collection_));
77  geom_token_ = esConsumes<GEMGeometry, MuonGeometryRecord, edm::Transition::BeginRun>();
78 }

References cf_token, Exception, geom_token_, edm::ParameterSet::getParameter(), HLT_FULL_cff::InputTag, edm::Service< T >::isAvailable(), and AlCaHLTBitMon_QueryRunRegistry::string.

◆ ~GEMDigiProducer()

GEMDigiProducer::~GEMDigiProducer ( )
overridedefault

Member Function Documentation

◆ beginRun()

void GEMDigiProducer::beginRun ( const edm::Run ,
const edm::EventSetup eventSetup 
)
override

Definition at line 138 of file GEMDigiProducer.cc.

138  {
140  gemDigiModule_->setGeometry(&*hGeom);
141  geometry_ = &*hGeom;
142 }

References gemDigiModule_, geom_token_, geometry_, and edm::EventSetup::getHandle().

◆ fillDescriptions()

void GEMDigiProducer::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 82 of file GEMDigiProducer.cc.

82  {
84  desc.add<std::string>("inputCollection", "g4SimHitsMuonGEMHits");
85  desc.add<std::string>("mixLabel", "mix");
86 
87  desc.add<double>("signalPropagationSpeed", 0.66);
88  desc.add<double>("timeResolution", 5.);
89  desc.add<double>("timeJitter", 1.0);
90  desc.add<double>("averageShapingTime", 50.0);
91  desc.add<double>("averageEfficiency", 0.98);
92  desc.add<double>("averageNoiseRate", 0.001);
93  // intrinsic noise rate (Hz/cm^2)
94 
95  // in terms of 25 ns
96  desc.add<int>("minBunch", -5);
97  desc.add<int>("maxBunch", 3);
98 
99  desc.add<bool>("fixedRollRadius", true);
100  // Uses fixed radius in the center of the roll
101  desc.add<bool>("digitizeOnlyMuons", false);
102  desc.add<bool>("simulateBkgNoise", false);
103  // false == No background simulation
104  desc.add<bool>("simulateNoiseCLS", true);
105  desc.add<bool>("simulateElectronBkg", true);
106  // flase == simulate only neutral bkg
107  desc.add<bool>("simulateIntrinsicNoise", false);
108 
109  desc.add<double>("instLumi", 7.5);
110  // in units of 1E34 cm^-2 s^-1. Internally the background is parmetrized from FLUKA+GEANT result at 5E+34 (PU 140). We are adding a 1.5 factor for PU 200
111  desc.add<double>("rateFact", 1.0);
112  // We are adding also a safety factor of 2 to tak into account the new beam pipe effect (not yet known). Hits can be thrown away later at re-digi step. Parameters are kept in sync with the ones used in the GEM digitizer
113  desc.add<double>("bxWidth", 25E-9);
114  desc.add<double>("referenceInstLumi", 5.);
115  // referecne inst. luminosity 5E+34 cm^-2s^-1
116  desc.add<double>("resolutionX", 0.03);
117 
118  // The follwing parameters are needed to model the background contribution
119  // The parameters have been obtained after the fit of th perdicted by FLUKA
120  // By default the backgroundmodeling with these parameters should be disabled with
121  // the 9_2_X release setting simulateBkgNoise = false
122  desc.add<double>("GE11ModNeuBkgParam0", 5710.23);
123  desc.add<double>("GE11ModNeuBkgParam1", -43.3928);
124  desc.add<double>("GE11ModNeuBkgParam2", 0.0863681);
125  desc.add<double>("GE21ModNeuBkgParam0", 1440.44);
126  desc.add<double>("GE21ModNeuBkgParam1", -7.48607);
127  desc.add<double>("GE21ModNeuBkgParam2", 0.0103078);
128  desc.add<double>("GE11ElecBkgParam0", 406.249);
129  desc.add<double>("GE11ElecBkgParam1", -2.90939);
130  desc.add<double>("GE11ElecBkgParam2", 0.00548191);
131  desc.add<double>("GE21ElecBkgParam0", 97.0505);
132  desc.add<double>("GE21ElecBkgParam1", -43.3928);
133  desc.add<double>("GE21ElecBkgParam2", 00.000550599);
134 
135  descriptions.add("simMuonGEMDigisDef", desc);
136 }

References edm::ConfigurationDescriptions::add(), submitPVResolutionJobs::desc, and AlCaHLTBitMon_QueryRunRegistry::string.

◆ produce()

void GEMDigiProducer::produce ( edm::Event e,
const edm::EventSetup eventSetup 
)
override

Definition at line 144 of file GEMDigiProducer.cc.

144  {
146  CLHEP::HepRandomEngine* engine = &rng->getEngine(e.streamID());
147 
149  e.getByToken(cf_token, cf);
150 
152 
153  // Create empty output
154  auto digis = std::make_unique<GEMDigiCollection>();
155  auto gemDigiSimLinks = std::make_unique<GEMDigiSimLinks>();
156 
157  // arrange the hits by eta partition
158  std::map<uint32_t, edm::PSimHitContainer> hitMap;
159  for (const auto& hit : hits) {
160  hitMap[GEMDetId(hit.detUnitId()).rawId()].emplace_back(hit);
161  }
162 
163  // simulate signal and noise for each eta partition
164  const auto& etaPartitions(geometry_->etaPartitions());
165 
166  for (const auto& roll : etaPartitions) {
167  const GEMDetId detId(roll->id());
168  const uint32_t rawId(detId.rawId());
169  const auto& simHits(hitMap[rawId]);
170 
171  LogDebug("GEMDigiProducer") << "GEMDigiProducer: found " << simHits.size() << " hit(s) in eta partition" << rawId;
172 
173  gemDigiModule_->simulate(roll, simHits, engine);
174  gemDigiModule_->fillDigis(rawId, *digis);
175  (*gemDigiSimLinks).insert(gemDigiModule_->gemDigiSimLinks());
176  }
177 
178  // store them in the event
179  e.put(std::move(digis));
180  e.put(std::move(gemDigiSimLinks), "GEM");
181 }

References cf_token, MillePedeFileConverter_cfg::e, GEMGeometry::etaPartitions(), gemDigiModule_, geometry_, edm::RandomNumberGenerator::getEngine(), hfClusterShapes_cfi::hits, LogDebug, eostools::move(), edm::Handle< T >::product(), and FastTrackerRecHitCombiner_cfi::simHits.

Member Data Documentation

◆ cf_token

edm::EDGetTokenT<CrossingFrame<PSimHit> > GEMDigiProducer::cf_token
private

Definition at line 54 of file GEMDigiProducer.cc.

Referenced by GEMDigiProducer(), and produce().

◆ gemDigiModule_

std::unique_ptr<GEMDigiModule> GEMDigiProducer::gemDigiModule_
private

Definition at line 59 of file GEMDigiProducer.cc.

Referenced by beginRun(), and produce().

◆ geom_token_

edm::ESGetToken<GEMGeometry, MuonGeometryRecord> GEMDigiProducer::geom_token_
private

Definition at line 55 of file GEMDigiProducer.cc.

Referenced by beginRun(), and GEMDigiProducer().

◆ geometry_

const GEMGeometry* GEMDigiProducer::geometry_
private

Definition at line 57 of file GEMDigiProducer.cc.

Referenced by beginRun(), and produce().

edm::RandomNumberGenerator::getEngine
virtual CLHEP::HepRandomEngine & getEngine(StreamID const &)=0
Use this engine in event methods.
GEMDigiProducer::geom_token_
edm::ESGetToken< GEMGeometry, MuonGeometryRecord > geom_token_
Definition: GEMDigiProducer.cc:55
edm::Handle::product
T const * product() const
Definition: Handle.h:70
hfClusterShapes_cfi.hits
hits
Definition: hfClusterShapes_cfi.py:5
GEMDigiProducer::gemDigiModule_
std::unique_ptr< GEMDigiModule > gemDigiModule_
Definition: GEMDigiProducer.cc:59
HLT_FULL_cff.InputTag
InputTag
Definition: HLT_FULL_cff.py:89281
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
FastTrackerRecHitCombiner_cfi.simHits
simHits
Definition: FastTrackerRecHitCombiner_cfi.py:5
edm::Handle
Definition: AssociativeIterator.h:50
edm::Service::isAvailable
bool isAvailable() const
Definition: Service.h:40
GEMDigiProducer::geometry_
const GEMGeometry * geometry_
Definition: GEMDigiProducer.cc:57
edm::ConfigurationDescriptions::add
void add(std::string const &label, ParameterSetDescription const &psetDescription)
Definition: ConfigurationDescriptions.cc:57
MixCollection
Definition: MixCollection.h:10
edm::ESHandle< GEMGeometry >
AlCaHLTBitMon_QueryRunRegistry.string
string
Definition: AlCaHLTBitMon_QueryRunRegistry.py:256
LogDebug
#define LogDebug(id)
Definition: MessageLogger.h:233
GEMDetId
Definition: GEMDetId.h:18
edm::Service< edm::RandomNumberGenerator >
edm::EventSetup::getHandle
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
Definition: EventSetup.h:155
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
eostools.move
def move(src, dest)
Definition: eostools.py:511
Exception
Definition: hltDiff.cc:245
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
GEMGeometry::etaPartitions
const std::vector< const GEMEtaPartition * > & etaPartitions() const
Return a vector of all GEM eta partitions.
Definition: GEMGeometry.cc:40
GEMDigiProducer::cf_token
edm::EDGetTokenT< CrossingFrame< PSimHit > > cf_token
Definition: GEMDigiProducer.cc:54
hit
Definition: SiStripHitEffFromCalibTree.cc:88
MillePedeFileConverter_cfg.e
e
Definition: MillePedeFileConverter_cfg.py:37