Skip to content
Snippets Groups Projects
Select Git revision
  • 069cf6664762e66422bde0b0ebedd8f9840fac87
  • master default protected
  • palspeic-master-patch-91700
  • 144-irt-geometry
  • deathvalley-acts-dd4hep-plugin
  • canyonlands-acts-dd4hep-plugin
  • 148-hcal-geometry-development
  • adjust-barrel-emcalo-geometry
  • 148-hcal-geometry-development-wdconinc-suggestion
  • WorkingGemTrd_MLmodel_andAnalysis
  • 144-test-small-sensor-overlap
  • 59-detailed-forward-gem-trd
  • vdesai-master-patch-09582
  • mriganka-branch02
  • zdemirog-master-patch-64142
  • weibin-master-patch-37475
  • vanekjan-master-patch-74522
  • lkosarzew-master-patch-25029
  • swapneshkhade-master-patch-16755
  • mlavinsky-master-patch-10431
  • niveditharam-master-patch-05822
  • deathvalley-v1.1
  • deathvalley-v1.0-1.5T
  • deathvalley-v1.0
  • canyonlands-v2.2
  • canyonlands-v2.1
  • canyonlands-v2.0
  • canyonlands-v1.2
  • canyonlands-v1.1
  • acadia-v2.1
  • canyonlands-v1.0
  • acadia-v2.0
  • acadia-v1.1
  • acadia-v1.0
  • acadia-v1.0-alpha
  • v0.2.0
  • v0.1.0
37 results

checkOverlaps.py

Blame
  • Forked from EIC / detectors / athena
    158 commits behind the upstream repository.
    checkOverlaps.py 1.36 KiB
    from __future__ import absolute_import, unicode_literals
    import os
    import time
    import logging
    
    import argparse
    parser = argparse.ArgumentParser(
         prog='checkOverlaps.py',
         description='''Check for overlaps using Geant4''',
         epilog='''
         This program checks the compact detector file for overlaps using Geant4.
             ''')
    parser.add_argument("-c", "--compact", help="compact detector file",default="athena.xml")
    parser.add_argument("-r", "--resolution", help="number of points on surface",default="10000")
    parser.add_argument("-t", "--tolerance", help="minimum distance (in mm) to report overlaps",default="0.1")
    parser.add_argument("-v", "--verbose", help="print output", action='store_true')
    
    args = parser.parse_args()
    
    import DDG4
    from g4units import keV, GeV, mm, ns, MeV
    
    def run():
      kernel = DDG4.Kernel()
      description = kernel.detectorDescription()
      kernel.loadGeometry(str("file:" + args.compact))
    
      DDG4.importConstants(description)
    
      geant4 = DDG4.Geant4(kernel)
      ui = geant4.setupCshUI(ui=None)
      ui.Commands = [
          '/geometry/test/resolution {}'.format(args.resolution),
          '/geometry/test/tolerance {}'.format(args.tolerance),
          '/geometry/test/verbosity {}'.format(1 if args.verbose else 0),
          '/geometry/test/run'
          ]
      kernel.configure()
      kernel.initialize()
      kernel.run()
      kernel.terminate()
    
    
    if __name__ == "__main__":
      run()