Chombo + EB
3.0
|
#include <LinearSolver.H>
Public Member Functions | |
virtual | ~LinearOp () |
virtual void | residual (T &a_lhs, const T &a_phi, const T &a_rhs, bool a_homogeneous=false)=0 |
virtual void | preCond (T &a_cor, const T &a_residual)=0 |
virtual void | applyOp (T &a_lhs, const T &a_phi, bool a_homogeneous=false)=0 |
virtual void | create (T &a_lhs, const T &a_rhs)=0 |
virtual void | clear (T &a_lhs) |
virtual void | assign (T &a_lhs, const T &a_rhs)=0 |
virtual void | assignLocal (T &a_lhs, const T &a_rhs) |
virtual Real | dotProduct (const T &a_1, const T &a_2)=0 |
virtual void | mDotProduct (const T &a_1, const int a_sz, const T a_2[], Real a_mdots[]) |
virtual void | incr (T &a_lhs, const T &a_x, Real a_scale)=0 |
virtual void | axby (T &a_lhs, const T &a_x, const T &a_y, Real a_a, Real a_b)=0 |
virtual void | scale (T &a_lhs, const Real &a_scale)=0 |
virtual Real | norm (const T &a_rhs, int a_ord)=0 |
virtual Real | dx () const |
virtual void | setToZero (T &a_lhs)=0 |
virtual void | write (const T *a, const char *filename) |
Operator class for Linear solver for solving L(phi) = rhs.
|
pure virtual |
Say you are solving L(phi) = rhs. Make a_lhs = L(a_phi) - a_rhs. If a_homogeneous is true, evaluate the operator using homogeneous boundary conditions.
Implemented in EBAMRPoissonOp, EBViscousTensorOp, EBConductivityOp, slowEBCO, ViscousTensorOp, AMRPoissonOp, EBPoissonOp, ResistivityOp, AMRNodeOp, MultilevelLinearOp< T >, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::~LinearOp().
|
pure virtual |
Given the current state of the residual the correction, apply your preconditioner to a_cor.
Implemented in EBAMRPoissonOp, EBViscousTensorOp, EBConductivityOp, slowEBCO, ViscousTensorOp, AMRPoissonOp, EBPoissonOp, ResistivityOp, AMRNodeOp, MultilevelLinearOp< T >, VCAMRPoissonOp2, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::~LinearOp().
|
pure virtual |
In the context of solving L(phi) = rhs, set a_lhs = L(a_phi). If a_homogeneous is true, evaluate the operator using homogeneous boundary conditions.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, EBPoissonOp, AMRPoissonOp, AMRNodeOp, ResistivityOp, MultilevelLinearOp< T >, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::~LinearOp().
|
pure virtual |
Creat data holder a_lhs that mirrors a_rhs. You do not need to copy the data of a_rhs, just make a holder the same size.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, EBPoissonOp, AMRPoissonOp, ResistivityOp, AMRNodeOp, MultilevelLinearOp< T >, NewPoissonOp, and NewPoissonOp4.
Referenced by AMRMultiGrid< LevelData< T > >::init(), and LinearOp< LevelData< NodeFArrayBox > >::~LinearOp().
|
inlinevirtual |
Opposite of create – perform any operations required before lhs goes out of scope. In general, the only time this needs to be defined in a derived class is if the create() function called new. Otherwise, the default no-op function is sufficient.
Reimplemented in MultilevelLinearOp< T >.
|
pure virtual |
Set a_lhs equal to a_rhs.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, ViscousTensorOp, slowEBCO, EBPoissonOp, AMRPoissonOp, ResistivityOp, AMRNodeOp, MultilevelLinearOp< T >, NewPoissonOp, and NewPoissonOp4.
Referenced by AMRLevelOp< LevelData< NodeFArrayBox > >::assignCopier(), LinearOp< LevelData< NodeFArrayBox > >::assignLocal(), and LinearOp< LevelData< NodeFArrayBox > >::clear().
|
inlinevirtual |
Reimplemented in AMRPoissonOp.
|
pure virtual |
Compute and return the dot product of a_1 and a_2. In most contexts, this means return the sum over all data points of a_1*a_2.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, ViscousTensorOp, slowEBCO, AMRPoissonOp, EBPoissonOp, ResistivityOp, MultilevelLinearOp< T >, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::assignLocal(), and LinearOp< LevelData< NodeFArrayBox > >::mDotProduct().
|
inlinevirtual |
Reimplemented in AMRPoissonOp.
|
pure virtual |
Increment by scaled amount (a_lhs += a_scale*a_x).
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, ViscousTensorOp, slowEBCO, AMRPoissonOp, EBPoissonOp, ResistivityOp, MultilevelLinearOp< T >, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::mDotProduct().
|
pure virtual |
Set input to a scaled sum (a_lhs = a_a*a_x + a_b*a_y).
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, AMRPoissonOp, EBPoissonOp, ResistivityOp, MultilevelLinearOp< T >, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::mDotProduct().
|
pure virtual |
Multiply the input by a given scale (a_lhs *= a_scale).
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, EBPoissonOp, AMRPoissonOp, ResistivityOp, MultilevelLinearOp< T >, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::mDotProduct().
Return the norm of a_rhs. a_ord == 0 max norm, a_ord == 1 sum(abs(a_rhs)), else, L(a_ord) norm.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, EBPoissonOp, AMRPoissonOp, MultilevelLinearOp< T >, ResistivityOp, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by AMRLevelOp< LevelData< NodeFArrayBox > >::AMRNorm(), AMRLevelOp< LevelData< NodeFArrayBox > >::localMaxNorm(), and LinearOp< LevelData< NodeFArrayBox > >::mDotProduct().
Return dx at this level of refinement
Reimplemented in AMRPoissonOp, ViscousTensorOp, and EBAMRPoissonOp.
Referenced by PetscSolver< LevelData< FArrayBox > >::define().
|
pure virtual |
Set a_lhs to zero.
Implemented in EBAMRPoissonOp, EBConductivityOp, EBViscousTensorOp, slowEBCO, ViscousTensorOp, EBPoissonOp, AMRPoissonOp, MultilevelLinearOp< T >, ResistivityOp, AMRNodeOp, NewPoissonOp, and NewPoissonOp4.
Referenced by LinearOp< LevelData< NodeFArrayBox > >::dx(), and AMRLevelOp< LevelData< NodeFArrayBox > >::zeroCovered().
|
inlinevirtual |
Debugging aid for solvers. Print out a "T" to a file named "filename" default implementation is to print out a message saying "LinearOp::write not implemented"
Reimplemented in AMRPoissonOp, and MultilevelLinearOp< T >.