BUG: UListIO: byteSize overflowing on really big faceLists
[OpenFOAM-2.0.x.git] / src / OpenFOAM / matrices / lduMatrix / solvers / ICCG / ICCG.C
blob6ebd2725ecbe9f0b6d6606e5d40b8bb8dca4a288
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 2011 OpenFOAM Foundation
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 \*---------------------------------------------------------------------------*/
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>& interfaceBouCoeffs,
72     const FieldField<Field, scalar>& interfaceIntCoeffs,
73     const lduInterfaceFieldPtrsList& interfaces,
74     const dictionary& solverControls
77     PCG
78     (
79         fieldName,
80         matrix,
81         interfaceBouCoeffs,
82         interfaceIntCoeffs,
83         interfaces,
84         solverControls
85     )
89 Foam::ICCG::ICCG
91     const word& fieldName,
92     const lduMatrix& matrix,
93     const FieldField<Field, scalar>& interfaceBouCoeffs,
94     const FieldField<Field, scalar>& interfaceIntCoeffs,
95     const lduInterfaceFieldPtrsList& interfaces,
96     const scalar tolerance,
97     const scalar relTol
100     PCG
101     (
102         fieldName,
103         matrix,
104         interfaceBouCoeffs,
105         interfaceIntCoeffs,
106         interfaces,
107         solverDict(tolerance, relTol)
108     )
111 // ************************************************************************* //