1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
|
#! /usr/bin/env python
from __future__ import print_function
from openturns import *
from openturns.testing import *
TESTPREAMBLE()
PlatformInfo.SetNumericalPrecision(3)
# Kriging use case
spatialDimension = 2
# Learning data
levels = [8., 5.]
box = Box(levels)
inputSample = box.generate()
# Scale each direction
inputSample *= 10
model = NumericalMathFunction(['x', 'y'], ['z'], ['cos(0.5*x) + sin(y)'])
outputSample = model(inputSample)
# Validation data
sampleSize = 10
inputValidSample = ComposedDistribution(2 * [Uniform(0, 10.0)]).getSample(sampleSize)
outputValidSample = model(inputValidSample)
# 2) Definition of exponential model
# The parameters have been calibrated using TNC optimization
# and AbsoluteExponential models
covarianceModel = SquaredExponential([1.98824,0.924731], [3.15352])
# 3) Basis definition
basisCollection = BasisCollection(1, ConstantBasisFactory(spatialDimension).build())
# Kriring algorithm
algo = KrigingAlgorithm(inputSample, outputSample, basisCollection, covarianceModel)
algo.run()
result = algo.getResult()
# Get meta model
metaModel = result.getMetaModel()
outData = metaModel(inputValidSample)
# 4) Errors
# Interpolation
assert_almost_equal(outputSample, metaModel(inputSample), 3.0e-5, 3.0e-5)
# 5) Kriging variance is 0 on learning points
var = result.getConditionalCovariance(inputSample)
# assert_almost_equal could not be applied to matrices
# application to NumericalPoint
covariancePoint = NumericalPoint(var.getImplementation())
theoricalVariance = NumericalPoint(covariancePoint.getSize(), 0.0)
assert_almost_equal(covariancePoint, theoricalVariance, 7e-7, 7e-7)
# Random vector evaluation
rvector = KrigingRandomVector(result, inputValidSample[0])
# Realization of the random vector
realization = rvector.getRealization()
print("Realization of the KRV=", realization)
# Get a sample of size 10
realizations = rvector.getSample(10)
print("Sample of realizations of the KRV=", realizations)
|