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

ot.Log.Show(ot.Log.NONE)

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.5112560.16655790.2891242
11-0.6232318-1.5157873.686029
220.2845683-0.84800722.800095
331.9074780.38176616.784218
44-0.1213199-0.018476934.01506
55-0.41922560.95025526.078735
66-0.11239131.5788828.505499
770.57268941.4021289.293936
881.0113141.54286111.40318
990.4464708-1.06727110.3384