Newer
Older
Markus Frank
committed
# ==========================================================================
# AIDA Detector description implementation
# --------------------------------------------------------------------------
# Copyright (C) Organisation europeenne pour la Recherche nucleaire (CERN)
# All rights reserved.
#
# For the licensing terms see $DD4hepINSTALL/LICENSE.
# For the list of contributors see $DD4hepINSTALL/doc/CREDITS.
#
# ==========================================================================
#
from __future__ import absolute_import, unicode_literals
import logging
#
logging.basicConfig(format='%(levelname)s: %(message)s', level=logging.INFO)
logger = logging.getLogger(__name__)
Markus Frank
committed
#
#
"""
dd4hep simulation example setup using the python configuration
@author M.Frank
@version 1.0
"""
def run():
import os
import DDG4
from DDG4 import OutputLevel as Output
from g4units import keV
args = DDG4.CommandLine()
if args.help:
import sys
logger.info("""
python <dir>/Channeling.py -option [-option]
-geometry <geometry file name> File is expected in the examples
install area:
""" + install_dir + """
-vis Enable visualization
-macro Pass G4 macro file to UI executive
-batch Run in batch mode for unit testing
-events <number> Run geant4 for specified number of events
(batch mode only)
""")
sys.exit(0)
Markus Frank
committed
kernel = DDG4.Kernel()
kernel.loadGeometry(str("file:" + install_dir + "/examples/DDG4/compact/Channeling.xml"))
DDG4.importConstants(kernel.detectorDescription(), debug=False)
geant4 = DDG4.Geant4(kernel, tracker='Geant4TrackerCombineAction')
geant4.printDetectors()
# Configure UI
if args.macro:
ui = geant4.setupCshUI(macro=args.macro, vis=args.vis)
Markus Frank
committed
else:
ui = geant4.setupCshUI(vis=args.vis)
if args.batch:
ui.Commands = ['/run/beamOn ' + str(args.events), '/ddg4/UI/terminate']
Markus Frank
committed
# Configure field
geant4.setupTrackingField(prt=True)
# Configure Event actions
prt = DDG4.EventAction(kernel, 'Geant4ParticlePrint/ParticlePrint')
prt.OutputLevel = Output.DEBUG
prt.OutputType = 3 # Print both: table and tree
kernel.eventAction().adopt(prt)
generator_output_level = Output.INFO
# Configure G4 geometry setup
seq, act = geant4.addDetectorConstruction("Geant4DetectorGeometryConstruction/ConstructGeo")
act.DebugMaterials = True
act.DebugElements = False
act.DebugVolumes = True
act.DebugShapes = True
act.DebugSurfaces = True
# Setup particle gun
gun = geant4.setupGun("Gun", particle='gamma', energy=5 * keV, multiplicity=1)
gun.OutputLevel = generator_output_level
geant4.setupTracker('ChannelingDevice')
# Now build the physics list:
phys = geant4.setupPhysics('QGSP_BERT')
ph = DDG4.PhysicsList(kernel, 'Channeling')
ph.addPhysicsConstructor(str('Geant4ChannelingPhysics'))
Markus Frank
committed
ph.enableUI()
phys.adopt(ph)
phys.dump()
Markus Frank
committed
phys.dump()
geant4.execute()
if __name__ == "__main__":
run()