#!/usr/bin/env python3 # Main driver to run raser # Author FU Chenxi <1256257282@qq.com>, SHI Xin <shixin@ihep.ac.cn> # Created [2023-08-29 Tue 11:48] import sys import argparse import importlib import subprocess VERSION = 4.0 parser = argparse.ArgumentParser(prog='raser') parser.add_argument('--version', action='version', version='%(prog)s {}'.format(VERSION)) parser.add_argument('-b', '--batch', help='submit BATCH job to cluster', action="store_true") parser.add_argument('-t', '--test', help='TEST', action="store_true") parser.add_argument('-sh', '--shell', help='flag of run raser in SHELL', action="store_true") subparsers = parser.add_subparsers(help='sub-command help', dest="subparser_name") parser_asic = subparsers.add_parser('asic', help='ASIC design') parser_asic.add_argument('label', help='LABEL to identify ASIC design') parser_cce = subparsers.add_parser('cce', help='Charge Collection Efficiency') parser_cce.add_argument('label', help='LABEL to identify CCE experiment') parser_draw = subparsers.add_parser('current', help='calculate drift current') parser_draw.add_argument('label', help='LABEL to identify root files') parser_gsignal = subparsers.add_parser('elec', help='electronic readout') parser_gsignal.add_argument('label', help='LABEL to identify electronics files') parser_field = subparsers.add_parser('field', help='calculate field/weight field and iv/cv') parser_field.add_argument('label', help='LABEL to identify operation') parser_field.add_argument('-v', '--verbose', help='VERBOSE level', action='count', default=0) parser_field.add_argument('-cv', help='CV simulation', action="store_true") parser_field.add_argument("-wf", help="WeightField Simulation", action="store_true") parser_fpga = subparsers.add_parser('fpga', help='FPGA design') parser_fpga.add_argument('label', help='LABEL to identify FPGA design') parser_gen_signal = subparsers.add_parser('gen_signal', help='generate signal') parser_gen_signal.add_argument('det_name', help='name of the detector') parser_gen_signal.add_argument('-l','--label', help='LABEL to identify signal generation method', default='signal') parser_gen_signal.add_argument('-vol', '--voltage', type=str, help='bias voltage') parser_gen_signal.add_argument('-abs', '--absorber', type=str, help='model of particle energy absorber') parser_gen_signal.add_argument('-amp', '--amplifier', type=str, help='amplifier') parser_gen_signal.add_argument('-s', '--scan', type=int, help='instance number for scan mode') parser_spaceres = subparsers.add_parser('spaceres', help='space resolution calculation') parser_spaceres.add_argument('label', help='LABEL to identify spaceres files') parser_spaceres = subparsers.add_parser('timeres', help='time resolution calculation') parser_spaceres.add_argument('det_name', help='name of the detector') parser_tct = subparsers.add_parser('tct', help='TCT simulation') parser_tct.add_argument('label', help='LABEL to identify TCT options') parser_tct.add_argument('det_name', help='name of the detector') parser_tct.add_argument('laser', help='name of the laser') parser_tct.add_argument('-vol', '--voltage', type=str, help='bias voltage') parser_tct.add_argument('-amp', '--amplifier', type=str, help='amplifier') parser_tct.add_argument('-s', '--scan', type=int, help='instance number for scan mode') args = parser.parse_args() if len(sys.argv) == 1: parser.print_help() sys.exit(1) kwargs = vars(args) submodules = ['asic', 'cce', 'current', 'draw', 'elec', 'field', 'fpga', 'gen_signal', 'particle', 'spaceres', 'tct', 'timeres'] submodule = kwargs['subparser_name'] if submodule not in submodules: raise NameError(submodule) if kwargs['batch'] == True: from util import batchjob destination = submodule command = ' '.join(sys.argv[1:]) command = command.replace('--batch ', '') command = command.replace('-b ', '') batchjob.main(destination, command, args) elif kwargs['shell'] == False: # not in shell try: for package in ['ROOT', 'geant4_pybind', 'devsim', 'numpy', 'scipy']: # package dependency check import package submodule = importlib.import_module(submodule) submodule.main(kwargs) except ModuleNotFoundError: # use apptainer instead command = ' '.join(['-sh']+sys.argv[1:]) import os IMGFILE = os.environ.get('IMGFILE') BINDPATH = os.environ.get('BINDPATH') raser_shell = "/usr/bin/apptainer exec --env-file cfg/env -B" + " " \ + BINDPATH + " " \ + IMGFILE + " " \ + "python3 raser" subprocess.run([raser_shell+' '+command], shell=True, executable='/bin/bash') else: # in shell submodule = importlib.import_module(submodule) submodule.main(kwargs)