Skip to main content

A python package that processes lidar and imagery data in forestry

Project description


Logo

Phytospatial

A python package that processes lidar and imagery data in forestry

Explore the docs »



Python versions License DOI Build Status
Windows MacOS Linux

About The Project

Phytospatial is a Python toolkit designed to streamline the processing of remote sensing data for forestry and vegetation analysis. It provides tools for handling large hyperspectral rasters, validating vector geometries, and extracting spectral statistics from tree crowns. It also allows for passive-active raster-level fusion via its image processing module.

Key Features

  • Memory-Safe Processing: Process massive rasters using windowed reading (via rasterio) without overloading RAM.
  • Forestry Focused: Specialized tools for tree crown validation and species labeling.

Getting Started

Installation

To get up and running quickly with pip:

pip install phytospatial

New to Python? Check out our detailed Installation Guide for Conda and Virtual Environment setup.

Usage

Here is a simple example of extracting spectral data from tree crowns using the extract_to_dataframe API, which automatically handles memory management and tiling strategies.

from phytospatial import extract, loaders

# Load tree crowns (returns a standardized Vector object)
crowns = loaders.load_crowns("data/crowns.shp")

# Extract features directly into a pandas DataFrame
# The 'auto' mode automatically selects the best processing strategy
df = extract.extract_to_dataframe(
    raster_input="data/image.tif",
    vector_input=crowns,
    tile_mode="auto"
)

print(df.head())

For a complete workflow, see the Spectral Extraction Tutorial.

Contribute

As an open-source project, we encourage and welcome contributions of students, researchers, or professional developers.

Want to help? Please read our CONTRIBUTING section for a detailed explanation of how to submit pull requests. Please also make sure to read the project's CODE OF CONDUCT.

Not sure how to implement your idea, but want to contribute?
Feel free to leave a feature request here.

Citation

If you use this project in your research, please cite it as:

Grand'Maison, L.-V. (2026). Phytospatial: a python package that processes lidar and imagery data in forestry (0.5.1) [software]. Zenodo. https://doi.org/10.5281/zenodo.18112045

Contact

The project is currently being maintained by Louis-Vincent Grand'Maison.

Feel free to contact me by email or linkedin:
Email - lvgra@ulaval.ca
Linkedin - grandmaison-lv

Acknowledgments & Funding

This software is developed by Louis-Vincent Grand'Maison as part of a PhD project. The maintenance and development of this project is supported by several research scholarships:

  • Fonds de recherche du Québec – Nature et technologies (FRQNT) (Scholarship 2024-2025)
  • Natural Sciences and Engineering Research Council of Canada (NSERC) (Scholarship 2025-present)
  • Université Laval (Scholarship 2024-present)

License

Phytospatial is distributed under the Apache License, Version 2.0.
See the LICENSE file for the full text. This license includes a permanent, world-wide, non-exclusive, no-charge, royalty-free, irrevocable patent license for all users.

See LICENSE for more information on licensing and copyright.

(Back to Top)

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

phytospatial-0.5.1.tar.gz (58.6 kB view details)

Uploaded Source

Built Distribution

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

phytospatial-0.5.1-py3-none-any.whl (69.0 kB view details)

Uploaded Python 3

File details

Details for the file phytospatial-0.5.1.tar.gz.

File metadata

  • Download URL: phytospatial-0.5.1.tar.gz
  • Upload date:
  • Size: 58.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for phytospatial-0.5.1.tar.gz
Algorithm Hash digest
SHA256 df3219173e105642267d1db8fe435633502ec4eeff90944833efcc4e45d39e0b
MD5 ad9f445baf72c58e51e35a2c38401b65
BLAKE2b-256 8c0bc7fcd0af384e47e1d2c9269f050b2ed6a82f7e05850bc266465cc8a4bb2a

See more details on using hashes here.

Provenance

The following attestation bundles were made for phytospatial-0.5.1.tar.gz:

Publisher: publish.yml on Louis-Gm/phytospatial

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file phytospatial-0.5.1-py3-none-any.whl.

File metadata

  • Download URL: phytospatial-0.5.1-py3-none-any.whl
  • Upload date:
  • Size: 69.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for phytospatial-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a5f336d60610fecec4c94baf2e3a459a3ef2ee0ddc2dfb0763e61a130d380856
MD5 0cb1ad56001d123d0d505dd7d3f04052
BLAKE2b-256 ee9ad9ed0b02c57ac95dfc854abeb9d599ba25f43b93df751dcfee6460a9ee54

See more details on using hashes here.

Provenance

The following attestation bundles were made for phytospatial-0.5.1-py3-none-any.whl:

Publisher: publish.yml on Louis-Gm/phytospatial

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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