Nektar++
|
#include <NekNonlinSys.h>
Protected Member Functions | |
virtual void | v_InitObject () |
virtual void | v_SetupNekNonlinSystem (const int nGlobal, const Array< OneD, const NekDouble > &pInput, const Array< OneD, const NekDouble > &pSource, const int nDir)=0 |
![]() | |
virtual int | v_SolveSystem (const int nGlobal, const Array< OneD, const NekDouble > &pInput, Array< OneD, NekDouble > &pOutput, const int nDir, const NekDouble tol, const NekDouble factor) |
virtual bool | v_ConvergenceCheck (const int nIteration, const Array< OneD, const NekDouble > &Residual, const NekDouble tol) |
virtual void | v_NekSysInitialGuess (const Array< OneD, const NekDouble > &pInput, Array< OneD, NekDouble > &pguess) |
Protected Attributes | |
NekLinSysIterSharedPtr | m_linsol |
NekDouble | m_NonlinIterTolRelativeL2 |
NekDouble | m_LinSysRelativeTolInNonlin |
std::string | m_LinSysIterSolverType |
int | m_totalIterations = 0 |
int | m_NtotLinSysIts = 0 |
Array< OneD, NekDouble > | m_Solution |
Array< OneD, NekDouble > | m_Residual |
Array< OneD, NekDouble > | m_DeltSltn |
Array< OneD, NekDouble > | m_SourceVec |
bool | m_ResidualUpdated = false |
![]() | |
int | m_maxiter |
Maximum iterations. More... | |
NekDouble | m_tolerance |
Tolerance of iterative solver. More... | |
LibUtilities::CommSharedPtr | m_Comm |
Communicate. More... | |
bool | m_converged |
Whether the iteration has been converged. More... | |
bool | m_root |
Root if parallel. More... | |
bool | m_verbose |
Verbose. More... | |
bool | m_FlagWarnings |
NekSysOperators | m_operator |
Operators. More... | |
int | m_SysDimen |
The dimension of the system. More... | |
Additional Inherited Members | |
![]() | |
static NekSysSharedPtr | CreateInstance (const LibUtilities::SessionReaderSharedPtr &pSession, const LibUtilities::CommSharedPtr &vComm, const int nDimen, const NekSysKey &pKey) |
Solves a nonlinear system using iterative methods.
Definition at line 56 of file NekNonlinSys.h.
Nektar::LibUtilities::NekNonlinSys::NekNonlinSys | ( | const LibUtilities::SessionReaderSharedPtr & | pSession, |
const LibUtilities::CommSharedPtr & | vComm, | ||
const int | nDimen, | ||
const NekSysKey & | pKey | ||
) |
Definition at line 55 of file NekNonlinSys.cpp.
References ASSERTL0, Nektar::LibUtilities::NekFactory< tKey, tBase, tParam >::CreateInstance(), Nektar::LibUtilities::GetNekLinSysIterFactory(), Nektar::LibUtilities::NekSys::m_Comm, m_linsol, m_LinSysIterSolverType, Nektar::LibUtilities::NekSysKey::m_LinSysIterSolverTypeInNonlin, m_LinSysRelativeTolInNonlin, Nektar::LibUtilities::NekSysKey::m_LinSysRelativeTolInNonlin, Nektar::LibUtilities::NekSys::m_maxiter, Nektar::LibUtilities::NekSysKey::m_NekNonlinSysMaxIterations, Nektar::LibUtilities::NekSysKey::m_NekNonlinSysTolerance, m_NonlinIterTolRelativeL2, Nektar::LibUtilities::NekSysKey::m_NonlinIterTolRelativeL2, Nektar::LibUtilities::NekSys::m_SysDimen, and Nektar::LibUtilities::NekSys::m_tolerance.
Nektar::LibUtilities::NekNonlinSys::~NekNonlinSys | ( | ) |
Definition at line 152 of file NekNonlinSys.cpp.
|
inline |
Definition at line 104 of file NekNonlinSys.h.
References m_linsol.
|
inline |
Definition at line 119 of file NekNonlinSys.h.
References m_NtotLinSysIts.
|
inline |
Definition at line 71 of file NekNonlinSys.h.
References m_Residual.
|
inline |
Definition at line 65 of file NekNonlinSys.h.
References m_Solution.
|
inline |
Definition at line 77 of file NekNonlinSys.h.
References m_SourceVec.
Definition at line 114 of file NekNonlinSys.h.
References m_LinSysRelativeTolInNonlin.
|
inline |
Definition at line 98 of file NekNonlinSys.h.
References Nektar::LibUtilities::NekSys::m_maxiter.
Definition at line 93 of file NekNonlinSys.h.
References Nektar::LibUtilities::NekSys::m_tolerance.
Definition at line 109 of file NekNonlinSys.h.
References m_NonlinIterTolRelativeL2.
|
inline |
Definition at line 83 of file NekNonlinSys.h.
References ASSERTL0, m_Residual, m_ResidualUpdated, Nektar::LibUtilities::NekSys::m_SysDimen, and Vmath::Vcopy().
|
inline |
Definition at line 124 of file NekNonlinSys.h.
References v_SetupNekNonlinSystem().
|
protectedvirtual |
Reimplemented from Nektar::LibUtilities::NekSys.
Reimplemented in Nektar::LibUtilities::NekNonlinSysNewton.
Definition at line 147 of file NekNonlinSys.cpp.
References Nektar::LibUtilities::NekSys::v_InitObject().
|
protectedpure virtual |
Implemented in Nektar::LibUtilities::NekNonlinSysNewton.
Referenced by SetupNekNonlinSystem().
Definition at line 144 of file NekNonlinSys.h.
Referenced by Nektar::LibUtilities::NekNonlinSysNewton::v_InitObject(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
|
protected |
Definition at line 132 of file NekNonlinSys.h.
Referenced by GetLinSys(), NekNonlinSys(), Nektar::LibUtilities::NekNonlinSysNewton::v_SetupNekNonlinSystem(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
|
protected |
Definition at line 137 of file NekNonlinSys.h.
Referenced by NekNonlinSys().
|
protected |
Definition at line 135 of file NekNonlinSys.h.
Referenced by Nektar::LibUtilities::NekNonlinSysNewton::CalcInexactNewtonForcing(), NekNonlinSys(), and SetLinSysRelativeTolInNonlin().
|
protected |
Definition at line 134 of file NekNonlinSys.h.
Referenced by NekNonlinSys(), SetNonlinIterTolRelativeL2(), and Nektar::LibUtilities::NekNonlinSysNewton::v_ConvergenceCheck().
|
protected |
Definition at line 140 of file NekNonlinSys.h.
Referenced by GetNtotLinSysIts(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
Definition at line 143 of file NekNonlinSys.h.
Referenced by GetRefResidual(), SetRefResidual(), Nektar::LibUtilities::NekNonlinSysNewton::v_InitObject(), Nektar::LibUtilities::NekNonlinSysNewton::v_SetupNekNonlinSystem(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
|
protected |
Definition at line 147 of file NekNonlinSys.h.
Referenced by SetRefResidual(), Nektar::LibUtilities::NekNonlinSysNewton::v_SetupNekNonlinSystem(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
Definition at line 142 of file NekNonlinSys.h.
Referenced by GetRefSolution(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SolveSystem().
Definition at line 145 of file NekNonlinSys.h.
Referenced by GetRefSourceVec(), Nektar::LibUtilities::NekNonlinSysNewton::v_InitObject(), and Nektar::LibUtilities::NekNonlinSysNewton::v_SetupNekNonlinSystem().
|
protected |
Definition at line 139 of file NekNonlinSys.h.