.job.qsub 840 B

123456789101112131415161718192021222324252627282930313233
  1. #!/bin/bash
  2. #PBS -N fmm
  3. #PBS -V
  4. eval $nodes_;
  5. eval $cores_;
  6. eval $mpi_proc_;
  7. eval $threads_;
  8. eval $max_time_;
  9. eval $fname_;
  10. eval $args_;
  11. WORK_DIR=${PBS_O_WORKDIR}
  12. cd ${WORK_DIR}
  13. for (( k=0; k<${#nodes[@]}; k++ )) ; do
  14. if [ "${nodes[k]}" == "${NODES}" ] &&
  15. [ "${mpi_proc[k]}" == "${MPI_PROC}" ]; then
  16. export OMP_NUM_THREADS=${threads[k]};
  17. # CPU only
  18. EXEC_=${EXEC};
  19. FNAME=${RESULT_DIR}/$(basename ${EXEC_})_${fname[k]}.out;
  20. if [ -f ${EXEC_} ] && [ ! -s ${FNAME} ] ; then
  21. printf '%*s\n\n' "100" ' ' | tr ' ' "#" | tee -a ${FNAME};
  22. printf "COMMAND: ${EXEC_} ${args[k]}\n" | tee -a ${FNAME};
  23. ${TIMEOUT} ${max_time[k]} time mpirun -np ${mpi_proc[k]} ${EXEC_} ${args[k]} &> >(tee -a ${FNAME});
  24. printf '\n%*s\n\n' "100" ' ' | tr ' ' "#" | tee -a ${FNAME};
  25. fi;
  26. fi;
  27. done;