12#include <CLHEP/Units/SystemOfUnits.h>
62 default:
return "unknown-gtouchable";
86 GIdentifier(
const std::string& n,
int v) : idName{n}, idValue{v} {
103 [[nodiscard]]
inline std::string
getName()
const {
return idName; }
109 [[nodiscard]]
inline int getValue()
const {
return idValue; }
160 GTouchable(
const std::shared_ptr<GOptions>& gopt,
161 const std::string& digitization,
162 const std::string& gidentityString,
163 const std::vector<double>& dimensions,
179 GTouchable(
const std::shared_ptr<GLogger>& logger,
180 const std::string& digitization,
181 const std::string& gidentityString,
182 const std::vector<double>& dimensions,
197 GTouchable(
const std::shared_ptr<GTouchable>& base,
int newTimeIndex)
200 gidentity(base->gidentity),
201 trackId(base->trackId),
202 eMultiplier(base->eMultiplier),
203 stepTimeAtElectronicsIndex(newTimeIndex) {
270 [[nodiscard]]
inline std::vector<GIdentifier>
getIdentity()
const {
return gidentity; }
281 std::string idString;
282 for (
const auto&
id : gidentity) { idString +=
id.getName() +
": " + std::to_string(
id.getValue()) +
" "; }
300 [[nodiscard]]
inline double getMass()
const {
return mass; }
312 for (
const auto& gt : v) {
314 log->
info(2,
"GTouchable",
this,
" exists in vector.");
318 log->
info(2,
"GTouchable",
this,
" does not exist in vector.");
333 static std::shared_ptr<GTouchable>
create(
const std::shared_ptr<GOptions>& gopt) {
334 int touchableNumber = globalGTouchableCounter.fetch_add(1, std::memory_order_relaxed);
335 int sector = ( touchableNumber % 6 ) + 1;
336 int paddle = ( touchableNumber % 20 ) + 1;
337 std::string identity =
"sector: " + std::to_string(sector) +
", paddle: " + std::to_string(paddle);
338 const auto& dimensions = {10.0, 20.0, 30.0};
339 const double& mass = 100 * CLHEP::g;
341 return std::make_shared<GTouchable>(gopt,
"readout", identity, dimensions, mass);
354 static std::shared_ptr<GTouchable>
create(
const std::shared_ptr<GLogger>& logger) {
355 int touchableNumber = globalGTouchableCounter.fetch_add(1, std::memory_order_relaxed);
356 int sector = ( touchableNumber % 6 ) + 1;
357 int paddle = ( touchableNumber % 20 ) + 1;
358 std::string identity =
"sector: " + std::to_string(sector) +
", paddle: " + std::to_string(paddle);
359 const auto& dimensions = {10.0, 20.0, 30.0};
360 const double& mass = 100 * CLHEP::g;
362 return std::make_shared<GTouchable>(logger,
"readout", identity, dimensions, mass);
367 std::vector<GIdentifier> gidentity;
371 int stepTimeAtElectronicsIndex;
372 std::vector<double> detectorDimensions;
379 static std::atomic<int> globalGTouchableCounter;
std::shared_ptr< GLogger > log
void debug(debug_type type, Args &&... args) const
void info(int level, Args &&... args) const
Represents a touchable sensitive detector element used as a hit-collection discriminator.
GTouchable(const GTouchable &)=default
static std::shared_ptr< GTouchable > create(const std::shared_ptr< GOptions > &gopt)
Creates a synthetic readout touchable for testing (options-based).
std::vector< GIdentifier > getIdentity() const
Returns a copy of the identity vector.
~GTouchable()
Destructor with debug trace.
void assignPId(int p)
Assigns the particle id used by particle counter discrimination.
bool operator==(const GTouchable >ouchable) const
Compares two GTouchable instances using the module comparison semantics.
void assignTrackId(int tid)
Assigns the track id used by flux and dosimeter discrimination.
void assignStepTimeAtElectronicsIndex(int timeIndex)
Assigns the electronics time-cell index used by readout discrimination.
friend std::ostream & operator<<(std::ostream &stream, const GTouchable >ouchable)
Stream output helper used in logs and diagnostics.
double getEnergyMultiplier() const
Returns the energy multiplier used for energy sharing.
static std::shared_ptr< GTouchable > create(const std::shared_ptr< GLogger > &logger)
Creates a synthetic readout touchable for testing (logger-based).
GTouchable & operator=(const GTouchable &)=default
double getMass() const
Returns the mass of the sensitive g4volume.
int getStepTimeAtElectronicsIndex() const
Returns the electronics time-cell index.
bool exists_in_vector(const std::vector< GTouchable > &v) const
Checks whether this touchable exists in a vector using operator== semantics.
std::string getIdentityString() const
Builds a human-readable identity string from the stored identifiers.
std::vector< double > getDetectorDimensions() const
Returns the detector dimensions stored at construction time.
GTouchable(const std::shared_ptr< GTouchable > &base, int newTimeIndex)
Copy constructor that preserves identity but updates the electronics time-cell index.
Conventions and constants used by the gtouchable module.
#define INTEGRAL_COUNTERNAME
Digitization type name for integral_counter.
#define FLUXNAME
Digitization type name for flux-like detectors.
#define DOSIMETERNAME
Digitization type name for dosimeters.
#define COUNTERNAME
Digitization type name for simple particle counters.
GTouchableType
Enumeration representing the type of a touchable sensitive element.
Options definition entry point for the gtouchable module.
const char * to_string(GTouchableType t)
Converts a GTouchableType value to a stable string for logging.
A single (name,value) identifier element used to build a touchable identity vector.
GIdentifier(const std::string &n, int v)
Constructs a GIdentifier.
friend std::ostream & operator<<(std::ostream &stream, const GIdentifier &gidentifier)
Stream output helper used in logs and diagnostics.
std::string getName() const
Returns the identifier name.
bool operator==(const GIdentifier &gid) const
Compares identifiers by value only.
int getValue() const
Returns the identifier value.