Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2024-04-06 12:15:17

0001 ###############################################################################
0002 # Way to use this:
0003 #   cmsRun g4OverlapCheckGE0_cfg.py geometry=Test tol=0.1
0004 #
0005 #   Options for geometry Test, D99
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                  "Test",
0017                   VarParsing.VarParsing.multiplicity.singleton,
0018                   VarParsing.VarParsing.varType.string,
0019                   "geometry of operations: Test, D99")
0020 options.register('tol',
0021                  0.1,
0022                  VarParsing.VarParsing.multiplicity.singleton,
0023                  VarParsing.VarParsing.varType.float,
0024                  "Tolerance for checking overlaps: 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 from Configuration.Eras.Era_Phase2C17I13M9_cff import Phase2C17I13M9
0036 process = cms.Process('OverlapCheck',Phase2C17I13M9)
0037 
0038 if (options.geometry == "Test"):
0039     geomFile = "Geometry.MuonCommonData.testGE0XML_cfi"
0040 else:
0041     geomFile = "Geometry.MuonCommonData.cmsExtendedGeometry2026D99XML_cfi"
0042 
0043 baseName = "cms2026" + options.geometry + "DDD"
0044 
0045 print("Geometry file Name: ", geomFile)
0046 print("Base file Name:     ", baseName)
0047 
0048 process.load(geomFile)
0049 if (options.geometry == "Test"):
0050     process.load("Geometry.MuonNumbering.muonGeometryConstants_cff")
0051     process.load("Geometry.MuonNumbering.muonOffsetESProducer_cff")
0052 else:
0053     process.load("Geometry.TrackerNumberingBuilder.trackerNumberingGeometry_cff")
0054     process.load("SLHCUpgradeSimulations.Geometry.fakePhase2OuterTrackerConditions_cff")
0055     process.load("Geometry.EcalCommonData.ecalSimulationParameters_cff")
0056     process.load("Geometry.HcalCommonData.hcalDDDSimConstants_cff")
0057     process.load("Geometry.HGCalCommonData.hgcalParametersInitialization_cfi")
0058     process.load("Geometry.HGCalCommonData.hgcalNumberingInitialization_cfi")
0059     process.load("Geometry.MuonNumbering.muonGeometryConstants_cff")
0060     process.load("Geometry.MuonNumbering.muonOffsetESProducer_cff")
0061     process.load("Geometry.MTDNumberingBuilder.mtdNumberingGeometry_cff")
0062 
0063 process.load('FWCore.MessageService.MessageLogger_cfi')
0064 
0065 from SimG4Core.PrintGeomInfo.g4TestGeometry_cfi import *
0066 process = checkOverlap(process)
0067 
0068 #if hasattr(process,'MessageLogger'):
0069 #    process.MessageLogger.SimG4CoreGeometry=dict()
0070 
0071 # enable Geant4 overlap check 
0072 process.g4SimHits.CheckGeometry = True
0073 
0074 # Geant4 geometry check 
0075 process.g4SimHits.G4CheckOverlap.OutputBaseName = cms.string(baseName)
0076 process.g4SimHits.G4CheckOverlap.OverlapFlag = cms.bool(True)
0077 process.g4SimHits.G4CheckOverlap.Tolerance  = cms.double(options.tol)
0078 process.g4SimHits.G4CheckOverlap.Resolution = cms.int32(10000)
0079 process.g4SimHits.G4CheckOverlap.Depth      = cms.int32(-1)
0080 # tells if NodeName is G4Region or G4PhysicalVolume
0081 process.g4SimHits.G4CheckOverlap.RegionFlag = cms.bool(False)
0082 # list of names
0083 process.g4SimHits.G4CheckOverlap.NodeNames  = cms.vstring('OCMS')
0084 # enable dump gdml file 
0085 process.g4SimHits.G4CheckOverlap.gdmlFlag   = cms.bool(False)
0086 # if defined a G4PhysicsVolume info is printed
0087 process.g4SimHits.G4CheckOverlap.PVname     = ''
0088 # if defined a list of daughter volumes is printed
0089 process.g4SimHits.G4CheckOverlap.LVname     = ''
0090 
0091 # extra output files, created if a name is not empty
0092 process.g4SimHits.FileNameField   = ''
0093 process.g4SimHits.FileNameGDML    = ''
0094 process.g4SimHits.FileNameRegions = ''
0095 #