Nektar++
|
#include <Preconditioner.h>
Protected Member Functions | |
virtual DNekScalMatSharedPtr | v_TransformedSchurCompl (int offset, int bndoffset, const std::shared_ptr< DNekScalMat > &loc_mat) |
Get block elemental transposed transformation matrix \(\mathbf{R}^{T}\). More... | |
virtual void | v_InitObject () |
virtual void | v_DoPreconditioner (const Array< OneD, NekDouble > &pInput, Array< OneD, NekDouble > &pOutput) |
Apply a preconditioner to the conjugate gradient method. More... | |
virtual void | v_DoPreconditionerWithNonVertOutput (const Array< OneD, NekDouble > &pInput, Array< OneD, NekDouble > &pOutput, const Array< OneD, NekDouble > &pNonVertOutput, Array< OneD, NekDouble > &pVertForce) |
Apply a preconditioner to the conjugate gradient method with an output for non-vertex degrees of freedom. More... | |
virtual void | v_DoTransformBasisToLowEnergy (Array< OneD, NekDouble > &pInOut) |
Transform from original basis to low energy basis. More... | |
virtual void | v_DoTransformCoeffsFromLowEnergy (Array< OneD, NekDouble > &pInOut) |
Transform from low energy coeffs to orignal basis. More... | |
virtual void | v_DoTransformCoeffsToLowEnergy (const Array< OneD, NekDouble > &pInput, Array< OneD, NekDouble > &pOutput) |
Multiply by the block inverse transformation matrix. More... | |
virtual void | v_DoTransformBasisFromLowEnergy (const Array< OneD, NekDouble > &pInput, Array< OneD, NekDouble > &pOutput) |
Multiply by the block transposed inverse transformation matrix. More... | |
virtual void | v_BuildPreconditioner () |
Protected Attributes | |
const std::weak_ptr< GlobalLinSys > | m_linsys |
PreconditionerType | m_preconType |
DNekMatSharedPtr | m_preconditioner |
std::weak_ptr< AssemblyMap > | m_locToGloMap |
LibUtilities::CommSharedPtr | m_comm |
Private Member Functions | |
void | NullPreconditioner (void) |
Static Private Attributes | |
static std::string | lookupIds [] |
static std::string | def |
This class implements preconditioning for the conjugate gradient matrix solver.
This class implements diagonal preconditioning for the conjugate gradient matrix solver.
Definition at line 65 of file Preconditioner.h.
Nektar::MultiRegions::Preconditioner::Preconditioner | ( | const std::shared_ptr< GlobalLinSys > & | plinsys, |
const AssemblyMapSharedPtr & | pLocToGloMap | ||
) |
Definition at line 76 of file Preconditioner.cpp.
|
inlinevirtual |
Definition at line 73 of file Preconditioner.h.
Array< OneD, NekDouble > Nektar::MultiRegions::Preconditioner::AssembleStaticCondGlobalDiagonals | ( | ) |
Performs global assembly of diagonal entries to global Schur complement matrix.
Definition at line 176 of file Preconditioner.cpp.
References m_linsys, and m_locToGloMap.
Referenced by Nektar::MultiRegions::PreconditionerDiagonal::StaticCondDiagonalPreconditionerSum().
|
inline |
Definition at line 235 of file Preconditioner.h.
References v_BuildPreconditioner().
|
inline |
Definition at line 178 of file Preconditioner.h.
References v_DoPreconditioner().
|
inline |
Definition at line 187 of file Preconditioner.h.
References v_DoPreconditionerWithNonVertOutput().
|
inline |
Definition at line 226 of file Preconditioner.h.
References v_DoTransformBasisFromLowEnergy().
|
inline |
Definition at line 199 of file Preconditioner.h.
References v_DoTransformBasisToLowEnergy().
|
inline |
Definition at line 208 of file Preconditioner.h.
References v_DoTransformCoeffsFromLowEnergy().
|
inline |
Definition at line 217 of file Preconditioner.h.
References v_DoTransformCoeffsToLowEnergy().
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Definition at line 161 of file Preconditioner.h.
References v_InitObject().
|
inline |
Definition at line 169 of file Preconditioner.h.
References v_TransformedSchurCompl().
|
protectedvirtual |
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithDiag, Nektar::MultiRegions::PreconditionerLinearWithBlock, Nektar::MultiRegions::PreconditionerLinear, Nektar::MultiRegions::PreconditionerNull, Nektar::MultiRegions::PreconditionerDiagonal, and Nektar::MultiRegions::PreconditionerBlock.
Definition at line 157 of file Preconditioner.cpp.
Referenced by BuildPreconditioner().
|
protectedvirtual |
Apply a preconditioner to the conjugate gradient method.
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithDiag, Nektar::MultiRegions::PreconditionerLinearWithBlock, Nektar::MultiRegions::PreconditionerLinear, Nektar::MultiRegions::PreconditionerNull, Nektar::MultiRegions::PreconditionerDiagonal, and Nektar::MultiRegions::PreconditionerBlock.
Definition at line 100 of file Preconditioner.cpp.
References Nektar::ErrorUtil::efatal, and NEKERROR.
Referenced by DoPreconditioner().
|
protectedvirtual |
Apply a preconditioner to the conjugate gradient method with an output for non-vertex degrees of freedom.
Reimplemented in Nektar::MultiRegions::PreconditionerLinear.
Definition at line 111 of file Preconditioner.cpp.
References Nektar::ErrorUtil::efatal, and NEKERROR.
Referenced by DoPreconditionerWithNonVertOutput().
|
protectedvirtual |
Multiply by the block transposed inverse transformation matrix.
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, and Nektar::MultiRegions::PreconditionerLinearWithLowEnergy.
Definition at line 150 of file Preconditioner.cpp.
References Nektar::ErrorUtil::efatal, and NEKERROR.
Referenced by DoTransformBasisFromLowEnergy().
|
protectedvirtual |
Transform from original basis to low energy basis.
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, and Nektar::MultiRegions::PreconditionerLinearWithLowEnergy.
Definition at line 123 of file Preconditioner.cpp.
Referenced by DoTransformBasisToLowEnergy().
|
protectedvirtual |
Transform from low energy coeffs to orignal basis.
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, and Nektar::MultiRegions::PreconditionerLinearWithLowEnergy.
Definition at line 132 of file Preconditioner.cpp.
Referenced by DoTransformCoeffsFromLowEnergy().
|
protectedvirtual |
Multiply by the block inverse transformation matrix.
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, and Nektar::MultiRegions::PreconditionerLinearWithLowEnergy.
Definition at line 141 of file Preconditioner.cpp.
Referenced by DoTransformCoeffsToLowEnergy().
|
protectedvirtual |
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithLowEnergy, Nektar::MultiRegions::PreconditionerLinearWithDiag, Nektar::MultiRegions::PreconditionerLinearWithBlock, Nektar::MultiRegions::PreconditionerLinear, Nektar::MultiRegions::PreconditionerNull, Nektar::MultiRegions::PreconditionerDiagonal, and Nektar::MultiRegions::PreconditionerBlock.
Definition at line 92 of file Preconditioner.cpp.
References Nektar::ErrorUtil::efatal, and NEKERROR.
Referenced by InitObject().
|
protectedvirtual |
Get block elemental transposed transformation matrix \(\mathbf{R}^{T}\).
Reimplemented in Nektar::MultiRegions::PreconditionerLowEnergy, and Nektar::MultiRegions::PreconditionerLinearWithLowEnergy.
Definition at line 165 of file Preconditioner.cpp.
Referenced by TransformedSchurCompl().
|
staticprivate |
Definition at line 154 of file Preconditioner.h.
|
staticprivate |
Definition at line 153 of file Preconditioner.h.
|
protected |
Definition at line 122 of file Preconditioner.h.
Referenced by Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerCG(), Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerHDG(), Nektar::MultiRegions::PreconditionerLowEnergy::SetUpReferenceElements(), Nektar::MultiRegions::PreconditionerLowEnergy::v_BuildPreconditioner(), and Nektar::MultiRegions::PreconditionerLowEnergy::v_InitObject().
|
protected |
Definition at line 118 of file Preconditioner.h.
Referenced by AssembleStaticCondGlobalDiagonals(), Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerCG(), Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerHDG(), Nektar::MultiRegions::PreconditionerDiagonal::DiagonalPreconditionerSum(), Nektar::MultiRegions::PreconditionerLowEnergy::SetupBlockTransformationMatrix(), Nektar::MultiRegions::PreconditionerLowEnergy::SetUpReferenceElements(), Nektar::MultiRegions::PreconditionerBlock::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerLinear::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerLowEnergy::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerLinearWithBlock::v_InitObject(), Nektar::MultiRegions::PreconditionerLinearWithDiag::v_InitObject(), Nektar::MultiRegions::PreconditionerLinearWithLowEnergy::v_InitObject(), Nektar::MultiRegions::PreconditionerLowEnergy::v_InitObject(), and Nektar::MultiRegions::PreconditionerLowEnergy::v_TransformedSchurCompl().
|
protected |
Definition at line 121 of file Preconditioner.h.
Referenced by AssembleStaticCondGlobalDiagonals(), Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerCG(), Nektar::MultiRegions::PreconditionerBlock::BlockPreconditionerHDG(), Nektar::MultiRegions::PreconditionerLowEnergy::CreateVariablePMask(), Nektar::MultiRegions::PreconditionerDiagonal::DiagonalPreconditionerSum(), Nektar::MultiRegions::PreconditionerLowEnergy::SetupBlockTransformationMatrix(), Nektar::MultiRegions::PreconditionerDiagonal::StaticCondDiagonalPreconditionerSum(), Nektar::MultiRegions::PreconditionerDiagonal::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerLinear::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerLowEnergy::v_BuildPreconditioner(), Nektar::MultiRegions::PreconditionerBlock::v_DoPreconditioner(), Nektar::MultiRegions::PreconditionerDiagonal::v_DoPreconditioner(), Nektar::MultiRegions::PreconditionerLinearWithLowEnergy::v_DoPreconditioner(), Nektar::MultiRegions::PreconditionerLowEnergy::v_DoPreconditioner(), Nektar::MultiRegions::PreconditionerLinear::v_DoPreconditionerWithNonVertOutput(), Nektar::MultiRegions::PreconditionerLowEnergy::v_DoTransformBasisFromLowEnergy(), Nektar::MultiRegions::PreconditionerLowEnergy::v_DoTransformBasisToLowEnergy(), Nektar::MultiRegions::PreconditionerLowEnergy::v_DoTransformCoeffsFromLowEnergy(), Nektar::MultiRegions::PreconditionerLowEnergy::v_DoTransformCoeffsToLowEnergy(), Nektar::MultiRegions::PreconditionerBlock::v_InitObject(), Nektar::MultiRegions::PreconditionerLinearWithBlock::v_InitObject(), Nektar::MultiRegions::PreconditionerLinearWithDiag::v_InitObject(), Nektar::MultiRegions::PreconditionerLinearWithLowEnergy::v_InitObject(), and Nektar::MultiRegions::PreconditionerLowEnergy::v_InitObject().
|
protected |
Definition at line 120 of file Preconditioner.h.
|
protected |
Definition at line 119 of file Preconditioner.h.