45#include "Teuchos_TimeMonitor.hpp"
49 const Teuchos::RCP<const EpetraExt::MultiComm>& sg_comm_,
51 const Teuchos::RCP<const Stokhos::EpetraSparse3Tensor>& epetraCijk_,
52 const Teuchos::RCP<const Epetra_CrsGraph>& base_graph,
53 const Teuchos::RCP<const Epetra_Map>& domain_sg_map_,
54 const Teuchos::RCP<const Epetra_Map>& range_sg_map_,
55 const Teuchos::RCP<Teuchos::ParameterList>& params) :
57 *(epetraCijk_->getStochasticGraph()),
70 scale_op = params->get(
"Scale Operator by Inverse Basis Norms",
true);
83 const Teuchos::RCP<Stokhos::EpetraOperatorOrthogPoly >& ops)
85#ifdef STOKHOS_TEUCHOS_TIME_MONITOR
86 TEUCHOS_FUNC_TIME_MONITOR(
"Stokhos: SG Fully Assembled Operator Assembly");
101 k_end =
Cijk->find_k(dim+1);
105 const Teuchos::Array<double>& norms =
sg_basis->norm_squared();
108 Teuchos::RCP<Epetra_RowMatrix> block =
109 Teuchos::rcp_dynamic_cast<Epetra_RowMatrix>(
block_ops->getCoeffPtr(k),
112 j_it !=
Cijk->j_end(k_it); ++j_it) {
115 i_it !=
Cijk->i_end(j_it); ++i_it) {
117 double c =
value(i_it);
120 this->SumIntoGlobalBlock(c, *block, i,
j);
128Teuchos::RCP< Stokhos::EpetraOperatorOrthogPoly >
135Teuchos::RCP<const Stokhos::EpetraOperatorOrthogPoly >
146#ifdef STOKHOS_TEUCHOS_TIME_MONITOR
147 TEUCHOS_FUNC_TIME_MONITOR(
"Stokhos: SG Operator Apply");
int Apply(const Epetra_MultiVector &X, Epetra_MultiVector &Y) const
CRS matrix of dense blocks.
Teuchos::RCP< const Epetra_Map > domain_sg_map
Stores domain SG map.
bool scale_op
Flag indicating whether operator be scaled with <\psi_i^2>.
Teuchos::RCP< const Stokhos::EpetraSparse3Tensor > epetraCijk
Stores Epetra Cijk tensor.
Teuchos::RCP< const EpetraExt::MultiComm > sg_comm
Stores SG parallel communicator.
virtual int Apply(const Epetra_MultiVector &Input, Epetra_MultiVector &Result) const
Wrap Apply() to add a timer.
Teuchos::RCP< const Epetra_Map > range_sg_map
Stores range SG map.
Teuchos::RCP< const Cijk_type > Cijk
Stores triple product tensor.
bool include_mean
Flag indicating whether to include mean term.
virtual Teuchos::RCP< Stokhos::EpetraOperatorOrthogPoly > getSGPolynomial()
Get SG polynomial.
virtual ~FullyAssembledOperator()
Destructor.
Teuchos::RCP< const Stokhos::OrthogPolyBasis< int, double > > sg_basis
Stochastic Galerking basis.
bool only_use_linear
Flag indicating whether to only use linear terms.
Teuchos::RCP< Stokhos::EpetraOperatorOrthogPoly > block_ops
Stores operators.
virtual void setupOperator(const Teuchos::RCP< Stokhos::EpetraOperatorOrthogPoly > &poly)
Setup operator.
FullyAssembledOperator(const Teuchos::RCP< const EpetraExt::MultiComm > &sg_comm, const Teuchos::RCP< const Stokhos::OrthogPolyBasis< int, double > > &sg_basis, const Teuchos::RCP< const Stokhos::EpetraSparse3Tensor > &epetraCijk, const Teuchos::RCP< const Epetra_CrsGraph > &base_graph, const Teuchos::RCP< const Epetra_Map > &domain_sg_map, const Teuchos::RCP< const Epetra_Map > &range_sg_map, const Teuchos::RCP< Teuchos::ParameterList > ¶ms)
Constructor.
Abstract base class for multivariate orthogonal polynomials.
kji_sparse_array::const_iterator k_iterator
SparseArrayIterator< index_iterator, value_iterator >::value_reference value(const SparseArrayIterator< index_iterator, value_iterator > &it)
SparseArrayIterator< index_iterator, value_iterator >::value_type index(const SparseArrayIterator< index_iterator, value_iterator > &it)
j_sparse_array::const_iterator kji_iterator
ji_sparse_array::const_iterator kj_iterator