This repository has been archived on 2023-11-20. You can view files and clone it, but cannot push or open issues or pull requests.
foam-extend4.1-coherent-io/bin/foamUpgradeTurbulenceProperties

98 lines
3 KiB
Text
Raw Normal View History

#!/bin/sh
#------------------------------------------------------------------------------
# ========= |
2013-12-11 16:09:41 +00:00
# \\ / F ield | foam-extend: Open Source CFD
# \\ / O peration | Version: 4.1
2016-06-20 15:00:40 +00:00
# \\ / A nd | Web: http://www.foam-extend.org
# \\/ M anipulation | For copyright notice see file Copyright
#------------------------------------------------------------------------------
# License
2013-12-11 16:09:41 +00:00
# This file is part of foam-extend.
#
2013-12-11 16:09:41 +00:00
# foam-extend is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by the
2013-12-11 16:09:41 +00:00
# Free Software Foundation, either version 3 of the License, or (at your
# option) any later version.
#
2013-12-11 16:09:41 +00:00
# foam-extend 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
2013-12-11 16:09:41 +00:00
# along with foam-extend. If not, see <http://www.gnu.org/licenses/>.
#
# Script
# foamUpgradeTurbulenceProperties
#
# Description
# Upgrade the turbulenceProperties dictionary to the new format employed
# in OpenFOAM version 1.5-dev
# - RAS turbulence models now defined by the RASProperties dictionary,
2010-05-27 10:48:11 +00:00
# and RASModel keyword.
# - LES turbulence models now defined by the LESProperties dictionary,
# and LESModel keyword.
#
#------------------------------------------------------------------------------
2010-05-27 10:48:11 +00:00
usage() {
cat<<USAGE
2010-05-27 10:48:11 +00:00
usage: ${0##*/} <turbulenceProperties>
2010-05-27 10:48:11 +00:00
Where <turbulenceProperties> is the full path to the
turbulenceProperties dictionary
2010-05-27 10:48:11 +00:00
Note: can upgrade several files at once
2010-05-27 10:48:11 +00:00
USAGE
exit 1
}
2010-05-27 10:48:11 +00:00
#
# $1: turbulence model
# $2: new properties type
# $3: original dictionary
#
convertDict()
{
echo "Identified $1 turbulence model in '$3'"
outputPath=`dirname $3`
2010-05-27 10:48:11 +00:00
if [ -e "$outputPath/$1Properties" ]
then
echo "Error: file already exists $outputPath/$1Properties'" 1>&2
else
sed -e "s/turbulenceProperties/$1Properties/" \
-e "s/$2/$1Model/" \
-e "s/[a-zA-Z0-9]* [ ]*\[[0-9 ]*\]//" \
$3 > "$outputPath/$1Properties"
2010-05-27 10:48:11 +00:00
echo " wrote $outputPath/$1Properties"
fi
}
2010-05-27 10:48:11 +00:00
[ $# -ge 1 ] || usage
2010-05-27 10:48:11 +00:00
for turbDict
do
# Identify type of turbulence model and convert
if [ -f $turbDict ]
then
if grep turbulenceModel $turbDict >/dev/null 2>&1
then
convertDict RAS turbulenceModel $turbDict
elif grep LESmodel $turbDict >/dev/null 2>&1
then
convertDict LES LESmodel $turbDict
else
echo "Unable to determine turbulence model type in '$turbDict'" 1>&2
echo " - nothing changed" 1>&2
fi
else
echo "Error: file '$turbDict' does not exist" 1>&2
fi
done
#------------------------------------------------------------------------------