svMultiPhysics
Loading...
Searching...
No Matches
TrilinosLinearAlgebra.h
1// SPDX-FileCopyrightText: Copyright (c) Stanford University, The Regents of the University of California, and others.
2// SPDX-License-Identifier: BSD-3-Clause
3
4#ifndef TRILINOS_LINEAR_ALGEBRA_H
5#define TRILINOS_LINEAR_ALGEBRA_H
6
7#include "LinearAlgebra.h"
8
9/// @brief The TrilinosLinearAlgebra class implements the LinearAlgebra
10/// interface for the Trilinos numerical linear algebra package.
11///
12class TrilinosLinearAlgebra : public virtual LinearAlgebra {
13
14 public:
17
18 virtual void alloc(ComMod& com_mod, eqType& lEq);
19 virtual void assemble(ComMod& com_mod, const int num_elem_nodes, const Vector<int>& eqN,
20 const Array3<double>& lK, const Array<double>& lR);
21 virtual void check_options(const consts::PreconditionerType prec_cond_type, const consts::LinearAlgebraType assembly_type);
22 virtual void initialize(ComMod& com_mod, eqType& lEq);
23 virtual void set_assembly(consts::LinearAlgebraType atype);
24 virtual void set_preconditioner(consts::PreconditionerType prec_type);
25 virtual void solve(ComMod& com_mod, eqType& lEq, const Vector<int>& incL, const Vector<double>& res);
26
27 private:
28 static std::set<consts::LinearAlgebraType> valid_assemblers;
29 void initialize_fsils(ComMod& com_mod, eqType& lEq);
30 bool use_fsils_assembly = false;
31 /// @brief The FsilsLinearAlgebra object used to assemble local element matrices.
32 LinearAlgebra* fsils_solver = nullptr;
33 // Private class used to hide Trilinos implementation details.
34 class TrilinosImpl;
35 TrilinosImpl* impl = nullptr;
36};
37
38#endif
39
The Array3 template class implements a simple interface to 3D arrays.
Definition Array3.h:25
The ComMod class duplicates the data structures in the Fortran COMMOD module defined in MOD....
Definition ComMod.h:1514
The LinearAlgebra class provides an abstract interface to linear algebra frameworks: FSILS,...
Definition LinearAlgebra.h:13
Definition trilinos_impl.cpp:1089
The TrilinosLinearAlgebra class implements the LinearAlgebra interface for the Trilinos numerical lin...
Definition TrilinosLinearAlgebra.h:12
virtual void solve(ComMod &com_mod, eqType &lEq, const Vector< int > &incL, const Vector< double > &res)
Solve a system of linear equations.
Definition TrilinosLinearAlgebra.cpp:169
virtual void set_preconditioner(consts::PreconditionerType prec_type)
Set the proconditioner.
Definition TrilinosLinearAlgebra.cpp:156
virtual void assemble(ComMod &com_mod, const int num_elem_nodes, const Vector< int > &eqN, const Array3< double > &lK, const Array< double > &lR)
Assemble local element arrays.
Definition TrilinosLinearAlgebra.cpp:74
virtual void set_assembly(consts::LinearAlgebraType atype)
Set the linear algebra package for assmbly.
Definition TrilinosLinearAlgebra.cpp:136
virtual void initialize(ComMod &com_mod, eqType &lEq)
Initialize Trilinos framework.
Definition TrilinosLinearAlgebra.cpp:111
virtual void check_options(const consts::PreconditionerType prec_cond_type, const consts::LinearAlgebraType assembly_type)
Check the validity of the precondition and assembly options.
Definition TrilinosLinearAlgebra.cpp:88
virtual void alloc(ComMod &com_mod, eqType &lEq)
Allocate data arrays.
Definition TrilinosLinearAlgebra.cpp:59
The Vector template class is used for storing int and double data.
Definition Vector.h:23
Equation type.
Definition ComMod.h:1069