Panzer
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
disc-fe
src
responses
Panzer_ResponseEvaluatorFactory_IPCoordinates_impl.hpp
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
#ifndef __Panzer_ResponseEvaluatorFactory_IPCoordinates_impl_hpp__
44
#define __Panzer_ResponseEvaluatorFactory_IPCoordinates_impl_hpp__
45
46
#include <string>
47
#include <sstream>
48
49
#include "PanzerDiscFE_config.hpp"
50
51
#include "
Panzer_IntegrationRule.hpp
"
52
#include "
Panzer_PhysicsBlock.hpp
"
53
#include "Panzer_Integrator_Scalar.hpp"
54
#include "
Panzer_ResponseScatterEvaluator_IPCoordinates.hpp
"
55
#include "
Panzer_Response_IPCoordinates.hpp
"
56
57
namespace
panzer
{
58
59
template
<
typename
EvalT>
60
Teuchos::RCP<ResponseBase>
ResponseEvaluatorFactory_IPCoordinates<EvalT>::
61
buildResponseObject
(
const
std::string & responseName,
const
std::vector<WorksetDescriptor> & wkstDesc)
const
62
{
63
// check that the input worksets constains only element blocks
64
bool
failure =
false
;
65
std::stringstream failureStrm;
66
for
(std::size_t i=0;i<wkstDesc.size();i++) {
67
failure |= wkstDesc[i].useSideset();
68
failureStrm << wkstDesc[i] << std::endl;
69
}
70
TEUCHOS_TEST_FOR_EXCEPTION(failure,std::runtime_error,
71
"REF_IPCoordinates::buildResponseObject: could not build using side set descriptors:\n"
72
<< failureStrm.str());
73
74
return
Teuchos::rcp(
new
Response_IPCoordinates<EvalT>
(responseName));
75
}
76
77
template
<
typename
EvalT>
78
void
ResponseEvaluatorFactory_IPCoordinates<EvalT>::
79
buildAndRegisterEvaluators
(
const
std::string & responseName,
80
PHX::FieldManager<panzer::Traits>
& fm,
81
const
panzer::PhysicsBlock
&
/* physicsBlock */
,
82
const
Teuchos::ParameterList&
/* user_data */
)
const
83
{
84
using
Teuchos::RCP;
85
using
Teuchos::rcp;
86
87
// build scatter evaluator
88
{
89
// build useful evaluator
90
Teuchos::RCP<PHX::Evaluator<panzer::Traits> > eval
91
= Teuchos::rcp(
new
ResponseScatterEvaluator_IPCoordinates<EvalT,panzer::Traits>
(responseName,
cubatureDegree_
));
92
93
this->
template
registerEvaluator<EvalT>
(fm, eval);
94
95
// require last field
96
fm.template requireField<EvalT>(*eval->evaluatedFields()[0]);
97
}
98
}
99
100
template
<
typename
EvalT>
101
bool
ResponseEvaluatorFactory_IPCoordinates<EvalT>::
102
typeSupported
()
const
103
{
104
return
false
;
105
}
106
107
template
< >
108
bool
ResponseEvaluatorFactory_IPCoordinates<panzer::Traits::Residual>::
109
typeSupported
()
const
110
{
111
return
true
;
112
}
113
114
}
115
116
#endif
Panzer_IntegrationRule.hpp
Panzer_PhysicsBlock.hpp
Panzer_ResponseScatterEvaluator_IPCoordinates.hpp
Panzer_Response_IPCoordinates.hpp
PHX::FieldManager
Definition
Panzer_BCStrategy_Base.hpp:53
panzer::EvaluatorsRegistrar::registerEvaluator
void registerEvaluator(PHX::FieldManager< panzer::Traits > &fm, const Teuchos::RCP< PHX::Evaluator< panzer::Traits > > &op) const
Definition
Panzer_EvaluatorsRegistrar.hpp:88
panzer::PhysicsBlock
Object that contains information on the physics and discretization of a block of elements with the SA...
Definition
Panzer_PhysicsBlock.hpp:116
panzer::ResponseEvaluatorFactory_IPCoordinates::buildAndRegisterEvaluators
virtual void buildAndRegisterEvaluators(const std::string &responseName, PHX::FieldManager< panzer::Traits > &fm, const panzer::PhysicsBlock &physicsBlock, const Teuchos::ParameterList &user_data) const
Definition
Panzer_ResponseEvaluatorFactory_IPCoordinates_impl.hpp:79
panzer::ResponseEvaluatorFactory_IPCoordinates::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName, const std::vector< WorksetDescriptor > &eBlocks) const
Definition
Panzer_ResponseEvaluatorFactory_IPCoordinates_impl.hpp:61
panzer::ResponseEvaluatorFactory_IPCoordinates::typeSupported
virtual bool typeSupported() const
Definition
Panzer_ResponseEvaluatorFactory_IPCoordinates_impl.hpp:102
panzer::ResponseEvaluatorFactory_IPCoordinates::cubatureDegree_
int cubatureDegree_
Definition
Panzer_ResponseEvaluatorFactory_IPCoordinates.hpp:111
panzer::ResponseScatterEvaluator_IPCoordinates
Definition
Panzer_ResponseScatterEvaluator_IPCoordinates.hpp:66
panzer::Response_IPCoordinates
Definition
Panzer_Response_IPCoordinates.hpp:71
panzer
Computes .
Definition
Panzer_BasisValues_Evaluator_decl.hpp:54
Generated by
1.17.0