Skip to main content

Python tools for obtaining and working with ICESat-2 data

Project description

Python tools for obtaining and working with ICESat-2 data

All Contributors GitHub license Conda install Pypi install

JOSS publication link and DOI Zenodo all-versions DOI for icepyx

Latest release (main branch): Docs Status main Unit Tests Status (main) Integration Tests Status (main) Code Coverage main

Current development version (development branch): Docs Status dev Unit Tests Status (dev) Integration Tests Status (main) Code Coverage dev pre-commit.ci status

Origin and Purpose

icepyx is both a software library and a community composed of ICESat-2 data users, developers, and the scientific community. We are working together to develop a shared library of resources - including existing resources, new code, tutorials, and use-cases/examples - that simplify the process of querying, obtaining, analyzing, and manipulating ICESat-2 and (via the QUEST module) relevant ancillary datasets to enable scientific discovery.

icepyx aims to provide a clearinghouse for code, functionality to improve interoperability, documentation, examples, and educational resources that tackle disciplinary research questions while minimizing the amount of repeated effort across groups utilizing similar datasets. icepyx also hopes to foster collaboration, open-science, and reproducible workflows by integrating and sharing resources.

Many of the underlying tools from which icepyx was developed began as Jupyter Notebooks developed for and during the cryosphere-themed ICESat-2 Hackweek at the University of Washington in June 2019 or as scripts written and used by the ICESat-2 Science Team members. Originally called icesat2py, the project combined and generalized these scripts into a unified framework, adding examples, documentation, and testing where necessary and making them accessible for everyone. Similar scripts were conceived at the 2021 Hackweek, which in turn led to the development of QUEST. icepyx is now a domain-agnostic, standalone software package and community (under the broader icesat2py GitHub organization) that continues to build functionality for obtaining and working with ICESat-2 data products locally and in the cloud. It also improves interoperability for ICESat-2 datasets with other open-source tools.

Installation

The simplest way to install icepyx is by using the conda package manager. Conda install

conda install icepyx

Alternatively, you can also install icepyx using pip. Pypi install

pip install icepyx

More detailed instructions for installing icepyx can be found at https://icepyx.readthedocs.io/en/latest/getting_started/install.html

Quick Start

import icepyx as ipx
query = ipx.Query(
    # Collection short name
    "ATL06",
    # Bounding box
    [-55, 68, -48, 71],
    # Time bounds
    ['2019-02-20','2019-02-28'],
)
query.download_granules('/tmp/icepyx')
$ ls -1 /tmp/icepyx/
processed_ATL06_20190221121851_08410203_006_02.h5
processed_ATL06_20190222010344_08490205_006_02.h5
processed_ATL06_20190225121032_09020203_006_02.h5
processed_ATL06_20190226005526_09100205_006_02.h5

See the examples below for more things icepyx can do!

Examples (Jupyter Notebooks)

Listed below are example Jupyter notebooks for working with ICESat-2 (IS2).

IS2_data_access

IS2_data_access2_subsetting

IS2_data_variables

IS2_data_visualization

IS2_data_read-in

IS2_cloud_data_access

QUEST_Finding_Argo_IS2_data

Citing icepyx

This community and software is developed with the goal of supporting science applications. Thus, our contributors (including those who have developed the packages used within icepyx) and maintainers justify their efforts and demonstrate the impact of their work through citations. Please see CITATION.rst for additional citation information.

Contact

Working with ICESat-2 data and have ideas you want to share? Have a great suggestion or recommendation of something you’d like to see implemented and want to find out if others would like that tool too? Come join the conversation at: https://discourse.pangeo.io/. Search for “icesat-2” under the “science” topic to find us.

Contribute

We welcome and invite contributions to icepyx from anyone at any career stage and with any amount of coding experience! Check out our contribution guidelines to see how you can contribute.

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms. Contributor Covenant

Research notice

Please note that this repository is participating in a study into sustainability of open source projects. Data will be gathered about this repository for approximately the next 12 months, starting from June 2021.

Data collected will include number of contributors, number of PRs, time taken to close/merge these PRs, and issues closed.

For more information, please visit the informational page or download the participant information sheet.

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

icepyx-2.0.1.tar.gz (85.4 kB view details)

Uploaded Source

Built Distribution

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

icepyx-2.0.1-py3-none-any.whl (78.1 kB view details)

Uploaded Python 3

File details

Details for the file icepyx-2.0.1.tar.gz.

File metadata

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

File hashes

Hashes for icepyx-2.0.1.tar.gz
Algorithm Hash digest
SHA256 a29ff754d8526df6b917ef7b7c28635662187e9c994e43aadf3fe788c937cb52
MD5 75b3f01b55a9422cf61c8309d08064c0
BLAKE2b-256 7d64f512c5ec8e461c28aaa7235fc052fb0e695e54fda99660d8a63b1db45231

See more details on using hashes here.

Provenance

The following attestation bundles were made for icepyx-2.0.1.tar.gz:

Publisher: publish_to_pypi.yml on icesat2py/icepyx

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

File details

Details for the file icepyx-2.0.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for icepyx-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ab68fa202de897a25c38ba73bcd85ae2c38764ae74750f0dd5e19b7ffab32b1b
MD5 fc91e29d2fc83e64124981a69b2897a8
BLAKE2b-256 54c978b9f3fde1ecaa8395c7d818ce75e089aed00b9fd75d3f58f4397fa1b1e7

See more details on using hashes here.

Provenance

The following attestation bundles were made for icepyx-2.0.1-py3-none-any.whl:

Publisher: publish_to_pypi.yml on icesat2py/icepyx

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