DD4hep  1.30.0
Detector Description Toolkit for High Energy Physics
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
dd4hep::sim::Geant4PythonDetectorConstruction Class Reference

Base class to initialize a multi-threaded or single threaded Geant4 application. More...

#include <Geant4PythonDetectorConstruction.h>

Inheritance diagram for dd4hep::sim::Geant4PythonDetectorConstruction:
dd4hep::sim::Geant4DetectorConstruction dd4hep::sim::Geant4Action

Public Member Functions

 Geant4PythonDetectorConstruction (Geant4Context *c, const std::string &nam)
 Standard constructor. More...
 
virtual ~Geant4PythonDetectorConstruction ()
 Default destructor. More...
 
void setConstructGeo (PyObject *callable, PyObject *args)
 Set the Detector initialization command. More...
 
void setConstructField (PyObject *callable, PyObject *args)
 Set the field initialization command. More...
 
void setConstructSensitives (PyObject *callable, PyObject *args)
 Set the sensitive detector initialization command. More...
 
virtual void constructGeo (Geant4DetectorConstructionContext *ctxt) override
 Geometry construction callback. Called at "Construct()". More...
 
virtual void constructField (Geant4DetectorConstructionContext *ctxt) override
 Electromagnetic field construction callback. Called at "ConstructSDandField()". More...
 
virtual void constructSensitives (Geant4DetectorConstructionContext *ctxt) override
 Sensitive detector construction callback. Called at "ConstructSDandField()". More...
 
- Public Member Functions inherited from dd4hep::sim::Geant4DetectorConstruction
 Geant4DetectorConstruction (Geant4Context *context, const std::string &nam)
 Standard Constructor. More...
 
virtual ~Geant4DetectorConstruction ()
 Default destructor. More...
 
virtual G4VSensitiveDetectorcreateSensitiveDetector (const std::string &type, const std::string &name)
 Create Geant4 sensitive detector object using the factory mechanism. More...
 
- Public Member Functions inherited from dd4hep::sim::Geant4Action
 Geant4Action (Geant4Context *context, const std::string &nam)
 Standard constructor. More...
 
long addRef ()
 Increase reference count. More...
 
long release ()
 Decrease reference count. Implicit destruction. More...
 
Geant4Contextcontext () const
 Access the context. More...
 
virtual void updateContext (Geant4Context *ctxt)
 Set or update client context. More...
 
virtual void configureFiber (Geant4Context *thread_context)
 Set or update client for the use in a new thread fiber. More...
 
const std::string & name () const
 Access name of the action. More...
 
const char * c_name () const
 Access name of the action. More...
 
void setName (const std::string &new_name)
 Set the object name. More...
 
PropertyManagerproperties ()
 Access to the properties of the object. More...
 
PrintLevel outputLevel () const
 Access the output level. More...
 
PrintLevel setOutputLevel (PrintLevel new_level)
 Set the output level; returns previous value. More...
 
Geant4UIMessengercontrol () const
 Access to the UI messenger. More...
 
virtual void enableUI ()
 Enable and install UI messenger. More...
 
template<typename T >
Geant4ActiondeclareProperty (const std::string &nam, T &val)
 Declare property. More...
 
template<typename T >
Geant4ActiondeclareProperty (const char *nam, T &val)
 Declare property. More...
 
bool hasProperty (const std::string &name) const
 Check property for existence. More...
 
Propertyproperty (const std::string &name)
 Access single property. More...
 
virtual void installMessengers ()
 Install property control messenger if wanted. More...
 
virtual void installCommandMessenger ()
 Install command control messenger if wanted. More...
 
virtual void installPropertyMessenger ()
 Install property control messenger if wanted. More...
 
void print (const char *fmt,...) const
 Support for messages with variable output level using output level. More...
 
void printM1 (const char *fmt,...) const
 Support for messages with variable output level using output level-1. More...
 
void printM2 (const char *fmt,...) const
 Support for messages with variable output level using output level-2. More...
 
void printP1 (const char *fmt,...) const
 Support for messages with variable output level using output level+1. More...
 
