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.2.tar.gz (11.0 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.2-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sh_batch_grid_builder-0.2.2.tar.gz
  • Upload date:
  • Size: 11.0 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.2.tar.gz
Algorithm Hash digest
SHA256 676b87e4e7541588febb410f1488f856cff30eac443258321fc2aa3fc419f98f
MD5 c4370318b13280dc0eda5cba2b3d8e5a
BLAKE2b-256 1b781f547dd18ccc6e5ef7fd1dcd55c7073c8cb7fc427fb880585ae16bfc1da8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for sh_batch_grid_builder-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cfb689ab7db08afb2b526511d1d099eeb323082149c9c9066390b9be16a99762
MD5 94ebc89d8a718563a2375b06651e4613
BLAKE2b-256 6c0a57e4f817c3afb9515ee249870ab47b7536c2c5e7c2babc09c5d63db6a84a

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