Panzer
Version of the Day
disc-fe
src
Panzer_EquationSet_Factory_Composite.cpp
Go to the documentation of this file.
1
// @HEADER
2
// ***********************************************************************
3
//
4
// Panzer: A partial differential equation assembly
5
// engine for strongly coupled complex multiphysics systems
6
// Copyright (2011) Sandia Corporation
7
//
8
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
9
// the U.S. Government retains certain rights in this software.
10
//
11
// Redistribution and use in source and binary forms, with or without
12
// modification, are permitted provided that the following conditions are
13
// met:
14
//
15
// 1. Redistributions of source code must retain the above copyright
16
// notice, this list of conditions and the following disclaimer.
17
//
18
// 2. Redistributions in binary form must reproduce the above copyright
19
// notice, this list of conditions and the following disclaimer in the
20
// documentation and/or other materials provided with the distribution.
21
//
22
// 3. Neither the name of the Corporation nor the names of the
23
// contributors may be used to endorse or promote products derived from
24
// this software without specific prior written permission.
25
//
26
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
27
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
28
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
30
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
31
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
32
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
33
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
34
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
35
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
36
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
37
//
38
// Questions? Contact Roger P. Pawlowski (rppawlo@sandia.gov) and
39
// Eric C. Cyr (eccyr@sandia.gov)
40
// ***********************************************************************
41
// @HEADER
42
43
#include "
Panzer_EquationSet_Factory_Composite.hpp
"
44
#include "
Teuchos_ParameterList.hpp
"
45
#include "
Panzer_CellData.hpp
"
46
#include "
Panzer_GlobalData.hpp
"
47
#include <sstream>
48
49
namespace
panzer
{
50
51
EquationSet_FactoryComposite::EquationSet_FactoryComposite
(
const
std::vector<
Teuchos::RCP<panzer::EquationSetFactory>
>& factories) :
52
m_factories(factories)
53
{ }
54
55
Teuchos::RCP<panzer::EquationSet_TemplateManager<panzer::Traits>
>
56
EquationSet_FactoryComposite::buildEquationSet
(
const
Teuchos::RCP<Teuchos::ParameterList>
& input_plist,
57
const
int
& default_integration_rule,
58
const
panzer::CellData
& cell_data,
59
const
Teuchos::RCP<panzer::GlobalData>
& global_data,
60
const
bool
build_transient_support)
const
61
{
62
Teuchos::RCP<panzer::EquationSet_TemplateManager<panzer::Traits>
> eq_set;
63
64
65
for
(std::vector<
Teuchos::RCP<panzer::EquationSetFactory>
>::const_iterator factory =
m_factories
.begin();
66
factory !=
m_factories
.end(); ++factory) {
67
eq_set = (*factory)->buildEquationSet(input_plist,default_integration_rule,cell_data,global_data,build_transient_support);
68
69
if
(
nonnull
(eq_set))
70
break
;
71
}
72
73
std::ostringstream os;
74
os <<
"The equation set factory failed to build and equation set for the following input parameter list. Please correct the input list:\n"
;
75
input_plist->
print
(os);
76
TEUCHOS_TEST_FOR_EXCEPTION
(
is_null
(eq_set), std::logic_error,os.str());
77
78
return
eq_set;
79
}
80
81
}
82
is_null
bool is_null(const boost::shared_ptr< T > &p)
Teuchos_ParameterList.hpp
panzer::EquationSet_FactoryComposite::EquationSet_FactoryComposite
EquationSet_FactoryComposite(const std::vector< Teuchos::RCP< panzer::EquationSetFactory > > &factories)
Definition:
Panzer_EquationSet_Factory_Composite.cpp:51
panzer::CellData
Data for determining cell topology and dimensionality.
Definition:
Panzer_CellData.hpp:65
panzer::EquationSet_FactoryComposite::m_factories
std::vector< Teuchos::RCP< panzer::EquationSetFactory > > m_factories
Definition:
Panzer_EquationSet_Factory_Composite.hpp:57
panzer::EquationSet_FactoryComposite::buildEquationSet
Teuchos::RCP< panzer::EquationSet_TemplateManager< panzer::Traits > > buildEquationSet(const Teuchos::RCP< Teuchos::ParameterList > &input_plist, const int &default_integration_rule, const panzer::CellData &cell_data, const Teuchos::RCP< panzer::GlobalData > &global_data, const bool build_transient_support) const
Definition:
Panzer_EquationSet_Factory_Composite.cpp:56
Teuchos::RCP
Panzer_GlobalData.hpp
Panzer_CellData.hpp
Teuchos::ParameterList::print
void print() const
Panzer_EquationSet_Factory_Composite.hpp
nonnull
bool nonnull(const boost::shared_ptr< T > &p)
panzer
Definition:
Panzer_BasisValues_Evaluator_decl.hpp:54
TEUCHOS_TEST_FOR_EXCEPTION
#define TEUCHOS_TEST_FOR_EXCEPTION(throw_exception_test, Exception, msg)
Generated by
1.8.16