|
Nektar++
|
A global linear system. More...
#include <GlobalLinSysPETScStaticCond.h>


Public Member Functions | |
| GlobalLinSysPETScStaticCond (const GlobalLinSysKey &mkey, const boost::weak_ptr< ExpList > &pExpList, const boost::shared_ptr< AssemblyMap > &locToGloMap) | |
| Constructor for full direct matrix solve. More... | |
| GlobalLinSysPETScStaticCond (const GlobalLinSysKey &mkey, const boost::weak_ptr< ExpList > &pExpList, const DNekScalBlkMatSharedPtr pSchurCompl, const DNekScalBlkMatSharedPtr pBinvD, const DNekScalBlkMatSharedPtr pC, const DNekScalBlkMatSharedPtr pInvD, const boost::shared_ptr< AssemblyMap > &locToGloMap, const PreconditionerSharedPtr pPrecon=PreconditionerSharedPtr()) | |
| Constructor for full direct matrix solve. More... | |
| virtual | ~GlobalLinSysPETScStaticCond () |
Public Member Functions inherited from Nektar::MultiRegions::GlobalLinSysPETSc | |
| GlobalLinSysPETSc (const GlobalLinSysKey &pKey, const boost::weak_ptr< ExpList > &pExp, const boost::shared_ptr< AssemblyMap > &pLocToGloMap) | |
| Constructor for full direct matrix solve. More... | |
| virtual | ~GlobalLinSysPETSc () |
| Clean up PETSc objects. More... | |
| virtual void | v_SolveLinearSystem (const int pNumRows, const Array< OneD, const NekDouble > &pInput, Array< OneD, NekDouble > &pOutput, const AssemblyMapSharedPtr &locToGloMap, const int pNumDir) |
| Solve linear system using PETSc. More... | |
Public Member Functions inherited from Nektar::MultiRegions::GlobalLinSys | |
| GlobalLinSys (const GlobalLinSysKey &pKey, const boost::weak_ptr< ExpList > &pExpList, const boost::shared_ptr< AssemblyMap > &pLocToGloMap) | |
| Constructor for full direct matrix solve. More... | |
| virtual | ~GlobalLinSys () |
| const GlobalLinSysKey & | GetKey (void) const |
| Returns the key associated with the system. More... | |
| const boost::weak_ptr< ExpList > & | GetLocMat (void) const |
| void | InitObject () |
| void | Initialise (const boost::shared_ptr< AssemblyMap > &pLocToGloMap) |
| void | Solve (const Array< OneD, const NekDouble > &in, Array< OneD, NekDouble > &out, const AssemblyMapSharedPtr &locToGloMap, const Array< OneD, const NekDouble > &dirForcing=NullNekDouble1DArray) |
| Solve the linear system for given input and output vectors using a specified local to global map. More... | |
| boost::shared_ptr< GlobalLinSys > | GetSharedThisPtr () |
| Returns a shared pointer to the current object. More... | |
| int | GetNumBlocks () |
| DNekScalMatSharedPtr | GetBlock (unsigned int n) |
| DNekScalBlkMatSharedPtr | GetStaticCondBlock (unsigned int n) |
| void | DropStaticCondBlock (unsigned int n) |
| void | SolveLinearSystem (const int pNumRows, const Array< OneD, const NekDouble > &pInput, Array< OneD, NekDouble > &pOutput, const AssemblyMapSharedPtr &locToGloMap, const int pNumDir=0) |
| Solve the linear system for given input and output vectors. More... | |
Public Member Functions inherited from Nektar::MultiRegions::GlobalLinSysStaticCond | |
| GlobalLinSysStaticCond (const GlobalLinSysKey &mkey, const boost::weak_ptr< ExpList > &pExpList, const boost::shared_ptr< AssemblyMap > &locToGloMap) | |
| Constructor for full direct matrix solve. More... | |
| virtual | ~GlobalLinSysStaticCond () |
Static Public Member Functions | |
| static GlobalLinSysSharedPtr | create (const GlobalLinSysKey &pLinSysKey, const boost::weak_ptr< ExpList > &pExpList, const boost::shared_ptr< AssemblyMap > &pLocToGloMap) |
| Creates an instance of this class. More... | |
Static Public Attributes | |
| static std::string | className |
| Name of class. More... | |
| static std::string | className2 |
Protected Member Functions | |
| virtual void | v_InitObject () |
| virtual void | v_AssembleSchurComplement (boost::shared_ptr< AssemblyMap > locToGloMap) |
| Assemble the Schur complement matrix. More... | |
| virtual void | v_DoMatrixMultiply (const Array< OneD, const NekDouble > &input, Array< OneD, NekDouble > &output) |
| Apply matrix-vector multiplication using local approach and the assembly map. More... | |
| virtual DNekScalBlkMatSharedPtr | v_GetStaticCondBlock (unsigned int n) |
| Retrieves a the static condensation block matrices from n-th expansion using the matrix key provided by the m_linSysKey. More... | |
| virtual DNekScalBlkMatSharedPtr | v_PreSolve (int scLevel, NekVector< NekDouble > &F_GlobBnd) |
| virtual void | v_BasisTransform (Array< OneD, NekDouble > &pInOut, int offset) |
| virtual void | v_BasisInvTransform (Array< OneD, NekDouble > &pInOut) |
| virtual GlobalLinSysStaticCondSharedPtr | v_Recurse (const GlobalLinSysKey &mkey, const boost::weak_ptr< ExpList > &pExpList, const DNekScalBlkMatSharedPtr pSchurCompl, const DNekScalBlkMatSharedPtr pBinvD, const DNekScalBlkMatSharedPtr pC, const DNekScalBlkMatSharedPtr pInvD, const boost::shared_ptr< AssemblyMap > &locToGloMap) |
Protected Member Functions inherited from Nektar::MultiRegions::GlobalLinSysPETSc | |
| void | SetUpScatter () |
| Set up PETSc local (equivalent to Nektar++ global) and global (equivalent to universal) scatter maps. More... | |
| void | SetUpMatVec (int nGlobal, int nDir) |
| Construct PETSc matrix and vector handles. More... | |
| void | SetUpSolver (NekDouble tolerance) |
| Set up KSP solver object. More... | |
| void | CalculateReordering (const Array< OneD, const int > &glo2uniMap, const Array< OneD, const int > &glo2unique, const AssemblyMapSharedPtr &pLocToGloMap) |
| Calculate a reordering of universal IDs for PETSc. More... | |
Protected Member Functions inherited from Nektar::MultiRegions::GlobalLinSys | |
| virtual DNekScalMatSharedPtr | v_GetBlock (unsigned int n) |
| Retrieves the block matrix from n-th expansion using the matrix key provided by the m_linSysKey. More... | |
| virtual void | v_DropStaticCondBlock (unsigned int n) |
| Releases the static condensation block matrices from NekManager of n-th expansion using the matrix key provided by the m_linSysKey. More... | |
| PreconditionerSharedPtr | CreatePrecon (AssemblyMapSharedPtr asmMap) |
| Create a preconditioner object from the parameters defined in the supplied assembly map. More... | |
Protected Member Functions inherited from Nektar::MultiRegions::GlobalLinSysStaticCond | |
| virtual int | v_GetNumBlocks () |
| Get the number of blocks in this system. More... | |
| virtual void | v_Solve (const Array< OneD, const NekDouble > &in, Array< OneD, NekDouble > &out, const AssemblyMapSharedPtr &locToGloMap, const Array< OneD, const NekDouble > &dirForcing=NullNekDouble1DArray) |
| Solve the linear system for given input and output vectors using a specified local to global map. More... | |
| virtual void | v_Initialise (const boost::shared_ptr< AssemblyMap > &locToGloMap) |
| Initialise this object. More... | |
| void | SetupTopLevel (const boost::shared_ptr< AssemblyMap > &locToGloMap) |
| Set up the storage for the Schur complement or the top level of the multi-level Schur complement. More... | |
| void | ConstructNextLevelCondensedSystem (const boost::shared_ptr< AssemblyMap > &locToGloMap) |
Protected Attributes | |
| DNekScalBlkMatSharedPtr | m_S1Blk |
Protected Attributes inherited from Nektar::MultiRegions::GlobalLinSysPETSc | |
| Mat | m_matrix |
| PETSc matrix object. More... | |
| Vec | m_x |
| PETSc vector objects used for local storage. More... | |
| Vec | m_b |
| Vec | m_locVec |
| KSP | m_ksp |
| KSP object that represents solver system. More... | |
| PC | m_pc |
| PCShell for preconditioner. More... | |
| PETScMatMult | m_matMult |
| Enumerator to select matrix multiplication type. More... | |
| std::vector< int > | m_reorderedMap |
| Reordering that takes universal IDs to a unique row in the PETSc matrix. More... | |
| VecScatter | m_ctx |
| PETSc scatter context that takes us between Nektar++ global ordering and PETSc vector ordering. More... | |
| int | m_nLocal |
| Number of unique degrees of freedom on this process. More... | |
| PreconditionerSharedPtr | m_precon |
Protected Attributes inherited from Nektar::MultiRegions::GlobalLinSys | |
| const GlobalLinSysKey | m_linSysKey |
| Key associated with this linear system. More... | |
| const boost::weak_ptr< ExpList > | m_expList |
| Local Matrix System. More... | |
| const std::map< int, RobinBCInfoSharedPtr > | m_robinBCInfo |
| Robin boundary info. More... | |
| bool | m_verbose |
Protected Attributes inherited from Nektar::MultiRegions::GlobalLinSysStaticCond | |
| GlobalLinSysStaticCondSharedPtr | m_recursiveSchurCompl |
| Schur complement for Direct Static Condensation. More... | |
| DNekScalBlkMatSharedPtr | m_schurCompl |
| Block Schur complement matrix. More... | |
| DNekScalBlkMatSharedPtr | m_BinvD |
Block matrix. More... | |
| DNekScalBlkMatSharedPtr | m_C |
Block matrix. More... | |
| DNekScalBlkMatSharedPtr | m_invD |
Block matrix. More... | |
| boost::shared_ptr< AssemblyMap > | m_locToGloMap |
| Local to global map. More... | |
| Array< OneD, NekDouble > | m_wsp |
| Workspace array for matrix multiplication. More... | |
A global linear system.
Definition at line 55 of file GlobalLinSysPETScStaticCond.h.
| Nektar::MultiRegions::GlobalLinSysPETScStaticCond::GlobalLinSysPETScStaticCond | ( | const GlobalLinSysKey & | pKey, |
| const boost::weak_ptr< ExpList > & | pExpList, | ||
| const boost::shared_ptr< AssemblyMap > & | pLocToGloMap | ||
| ) |
Constructor for full direct matrix solve.
For a matrix system of the form
where
and
are invertible, store and assemble a static condensation system, according to a given local to global mapping. #m_linSys is constructed by AssembleSchurComplement().
| mKey | Associated matrix key. |
| pLocMatSys | LocalMatrixSystem |
| locToGloMap | Local to global mapping. |
Definition at line 89 of file GlobalLinSysPETScStaticCond.cpp.
References ASSERTL1, Nektar::MultiRegions::ePETScMultiLevelStaticCond, Nektar::MultiRegions::ePETScStaticCond, and Nektar::MultiRegions::GlobalLinSysKey::GetGlobalSysSolnType().
| Nektar::MultiRegions::GlobalLinSysPETScStaticCond::GlobalLinSysPETScStaticCond | ( | const GlobalLinSysKey & | mkey, |
| const boost::weak_ptr< ExpList > & | pExpList, | ||
| const DNekScalBlkMatSharedPtr | pSchurCompl, | ||
| const DNekScalBlkMatSharedPtr | pBinvD, | ||
| const DNekScalBlkMatSharedPtr | pC, | ||
| const DNekScalBlkMatSharedPtr | pInvD, | ||
| const boost::shared_ptr< AssemblyMap > & | locToGloMap, | ||
| const PreconditionerSharedPtr | pPrecon = PreconditionerSharedPtr() |
||
| ) |
Constructor for full direct matrix solve.
Definition at line 110 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSysStaticCond::m_BinvD, Nektar::MultiRegions::GlobalLinSysStaticCond::m_C, Nektar::MultiRegions::GlobalLinSysStaticCond::m_invD, Nektar::MultiRegions::GlobalLinSysPETSc::m_precon, and Nektar::MultiRegions::GlobalLinSysStaticCond::m_schurCompl.
|
virtual |
Definition at line 133 of file GlobalLinSysPETScStaticCond.cpp.
|
inlinestatic |
Creates an instance of this class.
Definition at line 60 of file GlobalLinSysPETScStaticCond.h.
|
protectedvirtual |
Assemble the Schur complement matrix.
Assemble the schur complement matrix from the block matrices stored in #m_blkMatrices and the given local to global mapping information.
| locToGloMap | Local to global mapping information. |
Reimplemented from Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 187 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSysPETSc::CalculateReordering(), Nektar::MultiRegions::GlobalLinSys::CreatePrecon(), Nektar::MultiRegions::ePETScMatMultShell, Nektar::MultiRegions::ePETScMultiLevelStaticCond, Nektar::MultiRegions::GlobalLinSysKey::GetGlobalSysSolnType(), Nektar::MultiRegions::GlobalLinSysStaticCond::m_BinvD, Nektar::MultiRegions::GlobalLinSysStaticCond::m_C, Nektar::MultiRegions::GlobalLinSysStaticCond::m_invD, Nektar::MultiRegions::GlobalLinSys::m_linSysKey, Nektar::MultiRegions::GlobalLinSysStaticCond::m_locToGloMap, Nektar::MultiRegions::GlobalLinSysPETSc::m_matMult, Nektar::MultiRegions::GlobalLinSysPETSc::m_matrix, Nektar::MultiRegions::GlobalLinSysPETSc::m_precon, Nektar::MultiRegions::GlobalLinSysPETSc::m_reorderedMap, Nektar::MultiRegions::GlobalLinSysStaticCond::m_schurCompl, Nektar::MultiRegions::GlobalLinSysPETSc::SetUpMatVec(), Nektar::MultiRegions::GlobalLinSysPETSc::SetUpScatter(), and Nektar::MultiRegions::GlobalLinSysPETSc::SetUpSolver().
|
protectedvirtual |
Reimplemented from Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 314 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSysPETSc::m_precon.
|
protectedvirtual |
Reimplemented from Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 307 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSysPETSc::m_precon.
|
protectedvirtual |
Apply matrix-vector multiplication using local approach and the assembly map.
| input | Vector input. |
| output | Result of multiplication. |
Implements Nektar::MultiRegions::GlobalLinSysPETSc.
Definition at line 331 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::NekVector< DataType >::GetPtr(), and Nektar::MultiRegions::GlobalLinSysStaticCond::m_locToGloMap.
|
protectedvirtual |
Retrieves a the static condensation block matrices from n-th expansion using the matrix key provided by the m_linSysKey.
| n | Number of the expansion |
Reimplemented from Nektar::MultiRegions::GlobalLinSys.
Definition at line 268 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MemoryManager< DataType >::AllocateSharedPtr(), Nektar::MultiRegions::GlobalLinSysStaticCond::m_locToGloMap, m_S1Blk, and Nektar::MultiRegions::GlobalLinSysStaticCond::m_schurCompl.
|
protectedvirtual |
Reimplemented from Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 138 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MemoryManager< DataType >::AllocateSharedPtr(), Nektar::MultiRegions::GlobalLinSys::CreatePrecon(), Nektar::eDIAGONAL, Nektar::StdRegions::eHybridDGHelmBndLam, Nektar::MultiRegions::GlobalMatrixKey::GetMatrixType(), Nektar::MultiRegions::GlobalLinSys::Initialise(), Nektar::MultiRegions::GlobalLinSys::m_expList, Nektar::MultiRegions::GlobalLinSys::m_linSysKey, Nektar::MultiRegions::GlobalLinSysStaticCond::m_locToGloMap, Nektar::MultiRegions::GlobalLinSysPETSc::m_precon, m_S1Blk, Nektar::MultiRegions::GlobalLinSysStaticCond::m_schurCompl, and Nektar::MultiRegions::GlobalLinSysStaticCond::SetupTopLevel().
|
protectedvirtual |
Reimplemented from Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 285 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSys::CreatePrecon(), Nektar::MultiRegions::GlobalLinSysStaticCond::m_locToGloMap, Nektar::MultiRegions::GlobalLinSysPETSc::m_precon, m_S1Blk, and Nektar::MultiRegions::GlobalLinSysStaticCond::m_schurCompl.
|
protectedvirtual |
Implements Nektar::MultiRegions::GlobalLinSysStaticCond.
Definition at line 344 of file GlobalLinSysPETScStaticCond.cpp.
References Nektar::MultiRegions::GlobalLinSysPETSc::m_precon.
|
static |
Name of class.
Registers the class with the Factory.
Definition at line 73 of file GlobalLinSysPETScStaticCond.h.
|
static |
Definition at line 74 of file GlobalLinSysPETScStaticCond.h.
|
protected |
Definition at line 97 of file GlobalLinSysPETScStaticCond.h.
Referenced by v_GetStaticCondBlock(), v_InitObject(), and v_PreSolve().
1.8.8