void printP2 (const char *fmt,...) const
 Support for messages with variable output level using output level+2. More...
 
void always (const char *fmt,...) const
 Support of always printed messages. More...
 
void debug (const char *fmt,...) const
 Support of debug messages. More...
 
void info (const char *fmt,...) const
 Support of info messages. More...
 
void warning (const char *fmt,...) const
 Support of warning messages. More...
 
void error (const char *fmt,...) const
 Support of error messages. More...
 
bool return_error (bool return_value, const char *fmt,...) const
 Action to support error messages. More...
 
void fatal (const char *fmt,...) const
 Support of fatal messages. Throws exception. More...
 
void except (const char *fmt,...) const
 Support of exceptions: Print fatal message and throw runtime_error. More...
 
void abortRun (const std::string &exception, const char *fmt,...) const
 Abort Geant4 Run by throwing a G4Exception with type RunMustBeAborted. More...
 
Geant4RunActionSequencerunAction () const
 Access to the main run action sequence from the kernel object. More...
 
Geant4EventActionSequenceeventAction () const
 Access to the main event action sequence from the kernel object. More...
 
Geant4SteppingActionSequencesteppingAction () const
 Access to the main stepping action sequence from the kernel object. More...
 
Geant4TrackingActionSequencetrackingAction () const
 Access to the main tracking action sequence from the kernel object. More...
 
Geant4StackingActionSequencestackingAction () const
 Access to the main stacking action sequence from the kernel object. More...
 
Geant4GeneratorActionSequencegeneratorAction () const
 Access to the main generator action sequence from the kernel object. More...
 

Protected Member Functions

void exec (const std::string &desc, const Geant4PythonCall &cmd) const
 Execute command in the python interpreter. More...
 
- Protected Member Functions inherited from dd4hep::sim::Geant4Action
 DDG4_DEFINE_ACTION_CONSTRUCTORS (Geant4Action)
 Define standard assignments and constructors. More...
 
virtual ~Geant4Action ()
 Default destructor. More...
 

Protected Attributes

Geant4PythonCall m_constructSD
 Sensitive detector initialization command. Default: empty. More...
 
Geant4PythonCall m_constructFLD
 Field initialization command. Default: empty. More...
 
Geant4PythonCall m_constructGEO
 Geometry initialization command. Default: empty. More...
 
- Protected Attributes inherited from dd4hep::sim::Geant4Action
Geant4Contextm_context { nullptr }
 Reference to the Geant4 context. More...
 
Geant4UIMessengerm_control { nullptr }
 Control directory of this action. More...
 
int m_outputLevel { 3 }
 Default property: Output level. More...
 
bool m_needsControl { false }
 Default property: Flag to create control instance. More...
 
std::string m_name { }
 Action name. More...
 
PropertyManager m_properties { }
 Property pool. More...
 
long m_refCount { 1 }
 Reference count. Initial value: 1. More...
 

Detailed Description

Base class to initialize a multi-threaded or single threaded Geant4 application.

Geant4PythonDetectorConstruction is the corresponding python action to populate the detector construction sequencer. and supports three ccallbacks:

// Set the Detector initialization command
void setConstructGeo(PyObject* callable, PyObject* args);
// Set the field initialization command
void setConstructField(PyObject* callable, PyObject* args);
// Set the sensitive detector initialization command
void setConstructSensitives(PyObject* callable, PyObject* args);

to be used in python as call sequence within the master thread:

init_seq = self.master().detectorConstruction(True) init_action = DetectorConstruction(self.master(),name_type) init_action.setConstructGeo(geometry_setup_call, < geometry_args > ) init_action.setConstructField(field_setup_call, < field_args > ) init_action.setConstructSensitives(sensitives_setup_call, < sensitives_args >) init_seq.adopt(init_action)

If any of the three callback is not set, the corresponding actiion is not executed. Hereby are geometry_setup_call, field_setup_call and sensitives_setup_call the callable objects to configure the geometry, the tracking field and the sensitive detectors. < geometry_args >, < field_args > and < sensitives_args > are the corresponding callable arguments in the form of a python tuple object.

