ROL
src
function
dynamic
ROL_DynamicFunctionDef.hpp
Go to the documentation of this file.
1
// @HEADER
2
// ************************************************************************
3
//
4
// Rapid Optimization Library (ROL) Package
5
// Copyright (2014) Sandia Corporation
6
//
7
// Under terms of Contract DE-AC04-94AL85000, there is a non-exclusive
8
// license for use of this work by or on behalf of the U.S. Government.
9
//
10
// Redistribution and use in source and binary forms, with or without
11
// modification, are permitted provided that the following conditions are
12
// met:
13
//
14
// 1. Redistributions of source code must retain the above copyright
15
// notice, this list of conditions and the following disclaimer.
16
//
17
// 2. Redistributions in binary form must reproduce the above copyright
18
// notice, this list of conditions and the following disclaimer in the
19
// documentation and/or other materials provided with the distribution.
20
//
21
// 3. Neither the name of the Corporation nor the names of the
22
// contributors may be used to endorse or promote products derived from
23
// this software without specific prior written permission.
24
//
25
// THIS SOFTWARE IS PROVIDED BY SANDIA CORPORATION "AS IS" AND ANY
26
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
28
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL SANDIA CORPORATION OR THE
29
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
31
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
32
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
33
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
34
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
35
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
36
//
37
// Questions? Contact lead developers:
38
// Drew Kouri (dpkouri@sandia.gov) and
39
// Denis Ridzal (dridzal@sandia.gov)
40
//
41
// ************************************************************************
42
// @HEADER
43
44
45
#pragma once
46
#ifndef ROL_DYNAMICFUNCTIONDEF_HPP
47
#define ROL_DYNAMICFUNCTIONDEF_HPP
48
49
50
namespace
ROL
{
51
52
template
<
typename
Real>
53
VectorWorkspace<Real>
&
54
DynamicFunction<Real>::getVectorWorkspace
()
const
{
return
workspace_
; }
55
56
template
<
typename
Real>
57
PartitionedVector<Real>
&
58
DynamicFunction<Real>::partition
(
Vector<Real>
& x )
const
{
59
return
static_cast<
PartitionedVector<Real>
&
>
(x);
60
}
61
62
template
<
typename
Real>
63
const
PartitionedVector<Real>
&
64
DynamicFunction<Real>::partition
(
const
Vector<Real>
& x )
const
{
65
return
static_cast<
const
PartitionedVector<Real>
&
>
(x);
66
}
67
68
template
<
typename
Real>
69
Vector<Real>
&
70
DynamicFunction<Real>::getNew
(
Vector<Real>
& x )
const
{
71
return
*(
partition
(x).get(1));
72
}
73
74
template
<
typename
Real>
75
const
Vector<Real>
&
76
DynamicFunction<Real>::getNew
(
const
Vector<Real>
& x )
const
{
77
return
*(
partition
(x).get(1));
78
}
79
80
template
<
typename
Real>
81
Vector<Real>
&
82
DynamicFunction<Real>::getOld
(
Vector<Real>
& x )
const
{
83
return
*(
partition
(x).get(0));
84
}
85
86
template
<
typename
Real>
87
const
Vector<Real>
&
88
DynamicFunction<Real>::getOld
(
const
Vector<Real>
& x )
const
{
89
return
*(
partition
(x).get(0));
90
}
91
92
}
// namespace ROL
93
94
95
#endif // ROL_DYNAMICFUNCTIONDEF_HPP
96
ROL::PartitionedVector
Defines the linear algebra of vector space on a generic partitioned vector.
Definition:
ROL_PartitionedVector.hpp:60
ROL::DynamicFunction::getVectorWorkspace
VectorWorkspace< Real > & getVectorWorkspace() const
Definition:
ROL_DynamicFunctionDef.hpp:54
ROL::Vector
Defines the linear algebra or vector space interface.
Definition:
ROL_Vector.hpp:80
ROL::DynamicFunction::getNew
V & getNew(V &x) const
Definition:
ROL_DynamicFunctionDef.hpp:70
ROL
Definition:
ROL_ElementwiseVector.hpp:61
workspace_
VectorWorkspace< Real > workspace_
Definition:
ROL_Objective_SerialSimOpt.hpp:149
ROL::DynamicFunction::getOld
V & getOld(V &x) const
Definition:
ROL_DynamicFunctionDef.hpp:82
ROL::DynamicFunction::partition
PV & partition(V &x) const
Definition:
ROL_DynamicFunctionDef.hpp:58
VectorWorkspace
Provides a "smart" cloning manager to be used a member variable in a class and called in the member f...
partition
PV & partition(V &x) const
Definition:
ROL_Objective_SerialSimOpt.hpp:154
Generated by
1.8.16