Forward compatibility: flex
[foam-extend-3.2.git] / applications / utilities / postProcessing / miscellaneous / ptot / ptot.C
blobdaa9d4192671fc4e5a78263a284896c4b6c4f648
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | foam-extend: Open Source CFD
4    \\    /   O peration     | Version:     3.2
5     \\  /    A nd           | Web:         http://www.foam-extend.org
6      \\/     M anipulation  | For copyright notice see file Copyright
7 -------------------------------------------------------------------------------
8 License
9     This file is part of foam-extend.
11     foam-extend is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation, either version 3 of the License, or (at your
14     option) any later version.
16     foam-extend is distributed in the hope that it will be useful, but
17     WITHOUT ANY WARRANTY; without even the implied warranty of
18     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
19     General Public License for more details.
21     You should have received a copy of the GNU General Public License
22     along with foam-extend.  If not, see <http://www.gnu.org/licenses/>.
24 Application
25     ptot
27 Description
28     For each time: calculate the total pressure.
30 \*---------------------------------------------------------------------------*/
32 #include "fvCFD.H"
34 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
36 int main(int argc, char *argv[])
38     timeSelector::addOptions();
40 #   include "setRootCase.H"
41 #   include "createTime.H"
43     instantList timeDirs = timeSelector::select0(runTime, args);
45 #   include "createMesh.H"
47     forAll(timeDirs, timeI)
48     {
49         runTime.setTime(timeDirs[timeI], timeI);
51         Info<< "Time = " << runTime.timeName() << endl;
53         IOobject pheader
54         (
55             "p",
56             runTime.timeName(),
57             mesh,
58             IOobject::MUST_READ
59         );
61         IOobject Uheader
62         (
63             "U",
64             runTime.timeName(),
65             mesh,
66             IOobject::MUST_READ
67         );
70         // Check p and U exist
71         if (pheader.headerOk() && Uheader.headerOk())
72         {
73             mesh.readUpdate();
75             Info<< "    Reading p" << endl;
76             volScalarField p(pheader, mesh);
78             Info<< "    Reading U" << endl;
79             volVectorField U(Uheader, mesh);
81             Info<< "    Calculating ptot" << endl;
82             if (p.dimensions() == dimensionSet(0, 2, -2, 0, 0))
83             {
84                 volScalarField ptot
85                 (
86                     IOobject
87                     (
88                         "ptot",
89                         runTime.timeName(),
90                         mesh,
91                         IOobject::NO_READ
92                     ),
93                     p + 0.5*magSqr(U)
94                 );
95                 ptot.write();
96             }
97             else
98             {
99                 IOobject rhoheader
100                 (
101                     "rho",
102                     runTime.timeName(),
103                     mesh,
104                     IOobject::MUST_READ
105                 );
107                 // Check rho exists
108                 if (rhoheader.headerOk())
109                 {
110                     Info<< "    Reading rho" << endl;
111                     volScalarField rho(rhoheader, mesh);
113                     volScalarField ptot
114                     (
115                         IOobject
116                         (
117                             "ptot",
118                             runTime.timeName(),
119                             mesh,
120                             IOobject::NO_READ
121                         ),
122                         p + 0.5*rho*magSqr(U)
123                     );
124                     ptot.write();
125                 }
126                 else
127                 {
128                     Info<< "    No rho" << endl;
129                 }
130             }
131         }
132         else
133         {
134             Info<< "    No p or U" << endl;
135         }
137         Info<< endl;
138     }
140     return 0;
144 // ************************************************************************* //