ATLAS Offline Software
Loading...
Searching...
No Matches
LArCalorimeter
LArG4
LArG4EC
src
LArG4EC/src/CryostatCalibrationMixedCalculator.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3
*/
4
5
// LArG4::EndcapCryostat::CalibrationMixedCalculator
6
// Prepared 13-Aug-2004 Bill Seligman
7
8
// This class calculates the values needed for calibration hits in the
9
// simulation.
10
11
// A "calculator" is used in much the same way as a hand-held
12
// calculator might be. The user supplies a value and hits 'Enter'
13
// (i.e., invokes the Process() method). Then they read off whatever
14
// values are of interest.
15
16
// This particular class is meant to be be used for particular volumes
17
// in the endcap cryostat. Some volumes have identifiers that change
18
// significantly (mixed samplings, types, subdets) within that single
19
// volume. This calculator handles those special cases.
20
21
#ifndef LArG4_EndcapCryostat_CalibrationMixedCalculator_H
22
#define LArG4_EndcapCryostat_CalibrationMixedCalculator_H
23
24
#include "
LArG4Code/LArCalibCalculatorSvcImp.h
"
25
#include "
LArG4Code/LArG4Identifier.h
"
26
#include "
CaloG4Sim/SimulationEnergies.h
"
27
#include "globals.hh"
28
29
#include <vector>
30
31
// Forward declaractions:
32
class
G4Step;
33
34
// Note the use of nested namespaces (mainly to prevent long names
35
// like LArG4HECCalibrationCalculator). This class is contained in
36
// the namespace LArG4::EndcapCryostat.
37
38
namespace
LArG4
{
39
40
namespace
EndcapCryostat
{
41
42
class
CalibrationMixedCalculator
:
public
LArCalibCalculatorSvcImp
{
43
public
:
44
45
CalibrationMixedCalculator
(
const
std::string& name, ISvcLocator *pSvcLocator);
46
CalibrationMixedCalculator
(
const
CalibrationMixedCalculator
&) =
delete
;
47
CalibrationMixedCalculator
&
operator=
(
const
CalibrationMixedCalculator
&) =
delete
;
48
StatusCode
initialize
() override final;
49
virtual ~
CalibrationMixedCalculator
();
50
51
// The Process method returns a boolean value. If it's true, the
52
// hit can be used by Geant4; if it's false, there's something wrong
53
// with the energy deposit and it should be ignored.
54
55
// For calibration work, most of the time we want the calculator
56
// to determine both the energy and the identifier. However,
57
// sometimes we want it calculate only the identifier (for
58
// escaped energy), or only the energy (no known application
59
// yet, but you can never tell). Use the enum (defined in
60
// VCalibrationCalculator.h) to control any special processing.
61
62
virtual G4bool
Process
(
const
G4Step* step,
LArG4Identifier
& identifier,
63
LArG4Identifier
& identifier_sr,
64
std
::
vector
<G4double> & energies,
65
const
eCalculatorProcessing
p =
kEnergyAndID
)
const
override final;
66
67
private
:
68
69
// Energy calculator
70
CaloG4
::SimulationEnergies
m_energyCalculator
{};
71
72
class
Parameters;
73
Parameters *
m_par
{
nullptr
};
74
75
// Define a "backup" calculator.
76
ServiceHandle<ILArCalibCalculatorSvc>
m_backupCalculator
{
this
,
"BackupCalculator"
,
"EndcapCryostatCalibrationLArCalculator"
};
77
};
78
79
}
// namespace EndcapCryostat
80
81
}
// namespace LArG4
82
83
#endif
// LArG4_EndcapCryostat_CalibrationMixedCalculator_H
LArCalibCalculatorSvcImp.h
LArG4Identifier.h
SimulationEnergies.h
LArCalibCalculatorSvcImp::LArCalibCalculatorSvcImp
LArCalibCalculatorSvcImp(const std::string &name, ISvcLocator *pSvcLocator)
Definition
LArCalibCalculatorSvcImp.cxx:7
LArG4Identifier
Definition
LArG4Identifier.h:121
LArG4::EndcapCryostat::CalibrationMixedCalculator::Process
virtual G4bool Process(const G4Step *step, LArG4Identifier &identifier, LArG4Identifier &identifier_sr, std::vector< G4double > &energies, const eCalculatorProcessing p=kEnergyAndID) const override final
LArG4::EndcapCryostat::CalibrationMixedCalculator::m_par
Parameters * m_par
Definition
LArG4EC/src/CryostatCalibrationMixedCalculator.h:73
LArG4::EndcapCryostat::CalibrationMixedCalculator::m_backupCalculator
ServiceHandle< ILArCalibCalculatorSvc > m_backupCalculator
Definition
LArG4EC/src/CryostatCalibrationMixedCalculator.h:76
LArG4::EndcapCryostat::CalibrationMixedCalculator::CalibrationMixedCalculator
CalibrationMixedCalculator(const std::string &name, ISvcLocator *pSvcLocator)
LArG4::EndcapCryostat::CalibrationMixedCalculator::CalibrationMixedCalculator
CalibrationMixedCalculator(const CalibrationMixedCalculator &)=delete
LArG4::EndcapCryostat::CalibrationMixedCalculator::m_energyCalculator
CaloG4::SimulationEnergies m_energyCalculator
Definition
LArG4EC/src/CryostatCalibrationMixedCalculator.h:70
LArG4::EndcapCryostat::CalibrationMixedCalculator::initialize
StatusCode initialize() override final
LArG4::EndcapCryostat::CalibrationMixedCalculator::operator=
CalibrationMixedCalculator & operator=(const CalibrationMixedCalculator &)=delete
ServiceHandle
Definition
ClusterMakerTool.h:36
vector
Definition
MultiHisto.h:13
const
CaloG4
Definition
EscapedEnergyRegistry.h:21
LArG4::EndcapCryostat
Definition
LArG4EC/src/CryostatCalibrationCalculator.h:42
LArG4
Definition
LArWheelCalculatorEnums.h:8
LArG4::eCalculatorProcessing
eCalculatorProcessing
Definition
LArG4EnumDefs.h:10
LArG4::kEnergyAndID
@ kEnergyAndID
Definition
LArG4EnumDefs.h:10
std
STL namespace.
private
#define private
Definition
xAODTruthCnvAlg.h:20
Generated on
for ATLAS Offline Software by
1.14.0