Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:30:30

0001 ###############################################################################
0002 # Way to use this:
0003 #   cmsRun g4OverlapCheckMuon_cfg.py geometry=2021 tol=0.1
0004 #
0005 #   Options for geometry 2016, 2017, 2021, 2026D88, 2026D92, 2026D93, 2026D99
0006 #
0007 ###############################################################################
0008 import FWCore.ParameterSet.Config as cms
0009 import os, sys, importlib, re
0010 import FWCore.ParameterSet.VarParsing as VarParsing
0011 
0012 ####################################################################
0013 ### SETUP OPTIONS
0014 options = VarParsing.VarParsing('standard')
0015 options.register('geometry',
0016                  "2021",
0017                   VarParsing.VarParsing.multiplicity.singleton,
0018                   VarParsing.VarParsing.varType.string,
0019                   "geometry of operations: 2016, 2017, 2021, 2026D88, 2026D92, 2026D93, 2026D99")
0020 options.register('tol',
0021                  0.1,
0022                  VarParsing.VarParsing.multiplicity.singleton,
0023                  VarParsing.VarParsing.varType.float,
0024                  "Tolerance for checking overlaps: 0.0, 0.01, 0.1, 1.0"
0025 )
0026 
0027 ### get and parse the command line arguments
0028 options.parseArguments()
0029 
0030 print(options)
0031 
0032 ####################################################################
0033 # Use the options
0034 
0035 if (options.geometry == "2026D88"):
0036     from Configuration.Eras.Era_Phase2C17I13M9_cff import Phase2C17I13M9
0037     process = cms.Process('G4PrintGeometry',Phase2C17I13M9)
0038     process.load('Configuration.Geometry.GeometryExtended2026D88Reco_cff')
0039     baseName = 'Muon2026D88'
0040 elif (options.geometry == "2026D92"):
0041     from Configuration.Eras.Era_Phase2C17I13M9_cff import Phase2C17I13M9
0042     process = cms.Process('G4PrintGeometry',Phase2C17I13M9)
0043     process.load('Configuration.Geometry.GeometryExtended2026D92Reco_cff')
0044     baseName = 'Muon2026D92'
0045 elif (options.geometry == "2026D93"):
0046     from Configuration.Eras.Era_Phase2C17I13M9_cff import Phase2C17I13M9
0047     process = cms.Process('G4PrintGeometry',Phase2C17I13M9)
0048     process.load('Configuration.Geometry.GeometryExtended2026D93Reco_cff')
0049     baseName = 'Muon2026D93'
0050 elif (options.geometry == "2026D99"):
0051     from Configuration.Eras.Era_Phase2C17I13M9_cff import Phase2C17I13M9
0052     process = cms.Process('G4PrintGeometry',Phase2C17I13M9)
0053     process.load('Configuration.Geometry.GeometryExtended2026D99Reco_cff')
0054     baseName = 'Muon2026D99'
0055 elif (options.geometry == "2016"):
0056     from Configuration.Eras.Era_Run2_2016_cff import Run2_2016
0057     process = cms.Process('G4PrintGeometry',Run2_2016)
0058     process.load('Configuration.Geometry.GeometryExtended2016Reco_cff')
0059     baseName = 'Muon2016'
0060 elif (options.geometry == "2017"):
0061     from Configuration.Eras.Era_Run2_2017_cff import Run2_2017
0062     process = cms.Process('G4PrintGeometry',Run2_2017)
0063     process.load('Configuration.Geometry.GeometryExtended2017Reco_cff')
0064     baseName = 'Muon2017'
0065 else:
0066     from Configuration.Eras.Era_Run3_DDD_cff import Run3_DDD
0067     process = cms.Process('G4PrintGeometry',Run3_DDD)
0068     process.load('Configuration.Geometry.GeometryExtended2021Reco_cff')
0069     baseName = 'Muon2021'
0070 
0071 print("Base file Name: ", baseName)
0072 
0073 from SimG4Core.PrintGeomInfo.g4TestGeometry_cfi import *
0074 process = checkOverlap(process)
0075 
0076 # enable Geant4 overlap check 
0077 process.g4SimHits.CheckGeometry = True
0078 
0079 # Geant4 geometry check 
0080 process.g4SimHits.G4CheckOverlap.OutputBaseName = cms.string(baseName)
0081 process.g4SimHits.G4CheckOverlap.OverlapFlag = cms.bool(True)
0082 process.g4SimHits.G4CheckOverlap.Tolerance  = cms.double(options.tol)
0083 process.g4SimHits.G4CheckOverlap.Resolution = cms.int32(10000)
0084 process.g4SimHits.G4CheckOverlap.Depth      = cms.int32(-1)
0085 # tells if NodeName is G4Region or G4PhysicalVolume
0086 process.g4SimHits.G4CheckOverlap.RegionFlag = cms.bool(False)
0087 # list of names
0088 process.g4SimHits.G4CheckOverlap.NodeNames  = cms.vstring('OCMS')
0089 # enable dump gdml file 
0090 process.g4SimHits.G4CheckOverlap.gdmlFlag   = cms.bool(False)
0091 # if defined a G4PhysicsVolume info is printed
0092 process.g4SimHits.G4CheckOverlap.PVname     = ''
0093 # if defined a list of daughter volumes is printed
0094 process.g4SimHits.G4CheckOverlap.LVname     = ''
0095 
0096 # extra output files, created if a name is not empty
0097 process.g4SimHits.FileNameField   = ''
0098 process.g4SimHits.FileNameGDML    = ''
0099 process.g4SimHits.FileNameRegions = ''