Ridal — Speeding up Ground Penetrating Radar (GPR) processing
The aim of ridal is to quickly and accurately process GPR data.
In one command, most data can be processed in pre-set profiles or with custom filter settings, and batch modes allow for sequences of datasets to be processed with the same settings.
Built in rust with a high focus on testing and performance, ridal may be for you if large data volumes and strange fileformats are common issues.
The name is a take on the loosely defined "Data Abstraction Library" (DAL) projects like GDAL and PDAL, but for radar.
A near-term goal of Ridal is to enable easy translation between formats, such as ridal translate input.rad output.dzt (this is not yet implemented).
Much of the functionality has been inspired from the projects RGPR and ImpDAR; both of which are more mature projects. For example, Ridal currently only works on Malå (.rd3) and pulseEKKO (.dt1) radar formats. For many uses, these will more likely be the tools for you!
Prior to Feb. 2026, this program was called rsgpr.
Radargram (100 MHz Malå) of Kroppbreen in Svalbard. Collected 28 Feb. 2023.
Installation
Requirements
cargo(only for the CLI; not the python package). Easiest installed using rustup.gdal(optional, for sampling heights from DEMs). For Debian or derivatives, this meansgdal-bin.proj(optional, for CRS support other than WGS84 UTM Zones). For Debian or derivatives, this meansproj-bin.
Using cargo, the ridal CLI can be installed (after installing the requirements):
with nix, the flake can be used without worrying about the requirements above:
{
inputs = {
ridal.url = "github:erikmannerfelt/ridal";
};
}
or in an ephemeral shell:
Python
There's a very early implementation of a Python package, which will be expanded in the future:
See scripts/render_kroppbreen.py for an example of how it can be used.
Simple CLI usage
See the help page of ridal for info on how to interact with the CLI:
To toggle useful information on a file, the -i or --info argument shows the metadata and a summary of the location data:
Processing a file using the default processing profile:
All processing steps are shown in the steps.md file.
The output will be a NetCDF file with the same name but an .nc suffix.
By default, the output is saved in the same directory as the input.
For more control, the output directory and/or filename can be controlled with -o or --output.
To process multiple files in "batch mode", provide a "glob" pattern as the filename.
Optionally, for many sequential files, the --merge argument allows merging multiple files into one.
A rudimentary profile renderer is available with the -r argument.
This will be saved in the same location as the output file as a JPG if another filename is not given.
Papers using Ridal
- Kleber et al. (2023): Groundwater springs formed during glacial retreat are a large source of methane in the high Arctic
- Harcourt et al. (2026): Surging glaciers in Svalbard: Observing their distribution, characteristics and evolution
... and many others in preparation/review