Panzer
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
disc-fe
src
responses
Panzer_ResponseEvaluatorFactory_Probe_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_Probe_impl_hpp__
44
#define __Panzer_ResponseEvaluatorFactory_Probe_impl_hpp__
45
46
#include <string>
47
48
#include "PanzerDiscFE_config.hpp"
49
50
#include "
Panzer_IntegrationRule.hpp
"
51
#include "
Panzer_PhysicsBlock.hpp
"
52
#include "
Panzer_CellExtreme.hpp
"
53
#include "
Panzer_ResponseScatterEvaluator_Probe.hpp
"
54
#include "
Panzer_Response_Probe.hpp
"
55
56
namespace
panzer
{
57
58
template
<
typename
EvalT,
typename
LO,
typename
GO>
59
Teuchos::RCP<ResponseBase>
ResponseEvaluatorFactory_Probe<EvalT,LO,GO>::
60
buildResponseObject
(
const
std::string & responseName)
const
61
{
62
Teuchos::RCP<ResponseBase> response = Teuchos::rcp(
new
Response_Probe<EvalT>
(responseName,
comm_
,
linearObjFactory_
));
63
response->setRequiresDirichletAdjustment(
applyDirichletToDerivative_
);
64
65
return
response;
66
}
67
68
template
<
typename
EvalT,
typename
LO,
typename
GO>
69
void
ResponseEvaluatorFactory_Probe<EvalT,LO,GO>::
70
buildAndRegisterEvaluators
(
const
std::string & responseName,
71
PHX::FieldManager<panzer::Traits>
& fm,
72
const
panzer::PhysicsBlock
& physicsBlock,
73
const
Teuchos::ParameterList & user_data)
const
74
{
75
using
Teuchos::RCP;
76
using
Teuchos::rcp;
77
78
// build scatter evaluator
79
{
80
Teuchos::RCP<ProbeScatterBase> scatterObj =
81
(
globalIndexer_
!=Teuchos::null) ? Teuchos::rcp(
new
ProbeScatter<LO,GO>
(
globalIndexer_
)) : Teuchos::null;
82
std::string field = (
fieldName_
==
""
? responseName :
fieldName_
);
83
84
// Get basis and integration rule associated with field
85
std::vector<panzer::StrPureBasisPair> blockFields = physicsBlock.
getProvidedDOFs
();
86
RCP<const panzer::PureBasis> basis;
87
for
(
auto
&& v : blockFields) {
88
if
(v.first == field) {
89
basis = v.second;
90
break
;
91
}
92
}
93
RCP<panzer::IntegrationRule> ir = physicsBlock.
getIntegrationRules
().at(
cubatureDegree_
);
94
95
// build useful evaluator
96
Teuchos::RCP<PHX::Evaluator<panzer::Traits> > eval
97
= Teuchos::rcp(
new
ResponseScatterEvaluator_Probe<EvalT,panzer::Traits,LO,GO>
(responseName,
98
field,
99
fieldComponent_
,
100
point_
,
101
*ir,
102
basis,
103
globalIndexer_
,
104
scatterObj));
105
106
this->
template
registerEvaluator<EvalT>
(fm, eval);
107
108
// require last field
109
fm.template requireField<EvalT>(*eval->evaluatedFields()[0]);
110
}
111
}
112
113
template
<
typename
EvalT,
typename
LO,
typename
GO>
114
bool
ResponseEvaluatorFactory_Probe<EvalT,LO,GO>::
115
typeSupported
()
const
116
{
117
if
(PHX::print<EvalT>()==PHX::print<panzer::Traits::Residual>() ||
118
PHX::print<EvalT>()==PHX::print<panzer::Traits::Tangent>() ||
119
PHX::print<EvalT>()==PHX::print<panzer::Traits::Jacobian>()
120
)
121
return
true
;
122
123
return
false
;
124
}
125
126
}
127
128
#endif
Panzer_CellExtreme.hpp
Panzer_IntegrationRule.hpp
Panzer_PhysicsBlock.hpp
Panzer_ResponseScatterEvaluator_Probe.hpp
Panzer_Response_Probe.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::PhysicsBlock::getIntegrationRules
const std::map< int, Teuchos::RCP< panzer::IntegrationRule > > & getIntegrationRules() const
Returns the unique set of point rules, key is the unique panzer::PointRule::name().
Definition
Panzer_PhysicsBlock.cpp:744
panzer::PhysicsBlock::getProvidedDOFs
const std::vector< StrPureBasisPair > & getProvidedDOFs() const
Definition
Panzer_PhysicsBlock.cpp:682
panzer::ProbeScatter
Definition
Panzer_ResponseScatterEvaluator_Probe.hpp:76
panzer::ResponseEvaluatorFactory_Probe::globalIndexer_
Teuchos::RCP< const panzer::GlobalIndexer > globalIndexer_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:136
panzer::ResponseEvaluatorFactory_Probe::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_Probe_impl.hpp:70
panzer::ResponseEvaluatorFactory_Probe::fieldName_
std::string fieldName_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:134
panzer::ResponseEvaluatorFactory_Probe::comm_
MPI_Comm comm_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:130
panzer::ResponseEvaluatorFactory_Probe::cubatureDegree_
int cubatureDegree_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:133
panzer::ResponseEvaluatorFactory_Probe::point_
Teuchos::Array< double > point_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:131
panzer::ResponseEvaluatorFactory_Probe::linearObjFactory_
Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > linearObjFactory_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:135
panzer::ResponseEvaluatorFactory_Probe::fieldComponent_
int fieldComponent_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:132
panzer::ResponseEvaluatorFactory_Probe::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName) const
Definition
Panzer_ResponseEvaluatorFactory_Probe_impl.hpp:60
panzer::ResponseEvaluatorFactory_Probe::applyDirichletToDerivative_
bool applyDirichletToDerivative_
Definition
Panzer_ResponseEvaluatorFactory_Probe.hpp:137
panzer::ResponseEvaluatorFactory_Probe::typeSupported
virtual bool typeSupported() const
Definition
Panzer_ResponseEvaluatorFactory_Probe_impl.hpp:115
panzer::ResponseScatterEvaluator_Probe
Definition
Panzer_ResponseScatterEvaluator_Probe.hpp:144
panzer::Response_Probe
Definition
Panzer_Response_Probe.hpp:77
panzer
Computes .
Definition
Panzer_BasisValues_Evaluator_decl.hpp:54
Generated by
1.17.0