the Creative Commons Attribution 4.0 License.
the Creative Commons Attribution 4.0 License.
Structural, petrophysical, and geological constraints in potential field inversion using the Tomofastx v1.0 opensource code
Vitaliy Ogarko
Roland Martin
Mark Jessell
Mark Lindsay
The quantitative integration of geophysical measurements with data and information from other disciplines is becoming increasingly important in answering the challenges of undercover imaging and of the modelling of complex areas. We propose a review of the different techniques for the utilisation of structural, petrophysical, and geological information in single physics and joint inversion as implemented in the Tomofastx opensource inversion platform. We detail the range of constraints that can be applied to the inversion of potential field data. The inversion examples we show illustrate a selection of scenarios using a realistic synthetic data set inspired by realworld geological measurements and petrophysical data from the Hamersley region (Western Australia). Using Tomofastx's flexibility, we investigate inversions combining the utilisation of petrophysical, structural, and/or geological constraints while illustrating the utilisation of the Lcurve principle to determine regularisation weights. Our results suggest that the utilisation of geological information to derive disjoint interval bound constraints is the most effective method to recover the true model. It is followed by model smoothness and smallness conditioned by geological uncertainty and crossgradient minimisation.
 Article
(12891 KB)  Fulltext XML
 Companion paper
 BibTeX
 EndNote
Geophysical data provide detailed information about the structure and composition of the Earth's interior otherwise not accessible by direct observation methods, and thus these data play a central role in every major Earth imaging initiative. Applications of geophysical modelling range from deep Earth imaging to study the crust and the mantle to shallow investigations of the subsurface for the exploration of natural resources. Recent integration of different geophysical methods has been recognised as a means to reduce interpretation ambiguity and uncertainty. Further developments introduce uncertainty estimates from other geoscientific disciplines such as geology and petrophysics to produce more reliable and plausible models. Various techniques integrating different geophysical techniques have been developed with the aim to produce more geologically meaningful models, as reviewed by Parsekian et al. (2015), Lelièvre and Farquharson (2016), Moorkamp et al. (2016), Ren and Kalscheuer (2019), and Meju and Gallardo (2016), and several kinds of optimisation for such problems exist (Bijani et al., 2017). In the natural resource exploration sector, the calls of Wegener (1923), Eckhardt (1940), and Nettleton (1949) for the development of comprehensive, thorough multidisciplinary and multiphysical integrated modelling have been acknowledged by the scientific community, and data integration is now an area of active research, to quote André Revil's preface of the compilation of reviews proposed by Moorkamp et al. (2016): “The joint inversion of geophysical data with different sensitivities [...] is also a new frontier”. The integration of multiple physical fields (both geophysical and geological) is particularly relevant for techniques relying on potential field gravity and magnetic data, as these constitute the most commonly acquired and widely available geophysical data types worldwide. The need for integrated techniques is partly due to the interpretation ambiguity of geophysical data and resulting effects of nonuniqueness on inversion. Therefore, effective inversion of potential field data necessitates the utilisation of constraints derived from prior information extracted from geological and petrophysical measurements or other geophysical techniques whenever available.
A number of methods for the introduction of geological and petrophysical prior information into potential field inversion have been developed. For example, when limited geological information is available, the assumption is that spatial variation of density and magnetic susceptibility are colocated. This can be enforced through simple structural constraints encouraging structural correlation between the two models using Gramian constraints (Zhdanov et al., 2012) or the crossgradient technique introduced in Gallardo and Meju (2003). When petrophysical information is available, petrophysical constraints can be applied during inversion to obtain inverted properties that match certain statistics (see techniques introduced by Paasche and Tronicke, 2007; De Stefano et al., 2011; Sun and Li, 2011, 2015, 2016; Lelièvre et al., 2012; CarterMcAuslan et al., 2015; Zhang and Revil, 2015; Giraud et al., 2016, 2017, 2019c; Heincke et al., 2017). Furthermore, when geological data are available, geological models can be derived, and their statistics can be used to derive a candidate model for forward modelling (Guillen et al., 2008; Lindsay et al., 2013; de La Varga et al., 2019), to derive statistical petrophysical constraints for inversion (Giraud et al., 2017, 2019c, d), and to restrict the range of accepted values using spatially varying disjoint bound constraints (Ogarko et al., 2021a) or multinary transformation (Zhdanov and Lin, 2017).
In this paper, we present a versatile inversion platform designed to integrate geological and petrophysical constraints to the inversion of gravity and magnetic data at different scales. We present Tomofastx (“x” for “extendable”) as an opensource inversion platform capable of dealing with varying amounts and qualities of input data. Tomofastx is designed to conduct constrained single physics and joint physics inversions. The need for reproducible research (Peng, 2011) is facilitated by opensource code (Gil et al., 2016), and thus we introduce and detail the different constraints implemented in Tomofastx before providing a realistic synthetic application example using selected functionalities. We illustrate the use of Tomofastx by performing a realistic synthetic study investigating several modelling scenarios typically encountered by practitioners and provide information to get free access to the source code and to run it using the synthetic data shown in this paper. We perform single physics inversion of gravity data and study the influence of prior information using several amounts and types of constraints, and run joint inversion of gravity and magnetic data. The flexibility of Tomofastx is exploited to test the effect of structural constraints combined with petrophysical and geological prior information that are yet to be demonstrated in the published literature. A challenging geological setting is used to examine the capability of crossgradient constraints within the joint inversion method. The mathematical formulations of geophysical problems and solutions are detailed throughout the paper, and sufficient information is provided to allow the reproducibility of this work using Tomofastx.
The remainder of the contribution revolves around two main aspects. We first review the theory behind the inversion algorithm and the different techniques used, with an emphasis on the mathematical formulation of the problem. We then present a synthetic example inspired from a geological model in the Hamersley province (Western Australia), where we investigate two case scenarios. In the first case, we apply structural constraints to an area where geology contradicts the assumption of colocated and correlated density and magnetic susceptibility variations. In the second case, we investigate a novel combination of petrophysical and structural information to constrain a single physics inversion. Finally, we place Tomofastx in the general context of research in geophysical inverse modelling and conclude this article.
2.1 Purpose of Tomofastx
Tomofastx can be used in a wide range of geoscientific scenarios as it can integrate multiple forms of prior information to constrain inversion and follow appropriate inversion strategies. Constraints can be applied through Tikhonovstyle regularisation of the inverse problem (Tikhonov and Arsenin, 1977, 1978). In single physics inversion, these comprise model smallness (also called “model damping”, minimising the norm of the model; see Hoerl and Kennard, 1970) and model smoothness (also called “gradient damping”, minimising the norm of the spatial gradient of the model; see Li and Oldenburg, 1996). For more detailed imaging, petrophysical constraints using Gaussian mixture models (Giraud et al., 2019c), as well as structural constraints (Giraud et al., 2019d; Martin et al., 2020) and multiple interval bound constraints (Ogarko et al., 2021a), can be used depending on the requirements of the study and the information available. In the case of single physics inversion with structural constraints, structural similarity between a selected reference model and the inverted models can be maximised using structural constraints based on crossgradients (Gallardo and Meju, 2003) and locally weighted gradients in the same philosophy as Brown et al. (2012), Wiik et al. (2015), Yan et al. (2017), and Giraud et al. (2019d). Generally speaking, in the joint inversion case, the two models inverted for are linked using the structural constraints just mentioned or petrophysical clustering constraints in the same spirit as CarterMcAuslan et al. (2015), Kamm et al. (2015), Sun and Li (2015, 2017), Zhang and Revil (2015), and Bijani et al. (2017). In addition to the underlying assumptions defining the relationship between the properties that have been jointly inverted, prior information from previous modelling or geological information can be incorporated in inversion using model and structural covariance matrices by assigning weights that vary spatially. In such cases, Tomofastx allows for utilising prior information extensively. Furthermore, Tomofastx allows the use of an arbitrary number of prior and starting models, enabling the investigation of the subsurface in a detailed and stochastically oriented fashion. Tomofastx was initially developed for application to regional or crustal studies (areas covering hundreds of kilometres) and retains this capability. The current version of Tomofastx is now more versatile as development is now directed toward use for exploration targeting and the monitoring of natural resources (kilometric scale).
Lastly, in addition to inversion, Tomofastx offers the possibility to assess uncertainty in the recovered models. The uncertainty assessments include statistical measures gathered from the petrophysical constraints, posterior leastsquares variance matrices of the recovered model (in the least squares with QRfactorisation algorithm – LSQR – sensu Paige and Saunders, 1982; see Sect. 2.5), and the degree of structural similarity between the models (for joint inversion or structurally constrained inversion). From a practical point of view, associated with the inversion algorithm is a user manual covering most functionalities and a reduced 2D Python notebook illustrating concepts (see Sect. 7 for more information) that can be used for testing or educational purposes. A summary of the inverse modelling workflow of Tomofastx is shown in Fig. 1.
2.2 General design
The implementation we present extends the original inversion platform “Tomofast” (Martin et al., 2013, 2018). Tomofastx is an extended implementation proposed and modified by Martin et al. (2018), Giraud et al. (2019c, d), Martin et al. (2020), and Ogarko et al. (2021a). Tomofastx follows the objectoriented Fortran 2008 standard and utilises classes designed to account for the mathematics of the problem. This introduces enhanced modularity based on the implementation of specific modules that can be called depending on the type of inversion required. The utilisation of classes in Tomofastx also eases the addition of new functionalities and permits the reduction of software complexity while maintaining flexibility. Our implementation uses an indexed hexahedral solid body mesh, giving the possibility to adapt the problem geometry, allowing the regularisation of the problem in the same fashion as Wiik et al. (2015) or to perform overburden stripping. By default, the sensitivity matrix to geophysical measurements is stored in a sparse format (using the compressed sparse row format) to reduce memory consumption and for fast matrix vector multiplication.
Attention has also been given to computational aspects. The only dependency of Tomofastx is the message passing interface (MPI) libraries, which eases installation and usage. This allows optimal usage of multiCPU systems regardless of the number of CPUs. Parallelisation is made on the model cells using a domain decomposition approach in space; i.e. the model is divided into nearly equal, nonoverlapping contiguous parts distributed among the CPUs, hence enforcing minimum load imbalance. Consequently, the code is fully scalable as the maximum number of CPUs is not limited by the number of receivers or measured data points. For large 3D models, Tomofastx can run on hundreds of CPUs for a typical problem with 10^{5}–10^{6} model cells and 10^{3}–10^{4} data points. Parallel efficiency tests reveal excellent scalability and speed performance provided that the portions of the model sent to the CPUs are of sufficient size. In the current implementation, the optimum number of elements per CPU is 512. Interested readers can refer to Appendix D for more information.
2.3 Cost function
2.3.1 General formulation
Tomofastx inversions rely on optimisation of a leastsquares cost function and are optimised iteratively. The choice of a leastsquares framework was motivated by flexibility in the number of constraints and forms of prior information used in the optimisation process.
The objective function θ is derived from the log likelihood of a probabilistic density function Θ (see Tarantola, 2005, chaps. 1 and 3, for details). In the case of geophysical inversion, it is representative of the “degree of knowledge that we have about the values of the parameters of our system” (Tarantola and Valette, 1982), as summarised below. Let us first define Θ as follows:
where Θ_{d}(d,m) is the density function over the geophysical data d that model m represents, and Θ_{i}(m) is the density function for the ith type of prior information available (the “constraints” set).
On the premise that Gaussian probability densities approximate the problem appropriately, Θ_{d}(d,m) can be expressed as follows:
where g(m) is the forward data set calculated by the forward operator g and the matrix W_{d} weights the data points. Similarly, we formulate the different Θ_{i∈constraints} as follows:
where f is a function of the model and prior information. W_{i} is a covariance matrix weighting of f(m), and α_{i} contains positive scalars that are introduced to adjust the relative importance of the ith constraint term. W_{i} and α_{i} are derived from prior information or set according to study objectives.
From Eq. (3), it is clear that maximising Θ(d,m) is equivalent to minimising its negative logarithm, θ(d,m), defined as follows:
which corresponds to the general formulation of a cost function as formalised in the leastsquares framework; α_{d} is a weight controlling the importance of the corresponding data term (i.e. gravity or magnetic) in the overall cost function.
2.3.2 Definition of regularisation constraints
Adapting the formulation of the second term of Eq. (4) to the different types of prior information that we can accommodate leads to the following aggregate cost function:
where the different terms following the data misfit term $\Vert {\mathbf{W}}_{\mathrm{d}}(\mathit{d}g(\mathit{m}\left)\right){\Vert}_{\mathrm{2}}^{\mathrm{2}}$ constitute constraints for the inversion of geophysical data acting as regularisation in the fashion of Tikhonov regularisation (Tikhonov and Arsenin, 1977). In Eqs. (2)–(5), W_{d} represents geophysical data weighting. Generally, W_{d} should be the data covariance. It is calculated by Tomofastx as follows:
where I_{w} is a diagonal matrix equal to the identity matrix in single domain inversion or giving the weight of one data misfit term (i.e. gravity data) against the other (i.e. magnetic data) in joint inversion; d_{i} is the ith datum. By convention, we fix I_{w} to the identity matrix I for gravity inversion and use I_{w}=Iα_{mag} in joint inversion. In such cases, α_{mag} is a strictly positive scalar.
The main terms of the cost function are defined below. The other individual terms are defined in the next subsection and summarised in Appendix B:

