Panzer
Version of the Day
Toggle main menu visibility
Loading...
Searching...
No Matches
disc-fe
src
responses
Panzer_ResponseEvaluatorFactory_Functional.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_Functional_hpp__
44
#define __Panzer_ResponseEvaluatorFactory_Functional_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_Functional
:
public
ResponseEvaluatorFactory
<EvalT> {
64
public
:
65
66
ResponseEvaluatorFactory_Functional
(MPI_Comm comm,
int
cubatureDegree=1,
bool
requiresCellIntegral=
true
,
const
std::string & quadPointField=
""
,
67
const
Teuchos::RCP<
const
panzer::LinearObjFactory<panzer::Traits>
> & linearObjFactory=Teuchos::null,
68
bool
applyDirichletToDerivative=
false
)
69
:
comm_
(comm),
cubatureDegree_
(cubatureDegree),
requiresCellIntegral_
(requiresCellIntegral)
70
,
quadPointField_
(quadPointField),
linearObjFactory_
(linearObjFactory)
71
,
applyDirichletToDerivative_
(applyDirichletToDerivative)
72
{ }
73
74
virtual
~ResponseEvaluatorFactory_Functional
() {}
75
85
virtual
Teuchos::RCP<ResponseBase>
buildResponseObject
(
const
std::string & responseName)
const
;
86
87
virtual
Teuchos::RCP<ResponseBase>
buildResponseObject
(
const
std::string & responseName,
88
const
std::vector<WorksetDescriptor> &
/* wkstDesc */
)
const
89
{
return
buildResponseObject
(responseName); }
90
102
virtual
void
buildAndRegisterEvaluators
(
const
std::string & responseName,
103
PHX::FieldManager<panzer::Traits>
& fm,
104
const
panzer::PhysicsBlock
& physicsBlock,
105
const
Teuchos::ParameterList & user_data)
const
;
106
114
virtual
bool
typeSupported
()
const
;
115
116
protected
:
118
int
getCubatureDegree
()
const
{
return
cubatureDegree_
; }
119
120
private
:
121
MPI_Comm
comm_
;
122
int
cubatureDegree_
;
123
bool
requiresCellIntegral_
;
124
std::string
quadPointField_
;
125
Teuchos::RCP<const panzer::LinearObjFactory<panzer::Traits> >
linearObjFactory_
;
126
bool
applyDirichletToDerivative_
;
127
};
128
129
template
<
typename
LO,
typename
GO>
130
struct
FunctionalResponse_Builder
:
public
ResponseMESupportBuilderBase
{
131
MPI_Comm
comm
;
132
int
cubatureDegree
;
133
bool
requiresCellIntegral
;
134
std::string
quadPointField
;
135
bool
applyDirichletToDerivative
;
// if this is set to true, then the dirichlet values will be zerod out in
136
// the DgDx vector
137
138
FunctionalResponse_Builder
() :
applyDirichletToDerivative
(false) {}
139
140
virtual
~FunctionalResponse_Builder
() {}
141
142
void
setDerivativeInformation
(
const
Teuchos::RCP<
const
panzer::LinearObjFactory<panzer::Traits>
> & in_linearObjFactory)
143
{
144
linearObjFactory
= in_linearObjFactory;
145
}
146
147
template
<
typename
T>
148
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
build
()
const
149
{
return
Teuchos::rcp(
new
ResponseEvaluatorFactory_Functional<T,LO,GO>
(
comm
,
cubatureDegree
,
requiresCellIntegral
,
quadPointField
,
150
linearObjFactory
,
applyDirichletToDerivative
)); }
151
152
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildValueFactory
()
const
153
{
return
build<panzer::Traits::Residual>
(); }
154
155
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildDerivativeFactory
()
const
156
{
return
build<panzer::Traits::Jacobian>
(); }
157
158
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildTangentFactory
()
const
159
{
return
build<panzer::Traits::Tangent>
(); }
160
161
#ifdef Panzer_BUILD_HESSIAN_SUPPORT
162
virtual
Teuchos::RCP<panzer::ResponseEvaluatorFactoryBase>
buildHessianFactory
()
const
163
{
return
build<panzer::Traits::Hessian>
(); }
164
#endif
165
166
private
:
167
Teuchos::RCP<const panzer::LinearObjFactory<panzer::Traits> >
linearObjFactory
;
168
};
169
170
171
}
172
173
#include "
Panzer_ResponseEvaluatorFactory_Functional_impl.hpp
"
174
175
#endif
Panzer_BC.hpp
Panzer_LinearObjFactory.hpp
Panzer_PhysicsBlock.hpp
Panzer_ResponseEvaluatorFactory.hpp
Panzer_ResponseEvaluatorFactory_Functional_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_Functional
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:63
panzer::ResponseEvaluatorFactory_Functional::requiresCellIntegral_
bool requiresCellIntegral_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:123
panzer::ResponseEvaluatorFactory_Functional::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_Functional_impl.hpp:72
panzer::ResponseEvaluatorFactory_Functional::~ResponseEvaluatorFactory_Functional
virtual ~ResponseEvaluatorFactory_Functional()
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:74
panzer::ResponseEvaluatorFactory_Functional::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName) const
Definition
Panzer_ResponseEvaluatorFactory_Functional_impl.hpp:62
panzer::ResponseEvaluatorFactory_Functional::getCubatureDegree
int getCubatureDegree() const
Accessor method for Cubature degree (can be used by sub classes).
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:118
panzer::ResponseEvaluatorFactory_Functional::quadPointField_
std::string quadPointField_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:124
panzer::ResponseEvaluatorFactory_Functional::ResponseEvaluatorFactory_Functional
ResponseEvaluatorFactory_Functional(MPI_Comm comm, int cubatureDegree=1, bool requiresCellIntegral=true, const std::string &quadPointField="", const Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > &linearObjFactory=Teuchos::null, bool applyDirichletToDerivative=false)
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:66
panzer::ResponseEvaluatorFactory_Functional::comm_
MPI_Comm comm_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:121
panzer::ResponseEvaluatorFactory_Functional::linearObjFactory_
Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > linearObjFactory_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:125
panzer::ResponseEvaluatorFactory_Functional::buildResponseObject
virtual Teuchos::RCP< ResponseBase > buildResponseObject(const std::string &responseName, const std::vector< WorksetDescriptor > &) const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:87
panzer::ResponseEvaluatorFactory_Functional::applyDirichletToDerivative_
bool applyDirichletToDerivative_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:126
panzer::ResponseEvaluatorFactory_Functional::cubatureDegree_
int cubatureDegree_
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:122
panzer::ResponseEvaluatorFactory_Functional::typeSupported
virtual bool typeSupported() const
Definition
Panzer_ResponseEvaluatorFactory_Functional_impl.hpp:139
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::FunctionalResponse_Builder::buildHessianFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildHessianFactory() const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:162
panzer::FunctionalResponse_Builder::buildValueFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildValueFactory() const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:152
panzer::FunctionalResponse_Builder::buildTangentFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildTangentFactory() const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:158
panzer::FunctionalResponse_Builder::cubatureDegree
int cubatureDegree
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:132
panzer::FunctionalResponse_Builder::~FunctionalResponse_Builder
virtual ~FunctionalResponse_Builder()
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:140
panzer::FunctionalResponse_Builder::linearObjFactory
Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > linearObjFactory
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:167
panzer::FunctionalResponse_Builder::buildDerivativeFactory
virtual Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > buildDerivativeFactory() const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:155
panzer::FunctionalResponse_Builder::build
Teuchos::RCP< panzer::ResponseEvaluatorFactoryBase > build() const
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:148
panzer::FunctionalResponse_Builder::FunctionalResponse_Builder
FunctionalResponse_Builder()
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:138
panzer::FunctionalResponse_Builder::quadPointField
std::string quadPointField
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:134
panzer::FunctionalResponse_Builder::requiresCellIntegral
bool requiresCellIntegral
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:133
panzer::FunctionalResponse_Builder::comm
MPI_Comm comm
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:131
panzer::FunctionalResponse_Builder::applyDirichletToDerivative
bool applyDirichletToDerivative
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:135
panzer::FunctionalResponse_Builder::setDerivativeInformation
void setDerivativeInformation(const Teuchos::RCP< const panzer::LinearObjFactory< panzer::Traits > > &in_linearObjFactory)
Definition
Panzer_ResponseEvaluatorFactory_Functional.hpp:142
Generated by
1.17.0