Merge branch 'master' of github.com:OpenCFD/OpenFOAM-1.7.x
[OpenFOAM-1.7.x.git] / applications / test / dataEntry / testDataEntry.C
blobb3547e250c2c3d0e3c0e304484896d028cf54d8f
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 1991-2010 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software: you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by
13     the Free Software Foundation, either version 3 of the License, or
14     (at your option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM.  If not, see <http://www.gnu.org/licenses/>.
24 Application
25     testDataEntry
27 Description
28     Tests lagrangian/intermediate/submodels/IO/DataEntry
30 \*---------------------------------------------------------------------------*/
32 #include "fvCFD.H"
33 #include "DataEntry.H"
34 #include "IOdictionary.H"
36 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
38 int main(int argc, char *argv[])
40 #   include "setRootCase.H"
41 #   include "createTime.H"
42 #   include "createMesh.H"
44     IOdictionary dataEntryProperties
45     (
46         IOobject
47         (
48             "dataEntryProperties",
49             runTime.constant(),
50             mesh,
51             IOobject::MUST_READ,
52             IOobject::NO_WRITE
53         )
54     );
56     autoPtr<DataEntry<scalar> > dataEntry
57     (
58         DataEntry<scalar>::New
59         (
60             "dataEntry",
61             dataEntryProperties
62         )
63     );
65     scalar x0 = readScalar(dataEntryProperties.lookup("x0"));
66     scalar x1 = readScalar(dataEntryProperties.lookup("x1"));
68     Info<< "Data entry type: " << dataEntry().type() << nl << endl;
70     Info<< "Inputs" << nl
71         << "    x0 = " << x0 << nl
72         << "    x1 = " << x1 << nl
73         << endl;
75     Info<< "Interpolation" << nl
76         << "    f(x0) = " << dataEntry().value(x0) << nl
77         << "    f(x1) = " << dataEntry().value(x1) << nl
78         << endl;
80     Info<< "Integration" << nl
81         << "    int(f(x)) lim(x0->x1) = " << dataEntry().integrate(x0, x1) << nl
82         << endl;
84     return 0;
88 // ************************************************************************* //