All python callbacks are supposed to return the integer '1' on success. Any other return code is assumed to be failure.

Author
M.Frank
Version
1.0

Definition at line 63 of file Geant4PythonDetectorConstruction.h.

Constructor & Destructor Documentation

◆ Geant4PythonDetectorConstruction()

Geant4PythonDetectorConstruction::Geant4PythonDetectorConstruction ( Geant4Context c,
const std::string &  nam 
)

Standard constructor.

Standard constructor, initializes variables.

Definition at line 28 of file Geant4PythonDetectorConstruction.cpp.

◆ ~Geant4PythonDetectorConstruction()

virtual dd4hep::sim::Geant4PythonDetectorConstruction::~Geant4PythonDetectorConstruction ( )
inlinevirtual

Default destructor.

Definition at line 78 of file Geant4PythonDetectorConstruction.h.

Member Function Documentation

◆ constructField()

void Geant4PythonDetectorConstruction::constructField ( Geant4DetectorConstructionContext ctxt)
overridevirtual

Electromagnetic field construction callback. Called at "ConstructSDandField()".

Callback function to build setup for the MT master thread.

Reimplemented from dd4hep::sim::Geant4DetectorConstruction.

Definition at line 69 of file Geant4PythonDetectorConstruction.cpp.

◆ constructGeo()

void Geant4PythonDetectorConstruction::constructGeo ( Geant4DetectorConstructionContext ctxt)
overridevirtual

Geometry construction callback. Called at "Construct()".

Callback function to build setup for the MT worker thread.

Reimplemented from dd4hep::sim::Geant4DetectorConstruction.

Definition at line 61 of file Geant4PythonDetectorConstruction.cpp.

◆ constructSensitives()

void Geant4PythonDetectorConstruction::constructSensitives ( Geant4DetectorConstructionContext ctxt)
overridevirtual

Sensitive detector construction callback. Called at "ConstructSDandField()".

Callback function to build setup for the MT master thread.

Reimplemented from dd4hep::sim::Geant4DetectorConstruction.

Definition at line 76 of file Geant4PythonDetectorConstruction.cpp.

◆ exec()

void Geant4PythonDetectorConstruction::exec ( const std::string &  desc,
const Geant4PythonCall cmd 
) const
protected

Execute command in the python interpreter.

Definition at line 51 of file Geant4PythonDetectorConstruction.cpp.

◆ setConstructField()

void Geant4PythonDetectorConstruction::setConstructField ( PyObject *  callable,
PyObject *  args 
)

Set the field initialization command.

Definition at line 41 of file Geant4PythonDetectorConstruction.cpp.

◆ setConstructGeo()

void Geant4PythonDetectorConstruction::setConstructGeo ( PyObject *  callable,
PyObject *  args 
)

Set the Detector initialization command.

Definition at line 36 of file Geant4PythonDetectorConstruction.cpp.

◆ setConstructSensitives()

void Geant4PythonDetectorConstruction::setConstructSensitives ( PyObject *  callable,
PyObject *  args 
)

Set the sensitive detector initialization command.

Definition at line 46 of file Geant4PythonDetectorConstruction.cpp.

Member Data Documentation

◆ m_constructFLD

Geant4PythonCall dd4hep::sim::Geant4PythonDetectorConstruction::m_constructFLD
protected

Field initialization command. Default: empty.

Definition at line 68 of file Geant4PythonDetectorConstruction.h.

◆ m_constructGEO

Geant4PythonCall dd4hep::sim::Geant4PythonDetectorConstruction::m_constructGEO
protected

Geometry initialization command. Default: empty.

Definition at line 70 of file Geant4PythonDetectorConstruction.h.

◆ m_constructSD

Geant4PythonCall dd4hep::sim::Geant4PythonDetectorConstruction::m_constructSD
protected

Sensitive detector initialization command. Default: empty.

Definition at line 66 of file Geant4PythonDetectorConstruction.h.


The documentation for this class was generated from the following files: