L2 Subsetter Service
Project description
l2ss-py
Harmony service for subsetting L2 data. l2ss-py supports:
- Spatial subsetting
- Bounding box
- Shapefile subsetting
- GeoJSON subsetting
- Temporal subsetting
- Variable subsetting
If you would like to contribute to l2ss-py, refer to the contribution document.
Initial setup, with poetry
- Follow the instructions for installing
poetry
here. - Install l2ss-py, with its dependencies, by running the following from the repository directory:
poetry install
Note: l2ss-py can be installed as above and run without any dependency on harmony
.
However, to additionally test the harmony adapter layer,
extra dependencies can be installed with poetry install -E harmony
.
How to test l2ss-py locally
Unit tests
There are comprehensive unit tests for l2ss-py. The tests can be run as follows:
poetry run pytest -m "not aws and not integration" tests/
You can generate coverage reports as follows:
poetry run pytest --junitxml=build/reports/pytest.xml --cov=podaac/ --cov-report=html -m "not aws and not integration" tests/
Note: The majority of the tests execute core functionality of l2ss-py without ever interacting with the harmony python modules.
The test_subset_harmony
tests, however, are explicitly for testing the harmony adapter layer
and do require the harmony optional dependencies be installed,
as described above with the -E harmony
argument.
l2ss-py script
You can run l2ss-py on a single granule without using Harmony. In order to run this, the l2ss-py package must be installed in your current Python interpreter
$ l2ss-py --help
usage: run_subsetter.py [-h] [--bbox BBOX BBOX BBOX BBOX]
[--variables VARIABLES [VARIABLES ...]]
[--min-time MIN_TIME] [--max-time MAX_TIME] [--cut]
input_file output_file
Run l2ss-py
positional arguments:
input_file File to subset
output_file Output file
optional arguments:
-h, --help show this help message and exit
--bbox BBOX BBOX BBOX BBOX
Bounding box in the form min_lon min_lat max_lon
max_lat
--variables VARIABLES [VARIABLES ...]
Variables, only include if variable subset is desired.
Should be a space separated list of variable names
e.g. sst wind_dir sst_error ...
--min-time MIN_TIME Min time. Should be ISO-8601 format. Only include if
temporal subset is desired.
--max-time MAX_TIME Max time. Should be ISO-8601 format. Only include if
temporal subset is desired.
--cut If provided, scanline will be cut
--shapefile SHAPEFILE
Path to either shapefile or geojson file used to subset the provided input granule
For example:
l2ss-py /path/to/input.nc /path/to/output.nc --bbox -50 -10 50 10 --variables wind_speed wind_dir ice_age time --min-time '2015-07-02T09:00:00' --max-time '2015-07-02T10:00:00' --cut
An addition to providing a bounding box, spatial subsetting can be achieved by passing in a shapefile or a geojson file.
poetry run l2ss-py /path/to/input.nc /path/to/output.nc --shapefile /path/to/test.shp
or
poetry run l2ss-py /path/to/input.nc /path/to/output.nc --shapefile /path/to/test.geojson
Running Harmony locally
In order to fully test l2ss-py with Harmony, you can run Harmony locally. This requires the data exists in UAT Earthdata Cloud.
- Set up local Harmony instance. Instructions here
- Add concept ID for your data to services.yml
- Execute a local Harmony l2ss-py request. For example:
localhost:3000/YOUR_COLLECTION_ID/ogc-api-coverages/1.0.0/collections/all/coverage/rangeset?format=application%2Fx-netcdf4&subset=lat(-10%3A10)&subset=lon(-10%3A10)&maxResults=2
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file l2ss_py-2.11.0.tar.gz
.
File metadata
- Download URL: l2ss_py-2.11.0.tar.gz
- Upload date:
- Size: 34.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.10.14 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9a64dd2db7a6f810d4217677bf222ff7fea3d646ea59a29bd2597e32da1df5c5 |
|
MD5 | 0fac941c1230b22c5137b3c4b30a720a |
|
BLAKE2b-256 | 4ba1157eae578709b0a95316f56f712b6f8519617d0ecae2bb6385cce6ec62a6 |
File details
Details for the file l2ss_py-2.11.0-py3-none-any.whl
.
File metadata
- Download URL: l2ss_py-2.11.0-py3-none-any.whl
- Upload date:
- Size: 36.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.3.2 CPython/3.10.14 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5076879b766c57d791f36a5c14ca2fc47efac3ce7b6705646c2ccd221786c432 |
|
MD5 | e55760495dad5003ef734505dc1a0ad9 |
|
BLAKE2b-256 | 6774626daf087472636c5788c8a44431e77b9d71ac670291935d7322fda2226d |