gdynamicDigitization
Loading...
Searching...
No Matches
gFluxDigitization.cc
Go to the documentation of this file.
1#include "gFluxDigitization.h"
2
3// See header for API docs.
5 double timeWindow = 10; // electronic readout time-window of the detector
6 double gridStartTime = 0; // defines the windows grid
7 HitBitSet hitBitSet("000001"); // defines what information to be stored in the hit
8 double maxStep = 1 * CLHEP::mm;
9
10 readoutSpecs = std::make_shared<GReadoutSpecs>(timeWindow, gridStartTime, hitBitSet, maxStep, log);
11
12 return true;
13}
14
15// See header for API docs.
16std::unique_ptr<GDigitizedData> GFluxDigitization::digitizeHitImpl(GHit* ghit, size_t hitn) {
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.
std::unique_ptr< GDigitizedData > digitizeHitImpl(GHit *ghit, size_t hitn) override
Digitizes a hit for flux detectors.
bool defineReadoutSpecsImpl() override
Defines readout specifications for flux digitization.
int getPid() const
std::vector< GIdentifier > getGID() const
double getTotalEnergyDeposited()
double getAverageTime()
double getE() const
std::bitset< NHITBITS > HitBitSet
std::string getName() const
int getValue() const