Second version of BlockILUCp preconditioner
This commit is contained in:
parent
fcda21ed73
commit
6824cfda9c
5 changed files with 198 additions and 31 deletions
|
@ -30,7 +30,7 @@ License
|
||||||
template<class Type>
|
template<class Type>
|
||||||
Foam::extendedBlockLduMatrix<Type>::extendedBlockLduMatrix
|
Foam::extendedBlockLduMatrix<Type>::extendedBlockLduMatrix
|
||||||
(
|
(
|
||||||
const blockLduMatrix<Type>& blockLdum,
|
const BlockLduMatrix<Type>& blockLdum,
|
||||||
const label extensionLevel,
|
const label extensionLevel,
|
||||||
const polyMesh& polyMesh
|
const polyMesh& polyMesh
|
||||||
)
|
)
|
||||||
|
@ -68,24 +68,74 @@ Foam::extendedBlockLduMatrix<Type>::extendedBlockLduMatrix
|
||||||
const unallocLabelList& faceMap = extLduAddr_.faceMap();
|
const unallocLabelList& faceMap = extLduAddr_.faceMap();
|
||||||
|
|
||||||
// Avoid assuming it's upper if the matrix is symmetric
|
// Avoid assuming it's upper if the matrix is symmetric
|
||||||
if (blockLdum.hasUpper())
|
if (blockLdum.thereIsUpper())
|
||||||
{
|
{
|
||||||
// Allocate extended upper only
|
// Allocate extended upper only
|
||||||
extendedUpperPtr_ = new TypeCoeffField
|
extendedUpperPtr_ = new TypeCoeffField
|
||||||
(
|
(
|
||||||
extLduAddr_.extendedUpperAddr().size(),
|
extLduAddr_.extendedUpperAddr().size()
|
||||||
pTraits<Type>::zero
|
|
||||||
);
|
);
|
||||||
TypeCoeffField& extUpper = *extendedUpperPtr_;
|
TypeCoeffField& extUpper = *extendedUpperPtr_;
|
||||||
|
|
||||||
// Get upper coeffs from underlying lduMatrix
|
// Get upper coeffs from underlying lduMatrix
|
||||||
const TypeCoeffField& upper = blockLdum.upper();
|
const TypeCoeffField& upper = blockLdum.upper();
|
||||||
|
|
||||||
|
if (upper.activeType() == blockCoeffBase::SCALAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::scalarTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asScalar();
|
||||||
|
activeType& activeExtUpper = extUpper.asScalar();
|
||||||
|
|
||||||
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
// positions
|
// positions
|
||||||
forAll (upper, faceI)
|
forAll (upper, faceI)
|
||||||
{
|
{
|
||||||
extUpper[faceMap[faceI]] = upper[faceI];
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (upper.activeType() == blockCoeffBase::LINEAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::linearTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asLinear();
|
||||||
|
activeType& activeExtUpper = extUpper.asLinear();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (upper, faceI)
|
||||||
|
{
|
||||||
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (upper.activeType() == blockCoeffBase::SQUARE)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::squareTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asSquare();
|
||||||
|
activeType& activeExtUpper = extUpper.asSquare();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (upper, faceI)
|
||||||
|
{
|
||||||
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FatalErrorIn
|
||||||
|
(
|
||||||
|
"extendedBlockLduMatrix(lduMatrix&, label, polyMesh&)"
|
||||||
|
) << "Problem between ordinary block matrix and extended"
|
||||||
|
<< " block matrix upper coeffs type morphing."
|
||||||
|
<< abort(FatalError);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -93,19 +143,69 @@ Foam::extendedBlockLduMatrix<Type>::extendedBlockLduMatrix
|
||||||
// Allocate extended lower only
|
// Allocate extended lower only
|
||||||
extendedLowerPtr_ = new TypeCoeffField
|
extendedLowerPtr_ = new TypeCoeffField
|
||||||
(
|
(
|
||||||
extLduAddr_.extendedLowerAddr().size(),
|
extLduAddr_.extendedLowerAddr().size()
|
||||||
pTraits<Type>::zero
|
|
||||||
);
|
);
|
||||||
TypeCoeffField& extLower = *extendedLowerPtr_;
|
TypeCoeffField& extLower = *extendedLowerPtr_;
|
||||||
|
|
||||||
// Get lower coeffs from underlying lduMatrix
|
// Get lower coeffs from underlying lduMatrix
|
||||||
const TypeCoeffField& lower = blockLdum.lower();
|
const TypeCoeffField& lower = blockLdum.lower();
|
||||||
|
|
||||||
|
if (lower.activeType() == blockCoeffBase::SCALAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::scalarTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeLower = lower.asScalar();
|
||||||
|
activeType& activeExtLower = extLower.asScalar();
|
||||||
|
|
||||||
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
// positions
|
// positions
|
||||||
forAll (lower, faceI)
|
forAll (lower, faceI)
|
||||||
{
|
{
|
||||||
extLower[faceMap[faceI]] = lower[faceI];
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (lower.activeType() == blockCoeffBase::LINEAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::linearTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeLower = lower.asLinear();
|
||||||
|
activeType& activeExtLower = extLower.asLinear();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (lower, faceI)
|
||||||
|
{
|
||||||
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (lower.activeType() == blockCoeffBase::SQUARE)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::squareTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeLower = lower.asSquare();
|
||||||
|
activeType& activeExtLower = extLower.asSquare();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (lower, faceI)
|
||||||
|
{
|
||||||
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FatalErrorIn
|
||||||
|
(
|
||||||
|
"extendedBlockLduMatrix(lduMatrix&, label, polyMesh&)"
|
||||||
|
) << "Problem between ordinary block matrix and extended"
|
||||||
|
<< " block matrix lower coeffs type morphing."
|
||||||
|
<< abort(FatalError);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -118,22 +218,82 @@ Foam::extendedBlockLduMatrix<Type>::extendedBlockLduMatrix
|
||||||
const label nExtFaces = extLduAddr_.extendedUpperAddr().size();
|
const label nExtFaces = extLduAddr_.extendedUpperAddr().size();
|
||||||
|
|
||||||
// Allocate extended upper and lower
|
// Allocate extended upper and lower
|
||||||
extendedUpperPtr_ = new TypeCoeffField(nExtFaces, pTraits<Type>::zero);
|
extendedUpperPtr_ = new TypeCoeffField(nExtFaces);
|
||||||
TypeCoeffField& extUpper = *extendedUpperPtr_;
|
TypeCoeffField& extUpper = *extendedUpperPtr_;
|
||||||
|
|
||||||
extendedLowerPtr_ = new TypeCoeffField(nExtFaces, pTraits<Type>::zero);
|
extendedLowerPtr_ = new TypeCoeffField(nExtFaces);
|
||||||
TypeCoeffField& extLower = *extendedLowerPtr_;
|
TypeCoeffField& extLower = *extendedLowerPtr_;
|
||||||
|
|
||||||
// Get upper and lower coeffs from underlying lduMatrix
|
// Get upper and lower coeffs from underlying lduMatrix
|
||||||
const TypeCoeffField& upper = blockLdum.upper();
|
const TypeCoeffField& upper = blockLdum.upper();
|
||||||
const TypeCoeffField& lower = blockLdum.lower();
|
const TypeCoeffField& lower = blockLdum.lower();
|
||||||
|
|
||||||
|
// Assuming lower and upper have the same active type
|
||||||
|
if (upper.activeType() == blockCoeffBase::SCALAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::scalarTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asScalar();
|
||||||
|
activeType& activeExtUpper = extUpper.asScalar();
|
||||||
|
const activeType& activeLower = lower.asScalar();
|
||||||
|
activeType& activeExtLower = extLower.asScalar();
|
||||||
|
|
||||||
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
// positions
|
// positions
|
||||||
forAll (upper, faceI)
|
forAll (upper, faceI)
|
||||||
{
|
{
|
||||||
extUpper[faceMap[faceI]] = upper[faceI];
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
extLower[faceMap[faceI]] = lower[faceI];
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (upper.activeType() == blockCoeffBase::LINEAR)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::linearTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asLinear();
|
||||||
|
activeType& activeExtUpper = extUpper.asLinear();
|
||||||
|
const activeType& activeLower = lower.asLinear();
|
||||||
|
activeType& activeExtLower = extLower.asLinear();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (upper, faceI)
|
||||||
|
{
|
||||||
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (upper.activeType() == blockCoeffBase::SQUARE)
|
||||||
|
{
|
||||||
|
// Helper type definition
|
||||||
|
typedef typename CoeffField<Type>::squareTypeField activeType;
|
||||||
|
|
||||||
|
// Get references to fields
|
||||||
|
const activeType& activeUpper = upper.asSquare();
|
||||||
|
activeType& activeExtUpper = extUpper.asSquare();
|
||||||
|
const activeType& activeLower = lower.asSquare();
|
||||||
|
activeType& activeExtLower = extLower.asSquare();
|
||||||
|
|
||||||
|
// Copy non-zero coeffs from basic lduMatrix into corresponding
|
||||||
|
// positions
|
||||||
|
forAll (upper, faceI)
|
||||||
|
{
|
||||||
|
activeExtUpper[faceMap[faceI]] = activeUpper[faceI];
|
||||||
|
activeExtLower[faceMap[faceI]] = activeLower[faceI];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FatalErrorIn
|
||||||
|
(
|
||||||
|
"extendedBlockLduMatrix(lduMatrix&, label, polyMesh&)"
|
||||||
|
) << "Problem between ordinary block matrix and extended"
|
||||||
|
<< " block matrix upper/lower coeffs type morphing."
|
||||||
|
<< abort(FatalError);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -172,8 +332,7 @@ Foam::extendedBlockLduMatrix<Type>::extendedLower()
|
||||||
{
|
{
|
||||||
extendedLowerPtr_ = new TypeCoeffField
|
extendedLowerPtr_ = new TypeCoeffField
|
||||||
(
|
(
|
||||||
extLduAddr_.extendedLowerAddr().size(),
|
extLduAddr_.extendedLowerAddr().size()
|
||||||
pTraits<Type>::zero
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -196,8 +355,7 @@ Foam::extendedBlockLduMatrix<Type>::extendedUpper()
|
||||||
{
|
{
|
||||||
extendedUpperPtr_ = new TypeCoeffField
|
extendedUpperPtr_ = new TypeCoeffField
|
||||||
(
|
(
|
||||||
extLduAddr_.extendedUpperAddr().size(),
|
extLduAddr_.extendedUpperAddr().size()
|
||||||
pTraits<Type>::zero
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -58,7 +58,7 @@ class extendedBlockLduMatrix
|
||||||
{
|
{
|
||||||
// Public data type
|
// Public data type
|
||||||
|
|
||||||
typedef typename BlockLduMatrix<Type>::TypeCoeffField TypeCoeffField;
|
typedef CoeffField<Type> TypeCoeffField;
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -145,6 +145,12 @@ public:
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
|
#ifdef NoRepository
|
||||||
|
# include "extendedBlockLduMatrix.C"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// ************************************************************************* //
|
// ************************************************************************* //
|
||||||
|
|
|
@ -54,7 +54,7 @@ void Foam::BlockILUCpPrecon<Type>::calcFactorization
|
||||||
if (!this->matrix_.diagonal())
|
if (!this->matrix_.diagonal())
|
||||||
{
|
{
|
||||||
// Create multiplication function object
|
// Create multiplication function object
|
||||||
typename BlockCoeff<Type>::multiply mult;
|
typename BlockCoeff<LDUType>::multiply mult;
|
||||||
|
|
||||||
// Get necessary const access to extended ldu addressing
|
// Get necessary const access to extended ldu addressing
|
||||||
const extendedLduAddressing& addr = extBlockMatrix_.extendedLduAddr();
|
const extendedLduAddressing& addr = extBlockMatrix_.extendedLduAddr();
|
||||||
|
@ -98,7 +98,6 @@ void Foam::BlockILUCpPrecon<Type>::calcFactorization
|
||||||
// Start and end of k-th row (upper) and k-th column (lower)
|
// Start and end of k-th row (upper) and k-th column (lower)
|
||||||
fStart = ownStartPtr[rowI];
|
fStart = ownStartPtr[rowI];
|
||||||
fEnd = ownStartPtr[rowI + 1];
|
fEnd = ownStartPtr[rowI + 1];
|
||||||
|
|
||||||
// Initialize temporary working diagonal
|
// Initialize temporary working diagonal
|
||||||
zDiagI = diagPtr[rowI];
|
zDiagI = diagPtr[rowI];
|
||||||
|
|
||||||
|
@ -172,7 +171,7 @@ void Foam::BlockILUCpPrecon<Type>::calcFactorization
|
||||||
|
|
||||||
// Update diagonal entry, inverting it for future use
|
// Update diagonal entry, inverting it for future use
|
||||||
LDUType& diagRowI = diagPtr[rowI];
|
LDUType& diagRowI = diagPtr[rowI];
|
||||||
diagRowI = mult.inv(zDiagI);
|
diagRowI = mult.inverse(zDiagI);
|
||||||
|
|
||||||
// Index for updating L and U
|
// Index for updating L and U
|
||||||
register label zwIndex;
|
register label zwIndex;
|
||||||
|
|
|
@ -39,9 +39,9 @@ namespace Foam
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * //
|
||||||
|
|
||||||
// Excluded tensor and vector, need reduced versions. VV, 3/Jul/2015.
|
// Excluded tensor, need reduced version. VV, 3/Jul/2015.
|
||||||
makeBlockPrecon(blockScalarPrecon, blockILUCpPreconScalar);
|
makeBlockPrecon(blockScalarPrecon, blockILUCpPreconScalar);
|
||||||
//makeBlockPrecon(blockVectorPrecon, blockILUCpPreconVector);
|
makeBlockPrecon(blockVectorPrecon, blockILUCpPreconVector);
|
||||||
//makeBlockPrecon(blockTensorPrecon, blockILUCpPreconTensor);
|
//makeBlockPrecon(blockTensorPrecon, blockILUCpPreconTensor);
|
||||||
|
|
||||||
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
|
||||||
|
|
|
@ -31,6 +31,7 @@ License
|
||||||
#include "blockDiagonalPrecons.H"
|
#include "blockDiagonalPrecons.H"
|
||||||
#include "blockGaussSeidelPrecons.H"
|
#include "blockGaussSeidelPrecons.H"
|
||||||
#include "BlockCholeskyPrecon.H"
|
#include "BlockCholeskyPrecon.H"
|
||||||
|
#include "BlockILUCpPrecon.H"
|
||||||
|
|
||||||
#include "blockLduSmoothers.H"
|
#include "blockLduSmoothers.H"
|
||||||
#include "blockGaussSeidelSmoothers.H"
|
#include "blockGaussSeidelSmoothers.H"
|
||||||
|
@ -83,6 +84,9 @@ makeBlockPrecon(block##Type##Precon, block##Type##GaussSeidelPrecon); \
|
||||||
typedef BlockCholeskyPrecon<type > block##Type##CholeskyPrecon; \
|
typedef BlockCholeskyPrecon<type > block##Type##CholeskyPrecon; \
|
||||||
makeBlockPrecon(block##Type##Precon, block##Type##CholeskyPrecon); \
|
makeBlockPrecon(block##Type##Precon, block##Type##CholeskyPrecon); \
|
||||||
\
|
\
|
||||||
|
typedef BlockILUCpPrecon<type > block##Type##ILUCpPrecon; \
|
||||||
|
makeBlockPrecon(block##Type##Precon, block##Type##ILUCpPrecon); \
|
||||||
|
\
|
||||||
/* Smoothers */ \
|
/* Smoothers */ \
|
||||||
typedef BlockLduSmoother<type > block##Type##Smoother; \
|
typedef BlockLduSmoother<type > block##Type##Smoother; \
|
||||||
defineNamedTemplateTypeNameAndDebug(block##Type##Smoother, 0); \
|
defineNamedTemplateTypeNameAndDebug(block##Type##Smoother, 0); \
|
||||||
|
|
Reference in a new issue