Skip to main content

Algorithms and utilities for Synthetic Aperture Radar (SAR) sensors

Project description

Sarsen

Algorithms and utilities for Synthetic Aperture Radar (SAR) sensors. Enables cloud-native SAR processing via Xarray and Dask.

This Open Source project is sponsored by B-Open - https://www.bopen.eu.

Features and limitations

Sarsen is a Python library and command line tool with the following functionalities:

  • provides algorithms to terrain-correct satellite SAR data
    • geometric terrain correction (geocoding)
      • fast mode: to terrain-correct images
      • accurate mode: for interferometric processing
    • radiometric terrain correction (gamma flattening)
  • accesses SAR data via xarray-sentinel:
    • supports most Sentinel-1 data products as distributed by ESA:
      • Sentinel-1 Single Look Complex (SLC) SM/IW/EW
      • Sentinel-1 Ground Range Detected (GRD) SM/IW/EW
    • reads uncompressed and compressed SAFE data products on the local computer or on a network via fsspec - depends on rasterio>=1.3a3
  • accesses DEM data via rioxarray:
    • reads local and remote data in virtually any raster format via rasterio / GDAL
  • supports larger-than-memory and distributed data access and processing via Dask

Overall, the software is in the beta phase and the usual caveats apply.

Current limitations and work-in-progress items:

  • documentation needs improvement. See #6.
  • the performance of the radiometric terrain-correction can probably be optimised. See #7.

Non-objectives / Caveat emptor items:

  • No attempt is made to support UTC leap seconds. Observations that include a leap second may crash the code or silently return wrong results.

SAR terrain-correction

The typical side-looking SAR system acquires data with uniform sampling in azimuth and slant range, where the azimuth and range represents the time when a given target is acquired and the absolute sensor-to-target distance, respectively. Because of this, the near range appears compressed with respect to the far range. Furthermore, any deviation of the target elevation from a smooth geoid results in additional local geometric and radiometric distortions known as foreshortening, layover and shadow.

  • Radar foreshortening: Terrain surfaces sloping towards the radar appear shortened relative to those sloping away from the radar. These regions are much brighter than other places on the SAR image.
  • Radar layover: It's an extreme case of foreshortening occurring when the terrain slope is greater than the angle of the incident signal.
  • Radar shadows: They occur when ground points at the same azimuth but different slant ranges are aligned in the direction of the line-of-sight. This is usually due to a back slope with an angle steeper than the viewing angle. When this happens, the radar signal never reaches the farthest points, and thus there is no measurement, meaning that this lack of information is unrecoverable.

The geometric terrain correction (GTC) corrects the distortions due to the target elevation. The radiometric terrain correction (RTC) also compensates for the backscatter modulation generated by the topography of the scene.

Install

The easiest way to install sarsen is in a conda environment. The following commands create a new environment, activate it, install the package and its dependencies:

    conda create -n SARSEN
    conda activate SARSEN
    conda install -c conda-forge dask proj-data sarsen

Note that the proj-data package is rather large (500+Mb) and it is only needed to handle input DEM whose vertical coordinate is not on a known ellipsoid, for example SRTM DEM with heigths over the EGM96 geoid.

Command line usage

The sarsen command line tool corrects SAR data based on a selected DEM and may produce geometrically terrain-corrected images (GTC) or radiometrically terrain-corrected images (RTC). Terrain-corrected images will have the same pixels as the input DEM, that should be resampled to the target projection and spacing in advance, for example using gdalwarp.

The following command performs a geometric terrain correction:

  sarsen gtc S1B_IW_GRDH_1SDV_20211217T141304_20211217T141329_030066_039705_9048.SAFE IW/VV South-of-Redmond-10m_UTM.tif

Performing geometric and radiometric terrain correction requires significantly more resources. Currently it is possible to produce 50km x 50km RTC images at a 10m resolution on a 32Gb machine:

  sarsen rtc S1B_IW_GRDH_1SDV_20211217T141304_20211217T141329_030066_039705_9048.SAFE IW/VV South-of-Redmond-10m_UTM.tif

Python API usage

The python API has entry points to the same commands and it also gives access to several lower level algorithms, but internal APIs should not be considered stable:

The following code applies the geometric terrain correction to the VV polarization of "S1B_IW_GRDH_1SDV_20211217T141304_20211217T141329_030066_039705_9048.SAFE" product:

from sarsen import apps
gtc = apps.terrain_correction(
  "S1B_IW_GRDH_1SDV_20211217T141304_20211217T141329_030066_039705_9048.SAFE",
  measurement_group="IW/VV",
  dem_urlpath="South-of-Redmond-10m_UTM.tif",
)

The radiometric correction can be activated using the key correct_radiometry: :

from sarsen import apps
rtc = apps.terrain_correction(
  "S1B_IW_GRDH_1SDV_20211217T141304_20211217T141329_030066_039705_9048.SAFE",
  measurement_group="IW/VV",
  dem_urlpath="South-of-Redmond-10m_UTM.tif",
  correct_radiometry="gamma_nearest"
)

Reference documentation

This is the list of the reference documents:

Project resources

on-push codecov

Contributing

The main repository is hosted on GitHub. Testing, bug reports and contributions are highly welcomed and appreciated:

https://github.com/bopen/sarsen

Lead developer:

Main contributors:

See also the list of contributors who participated in this project.

Sponsoring

B-Open commits to maintain the project long term and we are happy to accept sponsorships to develop new features.

We wish to express our gratitude to the project sponsors:

  • Microsoft has sponsored the support for GRD products and the gamma flattening algorithm.

License

Copyright 2016-2022 B-Open Solutions srl

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

    http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sarsen-0.9.0.tar.gz (926.4 kB view details)

Uploaded Source

Built Distribution

sarsen-0.9.0-py3-none-any.whl (18.5 kB view details)

Uploaded Python 3

File details

Details for the file sarsen-0.9.0.tar.gz.

File metadata

  • Download URL: sarsen-0.9.0.tar.gz
  • Upload date:
  • Size: 926.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for sarsen-0.9.0.tar.gz
Algorithm Hash digest
SHA256 1b5c9ea33f8dedbf2c3a716390aaa405ccaa93b4024d4af6a04a50d00e1e5046
MD5 49f75fa028967eddaea1b5dc279a0665
BLAKE2b-256 1c5ab16bf3768fe5d7adcfd7303d2a7d2c3531451dc1cba86f049d9993e8c8e5

See more details on using hashes here.

File details

Details for the file sarsen-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: sarsen-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 18.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for sarsen-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8622385da6c5b5098867afbdd1de777b155b3ef96d8331f3ff15a6cef8e451ec
MD5 581008fcb114a06594d2fabd0bcc991a
BLAKE2b-256 f6ade8d73df6f6eae3e9bcb7709b70506843658457208670c660512f48385a57

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page