software:himster2
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
software:himster2 [2019/09/11 08:55] – himuser | software:himster2 [2022/01/14 18:44] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | === SSH connection to the git repository | + | === Source code checkout |
- | Set up the ssh connection to '' | ||
- | |||
- | \\ | ||
- | === Source code checkout === | ||
< | < | ||
git clone https:// | git clone https:// | ||
</ | </ | ||
- | Alternatively (not preferred), check out from the fileserver | + | Alternatively (not preferred), check out from the fileserver. \\ |
+ | |||
+ | Set up the ssh connection to '' | ||
+ | Then check out: | ||
< | < | ||
git clone agmaas@bwec-fileserver:/ | git clone agmaas@bwec-fileserver:/ | ||
Line 18: | Line 17: | ||
\\ | \\ | ||
=== Environment setup === | === Environment setup === | ||
- | load module and set the variable FAIRSOFT_BUILD_DIR: | + | load module and set the variable FAIRSOFT_BUILD_DIR:\\ |
+ | new since Nov 2020: | ||
< | < | ||
- | module load fairsoft/ | + | export MODULEPATH=$MODULEPATH:/ |
- | export FAIRSOFT_BUILD_DIR=/ | + | module load fairsoft/ |
+ | export FAIRSOFT_BUILD_DIR=/ | ||
</ | </ | ||
+ | |||
or | or | ||
< | < | ||
Line 33: | Line 35: | ||
Follow the instruction on the [[software: | Follow the instruction on the [[software: | ||
+ | \\ | ||
+ | === Send jobs to the queue system slurm === | ||
+ | All of the following information has been gathered by studying the '' | ||
+ | In the following a minimum script to run a single job on slurm is given. | ||
+ | To submit your job use | ||
+ | < | ||
+ | $ sbatch myjobscript | ||
+ | </ | ||
+ | |||
+ | |||
+ | Example for myjobscript: | ||
+ | |||
+ | < | ||
+ | #!/bin/bash | ||
+ | # | ||
+ | # Example SLURM job script to run primag4sim on HimsterII | ||
+ | # | ||
+ | |||
+ | # First think about the resources you need and set the job requirements: | ||
+ | |||
+ | #SBATCH -J g4simtest | ||
+ | #SBATCH -o g4simtest.%j.out | ||
+ | #SBATCH -p himster2_exp | ||
+ | #SBATCH -N 1 # Total number of nodes requested (64 cores/node per Mogon I node) | ||
+ | #SBATCH -n 1 # Total number of tasks | ||
+ | #SBATCH -t 00: | ||
+ | |||
+ | #SBATCH -A m2_him_exp | ||
+ | |||
+ | # A script to set the environment is sourced. It must contain all | ||
+ | # environment settings needed to run the program, as if you would | ||
+ | # run it just after login on himsterII. Something like | ||
+ | # | ||
+ | # module load fairsoft/ | ||
+ | # export FAIRSOFT_BUILD_DIR=... | ||
+ | # | ||
+ | # should be in there. Think about what you need. | ||
+ | # | ||
+ | |||
+ | source mysetenv.sh | ||
+ | |||
+ | # Submit the executable with the needed arguments (it might also be a script) | ||
+ | |||
+ | srun < | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | An example script is given here to run a train of jobs with different '' | ||
+ | It is broken down in pieces with comments between them, deliberately to try and avoid unthoughtful copy-pasting. Things can be done in many different ways, this is just an example which should run and also produce | ||
+ | |||
+ | Provide the possibility to have a "dry runs" where all scripts are prepared and can be checked, without actually starting the jobs. That is very useful to avoid having to chase running jobs with wrong settings. | ||
+ | |||
+ | The following code can be executed with: | ||
+ | < | ||
+ | $ ./ | ||
+ | </ | ||
+ | |||
+ | < | ||
+ | #!/bin/bash | ||
+ | # | ||
+ | # Script for running a train of primag4sim jobs on HimsterII | ||
+ | # | ||
+ | |||
+ | # set to 1 to really submit the jobs | ||
+ | dorun=0 | ||
+ | </ | ||
+ | |||
+ | Data, logs and all used scripts will be saved with the output root files on the lustre filesystem, where there is some storage space. Create a personal directory at ''/ | ||
+ | |||
+ | < | ||
+ | # the path where scripts, confs, logs and output is stored | ||
+ | outpath=/ | ||
+ | </ | ||
+ | |||
+ | |||
+ | Base macro and config files have to be copied previously to the output directory and will be used as starting point for the job specific ones. | ||
+ | The directory structure for all input and output files is constructed. | ||
+ | < | ||
+ | # base scripts to be completed for single jobs | ||
+ | confbase=$outpath/ | ||
+ | macrobase=$outpath/ | ||
+ | |||
+ | # the simulation executable | ||
+ | exec=$G4WORKDIR/ | ||
+ | |||
+ | |||
+ | # make dirs | ||
+ | mkdir -p $outpath/ | ||
+ | mkdir -p $outpath/ | ||
+ | mkdir -p $outpath/ | ||
+ | mkdir -p $outpath/ | ||
+ | mkdir -p $outpath/ | ||
+ | </ | ||
+ | |||
+ | |||
+ | The main loop on the jobs to be started (200 in this example) starts here. For each job config and macro files are completed, the job script is constructed and the job submitted if it is not a dry run. | ||
+ | < | ||
+ | for i in `seq 0 199`; do | ||
+ | | ||
+ | istr=`printf %04d $i` | ||
+ | |||
+ | script=$outpath/ | ||
+ | log=$outpath/ | ||
+ | config=$outpath/ | ||
+ | macro=$outpath/ | ||
+ | rootfile=$outpath/ | ||
+ | |||
+ | # prepare config file | ||
+ | cat $confbase > $config | ||
+ | echo " | ||
+ | macro-file $macro | ||
+ | root-output-file $rootfile" | ||
+ | |||
+ | # prepare macro file | ||
+ | echo "/ | ||
+ | cat $macrobase >> $macro | ||
+ | | ||
+ | # prepare sbatch script | ||
+ | echo "# | ||
+ | echo " | ||
+ | #SBATCH -J run$istr | ||
+ | #SBATCH -o $log | ||
+ | #SBATCH -p himster2_exp | ||
+ | #SBATCH -N 1 | ||
+ | #SBATCH -n 1 | ||
+ | #SBATCH -t 02:00:00 | ||
+ | #SBATCH -A m2_him_exp | ||
+ | source $HOME/ | ||
+ | srun $exec $config | ||
+ | " >> $script | ||
+ | |||
+ | # submit the job | ||
+ | if [ $dorun -eq 1 ]; then sbatch $script; | ||
+ | |||
+ | done | ||
+ | |||
+ | </ | ||
software/himster2.1568192137.txt.gz · Last modified: 2022/01/14 18:44 (external edit)