Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2025-03-13 02:32:03

0001 ###############################################################################
0002 # Way to use this:
0003 #   cmsRun g4OverlapCheck2021_cfg.py geometry=2021 tol=0.1
0004 #
0005 #   Options for geometry 2018, 2021, 2023, 2024, 2025, 2025N, 2025P, 2025Q,
0006 #                        2025R
0007 #           for tol      0.01, 0.1, 1.0
0008 #
0009 ###############################################################################
0010 import FWCore.ParameterSet.Config as cms
0011 import os, sys, importlib, re
0012 import FWCore.ParameterSet.VarParsing as VarParsing
0013 
0014 ####################################################################
0015 ### SETUP OPTIONS
0016 options = VarParsing.VarParsing('standard')
0017 options.register('geometry',
0018                  "2021",
0019                   VarParsing.VarParsing.multiplicity.singleton,
0020                   VarParsing.VarParsing.varType.string,
0021                   "geometry of operations: 2018, 2021, 2023, 2024, 2025, 2025N,, 2025P, 2025Q, 2025R")
0022 options.register('tol',
0023                  0.01,
0024                  VarParsing.VarParsing.multiplicity.singleton,
0025                  VarParsing.VarParsing.varType.float,
0026                  "Tolerance for checking overlaps: 0.01, 0.1, 1.0"
0027 )
0028 
0029 ### get and parse the command line arguments
0030 options.parseArguments()
0031 
0032 print(options)
0033 
0034 ####################################################################
0035 # Use the options
0036 geomName = "Geometry.MuonCommonData.testExtendedGeometry" + options.geometry + "XML_cfi"
0037 baseName = "GeometryExtended" + options.geometry + str(options.tol)
0038 
0039 print("Geometry file: ", geomName)
0040 print("Base name:     ", baseName)
0041 
0042 if (options.geometry == "2018"):
0043     from Configuration.Eras.Era_Run2_2018_cff import Run2_2018
0044     process = cms.Process('OverlapCheck',Run2_2018)
0045 else:
0046     from Configuration.Eras.Era_Run3_DDD_cff import Run3_DDD
0047     process = cms.Process('OverlapCheck',Run3_DDD)
0048 
0049 process.load(geomName)
0050 process.load("Geometry.TrackerNumberingBuilder.trackerNumberingGeometry_cff")
0051 process.load("Geometry.EcalCommonData.ecalSimulationParameters_cff")
0052 process.load("Geometry.HcalCommonData.hcalDDDSimConstants_cff")
0053 process.load("Geometry.MuonNumbering.muonGeometryConstants_cff")
0054 process.load("Geometry.MuonNumbering.muonOffsetESProducer_cff")
0055 process.load('FWCore.MessageService.MessageLogger_cfi')
0056 
0057 from SimG4Core.PrintGeomInfo.g4TestGeometry_cfi import *
0058 process = checkOverlap(process)
0059 
0060 #process.MessageLogger.SimG4CoreGeometry=dict()
0061 
0062 # enable Geant4 overlap check 
0063 process.g4SimHits.CheckGeometry = True
0064 
0065 # Geant4 geometry check 
0066 process.g4SimHits.G4CheckOverlap.OutputBaseName = cms.string(baseName)
0067 process.g4SimHits.G4CheckOverlap.OverlapFlag = cms.bool(True)
0068 process.g4SimHits.G4CheckOverlap.Tolerance  = cms.double(options.tol)
0069 process.g4SimHits.G4CheckOverlap.Resolution = cms.int32(10000)
0070 process.g4SimHits.G4CheckOverlap.Depth      = cms.int32(-1)
0071 # tells if NodeName is G4Region or G4PhysicalVolume
0072 process.g4SimHits.G4CheckOverlap.RegionFlag = cms.bool(False)
0073 # list of names
0074 process.g4SimHits.G4CheckOverlap.NodeNames  = cms.vstring('OCMS')
0075 # enable dump gdml file 
0076 process.g4SimHits.G4CheckOverlap.gdmlFlag   = cms.bool(False)
0077 # if defined a G4PhysicsVolume info is printed
0078 process.g4SimHits.G4CheckOverlap.PVname     = ''
0079 # if defined a list of daughter volumes is printed
0080 process.g4SimHits.G4CheckOverlap.LVname     = ''
0081 
0082 # extra output files, created if a name is not empty
0083 process.g4SimHits.FileNameField   = ''
0084 process.g4SimHits.FileNameGDML    = ''
0085 process.g4SimHits.FileNameRegions = ''
0086 #