the Creative Commons Attribution 4.0 License.
Special issue: The Loop 3D stochastic geological modelling platform – development...
Development and technical paper 29 Jun 2021
Development and technical paper  29 Jun 2021
LoopStructural 1.0: timeaware geological modelling
 ^{1}School of Earth Atmosphere and Environment, Monash University, Melbourne 3800, Australia
 ^{2}Université d'Orléans, CNRS, BRGM, ISTO, UMR 7327, Orleans, France
 ^{3}Mineral Exploration Cooperative Research Centre, School of Earth Sciences, UWA, Perth 6907, Australia
 ^{1}School of Earth Atmosphere and Environment, Monash University, Melbourne 3800, Australia
 ^{2}Université d'Orléans, CNRS, BRGM, ISTO, UMR 7327, Orleans, France
 ^{3}Mineral Exploration Cooperative Research Centre, School of Earth Sciences, UWA, Perth 6907, Australia
Correspondence: Lachlan Grose (lachlan.grose@monash.edu)
Hide author detailsCorrespondence: Lachlan Grose (lachlan.grose@monash.edu)
In this contribution we introduce LoopStructural, a new opensource 3D geological modelling Python package (http://www.github.com/Loop3d/LoopStructural, last access: 15 June 2021). LoopStructural provides a generic API for 3D geological modelling applications harnessing the core Python scientific libraries pandas, numpy and scipy. Six different interpolation algorithms, including three discrete interpolators and 3 polynomial trend interpolators, can be used from the same model design. This means that different interpolation algorithms can be mixed and matched within a geological model allowing for different geological objects, e.g. different conformable foliations, fault surfaces and unconformities to be modelled using different algorithms. Geological features are incorporated into the model using a timeaware approach, where the most recent features are modelled first and used to constrain the geometries of the older features. For example, we use a fault frame for characterising the geometry of the fault surface and apply each fault sequentially to the faulted surfaces. In this contribution we use LoopStructural to produce synthetic proof of concepts models and a 86 km × 52 km model of the Flinders Ranges in South Australia using map2loop.
Understanding and characterising the geometry and interaction between geological features in the subsurface is an important stage in resource identification and management. A surface or combination of surfaces can be used to represent the subsurface geometry of geological features or structural elements within 3D geological models (Caumon et al., 2009). There are two main approaches for representing surfaces in 3D geological models: (1) one in which the surface is represented by directly triangulating control points defining the surface geometry or (2) one in which the surface is extracted as an isovalue or level set of an implicit function (Wellmann and Caumon, 2018). Explicit surface representation in geological modelling refers to manually drawn surfaces and is usually time consuming and requires significant subjective user input because surfaces are usually sculpted to the modellers conceptual idea in a similar way to drawing polylines in geographical information systems or using computeraided design software. Implicit surface representation involves approximating an unknown function that represents the distance to a geological surface. The implicit function can be queried anywhere throughout the model for the value or gradient of the function. The implicit function is fitted to observations that are used to infer the geometry of a geological surface, for example the distance to the geological surface (for stratigraphic horizons this may be the cumulative thickness) or the gradient of the function (on contact or off contact) observations. The topological relationships between different geological features, e.g. horizons, faults interactions, intrusions and unconformities, are incorporated using multiple implicit functions for different components of the model. Implicit surface representation removes the need to generate surfaces and allows for the geological features to be represented directly by the implicit function value.
All implicit surface modelling techniques involve finding a combination of weighted basis functions that fit the geological observations. There are two main approaches used for implicit surface modelling: (1) datasupported approaches where the basis functions are estimated at the data points (Calcagno et al., 2008a; Cowan et al., 2003; Gonçalves et al., 2017; Hillier et al., 2014; Lajaunie et al., 1997) and (2) discrete interpolation where the basis functions are located on a predefined support (Caumon et al., 2013; Frank et al., 2007; Irakarama et al., 2018; Renaudeau et al., 2019). The algorithms are often linked to commercial software, e.g. Leapfrog^{1}, 3D GeoModeller^{2} and GocadSKUA^{3}. These packages will usually only provide one algorithm for interpolation, making it difficult to compare different interpolation schemes. The algorithms are also usually black box algorithms with limited ability to change algorithm parameters, with no understanding of how the algorithm is implemented. A recent opensource Python library, Gempy (de la Varga et al., 2019), implements the dual cokriging implicit interpolation algorithm (Lajaunie et al., 1997) using a high performance computational library.
In this contribution we introduce the opensource LoopStructural, a 3D geological modelling Python library based on the incremental contributions of Laurent et al. (2016) and Grose et al. (2017, 2018, 2019). LoopStructural is a new geological modelling engine developed within the Loop^{4} consortium (Ailleres et al., 2018). The core modelling library within LoopStructural depends on scipy (Virtanen et al., 2020), numpy (Van Der Walt et al., 2011) and pandas (pandas development team, 2020), the core scientific Python libraries. A visualisation module uses LavaVu (Kaluza et al., 2020), a minimal OpenGL visualisation package allowing for models to be visualised within a Jupyter notebook environment. LoopStructural has been written using an objectoriented program design with class structures designed to allow for powerful inheritance and modularity. The design of LoopStructural allows development and research into geological modelling methods to be easily performed without having to rewrite boiler plate code for interpolation algorithms, visualisation and model interaction. LoopStructural is a modelling package allowing for multiple stratigraphic groups, faults, folds and unconformities to be represented using implicit surfaces. Different interpolation algorithms can be used for interpolating these surfaces with the ability to mix and match interpolation algorithms depending on the surface type being modelled. LoopStructural has native implementation of discrete implicit modelling using a piecewise linear interpolation on a tetrahedral mesh (Caumon et al., 2013; Frank et al., 2007; Mallet, 2014, 2002), finitedifference interpolation on a Cartesian grid (Irakarama et al., 2018; Renaudeau et al., 2018), fold interpolation using tetrahedral meshes (Laurent et al., 2016) and an interface to a generalised radial basis interpolation (Hillier et al., 2014).
This paper begins with a background analysis of 3D modelling methods and the algorithms used in implicit modelling, with an overview of the mathematical and geological backgrounds used in our implementation. A detailed overview of the specifics of the implementation can be found on (http://loop3d.github.io/LoopStructural, last access: 15 June 2021). To demonstrate the versatility of LoopStructural and to provide a user guide we include four case studies in this paper with corresponding Jupyter notebooks. The first case study is a synthetic example interpolating two planar surfaces where the height of one surface has been perturbed to simulate uncertainty in the surface location. In this example we use the LoopStructural API to compare three different interpolation codes and investigate the parameters and how they are affected by noise. The second example is a synthetic refolded type 3 interference pattern from Laurent et al. (2016), where we apply the timeaware discrete fold interpolation method described by Laurent et al. (2016) for modelling the refolded folds. In the third case study LoopStructural is applied to a real dataset from the Flinders Ranges in South Australia, where the dataset has been prepared using the preprocessing module of the Loop workflow map2loop (Jessell et al., 2021). In the fourth and final case study we use map2loop to augment an input dataset for a model in the Hamersley region in Western Australia. We generate 10 unique models, demonstrating the range of possible geometries when perturbing the fault geometry.
A 3D geological model can be represented by a collection of surfaces representing geological features (e.g. fault surfaces, stratigraphic horizons, axial surfaces of folds, unconformities) (Wellmann and Caumon, 2018). There are two main tasks for a 3D modelling software package:

the creation of the surfaces from geological observations and knowledge, this is known as interpolation;

the incorporation of geological concepts into the surface description, e.g. faulted surfaces should show displacement and unconformities should be a boundary between units.
In LoopStructural surfaces are implicitly represented by an isovalue of one or more volumetric scalar fields (Calcagno et al., 2008a; Caumon et al., 2013; Cowan et al., 2003; Frank et al., 2007; Gonçalves et al., 2017; Hillier et al., 2014; Jessell, 1981; de la Varga et al., 2019; Lajaunie et al., 1997; Mallet, 2002, 2014; Manchuk and Deutsch, 2019; Maxelon et al., 2009; Moyen et al., 2004; Renaudeau et al., 2019; Yang et al., 2019). The geological rules are managed by adding the geological event (folding event, one fault, another fault, an unconformity) structural parameters in a timeaware approach, where the most recent event is added first and the constraints are added backwards in time. Complex geological features such as folds and faults are integrated into LoopStructural by building a structural frame around the principal structural directions of the feature being modelled. Using these structural frames geological rules can be integrated into the modelling workflows – e.g. fault kinematics can be added to the faulted feature because the fault geometry is known before interpolating the faulted feature or fold overprinting relationships can be incorporated using multiple structural frames (Laurent et al., 2016).
2.1 Implicit surface modelling
Implicit surface modelling involves the representation of the geometry of a geological feature using a function f(xyz) where the value of the function is the same along the observation of the surface. There are two possible ways of framing this question. The first approach uses the scalar field value as a distance from a reference horizon, e.g. the location of the horizon for a single surface would be the value of the scalar field. Using this approach, which we will call the signed distance approach, the same implicit function can represent conformable horizons where the value of each horizon is the cumulative thickness from the base of the series (Caumon et al., 2013; Hillier et al., 2014; Jessell, 1981; Manchuk and Deutsch, 2019; Wellmann and Caumon, 2018). The second approach, often referred to as the potential field approach, does not specify the value of the scalar field. The potential field approach only defines the potential field to have the same value for specific interfaces, such as contacts between geological units and fault traces (Calcagno et al., 2008a; de la Varga et al., 2019). As with the signed distance field, the potential field can represent conformable horizons – where the value of the implicit function evaluated on the input observations can be used to infer the potential field value for these horizons.
These implicit functions have no known analytical solution, which means that they need to be approximated from the observations that are provided. The implicit function is represented by a weighted combination of basis functions:
where N is the number of basis functions, w are the weights and φ are the basis functions. There are two approaches for approximating the implicit function: the first approach uses a discrete formulation for the interpolation where N is defined by some sort of mesh (Caumon et al., 2013; Frank et al., 2007; Mallet, 1992; Moyen et al., 2004), and the second approach uses datasupported basis functions where N is defined by the number of data points (Calcagno et al., 2008a; Cowan et al., 2003; Gonçalves et al., 2017; Hillier et al., 2014; de la Varga et al., 2019; Lajaunie et al., 1997).
2.1.1 Input data
Geological observations that are directly incorporated into 3D modelling can generally be divided into two categories: observations that describe the orientation of a geological feature (on contact and off contact) and observations that describe the location within a geological feature (cumulative thickness for conformable stratigraphic horizons, or location of fault surface). In the context of a geological map, location observations may be the trace of a geological surface on the geological map, or a single point observation at an outcrop or from a borehole. Orientation observations generally record a geometrical property of the surface – e.g. a vector that is tangential to the plane or the vector that is normal to the plane (black and dashed arrows in Fig. 1).
When modelling using the potential field approach, the value of the scalar field is inferred through the magnitude of the normal control points. Using the signed distance approach, the value of the scalar field is defined by the value of the observations and effectively controls the thickness of the layers. Orientation constraints either control a component of the orientation, e.g. specifying that the gradient of the function should be orthogonal to the observation or constrain the magnitude and direction of the norm of the gradient of the implicit function.
All geological observations constrain a component of the implicit function at a location in the model:

Observations for the location of the geological feature will constrain the value of the scalar field $f\left(x,y,z\right)=v$.

Observations for the orientation of the contact can either
 •

constrain the partial derivatives of the function $\mathrm{\nabla}f\left(x,y,z\right)=\mathit{n}$ or
 •

constrain a vector which is parallel to the contact $\mathrm{\nabla}f\left(x,y,z\right)\cdot \mathit{t}=\mathrm{0}$.
It is worth noting that when constraining the partial derivative of the scalar field, the norm of the vector defines the norm of the implicit function which controls the distance between isosurfaces. The sign of the vector must be consistent with the polarity of the structural observation, e.g. for bedding this must be the younging direction. Structural orientations can also be incorporated into the model using two tangent constraints where ${\mathit{t}}_{\mathrm{1}}\times {\mathit{t}}_{\mathrm{2}}=\mathit{n}$, where × is the vector product. In the following sections we will outline the theoretical background for the piecewise linear interpolation, finitedifference interpolation and datasupported interpolation. Within all approaches, the observations are incorporated by adding observations as constraints into a linear system of equations.
2.1.2 Piecewise linear interpolation
The volumetric scalar field is defined by a piecewise linear function on a volumetric tetrahedral mesh. In LoopStructural the volumetric tetrahedral mesh creation is simplified by subdividing a regular Cartesian grid into a tetrahedral mesh where one cubic element is divided into five tetrahedra (see Appendix A). The linear tetrahedron is the basis of the piecewise linear interpolation algorithm, where the property within the tetrahedron is interpolated using a linear function; see Appendix A for a detailed description of the linear basis function. We use constant gradient regularisation (Caumon et al., 2013; Frank et al., 2007; Mallet, 1992), where the change in gradient of the implicit function is minimised between tetrahedra with a shared face. The constant gradient regularisation is as follows:
where ∂φ^{T1} is the gradient of the first tetrahedron, ∂φ^{T2} is the gradient of the second tetrahedron and n is the normal vector to the shared face.
2.1.3 Finitedifference interpolation
The second discrete interpolation approach approximates the interpolant using a combination of trilinear basis functions on a Cartesian grid. The basis functions describe the interpolation as a function of the corners of the cell within which the point where the function is to be estimated falls; see Appendix B for the trilinear basis functions. For example, to evaluate the value of the implicit function at a point x_{i}y_{i}z_{i}, first the cell c is found using integer division of the point coordinates and the grid step vector, where the integer corresponds to the index of the cell in the grid. The local coordinates (ξ, η, ζ) are determined by finding the relative location of the point within the cell. Different regularisation terms can be used; for example Irakarama et al. (2018) minimise the sum of the second derivatives:
Alternatively, a partial differential equation such as the bending energy (Renaudeau et al., 2019) or Gaussian curvature could be used. In LoopStructural 1.0, currently only the sum of the second derivatives can be used. The objectoriented program design would allow for different regularisation constraints to be implemented without requiring any boiler plate code.
2.1.4 Solving discrete interpolation
Using either the piecewise linear interpolator or the finitedifference interpolator the scalar field is defined by the node values of the support. These can be found by solving a system of equations with M unknowns ${x}_{\mathrm{1}},\mathrm{\dots},{x}_{M}$ (Caumon et al., 2013; Frank et al., 2007; Mallet, 2004). The unknowns can be found by solving the linear system of equations:
where A is an N×M sparse matrix containing the linear constraints and b the righthand side vector containing the observation of constraint value. For example, to integrate value observations the row in the interpolation matrix A would contain the shape parameters for the cell in which the point is contained. The righthand side would be the value of the scalar field.
The interpolation problem is overconstrained, i.e. N>M, and can be solved in a least squares sense. The least squares problem can be solved using a number of different algorithms either directly where A^{T}⋅A is directly inverted, e.g. using lower–upper decomposition, or using an iterative algorithm such as conjugate gradient. Generally, for large problems an iterative approach is recommended because it requires less memory. LoopStructural allows for multiple different solvers to be used for the least squares problem. The default solver is the conjugate gradient algorithm implemented in scipy. To speed up the solver and in some cases improve the stability of the solution we provide the option of adding a small value (the smallest representable float) to the diagonal of the square matrix (A^{T}⋅A).
2.1.5 Datasupported interpolation
Another approach for implicit surface modelling is to use basis functions that are located at the same location as data points.
This can be done using radial basis interpolation where the interpolation problem is attempting to approximate the signed distance field:
Alternatively, the problem can be represented using dual cokriging (Calcagno et al., 2008b; de la Varga et al., 2019; Lajaunie et al., 1997), where the interpolation algorithm estimates the potential field, which estimates incremental differences between the scalar field for different horizons. Using this approach, the system is separated into two parts: (1) the orientation observations which are incorporated using the direction and magnitude and (2) the difference between the potential field for different horizons.
LoopStructural uses SurfE, a C++ implementation of the generalised radial basis interpolation (Hillier et al., 2014) for all datasupported interpolations. SurfE has three approaches for implicit surface reconstruction (1) signed distance interpolation using radial basis functions, (2) potential field interpolation using dual cokriging (Lajaunie et al., 1997) and (3) signed distance interpolation using a separate scalar field for each surface. The interface between LoopStructural and SurfE allows the user to access all of the interpolation parameters used by SurfE. These include access to more sophisticated solvers, as well as the addition of a smoothing parameter into the interpolation.
2.2 Modelling geological features
There are three ways that the geometry of rock packages can structurally interact in a geological model:

stratigraphic contacts – the contact between sedimentary layers;

fault contacts;

intrusive contacts.
These geological interfaces can all be affected by deformational structures such as folds, faults and shear zones. In the following sections we will describe how these different geological features are integrated into 3D modelling workflows by describing how different scalar fields interact and how the structural geology of faults and folds are added into the implicit surface description.
2.2.1 Stratigraphic contacts
In an implicit geological model, the distribution of stratigraphic packages is defined by the values of a volumetric scalar field. The scalar field is defined by an implicit function that is fitted to observations (location and orientation) defining the geometry of the top or base of a geological unit. A single geological interface can be modelled using a single scalar field, or multiple conformable interfaces can be modelled using a single scalar field where different isovalues are used to represent the different contacts. A stratigraphic group can be considered as a collection of stratigraphic surfaces that are conformable. When modelling a stratigraphic group, the value of the scalar field represents the distance away from the base of a group of conformable layers.
An unconformity is a geological interface where the rock units on either side are of significantly different ages, usually representing a period of erosion. In Fig. 3 the three conventional types of unconformity are shown. In Fig. 3a. the unconformity between the units is a disconformity and the geometry of the disconformity is not associated with either stratigraphic package. The disconformity is usually identified by the significant gap between the ages of the rocks. In this type of contact the layers actually share a similar geometry and for the purpose of 3D modelling the units could be represented by a single stratigraphic group. Angular unconformities (Fig. 3b) are observed when erosion occurs after some deformation (the older beds are not horizontal anymore) and before the next deposition of sedimentary layers. As the name suggests the angular unconformity represents a boundary between two differently oriented stratigraphic sequences. In a 3D model an angular unconformity can be introduced by setting the boundary between the two sequences to be the base of the younger package. In practice, this means that the two groups are modelled with two separate scalar fields. In Fig. 3c a nonconformity is shown; in this type of unconformity the geometry of the older unit defines the base of the younger unit. This could occur when a stratigraphic package is deposited on top of a crystalline basement.
2.2.2 Structural frames
A structural frame (Fig. 4) is a local coordinate system that is built around the major structural elements of a geological event. In LoopStructural structural frames are used for characterising the geometry of folds where the major structural element is the fold axial foliation (Fig. 4b) and the structural direction is roughly the fold axis. A fault frame is a structural frame where the major structural feature is the fault surface, the structural direction is the fault slip and the intermediate direction is the fault extent (Fig. 4). In LoopStructural, structural frames are built by first building the major structural feature which will typically have more observations, e.g. fault surface location or axial foliations. The structural direction is then built using any available observations of the structural direction, e.g. local observations of the fault slip or the fold axis, combined with an additional constraint which sets the gradient of the scalar field to be orthogonal to the major structural feature. The third coordinate can be built with an arbitrary value constraint, or value constraints to specify the extent of the field in this direction (e.g. for faults −1 and 1 specify the edges of the fault). This value constraint is combined with two global orthogonality constraints specifying that the scalar field should be orthogonal to both the major structural feature and the structural direction.
2.2.3 Faults
“A fault is a tabular volume of rock consisting of a central slip surface or core, formed by an intense shearing, and a surrounding volume of rock that has been affected by more gentle brittle deformation spatially and genetically related to the fault” (Fossen, 2010).
When adding faults there are two aspects to modelling the fault: (1) building the fault surface geometry and (2) integrating the fault displacement into older surfaces. Where possible, measurements of faults include the movement direction and the magnitude of displacement. There are three broad approaches for integrating faults into the implicit modelling framework: (1) add the fault into the implicit description of the surface (Calcagno et al., 2008a; de la Varga et al., 2019); (2) apply the fault after interpolating a continuous surface (Godefroy et al., 2018a; Laurent et al., 2013) and (3) represent the foot wall and hanging wall by separate implicit functions. Regardless of the approach used, the geometry of the fault surface is defined before defining the geometry of the surfaces displaced by the fault. The fault surface can be interpolated by building a scalar field where the fault surface is represented by an isovalue.
In LoopStructural there are two ways of representing faults: (1) the fault kinematics are added into the implicit description of the scalar field of the faults and applied to the affected scalar field(s) (Grose et al., 2021a) and (2) faults are treated as domain boundaries and separate scalar fields are used to model the hanging wall and footwall of the fault. The kinematics of the fault are added into the implicit description of the faulted surface. To do this a fault frame is built (Fig. 4c) where three coordinates are interpolated: (1) a scalar field representing the distance to the fault surface, (2) a scalar field representing the distance along the slip direction of the fault and (3) a scalar field representing the extent of the fault. These coordinates can then be used to define the fault ellipsoid, which is a volumetric representation of the area deformed by the fault. The displacement of the fault can be defined relative to this coordinate system, e.g. the displacement of the fault should decay away from the fault centre along the fault extent and along the direction of displacement using the bellshaped curve (Fig. 5d). The displacement may decrease with distance away from the fault centre perpendicular to the fault surface; this can be defined using the profile in Fig. 5c. If the displacement is constant within the model area the curves in Fig. 5a and b can be substituted for Fig. 5c and d respectively. The displacement curves shown in Fig. 5 can be substituted for any function of the fault frame coordinates. The same approach for combining the fault profiles (Fig. 5) within the fault frame has been used to define a volumetric fault displacement field (Jessell and Valenta, 1996; Godefroy et al., 2018b), the latter of which was adapted from the following Laurent et al. (2013):
where ${D}_{\mathrm{0},\mathrm{1},\mathrm{2}}$ are 1D curves (e.g. any of the curves in Fig. 5) describing the displacement of the fault within the fault frame.
The fault frame can be built using a discrete implicit modelling approach as additional constraints can be added into the interpolation to enforce the orthogonality of the three coordinate systems. This is added into the interpolation matrix by adding a constraint for every element in the mesh where $\mathrm{\nabla}{\mathit{\varphi}}_{\mathrm{0}}\left(x,y,z\right)\cdot \mathrm{\nabla}{\mathit{\varphi}}_{\mathrm{1}}\left(x,y,z\right)=\mathrm{0}$. This constraint can be added twice so that when modelling ϕ_{2} both ϕ_{0} and ϕ_{1} are orthogonal. In general, this means that if the fault orientation, fault trace and fault slip direction are known, the fault can be modelled. Where the fault slip is unknown, this can be substituted by conceptual knowledge, e.g. enforcing strikeslip faults or reverse faults.
2.2.4 Folds
Folds are challenging to model using classical implicit interpolation algorithms, because by definition a folded surface has a symmetry only defined by their axial surface. The symmetry is hard to reproduce by only interpolating orientations of the folded foliation as this would require orientations to be sampled in a symmetrical way across the axial surface (Laurent et al., 2016; Lisle et al., 2007; Mynatt et al., 2007). The regularisation of implicit algorithms are usually defined to minimise some sort of curvature between observations such as constant gradient regularisation, minimising second derivatives using finite differences or the weighted combination of infinite basis functions (Calcagno et al., 2008a; Cowan et al., 2003; Frank et al., 2007; Jessell et al., 2014; Lajaunie et al., 1997; Laurent, 2016; Mallet, 2014). As a result, to model folded geometries the geologist is required to add interpretive constraints such as synthetic bore holes, cross sections or simply synthetic constraints to produce model geometries that fit the geologist's conceptual idea of the fold (Caumon et al., 2003; Jessell et al., 2014, 2010).
There have been a number of different approaches to incorporating folds into implicit modelling including incorporating the fold axial surfaces (Laurent et al., 2016; Maxelon et al., 2009), the fold axis (Hillier et al., 2014; Laurent et al., 2016; Massiot and Caumon, 2010), both these structural elements and fold overprinting relationships (Laurent et al., 2016).
LoopStructural implements the following fold constraints: the fold axis, fold axial surface and overprinting relationships (Laurent et al., 2016) by adding additional constraints into a discrete interpolation approach. A fold frame (Figs. 4b and 6) is built where the principal axes of the fold frame correspond with the direction of the finitestrain ellipsoid. The fold frame allows for the geometry of the folded surface to be defined.
The orientation of the fold axis (${\mathbf{F}}_{\mathrm{A}}^{\mathrm{T}}$) can be defined within the fold frame by rotating the fold axis direction field by the fold axis rotation angle (Fig. 6b2). The fold direction (${\mathbf{F}}_{\mathrm{D}}^{\mathrm{T}}$) is defined by rotating the normal to the axial foliation around the fold axis by the fold limb rotation angle. The orientation of the folded surface is the plane defined by the fold axis vector and the fold direction vector (Fig. 6b3). The fold constraints have been implemented into the piecewise linear interpolator using four main constraints, where φ(xyz) represents the implicit function, ∇ represents the gradient, t represents a tetrahedron where the constraint is applied and T1 and T2 are two tetrahedrons that share a face, and h_{s} is the expected magnitude of the gradient norm:

The folded surface should contain the orientation of the fold axis: ${\mathbf{F}}_{\mathrm{A}}^{\mathrm{T}}\cdot \mathrm{\nabla}\mathit{\phi}\left(xyz\right)=\mathrm{0}$.

The folded surface will contain the fold direction (solid red arrow in Fig. 6b3) vector: ${\mathbf{F}}_{\mathrm{D}}^{\mathrm{T}}\cdot \mathrm{\nabla}\mathit{\phi}\left(xyz\right)=\mathrm{0}$.

The regularisation should only occur within the intermediate structural direction (e_{x}) ${\mathbf{e}}_{x\mathrm{0}}^{\mathrm{t}}\cdot \mathrm{\nabla}{\mathit{\phi}}_{\mathrm{T}\mathrm{1}}\left(xyz\right){\mathbf{e}}_{x\mathrm{1}}^{\mathrm{t}}\cdot \mathrm{\nabla}{\mathit{\phi}}_{\mathrm{T}\mathrm{2}}\left(xyz\right)=\mathrm{0}$.

A similar fold constraint is as follows: ${\mathbf{e}}_{x}^{\mathrm{t}}\cdot \mathrm{\nabla}\mathit{\phi}\left(xyz\right)=\frac{\mathrm{1}}{{h}_{\mathrm{s}}}$.
The fold constraints require two angles to be known throughout the model: the fold axis rotation angle (α_{P}) and the fold limb rotation angle (α_{L}). The fold axis rotation angle (α_{P}) is the angle between the fold axis and e_{y} (Grose et al., 2017).
The fold limb rotation angle (α_{L}) is the angle that defines the orientation of the folded foliation relative to fold axial foliation and will be 0 in the hinge of the fold and positive and negative in the limbs (Grose et al., 2017). Grose et al. (2017) used the fold frame to calculate these angles for observations and then applied interpolation either using radial basis functions or by fitting an objective function (a Fourier series) to the rotation angles within the fold frame coordinates. The wavelength of the fold can be estimated by calculating an experimental semivariogram of the fold rotation angle in the fold frame coordinates. For periodic folding, the experimental variogram has a periodic curve where the first peak indicates the halfwavelength of the fold (Grose et al., 2017).
In LoopStructural the default approach for fitting the fold rotation angle is to fit a Fourier series. The fold axis rotation angle is calculated first; the wavelength is first estimated automatically using the gradient descent method on the experimental variogram of the fold axis. The fold rotation angle is optimised using the scipy.optimize.curve_fit method using nonlinear least squares to fit wavelength and Fourier coefficients. The fold axis can then be defined throughout the model by applying the rotation of e_{y}⋅R_{p}. If the fold axis is constant (cylindrical folding), a constant fold axis vector can be used.
The fold limb rotation angle is calculated by finding the complementary angle between the normal to the folded foliation and e_{z} in the plane perpendicular to the fold axis. The fold limb rotation angle can be interpolated by fitting a Fourier series to the observations in the same way as fitting the fold axis rotation angle.
Grose et al. (2018, 2019) use inverse problem theory to fit a forward model of the fold geometry to the observed fold rotation angles. The joint posterior distribution of the fold parameters (Fourier series coefficients, fold wavelength and a misfit parameter) are sampled using Bayesian inference. This allows multiple fold geometries to be explored without perturbing the datasets. LoopStructural does not provide a direct probabilistic interface; however, it is possible to define a probabilistic representation of the fold geometry curves and add this into the modelling workflow. An example using the Python library emcee (ForemanMackey et al., 2013) is provided in the LoopStructural documentation.
3.1 Loop structural design
LoopStructural is written using Python 3.6+, using numpy data structures and operations. The design of LoopStructural follows an objectoriented architecture with multiple levels of inheritance. Objectoriented design allows for LoopStructural to be used as a development platform for 3D geological modelling, where new features can be added without needing to implement boiler plate code. There are five submodules that can be imported into a Python environment:

core contains the core modelling functionalities and the management of the geological concepts.

interpolation contains the various interpolation code and supports used to build scalar fields.

datasets contains the test and reference datasets.

utils contains miscellaneous functions.

visualisation contains model visualisation tools.
The creation and management of different geological objects is managed by the GeologicalModel. To initialise an instance, the required arguments are the minimum and maximum extents of the bounding box, which are specified by two separate vectors. The default behaviour is to define a rescaling coefficient as follows:
Adding different geological objects can be done through using an instance of GeologicalModel. There are four different types of observations that can be incorporated into an interpolation algorithm:

value constrains the value of the scalar field at a particular location and can either represent the location of a surface or the distance away from the surface.

gradient constrains only the gradient of the scalar field; e.g. the normal to the scalar field should be orthogonal to two vectors within the gradient plane.

tangent is the scalar field and should be orthogonal to a vector.

norm constrains the direction and magnitude of the scalar field norm.
The data can be associated with the GeologicalModel using the set_data(data) method where “data” is a pandas data frame. When added into the model the data points are transformed into the model coordinate system.
3.2 Adding geological objects
Within LoopStructural geological objects such as stratigraphy, faults, folding event and unconformities are all represented by a GeologicalFeature. A GeologicalFeature can be evaluated for the value of the scalar field and/or the gradient of the scalar field at a location.
The GeologicalModel contains an ordered collection of geological features and determines how the features interact. For example, unconformity geological features act as a mask to determine where the interface between packages should be. The ordering of the GeologicalFeatures inside the model reflects the timing of the geological events being modelled. The most recent features are added first as their geometry is used to constrain the older features.
There are different ways a GeologicalFeature can be added to a GeologicalModel depending on the type of geological object that is being modelled. The LoopStructural GeologicalModel class provides an interface for creating geological objects, where different types of geological features can be added using different functions. All geological objects are represented by one or multiple volumetric scalar field. These scalar fields can be built using an implicit interpolation algorithm where the implicit function is approximated from observations of the scalar field. Alternatively, a GeologicalFeature can be represented by an analytical function (or a combination of existing GeologicalFeatures). LoopStructural allows for different interpolation algorithms to be specified for different GeologicalFeatures within the same model. The interpolation algorithm and any parameter definitions are specified by adding additional keyword arguments to the function. Table 1 outlines the possible arguments that can be specified for the interpolator.
3.3 Model output
LoopStructural includes a number of helper functions for evaluating the GeologicalModel on an array of coordinates within the model. The following functions can be called from a GeologicalModel as shown in the code below.

To evaluate the lithology value at a location the function evaluate_model(xyz) returns a numpy array containing the integer ID of the stratigraphy that was specified in the stratigraphic column.

To evaluate the value of a GeologicalFeature at a location within the model the function evaluate_feature_value(feature_name,xyz) returns the value of the scalar field that represents the geological feature.

To evaluate the gradient of a GeologicalFeature the evaluate_feature_gradient(feature_name,xyz) can be called.
Triangulated surfaces can be extracted from a GeologicalFeature within LoopStructural and exported into common mesh formats, e.g. Visualisation ToolKit (.vtk) or Wavefront (.obj). These surfaces can then be imported into external software, e.g. ParaView^{5}.
3.4 Model visualisation
LoopStructural has three different visualisation tools that can be accessed from the LoopStructural.visualisation module:

LavaVuModelViewer. LavaVu (Kaluza et al., 2020) is a visualisation module that provides interactive visualisation. We use LavaVu for visualising triangulated surfaces representing the geological interfaces as well as the scalar field representing the implicit function. The creation and manipulation of LavaVu objects is wrapped by the LavaVuModelViewer class which provides an interface to the GeologicalModel. This is an interactive (and static) 3D visualisation using LavaVu.

MapView. This is a 2D visualisation (cross section, map) using matplotlib (Hunter, 2007) that can create a geological map from the resulting geological model. Input datasets can be plotted drawing the location of contacts and the orientation of the contacts using the strike and dip symbology. The scalar field can be evaluated on the map surface, contours can be drawn or the geological model can be plotted onto the map.

FoldRotationAnglePlotter. This is a visualisation module for producing S plots and Svariogram plots for a folded geological feature. Plotting is handled using matplotlib.
4.1 Implicit surface modelling
In the first example we will demonstrate modelling two synthetic surfaces using the same scalar field within a model volume of ($\mathrm{0.1},\mathrm{0.1},\mathrm{0.1}$) and $\left(\mathrm{5.1},\mathrm{5.1},\mathrm{5.1}\right)$. The observations are two sets of points. The first set forms a surface at points on a regular grid for z=4 and the second set forms a surface at $z=\mathrm{0.2}\cdot \mathrm{sin}\left(x\cdot \mathrm{10}\right)+\mathrm{0.2}\cdot \mathrm{cos}\left(y\right)+\mathrm{0.15}\cdot N\left(\mathrm{0},\mathrm{0.1}\right)$ where N(0,0.1) is a normal distribution with a mean of 0 and standard deviation of 0.1.
In Fig. 7a the data points are shown, and in Fig. 7b, c and d the same surfaces are interpolated using the three default interpolation algorithms in LoopStructural (PLI – piecewise linear interpolator, FDI – finitedifference interpolator and SurfE – radial basis interpolation). The results for the interpolation using PLI and FDI are very similar, as both interpolation algorithms use least squares to fit observations whilst minimising a global regularisation term that effectively minimises the second derivative of the implicit function. This means that the interpolant balances fitting the observations with minimising the roughness of the resulting surfaces. The radial basis interpolation used by SurfE is a direct interpolation approach, which means that the interpolant must fit all of the observations (although a smoothing constraint can be used). In this example, because the surfaces are overconstrained to a highly variable point set the resulting surface is nonmanifold (cannot be unfolded into a flat plane). While this does not necessarily mean the surface is incorrect it is geologically unlikely.
The weighting of the regularisation constraint generally has the biggest impact on the resulting geometry when using the discrete interpolation approaches. In Fig. 8 the regularisation constraint is varied from 0.1 (rougher surface) to 1.5 (smoother surface). Lower regularisation constraints result in surfaces that more closely fit the observations at the cost of a more irregular surface. However, even for the lowest regularisation constraints the surfaces still do not fit every observation. There is no explicit rule for choosing the relative weighting of the regularisation, as it is often dependent on the surfaces being modelled. For example, when modelling a surface where the underlying process causing the variation in the data points is nonstationary, a higher regularisation constraint is appealing as the goal of the modelling is to reproduce the effect of this process. However, if the perturbations are the result of a process we are trying to model (probably a stationary process) then a lower regularisation constraint would be appealing. A smoothing constraint can be added into the radial basis interpolation which aims to increase the smoothness of the resulting surface. The smoothing constraint for datasupported methods adds a buffer to how closely the function must fit the observations. In Fig. 8 increasing regularisation results in smoother surfaces; however, with this approach the fit to both surfaces is impacted, which can be seen by the change in colour of the surface, which represents the local height of the surface.
4.2 Modelling folds: type 3 interference
To demonstrate the timeaware approach for modelling folds we reuse the case study from Laurent et al. (2016). The reference model was generated using Noddy (Jessell and Valenta, 1996) with two folding events forming a type 3 interference pattern:

F1 involves largescale recumbent folding (wavelength: 608 m, amplitude: 435 m, fold axis: N000E/45^{∘}).

F2 involves upright open folding (wavelength: 400 m, amplitude: 30 m).
The structural observations were sampled from a synthetic topographical horizon from three outcrop locations. The axial foliation to F2, S2, is shown in Fig. 9a. The observations of S2 are used to interpolate the major structural feature of the F2 fold frame (Fig. 12a). The axial foliation of F1, S1, is shown in Fig. 9b, and the scalar field value of the interpolated S2 is shown on the map. The fold rotation angle for F2 is calculated by finding the angle between the interpolated S2 field and the folded S1 field and is shown in the S plot for Fig. 10a. The red curve in Fig. 10a is a Fourier series that is automatically fitted to the observations. The wavelength of the fold is estimated by finding the first peak of the S variogram (Fig. 10b). Fold constraints are added into the interpolation algorithm using this curve to define the geometry of the fold along the fold axis, and the average intersection lineation between the S1 foliation and the interpolated S2 field is a proxy for the fold axis. The interpolated scalar field is shown in Fig. 12b. The observations of S0 are shown in Fig. 9c, and the scalar value of the S1 field is shown on the map. The S plot for F1 is shown in Fig. 11a and shows two opposing fold limbs in the data points. The red curve shows the Fourier series that characterises the geometry of the fold along the fold axis and indicates that there are two unobserved fold hinges away from the data points. These constraints are added into the implicit model, and the scalar field is shown in Fig. 12c.
4.3 Integration with map2loop
In the final examples we use map2loop (Jessell et al., 2021) as a preprocessor to generate an input dataset from regional geological survey maps, the national stratigraphic database and a global digital elevation model. map2loop creates a set of augmented data files that can be used to build a geological model in LoopStructural. The class method (GeologicalModel.from_map2loop_directory(m2l_directory, **kwargs)) creates an instance of a GeologicalModel from a root map2loop output directory. We will demonstrate the interface between map2loop and LoopStructural with two case studies (1) from the Flinders Ranges in South Australia and (2) from the Hamersley region in Western Australia. The first case study demonstrates the interface between map2loop and LoopStructural for a large regional model. The second case study shows how the conceptual model used to generate the input dataset can be varied.
The first example uses a small study area from South Australia using the Geological Survey of South Australia's openaccess datasets (GSSA, 2020). The model area covers approximately 85 km by 53 km within the Finders Ranges in South Australia. The stratigraphic units within this area are shown in Fig. 13a, and the outcropping geology is shown in the geological map (Fig. 13b); the patches of the map without any geological units represent shallow Tertiary and Quaternary cover. map2loop extracts basal contacts from the outcropping geological units and estimates the layer thicknesses shown in the stratigraphic column. Within this map area all of the stratigraphic groups share a similar deformation history and area modelled as a single supergroup. The cumulative thickness is estimated for all of the stratigraphic horizons relative to the Pound Subgroup and is used to constrain the value of the implicit function. There are 15 faults within the model area with limited geometrical information constraining only the map trace of the faults. As a result, the faults are assumed to be vertical with a vertical slip direction, and the displacements are estimated from the geometry on the geological map using map2loop. The geometry of the fault can be changed within LoopStructural and map2loop to explore the uncertainty space. The overprinting relationships of the faults are estimated from the geological map using map2loop by analysing the intersection between faults on the geological map. The estimated overprinting relationships are used to constrain the order of the faults in the geological model. The scalar field representing the supergroup is interpolated after the observations of the stratigraphic horizon (contacts and orientation measurements) are unfaulted using the calculated fault displacements. The modelling workflow is all encapsulated in the (GeologicalModel.from_map2loop_directory(m2l_directory, **kwargs)) class method, meaning the geological model can be produced without any user input.
The resulting geological model surfaces are shown in Fig. 14 where the surface represents the base of a stratigraphic group and are coloured using the stratigraphic column (Fig. 13a). The faults in the model are interpolated using a Cartesian grid with 50 000 elements and are interpolated using the finitedifference interpolator, and the interpolation matrix is solved using the pyamg algorithmic multigrid solver (Olson and Schroder, 2018). Stratigraphy is interpolated using a finer mesh with 500 000 elements using the finitedifference interpolator and also using pyamg. Using a workstation laptop with an i7 processor and 32gb of RAM the data processing using map2loop takes approximately 1 min, building the implicit model takes approximately 8 min and the rendering of the surfaces on a ($\mathrm{200}\times \mathrm{200}\times \mathrm{100}$) Cartesian grid takes 3 min. The intersection of the solid geological model and the map surface is shown in Fig. 13c, allowing for a comparison with the input dataset. The geological model has interpolated the geological packages underneath the surficial deposits.
In the second example we use map2loop to process a small area of the Turner Syncline in the Hamersley region in Western Australia using data provided by the Geological Survey of Western Australia (GSWA) (2016). The model area is 12 km × 13 km and includes three faults. The default assumption by map2loop is that the faults are vertical and are purely dip slip, and the hanging wall and displacement are estimated by analysing the map pattern of the faulted units (for more information about this process the reader is referred to Jessell et al., 2021). In this example, we have created 12 realisations of the geological model by rotating the fault slip direction from a vertical vector around the normal to the fault surface. The resulting models are shown in Fig. 14 where the fault slip vector is shown as a pole on the stereonet and the fault plane is shown by a great circle. The results show a wide range in geometries with some structures being unlikely, for example a rotation of 120^{∘} removes the map expression of the western fault. LoopStructural provides an easy interface to allow for the kinematics and conceptual models for different geological features to be incorporated into the modelling workflow.
LoopStructural is the 3D geological modelling module for Loop, a new opensource 3D probabilistic geological and geophysical modelling platform. LoopStructural integrates the relative timing of geological features into the description of the model elements using a timeaware modelling approach where the model is built by adding geological features in the reverse order from which they occur. This is necessary for capturing the complexities of complex structural geometries, for this approach is used for modelling refolded folds (Fig. 12). In a similar way faults are added backwards in time; this means that the displacements of the faults are applied to the model prior to interpolating the faulted surface. As a result, the fault displacements and overprinting relationships are internally consistent. In comparison, where faults are represented using step functions (Calcagno et al., 2008b; de la Varga and Wellmann, 2016) the fault displacements are added into the interpolation of the faulted surfaces using the polynomial trend in the dual cokriging system, meaning the cumulative displacement is determined as the best global fit, rather than incorporating the displacements of individual faults.
LoopStructural provides a flexible opensource implementation of implicit geological modelling algorithms workflows. The motivation behind developing LoopStructural was to create a framework for being able to develop new implicit geological modelling algorithms and tools. LoopStructural has native implementation of piecewise linear interpolation (Caumon et al., 2013; Frank et al., 2007; Mallet, 1992, 2004), including the fold constraints (Grose et al., 2017; Laurent et al., 2016) and a finitedifference interpolator, minimising the second derivative as a regularisation constraint (Irakarama et al., 2018). In Fig. 8 we showed that choosing the regularisation weight is somewhat dependent on the quality of the input dataset. For this reason, varying the regularisation weight and interpolation approach should be a common step in implicit modelling workflows. The current implementation of the piecewise linear interpolation uses a tetrahedral mesh that is derived from a Cartesian grid. A more sophisticated mesh generated from an external mesh generation code could be integrated into LoopStructural by overwriting the tetrahedral mesh class with a custom class. Within the LoopStructural architecture alternative regularisation constraints could easily be incorporated. For example, it is possible to define custom constraints for implementation within the finitedifference scheme; the user simply has to provide a dictionary containing 3D numpy arrays, where each pixel in the array represents the 3D finitedifference mask and a relative weighting. New interpolation schemes can be easily implemented using various levels of inheritance to avoid rewriting boiler plate code. For example, the interface with SurfE capitalises on the objectoriented design of LoopStructural, where the interface between LoopStructural and SurfE was achieved by creating a new class which inherits the components for the base geological interpolation class. Both the piecewise linear interpolator and finitedifference interpolator inherit from a base discrete interpolation class which manages the assembly of the least squares system and the solving of the least squares problem. This objectoriented design allows for the interpolation algorithms to be interchanged and reimplemented without modifying the other aspects of the geological modelling.
A recent focus of 3D modelling research has been to simulate uncertainties by framing the problem as an inverse problem, where the data points are the parameters of the forward model (de la Varga et al., 2019). This allows for additional geological knowledge to be integrated into the model definition such as fault displacement, fault type and fold geometry. Within LoopStructural, we have directly integrated many aspects of the geological knowledge into the interpolation schemes and model definition. The fundamental reasoning behind our approach is that the subjective constraints that are required to capture the geological features with standard implicit algorithms will be one of the greatest sources of uncertainty in the model. By incorporating the geological concepts into the geological modelling algorithms, these conceptual uncertainties can be integrated into a probabilistic definition of the geological model. Currently, LoopStructural does not have a probabilistic interface; however, all parameters relating to geological structures (topological ordering, fold geometries, fault displacement and geometries) are accessible from the GeologicalModel class functions.
In Fig. 14, map2loop (Jessell et al., 2021) generates an augmented dataset from the openaccess geological survey databases (stratigraphic database, DTM, geology shapefiles, structural lines and structural observations). In this example, the total time from data processing to model rendering was approximately 10 min. Using discrete implicit modelling means that the complexity of the model is defined by the resolution of the support, rather than the number of observations. Discrete interpolation involves solving the linear equation $\mathbf{A}\cdot x=\mathit{b}$ where A is a sparse matrix. Different algorithms can be used for solving this linear system. For example, the algorithmic multigrid solver used in the Flinders Ranges model can be substituted for the default conjugate gradient solver increasing the interpolation time. The algebraic solver uses multiple levels of conjugate gradient solvers for coarse grids to approximate the solution to the interpolation problem. The coarse grid solution is then used for improving the solving of the next level. Other approaches to speeding up the linear system could be applied such as using preconditioner for the conjugate gradient solver.
The fault displacement profiles (Fig. 5) define the fault displacement within the fault volume; however, these conceptual profiles are not fitted to the observations. Godefroy et al. (2018b) interpolate a continuous surface without observations within the fault domain and then use particle swarm optimisation to fit the displacement profiles to the unused observations. LoopStructural cannot apply this same approach because all data points are restored (with respect to the fault displacement) prior to interpolating the faulted surfaces. The displacement estimates calculated by map2loop could be used to estimate the displacement profile along the fault trace. The fault displacements could then be optimised using a probabilistic representation of the model geometry parameters. Within the same framework it would be necessary to include the parameterisation of the fault slip vector and fault dip if these are defined by a conceptual model rather than observations. However, defining a specific likelihood function for constraining the fault displacement is challenging and may be specific to the geology in question – e.g. where observations are abundant it would be possible to adopt the technique from Godefroy et al. (2018b) and separate some data from the interpolation; however, when dealing with typical regional scale map sheets most of the observations occur on the surface with limited constraints on the 3D geometry.
In this contribution we have introduced LoopStructural, a new opensource Python library for implicit 3D geological modelling. The key features of LoopStructural are as follows:

implicit 3D geological modelling algorithms using discrete interpolation,

implementation of structural geology of folds and faults using structural frames,

a direct link to map2loop for automated 3D geological modelling,

an objectoriented software design allowing for easy development and extension of the 3D modelling algorithms.
LoopStructural uses a timeaware modelling approach where relative timing between different geological features (folding, faulting and stratigraphy features) allows for complex overprinting relationships to be incorporated into the implicit geological models. Folds and faults are encoded using structural frames, a curvilinear coordinate system that is oriented with the geometry of the major structural feature of the deformational event. Using structural frames, the geometry of folds and faults can be locally characterised similarly to how a structural geologist describes the objects in the field.
A cube is defined by eight vertices and can be referenced inside a Cartesian grid by the indices ijk. We subdivide each cubic element in a Cartesian grid into five tetrahedrons. To ensure that neighbouring tetrahedrons share common faces two masks need to be applied. We apply the even mask when $i+j+k$ is even.
The property is interpolated linearly within the element,
This can be expressed by the values at the nodes (0–3):
Solving this set of linear equations for a, b, c, d depends on the location of the tetrahedron nodes and has to be recalculated for every tetrahedron. This can be simplified by applying a coordinate transformation to a reference tetrahedron (Fig. 2). This simplifies the solution and allows for the interpolation to be described by the barycentric coordinates (c_{0}c_{1}c_{2}c_{3}) of the tetrahedron. The barycentric coordinates can be used as a local coordinate system for the tetrahedron (ξηζ).
Since
The property within the tetrahedron can be interpolated using the four shape functions below:
The gradient of the function within the tetrahedron ∂ϕ_{T} can be found by applying the chain rule between the derivative of the shape function within the barycentric coordinates and the partial derivatives with respect to the natural coordinates and Cartesian coordinates:
The implicit function can be described relative to the eight vertices of the cell using the shape functions (${N}_{\mathrm{0},\mathrm{\dots},\mathrm{7}}$):
The derivative of the function can be calculated by applying the chain rule, in the same way as for the linear tetrahedron, however in this case to all eight shape functions N_{0…7}.
LoopStructural is a free opensource Python library licensed under the Massachusetts Institute of Technology (MIT) license. It is currently hosted on https://github.com/Loop3d/LoopStructural (last access: 15 June 2021) the version associated with the publication can be found https://doi.org/10.5281/zenodo.4649536 (Grose et al., 2021b).
Documentation is available within the package and is hosted on https://loop3d.github.io/LoopStructural (last access: 15 June 2021).
Jupyter notebooks used for the examples in this paper are available on https://github.com/lachlangrose/loopstructural_paper_examples (last access: 15 June 2021) and can also be found https://doi.org/10.5281/zenodo.4677735 (Grose, 2021).
LG, GL and LA contributed to the conceptual design of the project. GL wrote an initial version of the fold interpolation code. LG wrote and maintained the code. MJ was involved with the integration with map2loop and ongoing testing of the code. LG prepared the paper with contributions from all authors for reviewing and editing.
The authors declare that they have no conflict of interest.
This research has performed as part of the Loop project, a OneGeology initiative funded by the Australian Research Council and supported by Monash University; the University of Western Australia; Geoscience Australia; the Geological Surveys of Western Australia, Northern Territory, South Australia and New South Wales; the Research for Integrative Numerical Geology; Universite de Lorraine; RWTH Aachen; Geological Survey of Canada; British Geological Survey; and Bureau de Recherches Géòlogiques et Minières and Auscope. The work has also been supported by the Mineral Exploration Cooperative Research Centre, whose activities are funded by the Australian Government's Cooperative Research Centre Programme. This is MinEx CRC Document 2021/41. The source data used in the final example were provided by Geological Survey of South Australia, Geological Survey of Western Australia and Geoscience Australia.
This research has been supported by the Australian Research Council (grant no. LP170100985).
This paper was edited by Andrew Wickert and reviewed by Italo Goncalves and one anonymous referee.
Ailleres, L., Grose, L., Laurent, G., Armit, R., Jessell, M., Caumon, G., de Kemp, E., and Wellmann, F.: Loop – a new open source platform for 3D geostructural simulations, in: Threedimensional geological mapping workshop, Resources for Future Generations meeting, 16–21 June 2018, Vancouver, BC, Canada, 14–18, 2018.
Calcagno, P., Chilès, J. P., Courrioux, G., and Guillen, A.: Geological modelling from field data and geological knowledge: Part I. Modelling method coupling 3D potentialfield interpolation and geological rules, Phys. Earth Planet. Int., 171, 147–157, https://doi.org/10.1016/j.pepi.2008.06.013, 2008a.
Calcagno, P., Chilès, J. P., Courrioux, G., and Guillen, A.: Geological modelling from field data and geological knowledge: Part I. Modelling method coupling 3D potentialfield interpolation and geological rules, Phys. Earth Planet. Int., 171, 147–157, https://doi.org/10.1016/j.pepi.2008.06.013, 2008b.
Caumon, G., Sword Jr., C. H., and Mallet, J.L.: Constrained modifications of nonmanifold Breps, in: Proceedings of the Symposium on Solid Modeling and Applications, 310–315, available at: https://www.scopus.com/inward/record.uri?eid=2s2.00037703530&partnerID=40&md5=50efe82f0caf397df09cd6d7c9ea392d (last access: 15 June 2021), 2003.
Caumon, G., CollonDrouaillet, P., de Veslud, C., Viseur, S., Sausse, J., Le Carlier De Veslud, C., Viseur, S., and Sausse, J.: Surfacebased 3D modeling of geological structures, Math. Geosci., 41, 927–945, https://doi.org/10.1007/s1100400992442, 2009.
Caumon, G., Gray, G., Antoine, C., and Titeux, M.O.: ThreeDimensional Implicit Stratigraphic Model Building From Remote Sensing Data on Tetrahedral Meshes: Theory and Application to a Regional Model of La Popa Basin, NE Mexico, IEEE T. Geosci. Remote, 51, 1613–1621, https://doi.org/10.1109/TGRS.2012.2207727, 2013.
Cowan, E., Beatson, R., Ross, H., Fright, W., McLennan, T., Evans, T., Carr, J., Lane, R., Bright, D., Gillman, A., Oshust, P., and Titley, M.: Practical implicit geological modelling, 5th Int. Min. Geol. Conf., 8, 89–99, 2003.
de la Varga, M. and Wellmann, J. F.: Structural geologic modeling as an inference problem: A Bayesian perspective, Interpretation, 4, 1–16, https://doi.org/10.1190/INT20150188.1, 2016.
de la Varga, M., Schaaf, A., and Wellmann, F.: GemPy 1.0: opensource stochastic geological modeling and inversion, Geosci. Model Dev., 12, 1–32, https://doi.org/10.5194/gmd1212019, 2019.
ForemanMackey, D., Hogg, D. W., Lang, D., and Goodman, J.: emcee: The MCMC Hammer, Publ. Astron. Soc. Pacific, 125, 306, available at: http://stacks.iop.org/15383873/125/i=925/a=306 (last access: 15 June 2021), 2013.
Fossen, H.: Faults, in Structural Geology, 151–188, Cambridge University Press, Cambridge, 2010.
Frank, T., Tertois, A.L. L., and Mallet, J.L. L.: 3Dreconstruction of complex geological interfaces from irregularly distributed and noisy point data, Comput. Geosci., 33, 932–943, https://doi.org/10.1016/j.cageo.2006.11.014, 2007.
Geological Survey of Western Australia: 1:500 000 State interpreted bedrock geology of Western Australia, 2016.
Godefroy, G., Caumon, G., Ford, M., Laurent, G., and Jackson, C. A.L.: A parametric fault displacement model to introduce kinematic control into modeling faults from sparse data, Interpretation, 6, B1–B13, https://doi.org/10.1190/INT20170059.1, 2018a.
Godefroy, G., Caumon, G., Ford, M., Laurent, G., and Jackson, C. A.L.: A parametric fault displacement model to introduce kinematic control into modeling faults from sparse data, Interpretation, 6, B1–B13, https://doi.org/10.1190/INT20170059.1, 2018b.
Gonçalves, Í. G., Kumaira, S., and Guadagnin, F.: A machine learning approach to the potentialfield method for implicit modeling of geological structures, Comput. Geosci., 103, 173–182, https://doi.org/10.1016/j.cageo.2017.03.015, 2017.
Grose, L.: lachlangrose/loopstructural_paper_examples: LoopStructural 1.0: Time aware geological modelling. (Version 1.0), Zenodo [code], https://doi.org/10.5281/zenodo.4677735, 2021.
Grose, L., Laurent, G., Aillères, L., Armit, R., Jessell, M., and Caumon, G.: Structural data constraints for implicit modeling of folds, J. Struct. Geol., 104, 80–92, https://doi.org/10.1016/j.jsg.2017.09.013, 2017.
Grose, L., Laurent, G., Aillères, L., Armit, R., Jessell, M., and CousinDechenaud, T.: Inversion of structural geology data for fold geometry, J. Geophys. Res.Sol. Ea., 123, 6318–6333, https://doi.org/10.1029/2017JB015177, 2018.
Grose, L., Ailleres, L., Laurent, G., Armit, R., and Jessell, M.: Inversion of geological knowledge for fold geometry, J. Struct. Geol., 119, 1–14, https://doi.org/10.1016/j.jsg.2018.11.010, 2019.
Grose, L., Ailleres, L., Laurent, G., Caumon, G., Jessell, M., and Armit, R.: Realistic modelling of faults in LoopStructural 1.0, Geosci. Model Dev. Discuss. [preprint], https://doi.org/10.5194/gmd2021112, in review, 2021a.
Grose, L., Fazio, V., Thomson, R., and Picavet, V.: Loop3D/LoopStructural: minor features and bug fixes (Version 1.0.91), Zenodo [data set], https://doi.org/10.5281/zenodo.4649536, 2021b.
GSSA: The Department for Energy and Mining, the Government of South Australia, Geoscientific Data, available at: https://energymining.sa.gov.au/minerals/geoscience/geoscientific_data/maps (last access: 17 September 2020), 2020.
Hillier, M. J., Schetselaar, E. M., de Kemp, E. A., and Perron, G.: ThreeDimensional Modelling of Geological Surfaces Using Generalized Interpolation with Radial Basis Functions, Math. Geosci., 46, 931–953, https://doi.org/10.1007/s1100401495403, 2014.
Hunter, J. D.: Matplotlib: A 2D graphics environment, Comput. Sci. Eng., 9, 90–95, https://doi.org/10.1109/MCSE.2007.55, 2007.
Irakarama, M., Laurent, G., Renaudeau, J., and Caumon, G.: Finite Difference Implicit Modeling of Geological Structures, 2018, 1–5, https://doi.org/10.3997/22144609.201800794, 2018.
Jessell, M., Aillères, L., Kemp, E. De, Lindsay, M., Wellmann, F., Hillier, M., Laurent, G., Carmichael, T., and Martin, R.: Next generation 3D geological modelling and inversion, Soc. Econ. Geol. Spec. Publ., 18, 261–272, 2014.
Jessell, M. W.: Noddy: an interactive map creation package, Unpubl. MSc Thesis, Univ. London, available at: http://scholar.google.com/scholar?hl=en&btnG=Search&q=intitle:%22Noddy%22++AN+INTERACTIVE+MAP+CREATION+PACKAGE#0 (last access: 23 June 2014), 1981.
Jessell, M. W. and Valenta, R. K.: Structural geophysics: Integrated structural and geophysical modelling, Comput. Meth. Geosci., 15, 303–324, https://doi.org/10.1016/S1874561X(96)800277, 1996.
Jessell, M. W., Ailleres, L., and de Kemp, E. A.: Towards an integrated inversion of geoscientific data: What price of geology?, Tectonophysics, 490, 294–306, https://doi.org/10.1016/j.tecto.2010.05.020, 2010.
Jessell, M., Ogarko, V., Lindsay, M., Joshi, R., Piechocka, A., Grose, L., de la Varga, M., Ailleres, L., and Pirot, G.: Automated geological map deconstruction for 3D model construction, Geosci. Model Dev. Discuss. [preprint], https://doi.org/10.5194/gmd2020400, in review, 2021.
Kaluza, O., Moresi, L., Mansour, J., Barnes, D. G., and Quenette, S.: lavavu/LavaVu: v1.6.1, Zenodo, https://doi.org/10.5281/zenodo.3955381, 2020.
Lajaunie, C., Courrioux, G., and Manuel, L.: Foliation fields and 3D cartography in geology; principles of a method based on potential interpolation, Math. Geol., 29, 571–584, https://doi.org/10.1007/BF02775087, 1997.
Laurent, G.: Iterative Thickness Regularization of Stratigraphic Layers in Discrete Implicit Modeling, Math. Geosci., 48, 811–833, https://doi.org/10.1007/s110040169637y, 2016.
Laurent, G., Caumon, G., Bouziat, A., and Jessell, M.: A parametric method to model 3D displacements around faults with volumetric vector fields, Tectonophysics, 590, 83–93, https://doi.org/10.1016/j.tecto.2013.01.015, 2013.
Laurent, G., Ailleres, L., Grose, L., Caumon, G., Jessell, M., and Armit, R.: Implicit modeling of folds and overprinting deformation, Earth Planet. Sci. Lett., 456, 26–38, https://doi.org/10.1016/j.epsl.2016.09.040, 2016.
Lisle, R. J., Toimil, N. C., Lisle, R. J., and Toimil, N. C.: Defi ning folds on threedimensional surfaces, GeoScience World, https://doi.org/10.1130/G23207A.1, 2007.
Mallet, J.: Geomodeling, Oxford University Press, New York, NY, USA, 2002.
Mallet, J. L.: Spacetime mathematical framework for sedimentary geology, Math. Geol., 36, 1–32, https://doi.org/10.1023/B:MATG.0000016228.75495.7c, 2004.
Mallet, J.L.: Elements of Mathematical Sedimentary Geology: the GeoChron Model, EAGE, 1–4, https://doi.org/10.3997/9789073834811, 2014.
Mallet, J.L. L.: Discrete smooth interpolation in geometric modelling, Comput. Des., 24, 178–191, https://doi.org/10.1016/00104485(92)90054E, 1992.
Manchuk, J. G. and Deutsch, C. V.: Boundary modeling with moving least squares, Comput. Geosci., 126, 96–106, https://doi.org/10.1016/j.cageo.2019.02.006, 2019.
Massiot, C. and Caumon, G.: Accounting for axial directions, cleavages and folding style during 3D structural modeling, in: 30th Gocad Meeting Proceedings, 30th Gocad meeting, September 2010, Nancy, France, 2010.
Maxelon, M., Renard, P., Courrioux, G., Braendli, M., Mancktelow, N. S., Brändli, M., Mancktelow, N. S., Braendli, M., and Mancktelow, N. S.: A workflow to facilitate threedimensional geometrical modelling of complex polydeformed geological units, Comput. Geosci., 35, 644–658, https://doi.org/10.1016/j.cageo.2008.06.005, 2009.
Moyen, R., Mallet, J.L., Frank, T., Leflon, B., and Royer, J.J.: 3DParameterization of the 3D geological space – The GeoChron model, Proc. Eur. Conf. Math. Oil Recover, ECMOR IX, September, 8, 2004.
Mynatt, I., Bergbauer, S., and Pollard, D. D.: Using differential geometry to describe 3D folds, J. Struct. Geol., 29, 1256–1266, https://doi.org/10.1016/j.jsg.2007.02.006, 2007.
Olson, L. N. and Schroder, J. B.: PyAMG: Algebraic Multigrid Solvers in Python v4.0, available at: https://github.com/pyamg/pyamg (last access: 15 June 2021), 2018.
pandas development team: pandasdev/pandas: Pandas, Zenodo, https://doi.org/10.5281/zenodo.3509134, 2020.
Renaudeau, J., Irakarama, M., Laurent, G., Maerten, F., and Caumon, G.: Implicit Modelling of Geological Structures: a Cartesian Grid Method Handling Discontinuities With Ghost Points, RING Meet. Preceedings, 1, 189–199, https://doi.org/10.2495/be410171, 2018.
Renaudeau, J., Malvesin, E., Maerten, F., and Caumon, G.: Implicit Structural Modeling by Minimization of the Bending Energy with Moving Least Squares Functions, Math. Geosci., 51, 693–724, https://doi.org/10.1007/s11004019097896, 2019.
Van Der Walt, S., Colbert, S. C., and Varoquaux, G.: The NumPy array: a structure for efficient numerical computation, Comput. Sci. Eng., 13, 22–30, 2011.
Virtanen, P., Gommers, R., Oliphant, T. E., Haberland, M., Reddy, T., Cournapeau, D., Burovski, E., Peterson, P., Weckesser, W., Bright, J., van der Walt, S. J., Brett, M., Wilson, J., Jarrod Millman, K., Mayorov, N., Nelson, A. R. J̃., Jones, E., Kern, R., Larson, E., Carey, C. J., Polat, Ilhan, Feng, Y., Moore, E. W., Vand erPlas, J., Laxalde, D., Perktold, J., Cimrman, R., Henriksen, I., Quintero, E. Ã., Harris, C. R., Archibald, A. M., Ribeiro, A. H., Pedregosa, F., van Mulbregt, P., and Contributors, S. 1. 0: SciPy 1.0: Fundamental Algorithms for Scientific Computing in Python, Nat. Methods, 17, 261–272, https://doi.org/10.1038/s4159201906862, 2020.
Wellmann, F. and Caumon, G.: 3D Structural geological models: Concepts, methods, and uncertainties, 1st ed., Adv. Geophys., 59, 1–121, https://doi.org/10.1016/bs.agph.2018.09.001, 2018.
Yang, L., Hyde, D., Grujic, O., Scheidt, C., and Caers, J.: Assessing and visualizing uncertainty of 3D geological surfaces using level sets with stochastic motion, Comput. Geosci., 122, 54–67, https://doi.org/10.1016/j.cageo.2018.10.006, 2019.
https://www.seequent.com/productssolutions/leapfrogsoftware/; last access: 15 June 2021
https://www.intrepidgeophysics.com/product/geomodeller/; last access: 15 June 2021
https://www.pdgm.com/products/skuagocad/; last access: 15 June 2021
https://www.loop3d.org; last access: 15 June 2021
https://www.paraview.org/, last access: 15 June 2021
 Abstract
 Introduction
 Materials and methods
 Implementation in LoopStructural
 Examples
 Discussion
 Conclusions
 Appendix A: Tetrahedral mesh
 Appendix B: Trilinear interpolation in a cubic element
 Code and data availability
 Author contributions
 Competing interests
 Acknowledgements
 Financial support
 Review statement
 References
 Abstract
 Introduction
 Materials and methods
 Implementation in LoopStructural
 Examples
 Discussion
 Conclusions
 Appendix A: Tetrahedral mesh
 Appendix B: Trilinear interpolation in a cubic element
 Code and data availability
 Author contributions
 Competing interests
 Acknowledgements
 Financial support
 Review statement
 References