Mercurial > hg > cc > cirrus_work
view bin/_runme.sh @ 54:9c63039a9b6d
little steps
author | Henry S. Thompson <ht@inf.ed.ac.uk> |
---|---|
date | Fri, 07 Jul 2023 19:30:23 +0100 |
parents | 316495371bbc |
children | 235004978b22 |
line wrap: on
line source
#!/bin/bash # This runs on the compute nodes... # Args: wd [-d] [-t nthreads] [-b CMDS] [-i input] CMDS # See ug4/azure/notes.txt for documentation N=$SLURM_JOB_NUM_NODES n=$SLURM_NTASKS c=$SLURM_CPUS_PER_TASK nodename=$SLURMD_NODENAME local=$SLURM_LOCALID node=$SLURM_NODEID task=$SLURM_PROCID cd "$1" shift if [ "$1" = "-d" ] then shift debug=1 fi if [ "$1" = "-t" ] then shift threadsPerTask=$1 shift else threadsPerTask=2 fi pjobs=$((c / $threadsPerTask)) echo $(date) task $n.$task on $nodename:$N.$node start $pjobs jobs 1>&2 PATH=$W/$USER/bin:$W/shared/bin:$PATH export task PATH n if [ "$1" = "-b" ] then shift eval "$1" shift fi if [ "$1" = "-i" ] then shift input="$1" shift if [ "$debug" ] then echo $(date) task $n.$task input "|$input|" fi fi export cmd="$1" shift doit () { arg="$1" echo $(date) start $task $PARALLEL_SEQ "|$cmd|$arg|" eval "$cmd" echo $(date) end $task $PARALLEL_SEQ } export -f doit if [ "$debug" ] then echo $(date) task $n.$task cmd "|$cmd|" doit $(type doit) fi eval "$input" | \ if [ "$debug" ] then tee >(cat 1>&2) else cat fi | \ if [ $pjobs -le 1 ] then xargs -I ^ -n 1 bash -c "doit ^" else parallel --line-buffer -j $pjobs doit '{}' fi echo $(date) task $n.$task on $nodename:$N.$node end 1>&2