Skip to main content

A tool for generating projection grid aligned bounding boxes and pixelated geometries from AOI (Area of Interest) files for Sentinel Hub Batch V2 API on CDSE

Project description

SH Batch Grid Builder

This tool is designed to build custom tiling grids for the Sentinel Hub Batch V2 API on CDSE. The custom grid is built around an input AOI for a given projection and ensures the Batch request produces outputs matching the pixel grid of the given projection.

Features

  • Aligned Bounding Boxes: Generate projection grid-aligned bounding boxes that snap to a specified grid resolution
  • Pixelated Geometries: Convert geometries to pixelated representations in order to only query data for the given AOI
  • Automatic Splitting: Automatically splits large geometries that exceed pixel limits
  • Multiple CRS Support: Works with any EPSG code, automatically handling CRS-specific grid origins

Installation

From PyPI

pip install sh-batch-grid-builder

From Source

git clone https://github.com/maximlamare/SH-Batch-Grid-Builder.git
cd SH-Batch-Grid-Builder
pip install .

Development Installation

git clone https://github.com/maximlamare/SH-Batch-Grid-Builder.git
cd SH-Batch-Grid-Builder
pip install -e ".[dev]"

Usage

Command Line Interface

The tool provides a command-line interface via the sh-grid-builder command:

sh-grid-builder <input_aoi> --resolution "(x,y)" --epsg <epsg_code> --output-type <type> -o <output_file>

Arguments

  • input_aoi: Path to input AOI file (GeoJSON, GPKG, or other formats supported by GeoPandas)
  • --resolution: Grid resolution as (x,y) tuple in CRS coordinate units:
    • Format: "(x,y)" or "x,y" (brackets optional, e.g., "(300,359)" or "300,359")
    • Important: Always quote the resolution value to prevent shell interpretation (e.g., --resolution "(300,359)" or --resolution "300,359")
    • Note the resolution must be in the units of the selected projection (e.g. EPSG:3035: resolution in meters; EPSG:4326: resolution in degrees).
    • X and Y resolutions can be different to support non-square pixels
  • The tool automatically detects and displays the CRS units when running
  • --epsg: EPSG code for the output CRS (e.g., 3035 for ETRS89 / LAEA Europe, 4326 for WGS84)
  • --output-type: Type of output to generate:
    • bounding-box: Generate an aligned bounding box that covers the AOI
    • pixelated: Generate pixelated geometry of the AOI
  • -o, --output: Path to output file (GPKG format required)

Examples

Generate aligned bounding boxes with same resolution for x and y:

sh-grid-builder data/aoi.geojson --resolution "(10,10)" --epsg 3035 --output-type bounding-box -o output_bbox.gpkg

Generate aligned bounding boxes with different x and y resolutions:

sh-grid-builder data/aoi.geojson --resolution "(300,359)" --epsg 32632 --output-type bounding-box -o output_bbox.gpkg

Generate pixelated geometry:

sh-grid-builder data/aoi.geojson --resolution "10,10" --epsg 3035 --output-type pixelated -o output_pixelated.gpkg

Example with geographic CRS (degrees):

sh-grid-builder data/aoi.geojson --resolution "(0.001,0.001)" --epsg 4326 --output-type bounding-box -o output_bbox.gpkg

Python API

You can also use the package programmatically:

from sh_batch_grid_builder import GeoData

# Initialize with AOI file, EPSG code, and resolutions (x, y)
geo_data = GeoData("path/to/aoi.geojson", epsg_code=3035, resolution_x=10.0, resolution_y=10.0)

# Or with different x and y resolutions
geo_data = GeoData("path/to/aoi.geojson", epsg_code=4326, resolution_x=0.002976190476204, resolution_y=0.002976190476204)

# Generate aligned bounding boxes
aligned_bboxes = geo_data.create_aligned_bounding_box(max_pixels=3500)

# Generate pixelated geometry (includes all pixels that touch/intersect the AOI)
pixelated_geom = geo_data.create_pixelated_geometry(max_pixels=3500)

# Save results
aligned_bboxes.to_file("output_bbox.gpkg", driver="GPKG")
pixelated_geom.to_file("output_pixelated.gpkg", driver="GPKG")

How It Works

Aligned Bounding Boxes

The tool creates bounding boxes that are aligned to a grid based on:

  1. The specified X and Y resolutions (can be different for non-square pixels)
  2. The CRS origin (false easting/northing) for projected coordinate systems
  3. Automatic splitting when dimensions exceed 3500 pixels (fixed limit)

Pixelated Geometries

The pixelated geometry generation uses a raster-based approach:

  1. Converts the input geometry to a raster mask
  2. Polygonizes the raster back to vector format
  3. Automatically splits large geometries to avoid memory issues

This approach is much faster than vector-based methods for large grids. Pixelated output includes any pixel that touches/intersects the AOI.

Requirements

  • Python >= 3.8
  • geopandas >= 0.12.0
  • pyproj >= 3.4.0
  • shapely >= 2.0.0
  • rasterio >= 1.3.0
  • numpy >= 1.21.0

Development

Running Tests

pytest

Building the Package

python -m build

License

MIT License

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

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

sh_batch_grid_builder-0.2.1.tar.gz (10.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sh_batch_grid_builder-0.2.1-py3-none-any.whl (9.8 kB view details)

Uploaded Python 3

File details

Details for the file sh_batch_grid_builder-0.2.1.tar.gz.

File metadata

  • Download URL: sh_batch_grid_builder-0.2.1.tar.gz
  • Upload date:
  • Size: 10.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for sh_batch_grid_builder-0.2.1.tar.gz
Algorithm Hash digest
SHA256 0f1768a94d58d0ef3c1a540bd1033c2e5a859bae9ae00e8e0e94276546db77c0
MD5 91cb10a2d668f206e688633df2c1f7c0
BLAKE2b-256 a85755a9aa6e517b6de95a43b514799c27772e1588fb8839bfec65d32fc71c4a

See more details on using hashes here.

File details

Details for the file sh_batch_grid_builder-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for sh_batch_grid_builder-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e59b6f4e7d2ab1d7e68a5d02855ab8607f81ff46ab7dadeadfe99f914e23b658
MD5 2a30956827c27ef2c10c1ec4eaaaeab4
BLAKE2b-256 ecd238fa1c001e95c1cf9a0673b4b6104e7d5f0650a8aaf051c777b59777c532

See more details on using hashes here.

Supported by

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