mirror of
				https://github.com/OPM/opm-simulators.git
				synced 2025-02-25 18:55:30 -06:00 
			
		
		
		
	the number of options were getting unmanagable as a flat list. also add help/usage to the scripts
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/bin/bash
 | |
| 
 | |
| # This performs a serial and a parallel for a simulator,
 | |
| # then compares the summary and restart files from the two runs.
 | |
| # Meant to track regression in parallel simulators.
 | |
| 
 | |
| if test $# -eq 0
 | |
| then
 | |
|   echo -e "Usage:\t$0 <options> -- [additional simulator options]"
 | |
|   echo -e "\tMandatory options:"
 | |
|   echo -e "\t\t -i <path>     Path to read deck from"
 | |
|   echo -e "\t\t -r <path>     Path to store results in"
 | |
|   echo -e "\t\t -b <path>     Path to simulator binary"
 | |
|   echo -e "\t\t -f <filename> Deck file name"
 | |
|   echo -e "\t\t -a <tol>      Absolute tolerance in comparison"
 | |
|   echo -e "\t\t -t <tol>      Relative tolerance in comparison"
 | |
|   echo -e "\t\t -c <path>     Path to comparison tool"
 | |
|   echo -e "\t\t -e <filename> Simulator binary to use"
 | |
|   echo -e "\tOptional options:"
 | |
|   echo -e "\t\t -n <procs>    Number of MPI processes to use"
 | |
|   exit 1
 | |
| fi
 | |
| 
 | |
| MPI_PROCS=4
 | |
| OPTIND=1
 | |
| while getopts "i:r:b:f:a:t:c:e:n:" OPT
 | |
| do
 | |
|   case "${OPT}" in
 | |
|     i) INPUT_DATA_PATH=${OPTARG} ;;
 | |
|     r) RESULT_PATH=${OPTARG} ;;
 | |
|     b) BINPATH=${OPTARG} ;;
 | |
|     f) FILENAME=${OPTARG} ;;
 | |
|     a) ABS_TOL=${OPTARG} ;;
 | |
|     t) REL_TOL=${OPTARG} ;;
 | |
|     c) COMPARE_ECL_COMMAND=${OPTARG} ;;
 | |
|     e) EXE_NAME=${OPTARG} ;;
 | |
|     n) MPI_PROCS=${OPTARG} ;;
 | |
|   esac
 | |
| done
 | |
| shift $(($OPTIND-1))
 | |
| TEST_ARGS="$@"
 | |
| 
 | |
| rm -Rf ${RESULT_PATH}
 | |
| mkdir -p ${RESULT_PATH}
 | |
| cd ${RESULT_PATH}
 | |
| ${BINPATH}/${EXE_NAME} ${TEST_ARGS} --enable-opm-rst-file=true --output-dir=${RESULT_PATH}
 | |
| 
 | |
| test $? -eq 0 || exit 1
 | |
| mkdir mpi
 | |
| cd mpi
 | |
| mpirun -np ${MPI_PROCS} ${BINPATH}/${EXE_NAME} ${TEST_ARGS} --enable-opm-rst-file=true --output-dir=${RESULT_PATH}/mpi
 | |
| test $? -eq 0 || exit 1
 | |
| cd ..
 | |
| 
 | |
| ecode=0
 | |
| echo "=== Executing comparison for summary file ==="
 | |
| ${COMPARE_ECL_COMMAND} -t SMRY -R ${RESULT_PATH}/${FILENAME} ${RESULT_PATH}/mpi/${FILENAME} ${ABS_TOL} ${REL_TOL}
 | |
| if [ $? -ne 0 ]
 | |
| then
 | |
|   ecode=1
 | |
|   ${COMPARE_ECL_COMMAND} -t SMRY -a -R ${RESULT_PATH}/${FILENAME} ${RESULT_PATH}/mpi/${FILENAME} ${ABS_TOL} ${REL_TOL}
 | |
| fi
 | |
| 
 | |
| echo "=== Executing comparison for restart file ==="
 | |
| ${COMPARE_ECL_COMMAND} -l -t UNRST ${RESULT_PATH}/${FILENAME} ${RESULT_PATH}/mpi/${FILENAME} ${ABS_TOL} ${REL_TOL}
 | |
| if [ $? -ne 0 ]
 | |
| then
 | |
|   ecode=1
 | |
|   ${COMPARE_ECL_COMMAND} -a -l -t UNRST ${RESULT_PATH}/${FILENAME} ${RESULT_PATH}/mpi/${FILENAME} ${ABS_TOL} ${REL_TOL}
 | |
| fi
 | |
| 
 | |
| exit $ecode
 |