Skip to main content

A library to ease the manipulation of geospatial images

Project description

Rastereasy

Click on the logo to access the complete documentation with many examples and notebooks.

Click here for a complete documentation

Introduction

rastereasy is a Python library for simple manipulation of geospatial raster and vector data (e.g., *.tif, *.jp2, *.shp). The goal is to simplify geospatial workflows by offering tools for reading and processing raster and vector files, resampling, cropping, reprojecting, stacking, filtering, etc of raster images, easy visualizations such as color composites and spectral plots, use (train / apply) some classical Machine Learning algorithms on images, provide some tools for late fusion of classifications (Dempster-Shafer), ...

The main class, Geoimage, enables to process raster similarly than numpy arrays while keeping and adapting all meta data.

Documentation

A complete documentation can be found here

Example Usage

Here's a quick example of what you can do with rastereasy:

 import rastereasy

 # Load a georeferenced image
 image = rastereasy.Geoimage("example.tif")

 # Get image information
 image.info()

 # Print value of pixel [100,200]
 print(image[100,200])

 # Create a color composite
 image.colorcomp(['4', '3', '2'])

 # Resample and reproject
 image_resampled = image.resample(2)
 image_reproject = image.reproject("EPSG:4326")

 # Save the processed image
 image.save("processed_image.tif")

Installation

With pip

Install rastereasy via pip (the easiest method):

 $ pip install rastereasy

From source

To install rastereasy from source:

  1. Clone the repository from GitHub:
$ git clone https://github.com/pythonraster/rastereasy.git
  1. Navigate to the repository's root directory:
$ cd rastereasy
  1. Install the package using pip:
$ pip install .

Interactive Visualization Notes

Spectra visualization

Jupyter notebooks

As illustrated, rastereasy supports interactive plotting of spectral bands for individual pixels. To enable this functionality in Jupyter Notebook, rastereasy installs some Jupyter extensions in your environment. If it doesn't work, you may need to rebuild jupyter by the command:

jupyter lab build

Google Colab

To use the interactive plotting features in Google Colab, a special two-step setup is required.Follow these steps in the exact order. Separating the commands into different cells and restarting the session is essential.

Step 1: Install Libraries

Run the following cell to install rastereasy and the necessary dependencies for interactive widgets.

!pip install rastereasy ipympl
from google.colab import output
output.enable_custom_widget_manager()

Step 2: Restart the Runtime

After the installation is complete, you must restart the runtime.

Go to the menu: Runtime > Restart runtime (or use the shortcut Ctrl+M).

Step 3: Run Your Code

After restarting, you can now enable the interactive mode and use the library in a new cell.

%matplotlib widget
import rastereasy

To do

Check conda installation

Authors

Citation

If you use rastereasy, please cite:

Thomas Corpetti, Pierrick Matelot, Augustin de la Brosse, Candide Lissak Rastereasy: A Python package for an easy manipulation of remote sensing images Journal of Open Source Software, submitted, 2025.

License

This project is licensed under the MIT License – see the LICENCE file for details.

Releases

0.3.1

Bug fixes & improvement:

  • Naming: Fixed an issue where band names could be reset when manipulating images that already had saved names.

  • im2tiles: Now clears any existing snippets in a folder before saving new ones, preventing leftover files from previous runs.

0.3.0

This new version introduces several new features and improvements focused on dimensionality reduction, visualization, and overall consistency across the library.

New features

  • Dimensionality reduction: Added support for PCA, t-SNE, and LLE methods for feature extraction and visualization.

  • Visualization: Added a zoom parameter to all visualization functions (.visu(), .colorcomp(), .plot_spectra()), allowing users to focus on specific regions of interest.

Improvements

  • Crop function harmonization: The crop() function has been standardized. It now accepts either:

    • a pixel-based area definition: area=((deb_row, end_row), (deb_col, end_col)), or

    • geographic coordinates of the north-west (lat1, lon1) and south-east (lat2, lon2) corners.

  • Consistent documentation: Updated comments and docstrings to ensure consistency with the predict() function and other ML-related methods.

Bug fixes

  • Fixed a bug occurring when opening windowed versions of images that caused incorrect band naming.

0.2.2

  • Minor bug in plotting

0.2.1

  • Added a new boolean test: image.isnan() to check for NaN values in an image.

  • Renamed resampling() to resample().

    • Both functions remain available in this version, but resampling() is deprecated and will be removed in a future release.
  • Renamed apply_ML_model() to predict().

    • Both functions remain available in this version, but apply_ML_model() is deprecated and will be removed in a future release.

0.2.0

This release introduces several new features (custom band names persistence, metadata-only loading, partial image reading, improved lat/lon visualization, and warnings for multi-band stacks) while remaining fully backward compatible. The version has therefore been bumped from 0.1.4 to 0.2.0.

Here are the main changes

  • User-defined band names

    • Band names set by the user via im.change_names are now automatically saved with im.save and reloaded with rastereasy.Geoimage.
  • Metadata-only loading

    • You can now load only the metadata without reading the full image using meta_only=True: im = rastereasy.Geoimage('myimage.tif', meta_only=True)
  • Partial image reading (window or area)

    • It is now possible to read a specific part of the image with the area parameter:

    • By indices: area=((start_row, end_row), (start_col, end_col))

    • By geographic coordinates: area=((lon1, lon2), (lat1, lat2)) with extent='latlon'

  • Warning for multi-band images in files2stack

    • When using rastereasy.files2stack with images containing multiple bands, a warning is displayed to inform the user.
  • Minor bugs in visualization for latitude/longitude coordinates has also been fixed.

0.1.4

September 2025. Add useful functions for ML

0.1.3

September 2025. Minor corrections in help of functions

0.1.2

September 2025. Add filters (gaussian, median, laplace, sobel and generic) functions.

0.1.1

June 2025. Minor bugs related to interactive visualization fixed (works in console and notebooks).

0.1.0

June 2025. First release, version 0.1.0

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

rastereasy-0.3.1.tar.gz (17.7 MB view details)

Uploaded Source

Built Distribution

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

rastereasy-0.3.1-py3-none-any.whl (88.7 kB view details)

Uploaded Python 3

File details

Details for the file rastereasy-0.3.1.tar.gz.

File metadata

  • Download URL: rastereasy-0.3.1.tar.gz
  • Upload date:
  • Size: 17.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for rastereasy-0.3.1.tar.gz
Algorithm Hash digest
SHA256 5c8ed3bcfcdec9bc4e17e412d6ca09370128ce30fa47b5b8d8f7f0db171cec53
MD5 ef6f2b88d8c4daa42a3c175b8ba7fc79
BLAKE2b-256 48df1ca649c4df2718880266b3e0a0a77d48664d598f5bd50278a24eab5f02c1

See more details on using hashes here.

File details

Details for the file rastereasy-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: rastereasy-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 88.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for rastereasy-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 12ec1a6886970b9e590725362895771ae0d688975ac25a9ad7ee5237e8e65481
MD5 d0f1f7e9ebea6566b9905d206462b2dd
BLAKE2b-256 445cf9cbbf8e0340a915b9a3680437a13a0181b4936bc061bf45c993ae46897c

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