Vertex value function

A vertex value function f_{vertexvalue}: \mathcal{D} \times \mathbb{R}^d \rightarrow \mathcal{D} \times \mathbb{R}^q is a particular field function that lets invariant the mesh of a field and defined by a function h : \mathbb{R}^n \times \mathbb{R}^d  \rightarrow \mathbb{R}^q such that:

\begin{aligned} f_{vertexvalue}(\underline{t}, \underline{x})=(\underline{t}, h(\underline{t},\underline{x}))\end{aligned}

Let’s note that the input dimension of f_{vertexvalue} still design the dimension of \underline{x} : d. Its output dimension is equal to q.

The creation of the VertexValueFunction object requires the function h and the integer n: the dimension of the vertices of the mesh \mathcal{M}.

This example illustrates the creation of a field from the function h:\mathbb{R}\times\mathbb{R}^2 such as:

\begin{aligned}
   h(\underline{t}, \underline{x})=(t+x_1^2+x_2^2)
\end{aligned}

import openturns as ot

Create a mesh

N = 100
mesh = ot.RegularGrid(0.0, 1.0, N)

Create the function that acts the values of the mesh

h = ot.SymbolicFunction(["t", "x1", "x2"], ["t+x1^2+x2^2"])

Create the field function

f = ot.VertexValueFunction(h, mesh)

Evaluate f

inF = ot.Normal(2).getSample(N)
outF = f(inF)

# print input/output at first 10 mesh nodes
txy = mesh.getVertices()
txy.stack(inF)
txy.stack(outF)
txy[:10]
tX0X1y0
000.6082017-1.2661731.973104
11-0.43826561.2054782.645254
22-2.1813850.35004216.880971
33-0.3550071.4372495.191716
440.8106680.7931565.286279
55-0.47052560.26101795.289525
66-2.290062-1.28288512.89018
77-1.311781-0.090783838.729011
880.9957932-0.13945289.011051
99-0.56020560.44548979.512291