15#ifndef dealii_trilinos_precondition_h
16#define dealii_trilinos_precondition_h
21#ifdef DEAL_II_WITH_TRILINOS
29# include <Epetra_Map.h>
30# include <Epetra_MpiComm.h>
31# include <Epetra_MultiVector.h>
32# include <Epetra_RowMatrix.h>
33# include <Epetra_Vector.h>
34# include <Teuchos_ParameterList.hpp>
41class Ifpack_Preconditioner;
42class Ifpack_Chebyshev;
45 class MultiLevelPreconditioner;
53template <
typename number>
55template <
typename number>
150 const ::Vector<double> &src)
const;
158 const ::LinearAlgebra::distributed::Vector<double> &src)
const;
166 const ::LinearAlgebra::distributed::Vector<double> &src)
const;
212 <<
"The sparse matrix the preconditioner is based on "
213 <<
"uses a map that is not compatible to the one in vector "
214 << arg1 <<
". Check preconditioner and matrix setup.");
356 const unsigned int overlap = 0,
450 const unsigned int overlap = 0,
536 const double omega = 1,
639 const double omega = 1,
641 const unsigned int overlap = 0,
750 const double omega = 1,
752 const unsigned int overlap = 0,
876 const unsigned int overlap = 0);
995 const unsigned int overlap = 0);
1101 const unsigned int overlap = 0);
1362 std::vector<std::vector<bool>>(0),
1401 Teuchos::ParameterList ¶meter_list,
1402 std::unique_ptr<Epetra_MultiVector> &distributed_constant_modes,
1403 const Epetra_RowMatrix &matrix)
const;
1414 Teuchos::ParameterList ¶meter_list,
1415 std::unique_ptr<Epetra_MultiVector> &distributed_constant_modes,
1425 Teuchos::ParameterList ¶meter_list,
1426 std::unique_ptr<Epetra_MultiVector> &distributed_constant_modes,
1427 const Epetra_RowMatrix &matrix)
const;
1436 Teuchos::ParameterList ¶meter_list,
1437 std::unique_ptr<Epetra_MultiVector> &distributed_constant_modes,
1634 const Teuchos::ParameterList &ml_parameters);
1645 const Teuchos::ParameterList &ml_parameters);
1653 template <
typename number>
1655 initialize(const ::SparseMatrix<number> &deal_ii_sparse_matrix,
1657 const double drop_tolerance = 1e-13,
1658 const ::SparsityPattern *use_this_sparsity =
nullptr);
1697# if defined(DOXYGEN) || defined(DEAL_II_TRILINOS_WITH_MUELU)
1744 std::vector<std::vector<bool>>(0),
1903 Teuchos::ParameterList &muelu_parameters);
1912 Teuchos::ParameterList &muelu_parameters);
1920 template <
typename number>
1922 initialize(const ::SparseMatrix<number> &deal_ii_sparse_matrix,
1924 const double drop_tolerance = 1e-13,
1925 const ::SparsityPattern *use_this_sparsity =
nullptr);
1994 const ::Vector<double> &src)
const override;
2002 const ::Vector<double> &src)
const override;
2010 const ::LinearAlgebra::distributed::Vector<double> &src)
2020 const ::LinearAlgebra::distributed::Vector<double> &src)
2058 Assert(dst.trilinos_partitioner().SameAs(
2061 Assert(src.trilinos_partitioner().SameAs(
2065 const int ierr =
preconditioner->ApplyInverse(src.trilinos_vector(),
2066 dst.trilinos_vector());
2073 Assert(dst.trilinos_partitioner().SameAs(
2076 Assert(src.trilinos_partitioner().SameAs(
2081 const int ierr =
preconditioner->ApplyInverse(src.trilinos_vector(),
2082 dst.trilinos_vector());
2099 const ::Vector<double> &src)
const
2105 Epetra_Vector tril_dst(View,
2108 Epetra_Vector tril_src(View,
2110 const_cast<double *
>(src.begin()));
2112 const int ierr =
preconditioner->ApplyInverse(tril_src, tril_dst);
2119 const ::Vector<double> &src)
const
2125 Epetra_Vector tril_dst(View,
2128 Epetra_Vector tril_src(View,
2130 const_cast<double *
>(src.begin()));
2133 const int ierr =
preconditioner->ApplyInverse(tril_src, tril_dst);
2142 LinearAlgebra::distributed::Vector<double> &dst,
2143 const LinearAlgebra::distributed::Vector<double> &src)
const
2149 Epetra_Vector tril_dst(View,
2152 Epetra_Vector tril_src(View,
2154 const_cast<double *
>(src.
begin()));
2156 const int ierr =
preconditioner->ApplyInverse(tril_src, tril_dst);
2162 LinearAlgebra::distributed::Vector<double> &dst,
2163 const LinearAlgebra::distributed::Vector<double> &src)
const
2169 Epetra_Vector tril_dst(View,
2172 Epetra_Vector tril_src(View,
2174 const_cast<double *
>(src.
begin()));
2177 const int ierr =
preconditioner->ApplyInverse(tril_src, tril_dst);
size_type locally_owned_size() const
std::shared_ptr< SparseMatrix > trilinos_matrix
size_type memory_consumption() const
virtual ~PreconditionAMGMueLu() override=default
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
~PreconditionAMG() override
std::shared_ptr< SparseMatrix > trilinos_matrix
size_type memory_consumption() const
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
IndexSet locally_owned_range_indices() const
Epetra_MpiComm communicator
virtual void Tvmult(::LinearAlgebra::distributed::Vector< double > &dst, const ::LinearAlgebra::distributed::Vector< double > &src) const
virtual void Tvmult(MPI::Vector &dst, const MPI::Vector &src) const
virtual void vmult(MPI::Vector &dst, const MPI::Vector &src) const
Epetra_Operator & trilinos_operator() const
Teuchos::RCP< Epetra_Operator > preconditioner
virtual void Tvmult(::Vector< double > &dst, const ::Vector< double > &src) const
MPI_Comm get_mpi_communicator() const
virtual void vmult(::Vector< double > &dst, const ::Vector< double > &src) const
IndexSet locally_owned_domain_indices() const
virtual void vmult(::LinearAlgebra::distributed::Vector< double > &dst, const ::LinearAlgebra::distributed::Vector< double > &src) const
::types::global_dof_index size_type
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void vmult(LinearAlgebra::distributed::Vector< double > &dst, const ::LinearAlgebra::distributed::Vector< double > &src) const override
void vmult(MPI::Vector &dst, const MPI::Vector &src) const override
void Tvmult(MPI::Vector &dst, const MPI::Vector &src) const override
void Tvmult(LinearAlgebra::distributed::Vector< double > &dst, const ::LinearAlgebra::distributed::Vector< double > &src) const override
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
void initialize(const SparseMatrix &matrix, const AdditionalData &additional_data=AdditionalData())
virtual size_type size() const override
#define DEAL_II_NAMESPACE_OPEN
#define DEAL_II_DISABLE_EXTRA_DIAGNOSTICS
#define DEAL_II_NAMESPACE_CLOSE
#define DEAL_II_ENABLE_EXTRA_DIAGNOSTICS
static ::ExceptionBase & ExcNonMatchingMaps(std::string arg1)
#define Assert(cond, exc)
#define AssertDimension(dim1, dim2)
#define DeclException1(Exception1, type1, outsequence)
static ::ExceptionBase & ExcTrilinosError(int arg1)
#define AssertThrow(cond, exc)
unsigned int global_dof_index
double aggregation_threshold
std::vector< std::vector< bool > > constant_modes
AdditionalData(const bool elliptic=true, const unsigned int n_cycles=1, const bool w_cycle=false, const double aggregation_threshold=1e-4, const std::vector< std::vector< bool > > &constant_modes=std::vector< std::vector< bool > >(0), const unsigned int smoother_sweeps=2, const unsigned int smoother_overlap=0, const bool output_details=false, const char *smoother_type="Chebyshev", const char *coarse_type="Amesos-KLU")
unsigned int smoother_sweeps
unsigned int smoother_overlap
const char * smoother_type
std::vector< std::vector< bool > > constant_modes
double aggregation_threshold
AdditionalData(const bool elliptic=true, const bool higher_order_elements=false, const unsigned int n_cycles=1, const bool w_cycle=false, const double aggregation_threshold=1e-4, const std::vector< std::vector< bool > > &constant_modes=std::vector< std::vector< bool > >(0), const unsigned int smoother_sweeps=2, const unsigned int smoother_overlap=0, const bool output_details=false, const char *smoother_type="Chebyshev", const char *coarse_type="Amesos-KLU")
std::vector< std::vector< double > > constant_modes_values
unsigned int smoother_sweeps
bool higher_order_elements
unsigned int smoother_overlap
void set_operator_null_space(Teuchos::ParameterList ¶meter_list, std::unique_ptr< Epetra_MultiVector > &distributed_constant_modes, const Epetra_RowMatrix &matrix) const
const char * smoother_type
void set_parameters(Teuchos::ParameterList ¶meter_list, std::unique_ptr< Epetra_MultiVector > &distributed_constant_modes, const Epetra_RowMatrix &matrix) const
std::string block_creation_type
AdditionalData(const unsigned int block_size=1, const std::string &block_creation_type="linear", const double omega=1, const double min_diagonal=0, const unsigned int n_sweeps=1)
std::string block_creation_type
AdditionalData(const unsigned int block_size=1, const std::string &block_creation_type="linear", const double omega=1, const double min_diagonal=0, const unsigned int overlap=0, const unsigned int n_sweeps=1)
AdditionalData(const unsigned int block_size=1, const std::string &block_creation_type="linear", const double omega=1, const double min_diagonal=0, const unsigned int overlap=0, const unsigned int n_sweeps=1)
std::string block_creation_type
AdditionalData(const unsigned int overlap=0)
AdditionalData(const unsigned int degree=1, const double max_eigenvalue=10., const double eigenvalue_ratio=30., const double min_eigenvalue=1., const double min_diagonal=1e-12, const bool nonzero_starting=false)
AdditionalData(const unsigned int ic_fill=0, const double ic_atol=0., const double ic_rtol=1., const unsigned int overlap=0)
AdditionalData(const double ilut_drop=0., const unsigned int ilut_fill=0, const double ilut_atol=0., const double ilut_rtol=1., const unsigned int overlap=0)
AdditionalData(const unsigned int ilu_fill=0, const double ilu_atol=0., const double ilu_rtol=1., const unsigned int overlap=0)
AdditionalData(const double omega=1, const double min_diagonal=0, const unsigned int n_sweeps=1)
AdditionalData(const double omega=1, const double min_diagonal=0, const unsigned int overlap=0, const unsigned int n_sweeps=1)
AdditionalData(const double omega=1, const double min_diagonal=0, const unsigned int overlap=0, const unsigned int n_sweeps=1)