Skip to content
Snippets Groups Projects
foamGraphResUVWP 3.03 KiB
Newer Older
  • Learn to ignore specific revisions
  • #!/bin/csh -f
    #------------------------------------------------------------------------------
    # =========                 |
    
    # \\      /  F ield         | foam-extend: Open Source CFD
    
    #  \\    /   O peration     | Version:     4.1
    
    Henrik's avatar
    Henrik committed
    #   \\  /    A nd           | Web:         http://www.foam-extend.org
    #    \\/     M anipulation  | For copyright notice see file Copyright
    
    Hrvoje Jasak's avatar
    Hrvoje Jasak committed
    #------------------------------------------------------------------------------
    
    #     This file is part of foam-extend.
    
    #     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
    
    #     Free Software Foundation, either version 3 of the License, or (at your
    
    #     option) any later version.
    #
    
    #     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
    
    #     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
    
    #
    # Script
    #     foamGraphResUVWP
    #
    # Description
    
    #------------------------------------------------------------------------------
    
    set tmpU = newU$$.dat
    cat $1 | grep "Solving for Ux" | grep -v "solution singularity" | sed s/,//g | awk 'BEGIN { NENTRIES = 0 }{NENTRIES++; printf("%d %e\n", NENTRIES, $8)}' - > $tmpU
    
    set tmpV = newV$$.dat
    cat $1 | grep "Solving for Uy" | grep -v "solution singularity" | sed s/,//g | awk 'BEGIN { NENTRIES = 0 }{NENTRIES++; printf("%d %e\n", NENTRIES, $8)}' - > $tmpV
    
    set tmpW = newW$$.dat
    cat $1 | grep "Solving for Uz" | grep -v "solution singularity" | sed s/,//g | awk 'BEGIN { NENTRIES = 0 }{NENTRIES++; printf("%d %e\n", NENTRIES, $8)}' - > $tmpW
    
    set tmpP = newP$$.dat
    cat $1 | grep "Solving for p" | grep -v "solution singularity" | sed s/,//g | awk 'BEGIN { NENTRIES = 0 }{NENTRIES++; printf("%d %e\n", NENTRIES, $8)}' - > $tmpP
    
    set linesU = `cat $tmpU | wc -l`
    set linesV = `cat $tmpV | wc -l`
    set linesW = `cat $tmpW | wc -l`
    set linesP = `cat $tmpP | wc -l`
    
    set ngraphs = 0
    
    if ($linesU > 1) then
    @ ngraphs = $ngraphs + 1
    endif
    
    if ($linesV > 1) then
    @ ngraphs = $ngraphs + 1
    endif
    
    if ($linesW > 1) then
    @ ngraphs = $ngraphs + 1
    endif
    
    if ($linesP > 1) then
    @ ngraphs = $ngraphs + 1
    endif
    
    cat << EOF > residualUVWP.dat
    EOF
    #Solver Performance
    #number of iterations
    #residual
    
    #0 0
    #$ngraphs
    #EOF
    
    if ($linesU > 1) then
    cat << EOF >> residualUVWP.dat
    
    EOF
    #U
    #0
    #$linesU
    #EOF
    cat $tmpU >> residualUVWP.dat
    endif
    
    if ($linesV > 1) then
    cat << EOF >> residualUVWP.dat
    
    EOF
    #V
    #0
    #$linesV
    #EOF
    cat $tmpV >> residualUVWP.dat
    endif
    
    if ($linesW > 1) then
    cat << EOF >> residualUVWP.dat
    
    EOF
    #W
    #0
    #$linesW
    #EOF
    cat $tmpW >> residualUVWP.dat
    endif
    
    if ($linesP > 1) then
    cat << EOF >> residualUVWP.dat
    
    EOF
    #P
    #0
    #$linesP
    #EOF
    cat $tmpP >> residualUVWP.dat
    endif
    
    rm $tmpU
    rm $tmpV
    rm $tmpW
    rm $tmpP
    
    #------------------------------------------------------------------------------