Open CASCADE Technology 7.8.2.dev
|
This class implements a system resolution C*X = B with an approach solution X0. There are no conditions on the number of equations. The algorithm used is the Uzawa algorithm. It is possible to have equal or inequal (<) equations to solve. The resolution is done with a minimization of Norm(X-X0). If there are only equal equations, the resolution is directly done and is similar to Gauss resolution with an optimisation because the matrix is a symmetric matrix. (The resolution is done with Crout algorithm) More...
#include <math_Uzawa.hxx>
Public Member Functions | |
math_Uzawa (const math_Matrix &Cont, const math_Vector &Secont, const math_Vector &StartingPoint, const Standard_Real EpsLix=1.0e-06, const Standard_Real EpsLic=1.0e-06, const Standard_Integer NbIterations=500) | |
Given an input matrix Cont, two input vectors Secont and StartingPoint, it solves Cont*X = Secont (only = equations) with a minimization of Norme(X-X0). The maximum iterations number allowed is fixed to NbIterations. The tolerance EpsLic is fixed for the dual variable convergence. The tolerance EpsLix is used for the convergence of X. Exception ConstructionError is raised if the line number of Cont is different from the length of Secont. | |
math_Uzawa (const math_Matrix &Cont, const math_Vector &Secont, const math_Vector &StartingPoint, const Standard_Integer Nci, const Standard_Integer Nce, const Standard_Real EpsLix=1.0e-06, const Standard_Real EpsLic=1.0e-06, const Standard_Integer NbIterations=500) | |
Given an input matrix Cont, two input vectors Secont and StartingPoint, it solves Cont*X = Secont (the Nce first equations are equal equations and the Nci last equations are inequalities <) with a minimization of Norme(X-X0). The maximum iterations number allowed is fixed to NbIterations. The tolerance EpsLic is fixed for the dual variable convergence. The tolerance EpsLix is used for the convergence of X. There are no conditions on Nce and Nci. Exception ConstructionError is raised if the line number of Cont is different from the length of Secont and from Nce + Nci. | |
Standard_Boolean | IsDone () const |
Returns true if the computations are successful, otherwise returns false. | |
const math_Vector & | Value () const |
Returns the vector solution of the system above. An exception is raised if NotDone. | |
const math_Vector & | InitialError () const |
Returns the initial error Cont*StartingPoint-Secont. An exception is raised if NotDone. | |
void | Duale (math_Vector &V) const |
returns the duale variables V of the systeme. | |
const math_Vector & | Error () const |
Returns the difference between X solution and the StartingPoint. An exception is raised if NotDone. | |
Standard_Integer | NbIterations () const |
returns the number of iterations really done. An exception is raised if NotDone. | |
const math_Matrix & | InverseCont () const |
returns the inverse matrix of (C * Transposed(C)). This result is needed for the computation of the gradient when approximating a curve. | |
void | Dump (Standard_OStream &o) const |
Prints information on the current state of the object. | |
Protected Member Functions | |
void | Perform (const math_Matrix &Cont, const math_Vector &Secont, const math_Vector &StartingPoint, const Standard_Integer Nci, const Standard_Integer Nce, const Standard_Real EpsLix=1.0e-06, const Standard_Real EpsLic=1.0e-06, const Standard_Integer NbIterations=500) |
Is used internally by the two constructors above. | |
This class implements a system resolution C*X = B with an approach solution X0. There are no conditions on the number of equations. The algorithm used is the Uzawa algorithm. It is possible to have equal or inequal (<) equations to solve. The resolution is done with a minimization of Norm(X-X0). If there are only equal equations, the resolution is directly done and is similar to Gauss resolution with an optimisation because the matrix is a symmetric matrix. (The resolution is done with Crout algorithm)
math_Uzawa::math_Uzawa | ( | const math_Matrix & | Cont, |
const math_Vector & | Secont, | ||
const math_Vector & | StartingPoint, | ||
const Standard_Real | EpsLix = 1.0e-06, | ||
const Standard_Real | EpsLic = 1.0e-06, | ||
const Standard_Integer | NbIterations = 500 ) |
Given an input matrix Cont, two input vectors Secont and StartingPoint, it solves Cont*X = Secont (only = equations) with a minimization of Norme(X-X0). The maximum iterations number allowed is fixed to NbIterations. The tolerance EpsLic is fixed for the dual variable convergence. The tolerance EpsLix is used for the convergence of X. Exception ConstructionError is raised if the line number of Cont is different from the length of Secont.
math_Uzawa::math_Uzawa | ( | const math_Matrix & | Cont, |
const math_Vector & | Secont, | ||
const math_Vector & | StartingPoint, | ||
const Standard_Integer | Nci, | ||
const Standard_Integer | Nce, | ||
const Standard_Real | EpsLix = 1.0e-06, | ||
const Standard_Real | EpsLic = 1.0e-06, | ||
const Standard_Integer | NbIterations = 500 ) |
Given an input matrix Cont, two input vectors Secont and StartingPoint, it solves Cont*X = Secont (the Nce first equations are equal equations and the Nci last equations are inequalities <) with a minimization of Norme(X-X0). The maximum iterations number allowed is fixed to NbIterations. The tolerance EpsLic is fixed for the dual variable convergence. The tolerance EpsLix is used for the convergence of X. There are no conditions on Nce and Nci. Exception ConstructionError is raised if the line number of Cont is different from the length of Secont and from Nce + Nci.
void math_Uzawa::Duale | ( | math_Vector & | V | ) | const |
returns the duale variables V of the systeme.
void math_Uzawa::Dump | ( | Standard_OStream & | o | ) | const |
Prints information on the current state of the object.
const math_Vector & math_Uzawa::Error | ( | ) | const |
Returns the difference between X solution and the StartingPoint. An exception is raised if NotDone.
const math_Vector & math_Uzawa::InitialError | ( | ) | const |
Returns the initial error Cont*StartingPoint-Secont. An exception is raised if NotDone.
const math_Matrix & math_Uzawa::InverseCont | ( | ) | const |
returns the inverse matrix of (C * Transposed(C)). This result is needed for the computation of the gradient when approximating a curve.
Standard_Boolean math_Uzawa::IsDone | ( | ) | const |
Returns true if the computations are successful, otherwise returns false.
Standard_Integer math_Uzawa::NbIterations | ( | ) | const |
returns the number of iterations really done. An exception is raised if NotDone.
|
protected |
Is used internally by the two constructors above.
const math_Vector & math_Uzawa::Value | ( | ) | const |
Returns the vector solution of the system above. An exception is raised if NotDone.