Panzer
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
disc-fe
src
responses
Panzer_ResponseEvaluatorFactory_ExtremeValue.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_hpp__
44
#define __Panzer_ResponseEvaluatorFactory_ExtremeValue_hpp__
45
46
#include <string>
47
48
#include "PanzerDiscFE_config.hpp"
49
#include "
Panzer_PhysicsBlock.hpp
"
50
#include "
Panzer_BC.hpp
"
51
#include "
Panzer_Traits.hpp
"
52
#include "
Panzer_ResponseEvaluatorFactory.hpp
"
53
#include "
Panzer_LinearObjFactory.hpp
"
54
#include "
Panzer_ResponseMESupportBuilderBase.hpp
"
55
56
#include <mpi.h>
57
58
namespace
panzer
{
59
62
template
<
typename
EvalT,
typename
LO,
typename
GO>
63
class
ResponseEvaluatorFactory_ExtremeValue
:
public
ResponseEvaluatorFactory
<EvalT> {
64
public
:
65
66
ResponseEvaluatorFactory_ExtremeValue
(MPI_Comm comm,
67
int
cubatureDegree=1,
68
bool
requiresCellReduction=
true
,
69
bool
useMax=
true
,
70
const
std::string & quadPointField=
""
,
71
const
Teuchos::RCP<
const
panzer::LinearObjFactory<panzer::Traits>
> & linearObjFactory=Teuchos::null,
72
const
Teuchos::RCP<const panzer::GlobalIndexer> & globalIndexer=Teuchos::null,
73
bool
applyDirichletToDerivative=
false
,
74
std::string in_prefix=
""
)
75
:
comm_
(comm),
cubatureDegree_
(cubatureDegree),
requiresCellExtreme_
(requiresCellReduction),
useMax_
(useMax)
76
,
quadPointField_
(quadPointField),
linearObjFactory_
(linearObjFactory),
globalIndexer_
(globalIndexer)
77
,
applyDirichletToDerivative_
(applyDirichletToDerivative)
78
,
prefix_
(in_prefix)
79
{
80
TEUCHOS_ASSERT((linearObjFactory==Teuchos::null && globalIndexer==Teuchos::null) ||
81
(linearObjFactory!=Teuchos::null && globalIndexer!=Teuchos::null));
82
}
83
84
virtual
~ResponseEvaluatorFactory_ExtremeValue
() {}
85
95
virtual
Teuchos::RCP<ResponseBase>
buildResponseObject
(
const
std::string & responseName)
const
;
96
97
virtual
Teuchos::RCP<ResponseBase>
buildResponseObject
(
const
std::string & responseName,
98
const
std::vector<WorksetDescriptor> &
/* wkstDesc */
)
const
99
{
return
buildResponseObject
(responseName); }
100
112
virtual
void
buildAndRegisterEvaluators
(
const
std::string & responseName,
113
PHX::FieldManager<panzer::Traits>
& fm,
114
const
panzer::PhysicsBlock
& physicsBlock,
115
const
Teuchos::ParameterList & user_data)
const
;
116
124
virtual
bool
typeSupported
()
const
;
125
126
protected
:
128
int
getCubatureDegree
()
const
{
return
cubatureDegree_
; }
129
130
private
:
131
MPI_Comm
comm_
;
132
int
cubatureDegree_
;
133
bool
requiresCellExtreme_
;
134
bool
useMax_
;
135
std::string
quadPointField_
;
136
Teuchos::RCP<const panzer::LinearObjFactory<panzer::Traits> >
linearObjFactory_
;
137
Teuchos::RCP<const panzer::GlobalIndexer>
globalIndexer_
;
138
bool
applyDirichletToDerivative_
;
139
std::string
prefix_
;
140
};
141
142
template
<
typename
LO,
typename
GO>
143
struct
ExtremeValueResponse_Builder
:
public
ResponseMESupportBuilderBase
{
144
MPI_Comm
comm
;
145
int
cubatureDegree
;
146
bool
requiresCellExtreme
;
147
bool
useMax
;
148
std::string
quadPointField
;
149
bool
applyDirichletToDerivative
;
// if this is set to true, then the dirichlet values will be zerod out in
150
// the DgDx vector
151
152
std::string
prefix
;
153
ExtremeValueResponse_Builder
() :
applyDirichletToDerivative
(false) {}
154
155
virtual
~ExtremeValueResponse_Builder
() {}
156
157
void
setDerivativeInformation
(
const
Teuchos::RCP<
const
panzer::LinearObjFactory<panzer::Traits>
> & in_linearObjFactory,
158
const
Teuchos::RCP<const panzer::GlobalIndexer> & in_globalIndexer)
159
{
160
linearObjFactory
= in_linearObjFactory;
161
globalIndexer
= in_globalIndexer;
162
163
TEUCHOS_ASSERT((
linearObjFactory
==Teuchos::null &&
globalIndexer
==Teuchos::null) ||
164
(
linearObjFactory
!=Teuchos::null &&
globalIndexer
!=Teuchos::null));
165
}
166
167
virtual
void
setDerivativeInformation
(
const
Teuchos::RCP<
const
panzer::LinearObjFactory<panzer::Traits>
> & in_linearObjFactory)
168
{
169
using
Teuchos::rcp_dynamic_cast;
170
171
setDerivativeInformation
(in_linearObjFactory,
172
rcp_dynamic_cast<const panzer::GlobalIndexer>(in_linearObjFactory->getDomainGlobalIndexer(),
true
));
173
}
174
175
template
<
typename
T>
176
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
build
()
const
177
{
return
Teuchos::rcp(
new
ResponseEvaluatorFactory_ExtremeValue<T,LO,GO>
(
comm
,
cubatureDegree
,
requiresCellExtreme
,
useMax
,
quadPointField
,
178
linearObjFactory
,
globalIndexer
,
applyDirichletToDerivative
,
prefix
)); }
179
180
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildValueFactory
()
const
181
{
return
build<panzer::Traits::Residual>
(); }
182
183
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildDerivativeFactory
()
const
184
{
return
build<panzer::Traits::Jacobian>
(); }
185
186
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildTangentFactory
()
const
187
{
return
build<panzer::Traits::Tangent>
(); }
188
189
#ifdef Panzer_BUILD_HESSIAN_SUPPORT
193
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildHessianFactory
()
const
194
{
return
build<panzer::Traits::Hessian>
(); }
195
#endif
196
197
private
:
198
Teuchos::RCP<const panzer::LinearObjFactory<panzer::Traits> >
linearObjFactory
;
199
Teuchos::RCP<const panzer::GlobalIndexer>
globalIndexer
;
200
};
201
202
203
}
204
205
#include "
Panzer_ResponseEvaluatorFactory_ExtremeValue_impl.hpp
"
206
207
#endif
Panzer_BC.hpp
Panzer_LinearObjFactory.hpp
Panzer_PhysicsBlock.hpp
Panzer_ResponseEvaluatorFactory.hpp
Panzer_ResponseEvaluatorFactory_ExtremeValue_impl.hpp
Panzer_ResponseMESupportBuilderBase.hpp
Panzer_Traits.hpp
PHX::FieldManager
Definition
Panzer_BCStrategy_Base.hpp:53
panzer::LinearObjFactory
Definition
Panzer_LinearObjFactory.hpp:104
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_ExtremeValue
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:63
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::getCubatureDegree
int getCubatureDegree() const
Accessor method for Cubature degree (can be used by sub classes).
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:128
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::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName, const std::vector< WorksetDescriptor > &) const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:97
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::~ResponseEvaluatorFactory_ExtremeValue
virtual ~ResponseEvaluatorFactory_ExtremeValue()
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:84
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::ResponseEvaluatorFactory_ExtremeValue::ResponseEvaluatorFactory_ExtremeValue
ResponseEvaluatorFactory_ExtremeValue(MPI_Comm comm, int cubatureDegree=1, bool requiresCellReduction=true, bool useMax=true, const std::string &quadPointField="", const Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > &linearObjFactory=Teuchos::null, const Teuchos::RCP< const panzer::GlobalIndexer > &globalIndexer=Teuchos::null, bool applyDirichletToDerivative=false, std::string in_prefix="")
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:66
panzer::ResponseEvaluatorFactory::ResponseEvaluatorFactory
ResponseEvaluatorFactory()
Definition
Panzer_ResponseEvaluatorFactory.hpp:69
panzer::ResponseMESupportBuilderBase
Definition
Panzer_ResponseMESupportBuilderBase.hpp:61
panzer
Computes .
Definition
Panzer_BasisValues_Evaluator_decl.hpp:54
panzer::build< panzer::Traits::Tangent >
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > ResponseMESupportBuilderBase::build< panzer::Traits::Tangent >() const
Definition
Panzer_ResponseMESupportBuilderBase.hpp:112
panzer::build< panzer::Traits::Residual >
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > ResponseMESupportBuilderBase::build< panzer::Traits::Residual >() const
Definition
Panzer_ResponseMESupportBuilderBase.hpp:104
panzer::build< panzer::Traits::Jacobian >
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > ResponseMESupportBuilderBase::build< panzer::Traits::Jacobian >() const
Definition
Panzer_ResponseMESupportBuilderBase.hpp:108
panzer::build< panzer::Traits::Hessian >
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > ResponseMESupportBuilderBase::build< panzer::Traits::Hessian >() const
Definition
Panzer_ResponseMESupportBuilderBase.hpp:117
panzer::ExtremeValueResponse_Builder::setDerivativeInformation
virtual void setDerivativeInformation(const Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > &in_linearObjFactory)
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:167
panzer::ExtremeValueResponse_Builder::requiresCellExtreme
bool requiresCellExtreme
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:146
panzer::ExtremeValueResponse_Builder::build
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > build() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:176
panzer::ExtremeValueResponse_Builder::linearObjFactory
Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > linearObjFactory
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:198
panzer::ExtremeValueResponse_Builder::buildHessianFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildHessianFactory() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:193
panzer::ExtremeValueResponse_Builder::comm
MPI_Comm comm
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:144
panzer::ExtremeValueResponse_Builder::setDerivativeInformation
void setDerivativeInformation(const Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > &in_linearObjFactory, const Teuchos::RCP< const panzer::GlobalIndexer > &in_globalIndexer)
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:157
panzer::ExtremeValueResponse_Builder::globalIndexer
Teuchos::RCP< const panzer::GlobalIndexer > globalIndexer
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:199
panzer::ExtremeValueResponse_Builder::quadPointField
std::string quadPointField
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:148
panzer::ExtremeValueResponse_Builder::buildValueFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildValueFactory() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:180
panzer::ExtremeValueResponse_Builder::applyDirichletToDerivative
bool applyDirichletToDerivative
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:149
panzer::ExtremeValueResponse_Builder::cubatureDegree
int cubatureDegree
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:145
panzer::ExtremeValueResponse_Builder::~ExtremeValueResponse_Builder
virtual ~ExtremeValueResponse_Builder()
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:155
panzer::ExtremeValueResponse_Builder::buildTangentFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildTangentFactory() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:186
panzer::ExtremeValueResponse_Builder::useMax
bool useMax
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:147
panzer::ExtremeValueResponse_Builder::buildDerivativeFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildDerivativeFactory() const
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:183
panzer::ExtremeValueResponse_Builder::prefix
std::string prefix
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:152
panzer::ExtremeValueResponse_Builder::ExtremeValueResponse_Builder
ExtremeValueResponse_Builder()
Definition
Panzer_ResponseEvaluatorFactory_ExtremeValue.hpp:153
Generated by
1.17.0