CoDiPack  3.0.0
A Code Differentiation Package
SciComp TU Kaiserslautern
Loading...
Searching...
No Matches
arrayAccessExpression.hpp
1/*
2 * CoDiPack, a Code Differentiation Package
3 *
4 * Copyright (C) 2015-2025 Chair for Scientific Computing (SciComp), University of Kaiserslautern-Landau
5 * Homepage: http://scicomp.rptu.de
6 * Contact: Prof. Nicolas R. Gauger (codi@scicomp.uni-kl.de)
7 *
8 * Lead developers: Max Sagebaum, Johannes Blühdorn (SciComp, University of Kaiserslautern-Landau)
9 *
10 * This file is part of CoDiPack (http://scicomp.rptu.de/software/codi).
11 *
12 * CoDiPack is free software: you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, either version 3 of the
15 * License, or (at your option) any later version.
16 *
17 * CoDiPack is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty
19 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
20 *
21 * See the GNU General Public License for more details.
22 * You should have received a copy of the GNU
23 * General Public License along with CoDiPack.
24 * If not, see <http://www.gnu.org/licenses/>.
25 *
26 * For other licensing options please contact us.
27 *
28 * Authors:
29 * - SciComp, University of Kaiserslautern-Landau:
30 * - Max Sagebaum
31 * - Johannes Blühdorn
32 * - Former members:
33 * - Tim Albring
34 */
35#pragma once
36
37#include "../../config.h"
38#include "../../misc/macros.hpp"
39#include "../../traits/realTraits.hpp"
40#include "../computeExpression.hpp"
41
43namespace codi {
44
51 template<typename T_Aggregated, size_t T_element>
53 public:
54 using Aggregated = CODI_DD(T_Aggregated, CODI_ANY);
55 static size_t constexpr element = T_element;
56
58
59 using InnerReal = typename Traits::InnerType;
60
63 template<typename T_Real>
64 struct ArrayAccessOperation : public UnaryOperation<T_Real, ArrayAccessOperation<T_Real>> {
65 public:
66
67 using Real = CODI_DD(T_Real, double);
68
70
72 template<typename Arg>
73 static CODI_INLINE Real primal(Arg const& arg) {
74 return Traits::template arrayAccess<element>(arg);
75 }
76
78 template<typename Tangent, typename Arg>
79 static CODI_INLINE auto applyTangentArg(Tangent const& tangent, Real const& result, Arg const& arg);
80 // TODO: Implement
81
83 template<typename Adjoint, typename Arg>
84 static CODI_INLINE auto applyAdjointArg(Adjoint const& adjoint, Real const& result, Arg const& arg) {
86
87 return Traits::template adjointOfArrayAccess<element>(result, adjoint);
88 }
89 };
90
92 template<typename Arg>
94 };
95
97 template<typename Aggregated, size_t element, typename Arg>
99
100}
#define CODI_INLINE
See codi::Config::ForcedInlines.
Definition config.h:469
#define CODI_DD(Type, Default)
Abbreviation for CODI_DECLARE_DEFAULT.
Definition macros.hpp:96
#define CODI_ANY
Used in default declarations of expression templates.
Definition macros.hpp:100
CoDiPack - Code Differentiation Package.
Definition codi.hpp:94
typename ArrayAccessExpressionImpl< Aggregated, element >::template Expression< Arg > ArrayAccessExpression
Expression that performs a[element] in a compile time context.
Definition arrayAccessExpression.hpp:98
inlinevoid CODI_UNUSED(Args const &...)
Disable unused warnings for an arbitrary number of arguments.
Definition macros.hpp:54
inlineauto arg(ExpressionInterface< std::complex< Real >, Arg > const &arg)
Function overload for FUNCTION.
Definition allOperators.hpp:75
Definition arrayAccessExpression.hpp:64
static inlineReal primal(Arg const &arg)
Definition arrayAccessExpression.hpp:73
static inlineauto applyAdjointArg(Adjoint const &adjoint, Real const &result, Arg const &arg)
Definition arrayAccessExpression.hpp:84
static inlineauto applyTangentArg(Tangent const &tangent, Real const &result, Arg const &arg)
T_Real Real
See ArrayAccessOperation.
Definition arrayAccessExpression.hpp:67
Aggregated Jacobian
Jacobian is the aggregated type.
Definition arrayAccessExpression.hpp:69
Definition arrayAccessExpression.hpp:52
ComputeExpression< InnerReal, ArrayAccessOperation, Arg > Expression
Definition of the array access expression.
Definition arrayAccessExpression.hpp:93
typename Traits::InnerType InnerReal
Inner type of the aggregate.
Definition arrayAccessExpression.hpp:59
RealTraits::AggregatedTypeTraits< Aggregated > Traits
Traits of the aggregated type.
Definition arrayAccessExpression.hpp:57
static size_t constexpr element
See ArrayAccessExpressionImpl.
Definition arrayAccessExpression.hpp:55
T_Aggregated Aggregated
See ArrayAccessExpressionImpl.
Definition arrayAccessExpression.hpp:54
Represents an operator or function with an arbitrary number of arguments in the expression tree.
Definition computeExpression.hpp:371
Methods that access inner values of aggregated types that contain CoDiPack active types.
Definition realTraits.hpp:226
int InnerType
Definition realTraits.hpp:229
Implements ComputeOperation for one argument.
Definition computeExpression.hpp:98