![]() |
ATLAS Offline Software
|
The Formula used is the highland formula for the projected scattering angle : More...
#include <MultipleScatteringUpdator.h>
Public Member Functions | |
| MultipleScatteringUpdator (const std::string &, const std::string &, const IInterface *) | |
| AlgTool like constructor. | |
| virtual | ~MultipleScatteringUpdator () |
| Virtual destructor. | |
| virtual StatusCode | initialize () override |
| AlgTool initailize method. | |
| virtual double | sigmaSquare (const MaterialProperties &mat, double p, double pathcorrection, ParticleHypothesis particle=pion, double deltaE=0.) const override |
| Calculate the sigma on theta introduced by multiple scattering, according to the RutherFord-Scott Formula. | |
| ServiceHandle< StoreGateSvc > & | evtStore () |
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. | |
| const ServiceHandle< StoreGateSvc > & | detStore () const |
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. | |
| virtual StatusCode | sysInitialize () override |
| Perform system initialization for an algorithm. | |
| virtual StatusCode | sysStart () override |
| Handle START transition. | |
| virtual std::vector< Gaudi::DataHandle * > | inputHandles () const override |
| Return this algorithm's input handles. | |
| virtual std::vector< Gaudi::DataHandle * > | outputHandles () const override |
| Return this algorithm's output handles. | |
| Gaudi::Details::PropertyBase & | declareProperty (Gaudi::Property< T, V, H > &t) |
| void | updateVHKA (Gaudi::Details::PropertyBase &) |
| MsgStream & | msg () const |
| bool | msgLvl (const MSG::Level lvl) const |
| virtual void | validationAction () const |
| Validation Action: Can be implemented optionally, outside access to internal validation steps. | |
Static Public Member Functions | |
| static const InterfaceID & | interfaceID () |
| AlgTool and IAlgTool interface methods. | |
Protected Member Functions | |
| void | renounceArray (SG::VarHandleKeyArray &handlesArray) |
| remove all handles from I/O resolution | |
| std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > | renounce (T &h) |
| void | extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps) |
| Add StoreName to extra input/output deps as needed. | |
Private Types | |
| typedef ServiceHandle< StoreGateSvc > | StoreGateSvc_t |
Private Member Functions | |
| Gaudi::Details::PropertyBase & | declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &) |
| specialization for handling Gaudi::Property<SG::VarHandleKey> | |
Private Attributes | |
| BooleanProperty | m_useTrkUtils |
| BooleanProperty | m_log_include |
| BooleanProperty | m_gaussianMixture |
| BooleanProperty | m_optGaussianMixtureG4 |
| ServiceHandle< IAthRNGSvc > | m_rndGenSvc |
| Random Generator service. | |
| ATHRNG::RNGWrapper * | m_rngWrapper = nullptr |
| Random engine. | |
| StringProperty | m_randomEngineName |
| StoreGateSvc_t | m_evtStore |
| Pointer to StoreGate (event store by default) | |
| StoreGateSvc_t | m_detStore |
| Pointer to StoreGate (detector store by default) | |
| std::vector< SG::VarHandleKeyArray * > | m_vhka |
| bool | m_varHandleArraysDeclared |
The Formula used is the highland formula for the projected scattering angle :
\( \theta_{ms} = \frac{13.6MeV}{p}\cdot\sqrt{t/X_{0}}[1 + 0.038\ln(t/X_{0})] \)
What is returned is the square of the expectation value of the deflection \( < (\theta_ms)^2 > = \sigma_ms^2 \)
Definition at line 42 of file MultipleScatteringUpdator.h.
|
privateinherited |
Definition at line 388 of file AthCommonDataStore.h.
| Trk::MultipleScatteringUpdator::MultipleScatteringUpdator | ( | const std::string & | t, |
| const std::string & | n, | ||
| const IInterface * | p ) |
AlgTool like constructor.
Definition at line 47 of file MultipleScatteringUpdator.cxx.
|
virtualdefault |
Virtual destructor.
|
inlineprivateinherited |
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition at line 156 of file AthCommonDataStore.h.
|
inlineinherited |
Definition at line 145 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 95 of file AthCommonDataStore.h.
|
inlineinherited |
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition at line 85 of file AthCommonDataStore.h.
|
protectedinherited |
Add StoreName to extra input/output deps as needed.
use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given
|
overridevirtual |
AlgTool initailize method.
Definition at line 59 of file MultipleScatteringUpdator.cxx.
|
overridevirtualinherited |
Return this algorithm's input handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
|
inlinestaticinherited |
AlgTool and IAlgTool interface methods.
Definition at line 36 of file IMultipleScatteringUpdator.h.
|
inlineinherited |
Definition at line 24 of file AthCommonMsg.h.
|
inlineinherited |
Definition at line 30 of file AthCommonMsg.h.
|
overridevirtualinherited |
Return this algorithm's output handles.
We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.
|
inlineprotectedinherited |
Definition at line 380 of file AthCommonDataStore.h.
|
inlineprotectedinherited |
remove all handles from I/O resolution
Definition at line 364 of file AthCommonDataStore.h.
|
overridevirtual |
Calculate the sigma on theta introduced by multiple scattering, according to the RutherFord-Scott Formula.
Implements Trk::IMultipleScatteringUpdator.
Definition at line 88 of file MultipleScatteringUpdator.cxx.
|
overridevirtualinherited |
Perform system initialization for an algorithm.
We override this to declare all the elements of handle key arrays at the end of initialization. See comments on updateVHKA.
Reimplemented in asg::AsgMetadataTool, AthCheckedComponent< AthAlgTool >, AthCheckedComponent<::AthAlgTool >, and DerivationFramework::CfAthAlgTool.
|
overridevirtualinherited |
Handle START transition.
We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.
|
inlineinherited |
Definition at line 308 of file AthCommonDataStore.h.
|
inlinevirtualinherited |
Validation Action: Can be implemented optionally, outside access to internal validation steps.
Definition at line 48 of file IMultipleScatteringUpdator.h.
|
privateinherited |
Pointer to StoreGate (detector store by default)
Definition at line 393 of file AthCommonDataStore.h.
|
privateinherited |
Pointer to StoreGate (event store by default)
Definition at line 390 of file AthCommonDataStore.h.
|
private |
Definition at line 71 of file MultipleScatteringUpdator.h.
|
private |
Definition at line 69 of file MultipleScatteringUpdator.h.
|
private |
Definition at line 73 of file MultipleScatteringUpdator.h.
|
private |
Definition at line 82 of file MultipleScatteringUpdator.h.
|
private |
Random Generator service.
Definition at line 78 of file MultipleScatteringUpdator.h.
|
private |
Random engine.
Definition at line 81 of file MultipleScatteringUpdator.h.
|
private |
Definition at line 67 of file MultipleScatteringUpdator.h.
|
privateinherited |
Definition at line 399 of file AthCommonDataStore.h.
|
privateinherited |
Definition at line 398 of file AthCommonDataStore.h.