m_{pr} refers to the prior model;

$\Vert {\mathbf{W}}_{\mathrm{m}}(\mathit{m}{\mathit{m}}_{\mathrm{pr}}){\Vert}_{p}^{\mathrm{2}}$ represents the smallness term (detailed in Sect. 2.4.1);

subscript p refers to the L_{p} norm (here taken such that $\mathrm{1}<p\le \mathrm{2}$);

∇ is the operator calculating the spatial gradient of the model;

$\Vert {\mathbf{W}}_{\mathrm{g}}\mathrm{\nabla}\mathit{m}{\Vert}_{\mathrm{2}}^{\mathrm{2}}$ represents the smoothness constraint on the model (detailed in Sect. 2.4.2);

$\Vert {\mathbf{W}}_{\mathrm{x}}(\mathrm{\nabla}{\mathit{m}}^{\left(\mathrm{1}\right)}\times \mathrm{\nabla}{\mathit{m}}^{\left(\mathrm{2}\right)}){\Vert}_{\mathrm{2}}^{\mathrm{2}}$ represents crossgradient constraints between the models m^{(1)} and m^{(2)} (detailed in Sect. 2.4.3);

$\Vert {\mathbf{W}}_{\text{pe}}\mathrm{P}\left(\mathit{m}\right){\Vert}_{\mathrm{2}}^{\mathrm{2}}$ represents petrophysics term (clustering constraint), into which P(m) represents petrophysical distributions used to impose petrophysical constraints (detailed in Sect. 2.4.4);

$\Vert {\mathbf{W}}_{\mathrm{a}}(\mathit{m}\mathit{z}+\mathit{u}){\Vert}_{\mathrm{2}}^{\mathrm{2}}$ is the formulation of the multiple bound constraints using the alternating direction of multipliers method (ADMM, detailed in Sect. 2.4.5).
In the case of joint inversion, the vectors defined above are concatenated and the matrices are expanded as follows:
where T denotes the transpose operator. For the more illustrative purposes of the joint inversion, here we take the gravity and magnetic joint inversion example, where G and M refer to gravity and magnetic problems, respectively.
In the case of single domain inversion, m^{(1)} is the model inverted for and is equal to m^{G} or m^{M} depending on the type of geophysical data inverted, and m^{(2)} is a reference model that can be used to constrain inversion from a structural point of view (see Sect. 2.4.3, and 4.3 for the theory and an example of utilisation, respectively).
In Eqs. (5)–(7), subscript m, g, x, pe, and a refer to model, gradient, crossgradient, petrophysics, and ADMM bound constraints, respectively. The different α terms are tradeoff parameters that control the importance given to the different terms during the inversion. These terms therefore play an important role in inversion and need to be determined carefully (see Sect. 4.1 and 4.2 for more details).
As mentioned above, the crossgradient constraints can be applied either to joint or single domain inversion. In the case of ADMM constraints, single or multiple bounds can be applied to define bounds for inverted model values. Such bound constraints can vary in space and be made of an arbitrary number of intervals, regardless of whether they are disjointed or not (see Sects. 2.4.5 and 4.5). Qualitatively, the case with multiple disjoint intervals can be interpreted as applying a dynamic smallness constraint term.
In Tomofastx, we introduce prior information in the diagonal variance matrices W_{i} such that they are no longer homogenous and can vary in space. Note that in the implementation of gravity and magnetic inversion, g(m)=Sm, with S the sensitivity matrix relating to measured geophysical data and corresponding recovered physical property (see Appendix C for details about their calculation). Introducing the sensitivity matrix S_{G} and S_{M} for gravity and magnetic data, respectively, we obtain the following equation:
For reference, the terms defined or used here are summarised in Appendix B. Tomofastx uses the least squares with QRfactorisation (LSQR) algorithm (Paige and Saunders, 1982) to solve the leastsquares problem. The full matrix formulation of the problem and the related system of equations are provided in Appendix E.
Generally, not all of the terms in Eq. (5) are used during a single inversion. The activation of selected terms from the cost function (setting α_{i}>0 and nonnull W_{i}) depends on the information available or on the requirements of the modelling to be performed. For example, a term not used during inversion has the corresponding weighting simply set to 0 (the corresponding matrix W_{i} is set to 0). Conversely, setting a specific weight to a relatively large value leads to the corresponding constraint to dominate the other terms. Such practice is typically used in sensitivity analysis to examine the effect of incorrectly assigned extreme weighting values on the inversion by providing an example to aid detection of this unintended situation.
In the following subsection, we detail the implementation of the different terms. The terms are introduced and detailed following the order they appear in Eq. (5).
2.4 Detailed formulation of constraints for inversion
In this section, we introduce the mathematical formulation of constraints applied during inversion. Throughout this paper, “geological information” relates to information extracted from probabilistic geological structural modelling. Petrophysical information relates to the statistics of the values inverted for (density contrast and magnetic susceptibility).
2.4.1 Smallness term
We repeat the smallness term as follows:
The smallness term corresponds to the ridge regression constraint, i.e. the smallness term of Hoerl and Kennard (1970). To simplify the problem, the covariance matrix W_{m} is assumed to be a diagonal matrix. In Tomofastx, it is used to adjust the strength of the constraint either globally (i.e W_{m}=I) or locally (i.e. the elements of W_{m} may vary from one cell to another). In the second case, W_{m} can be determined using prior information such as uncertainty from geological modelling or models and structural or statistical information derived from other geophysical techniques (e.g. seismic attributes and probabilistic results from magnetotellurics).
2.4.2 Smoothness term
The smoothness model term (Li and Oldenburg, 1996) is a total variation (TV)like regularisation term based on an original idea of Rudin et al. (1992). It constrains the degree of structural complexity allowed in the inverted model. We repeat the term as follows:
The covariance matrix W_{g} modulates the importance of the term by assigning the weights to each cell. For the sake of simplicity, the matrix W_{g} is commonly assumed to be a diagonal matrix. It is commonly set as the identity matrix (W_{g}=I), but several works vary the values in space accordingly with prior information. For instance, Brown et al. (2012) and Yan et al. (2017) use seismic models to calculate such weights for the inversion of electromagnetic data, and Giraud et al. (2019a), who present an application case using Tomofastx, invert gravity data using geological uncertainty information to calculate W_{g}. In Tomofastx, it can be set either globally (i.e. W_{g}=I) or locally (i.e. the elements of W_{g} may vary from one cell to another).
2.4.3 Crossgradient
The crossgradient constraints were introduced as a means to link two models that are inverted jointly by encouraging structural correlation between them (Gallardo and Meju, 2004). We refer the reader to Meju and Gallardo (2016) for a review of applications using this technique. We repeat the term below:
The matrix W_{x} modulates the importance of the term by assigning the weights to each cell. In previous works, it is always (to the best our knowledge) set as the identity matrix (W_{x}=I), with the exception of Rashidifard et al. (2020), who define such weights using seismic reflectivity and apply this approach to single physics inversion of gravity data constrained by fixed seismic velocity. In Tomofastx, three finitedifference numerical schemes can be chosen to calculate the crossgradient derivatives: forward, centred, and mixed. In what follows, we use a “mixed” finitedifference scheme, where inversion iterations with an odd number use a forward scheme and those with even numbers use a backward scheme (e.g. iteration 3 will use a forward scheme and iteration 4 a backward scheme). This scheme was chosen as it reduces the influence of the border effects of both the forward and backward schemes on the inverted model.
2.4.4 Statistical petrophysical constraints
One strategy to enforce the petrophysical constraints using statistics from petrophysical measurements is performed by encouraging the statistics of the recovered model to match that of a statistical model derived either from measurements made from the study area or literature values. In the current implementation of Tomofastx, a mixture model representing the expected statistics of the modelled rock units is used. We use a Gaussian mixture model to approximate the petrophysical properties of the lithologies in the studied area. In the mixture model, the weight of each Gaussian can be set in the input. We suggest using the probability of the corresponding rock unit when this information is available. The mismatch between the statistics of the recovered model and the mixture model is minimised in the optimisation framework following the same procedure described in Giraud et al. (2018, 2019b).
In the ith model cell, the likelihood term P(m_{i}) of model cell m_{i} is calculated as follows for the kth lithology:
where
𝒩 symbolises the normal distribution, and n_{f} is the total number of rock formations observed in the modelled area.
In practice, an expectation maximisation algorithm (McLachlan and Peel, 2000) can be used to estimate the mean μ_{k} and standard deviation σ_{k} of the petrophysical measurements.
In Eqs. (12)–(14), ω_{k} is the weight assigned to the Gaussian distribution representative of the petrophysics of the kth lithology in the mixture. In Eq. (14a), the weight ω_{k} assigned to each lithology is constant across the model, while in Eq. (14b) the weight ψ_{k,i} is derived from information derived from another modelling technique (geology, seismic, electromagnetic methods, etc.) and varies spatially.
We note that a small number of Gaussian distributions might not be suitable to approximate certain types of distributions like bimodal (magnetic susceptibility) or lognormal (electrical resistivity) distributions. However, we point out that increasing the quality of such an approximation depends on the number of Gaussian distributions used for approximation (McLachlan and Peel, 2000).
2.4.5 Disjoint bound constraints using the ADMM algorithm
The objective of the disjoint bound constraints is to optimise Eq. (5) while ensuring that in every model cell ${m}_{\mathrm{1}\le i\le {n}_{\mathrm{m}}}$ the inverted value lies within the prescribed bounds such that m_{i}∈B_{i}, defined as follows (Ogarko et al., 2021a):
where a_{i,l} and b_{i,l} are the lower and upper bounds for the ith model cell and l is the lithology index; L_{i}≤n_{f} is the total number of bounds allowed for the considered cell, corresponding to the number of distinct rock units allowed by such constraints. During inversion, such multiple bound constraints on the physical property values inverted for are gradually enforced using the ADMM algorithm. Implementation details are beyond the scope of this paper, but more information is provided in Appendix E, and we refer the reader to Ogarko et al. (2021a) for details. Details about the general mathematical formulation of the ADMM algorithm can be found in Dykstra (1983), chap. 7 in Bertsekas (2016), and in Boyd et al. (2011).
Note that the application of the ADMM bound constraints can be interpreted as being analogous to clustering constraints where (taking the example of the kth modelcell) the following conditions are met:

the centre values depend on both the current model m at any given integration and petrophysical information defining a and b;

the weight assigned to each centre value changes from one iteration to the next as a function of the distance between m_{k} and the closest bound, and the number of iterations m_{k} has remained outside B_{k}.
2.4.6 Depth weighting and data weighting
To balance the decreasing sensitivity of potential field data with the depth of the considered model cell, Tomofastx offers the possibility for the calculation of the depthweighting operator. The first one, which we use in this paper, utilises the integrated sensitivities technique following Portniaguine and Zhdanov (2002). For each model cell i, a weight D_{ii} is introduced:
The second option relies on the application of an inverse depthweighting power law function following Li and Oldenburg (1998) and Li and Chouteau (1998) for gravity and Li and Oldenburg (1996) for magnetic data:
where z_{i} is the depth of the ith model cell and ε is introduced to ensure numerical stability, such that z≫ε; the value of β depends on the type of data considered (gravity or magnetic). For more details about the use of depth weighting and selection of values of β, the reader is referred to the references provided in this subsection. The application of depth weighting as a preconditioner to the matrix system of equation solved for during inversion is shown in Appendix E.
2.5 Posterior uncertainty metrics
Uncertainty information is an important building block of modelling and a critical aspect of decision making (Scheidt et al., 2018). When available, uncertainty information can be communicated and used in subsequent modelling or for decision making (see examples of Ogarko et al., 2021a, who use uncertainty information in the model recovered by another method as input to their modelling using Tomofastx). Tomofastx allows the calculation of metrics reflecting the degree of uncertainty in the models before and after inversion. It allows monitoring the evolution of the different terms of the cost function during inversion. Tomofastx also calculates uncertainty metrics that are specific to the kind of constraints used in inversion:

the posterior covariance matrix of model m as estimated by the LSQR algorithm (Paige and Saunders, 1982, p. 53, for details and Sect. A1.1 for a brief introduction),

the value of the crossgradient in each cell,

the individual 𝒩_{k} values (Eq. 12) of the different Gaussians making up the Gaussian mixture used to define the petrophysical constraints.
The implementation of this series of indicators was performed with the intent to provide metrics for posterior analysis in detailed case studies. More information about these posterior uncertainty indicators is provided in Appendix A, which details functionalities of Tomofastx not explored here.
In this section, we introduce how the data used for synthetic modelling were derived, and we present examples of using prior information derived from geological modelling. The process of simulating a realistic field case study is described with the design of the numerical experiment.
3.1 Geological framework
The original geological model is based on a region in the Hamersley province (Western Australia). It was built using the map2loop algorithm (Jessell et al., 2021b) to parse the raw data and the Geomodeller^{®} implicit modelling engine for geological interpolation (Calcagno et al., 2008; Guillen et al., 2008) to model the contacts, stratigraphy, and orientation data measurement in the area (see the geographical location in Fig. 2). Data used to generate the model comprise the 2016 1:500 000 Interpreted Bedrock Geology map of Western Australia (https://catalogue.data.wa.gov.au/dataset/1500000stateinterpretedbedrockgeologydmirs016, last access: 2 December 2020) and the WAROX outcrop database (https://catalogue.nla.gov.au/Record/7429427, last access: 2 December 2020). Geological modelling was assisted by interpretation of the magnetic anomaly grid compilations at 80 m and the 400 m gravity anomaly grid from the Geological Survey of Western Australia (https://www.dmp.wa.gov.au/GeologicalSurvey/Regionalgeophysicalsuveydata1392.aspx, last access: 2 December 2020). More information about data availability is provided in Sect. 7.
In what follows, we use an adapted version of the original structural geological framework of the selected region by increasing the vertical dimensions of the model cells and assuming a flat topography. The resulting reference geological model used to generate the physical properties for geophysical modelling measurements is shown in Fig. 2 in terms of its geological units.
In addition to the modification of the structural model, we make adjustments to the original density values derived from field petrophysical measurements by reducing the differences between the density contrasts of different rock units. By doing so, we increase the interpretation ambiguity of inversion results and decrease the differentiability of the different rock units. The same procedure is applied to magnetic susceptibility to make accurate imaging using inversion more challenging. The threedimensional (3D) density contrast and magnetic susceptibility models used to generate the gravity and magnetic data are shown in Fig. 3.
3.2 Geophysical simulations and model discretisation
The core 3D model is discretised into ${N}_{\mathrm{x}}\times {N}_{y}\times {N}_{z}=\mathrm{103}\times \mathrm{113}\times \mathrm{33}$ cells of dimensions equal to $\mathrm{999}\times \mathrm{996}\times \mathrm{745}$ m^{3}. For both gravity and magnetics, we generate one geophysical measurement per cell along the horizontal axis, leading to ${N}_{\mathrm{x}}\times {N}_{y}=\mathrm{11}\phantom{\rule{0.125em}{0ex}}\mathrm{639}$ data points for each method, and add 10 padding cells in each horizontal direction to limit numerical border effects in the forward calculation, leading to a total of $\mathrm{123}\times \mathrm{133}\times \mathrm{33}=\mathrm{539}\phantom{\rule{0.125em}{0ex}}\mathrm{847}$ model cells. We simulate a ground gravity survey by locating the measurements 1 m above ground level, and aeromagnetic data acquired by a fixedwing aircraft flying 100 m above surface. To test the robustness of our inversion code to noise content in the data, the geophysical data inverted here are contaminated by noise.
The noise component was generated as follows. For each gravity measurement, we first add a perturbation value randomly sampled from the standard normal distribution of the whole data set multiplied by 9 % of the measurement's amplitude. We then add a second perturbation value randomly sampled from the standard normal distribution with an amplitude of 3 mGal (2 % of the dynamical range). These values were derived manually to obtain a realistic noise contamination. To simulate smallscale spatial coherence in the noise generated in this fashion, we then apply a twodimensional Gaussian filter to the 2D noise map obtained from the previous step. We then apply a twodimensional median filter to the resulting noisecontaminated gravity data to simulate denoising. For magnetic data, we apply the same procedure, using 12.5 % of the measurement's amplitude for the first step and 15 nT (1 % of the dynamical range) for the second step. Similarly to gravity data, these values were derived manually; no levelling noise was simulated. For comparison, the noisefree and contaminated synthetic measurements are shown in Fig. 4. The resulting noise standard deviation σ_{noise} for gravity and magnetic data are equal to 1.2 mGal and 8.5 nT, respectively.
The gravity data modelled here correspond to the complete Bouguer anomaly. Magnetic data are simulated using the magnetic strength of the Hamersley province (53 011 nT, which approximates the International Geomagnetic Reference Field in the area) reduced to the pole.
To complete the 3D modelling procedure, a series of 100 structural geological models are generated using Monte Carlo perturbations of the geological measurements (foliation and contact points between geological units) constraining the geological structures. This was performed using the Monte Carlo Uncertainty Estimator (MCUE) technique of PakyuzCharrier et al. (2018, 2019). The result is an ensemble of models that all fit the geological measurements within a given set of prior uncertainty parameters. The ensemble is thus assumed to represent the geological model space, rather than just a single “bestguess” model. Probabilities for the occurrence of different rock units can be calculated from the ensemble and used to constrain geophysical inversion (see examples of Giraud et al., 2017, 2019a; Ogarko et al., 2021a). More specifically, MCUE is useful to obtain the probability ψ_{i,l} of occurrence of the different lithologies l for every ith model cell and to calculate the related uncertainty indicators (Sect. 3.3). Detailing the probabilistic geological modelling procedure and analysing the results in 3D is beyond the scope of this paper and interested readers are referred to Lindsay et al. (2012), PakyuzCharrier et al. (2018), Wellmann and Caumon (2018), and references therein.
In this contribution, we simulate a case study where modelling is carried out along the 2D profile materialised by the black line in Figs. 3 and 4, extracted from the 3D modelling framework as detailed in the next subsection.
3.3 2D model simulation in a 3D world
As mentioned above, we perform the inversion of geophysical data along a 2D profile for simplicity and to simulate the challenging case of 2D data acquired in a 3D geological setting, in a part of the model where subhorizontal or gently dipping features can be observed. The philosophy of the numerical study presented here is summarised in Fig. 5.
The 2D geological Sect. considered is shown in Fig. 6 (the black line marked in Figs. 3 and 4). Geological certainty is estimated using a measure of the dispersion away from the perfectly uninformed case where the all rock units are equiprobable. In each model cell, this measure, which we write as ${\mathit{\sigma}}_{\mathit{\psi}}^{\prime}$, is calculated as a function of the standard deviation σ_{ψ} of the probability ψ of observing the different rock units as follows:
where card is the geological cardinality of the model. It is equal to the number of possible rock units observed in one location across the entire ensemble. From Eq. (18), ${\mathit{\sigma}}_{\mathit{\psi}}^{\prime}$ is maximum where rock units are well constrained and minimum where the model is the most uncertain. This geological certainty metric is shown in Fig. 6 for the 2D section considered in this example.
The probabilities of observation of the different lithologies are shown in Fig. 7. Note that for the purpose of the tests we perform on gravity data inversion, we reduce the set of probabilities by grouping rock units into fictitious units with the same density contrasts as single rock units. This reduces the number of rock units to six units that can be distinguished by gravity inversion, as several units may be assigned the same density contrast.
The geophysical data we use for inversion are extracted along the line marked in Figs. 3 and 4. The geophysical data and reference (true) petrophysical model extracted in this fashion are shown in Fig. 8. Care was taken not to use the same mesh for both generating the synthetic data set and its inverse modelling.
To inverse model the data shown in Fig. 8, we generate a mesh centred on the profile (oriented along the y direction) and add padding to either side and the northern and southern extremities. The resulting model comprises ${n}_{\mathrm{x}}\times {n}_{y}\times {n}_{z}=\mathrm{13}\times \mathrm{133}\times \mathrm{33}$ cells of dimensions equal to $\mathrm{2998}\times \mathrm{996}\times \mathrm{745}$ m^{3}. Note that we increased the model cell size in the direction perpendicular to the profile. The gravity and magnetic data sets along the profile each comprise 113 data points evenly distributed along the line.
While we focus on a 2D section extracted from a 3D model presented here (see location in Figs. 3 and 4), the 3D model and the associated gravity and magnetic data sets shown here are made publicly available (see Sect. 7).
In the examples shown below, we first perform single domain and joint (multiple domain) inversion (using the crossgradient constraint) assuming identity matrices for W_{m}, W_{g}, and W_{x}. We then investigate the influence of prior information on single domain inversion by combining structural and petrophysical information in the case of gravity inversion. The combination of petrophysical and structural constraints derived from geology is tested. The intention is to address knowledge gaps in the literature that describe the effects of parameterisation of such constraints.
4.1 Experimental protocol
It is necessary to determine the appropriate weights α assigned to the terms defining the constraints applied during inversion to optimise the cost function in Eq. (5). The α values that define the weights of the different terms in the cost function constitute hyperparameters of the inverse problem. Appropriate estimation of these hyperparameters is necessary to approximate the optimum value of the global misfit function. To this end, we use the Lcurve principle (Hansen and O'Leary, 1993; Hansen and Johnston, 2001; Santos and Bassrei, 2007) for each of the cases presented below. We perform series of inversions, sampling α values spanning the plausible range of potential choices using a heuristic approach.
When two constraint terms are used in inversion (i.e. with α>0), we extend the Lcurve approach to the twoparameter cases. In such cases, the optimum values for the α weights are determined by applying the Lcurve criterion using Lsurfaces (or elbow surface) instead of Lcurves (Belge et al., 2002) (we note that the Lcurves as plotted here can also be referred to as “Tikhonov curves” in the case where data misfit is plotted as a function of regularisation value). The optimum value for the α weight of the two constraint terms is therefore obtained by identification of the inflection point of the surface made up of the variations of the data misfit as a function of the weights under consideration. We chose this approach for its simplicity and note that there exist other techniques that use an automated process, such as the generalised crossvalidation technique (Craven and Wahba, 1978). We refer the reader to Farquharson and Oldenburg (2004) for a general introduction and Giraud et al. (2019b) and Martin et al. (2020) for an application of this principle to inversions using Tomofastx. The role the Lsurface analysis plays in the synthetic case presented here is reminded in the workflow shown in Fig. 5. In our analysis, we set the objective value for the data misfit $\Vert {\mathbf{W}}_{\mathrm{d}}(\mathit{d}g(\mathit{m}\left)\right){\Vert}_{\mathrm{2}}^{\mathrm{2}}$ to be equal to the objective data misfit ${\mathrm{\Theta}}_{\mathrm{d}}^{\text{obj}}(\mathit{d},\mathit{m})$, defined as follows:
so that the data is reproduced with a level of error superior or equal to the estimated noise level of the data. Here, this leads to ${\mathrm{\Theta}}_{\mathrm{d}}^{\text{obj}}=\mathrm{5.01}\times {\mathrm{10}}^{\mathrm{4}}$ for gravity inversion and to ${\mathrm{\Theta}}_{\mathrm{d}}^{\text{obj}}=\mathrm{1.55}\times {\mathrm{10}}^{\mathrm{4}}$ for magnetic data inversion.
For the sake of consistency in our study of the influence of constraints on inversion, we set m_{pr}=0 kg m^{−3} for gravity data inversion and m_{pr}=0 SI for magnetic data inversion.
4.2 Homogenously constrained potential field inversions
We first perform single physics inversion following the common strategy of constraining the model using smallness and smoothness constraints. Obtaining a good approximation of the optimum values of these parameters gives insights into the numerical structure of the problem. It constitutes valuable knowledge when using other kinds of constraints, and we consider it good practice to run such inversion prior to using more advanced constraints. Here, the first α parameters to determine are α_{m} and α_{g}, for both gravity and magnetic data inversion, assuming identity W_{m} and W_{g} matrices so that the constraints are applied homogenously over the entire model.
We generate grids in the (α_{m},α_{g}) plane using ${\mathit{\alpha}}_{\mathrm{m}}\in [{\mathrm{10}}^{\mathrm{8}},{\mathrm{10}}^{\mathrm{6}}]$ and ${\mathit{\alpha}}_{\mathrm{g}}\in [{\mathrm{10}}^{\mathrm{6}},{\mathrm{10}}^{\mathrm{3}}]$ for gravity inversion, and ${\mathit{\alpha}}_{\mathrm{m}}\in [{\mathrm{10}}^{\mathrm{3}},{\mathrm{10}}^{\mathrm{5}}]$ and ${\mathit{\alpha}}_{\mathrm{g}}\in [{\mathrm{10}}^{\mathrm{3}},{\mathrm{10}}^{\mathrm{8}}]$ for magnetic data inversion. These ranges were determined empirically and assumed to comprise the optimums. In this subsection, all matrices W in Eq. (5) are set as the identity matrix.
For accurate estimation, the (α_{m}, α_{g}) values are sampled more finely closer to the estimated optimum values. The resulting Lsurfaces are shown in Fig. 9, where the vicinity of the optimum value of (α_{m}, α_{g}) is shown with a green dot. From these values, we estimate the optimum values of (α_{m}, α_{g}) reported in Table 1.
The models corresponding to values in Table 1 are shown in Fig. 10.
The values of α_{m} and α_{g} obtained for such constraints can be used as a starting point in subsequent inversions to understand the influence of prior information when varying amounts and types of prior information are available about the structure of the subsurface or its petrophysics. For instance, in what follows we will investigate the utilisation of geological information to define W_{m} and W_{g} (Eqs. 9 and 10, respectively) and see how it can combined with petrophysical data to define B (Eq. 15) (see the following subsection where we use global and structural and/or petrophysical information). In the case of structural constraints relying on the spatial derivatives of model values (crossgradient values or local smoothness), the value of α_{m} may be kept constant and while the other α parameters (α_{g} or α_{x}) are adjusted. Conversely, α_{g} may be kept and α_{m} set to 0 for the utilisation of petrophysical constraints acting on the model values themselves instead of the spatial derivatives (ADMM or statistical petrophysical constraints). Here, we restrict our analysis to two α values being strictly superior to zero, thereby accounting for prior information in up to two constraints terms in the definition of the regularisation term in Eq. (5).
4.3 Joint inversion using the crossgradient constraint
We start from the previous step to perform joint inversion using the crossgradient constraint. Keeping the α_{m} weight constant and equal to the values determined from single domain inversion, it remains necessary to estimate the optimum values of the crossgradient constraint weight, α_{x}, and the relative importance given to the gravity and magnetic data misfit terms (setting α^{G}=1, it remains to determine α^{M}). We therefore investigate values in the (α_{x},α^{M}) plane, which we sample in the same fashion as in the previous subsection. The resulting surfaces are shown in Fig. 11.
In contrast to the single physics inversion shown in Fig. 9, it appears from Fig. 11 that the two hyperparameters to be determined here, α_{x} and α^{M}, influence the inversion differently. While the contour levels of the magnetic data misfit show a linear trend in the (α_{x},α^{M}) plane, it is clearly nonlinear in the case of gravity data misfit. This difference might be explained by the fact that the crossgradient is a secondorder regularisation (product of two spatial derivatives of model values) linking two models that are otherwise decoupled. In addition, this suggests that in cases differing from this one, the hyperparameter selection may be nonunique. Nevertheless, the value of the optimum value is unambiguous in our case and can be determined easily. From Fig. 11 we obtain $({\mathit{\alpha}}_{\text{x}},{\mathit{\alpha}}_{\text{mag}})=(\mathrm{1.995}\times {\mathrm{10}}^{\mathrm{4}}$, $\mathrm{2.57}\times {\mathrm{10}}^{\mathrm{5}}$). The corresponding inversion results are shown in Fig. 12.
Compared to Fig. 12, we observe that the application of the crossgradient constraint leads to adjustments of the model ensuring more structural consistency between density contrast and magnetic susceptibility, illustrating the applicability of the approach presented here. Also note that the model is also visually closer to the true model from approximately 7520 km northing and above. However, despite the increased structural consistency between the density contrast and magnetic susceptibility models, some of the structures of the model are not recovered accurately. For instance, the basinshape structure around 7500 km northing mirrors the actual geological structure (see Fig. 8) and is an effect of nonuniqueness on inversion. In this case, this illustrates the need for prior information in our inversion. While joint inversion of gravity and magnetic data using the crossgradient constraint improves imaging comparatively with an inversion constrained only using smallness and smoothness constraints, prior geological information or petrophysical information may be necessary to alleviate the remaining uncertainty.
4.4 Smallness and smoothness constraints using geological information
In this subsection, a sensitivity analysis to prior information in inversion is performed through a series of scenarios where geological structural information is introduced to adjust the smallness and smoothness constraints through W_{m} and W_{g}, respectively. In what follows, we apply this approach to gravity inversion.
The influence of geological information in defining the smallness and smoothness terms (detailed in Sects. 2.4.1 and 2.4.2) is analysed by investigating three additional scenarios allowed by the utilisation of either homogenous or geologically derived W_{m} and W_{g} matrices. In each case, we start from the (α_{m}, α_{g}) weights estimated in Sect. 4.2 from the analysis of the L surface, which we adjust to obtain the geophysical misfit sufficiently close to objective values. We restate that α_{m} and α_{g} weight the overall contribution of the model smallness and smoothness, respectively, in the cost function (Eq. 5).
In the first scenario we investigate (scenario b in Table 2), geological uncertainty information is used to define W_{m} while keeping W_{g} homogenous. This allows us to test the influence of geological prior information on the smallness term. The values of the diagonal variance matrix W_{m} are calculated using the geological certainty metric ${\mathit{\sigma}}_{\mathit{\psi}}^{\prime}$ (Eq. 18, shown in Fig. 6b for the 2D section modelled here) and keep W_{g} homogenous.
Contrary to the previous tests (see Sect. 4.2) where ${\mathbf{W}}_{\mathrm{m}}={\mathbf{I}}_{{n}_{\mathrm{m}}}$, we find the following result for the kth model cell:
Because $\mathrm{0}\le ({\mathit{\sigma}}_{\mathit{\psi}}^{\prime}{)}_{k}\le \mathrm{1}\phantom{\rule{0.25em}{0ex}}\forall k$, we have the following result:
Consequently, setting W_{m} in this fashion and keeping α_{m} constant translates to a lower overall relative importance of the smoothness term in the leastsquares cost function (Eq. 5), thereby moving away from the tradeoff inferred from the Lcurve principle (Sect. 4.2). To mitigate this, we adjust α_{m} to a value ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}$ such that
which equates $\left({\mathit{\alpha}}_{\mathrm{m}}^{\prime}{)}^{\mathrm{2}}\text{tr}\right({\mathbf{W}}_{\mathrm{m}})$ with (α_{m})^{2}n_{m} so that the overall weight assigned to the smallness term remains the same with and without geological structural information (lefthand side and righthand side of inequality in Eq. 20, respectively). Because the values of $\Vert {\mathbf{W}}_{\mathrm{m}}\mathit{m}\Vert $ depend on both W_{m} and m, which vary in space and also depend on the other terms of the cost function, minor adjustments of the value of ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}$ are necessary to reach the objective value of data misfit. In this example, this leads to tune the suggested ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}=\mathrm{8.4}\times {\mathrm{10}}^{\mathrm{7}}$ to ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}=\mathrm{8.85}\times {\mathrm{10}}^{\mathrm{7}}$ (keeping α_{g} constant). The corresponding inverted model is shown in Fig. 13b. The corresponding α weights are repeated in Table 2.
In the second scenario we test (scenario c in Table 2), geological uncertainty information is then used to define W_{g} while keeping W_{m} homogenous. This allows us to test the influence of geological prior information on the smoothness term. Following the same procedure as for the smallness term, we adjust the suggested ${\mathit{\alpha}}_{\mathrm{g}}^{\prime}=\mathrm{3.6}\times {\mathrm{10}}^{\mathrm{4}}$ to ${\mathit{\alpha}}_{\mathrm{g}}^{\prime}=\mathrm{4.1}\times {\mathrm{10}}^{\mathrm{4}}$. The corresponding inverted model is shown in Fig. 13c. Finally, we test the case where both W_{m} and W_{g} are defined using geological information in the form of ${\mathit{\sigma}}_{\mathit{\psi}}^{\prime}$. Starting from values of ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}$ and ${\mathit{\alpha}}_{\mathrm{g}}^{\prime}$ used in the previous tests, minor tuning is performed, leading to ${\mathit{\alpha}}_{\mathrm{m}}^{\prime}=\mathrm{6.1}\times {\mathrm{10}}^{\mathrm{7}}$ and ${\mathit{\alpha}}_{\mathrm{g}}^{\prime}=\mathrm{6.0}\times {\mathrm{10}}^{\mathrm{4}}$ inversion results in the model shown in Fig. 13d.
As can be seen in Fig. 13 by comparing Fig. 13a–b with Fig. 13c–d, the utilisation of geological structural information to adjust the smoothness regularisation strength spatially has more impact on inversion than adjusting the smallness term. While incorporating prior geological information in W_{m} constrains the model to a certain extent, using C_{v} to derive W_{g} has more influence on the inverted model than for W_{m}, with resulting models that are closer to the reference model.
Comparing Fig. 13c and d indicates that the use of geological uncertainty information to adjust the smallness regularisation strength spatially (through W_{m}) in addition to the model smoothness term (through W_{g}) modifies inversion results further towards the reference model. Figure 13d, which results from inversion using prior information in both constraint terms, provides the model closest to the reference. While most interfaces are wellrecovered when using geological information to define both W_{g} and W_{m}, the recovered density contrasts remain affected by the ambiguity inherent to gravity data in the presence of subhorizontal geological units (around 7460 km northing). This suggests that in this example, more prior information might be useful in recovering the causative model more truthfully, especially in cases where potential field inversion is ambiguous (e.g. subhorizontal interfaces for gravity inversion). This is the object of the next subsection, which describes a new single physics inversion scenario where petrophysical constraints are combined with structural constraints and geological information.
4.5 Structural and petrophysical constraints
In addition to the definition of matrices W_{m} and W_{g}, geological information can be combined with petrophysical knowledge to define the range of density values allowed in inversion. This is achieved with spatially varying bound constraints on the property inverted for density contrast in this case (see Sect. 2.4.5). Here, such bounds are defined using multiple intervals, each one corresponding to the range of density contrast values expected for a geological unit. Such bounds can be defined globally (homogenously) where all intervals are allowed everywhere in the model or locally when prior information about the presence of the rock units is available. In this work, we use the probability of occurrence of the different rock units to derive bounds that vary in space accordingly with the probability of observation of each of the rock units. In a given cell, only the bound values corresponding to rock units with a probability Ψ>0 are considered. Starting from Eq. (15), such spatially varying bounds B_{k} of the kth model cell are obtained as follows:
where a and b correspond to lower and upper bounds. We consider narrow bounds such that ${b}_{k,l}={a}_{k,l}+\mathit{\epsilon}$, with $\mathit{\epsilon}\ll {a}_{k,l}$, to encourage inversion to use density contrasts that closely resemble values defined a priori. Equation (23) corresponds to the application of a Boolean operator to the probabilities ${\mathrm{\Psi}}_{k=\mathrm{1}\mathrm{\dots}{n}_{\mathrm{f}}}$ in every cell to divide the studied area into domains defined by rock units with a probability Ψ>Ψ_{th}. In such cases, the ADMM bound constraints act as a proxy for a prior models that have been dynamically constrained by petrophysical information.
Four additional scenarios are tested to determine the influence of prior information on inversion to accommodate the addition of both the damping gradient and ADMM bound constraint term. The use of prior information is illustrated in Fig. 14.
At a given iteration, the ADMM bound constraint encourages inverted values to evolve inside one of the prescribed intervals depending on the current model m. As mentioned above, we can then make the analogy with a smallness term that is dynamically updated. For this reason, we treat the ADMM bound constraints in the same fashion as the smallness term, which we apply simultaneously to the model smoothness term.
Following the same protocol as Sect. 4.1 to determine α_{g} and α_{a}, we first perform inversion without the use of geological information in the form of the probabilities for the occurrence of different rock units or metrics that can be derived from them (Fig. 14a, i.e. with W_{g} and W_{a} equal to the identity matrix and the corresponding regularisation term weighted by α_{g} and α_{a}, respectively). It is therefore necessary to determine the value of α_{g} and α_{a} (Eq. 5). We perform an Lsurface analysis and sample values in the (α_{g},α_{a}) plane to estimate the optimum values for these hyperparameters (see Fig. 15). Values of α_{g} vary from $\mathrm{1.585}\times {\mathrm{10}}^{\mathrm{7}}$ and $\mathrm{1.585}\times {\mathrm{10}}^{\mathrm{5}}$, and values of α_{a} vary from $\mathrm{2.484}\times {\mathrm{10}}^{\mathrm{5}}$ and $\mathrm{2.484}\times {\mathrm{10}}^{\mathrm{7}}$. The resulting Lsurface is shown in Fig. 15.
From Fig. 15, we estimate the hyperparameters (α_{g},α_{a}) to be $({\mathit{\alpha}}_{\mathrm{g}},{\mathit{\alpha}}_{\mathrm{a}})=(\mathrm{2.2}\times {\mathrm{10}}^{\mathrm{5}},\mathrm{1.3}\times {\mathrm{10}}^{\mathrm{7}})$ in the case no geological information is used, meaning that both constraints are applied homogenously across the model.
From there, we follow the same procedure as described above (Sect. 4.1 and 4.2) to obtain an estimate for the values of α_{a} and α_{g} in the different configurations shown in Fig. 14b–d. The resulting inverted models are shown in Fig. 16, and the estimates of (α_{g},α_{a}) are provided in Table 3.
Figure 16 shows that the use of ADMM facilitates recovery of betterdefined interfaces between rock units than in previous inversions (Figs. 10, 12, and 13), and decreases the misfit with the causative model (shown in Fig. 6). Unsurprisingly, without the use of geological information (Fig. 16a) inversion results remain inconsistent with geology in several parts of the model, especially around the position 7500 km northing. The inconsistent results can be partly mitigated by using geologically derived smoothness constraints (Fig. 16b). In comparison, however, Fig. 16c shows that use of geological information to determine the bounds recovers features much closer to the causative model.
While Fig. 16d shows the more robust results overall, Fig. 16c and d present generally similar features. This indicates that in this case geological uncertainty information in structural constraints only allows the refining of features largely controlled by the utilisation of the ADMM constraints. This statement is supported by Fig. 16, where the comparison cases (a and b) and (c and d) reveal that the effect of using geological information to define bounds dominates over the effect of using uncertainty to define structural constraints.
The comparison of cases (a and b) and (c and d) in Fig. 16 can be extrapolated to Figs. 13 and 16 to compare constraints more broadly. This is discussed in Sect. 5.1, which presents a short comparative analysis of all gravity inversion results.
5.1 Sensitivity analysis summary: comparison of constrained inversions
Tomofastx was developed with the intent of providing practitioners with an inversion platform accounting for various forms of prior information and geophysical data sets. We have tested a series of constraints involving joint inversion and geological and petrophysical information. The inverted density contrast models for inversion using global smallness and smoothness constraints, joint inversion using the crossgradient technique, geologically derived smallness and smoothness constraints, and ADMM bound constraints (both global and using geological information) are shown in Fig. 17. We remind that all models shown here produce a similar data misfit ${\mathrm{\Theta}}_{\mathrm{d}}^{\text{obj}}$ accordingly with Eq. (19).
Firstly, it appears from Fig. 17 that regardless of the type of constraints considered, the utilisation of geological information (cases b, d, e, g–i) to derive spatially varying constraints for the W matrix of both terms used provides the models that are visually closest to the true model. In this category, the utilisation of petrophysical information in the ADMM bound constraints provides (cases h–i) models that are closest to the true model (the lowest model misfit values are indicated in the titles of the panels in Fig. 17). Secondly, the comparison of cases (a) and (d), (b) and (e), (f) and (g), and (h) and (i) indicates that while it has a less significant influence on the results, incorporating geological information in the definition of the smoothness term also influences inversion results significantly. Lastly, comparison of cases (a) and (b) and (d) and (e) suggests that the utilisation of geological information to adjust the smallness strength spatially has an effect on inversion that is the lowest with the crossgradient constraints (where structural information is passed on from another geophysical data set).
From the results shown in Sect. 4.2 through 4.5 and compared in Fig. 17, it is possible to make a qualitative ranking of the constraints according to their influence on the resulting model (from the most important influence to the least important influence): ADMM bound constraints > smoothness constraints > smallness constraints > crossgradient constraints. This observation is also corroborated by the values of the rootmeansquare misfit between the true and inverted model. We note that this ranking remains speculative as it might apply only to models sharing similarities with the case we investigated.
From these observations we also deduce that when geological uncertainty information is added to the definition of constraints (i.e. ${\mathit{\sigma}}_{\mathit{\psi}}^{\prime}$ for defining W_{m} and W_{g} and probabilities for defining B), the term of the cost function with the highest influence on the process will determine the main features of the model, which will be adjusted by the other term.
Tomofastx was developed with the intent of providing practitioners with an inversion platform allowing various forms of prior information and geophysical data. Constraints that represent uncertainty and our level of epistemic knowledge provide useful constraint to inversion. This is encouraging as the Tomofastx platform addresses a gap in inversion schemes that rely on a single model, with the model being as similar as possible to the target region, an often impossible requirement to meet. Thus, Tomofastx opens additional research avenues to the community that are widely acknowledged but remain largely unaddressed. Conceptual uncertainty relating the prior assumptions made about tectonic event history of the region, and thus the structure under study, can be analysed. Different event histories and topologies can be considered, giving a wider scope to the model space, and allowing the geophysics to invalidate implausible histories, while giving us pause to consider other histories that may be less likely but that are nonetheless possible.
5.2 Outlook for future developments
Another research avenue under consideration is the integration of results from probabilistic modelling of seismic and electrical data into Tomofastx. As stated in the introduction, one of the goals born in mind during the design of Tomofastx is interoperability. Current work involves the integration of Tomofastx into the Loop^{1} opensource 3D probabilistic geological and geophysical modelling platform (Ailleres et al., 2019), in an effort to unify geological and geophysical modelling at a more fundamental level than the more common cooperative approaches. Ongoing developments include the possibility to adjust weight assigned to the ADMM bound constraints accordingly with uncertainty levels in prior information used to define spatially varying intervals.
Future research includes the utilisation of implicit geological modelling (in the sense of Calcagno et al., 2008) with Tomofastx to define geological structures and rules that inversion will be encouraged to follow. It also comprises the incorporation of topological laws previously used a posteriori (Giraud et al., 2020) directly into inversion. The electrical capacitance tomography component of Tomofastx (Martin et al., 2018), which we have not detailed here, can be extended to acoustic (seismic) or electromagnetic data inversions that rely on the resolution of similar nonlinear inversion problems. It opens the door to more versatility in the code and can be applied to joint inversion in similar ways but on more than two physical domains.
In addition, future developments comprise the collaborative and joint inversion of seismic and potential field data. It is planned to develop an interface between Tomofastx and Unisolver (not yet released as open source by its authors), which is an extension of Seimic_Cpml code (Komatitsch and Martin, 2007; Martin et al., 2010, 2019), where integrated seismic imaging solvers are implemented. Unisolver is a multipurpose 2D and 3D seismic imaging platform based on highorder finitedifference and finitevolume discretisation and nonlinear seismic data inversion procedures. Such an interface would allow performing collaborative or joint inversion of seismic and gravity or magnetic data and could obtain the resulting models on the same mesh while benefitting from Tomofastx's various functionalities. This will be an easy way to provide Tomofastx with separate seismic information on the fly like sensitivity kernels as another physical domain.
In the implementation presented here, only the truncation of the matrix system based on maximum distance thresholding was discussed. It is planned to reduce memory requirements using the wavelet compression of the matrix system of the inverse problem in the same fashion as Martin et al. (2013).
We have shown a number of tests using a selected set of functionalities of Tomofastx. However, more or different tests could be done. For instance, an interesting research avenue is to exploit Tomofastx's capability to read an arbitrary number of prior and starting models to test the geological archetypes that can be identified by clustering of the set of geological models probabilistic geological modelling can produce (PakyuzCharrier et al., 2019). Additional features of Tomofastx, the testing of which lies beyond the scope of this paper, are Jacobian matrix truncating and different kinds of depth weighting and their effects on the different types of inversion. Finally, we have not used posterior uncertainty indicators listed in Sects. 2.5 and A1 as the paper focusses on the inversion capabilities of Tomofast. However, the output results of Tomofastx allow us to study uncertainty in the same fashion as Giraud et al. (2017, 2019c) where some of them are used.
Results obtained using the crossgradient technique for joint inversion of gravity and magnetic data showed that it can improve imaging of geological structures. However, our study also revealed some of the limitations of this method. In the synthetic example, structurally coherent features of the resulting model contradict the geology of the true model. In addition, our Lcurve (or Lsurface) analysis suggests that the determination of the optimum α weights of the cost function using the crossgradient technique may be affected by nonuniqueness and that multiple sets of weights could equally satisfy the Lcurve criterion. One interpretation is that this method remains affected by uncertainty and could be producing several families of models fitting geophysical data equally well. This observation differs from similar analysis performed in the case of joint inversion using petrophysical constraints, where such potential ambiguity was not suggested by the Lsurfaces (Giraud et al., 2019c). These impressions, however, require a more detailed investigation and constitute a new research avenue.
In our sensitivity analysis, we have produced a series of models that can be considered geophysically equivalent because they fit the geophysical data equally well. These models are the result of deterministic inversion, where prior information guides inversion towards one of the modes of the probability density function describing the problem (Eq. 1) or modifies them. It is therefore safe to assume that each mode is representative of an archetype of models from the geophysical data's null space. This highlights the interest of using “nullspace shuttles”, allowing navigation of the null space (Deal and Nolet, 1996; Muñoz and Rath, 2006; Vasco, 2007; Fichtner and Zunino, 2019) to explore the space of possible models without extensive sampling and to assess the robustness of the result. In addition, the plots of the Lcurves corresponding to the problem we presented suggest the presence of multiple optima in the hyperparameter space (weights α), which it might be interesting to investigate in future research, especially in the joint inversion case.
We have introduced the opensource joint inversion platform Tomofastx and demonstrated its capabilities with a realistic data set taken from the Hamersley region in central Western Australia. The geophysical theoretical background of Tomofastx was explained in depth to guide users in understanding and using the modelling approach implemented in the source code.
We leveraged the modularity of Tomofastx to study the sensitivity of inversion to prior structural, geological, and petrophysical information; joint inversion; and the code's scalability. We tested a new combination of constraints incorporating geological structural information in the smoothness term and dynamic prior model definition using petrophysical knowledge (ADMM bound constraints), a feature usually not available to most inversion software. Our sensitivity analyses on prior information and different constraints reveal that constraints using petrophysics (ADMM bound constraints) dominate over gradientbased constraints (smoothness and crossgradient constraints), which in turn exert more influence on inversion than smallness constraints. This shows the importance of prior information in inversion and illustrates the need to study the space of geophysically equivalent models.
The examples described here were designed to replicate a typical, rigorous approach to the development of a geoscientific model and be relevant to realworld application. The aim to ensure rigour and reproducibility of the result presented is facilitated by the release of the source code, data sets, and a reduced modified Python version of the algorithm that accompany this paper.
A1 Posterior uncertainty indicators
A1.1 Posterior LSQR variance matrix
At the first and last iteration of the inversion, the diagonal elements of the posterior covariance matrix of the recovered model are calculated in Tomofastx (see Sect. 2.5). The variances are part of the outputs of Tomofastx for further analysis by the user, such as the estimation of uncertainty in the recovered property model.
A1.2 Jacobian of the cost function
Tomofastx offers the possibility to examine the Jacobian matrix of the cost function (Eq. 5), which encapsulates the contribution of several constraint terms (see for example Eq. 5), by calculating its derivative with respect to the model m, $\partial \mathit{\theta}(d,m)/\partial m$. This feature takes advantage of the LSQR solver. In the LSQR algorithm, $\partial \mathit{\theta}(d,m)/\partial m$ is calculated at the beginning of each iteration when approximating a solution to the system of equations (Appendix E). The value of $\partial \mathit{\theta}(d,m)/\partial m$ can then be calculated before or after application of the depthweighting operator. It is computed as the product of the transpose of the matrix representing the lefthand side of the system of equations to be solved by the vector of the corresponding quantities to minimise data misfit, crossgradients, damping terms, etc. (constituting the righthand side of the corresponding equation, as shown in Appendix E). Importantly, its dimension is equal to the number of model parameters. It is therefore possible to store it on disk to provide a measure of the sensitivity of the data and the different terms of the misfit function to model variations at depth or in any part of the computational domain. By computing $\Vert \partial \mathit{\theta}(d,m)/\partial m\Vert $, it is possible to study the convergence of the algorithm, with small values indicating convergence. In addition, it is a metric that measures the stability of the algorithm and which is useful to determine whether the system of equations is well conditioned.
A1.3 Identification of rock units
Membership analysis of the inverted model can be performed when statistical petrophysical constraints were applied to inversion from the values of 𝒩_{k} reached after inversion converged. Membership values can be used to assess inverted models by reconstructing a rock unit model from the recovered inverted physical properties (Doetsch et al., 2010; Sun et al., 2012; Giraud et al., 2019c). Rock units labels can also be assigned to model cells when the ADMM bound constraints have converged. It allows attaching a petrophysical property interval to each model cell, allowing direct identification of rock types.
A1.4 Crossproduct of gradients
The crossproduct of model gradients in 3D can be stored after inversion and its L_{2} norm is given after each inversion cycle. It allows us to assess the degree of structural similarity between the models and to delineate areas showing specific structural similarities or dissimilarities.
A2 Jacobian matrix truncation
Tomofastx offers the possibility to use a moving sensitivity domain approach (Čuma et al., 2012; Čuma and Zhdanov 2014), limiting the sensitivity domain to a cylinder, the radius of which is chosen by the user, to reduce computational requirements (the option for a sphere is also present in the source code but commented in the current version). The underlying assumption is that cells beyond a given distance exert a negligible influence on the measurement. Generally speaking, this radius is provided by the users and should be chosen carefully.
A3 L_{p} norm
Tomofastx also offers the possibility of performing data inversion using a L_{p} norm ($\mathrm{1}<p\le \mathrm{2}$) to define the smallness term, as it has been proposed for electrical capacitance tomography (ECT) in Martin et al. (2018) in the framework of Tomofastx. The L_{p} norm inverse problem is nonlinear and can be solved iteratively using L_{2} minimisation. In the L_{p} norm case, the regularisation parameter can be approximated by a ppower law of the model at each point of the computational domain and must also be recomputed at each new inversion cycle. When the L_{p} norm is introduced for p<2, this procedure allows us to obtain sharper models with better interface definition and determine stronger contrasts for the specific cases under study. If p=2, the smallness term is reduced to L_{2} norm minimisation (the commonly used Tykhonovlike regularisation) as used in this work. The choice of other values such that $\mathrm{1}<p\le \mathrm{2}$ is at the discretion of the user or depending on prior information.
A4 Electrical capacitance tomography
Detailing electrical capacitance tomography (ECT) is beyond the scope of this paper, but we can apply to joint gravity and magnetic inversion the functionalities that have been introduced to solve the ECT inverse problem based on L_{2} data misfit norm and L_{p} ($\mathrm{1}<p\le \mathrm{2}$) damping term minimisation (see Sect. A3). In Tomofastx, ECT is based on the finitevolume method for the forward problem and on a nonlinear and iterative LSQR method to solve the inverse problem. As in propagative and diffusive geophysical inverse problems in frequency domain, the sensitivity matrix and the damping term depend on the current model and must be recomputed at each new iteration. We refer the reader to Martin et al. (2018) for more details on this technique. Note that algorithms developed in relation to this method can easily be extended to propagative and diffusive geophysical inverse problems.
Symbol  Definition 

