Open CASCADE Technology Reference Manual 8.0.0
Loading...
Searching...
No Matches
Public Member Functions
FEmTool_ProfileMatrix Class Reference

Symmetric Sparse ProfileMatrix useful for 1D Finite Element methods. More...

#include <FEmTool_ProfileMatrix.hxx>

Inheritance diagram for FEmTool_ProfileMatrix:
Inheritance graph
[legend]

Public Member Functions

 FEmTool_ProfileMatrix (const NCollection_Array1< int > &FirstIndexes)
 
void Init (const double Value) override
 
doubleChangeValue (const int I, const int J) override
 
bool Decompose () override
 To make a Factorization of <me>
 
void Solve (const math_Vector &B, math_Vector &X) const override
 Direct Solve of AX = B.
 
bool Prepare () override
 Make Preparation to iterative solve.
 
void Solve (const math_Vector &B, const math_Vector &Init, math_Vector &X, math_Vector &Residual, const double Tolerance=1.0e-8, const int NbIterations=50) const override
 Iterative solve of AX = B.
 
void Multiplied (const math_Vector &X, math_Vector &MX) const override
 returns the product of a SparseMatrix by a vector. An exception is raised if the dimensions are different
 
int RowNumber () const override
 returns the row range of a matrix.
 
int ColNumber () const override
 returns the column range of the matrix.
 
bool IsInProfile (const int i, const int j) const
 
void OutM () const
 
void OutS () const
 
- Public Member Functions inherited from Standard_Transient
 Standard_Transient ()
 Empty constructor.
 
 Standard_Transient (const Standard_Transient &)
 Copy constructor – does nothing.
 
Standard_Transientoperator= (const Standard_Transient &)
 Assignment operator, needed to avoid copying reference counter.
 
virtual ~Standard_Transient ()=default
 Destructor must be virtual.
 
virtual const opencascade::handle< Standard_Type > & DynamicType () const
 Returns a type descriptor about this object.
 
bool IsInstance (const opencascade::handle< Standard_Type > &theType) const
 Returns a true value if this is an instance of Type.
 
bool IsInstance (const char *const theTypeName) const
 Returns a true value if this is an instance of TypeName.
 
bool IsKind (const opencascade::handle< Standard_Type > &theType) const
 Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
bool IsKind (const char *const theTypeName) const
 Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism.
 
Standard_TransientThis () const
 Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero.
 
int GetRefCount () const noexcept
 Get the reference counter of this object.
 
void IncrementRefCounter () noexcept
 Increments the reference counter of this object. Uses relaxed memory ordering since incrementing only requires atomicity, not synchronization with other memory operations.
 
int DecrementRefCounter () noexcept
 Decrements the reference counter of this object; returns the decremented value. Uses release ordering for the decrement to ensure all writes to the object are visible before the count reaches zero. An acquire fence is added only when the count reaches zero, ensuring proper synchronization before deletion. This is more efficient than using acq_rel for every decrement.
 
virtual void Delete () const
 Memory deallocator for transient classes.
 

Additional Inherited Members

- Public Types inherited from Standard_Transient
typedef void base_type
 Returns a type descriptor about this object.
 
- Static Public Member Functions inherited from Standard_Transient
static constexpr const charget_type_name ()
 Returns a type descriptor about this object.
 
static const opencascade::handle< Standard_Type > & get_type_descriptor ()
 Returns type descriptor of Standard_Transient class.
 

Detailed Description

Symmetric Sparse ProfileMatrix useful for 1D Finite Element methods.

Constructor & Destructor Documentation

◆ FEmTool_ProfileMatrix()

FEmTool_ProfileMatrix::FEmTool_ProfileMatrix ( const NCollection_Array1< int > & FirstIndexes)

Member Function Documentation

◆ ChangeValue()

double & FEmTool_ProfileMatrix::ChangeValue ( const int I,
const int J )
overridevirtual

Implements FEmTool_SparseMatrix.

◆ ColNumber()

int FEmTool_ProfileMatrix::ColNumber ( ) const
overridevirtual

returns the column range of the matrix.

Implements FEmTool_SparseMatrix.

◆ Decompose()

bool FEmTool_ProfileMatrix::Decompose ( )
overridevirtual

To make a Factorization of <me>

Implements FEmTool_SparseMatrix.

◆ Init()

void FEmTool_ProfileMatrix::Init ( const double Value)
overridevirtual

Implements FEmTool_SparseMatrix.

◆ IsInProfile()

bool FEmTool_ProfileMatrix::IsInProfile ( const int i,
const int j ) const

◆ Multiplied()

void FEmTool_ProfileMatrix::Multiplied ( const math_Vector & X,
math_Vector & MX ) const
overridevirtual

returns the product of a SparseMatrix by a vector. An exception is raised if the dimensions are different

Implements FEmTool_SparseMatrix.

◆ OutM()

void FEmTool_ProfileMatrix::OutM ( ) const

◆ OutS()

void FEmTool_ProfileMatrix::OutS ( ) const

◆ Prepare()

bool FEmTool_ProfileMatrix::Prepare ( )
overridevirtual

Make Preparation to iterative solve.

Implements FEmTool_SparseMatrix.

◆ RowNumber()

int FEmTool_ProfileMatrix::RowNumber ( ) const
overridevirtual

returns the row range of a matrix.

Implements FEmTool_SparseMatrix.

◆ Solve() [1/2]

void FEmTool_ProfileMatrix::Solve ( const math_Vector & B,
const math_Vector & Init,
math_Vector & X,
math_Vector & Residual,
const double Tolerance = 1.0e-8,
const int NbIterations = 50 ) const
overridevirtual

Iterative solve of AX = B.

Implements FEmTool_SparseMatrix.

◆ Solve() [2/2]

void FEmTool_ProfileMatrix::Solve ( const math_Vector & B,
math_Vector & X ) const
overridevirtual

Direct Solve of AX = B.

Implements FEmTool_SparseMatrix.


The documentation for this class was generated from the following file: