Warning, /detector_benchmarks/benchmarks/ecal_gaps/Snakefile is written in an unsupported language. File is not indexed.
0001 import os
0002
0003
0004 rule ecal_gaps_sim:
0005 input:
0006 steering_file="EPIC/EVGEN/SINGLE/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.steer",
0007 warmup=ancient("warmup/{DETECTOR_CONFIG}.edm4hep.root"),
0008 geometry_lib=find_epic_libraries(),
0009 output:
0010 "sim_output/ecal_gaps/{DETECTOR_CONFIG}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX}.edm4hep.root",
0011 log:
0012 "sim_output/ecal_gaps/{DETECTOR_CONFIG}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX}.edm4hep.root.log",
0013 wildcard_constraints:
0014 PARTICLE="e-",
0015 ENERGY="(500MeV|5GeV|20GeV)",
0016 PHASE_SPACE="(3to50|45to135|130to177)deg",
0017 INDEX=r"\d{4}",
0018 params:
0019 N_EVENTS=1000,
0020 SEED=lambda wildcards: "1" + wildcards.INDEX,
0021 DETECTOR_PATH=os.environ["DETECTOR_PATH"],
0022 DETECTOR_CONFIG=lambda wildcards: wildcards.DETECTOR_CONFIG,
0023 DD4HEP_HASH=get_spack_package_hash("dd4hep"),
0024 NPSIM_HASH=get_spack_package_hash("npsim"),
0025 cache: True
0026 shell:
0027 """
0028 set -m # monitor mode to prevent lingering processes
0029 exec ddsim \
0030 --runType batch \
0031 --enableGun \
0032 --steeringFile "{input.steering_file}" \
0033 --random.seed {params.SEED} \
0034 --filter.tracker edep0 \
0035 -v WARNING \
0036 --numberOfEvents {params.N_EVENTS} \
0037 --compactFile {params.DETECTOR_PATH}/{params.DETECTOR_CONFIG}.xml \
0038 --outputFile {output}
0039 """
0040
0041
0042 rule ecal_gaps_recon:
0043 input:
0044 "sim_output/ecal_gaps/{DETECTOR_CONFIG}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX}.edm4hep.root",
0045 warmup=ancient("warmup/{DETECTOR_CONFIG}.edm4hep.root"),
0046 output:
0047 "sim_output/ecal_gaps/{DETECTOR_CONFIG}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX}.eicrecon.edm4eic.root",
0048 log:
0049 "sim_output/ecal_gaps/{DETECTOR_CONFIG}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX}.eicrecon.edm4eic.root.log",
0050 wildcard_constraints:
0051 INDEX=r"\d{4}",
0052 params:
0053 DETECTOR_CONFIG=lambda wildcards: wildcards.DETECTOR_CONFIG,
0054 EICRECON_HASH=get_spack_package_hash("eicrecon"),
0055 cache: True
0056 shell: """
0057 set -m # monitor mode to prevent lingering processes
0058 exec env DETECTOR_CONFIG={params.DETECTOR_CONFIG} \
0059 eicrecon {input} -Ppodio:output_file={output} \
0060 -Ppodio:output_collections=EcalEndcapNRecHits,EcalBarrelScFiRecHits,EcalBarrelImagingRecHits,EcalEndcapPRecHits,MCParticles
0061 """
0062
0063
0064 rule ecal_gaps:
0065 input:
0066 matplotlibrc=".matplotlibrc",
0067 script="benchmarks/ecal_gaps/ecal_gaps.py",
0068 # TODO pass as a file list?
0069 _=expand(
0070 "sim_output/ecal_gaps/{{DETECTOR_CONFIG}}/{PARTICLE}/{ENERGY}/{PHASE_SPACE}/{PARTICLE}_{ENERGY}_{PHASE_SPACE}.{INDEX:04d}.eicrecon.edm4eic.root",
0071 PARTICLE=["e-"],
0072 ENERGY=["500MeV", "5GeV", "20GeV"],
0073 PHASE_SPACE=["3to50deg", "45to135deg", "130to177deg"],
0074 INDEX=range(1),
0075 ),
0076 output:
0077 directory("results/{DETECTOR_CONFIG}/ecal_gaps"),
0078 log:
0079 scheduler=".logs/results/{DETECTOR_CONFIG}/ecal_gaps/scheduler.log",
0080 worker=".logs/results/{DETECTOR_CONFIG}/ecal_gaps/worker.log",
0081 threads: workflow.cores
0082 shell:
0083 """
0084 set -m # monitor mode to prevent lingering shells
0085 cleanup() {{
0086 echo Cleaning up
0087 kill $WORKER_PID $SCHEDULER_PID
0088 }}
0089 trap cleanup EXIT
0090
0091 PORT=$RANDOM
0092 dask scheduler --port $PORT 2>{log.scheduler} &
0093 export DASK_SCHEDULER=localhost:$PORT
0094 SCHEDULER_PID=$!
0095 dask worker tcp://$DASK_SCHEDULER --nworkers {threads} --nthreads 1 2>{log.worker} &
0096 WORKER_PID=$!
0097 env \
0098 MATPLOTLIBRC={input.matplotlibrc} \
0099 OUTPUT_DIR={output} \
0100 DETECTOR_CONFIG={wildcards.DETECTOR_CONFIG} \
0101 python {input.script}
0102 """