12#ifndef DUMUX_CVFE_IP_DATA_HH
13#define DUMUX_CVFE_IP_DATA_HH
23template<
class LocalPos,
class GlobalPos>
31 : local_(std::move(localPos)), global_(std::move(pos)) {}
33 : local_(localPos), global_(pos) {}
52template<
class LocalPosition,
class GlobalPosition,
class LocalIndex>
58 :
ParentType(localPos, pos), localDofIndex_(index) {}
60 :
ParentType(localPos, pos), localDofIndex_(index) {}
64 {
return localDofIndex_; }
67 LocalIndex localDofIndex_;
74template<
class LocalMapping,
class GlobalPos>
78 using LocalPosition = std::invoke_result_t<LocalMapping, const GlobalPos&>;
90 {
return localMapping_(global_); }
93 LocalMapping localMapping_;
101template<
class BaseClass,
class LocalIndex>
105 using GlobalPosition = std::remove_cvref_t<decltype(std::declval<BaseClass>().global())>;
106 using LocalPosition = std::remove_cvref_t<decltype(std::declval<BaseClass>().local())>;
108 template<
class... Args>
110 : BaseClass(std::forward<Args>(args)...), normal_(std::move(n)), scvfIndex_(index) {}
112 template<
class... Args>
114 : BaseClass(std::forward<Args>(args)...), normal_(n), scvfIndex_(index) {}
122 {
return scvfIndex_; }
126 LocalIndex scvfIndex_;
133template<
class IpData>
137 template<
class... Args>
139 : IpData(std::forward<Args>(args)...), qpIndex_(qpIdx) {}
146 std::size_t qpIndex_;
An interpolation point related to a face of an element.
Definition: cvfe/interpolationpointdata.hh:103
LocalIndex scvfIndex() const
The local index of an scvf.
Definition: cvfe/interpolationpointdata.hh:121
FaceInterpolationPointData(const GlobalPosition &n, LocalIndex index, Args &&... args)
Definition: cvfe/interpolationpointdata.hh:113
FaceInterpolationPointData(GlobalPosition &&n, LocalIndex index, Args &&... args)
Definition: cvfe/interpolationpointdata.hh:109
const GlobalPosition & unitOuterNormal() const
The unit outer normal vector at the quadrature point.
Definition: cvfe/interpolationpointdata.hh:117
std::remove_cvref_t< decltype(std::declval< BaseClass >().local())> LocalPosition
Definition: cvfe/interpolationpointdata.hh:106
std::remove_cvref_t< decltype(std::declval< BaseClass >().global())> GlobalPosition
Definition: cvfe/interpolationpointdata.hh:105
Wraps interpolation point data and adds a quadrature point index for use in quadrature loops.
Definition: cvfe/interpolationpointdata.hh:135
std::size_t qpIndex() const
The quadrature point index.
Definition: cvfe/interpolationpointdata.hh:142
IndexedQuadratureInterpolationPointData(std::size_t qpIdx, Args &&... args)
Definition: cvfe/interpolationpointdata.hh:138
An interpolation point related to an element that includes global and local positions.
Definition: cvfe/interpolationpointdata.hh:25
const LocalPosition & local() const
The local position of the quadrature point.
Definition: cvfe/interpolationpointdata.hh:40
GlobalPos GlobalPosition
Definition: cvfe/interpolationpointdata.hh:28
const GlobalPosition & global() const
The global position of the quadrature point.
Definition: cvfe/interpolationpointdata.hh:36
InterpolationPointData(LocalPosition &&localPos, GlobalPosition &&pos)
Definition: cvfe/interpolationpointdata.hh:30
LocalPos LocalPosition
Definition: cvfe/interpolationpointdata.hh:27
InterpolationPointData(const LocalPosition &localPos, const GlobalPosition &pos)
Definition: cvfe/interpolationpointdata.hh:32
An interpolation point related to a global position of an element, giving its local positions by a ma...
Definition: cvfe/interpolationpointdata.hh:76
InterpolationPointDataLocalMapping(LocalMapping &&mapping, GlobalPosition &&pos)
Definition: cvfe/interpolationpointdata.hh:81
const LocalPosition local() const
The local position of the quadrature point.
Definition: cvfe/interpolationpointdata.hh:89
InterpolationPointDataLocalMapping(LocalMapping &&mapping, const GlobalPosition &pos)
Definition: cvfe/interpolationpointdata.hh:82
std::invoke_result_t< LocalMapping, const GlobalPos & > LocalPosition
Definition: cvfe/interpolationpointdata.hh:78
const GlobalPosition & global() const
The global position of the quadrature point.
Definition: cvfe/interpolationpointdata.hh:85
GlobalPos GlobalPosition
Definition: cvfe/interpolationpointdata.hh:79
An interpolation point related to a localDof of an element, giving its global and local positions.
Definition: cvfe/interpolationpointdata.hh:54
LocalDofInterpolationPointData(const LocalPosition &localPos, const GlobalPosition &pos, LocalIndex index)
Definition: cvfe/interpolationpointdata.hh:59
LocalDofInterpolationPointData(LocalPosition &&localPos, GlobalPosition &&pos, LocalIndex index)
Definition: cvfe/interpolationpointdata.hh:57
LocalIndex localDofIndex() const
The local index of the corresponding dof.
Definition: cvfe/interpolationpointdata.hh:63
Definition: cvfe/interpolationpointdata.hh:17