Create an event based on a processΒΆ
This example gives elements to create an event based on a multivariate stochastic process. Let  be a stochastic process of dimension 
, where 
 is discretized on the mesh 
. We suppose that 
 contains 
 vertices.
We define the event  as:
where  is a domain of 
.
A particular domain  is the cartesian product of type:
In that case, the library defines  by its both extreme points : 
 and 
.
In the general case,  is a Domain object that is able to check if it contains a given point in 
.
The library creates an Event object from the process  and the domain 
. Then, it is possible to get a realization of the event 
, which is scalar 
 if 
 is a realization of 
 on 
.
[1]:
from __future__ import print_function
import openturns as ot
[2]:
# Define a 2-d mesh
indices = ot.Indices([40, 20])
mesher = ot.IntervalMesher(indices)
lowerBound = [0., 0.]
upperBound = [2., 1.]
interval = ot.Interval(lowerBound, upperBound)
mesh = mesher.build(interval)
[4]:
# Create the covariance model
amplitude = [1.0, 2.0, 3.0]
scale = [4.0, 5.0]
spatialCorrelation = ot.CorrelationMatrix(3)
spatialCorrelation[0, 1] = 0.8
spatialCorrelation[0, 2] = 0.6
spatialCorrelation[1, 2] = 0.1
covmodel = ot.ExponentialModel(scale, amplitude, spatialCorrelation)
# Create a normal process
process = ot.GaussianProcess(covmodel, mesh)
[5]:
# Create a domain A in R^3: [0.8; 1.2]*[1.5; 1.6]*[0.5; 0.7]
lowerBound = [0.8, 1.5, 0.5]
upperBound = [1.2, 1.6, 0.7]
domain = ot.Interval(lowerBound, upperBound)
# Create the event
event = ot.ProcessEvent(process, domain)
      OpenTURNS