![]() |
|
#include <pseudo_elastic_preconditioner.h>
Inheritance diagram for oomph::PseudoElasticPreconditioner:Public Types | |
| enum | Elastic_preconditioner_type { Exact_block_preconditioner , Block_diagonal_preconditioner , Block_lower_triangular_preconditioner , Block_upper_triangular_preconditioner } |
| typedef Preconditioner *(* | SubsidiaryPreconditionerFctPt) () |
Public Member Functions | |
| PseudoElasticPreconditioner () | |
| Default (and only) constructor. More... | |
| virtual | ~PseudoElasticPreconditioner () |
| destructor More... | |
| PseudoElasticPreconditioner (const PseudoElasticPreconditioner &)=delete | |
| Broken copy constructor. More... | |
| void | setup () |
| Broken assignment operator. More... | |
| void | preconditioner_solve (const DoubleVector &r, DoubleVector &z) |
| void | set_elastic_mesh (Mesh *mesh_pt) |
| void | set_lagrange_multiplier_mesh (Mesh *mesh_pt) |
| void | enable_inf_norm_of_s_scaling () |
| Call to use the inf norm of S as scaling. More... | |
| void | disable_inf_norm_of_s_scaling () |
| Call to use no scaling. More... | |
| void | set_lagrange_multiplier_subsidiary_preconditioner (SubsidiaryPreconditionerFctPt prec_fn) |
| void | set_elastic_subsidiary_preconditioner (SubsidiaryPreconditionerFctPt prec_fn) |
| Elastic_preconditioner_type & | elastic_preconditioner_type () |
| void | clean_up_memory () |
| Clears the memory. More... | |
Public Member Functions inherited from oomph::BlockPreconditioner< CRDoubleMatrix > | |
| BlockPreconditioner () | |
| Constructor. More... | |
| BlockPreconditioner (const BlockPreconditioner &)=delete | |
| Broken copy constructor. More... | |
| virtual | ~BlockPreconditioner () |
| Destructor. More... | |
| void | operator= (const BlockPreconditioner &)=delete |
| Broken assignment operator. More... | |
| CRDoubleMatrix * | matrix_pt () const |
| void | turn_on_recursive_debug_flag () |
| void | turn_off_recursive_debug_flag () |
| void | turn_on_debug_flag () |
| Toggles on the debug flag. More... | |
| void | turn_off_debug_flag () |
| Toggles off the debug flag. More... | |
| void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse) |
| void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse, const Vector< Vector< unsigned >> &doftype_coarsen_map_coarse) |
| virtual void | block_setup () |
| void | block_setup (const Vector< unsigned > &dof_to_block_map) |
| void | get_block (const unsigned &i, const unsigned &j, CRDoubleMatrix &output_matrix, const bool &ignore_replacement_block=false) const |
| CRDoubleMatrix | get_block (const unsigned &i, const unsigned &j, const bool &ignore_replacement_block=false) const |
| void | set_master_matrix_pt (CRDoubleMatrix *in_matrix_pt) |
| Set the matrix_pt in the upper-most master preconditioner. More... | |
| void | get_block_other_matrix (const unsigned &i, const unsigned &j, CRDoubleMatrix *in_matrix_pt, CRDoubleMatrix &output_matrix) |
| void | get_blocks (DenseMatrix< bool > &required_blocks, DenseMatrix< CRDoubleMatrix * > &block_matrix_pt) const |
| void | get_dof_level_block (const unsigned &i, const unsigned &j, CRDoubleMatrix &output_block, const bool &ignore_replacement_block=false) const |
| void | get_dof_level_block (const unsigned &block_i, const unsigned &block_j, CRDoubleMatrix &output_block, const bool &ignore_replacement_block) const |
| CRDoubleMatrix | get_concatenated_block (const VectorMatrix< BlockSelector > &selected_block) |
| void | get_concatenated_block_vector (const Vector< unsigned > &block_vec_number, const DoubleVector &v, DoubleVector &b) |
| void | return_concatenated_block_vector (const Vector< unsigned > &block_vec_number, const DoubleVector &b, DoubleVector &v) const |
| Takes concatenated block ordered vector, b, and copies its. More... | |
| void | get_block_vectors (const Vector< unsigned > &block_vec_number, const DoubleVector &v, Vector< DoubleVector > &s) const |
| void | get_block_vectors (const DoubleVector &v, Vector< DoubleVector > &s) const |
| void | return_block_vectors (const Vector< unsigned > &block_vec_number, const Vector< DoubleVector > &s, DoubleVector &v) const |
| void | return_block_vectors (const Vector< DoubleVector > &s, DoubleVector &v) const |
| void | get_block_vector (const unsigned &n, const DoubleVector &v, DoubleVector &b) const |
| void | return_block_vector (const unsigned &n, const DoubleVector &b, DoubleVector &v) const |
| void | get_block_ordered_preconditioner_vector (const DoubleVector &v, DoubleVector &w) |
| void | return_block_ordered_preconditioner_vector (const DoubleVector &w, DoubleVector &v) const |
| unsigned | nblock_types () const |
| Return the number of block types. More... | |
| unsigned | ndof_types () const |
| Return the total number of DOF types. More... | |
| const Mesh * | mesh_pt (const unsigned &i) const |
| unsigned | nmesh () const |
| int | block_number (const unsigned &i_dof) const |
| Return the block number corresponding to a global index i_dof. More... | |
| int | index_in_block (const unsigned &i_dof) const |
| const LinearAlgebraDistribution * | block_distribution_pt (const unsigned &b) const |
| Access function to the block distributions (const version). More... | |
| LinearAlgebraDistribution * | block_distribution_pt (const unsigned b) |
| Access function to the block distributions (non-const version). More... | |
| LinearAlgebraDistribution * | dof_block_distribution_pt (const unsigned &b) |
| Access function to the dof-level block distributions. More... | |
| const LinearAlgebraDistribution * | master_distribution_pt () const |
| unsigned | ndof_types_in_mesh (const unsigned &i) const |
| bool | is_subsidiary_block_preconditioner () const |
| bool | is_master_block_preconditioner () const |
| void | set_block_output_to_files (const std::string &basefilename) |
| void | disable_block_output_to_files () |
| Turn off output of blocks (by clearing the basefilename string). More... | |
| bool | block_output_on () const |
| Test if output of blocks is on or not. More... | |
| void | output_blocks_to_files (const std::string &basefilename, const unsigned &precision=8) const |
| void | post_block_matrix_assembly_partial_clear () |
| BlockPreconditioner< CRDoubleMatrix > * | master_block_preconditioner_pt () const |
| Access function to the master block preconditioner pt. More... | |
| void | clear_block_preconditioner_base () |
| void | document () |
| Vector< Vector< unsigned > > | doftype_coarsen_map_fine () const |
| Vector< unsigned > | get_fine_grain_dof_types_in (const unsigned &i) const |
| unsigned | nfine_grain_dof_types_in (const unsigned &i) const |
| MapMatrix< unsigned, CRDoubleMatrix * > | replacement_dof_block_pt () const |
| Access function to the replaced dof-level blocks. More... | |
| void | setup_matrix_vector_product (MatrixVectorProduct *matvec_prod_pt, CRDoubleMatrix *block_pt, const Vector< unsigned > &block_col_indices) |
| void | setup_matrix_vector_product (MatrixVectorProduct *matvec_prod_pt, CRDoubleMatrix *block_pt, const unsigned &block_col_index) |
| void | internal_get_block_ordered_preconditioner_vector (const DoubleVector &v, DoubleVector &w) const |
| void | internal_return_block_ordered_preconditioner_vector (const DoubleVector &w, DoubleVector &v) const |
| unsigned | internal_nblock_types () const |
| unsigned | internal_ndof_types () const |
| void | internal_return_block_vector (const unsigned &n, const DoubleVector &b, DoubleVector &v) const |
| void | internal_get_block_vector (const unsigned &n, const DoubleVector &v, DoubleVector &b) const |
| void | internal_get_block_vectors (const Vector< unsigned > &block_vec_number, const DoubleVector &v, Vector< DoubleVector > &s) const |
| void | internal_get_block_vectors (const DoubleVector &v, Vector< DoubleVector > &s) const |
| void | internal_return_block_vectors (const Vector< unsigned > &block_vec_number, const Vector< DoubleVector > &s, DoubleVector &v) const |
| void | internal_return_block_vectors (const Vector< DoubleVector > &s, DoubleVector &v) const |
| void | internal_get_block (const unsigned &i, const unsigned &j, CRDoubleMatrix &output_block) const |
| void | internal_get_block (const unsigned &block_i, const unsigned &block_j, CRDoubleMatrix &output_block) const |
| int | internal_block_number (const unsigned &i_dof) const |
| int | internal_index_in_block (const unsigned &i_dof) const |
| const LinearAlgebraDistribution * | internal_block_distribution_pt (const unsigned &b) const |
| Access function to the internal block distributions. More... | |
| void | insert_auxiliary_block_distribution (const Vector< unsigned > &block_vec_number, LinearAlgebraDistribution *dist_pt) |
| void | block_matrix_test (const unsigned &i, const unsigned &j, const CRDoubleMatrix *block_matrix_pt) const |
| int | get_index_of_value (const Vector< myType > &vec, const myType val, const bool sorted=false) const |
Public Member Functions inherited from oomph::Preconditioner | |
| Preconditioner () | |
| Constructor. More... | |
| Preconditioner (const Preconditioner &)=delete | |
| Broken copy constructor. More... | |
| void | operator= (const Preconditioner &)=delete |
| Broken assignment operator. More... | |
| virtual | ~Preconditioner () |
| Destructor (empty) More... | |
| virtual void | preconditioner_solve_transpose (const DoubleVector &r, DoubleVector &z) |
| void | setup (DoubleMatrixBase *matrix_pt) |
| void | setup (const Problem *problem_pt, DoubleMatrixBase *matrix_pt) |
| void | enable_silent_preconditioner_setup () |
| Set up the block preconditioner quietly! More... | |
| void | disable_silent_preconditioner_setup () |
| Be verbose in the block preconditioner setup. More... | |
| virtual void | set_matrix_pt (DoubleMatrixBase *matrix_pt) |
| Set the matrix pointer. More... | |
| virtual const OomphCommunicator * | comm_pt () const |
| Get function for comm pointer. More... | |
| virtual void | set_comm_pt (const OomphCommunicator *const comm_pt) |
| Set the communicator pointer. More... | |
| double | setup_time () const |
| Returns the time to setup the preconditioner. More... | |
| virtual void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse) |
| virtual void | turn_into_subsidiary_block_preconditioner (BlockPreconditioner< CRDoubleMatrix > *master_block_prec_pt, const Vector< unsigned > &doftype_in_master_preconditioner_coarse, const Vector< Vector< unsigned >> &doftype_coarsen_map_coarse) |
Public Member Functions inherited from oomph::DistributableLinearAlgebraObject | |
| DistributableLinearAlgebraObject () | |
| Default constructor - create a distribution. More... | |
| DistributableLinearAlgebraObject (const DistributableLinearAlgebraObject &matrix)=delete | |
| Broken copy constructor. More... | |
| void | operator= (const DistributableLinearAlgebraObject &)=delete |
| Broken assignment operator. More... | |
| virtual | ~DistributableLinearAlgebraObject () |
| Destructor. More... | |
| LinearAlgebraDistribution * | distribution_pt () const |
| access to the LinearAlgebraDistribution More... | |
| unsigned | nrow () const |
| access function to the number of global rows. More... | |
| unsigned | nrow_local () const |
| access function for the num of local rows on this processor. More... | |
| unsigned | nrow_local (const unsigned &p) const |
| access function for the num of local rows on this processor. More... | |
| unsigned | first_row () const |
| access function for the first row on this processor More... | |
| unsigned | first_row (const unsigned &p) const |
| access function for the first row on this processor More... | |
| bool | distributed () const |
| distribution is serial or distributed More... | |
| bool | distribution_built () const |
| void | build_distribution (const LinearAlgebraDistribution *const dist_pt) |
| void | build_distribution (const LinearAlgebraDistribution &dist) |
Private Member Functions | |
| void | elastic_preconditioner_solve (const DoubleVector &r, DoubleVector &z) |
| Apply the elastic subsidiary preconditioner. More... | |
| void | lagrange_multiplier_preconditioner_solve (const DoubleVector &r, DoubleVector &z) |
| Apply the lagrange multiplier subsidiary preconditioner. More... | |
Private Attributes | |
| double | Scaling |
| The scaling. Defaults to infinity norm of S. More... | |
| bool | Use_inf_norm_of_s_scaling |
| Elastic_preconditioner_type | E_preconditioner_type |
| unsigned | Dim |
| the dimension of the problem More... | |
| Preconditioner * | Elastic_preconditioner_pt |
| storage for the preconditioner for the solid system More... | |
| Vector< Preconditioner * > | Lagrange_multiplier_preconditioner_pt |
| lagrange multiplier preconditioner pt More... | |
| SubsidiaryPreconditionerFctPt | Lagrange_multiplier_subsidiary_preconditioner_function_pt |
| The Lagrange multiplier subsidiary preconditioner function pointer. More... | |
| SubsidiaryPreconditionerFctPt | Elastic_subsidiary_preconditioner_function_pt |
| The solid subsidiary preconditioner function pointer. More... | |
| Mesh * | Elastic_mesh_pt |
| Pointer to the mesh containing the solid elements. More... | |
| Mesh * | Lagrange_multiplier_mesh_pt |
| Pointer to the mesh containing the Lagrange multiplier elements. More... | |
Friends | |
| class | PseudoElasticFSIPreconditioner |
//////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// A subsidiary preconditioner for the pseudo-elastic FSI preconditioner. Also a stand-alone preconditioner for the problem of non-linear elasticity subject to prescribed displacement by Lagrange multiplier. Enumeration of Elastic DOF types in the Pseudo-Elastic Elements The method get_dof_types_for_unknowns() must be implemented such that DOFs subject be Lagrange multiplier and DOFs NOT subject to Lagrange multiplier have different labels. For example in a 3D problem there are 6 DOF types and the following labelling must be implemented: 0 - x displacement (without lagr mult traction) 1 - y displacement (without lagr mult traction) 2 - z displacement (without lagr mult traction) 4 - x displacement (with lagr mult traction) 5 - y displacement (with lagr mult traction) 6 - z displacement (with lagr mult traction)
| typedef Preconditioner*(* oomph::PseudoElasticPreconditioner::SubsidiaryPreconditionerFctPt) () |
This preconditioner includes the option to use subsidiary operators other than SuperLUPreconditioner for this problem. This is the typedef of a function that should return an instance of a subsidiary preconditioning operator. This preconditioner is responsible for the destruction of the subsidiary preconditioners.
The augmented elasticity system can be preconditioned in one of four ways. 0 - Exact preconditioner 1 - Block diagonal preconditioning 2 - Block upper triangular preconditioner 3 - Block lower triangular preconditioner We group together the different components of the displacement vector field for the block decomposition.
| Enumerator | |
|---|---|
| Exact_block_preconditioner | |
| Block_diagonal_preconditioner | |
| Block_lower_triangular_preconditioner | |
| Block_upper_triangular_preconditioner | |
|
inline |
Default (and only) constructor.
References E_preconditioner_type, Elastic_mesh_pt, Elastic_preconditioner_pt, Elastic_subsidiary_preconditioner_function_pt, Exact_block_preconditioner, Lagrange_multiplier_mesh_pt, Lagrange_multiplier_subsidiary_preconditioner_function_pt, and Use_inf_norm_of_s_scaling.
|
inlinevirtual |
destructor
References clean_up_memory().
|
delete |
Broken copy constructor.
|
virtual |
Clears the memory.
Reimplemented from oomph::Preconditioner.
References oomph::BlockPreconditioner< CRDoubleMatrix >::clear_block_preconditioner_base(), Elastic_preconditioner_pt, i, and Lagrange_multiplier_preconditioner_pt.
Referenced by oomph::PseudoElasticFSIPreconditioner::clean_up_memory(), setup(), and ~PseudoElasticPreconditioner().
|
inline |
Call to use no scaling.
References Use_inf_norm_of_s_scaling.
|
private |
Apply the elastic subsidiary preconditioner.
References Elastic_preconditioner_pt, oomph::Preconditioner::preconditioner_solve(), and UniformPSDSelfTest::r.
Referenced by oomph::PseudoElasticFSIPreconditioner::preconditioner_solve(), and preconditioner_solve().
|
inline |
Set the type of preconditioner applied to the elastic: 0 - Exact preconditioner 1 - Block diagonal preconditioning 2 - Block upper triangular preconditioner 3 - Block lower triangular preconditioner We group together the different components of the displacement vector field for the block decomposition.
References E_preconditioner_type.
Referenced by PrescribedBoundaryDisplacementProblem< ELEMENT >::PrescribedBoundaryDisplacementProblem(), FSIChannelWithLeafletProblem< ELEMENT >::set_iterative_solver(), PseudoElasticCollapsibleChannelProblem< FLUID_ELEMENT, SOLID_ELEMENT >::set_pseudo_elastic_fsi_solver(), and set_pseudo_elastic_fsi_solver().
|
inline |
Call to use the inf norm of S as scaling.
References Use_inf_norm_of_s_scaling.
|
private |
Apply the lagrange multiplier subsidiary preconditioner.
References Dim, oomph::BlockPreconditioner< CRDoubleMatrix >::get_block_vector(), i, Lagrange_multiplier_preconditioner_pt, oomph::DistributableLinearAlgebraObject::nrow_local(), UniformPSDSelfTest::r, oomph::BlockPreconditioner< CRDoubleMatrix >::return_block_vector(), Scaling, plotDoE::x, and y.
Referenced by oomph::PseudoElasticFSIPreconditioner::preconditioner_solve(), and preconditioner_solve().
|
inlinevirtual |
Apply the preconditioner. Method implemented in two other methods (elastic and lagrange multiplier subsidiary preocnditioner) for the PseudoElasticFSIPreconditioner
Implements oomph::Preconditioner.
References elastic_preconditioner_solve(), and lagrange_multiplier_preconditioner_solve().
|
inline |
Access function to mesh containing the block-preconditionable elastic elements
References Elastic_mesh_pt, and oomph::BlockPreconditioner< CRDoubleMatrix >::mesh_pt().
Referenced by PrescribedBoundaryDisplacementProblem< ELEMENT >::PrescribedBoundaryDisplacementProblem(), and oomph::PseudoElasticFSIPreconditioner::setup().
|
inline |
By default the elastic subsidiary systems are preconditioner with SuperLUPreconditioner. For a different preconditioner, pass a function to this method returning a different subsidiary operator.
References Elastic_subsidiary_preconditioner_function_pt.
Referenced by PrescribedBoundaryDisplacementProblem< ELEMENT >::PrescribedBoundaryDisplacementProblem(), PseudoElasticCollapsibleChannelProblem< FLUID_ELEMENT, SOLID_ELEMENT >::set_pseudo_elastic_fsi_solver(), and set_pseudo_elastic_fsi_solver().
|
inline |
Access function to mesh containing the block-preconditionable lagrange multiplier elements
References Lagrange_multiplier_mesh_pt, and oomph::BlockPreconditioner< CRDoubleMatrix >::mesh_pt().
Referenced by PrescribedBoundaryDisplacementProblem< ELEMENT >::PrescribedBoundaryDisplacementProblem(), and oomph::PseudoElasticFSIPreconditioner::setup().
|
inline |
By default the Lagrange multiplier subsidiary systems are preconditioner with SuperLUPreconditioner. For a different preconditioner, pass a function to this method returning a different subsidiary operator.
References Lagrange_multiplier_subsidiary_preconditioner_function_pt.
Referenced by PrescribedBoundaryDisplacementProblem< ELEMENT >::PrescribedBoundaryDisplacementProblem(), PseudoElasticCollapsibleChannelProblem< FLUID_ELEMENT, SOLID_ELEMENT >::set_pseudo_elastic_fsi_solver(), and set_pseudo_elastic_fsi_solver().
|
virtual |
Broken assignment operator.
Setup method for the PseudoElasticPreconditioner.
//////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////
Implements oomph::Preconditioner.
References Block_diagonal_preconditioner, Block_lower_triangular_preconditioner, oomph::BlockPreconditioner< CRDoubleMatrix >::block_setup(), Block_upper_triangular_preconditioner, clean_up_memory(), Dim, E_preconditioner_type, Elastic_mesh_pt, Elastic_preconditioner_pt, Elastic_subsidiary_preconditioner_function_pt, Exact_block_preconditioner, MergeRestartFiles::found, oomph::BlockPreconditioner< CRDoubleMatrix >::get_block(), i, oomph::CRDoubleMatrixHelpers::inf_norm(), oomph::BlockPreconditioner< CRDoubleMatrix >::is_master_block_preconditioner(), j, Lagrange_multiplier_mesh_pt, Lagrange_multiplier_preconditioner_pt, Lagrange_multiplier_subsidiary_preconditioner_function_pt, oomph::BlockTriangularPreconditioner< MATRIX >::lower_triangular(), oomph::BlockPreconditioner< CRDoubleMatrix >::matrix_pt(), oomph::BlockPreconditioner< CRDoubleMatrix >::ndof_types(), oomph::BlockPreconditioner< CRDoubleMatrix >::ndof_types_in_mesh(), OOMPH_CURRENT_FUNCTION, OOMPH_EXCEPTION_LOCATION, Scaling, oomph::GeneralPurposeBlockPreconditioner< MATRIX >::set_dof_to_block_map(), oomph::BlockPreconditioner< CRDoubleMatrix >::set_mesh(), oomph::BlockPreconditioner< CRDoubleMatrix >::set_nmesh(), oomph::BlockPreconditioner< CRDoubleMatrix >::set_replacement_dof_block(), oomph::GeneralPurposeBlockPreconditioner< MATRIX >::set_subsidiary_preconditioner_function(), oomph::BlockPreconditioner< MATRIX >::turn_into_subsidiary_block_preconditioner(), oomph::BlockTriangularPreconditioner< MATRIX >::upper_triangular(), and Use_inf_norm_of_s_scaling.
|
friend |
PseudoElasticFSIPreconditioner is a friend to access the private *_preconditioner_solve(...) method
|
private |
the dimension of the problem
Referenced by lagrange_multiplier_preconditioner_solve(), and setup().
|
private |
An unsigned indicating which method should be used for preconditioning the solid component.
Referenced by elastic_preconditioner_type(), PseudoElasticPreconditioner(), and setup().
|
private |
Pointer to the mesh containing the solid elements.
Referenced by PseudoElasticPreconditioner(), set_elastic_mesh(), and setup().
|
private |
storage for the preconditioner for the solid system
Referenced by clean_up_memory(), elastic_preconditioner_solve(), PseudoElasticPreconditioner(), and setup().
|
private |
The solid subsidiary preconditioner function pointer.
Referenced by PseudoElasticPreconditioner(), set_elastic_subsidiary_preconditioner(), and setup().
|
private |
Pointer to the mesh containing the Lagrange multiplier elements.
Referenced by PseudoElasticPreconditioner(), set_lagrange_multiplier_mesh(), and setup().
|
private |
lagrange multiplier preconditioner pt
Referenced by clean_up_memory(), lagrange_multiplier_preconditioner_solve(), and setup().
|
private |
The Lagrange multiplier subsidiary preconditioner function pointer.
Referenced by PseudoElasticPreconditioner(), set_lagrange_multiplier_subsidiary_preconditioner(), and setup().
|
private |
The scaling. Defaults to infinity norm of S.
Referenced by lagrange_multiplier_preconditioner_solve(), and setup().
|
private |
boolean indicating whether the inf-norm of S should be used as scaling. Default = true;
Referenced by disable_inf_norm_of_s_scaling(), enable_inf_norm_of_s_scaling(), PseudoElasticPreconditioner(), and setup().