XiDyMFoam : compressible version of XiFoam oscillatingCylinder : 2D case with cylinder moving up and down annularCombustorTurbine : part of 3D combuster using cyclicPeriodicAMI
121 lines
3.1 KiB
Bash
121 lines
3.1 KiB
Bash
#---------------------------------*- sh -*-------------------------------------
|
|
# ========= |
|
|
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
|
|
# \\ / O peration |
|
|
# \\ / A nd | Copyright (C) 2011-2015 OpenFOAM Foundation
|
|
# \\/ M anipulation | Copyright (C) 2015 OpenCFD Ltd.
|
|
#------------------------------------------------------------------------------
|
|
# License
|
|
# This file is part of OpenFOAM.
|
|
#
|
|
# OpenFOAM is free software: you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
|
|
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
# for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
# Script
|
|
# RunFunctions
|
|
#
|
|
# Description
|
|
# Miscellaneous functions for running tutorial cases
|
|
#------------------------------------------------------------------------------
|
|
|
|
getNumberOfProcessors()
|
|
{
|
|
sed -ne 's/^numberOfSubdomains\s*\(.*\);/\1/p' system/decomposeParDict
|
|
}
|
|
|
|
getApplication()
|
|
{
|
|
sed -ne 's/^ *application\s*\([a-zA-Z]*\)\s*;.*$/\1/p' system/controlDict
|
|
}
|
|
|
|
runApplication()
|
|
{
|
|
APP_LOGFILE=''
|
|
if [ "$1" = "-l" ]
|
|
then
|
|
APP_LOGFILE=$2
|
|
shift 2
|
|
fi
|
|
|
|
APP_RUN=$1
|
|
APP_NAME=${1##*/}
|
|
shift
|
|
|
|
APP_LOGFILE=${APP_LOGFILE:="log.$APP_NAME"}
|
|
|
|
if [ -f $APP_LOGFILE ]
|
|
then
|
|
echo "$APP_NAME already run on $PWD: remove log file $APP_LOGFILE to re-run"
|
|
else
|
|
echo "Running $APP_RUN on $PWD"
|
|
$APP_RUN "$@" > $APP_LOGFILE 2>&1
|
|
fi
|
|
}
|
|
|
|
runParallel()
|
|
{
|
|
APP_LOGFILE=''
|
|
if [ "$1" = "-l" ]
|
|
then
|
|
APP_LOGFILE=$2
|
|
shift 2
|
|
fi
|
|
|
|
APP_RUN=$1
|
|
APP_NAME=${1##*/}
|
|
shift
|
|
|
|
APP_LOGFILE=${APP_LOGFILE:="log.$APP_NAME"}
|
|
|
|
if [ -f $APP_LOGFILE ]
|
|
then
|
|
echo "$APP_NAME already run on $PWD: remove log file $APP_LOGFILE to re-run"
|
|
else
|
|
nProcs=$1
|
|
shift
|
|
echo "Running $APP_RUN in parallel on $PWD using $nProcs processes"
|
|
|
|
#if [ "$WM_SCHEDULER" ]
|
|
#then
|
|
# echo "$PWD: $WM_SCHEDULER -np $nProcs" 1>&2
|
|
# $WM_SCHEDULER -np $nProcs "( mpirun -np $nProcs $APP_RUN -parallel "$@" < /dev/null > $APP_LOGFILE 2>&1 )"
|
|
#else
|
|
( mpirun -np $nProcs $APP_RUN -parallel "$@" < /dev/null > $APP_LOGFILE 2>&1 )
|
|
#fi
|
|
fi
|
|
}
|
|
|
|
compileApplication()
|
|
{
|
|
echo "Compiling $1 application"
|
|
wmake $1
|
|
}
|
|
|
|
cloneCase()
|
|
{
|
|
if [ -d $2 ]
|
|
then
|
|
echo "Case already cloned: remove case directory $2 to clone"
|
|
else
|
|
echo "Cloning $2 case from $1"
|
|
mkdir $2
|
|
cpfiles="0 system constant"
|
|
for f in $cpfiles
|
|
do
|
|
cp -r $1/$f $2
|
|
done
|
|
fi
|
|
}
|
|
|
|
#------------------------------------------------------------------------------
|