Forward compatibility: flex
[foam-extend-3.2.git] / src / foam / matrices / lduMatrix / solvers / ICCG / ICCG.C
blob17edd715c762155c865a7821991c430319f5c7c0
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 \*---------------------------------------------------------------------------*/
26 #include "ICCG.H"
28 // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
30 namespace Foam
32     defineTypeNameAndDebug(ICCG, 0);
34     lduMatrix::solver::addsymMatrixConstructorToTable<ICCG>
35         addICCGSymMatrixConstructorToTable_;
38 // * * * * * * * * * * * * * Static Member Functions * * * * * * * * * * * * //
40 Foam::dictionary Foam::ICCG::solverDict
42     const scalar tol,
43     const scalar relTol
46     dictionary dict(IStringStream("solver PCG; preconditioner DIC;")());
47     dict.add("tolerance", tol);
48     dict.add("relTol", relTol);
50     return dict;
54 Foam::dictionary Foam::ICCG::solverDict
56     Istream& is
59     scalar tol(readScalar(is));
60     scalar relTol(readScalar(is));
62     return solverDict(tol, relTol);
65 // * * * * * * * * * * * * * * * * Constructors  * * * * * * * * * * * * * * //
67 Foam::ICCG::ICCG
69     const word& fieldName,
70     const lduMatrix& matrix,
71     const FieldField<Field, scalar>& coupleBouCoeffs,
72     const FieldField<Field, scalar>& coupleIntCoeffs,
73     const lduInterfaceFieldPtrsList& interfaces,
74     const dictionary& dict
77     PCG
78     (
79         fieldName,
80         matrix,
81         coupleBouCoeffs,
82         coupleIntCoeffs,
83         interfaces,
84         dict
85     )
89 Foam::ICCG::ICCG
91     const word& fieldName,
92     const lduMatrix& matrix,
93     const FieldField<Field, scalar>& coupleBouCoeffs,
94     const FieldField<Field, scalar>& coupleIntCoeffs,
95     const lduInterfaceFieldPtrsList& interfaces,
96     const scalar tolerance,
97     const scalar relTol
100     PCG
101     (
102         fieldName,
103         matrix,
104         coupleBouCoeffs,
105         coupleIntCoeffs,
106         interfaces,
107         solverDict(tolerance, relTol)
108     )
111 // ************************************************************************* //