Stokhos Package Browser (Single Doxygen Collection)  Version of the Day
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
Stokhos_SGOperatorFactory.cpp
Go to the documentation of this file.
1 // $Id$
2 // $Source$
3 // @HEADER
4 // ***********************************************************************
5 //
6 // Stokhos Package
7 // Copyright (2009) Sandia Corporation
8 //
9 // Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
10 // license for use of this work by or on behalf of the U.S. Government.
11 //
12 // Redistribution and use in source and binary forms, with or without
13 // modification, are permitted provided that the following conditions are
14 // met:
15 //
16 // 1. Redistributions of source code must retain the above copyright
17 // notice, this list of conditions and the following disclaimer.
18 //
19 // 2. Redistributions in binary form must reproduce the above copyright
20 // notice, this list of conditions and the following disclaimer in the
21 // documentation and/or other materials provided with the distribution.
22 //
23 // 3. Neither the name of the Corporation nor the names of the
24 // contributors may be used to endorse or promote products derived from
25 // this software without specific prior written permission.
26 //
27 // THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
28 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
29 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
30 // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
31 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
32 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
33 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
34 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
35 // LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
36 // NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
37 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
38 //
39 // Questions? Contact Eric T. Phipps (etphipp@sandia.gov).
40 //
41 // ***********************************************************************
42 // @HEADER
43 
49 #include "Teuchos_Assert.hpp"
50 
53  params(params_)
54 {
55 }
56 
60  const Teuchos::RCP<const Stokhos::OrthogPolyBasis<int,double> >& sg_basis,
62  const Teuchos::RCP<const Epetra_Map>& domain_base_map,
63  const Teuchos::RCP<const Epetra_Map>& range_base_map,
64  const Teuchos::RCP<const Epetra_Map>& domain_sg_map,
65  const Teuchos::RCP<const Epetra_Map>& range_sg_map)
66 {
68  std::string op_method = params->get("Operator Method", "Matrix Free");
69  if (op_method == "Matrix Free") {
71  sg_comm, sg_basis, epetraCijk,
72  domain_base_map, range_base_map,
73  domain_sg_map, range_sg_map, params));
74  }
75  else if (op_method == "KL Matrix Free") {
77  sg_comm, sg_basis, epetraCijk,
78  domain_base_map, range_base_map,
79  domain_sg_map, range_sg_map, params));
80  }
81  else if (op_method == "KL Reduced Matrix Free") {
83  sg_comm, sg_basis, epetraCijk,
84  domain_base_map, range_base_map,
85  domain_sg_map, range_sg_map, params));
86  }
87  else if (op_method == "Fully Assembled") {
89  params->get< Teuchos::RCP<const Epetra_CrsGraph> >("Base Graph");
91  sg_comm, sg_basis, epetraCijk, base_graph,
92  domain_sg_map, range_sg_map, params));
93  }
94  else
95  TEUCHOS_TEST_FOR_EXCEPTION(true, std::logic_error,
96  "Error! Unknown operator method " << op_method
97  << "." << std::endl);
98 
99  return sg_op;
100 }
An Epetra operator representing the block stochastic Galerkin operator.
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
An Epetra operator representing the block stochastic Galerkin operator.
T * get() const
TEUCHOS_DEPRECATED RCP< T > rcp(T *p, Dealloc_T dealloc, bool owns_mem)
virtual Teuchos::RCP< Stokhos::SGOperator > build(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_Map > &domain_base_map, const Teuchos::RCP< const Epetra_Map > &range_base_map, const Teuchos::RCP< const Epetra_Map > &domain_sg_map, const Teuchos::RCP< const Epetra_Map > &range_sg_map)
Build preconditioner operator.
SGOperatorFactory(const Teuchos::RCP< Teuchos::ParameterList > &params)
Constructor.
An Epetra operator representing the block stochastic Galerkin operator.
An Epetra operator representing the block stochastic Galerkin operator generated by fully assembling ...