9 #include "CLHEP/Random/RandFlat.h"
10 #include "CLHEP/Random/RandPoissonQ.h"
37 for (edm::PSimHitContainer::const_iterator _hit = rpcHits.begin(); _hit != rpcHits.end(); ++_hit) {
43 std::pair<int, int> digi(topology.channel(entr) + 1, time_hit);
60 area = striplength * (xmax -
xmin);
66 area = striplength * (xmax -
xmin);
71 CLHEP::RandPoissonQ randPoissonQ(*engine, ave);
72 N_hits = randPoissonQ.fire();
75 int strip =
static_cast<int>(CLHEP::RandFlat::shoot(engine, 1, nstrips));
77 time_hit = (
static_cast<int>(CLHEP::RandFlat::shoot(engine, (
nbxing *
gate) / gate))) -
nbxing / 2;
78 std::pair<int, int> digi(strip, time_hit);
LocalPoint localPosition(float strip) const override
void simulateNoise(const RPCRoll *, CLHEP::HepRandomEngine *) override
RPCSynchronizer * _rpcSync
DetectorHitMap theDetectorHitMap
void setRPCSimSetUp(RPCSimSetUp *simsetup)
constexpr uint32_t rawId() const
get the raw id
RPCSimSetUp * getRPCSimSetUp()
const RPCRollSpecs * specs() const
int getSimHitBx(const PSimHit *, CLHEP::HepRandomEngine *)
float stripLength() const override
edm::DetSet< RPCDigiSimLink > RPCDigiSimLinks
Container::value_type value_type
std::set< std::pair< int, int > > strips
RPCSimSimple(const edm::ParameterSet &config)
const Topology & topology() const override
T getParameter(std::string const &) const
tuple config
parse the configuration file
const Topology & topology() const override
void simulate(const RPCRoll *roll, const edm::PSimHitContainer &rpcHits, CLHEP::HepRandomEngine *) override
std::vector< PSimHit > PSimHitContainer
float stripLength() const override
det heigth (strip length in the middle)
RPCDigiSimLinks theRpcDigiSimLinks
LocalPoint localPosition(float strip) const override
int region() const
Region id: 0 for Barrel, +/-1 For +/- Endcap.