gdynamicDigitization
Loading...
Searching...
No Matches
gParticleCounterDigitization.cc
Go to the documentation of this file.
2
3// See header for API docs.
5 double timeWindow = 10; // electronic readout time-window of the detector
6 double gridStartTime = 0; // defines the window grid
7 auto hitBitSet = HitBitSet("000000"); // defines what information to be stored in the hit
8
9 readoutSpecs = std::make_shared<GReadoutSpecs>(timeWindow, gridStartTime, hitBitSet, log);
10
11 return true;
12}
13
14// See header for API docs.
15std::unique_ptr<GDigitizedData> GParticleCounterDigitization::digitizeHitImpl(GHit* ghit, size_t hitn) {
16 // Expected to be a single-identity detector: take the first identity entry.
17 GIdentifier identity = ghit->getGID().front();
18
19 auto gdata = std::make_unique<GDigitizedData>(gopts, ghit);
20
21 gdata->includeVariable(identity.getName(), identity.getValue());
22 gdata->includeVariable("hitn", static_cast<int>(hitn));
23 gdata->includeVariable("totEdep", ghit->getTotalEnergyDeposited());
24 gdata->includeVariable("time", ghit->getAverageTime());
25 gdata->includeVariable("pid", ghit->getPid());
26 gdata->includeVariable("totalE", ghit->getE());
27
28 return gdata;
29}
std::shared_ptr< GLogger > log
std::shared_ptr< GOptions > gopts
Options used by the digitization plugin instance.
std::shared_ptr< const GReadoutSpecs > readoutSpecs
Readout specs are created during initialization and treated as immutable.
int getPid() const
std::vector< GIdentifier > getGID() const
double getTotalEnergyDeposited()
double getAverageTime()
double getE() const
std::unique_ptr< GDigitizedData > digitizeHitImpl(GHit *ghit, size_t hitn) override
Digitizes a hit for particle counters.
bool defineReadoutSpecsImpl() override
Defines readout specifications for particle counter digitization.
std::bitset< NHITBITS > HitBitSet
Internal digitization plugins shipped with the gdynamic digitization library.
std::string getName() const
int getValue() const