![]() |
ATLAS Offline Software
|
Sensitive detector tool which manages activate-area LAr calib SDs. More...
#include <ActiveSDTool.h>
Public Member Functions | |
ActiveSDTool (const std::string &type, const std::string &name, const IInterface *parent) | |
Constructor. More... | |
StatusCode | initialize () override final |
Initialize the tool. More... | |
StatusCode | Gather () override final |
Calls down to all the SDs to pack their hits into one collection. More... | |
virtual StatusCode | Gather (HitCollectionMap &) override |
StatusCode | initializeSD () override |
Setup an SD in the current thread. More... | |
virtual StatusCode | SetupEvent () override |
Beginning of an athena event. More... | |
virtual StatusCode | SetupEvent (HitCollectionMap &) override |
Protected Member Functions | |
std::unique_ptr< LArG4CalibSD > | makeOneSD (const std::string &name, ILArCalibCalculatorSvc *calc, const std::vector< std::string > &volumes) const |
Helper method to create one SD. More... | |
StatusCode | assignSD (G4VSensitiveDetector *sd, const std::vector< std::string > &volumes) const |
Assign SD to a list of volumes. More... | |
G4VSensitiveDetector * | getSD () |
Retrieve the current SD. More... | |
void | SetSensitiveDetector (G4LogicalVolume *, G4VSensitiveDetector *) const |
Method stolen from G4VUserDetectorConstruction in G4 10.2. More... | |
Protected Attributes | |
Gaudi::Property< std::vector< std::string > > | m_volumeNames {this, "LogicalVolumeNames", {}} |
All the volumes to which this SD is assigned. More... | |
Gaudi::Property< std::vector< std::string > > | m_outputCollectionNames {this, "OutputCollectionNames", {}} |
Names of all output collections written out by this SD. More... | |
Gaudi::Property< bool > | m_noVolumes {this, "NoVolumes", false} |
This SensitiveDetector has no volumes associated with it. More... | |
Private Member Functions | |
StatusCode | initializeCalculators () override final |
Initialize Calculator Services. More... | |
G4VSensitiveDetector * | makeSD () const override final |
Create the SD wrapper for current worker thread. More... | |
void | setSD (G4VSensitiveDetector *) |
Set the current SD. More... | |
Static Private Member Functions | |
static bool | matchStrings (const char *first, const char *second) |
Match two strings with wildcard support. More... | |
Private Attributes | |
Gaudi::Property< std::string > | m_hitCollName {this, "HitCollectionName", "LArCalibrationHitActive"} |
Hit collection name. More... | |
ServiceHandle< ILArCalibCalculatorSvc > | m_bpsmodcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_embcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emepiwcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emeniwcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emepowcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emenowcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emepscalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emepobarcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_emenobarcalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_heccalc |
ServiceHandle< ILArCalibCalculatorSvc > | m_fcal1calc {this, "FCAL1CalibCalculator", "FCAL1CalibCalculator"} |
ServiceHandle< ILArCalibCalculatorSvc > | m_fcal2calc {this, "FCAL2CalibCalculator", "FCAL2CalibCalculator"} |
ServiceHandle< ILArCalibCalculatorSvc > | m_fcal3calc {this, "FCAL3CalibCalculator", "FCAL3CalibCalculator"} |
G4VSensitiveDetector * | m_SD {} |
The sensitive detector to which this thing corresponds. More... | |
SD volumes | |
Gaudi::Property< std::vector< std::string > > | m_stacVolumes {this, "StacVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_presBarVolumes {this, "PresamplerVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_posIWVolumes {this, "PosIWVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_negIWVolumes {this, "NegIWVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_posOWVolumes {this, "PosOWVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_negOWVolumes {this, "NegOWVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_presECVolumes {this, "PresVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_pBOBVolumes {this, "PosBOBarretteVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_nBOBVolumes {this, "NegBOBarretteVolumes"} |
Gaudi::Property< std::vector< std::string > > | m_fcal1Volumes {this, "FCAL1Volumes"} |
Gaudi::Property< std::vector< std::string > > | m_fcal2Volumes {this, "FCAL2Volumes"} |
Gaudi::Property< std::vector< std::string > > | m_fcal3Volumes {this, "FCAL3Volumes"} |
Gaudi::Property< std::vector< std::string > > | m_sliceVolumes {this, "SliceVolumes"} |
Sensitive detector tool which manages activate-area LAr calib SDs.
Design is in flux.
Definition at line 24 of file ActiveSDTool.h.
LArG4::ActiveSDTool::ActiveSDTool | ( | const std::string & | type, |
const std::string & | name, | ||
const IInterface * | parent | ||
) |
Constructor.
|
protectedinherited |
Assign SD to a list of volumes.
This method supports wild card matching
Definition at line 69 of file SensitiveDetectorBase.cxx.
|
finaloverridevirtualinherited |
Calls down to all the SDs to pack their hits into one collection.
Reimplemented from SensitiveDetectorBase.
|
inlineoverridevirtualinherited |
Reimplemented in TileGeoG4SDTool, TileGeoG4CalibSDTool, SctSensorSDTool, PixelSensorSDTool, SctSensor_CTBTool, BCMSensorSDTool, BLMSensorSDTool, and TRTSensitiveDetectorTool.
Definition at line 79 of file SensitiveDetectorBase.h.
|
protectedinherited |
Retrieve the current SD.
In AthenaMT, this means the thread-local SD. Otherwise, it is simply the single SD.
Definition at line 123 of file SensitiveDetectorBase.cxx.
|
finaloverrideinherited |
Initialize the tool.
|
finaloverrideprivatevirtual |
Initialize Calculator Services.
Reimplemented from LArG4::CalibSDTool.
|
overrideinherited |
Setup an SD in the current thread.
Separate from the AthAlgTool initialize() method because it needs to be called once per worker thread in AthenaMT. Don't confuse this with the G4 SD method Initialize which is called at the beginning of every G4 event.
Definition at line 30 of file SensitiveDetectorBase.cxx.
|
protectedinherited |
Helper method to create one SD.
|
finaloverrideprivate |
Create the SD wrapper for current worker thread.
|
staticprivateinherited |
Match two strings with wildcard support.
Compares two strings character by character with optional * wildcard in the first argument
Definition at line 150 of file SensitiveDetectorBase.cxx.
|
privateinherited |
Set the current SD.
In hive, this gets assigned as the thread-local SD.
Definition at line 137 of file SensitiveDetectorBase.cxx.
|
protectedinherited |
Method stolen from G4VUserDetectorConstruction in G4 10.2.
Definition at line 177 of file SensitiveDetectorBase.cxx.
|
inlineoverridevirtualinherited |
Beginning of an athena event.
This is where collection initialization should happen. If we are using a WriteHandle, then this could be empty.
Reimplemented in MuonWallSDTool, AFP_SensitiveDetectorTool, AFP_SiDSensitiveDetectorTool, AFP_TDSensitiveDetectorTool, CaloCellContainerSDTool, and ALFA_SensitiveDetectorTool.
Definition at line 70 of file SensitiveDetectorBase.h.
|
inlineoverridevirtualinherited |
Reimplemented in TileGeoG4SDTool, TileGeoG4CalibSDTool, SctSensorSDTool, PixelSensorSDTool, SctSensor_CTBTool, BCMSensorSDTool, BLMSensorSDTool, and TRTSensitiveDetectorTool.
Definition at line 71 of file SensitiveDetectorBase.h.
|
private |
Definition at line 58 of file ActiveSDTool.h.
Definition at line 83 of file CalibSDTool.h.
|
protectedinherited |
Are we set up to run with PID hits?
Definition at line 74 of file CalibSDTool.h.
|
private |
Definition at line 60 of file ActiveSDTool.h.
|
private |
Definition at line 64 of file ActiveSDTool.h.
|
private |
Definition at line 74 of file ActiveSDTool.h.
|
private |
Definition at line 68 of file ActiveSDTool.h.
|
private |
Definition at line 62 of file ActiveSDTool.h.
|
private |
Definition at line 72 of file ActiveSDTool.h.
|
private |
Definition at line 66 of file ActiveSDTool.h.
|
private |
Definition at line 70 of file ActiveSDTool.h.
|
private |
Definition at line 78 of file ActiveSDTool.h.
|
private |
Definition at line 52 of file ActiveSDTool.h.
|
private |
Definition at line 79 of file ActiveSDTool.h.
|
private |
Definition at line 53 of file ActiveSDTool.h.
|
private |
Definition at line 80 of file ActiveSDTool.h.
|
private |
Definition at line 54 of file ActiveSDTool.h.
|
private |
Definition at line 76 of file ActiveSDTool.h.
|
private |
Hit collection name.
Definition at line 39 of file ActiveSDTool.h.
|
protectedinherited |
Definition at line 84 of file CalibSDTool.h.
Definition at line 80 of file CalibSDTool.h.
|
protectedinherited |
Definition at line 81 of file CalibSDTool.h.
Definition at line 82 of file CalibSDTool.h.
|
private |
Definition at line 51 of file ActiveSDTool.h.
|
private |
Definition at line 46 of file ActiveSDTool.h.
|
private |
Definition at line 48 of file ActiveSDTool.h.
|
protectedinherited |
This SensitiveDetector has no volumes associated with it.
Definition at line 101 of file SensitiveDetectorBase.h.
|
protectedinherited |
Names of all output collections written out by this SD.
Definition at line 98 of file SensitiveDetectorBase.h.
|
private |
Definition at line 50 of file ActiveSDTool.h.
|
private |
Definition at line 45 of file ActiveSDTool.h.
|
private |
Definition at line 47 of file ActiveSDTool.h.
|
private |
Definition at line 44 of file ActiveSDTool.h.
|
private |
Definition at line 49 of file ActiveSDTool.h.
|
privateinherited |
The sensitive detector to which this thing corresponds.
Definition at line 125 of file SensitiveDetectorBase.h.
|
private |
Definition at line 55 of file ActiveSDTool.h.
|
private |
Definition at line 43 of file ActiveSDTool.h.
|
protectedinherited |
All the volumes to which this SD is assigned.
Definition at line 96 of file SensitiveDetectorBase.h.