Subscripts and superscripts  
d  refers to “data”, i.e. “mag” or “grav” 
m  model 
pr  refers to “prior” 
g  gradient 
x  crossgradient 
pe  refers to “petrophysics” 
a  ADMM 
G  gravity 
M  magnetics 
Model and physical quantities  
m  property model inverted for 
z  ADMM variable 
u  ADMM variable 
ω  membership value in Gaussian mixture 
ψ  membership value in Gaussian mixture (from geology) 
μ  mean value of petrophysical properties 
σ  standard deviation of petrophysical properties 
ε  positive threshold real number such that z≫ε 
n_{data}  number of geophysical data points 
n_{f}  number of rock formations 
d  geophysical data 
β  exponent for depthweighted power law 
Mathematical operators or notations  
g(.)  geophysical forward operator 
P(⋅)  petrophysical distribution operator 
∇⋅  gradient operator 
L_{p}  L_{p} norm 
L_{2}  L_{2} norm (sumofsquares) 
S  geophysical data sensitivity matrix 
diagonal matrices W  
W_{d}  diagonal matrix where all elements are equal to the inverse of the sum of squares of the data 
W_{m}  smallness term covariance matrix 
W_{g}  smoothness term covariance matrix 
W_{x}  crossgradient term covariance matrix 
W_{pe}  petrophysical term covariance matrix 
W_{a}  ADMM term covariance matrix 
D  depthweighting operator 
weighting terms α  
α_{m}  model 
α_{g}  gradient 
α_{x}  crossgradient 
α_{pe}  petrophysics 
α_{a}  multiple bound constraints 
α^{G}  weight assigned to the gravity inverse problem (used only in joint inversion) 
α^{M}  weight assigned to the magnetic inverse problem (used only in joint inversion) 
In this Appendix we summarise the forward calculation of gravity and magnetic data as performed in Tomofastx. In practice, Tomofastx calculates forward data using input data expressed in units from Système International (SI), expressed in kilograms, metres, and seconds. The gravity field f of a distribution of density anomalies Δρ over a volume of rock V at a location ${\mathit{r}}^{\prime}=[{x}^{\prime},{y}^{\prime},{z}^{\prime}]$ can be expressed as follows:
where $\mathit{r}=[x,y,z]$ defines the location of mass density anomaly Δρ(r) and G is the universal gravity constant. While Tomofastx is implemented in such a way that the three spatial components of f can be obtained, we consider only the vertical direction here, which we simply write as f for sake of clarity (note that here, when taken for the whole model, f=g_{G}). In our implementation, the volume V is discretised in N_{m} rectangular prisms (model cells) of constant density. Discretised, Eq. (C3) then rewrites as follows:
where Δx_{k}, Δy_{k}, and Δz_{k} define the dimensions of the kth rectangular prism. In our discretisation, we assume a model constituted of ${n}_{x}\times {n}_{y}\times {n}_{z}$ cells, with n_{x}, n_{y}, and n_{z} representing the number of cells in each direction. This leads to the computation of f using the following formulation of Eq. (C1):
where, using the formulation of Blakely (1995), the elements of the sensitivity matrix S are given as follows:
where ξ_{m}, η_{q}, and ζ_{t} are the coordinates of the vertices of the prism and
In Tomofastx, the total magnetic field anomaly is calculated by summing the responses of the prisms making up the model, following Bhattacharyya (1964, 1980). The regional magnetic field is denoted $\mathit{F}=({F}_{x},{F}_{y},{F}_{z})$, and the magnetisation is denoted $\mathit{M}=({M}_{x},{M}_{y},{M}_{z})$. We write $F=\Vert \mathit{F}\Vert $ and $M=\Vert \mathit{M}\Vert $. Note that remnant magnetisation is not accounted for.
Using the formalism of Blakely (1995), we denote ΔT the magnitude of the total magnetic field anomaly generated by a prism oriented parallel to the x, y, and z axes of the mesh similarly to the gravity case. We have the following equation:
where χ is the magnetic susceptibility. The sensitivity S is given as follows:
where, ${\mathit{\xi}}_{m=\mathrm{1},\mathrm{2}}$, ${\mathit{\eta}}_{q=\mathrm{1},\mathrm{2}}$, and ${\mathit{\zeta}}_{t=\mathrm{1},\mathrm{2}}$ are the coordinates of the vertices of the prism along the x, y, and z directions, respectively. The other terms of Eq. (C7) are defined below:
Although Tomofastx can run on personal computers in a few seconds or minutes for 2D inversions and small 3D volumes (typically a few minutes on a laptop for models smaller than approx. 100 000 model cells), it necessitates a supercomputer for realistically sized 3D case studies (e.g. models exceeding 500 000 model cells and 10 000 geophysical data points).
We assess Tomofastx's parallel efficiency using the strong scaling as an indicator. The strong scaling curve is given by plotting the number of CPUs as a function of user time. It is complemented by the relative speedup curve ${t}_{\mathrm{1}}/{t}_{{n}_{\text{cpu}}}$, where t_{1} and ${t}_{{n}_{\text{cpu}}}$ are the user times to complete inversion using the number of CPUs n_{cpu}=1 and a given number of CPU n_{cpu}, respectively. We performed the scaling tests on the EOS machine from the CALMIP supercomputing centre (https://www.top500.org/site/50539/, https://www.calmip.univtoulouse.fr/spip.php?article388 – the latter being in French only, both last accessed on 10 November 2020).
The fullsized model we used is made of ${N}_{\mathrm{x}}{N}_{y}{N}_{z}=\mathrm{128}\times \mathrm{128}\times \mathrm{32}=\mathrm{524}\phantom{\rule{0.125em}{0ex}}\mathrm{288}$ cells (i.e. 2^{19} cells), which we reduce by a factor of 2 by reducing the physical domain incrementally to ${N}_{\mathrm{x}}{N}_{y}{N}_{z}=\mathrm{32}\times \mathrm{32}\times \mathrm{32}=\mathrm{32}\phantom{\rule{0.125em}{0ex}}\mathrm{768}$ cells (i.e. 2^{15} cells) to be able to use it on a single CPU for the purpose of parallelisation efficiency analysis. In the configuration we use, the number of data points modelled is equal to N_{data}=N_{x}N_{y}.
Figure D1a shows the parallelisation efficiency. It reveals that the scaling is nearly perfect for up to 16 CPUs, that it is very good for 32 CPUs, and that it deteriorates above 64 CPUs. This corresponds to relative speedups (ratio between run time for a single CPU and a given number of CPUs) of about 14.5, 25, and 40 (Fig. D1b), respectively. For the cases using 64, 128, and 256 CPUs, speedup increases from 40 to 65, indicating that overhead interprocessor communication time for n_{cpu}≥64 increasingly impacts the total computation time for this (small) problem size. This is noticeable in Fig. D1a and b, as both curves seem to adopt an asymptotic behaviour for the largest numbers of CPUs. This illustrates the deterioration of performances due to interprocessor communications (Kumar et al., 1994). The deterioration of performances due to interprocessor communications is due to the number of elements (or model cells) processed by each CPU becoming smaller, while the number of elements involved in communications increases; ultimately, the time spent in pure computations in each core becomes smaller than the time spent in interprocessor communications.
The efficiency curves (e.g. Fig. D1a and b) allow us to determine the minimum number of elements per CPU that run efficiently (Hammond and Lichtner, 2010). The case of n_{cpu}=64 marks an inflection point in Fig. D1b, corresponding to point of diminishing return equal to a number of element per CPUs of 512. This indicates that for this particular configuration, it is preferable to run inversions with n_{cpu}≤64 to maximise parallel efficiency. For better understanding and interpretation of scaling and speedup, we repeat that the number of elements n_{el} per CPU as a function of n_{cpu} is as follows:
As a general rule, we recommend respecting the condition of n_{el}≥512. For a smaller number of elements, the allocated resources are used in a suboptimum manner. Note that the memory requirements vary proportionally with N_{x}N_{y}N_{z}N_{data}=n_{m}n_{d}, and thus no Jacobian matrix compression is used.
This Appendix introduces the matrix formulation of Eq. (5) and its resolution.
We can write the system of equations to be solved in the leastsquares sense as follows.
At iteration k, the system of the equation is linearised around the current model. It is solved for the optimum update of the current model m_{k} model update as described below. Models ${\mathit{m}}_{k}^{\left(\mathrm{1}\right)}$ and ${\mathit{m}}_{k}^{\left(\mathrm{2}\right)}$ are set accordingly with the type of inversion considered.
In Tomofastx, depthweighting D is applied as a sensitivity matrix preconditioner. The resulting system is solved using the LSQR algorithm (Paige and Saunders, 1982) as follows.
At each kth inversion cycle, we solve this system of equations and calculate the model update the model as follows:
The model m_{k} can then be updated to obtain m_{k+1}.
Following Ogarko et al. (2021a), u^{0}=0 and z^{0}=0. The updated ADMM variables z^{k+1} and u^{k+1} are calculated using the ADMM algorithm introduced by Boyd (2010):
where π_{B} is a projection onto the bounds B such that
The value of the starting model m^{0} is provided by the user.
The source code for Tomofastx as used in this paper can be found in Ogarko et al. (2021b, https://doi.org/10.5281/zenodo.4454220). The latest version of Tomofastx is available at https://github.com/TOMOFAST/Tomofastx (last access: 7 September 2021).
The geological model, a description of the input data, and the geophysical models are given in Jessell et al. (2021a, https://doi.org/10.5281/zenodo.4431796). It also contains a data set using the same model projected onto a finer mesh of approximately 4.2 M cells and 80 000 geophysical data. The data sets are licensed under the AttributionShareAlike 4.0 International (CC BYSA 4.0) license (see https://creativecommons.org/licenses/bysa/4.0/legalcode, last access: 7 September 2021, for details). Tomofastx's source code is licensed under the MIT License (https://opensource.org/licenses/MIT, last access: 7 September 2021).
JG designed the geophysical study and ran all inversions shown in the paper. He adjusted the geological model presented here, which was initially built by MJ and ML. JG performed posterior analysis and interpretation of results. JG is the main contributor to the writing of this article and preparation of the assets. JG carried out the scaling tests shown in the Appendices with the collaboration of VO. VO wrote the user manual of Tomofastx that can be found in the GitHub repository.
VO and JG worked together on the implementation of the gravity and magnetic inversion methodologies in Tomofastx. VO is the main developer of this version of Tomofastx, the development of which was carried in collaboration with JG and RM. The main contributors to the code are VO, JG, and RM. JG performed the initial testing of the different data integration techniques presented, with the exception of the crossgradient technique, which was implemented independently by VO.
RM participated in the redaction of this paper. RM initiated the Tomofast project and implemented the initial LSQR solver for gravity inversion, which was subsequently used as a starting point for the current version of the code. RM and VO added the possibility of performing data inversion using an Lp norm ($\mathrm{1}<p\le \mathrm{2}$) smallness term. RM and VO developed and tested the electrical capacitance tomography component of Tomofast.
JG and RM explored the functionalities of Tomofastx and performed extensive testing for robustness and validation of techniques implemented, especially the crossgradient technique.
ML and MJ produced the reference geological model from field measurements and carried out probabilistic geological modelling. ML and MJ were involved in the redaction of the manuscript and participated in the supervision of the project. MJ and ML were involved in the validation of the methodology at the initial development stage and supervised the overall progress of the presented work.
All authors participated in the revisions of the manuscript.
The authors declare that they have no conflict of interest.
Publisher's note: Copernicus Publications remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.
Appreciation is expressed to the CALMIP supercomputing centre (Toulouse, France). Roland Martin acknowledges the was supported from the CNES (French National Space Agency). Jérémie Giraud, Mark Lindsay, and Mark Jessell acknowledge the support from the Australian Government's Cooperative Research Centre Program. This is MinEx CRC Document 2021/3. Mark Lindsay acknowledges funding from the ARC and DECRA.
The authors acknowledge the contribution of Clement Barriere to the reduced 2D Python version of Tomofastx (called “Tomoslow”).
The authors appreciated discussions about geophysics–geology integration with Laurent Aillères and the rest of the Loop consortium's researchers. The authors thank Guillaume Pirot for his comments on the manuscript. The authors are also thankful to Mahtab Rashidifard, Nuwan Suriyaarachchi, Damien Ciolczyk, and Marina ZarateJeronimo for providing interesting discussions.
This research has been supported by the Department of Industry, Science, Energy and Resources of the Australian Government (grant no. GA22270); the CALMIP supercomputing centre (Toulouse, France) via their support through Roland Martin's supercomputing projects (no. P1138_2018, no. p1138_2019) and the computing time provided on the Olympe machine; and the CNES (French National Space Agency) through the projects 2017 and 2018TOSCA/GETGRAVIGOCE (no. AG68ANGS) grants. Jérémie Giraud, Mark Lindsay, and Mark Jessell are supported in part by Loop – 3D Enabling Stochastic 3D Geological Modelling (LP170100985) and the Mineral Exploration Cooperative Research Centre (MinEx CRC), whose activities are funded by the Australian Government's Cooperative Research Centre Program. This is MinEx CRC Document 2021/3. Mark Lindsay received funding from the ARC and DECRA (DE190100431).
This paper was edited by Thomas Poulet and reviewed by Mehrdad Bastani and one anonymous referee.
Ailleres, L., Jessell, M., de Kemp, E., Caumon, G., Wellmann, F., Grose, L., Armit, R., Lindsay, M., Giraud, J., Brodaric, B., Harrison, M., and Courrioux, G.: Loop – Enabling 3D stochastic geological modelling, ASEG Ext. Abstr., 2019, 1–3, https://doi.org/10.1080/22020586.2019.12072955, 2019.
Belge, M., Kilmer, M. E., and Miller, E. L.: Efficient determination of multiple regularization parameters in a generalized Lcurve framework, Inverse Probl., 18, 314, https://doi.org/10.1088/02665611/18/4/314, 2002.
Bertsekas, D. P.: Nonlinear programming, 3rd edn., Athena Scientific, Belmont, Massachussetts, USA, ISBN: 9781886529052, 2016.
Bhattacharyya, B. K.: Magnetic anomalies due to prismshaped bodies with arbitrary polarization, Geophysics, 29, 517–531, 1964.
Bhattacharyya, B. K.: A generalized multibody model for inversion of magnetic anomalies, Geophysics, 45, 255–270, https://doi.org/10.1190/1.1441081, 1980.
Bijani, R., Lelièvre, P. G., PonteNeto, C. F., and Farquharson, C. G.: Physicalproperty, lithology and surfacegeometrybased joint inversion using Pareto MultiObjective Global Optimization, Geophys. J. Int., 209, 730–748, https://doi.org/10.1093/gji/ggx046, 2017.
Blakely, R. J.: Potential Theory in Gravity and Magnetic Applications, Cambridge University Press, Cambridge, 1995.
Boyd, S.: Distributed Optimization and Statistical Learning via the Alternating Direction Method of Multipliers, Found. Trends^{®} Mach. Learn., 3, 1–122, https://doi.org/10.1561/2200000016, 2010.
Boyd, S., Parikh, N., Chu, E., Peleato, B., and Eckstein, J.: Distributedoptimization and statistical learning via the alternating direction methodof multipliers, Foundations and Trends^{®} in Machine Learning, 3, 1–122, https://doi.org/10.1561/2200000016, 2011.
Brown, V., Key, K., and Singh, S.: Seismically regularized controlledsource electromagnetic inversion, Geophysics, 77, E57–E65, https://doi.org/10.1190/geo20110081.1, 2012.
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. In., 171, 147–157, https://doi.org/10.1016/j.pepi.2008.06.013, 2008.
CarterMcAuslan, A., Lelièvre, P. G., and Farquharson, C. G.: A study of fuzzy c means coupling for joint inversion, using seismic tomography and gravity data test scenarios, Geophysics, 80, W1–W15, https://doi.org/10.1190/geo20140056.1, 2015.
Craven, P. and Wahba, G.: Smoothing noisy data with spline functions, Numer. Math., 31, 377–403, https://doi.org/10.1007/BF01404567, 1978.
Čuma, M. and Zhdanov, M. S.: Massively parallel regularized 3D inversion of potential fields on CPUs and GPUs, Comput. Geosci., 62, 80–87, https://doi.org/10.1016/j.cageo.2013.10.004, 2014.
Čuma, M., Wilson, G. A., and Zhdanov, M. S.: Largescale 3D inversion of potential field data, Geophys. Prospect., 60, 1186–1199, https://doi.org/10.1111/j.13652478.2011.01052.x, 2012.
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.
De Stefano, M., Golfré Andreasi, F., Re, S., Virgilio, M., and Snyder, F. F.: Multipledomain, simultaneous joint inversion of geophysical data with application to subsalt imaging, Geophysics, 76, R69–R80, https://doi.org/10.1190/1.3554652, 2011.
Deal, M. M. and Nolet, G.: Nullspace shuttles, Geophys. J. Int., 124, 372–380, https://doi.org/10.1111/j.1365246X.1996.tb07027.x, 1996.
Doetsch, J., Linde, N., Coscia, I., Greenhalgh, S. A., and Green, A. G.: Zonation for 3D aquifer characterization based on joint inversions of multimethod crosshole geophysical data, Geophysics, 75, G53–G64, https://doi.org/10.1190/1.3496476, 2010.
Dykstra, R. L.: An Algorithm for Restricted Least Squares Regression, J. Am. Stat. Assoc., 78, 837–842, https://doi.org/10.1080/01621459.1983.10477029, 1983.
Eckhardt, E. A.: Partnership between geology and geophysics in prospecting for oil, Geophysics, 5, 209–214, https://doi.org/10.1190/1.1441804, 1940.
Farquharson, C. G. and Oldenburg, D. W.: A comparison of automatic techniques for estimating the regularization parameter in nonlinear inverse problems, Geophys. J. Int., 156, 411–425, https://doi.org/10.1111/j.1365246X.2004.02190.x, 2004.
Fichtner, A. and Zunino, A.: Hamiltonian Nullspace Shuttles, Geophys. Res. Lett., 46, 644–651, https://doi.org/10.1029/2018GL080931, 2019.
Gallardo, L. A. and Meju, M. A.: Characterization of heterogeneous nearsurface materials by joint 2D inversion of dc resistivity and seismic data, Geophys. Res. Lett., 30, 1–4, https://doi.org/10.1029/2003GL017370, 2003.
Gallardo, L. A. and Meju, M. A.: Joint twodimensional DC resistivity and seismic travel time inversion with crossgradients constraints, J. Geophys. Res.Sol. Ea., 109, B03311, https://doi.org/10.1029/2003JB002716, 2004.
Gil, Y., David, C. H., Demir, I., Essawy, B. T., Fulweiler, R. W., Goodall, J. L., Karlstrom, L., Lee, H., Mills, H. J., Oh, J.H., Pierce, S. A., Pope, A., Tzeng, M. W., Villamizar, S. R., and Yu, X.: Toward the Geoscience Paper of the Future: Best practices for documenting and sharing research from data to software to provenance, Earth Space Sci., 3, 388–415, https://doi.org/10.1002/2015EA000136, 2016.
Giraud, J., Jessell, M., Lindsay, M., ParkyuzCharrier, E., and Martin, R.: Integrated geophysical joint inversion using petrophysical constraints and geological modelling, in: SEG Technical Program Expanded Abstracts 2016, pp. 1597–1601, Society of Exploration Geophysicists, Dallas, Texas, 2016.
Giraud, J., PakyuzCharrier, E., Jessell, M., Lindsay, M., Martin, R., and Ogarko, V.: Uncertainty reduction through geologically conditioned petrophysical constraints in joint inversion, Geophysics, 82, ID19–ID34, https://doi.org/10.1190/geo20160615.1, 2017.
Giraud, J., PakyuzCharrier, E., Ogarko, V., Jessell, M., Lindsay, M., and Martin, R.: Impact of uncertain geology in constrained geophysical inversion, ASEG Ext. Abstr., 2018, 1, https://doi.org/10.1071/ASEG2018abM1_2F, 2018.
Giraud, J., Lindsay, M., Ogarko, V., Jessell, M., Martin, R., and PakyuzCharrier, E.: Integration of geoscientific uncertainty into geophysical inversion by means of local gradient regularization, Solid Earth, 10, 193–210, https://doi.org/10.5194/se101932019, 2019a.
Giraud, J., Ogarko, V., Lindsay, M., PakyuzCharrier, E., Jessell, M., and Martin, R.: Sensitivity of constrained joint inversions to geological and petrophysical input data uncertainties with posterior geological analysis, Geophys. J. Int., 218, 666–688, https://doi.org/10.1093/gji/ggz152, 2019b.
Giraud, J., Ogarko, V., Lindsay, M., PakyuzCharrier, E., Jessell, M., and Martin, R.: Sensitivity of constrained joint inversions to geological and petrophysical input data uncertainties with posterior geological analysis, Geophys. J. Int., 218, 666–688, https://doi.org/10.1093/gji/ggz152, 2019c.
Giraud, J., Lindsay, M., Ogarko, V., Jessell, M., Martin, R., and PakyuzCharrier, E.: Integration of geoscientific uncertainty into geophysical inversion by means of local gradient regularization, Solid Earth, 10, 193–210, https://doi.org/10.5194/se101932019, 2019d.
Giraud, J., Lindsay, M., Jessell, M., and Ogarko, V.: Towards plausible lithological classification from geophysical inversion: honouring geological principles in subsurface imaging, Solid Earth, 11, 419–436, https://doi.org/10.5194/se114192020, 2020.
Guillen, A., Calcagno, P., Courrioux, G., Joly, A., and Ledru, P.: Geological modelling from field data and geological knowledge, Part II. Modelling validation using gravity and magnetic data inversion, Phys. Earth Planet. In., 171, 158–169, https://doi.org/10.1016/j.pepi.2008.06.014, 2008.
Hammond, G. E. and Lichtner, P. C.: Fieldscale model for the natural attenuation of uranium at the Hanford 300 Area using highperformance computing, Water Resour. Res., 46, W09527, https://doi.org/10.1029/2009WR008819, 2010.
Hansen, P. C. and Johnston, P. R.: The LCurve and its Use in the Numerical Treatment of Inverse Problems, in: Computational Inverse Problems in Electrocardiography, pp. 119–142, available at: https://www.sintef.no/globalassets/project/evitameeting/2005/lcurve.pdf (last access: 13 September 2021), 2001.
Hansen, P. C. and O'Leary, D. P.: The Use of the LCurve in the Regularization of Discrete IllPosed Problems, SIAM J. Sci. Comput., 14, 1487–1503, https://doi.org/10.1137/0914086, 1993.
Heincke, B., Jegen, M., Moorkamp, M., Hobbs, R. W., and Chen, J.: An adaptive coupling strategy for joint inversions that use petrophysical information as constraints, J. Appl. Geophys., 136, 279–297, https://doi.org/10.1016/j.jappgeo.2016.10.028, 2017.
Hoerl, A. E. and Kennard, R. W.: Ridge Regression: Application to nonorthogonal problems, Technometrics, 12, 69–82, https://doi.org/10.1080/00401706.1970.10488634, 1970.
Jessell, M., Giraud, J., and Lindsay, M.: 3D geological and petrophysical models with synthetic geophysics based on data from the Hamersley region (Western Australia), Zenodo [data set], https://doi.org/10.5281/zenodo.4431796, 2021a.
Jessell, M., Ogarko, V., de Rose, Y., 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 using map2loop 1.0 and map2model 1.0, Geosci. Model Dev., 14, 5063–5092, https://doi.org/10.5194/gmd1450632021, 2021b.
Kamm, J., Lundin, I. A., Bastani, M., Sadeghi, M., and Pedersen, L. B.: Joint inversion of gravity, magnetic, and petrophysical data – A case study from a gabbro intrusion in Boden, Sweden, Geophysics, 80, B131–B152, https://doi.org/10.1190/geo20140122.1, 2015.
Komatitsch, D. and Martin, R.: An unsplit convolutional perfectly matched layer improved at grazing incidence for the seismic wave equation, Geophysics, 72, SM155SM167, https://doi.org/10.1190/1.2757586, 2007.
Kostina, E., Saunders, M. A., and Schierle, I.: Computation of Covariance Matrices for Constrainted Parameter Estimation Problems using LSQR, Stanford Optim. Lab Rep., 4026, 1–11, 2009.
Kumar, V., Grama, A., Gupta, A., and Karypis, G.: Introduction to Parallel Computing: Design and Analysis of Algorithms, BenjaminCummings Publishing Co., Inc., Redwood City, CA, 1994.
Lelièvre, P., Farquharson, C., and Hurich, C.: Joint inversion of seismic traveltimes and gravity data on unstructured grids with application to mineral exploration, Geophysics, 77, K1–K15, https://doi.org/10.1190/geo20110154.1, 2012.
Lelièvre, P. G. and Farquharson, C. G.: Integrated Imaging for Mineral Exploration, in: Integrated Imaging of the Earth: Theory and Applications, American Geophysical Union, 137–166, 2016.
Li, X. and Chouteau, M.: Three Dimensional Modeling in All Space, Surv. Geophys., 19, 339–368, https://doi.org/10.1023/A:1006554408567, 1998.
Li, Y. and Oldenburg, D. W.: 3{D} inversion of magnetic data, Geophysics, 61, 394–408, 1996.
Li, Y. and Oldenburg, D. W.: 3D inversion of gravity data, Geophysics, 63, 109–119, https://doi.org/10.1190/1.1444302, 1998.
Lindsay, M. D., Aillères, L., Jessell, M. W., de Kemp, E. A., and Betts, P. G.: Locating and quantifying geological uncertainty in threedimensional models: Analysis of the Gippsland Basin, southeastern Australia, Tectonophysics, 546–547, 10–27, https://doi.org/10.1016/j.tecto.2012.04.007, 2012.
Lindsay, M. D., Perrouty, S., Jessell, M. W., and Aillères, L.: Making the link between geological and geophysical uncertainty: geodiversity in the Ashanti Greenstone Belt, Geophys. J. Int., 195, 903–922, https://doi.org/10.1093/gji/ggt311, 2013.
Martin, R., Komatitsch, D., Gedney, S. D., and Bruthiaux, E.: A highorder time and space formulation of the unsplit perfectly matched layer for the seismicwave equation using auxiliary differential equations (ADEPML), CMESComp. Model. Eng., 56, 17–42, https://doi.org/10.3970/cmes.2010.056.017, 2010.
Martin, R., Monteiller, V., Komatitsch, D., Perrouty, S., Jessell, M., Bonvalot, S., and Lindsay, M. D.: Gravity inversion using waveletbased compression on parallel hybrid CPU/GPU systems: application to southwest Ghana, Geophys. J. Int., 195, 1594–1619, https://doi.org/10.1093/gji/ggt334, 2013.
Martin, R., Ogarko, V., Komatitsch, D., and Jessell, M.: Parallel threedimensional electrical capacitance data imaging using a nonlinear inversion algorithm and Lp normbased model, Measurement, 128, 428–445, https://doi.org/10.1016/j.measurement.2018.05.099, 2018.
Martin, R., Bodet, L., Tournat, V., and Rejiba, F.: Seismic wave propagation in nonlinear viscoelastic media using the auxiliary differential equation method, Geophys. J. Int., 216, 453–469, https://doi.org/10.1093/gji/ggy441, 2019.
Martin, R., Giraud, J., Ogarko, V., Chevrot, S., Beller, S., Gégout, P., and Jessell, M.: Threedimensional gravity anomaly inversion in the Pyrenees using compressional seismic velocity model as structural similarity constraints, Geophys. J. Int., 225, 1063–1085, https://doi.org/10.1093/gji/ggaa414, 2020.
McLachlan, G. and Peel, D.: Finite Mixture Models, Wiley Ser. Prob. Stat., 419, https://doi.org/10.1198/tech.2002.s651, 2000.
Meju, M. A. and Gallardo, L. A.: Structural Coupling Approaches in Integrated Geophysical Imaging, pp. 49–67, 2016.
Moorkamp, M., Heincke, B., Jegen, M., Hobbs, R. W., and Roberts, A. W.: Joint Inversion in Hydrocarbon Exploration, in: Integrated Imaging of the Earth: Theory and Applications, pp. 167–189, 2016.
Muñoz, G. and Rath, V.: Beyond smooth inversion: the use of nullspace projection for the exploration of nonuniqueness in MT, Geophys. J. Int., 164, 301–311, https://doi.org/10.1111/j.1365246X.2005.02825.x, 2006.
Nettleton, L. L.: Geophysics, geology and oil finding, Geophysics, 14, 273–289, https://doi.org/10.1190/1.1437535, 1949.
Ogarko, V., Giraud, J., Martin, R., and Jessell, M.: Disjoint interval bound constraints using the alternating direction method of multipliers for geologically constrained inversion: Application to gravity data, Geophysics, 86, G1–G11, https://doi.org/10.1190/geo20190633.1, 2021a.
Ogarko, V., Giraud, J., and Martin, R.: Tomofastx v1.0 source code, Zenodo [code], https://doi.org/10.5281/zenodo.4454220, 2021b.
Paasche, H. and Tronicke, J.: Cooperative inversion of 2D geophysical data sets: A zonal approach based on fuzzy c means cluster analysis, Geophysics, 72, A35–A39, https://doi.org/10.1190/1.2670341, 2007.
Paige, C. C. and Saunders, M. A.: LSQR: An Algorithm for Sparse Linear Equations and Sparse Least Squares, ACM T. Math. Software, 8, 43–71, https://doi.org/10.1145/355984.355989, 1982.
PakyuzCharrier, E., Lindsay, M., Ogarko, V., Giraud, J., and Jessell, M.: Monte Carlo simulation for uncertainty estimation on structural data in implicit 3D geological modeling, a guide for disturbance distribution selection and parameterization, Solid Earth, 9, 385–402, https://doi.org/10.5194/se93852018, 2018.
PakyuzCharrier, E., Jessell, M., Giraud, J., Lindsay, M., and Ogarko, V.: Topological analysis in Monte Carlo simulation for uncertainty propagation, Solid Earth, 10, 1663–1684, https://doi.org/10.5194/se1016632019, 2019.
Parsekian, A. D., Singha, K., Minsley, B. J., Holbrook, W. S., and Slater, L.: Multiscale geophysical imaging of the critical zone, Rev. Geophys., 53, 1–26, https://doi.org/10.1002/2014RG000465, 2015.
Peng, R. D.: Reproducible Research in Computational Science, Science, 334, 1226–1227, https://doi.org/10.1126/science.1213847, 2011.
Portniaguine, O. and Zhdanov, M. S.: 3D magnetic inversion with data compression and image focusing, Geophysics, 67, 1532–1541, https://doi.org/10.1190/1.1512749, 2002.
Rashidifard, M., Giraud, J., Ogarko, V., Jessell, M., and Lindsay, M.: Cooperative Inversion of Seismic and Gravity Data Using Weighted StructureBased Constraints, in: NSG2020 3rd Conference on Geophysics for Mineral Exploration and Mining, European Association of Geoscientists & Engineers, online, pp. 1–5, 2020.
Ren, Z. and Kalscheuer, T.: Uncertainty and Resolution Analysis of 2D and 3D Inversion Models Computed from Geophysical Electromagnetic Data, Surv. Geophys., 41, 47–112, https://doi.org/10.1007/s10712019095673, 2019.
Rudin, L. I., Osher, S., and Fatemi, E.: Nonlinear total variation based noise removal algorithms, Physica D, 60, 259–268, https://doi.org/10.1016/01672789(92)90242F, 1992.
Santos, E. T. F. and Bassrei, A.: L and Θcurve approaches for the selection of regularization parameter in geophysical diffraction tomography, Comput. Geosci., 33, 618–629, https://doi.org/10.1016/j.cageo.2006.08.013, 2007.
Scheidt, C., Li, L., and Caers, J.: Quantifying Uncertainty in Subsurface Systems, John Wiley & Sons, Inc., Hoboken, NJ, 2018.
Sun, J. and Li, Y.: Geophysical inversion using petrophysical constraints with application to lithology differentiation, SEG San Antonio 2011 Annual Meeting, 4–9 November 2012, 2644–2648, 2011.
Sun, J. and Li, Y.: Multidomain petrophysically constrained inversion and geology differentiation using guided fuzzy cmeans clustering, Geophysics, 80, ID1–ID18, https://doi.org/10.1190/geo20140049.1, 2015.
Sun, J. and Li, Y.: Joint inversion of multiple geophysical data using guided fuzzy c means clustering, Geophysics, 81, ID37–ID57, https://doi.org/10.1190/geo20150457.1, 2016.
Sun, J. and Li, Y.: Joint inversion of multiple geophysical and petrophysical data using generalized fuzzy clustering algorithms, Geophys. J. Int., 208, 1201–1216, https://doi.org/10.1093/gji/ggw442, 2017.
Sun, J., Li, Y., and Studies, M.: Joint inversion of multiple geophysical data: A petrophysical approach using guided fuzzy cmeans clustering, SEG Las Vegas 2012 Annual Meeting, 18–23 September 2011, pp. 1–5, 2012.
Tarantola, A.: Inverse Problem Theory and Methods for Model Parameter Estimation, Society for Industrial and Applied Mathematics, Philadelphia, 2005.
Tarantola, A. and Valette, B.: Inverse Problems = Quest for Information, J. Geophys., 50, 159–170, https://doi.org/10.1038/nrn1011, 1982.
Tikhonov, A. N. and Arsenin, V. Y.: Solutions of IllPosed Problems, John Wiley, New York, 1977.
Tikhonov, A. N. and Arsenin, V. Y.: Solution of IllPosed Problems, Math. Comput., 32, 491, https://doi.org/10.2307/2006360, 1978.
Vasco, D. W.: Invariance, groups, and nonuniqueness: The discrete case, Geophys. J. Int., 168, 473–490, https://doi.org/10.1111/j.1365246X.2006.03161.x, 2007.
Wegener, A.: Die Entstehung der Kontinente und Ozeane, Geogr. J., 61, 304, https://doi.org/10.2307/1781265, 1923.
Wellmann, F. and Caumon, G.: 3D Structural geological models: Concepts, methods, and uncertainties, C. Schmelzback (Ed.), pp. 1–121, Elsevier, Cambridge, Massachusetts, 2018.
Wiik, T., Nordskag, J. I., Dischler, E. Ø., and Nguyen, A. K.: Inversion of inline and broadside marine controlledsource electromagnetic data with constraints derived from seismic data, Geophys. Prospect., 63, 1371–1382, https://doi.org/10.1111/13652478.12294, 2015.
Yan, P., Kalscheuer, T., Hedin, P., and Garcia Juanatey, M. A.: Twodimensional magnetotelluric inversion using reflection seismic data as constraints and application in the COSC project, Geophys. Res. Lett., 44, 3554–3563, https://doi.org/10.1002/2017GL072953, 2017.
Zhang, J. and Revil, A.: 2D joint inversion of geophysical data using petrophysical clustering and facies deformation, Geophysics, 80, M69–M88, 2015.
Zhdanov, M. S. and Lin, W.: Adaptive multinary inversion of gravity and gravity gradiometry data, Geophysics, 82, G101–G114, https://doi.org/10.1190/geo20160451.1, 2017.
Zhdanov, M. S., Gribenko, A., and Wilson, G.: Generalized joint inversion of multimodal geophysical data using Gramian constraints, Geophys. Res. Lett., 39, L09301, https://doi.org/10.1029/2012GL051233, 2012.
https://www.loop3d.org/ (last access: 7 September 2021)
 Abstract
 Introduction
 Inverse modelling platform Tomofastx
 Synthetic model and data
 Application example: sensitivity analysis to constraints and prior information
 Discussion
 Conclusions
 Appendix A: Other functionalities of Tomofastx
 Appendix B: Summary of the notation and terms used in the paper
 Appendix C: Forward gravity and magnetic data calculation
 Appendix D: Scaling tests
 Appendix E: Matrix formulation of leastsquares problem and resolution of the inverse problem
 Code and data availability
 Author contributions
 Competing interests
 Disclaimer
 Acknowledgements
 Financial support
 Review statement
 References
 Abstract
 Introduction
 Inverse modelling platform Tomofastx
 Synthetic model and data
 Application example: sensitivity analysis to constraints and prior information
 Discussion
 Conclusions
 Appendix A: Other functionalities of Tomofastx
 Appendix B: Summary of the notation and terms used in the paper
 Appendix C: Forward gravity and magnetic data calculation
 Appendix D: Scaling tests
 Appendix E: Matrix formulation of leastsquares problem and resolution of the inverse problem
 Code and data availability
 Author contributions
 Competing interests
 Disclaimer
 Acknowledgements
 Financial support
 Review statement
 References