Transiograms
Empirical transiograms
Transiograms of categorical variables are matrix-valued functions $t_{ab}(h)$ that measure the transition probability from categorical value $a$ to categorical value $b$ at a given lag $h \in \R$. They are often used for the simulation of Markov processes in more than one dimension.
The Carle's estimator of the empirical transiogram is given by
\[\widehat{t_{ab}}(h) = \frac{\sum_{(i,j) \in N(h)} {I_a}_i \cdot {I_b}_j}{\sum_{(i,j) \in N(h)} {I_a}_i}\]
where $N(h) = \left\{(i,j) \mid ||\p_i - \p_j|| = h\right\}$ is the set of pairs of locations at a distance $h$, and where $I_a$ and $I_b$ are the indicator variables for categorical values (or levels) $a$ and $b$, respectively.
(Omini)directional transiograms
GeoStatsFunctions.EmpiricalTransiogram
— TypeEmpiricalTransiogram(data, var; [options])
Computes the empirical (a.k.a. experimental) omnidirectional transiogram for categorical variable var
stored in geospatial data
.
Options
- nlags - number of lags (default to
20
) - maxlag - maximum lag in length units (default to 1/2 of minimum side of bounding box)
- distance - custom distance function (default to
Euclidean
distance) - algorithm - accumulation algorithm (default to
:ball
)
Available algorithms:
:full
- loop over all pairs of points in the data:ball
- loop over all points inside maximum lag ball
All implemented algorithms produce the exact same result. The :ball
algorithm is considerably faster when the maximum lag is much smaller than the bounding box of the domain of the data.
See also: DirectionalTransiogram
, PlanarTransiogram
, EmpiricalTransiogramSurface
.
References
Carle, S.F. & Fogg, G.E. 1996. Transition probability-based indicator geostatistics
Carle et al 1998. Conditional Simulation of Hydrofacies Architecture: A Transition Probability/Markov Approach
GeoStatsFunctions.DirectionalTransiogram
— FunctionDirectionalTransiogram(direction, data, var; dtol=1e-6u"m", [options])
Computes the empirical transiogram for the categorical variable var
stored in geospatial data
along a given direction
with band tolerance dtol
in length units.
Forwards options
to the underlying EmpiricalTransiogram
.
GeoStatsFunctions.PlanarTransiogram
— FunctionPlanarTransiogram(normal, data, var; ntol=1e-6u"m", [options])
Computes the empirical transiogram for the categorical variable var
stored in geospatial data
along a plane perpendicular to a normal
direction with plane tolerance ntol
in length units.
Forwards options
to the underlying EmpiricalTransiogram
.
Consider the following categorical image:
using GeoStatsImages
img = geostatsimage("Gaussian30x10")
Z = [z < 0 ? 1 : 2 for z in img.Z]
cat = georef((; Z=Z), img.geometry)
cat |> viewer
data:image/s3,"s3://crabby-images/6a41f/6a41fc9782ba1ee757d37a37806f436eeac0d8f0" alt="Example block output"
We can estimate the ominidirectional transiogram with
t = EmpiricalTransiogram(cat, :Z, maxlag = 50.)
funplot(t)
data:image/s3,"s3://crabby-images/b3a31/b3a31363cae795e9f51e7675b7996f204b593ecd" alt="Example block output"
Empirical surfaces
GeoStatsFunctions.EmpiricalTransiogramSurface
— TypeEmpiricalTransiogramSurface(data, var;
normal=Vec(0,0,1), nangs=50,
ptol=0.5u"m", dtol=0.5u"m",
[options])
Given a normal
direction, estimate the transiogram of variable var
along all directions in the corresponding plane of variation.
Optionally, specify the tolerance ptol
in length units for the plane partition, the tolerance dtol
in length units for the direction partition, the number of angles nangs
in the plane, and forward the options
to the underlying EmpiricalTransiogram
.
t = EmpiricalTransiogramSurface(cat, :Z, maxlag = 50.)
surfplot(t)
data:image/s3,"s3://crabby-images/7a12e/7a12ebdc370be25d729706d9b410e42e6ca9e8e5" alt="Example block output"
Theoretical transiograms
We provide various theoretical transiogram models from the literature, which can can be combined with ellipsoid distances to model geometric anisotropy.
Models
Linear
GeoStatsFunctions.LinearTransiogram
— TypeLinearTransiogram(; range, proportions)
A linear transiogram with range
in length units, and categorical proportions
.
LinearTransiogram(; ranges, rotation, proportions)
Alternatively, use multiple ranges
and rotation
matrix to construct an anisotropic model.
LinearTransiogram(ball; proportions)
Alternatively, use a custom metric ball
.
funplot(LinearTransiogram())
data:image/s3,"s3://crabby-images/e7e0c/e7e0ca41e5a916e5ec932398a69232f6416bdbf6" alt="Example block output"
Gaussian
GeoStatsFunctions.GaussianTransiogram
— TypeGaussianTransiogram(; range, proportions)
A Gaussian transiogram with range
in length units, and categorical proportions
.
GaussianTransiogram(; ranges, rotation, proportions)
Alternatively, use multiple ranges
and rotation
matrix to construct an anisotropic model.
GaussianTransiogram(ball; proportions)
Alternatively, use a custom metric ball
.
funplot(GaussianTransiogram())
data:image/s3,"s3://crabby-images/5e0d9/5e0d9e9af73f2e5fa2382ddfd3a8c312e74b2678" alt="Example block output"
Spherical
GeoStatsFunctions.SphericalTransiogram
— TypeSphericalTransiogram(; range, proportions)
A spherical transiogram with range
in length units, and categorical proportions
.
SphericalTransiogram(; ranges, rotation, proportions)
Alternatively, use multiple ranges
and rotation
matrix to construct an anisotropic model.
SphericalTransiogram(ball; proportions)
Alternatively, use a custom metric ball
.
funplot(SphericalTransiogram())
data:image/s3,"s3://crabby-images/c640a/c640a00a71c6ae0f9aac7dd02f27853425f50e42" alt="Example block output"
Exponential
GeoStatsFunctions.ExponentialTransiogram
— TypeExponentialTransiogram(; range, proportions)
An exponential transiogram with range
in length units, and categorical proportions
.
ExponentialTransiogram(; ranges, rotation, proportions)
Alternatively, use multiple ranges
and rotation
matrix to construct an anisotropic model.
ExponentialTransiogram(ball; proportions)
Alternatively, use a custom metric ball
.
funplot(ExponentialTransiogram())
data:image/s3,"s3://crabby-images/d0274/d02747e89609fedd5032956103a5d75bffa2adca" alt="Example block output"
MatrixExponential
GeoStatsFunctions.MatrixExponentialTransiogram
— TypeMatrixExponentialTransiogram(rate)
A matrix-exponential transiogram with transition rate
matrix.
MatrixExponentialTransiogram(; range, lengths, proportions)
Alternatively, build Euclidean ball with given range
and base transition rate matrix from mean lengths
and relative proportions
.
MatrixExponentialTransiogram(; ranges, rotation, lengths, proportions)
Alternatively, use multiple ranges
and rotation
matrix to construct an anisotropic model.
MatrixExponentialTransiogram(ball, rate)
Alternatively, use a custom metric ball
.
Examples
MatrixExponentialTransiogram(lengths=(3.0, 2.0, 1.0))
MatrixExponentialTransiogram(proportions=(0.5, 0.5))
References
Carle, S.F. & Fogg, G.E. 1996. Transition probability-based indicator geostatistics
Carle et al 1998. Conditional Simulation of Hydrofacies Architecture: A Transition Probability/Markov Approach
Notes
The final proportions of the matrix-exponential model can be different from the relative proportions specified during construction. They are also a function of the mean lengths.
funplot(MatrixExponentialTransiogram())
data:image/s3,"s3://crabby-images/a27ef/a27efc537af342626c80631d80e5f54c565baf76" alt="Example block output"
PiecewiseLinear
GeoStatsFunctions.PiecewiseLinearTransiogram
— TypePiecewiseLinearTransiogram(abscissas, ordinates)
A piecewise-linear transiogram model with abscissas
and matrix ordinates
obtained from an EmpiricalTransiogram
.
PiecewiseLinearTransiogram(ball, abscissas, ordinates)
Alternatively, use a custom metric ball
.
References