1#ifndef included_AMP_TrilinosMatrixShellOperator
2#define included_AMP_TrilinosMatrixShellOperator
4#include "AMP/operators/LinearOperator.h"
25 void setNodalDofMap( std::shared_ptr<AMP::Discretization::DOFManager> dofMap );
39 void reset( std::shared_ptr<const OperatorParameters> params )
override;
58 void *
object,
int row, std::vector<size_t> &cols, std::vector<double> &values )> );
69 std::function<
void(
void *,
int, std::vector<size_t> &, std::vector<double> & )>
d_getRow;
std::shared_ptr< Vector > shared_ptr
Shorthand for shared pointer to Vector.
std::shared_ptr< const Vector > const_shared_ptr
std::shared_ptr< AMP::Operator::Operator > shared_ptr
virtual void residual(AMP::LinearAlgebra::Vector::const_shared_ptr f, AMP::LinearAlgebra::Vector::const_shared_ptr u, AMP::LinearAlgebra::Vector::shared_ptr r) override
void reset(std::shared_ptr< const OperatorParameters > params) override
void setOperator(std::shared_ptr< Operator > op)
virtual ~TrilinosMatrixShellOperator()
void getColumn(int column, std::vector< size_t > &rows, std::vector< double > &values)
std::shared_ptr< Operator > d_operator
std::function< void(void *, int, std::vector< size_t > &, std::vector< double > &)> d_getRow
void setGetRow(std::function< void(void *object, int row, std::vector< size_t > &cols, std::vector< double > &values)>)
static int getRow(ML_Operator *data, int N_requested_rows, int requested_rows[], int allocated_space, int columns[], double values[], int row_lengths[])
std::shared_ptr< AMP::LinearAlgebra::Variable > getOutputVariable() const override
Return the output variable.
std::shared_ptr< AMP::Discretization::DOFManager > d_nodalDofMap
static int matVec(ML_Operator *data, int in_length, double in[], int out_length, double out[])
void setNodalDofMap(std::shared_ptr< AMP::Discretization::DOFManager > dofMap)
TrilinosMatrixShellOperator(std::shared_ptr< const OperatorParameters > params)
std::shared_ptr< AMP::LinearAlgebra::Variable > getInputVariable() const override
Return the input variable.
void apply(AMP::LinearAlgebra::Vector::const_shared_ptr u, AMP::LinearAlgebra::Vector::shared_ptr f) override
#define DISABLE_WARNINGS
Re-enable warnings.
#define ENABLE_WARNINGS
Suppress all warnings.