Panzer
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
disc-fe
src
responses
Panzer_ResponseEvaluatorFactory_ExtremeValue_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_ExtremeValue_impl_hpp__
44
#define __Panzer_ResponseEvaluatorFactory_ExtremeValue_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_ExtremeValue.hpp
"
54
#include "
Panzer_Response_ExtremeValue.hpp
"
55
56
namespace
panzer
{
57
58
template
<
typename
EvalT,
typename
LO,
typename
GO>
59
Teuchos::RCP<ResponseBase>
ResponseEvaluatorFactory_ExtremeValue<EvalT,LO,GO>::
60
buildResponseObject
(
const
std::string & responseName)
const
61
{
62
Teuchos::RCP<ResponseBase> response = Teuchos::rcp(
new
Response_ExtremeValue<EvalT>
(responseName,
comm_
,
useMax_
,
linearObjFactory_
));
63
response->setRequiresDirichletAdjustment(
applyDirichletToDerivative_
);
64
65
return
response;
66
}
67
68
template
<
typename
EvalT,
typename
LO,
typename
GO>
69
void
ResponseEvaluatorFactory_ExtremeValue<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
79
// build integration evaluator (integrate over element)
80
if
(
requiresCellExtreme_
) {
81
std::string field = (
quadPointField_
==
""
? responseName :
quadPointField_
);
82
83
// build integration rule to use in cell integral
84
RCP<IntegrationRule> ir = rcp(
new
IntegrationRule
(
cubatureDegree_
,physicsBlock.
cellData
()));
85
86
Teuchos::ParameterList pl;
87
// add prefix_ to help identify
88
pl.set(
"Extreme Name"
,
prefix_
+field);
89
pl.set(
"Field Name"
,field);
90
pl.set(
"IR"
,ir);
91
pl.set(
"Use Max"
,
useMax_
);
92
93
Teuchos::RCP<PHX::Evaluator<panzer::Traits> > eval
94
= Teuchos::rcp(
new
CellExtreme<EvalT,panzer::Traits>
(pl));
95
96
this->
template
registerEvaluator<EvalT>
(fm, eval);
97
}
98
99
100
// build scatter evaluator
101
{
102
Teuchos::RCP<ExtremeValueScatterBase> scatterObj =
103
(
globalIndexer_
!=Teuchos::null) ? Teuchos::rcp(
new
ExtremeValueScatter<LO,GO>
(
globalIndexer_
)) : Teuchos::null;
104
std::string field = (
quadPointField_
==
""
? responseName :
quadPointField_
);
105
field =
prefix_
+field;
// add prefix to help identify
106
107
// build useful evaluator
108
Teuchos::RCP<PHX::Evaluator<panzer::Traits> > eval
109
= Teuchos::rcp(
new
ResponseScatterEvaluator_ExtremeValue<EvalT,panzer::Traits>
(field,
110
responseName,
111
physicsBlock.
cellData
(),
112
useMax_
,
113
scatterObj));
114
115
this->
template
registerEvaluator<EvalT>
(fm, eval);
116
117
// require last field
118
fm.template requireField<EvalT>(*eval->evaluatedFields()[0]);
119
}
120
}
121
122
template
<
typename
EvalT,
typename
LO,
typename
GO>
123
bool
ResponseEvaluatorFactory_ExtremeValue<EvalT,LO,GO>::
124
typeSupported
()
const
125
{
126
if
( PHX::print<EvalT>()==PHX::print<panzer::Traits::Residual>() ||
127
PHX::print<EvalT>()==PHX::print<panzer::Traits::Tangent>()
128
)
129
return
true
;
130
131
if
(PHX::print<EvalT>()==PHX::print<panzer::Traits::Jacobian>())
132
return
false
;
133
134
return
false
;
135
}
136
137
}
138
139
#endif
Panzer_CellExtreme.hpp
Panzer_IntegrationRule.hpp
Panzer_PhysicsBlock.hpp
Panzer_ResponseScatterEvaluator_ExtremeValue.hpp
Panzer_Response_ExtremeValue.hpp
PHX::FieldManager
Definition
Panzer_BCStrategy_Base.hpp:53
panzer::CellExtreme
Definition
Panzer_CellExtreme.hpp:75
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::ExtremeValueScatter
Definition
Panzer_ResponseScatterEvaluator_ExtremeValue.hpp:73
panzer::IntegrationRule
Definition
Panzer_IntegrationRule.hpp:73
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::cellData
const panzer::CellData & cellData() const
Definition
Panzer_PhysicsBlock.cpp:770
panzer::ResponseEvaluatorFactory_ExtremeValue::globalIndexer_
Teuchos::RCP< const panzer::GlobalIndexer > globalIndexer_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:137
panzer::ResponseEvaluatorFactory_ExtremeValue::linearObjFactory_
Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > linearObjFactory_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:136
panzer::ResponseEvaluatorFactory_ExtremeValue::applyDirichletToDerivative_
bool applyDirichletToDerivative_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:138
panzer::ResponseEvaluatorFactory_ExtremeValue::useMax_
bool useMax_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:134
panzer::ResponseEvaluatorFactory_ExtremeValue::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_ExtremeValue_impl.hpp:70
panzer::ResponseEvaluatorFactory_ExtremeValue::comm_
MPI_Comm comm_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:131
panzer::ResponseEvaluatorFactory_ExtremeValue::requiresCellExtreme_
bool requiresCellExtreme_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:133
panzer::ResponseEvaluatorFactory_ExtremeValue::prefix_
std::string prefix_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:139
panzer::ResponseEvaluatorFactory_ExtremeValue::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName) const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue_impl.hpp:60
panzer::ResponseEvaluatorFactory_ExtremeValue::typeSupported
virtual bool typeSupported() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue_impl.hpp:124
panzer::ResponseEvaluatorFactory_ExtremeValue::quadPointField_
std::string quadPointField_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:135
panzer::ResponseEvaluatorFactory_ExtremeValue::cubatureDegree_
int cubatureDegree_
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:132
panzer::ResponseScatterEvaluator_ExtremeValue
Definition
Panzer_ResponseScatterEvaluator_ExtremeValue.hpp:92
panzer::Response_ExtremeValue
Definition
Panzer_Response_ExtremeValue.hpp:78
panzer
Computes .
Definition
Panzer_BasisValues_Evaluator_decl.hpp:54
Generated by
1.17.0