Skip to content
Snippets Groups Projects
RunFunctions 2.8 KiB
Newer Older
  • Learn to ignore specific revisions
  • #---------------------------------*- sh -*-------------------------------------
    
    # =========                 |
    # \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
    #  \\    /   O peration     |
    
    Henry's avatar
    Henry committed
    #   \\  /    A nd           | Copyright (C) 2011-2015 OpenFOAM Foundation
    
    #    \\/     M anipulation  |
    #------------------------------------------------------------------------------
    # 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
    
        sed -ne 's/^ *application\s*\([a-zA-Z]*\)\s*;.*$/\1/p' system/controlDict
    
            echo "$APP_NAME already run on $PWD: remove log file to re-run"
    
        else
            echo "Running $APP_RUN on $PWD"
    
            $APP_RUN "$@" > log.$APP_NAME 2>&1
    
        if [ -f log.$APP_NAME ]
    
            echo "$APP_NAME already run on $PWD: remove log file 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 > log.$APP_NAME 2>&1 )"
    
                ( mpirun -np $nProcs $APP_RUN -parallel "$@" < /dev/null > log.$APP_NAME 2>&1 )
    
    {
        echo "Compiling $1 application"
        wmake $1
    }
    
    
            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
    }
    
    #------------------------------------------------------------------------------