GA-AEM is a repository for Geoscience Australia's C++ programs and utilities for forward modelling and inversion of Airborne Electromagnetic (AEM) data. It includes Matlab and Python interfaces for forward model and derivative calculations. It also includes programs for post-processing inversion results to generate GoCAD SGrid sections, georeferenced-section images, Geoscience Australia's EarthSci and Portal curtain images and layer, depth-slice and elevation-slice grids.
- Dr Ross C Brodie, formerly Geoscience Australia
- Dr Richard Taylor, formerly Geoscience Australia
The majority of the development for this project was carried out by the authors whilst employed at Geoscience Australia. A significant part of the development was however carried out as part of a Geoscience Australia-CSIRO placement. The CSIRO Deep Earth Imaging Future Science Platform (DEI-FSP), CSIRO Discovery Program and CSIRO Research Office is acknowledged for funding and facilitating that placement.
For Windows users who do not wish to compile the programs themselves a package of pre-built Windows binaries are available for download from GitHub here.
- Although the pre-built Windows package does not require compiling, it will require the installation of some third-party dependencies. See the section on third party software dependencies for details.
- Then, once installed you will need to set or modify the user's
PATH
(and possiblyGDAL_DATA
andPROJ_LIB
) environment variables. These may be set in the user's environment or using the examplega-aem_vars.bat
batch file, which will probably need to be modified depending on which versions of, and where, you install ga-aem and the third-party packages. - See scripts/ga-aem_vars.bat and scripts/test_ga-aem_paths.bat for guidance on setting Windows environment variables for ga-aem.
- Ideally you would set the variables in the user environment (e.g.
Start Menu | search "edit environment variable for your account"
). After setting, be sure to open a fresh command window or Windows Explorer window.
- Mostly C++.
- Some Matlab.
- Some Python.
- gaforwardmodeltdem.exe - 1D forward modelling program for time-domain AEM data
- galeisbstdem.exe - deterministic 1D sample-by-sample or bunch-by-bunch inversion of time-domain AEM data
- galeisbstdem-nompi.exe - as above but without any parallel MPI support or dependency
- garjmcmctdem.exe - (undocumented) stochastic 1D sample by sample inversion of time-domain AEM data
- galeiallatonce.exe - (undocumented) stochastic 1D sample by sample inversion of time-domain AEM data
- ctlinedata2sgrid.exe - (undocumented) convert inversion outputs to GoCAD SGrids
- ctlinedata2georefimage.exe - (undocumented) convert inversion outputs to static georeferenced section images that can be displayed in a 2D GIS (a poor man's 3D).
- ctlinedata2slicegrids.exe - (undocumented) convert inversion outputs to layer, depth and elevation-slice grids in ErMapper format
- ctlinedata2curtainimage.exe - (undocumented) convert inversion outputs to GA's Earth Sci curtain image format
- removelog10conductivityfromsgrid.exe - legacy program for removing the log10 conductivity from GoCAD SGrids
- Examples of how to use the programs for various AEM systems.
- Matlab interface via MEX file (shared library) with examples.
- See here for details.
- Python interface via shared library with examples.
- See here for details.
- Note that the User Manual has not yet been updated to reflect changes made for v2.0.0-Release-20240424. However the examples and control files have been updated to reflect the latest changes to the code.
- User Manual.
- Theoretical details for GALEISBSTDEM.
- example_forward_model.exe - simple example of how to use ga-aem via C++ language code to run forward models.
- does not get installed as its only useful for developers.
- example_forward_model_c.exe - simple example of how to use ga-aem via C language code to run forward models.
- does not get installed as its only useful for developers.
When initially cloning the repository in git you should use the --recursive
option so that all of the submodules and their respective submodules are initialized and populated with code.
> git clone --recursive https://github.com/GeoscienceAustralia/ga-aem.git
or if you use SSH authentication,
> git clone --recursive git@github.com:GeoscienceAustralia/ga-aem.git
The ga-aem project has several source code dependencies that are included as git submodules from other open-source projects. The submodules are only required for building the programs and are not required if you are just using precompiled executables. See here for details of how the submodules should be initialized and updated.
For full functionality and to build all programs, and ultimately run them, the following packages are required: FFTW, MPI, NetCDF, GDAL and PETSc.
- See here for details of how to obtain and install the dependencies.
- Not all the dependencies are required for all the programs, as detailed below,
- FFTW
- required for galeisbstdem.exe, galeisbstdem-nompi.exe, garjmcmctdem.exe, galeiallatonce.exe, and the Matlab and Python interfaces.
- MPI
- optional for galeisbstdem.exe.
- required for garjmcmctdem.exe and galeiallatonce.exe.
- NetCDF
- optional for galeisbstdem.exe and galeisbstdem-nompi.exe.
- required for garjmcmctdem.exe.
- GDAL
- required only for ctlinedata2slicegrids.exe and ctlinedata2curtainimage.exe.
- PETSc
- required only for galeiallatonce.exe.
- FFTW
- The programs can be built from source code on both Linux and Windows systems, and probably other architectures.
- The ga-aem project make use of the CMake (>=v3.16) software.
- It is typically simpler to build the code on Linux, however note that Windows users can build and run the code easily on the free Ubuntu 20.04 emulator app available from the Microsoft Store.
- Nevertheless, the code definitely can be built on Windows with CMake or with the Microsoft Visual Studio IDE.
- Traditional Makefiles are now deprecated in ga-aem.
- CMake can be downloaded from https://cmake.org/download.
- The CMake program uses the file
CMakeLists.txt
to build the executables and libraries. Unless you really know what you are doing, do not edit this file. - If you are building on Windows with Visual Studio you should run CMake from the
X64 Native Tools Command Prompt for VS 2019 (or VS 2022)
so that the MSVC compiler is set up correctly.
- CMake involves a generate step, a build step, and an install step.
- The most basic way to use CMake is as follows:
> cd <ga-aem-repository-directory> // Change directory to the where the repo is located
> mkdir <build-dir> // <build-dir> is a temporary directory for building
> cd <build-dir> // change to the <build-dir>
> cmake -DCMAKE_BUILD_TYPE=Release .. // generate the cache using ../CMakeLists.txt in the directory above
> cmake --build . // build all targets
> cmake --install . --prefix <install-dir> // install the executables, libraries, headers, docs and Matlab and Python into the <install-dir>
- The above should work on Linux if you have a C and C++ compiler installed along with all the dependencies.
- However, it is recommend that you inspect, copy and then alter one of the provided CMake build script examples below to suit your specific purposes.
- MSVC on Windows
cmake_build_script_windows-vs2022.bat
. - GNU compiler on Ubuntu
cmake_build_script_ubuntu.sh
(including for the Ubuntu emulator on Windows). - GNU compiler on Gadi cluster
cmake_build_script_gadi-gnu.sh
. - Intel compiler on Gadi cluster
cmake_build_script_gadi-intel.sh
.
- MSVC on Windows
- It is highly likely that you will need to set some environment variables, particularly on Windows, to help CMake find the various third-party packages. These include
FFTW_DIR, NETCDF_DIR, GDAL_DIR, PETSC_DIR
. They may be set either inside the build script or in the user-environment. See here and here for tips.
- To choose a specific compiler, replace the line,
with, for example, one of these lines for the GNU, Intel and Intel-LLVM compilers respectively,
> cmake -DCMAKE_BUILD_TYPE=Release ..
or for Microsoft Visual Studio 2019 or 2022 compilers respectively,> cmake -DCMake_C_COMPILER=gcc -DCMake_CXX_COMPILER=g++ -DCMAKE_BUILD_TYPE=Release .. > cmake -DCMake_C_COMPILER=icc -DCMake_CXX_COMPILER=icpc -DCMAKE_BUILD_TYPE=Release .. > cmake -DCMake_C_COMPILER=icx -DCMake_CXX_COMPILER=icpx -DCMAKE_BUILD_TYPE=Release ..
> cmake -G "Visual Studio 16 2019" -A x64 -DCMAKE_CXX_COMPILER=msvc -DCMAKE_BUILD_TYPE=Release .. > cmake -G "Visual Studio 17 2022" -A x64 -DCMAKE_CXX_COMPILER=msvc -DCMAKE_BUILD_TYPE=Release ..
- Specific dependencies may be disabled by using one or more of the following optional command line switches in the initial generate step. These options are ON by default.
-DWITH_FFTW=OFF
-DWITH_MPI=OFF
-DWITH_GDAL=OFF
-DWITH_NETCDF=OFF
-DWITH_PETSC=OFF
This may be useful if, for example, you do not have the third-party packages installed or do not need that particular functionality. For example a minimalistic version of galeisbstdem.exe
could be built with the following in the generate step,
> cmake -G "Visual Studio 17 2022" -A x64 -Wno-dev -DCMAKE_CXX_COMPILER=msvc -DWITH_FFTW=ON -DWITH_MPI=OFF -DWITH_GDAL=OFF -DWITH_NETCDF=OFF -DWITH_PETSC=OFF -DCMAKE_BUILD_TYPE=Release ..
- In the build step all targets (executables/libraries) can be built,
or only specific targets can be specified,
> cmake --build . --config=Release
> cmake --build . --target galeisbstdem --config=Release > cmake --build . --target ctlinedata2sgrid --config=Release
- Note that in the build step, the --config=Release switch is required for the Visual Studio (and other generator style) compilers, but it is not required for the GNU and Intel compilers on Linux.
- The install step installs (copies) all the executables, libraries, headers, examples, Matlab and Python interfaces to an installation directory.
> cmake --install . --prefix <install-dir>
- The is a suitable installation directory, for example on Windows it might be,
> cmake --install . --prefix %LocalAppData%\GA-AEM
- On Windows systems you can build the programs with the Microsoft Visual Studio 2019 (or later) software in a GUI based integrated development environment (IDE). This is in fact how the code has been developed.
- Be certain to select and install the
Desktop development with C++
workload in the Visual Studio installer. - For convenience Microsoft Visual Studio project, solution and property sheet files are supplied. However some path updates will be required depending on how/where you have installed the third-party dependency libraries.
- See here for more details on how to build ga-aem using the Microsoft Visual Studio IDE.
- Revert to Makefiles instead of CMmake for Python build on linux. Plus change to pyproject.toml inplace of setup.py.
- Catered for deprecation of PETSC_NULL from Petsc v3.19 onward.
- Changed Pelton and ColeCole index for IP modelling in Matlab
- Allowed line number in column index 0 for ctlinedata* programs
- Linux script cmake_build_python_bindings.sh added for building python bindings alone
- Allow gatdaem1d.dylib as shared library name in python bindings
- Functionality changes to deterministic inversion program (galeisbstdem.exe)
- Added XZ amplitude inversion functionality.
- Added Bunch-by-bunch inversion functionality.
- More conservative (better) line search.
- Model parameter bounds and log-barrier constraint.
- More sanity checks on inputs and warning log output.
- Usability and convenience improvements.
- Zero and null data handling (for potentially culled data).
- Pass-through selected ancillary fields from input to output file.
- Input ASEGGDF2 DFN, HDR and CSV headers supported.
- Field names can be specified instead of column numbers.
- DFN, HDR, CSV and i3 output file headers.
- Vertical similarity/homogeneity constraints.
- Experimental output to GA's NetCDF line data format.
- Experimental delayed geometry inversion option.
- Experimental cable length constraint.
- Functionality changes to stochastic inversion program (garjmcmctdem.exe).
- Parallel tempering added.
- NetCDF file output of probability maps for selected soundings.
- Induced polarization forward-modelling (not inversion) capability added.
- Available in Matlab interface.
- Available in Python interface.
- Post-processing of inversion results programs added.
- GoCAD SGrid generation.
- Georeferenced section generation.
- Generation of rudimentary layer, depth slice and elevation slice grids.
- Generation of curtain images sections for GA's EarthSci and Portal.
- CMake build system supported and traditional Makefiles deprecated.
- Added Python 3.x interface for simple forward modelling and derivatives only.
- Added Matlab interface for simple forward modelling and derivatives only.
- Changed how the PPM normalization is carried out. Now PPM normalization is by directional-component-wise with respect to the maximum primary dB/dt or B-field at the receiver for a reference system geometry (which is usually estimated on a per flight or per survey basis). Previously PPM normalization was with respect to the system geometry for the forward model being run.
- Added GEOTEM (1996 ppm system) and SPECTREM (ppm system) examples.
- Fixed a bug in the thickness derivative of the second bottom layer. This may have effected few-layer inversions, but not multi-layer fixed-thickness inversion.
- Initial public release.