Metadata-Version: 2.4
Name: NLR-GAPs
Version: 0.9.2
Summary: National Laboratory of the Rockies' (NLR's) Geospatial Analysis Pipelines (GAPs) framework
Author-email: Paul Pinchuk <ppinchuk@nlr.gov>
Maintainer-email: Paul Pinchuk <ppinchuk@nlr.gov>, Grant Buster <gbuster@nlr.gov>
License-Expression: BSD-3-Clause
Project-URL: homepage, https://github.com/NatLabRockies/gaps
Project-URL: documentation, https://natlabrockies.github.io/gaps/
Project-URL: repository, https://github.com/NatLabRockies/gaps
Keywords: gaps,NLR
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Science/Research
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
Requires-Python: >=3.9
Description-Content-Type: text/x-rst
License-File: LICENSE
Requires-Dist: click>=8.1.8
Requires-Dist: colorama>=0.4.6
Requires-Dist: NLR-rex>=0.5.0
Requires-Dist: numpy<3,>=2.0.2
Requires-Dist: numpydoc>=1.8.0
Requires-Dist: pandas<3,>=2.2.3
Requires-Dist: psutil>=7.0.0
Requires-Dist: pyjson5>=1.6.4
Requires-Dist: pyyaml>=6.0.2
Requires-Dist: setuptools>=80.1.0
Requires-Dist: sphinx>=7.4.7
Requires-Dist: sphinx-click>=6.0.0
Requires-Dist: sphinx-copybutton>=0.5.2
Requires-Dist: sphinx-tabs>=3.4.1
Requires-Dist: sphinxcontrib-mermaid>=1.0.0
Requires-Dist: tabulate>=0.9.0
Requires-Dist: toml>=0.10.2
Provides-Extra: dev
Requires-Dist: ipython<9,>=8.18.1; extra == "dev"
Requires-Dist: jupyter<2,>=1.1.1; extra == "dev"
Requires-Dist: pipreqs<0.5,>=0.4.13; extra == "dev"
Requires-Dist: ruff<0.15,>=0.14.14; extra == "dev"
Provides-Extra: test
Requires-Dist: flaky<4,>=3.8.1; extra == "test"
Requires-Dist: h5py<4,>=3.13.0; extra == "test"
Requires-Dist: pytest<9,>=8.3.5; extra == "test"
Requires-Dist: pytest-cases<4,>=3.8.6; extra == "test"
Requires-Dist: pytest-cov>=3.0; extra == "test"
Requires-Dist: pytest-profiling<2,>=1.7.0; extra == "test"
Requires-Dist: pytest-xdist>=3.0; extra == "test"
Requires-Dist: snakeviz<3,>=2.2.2; extra == "test"
Requires-Dist: tox<5,>=4.25.0; extra == "test"
Provides-Extra: doc
Requires-Dist: ghp-import>=2.1; extra == "doc"
Requires-Dist: make>=0.1; extra == "doc"
Requires-Dist: myst-parser<4,>=3.0.1; extra == "doc"
Requires-Dist: pandoc<3,>=2.4; extra == "doc"
Requires-Dist: pydata-sphinx-theme<0.17,>=0.16.1; extra == "doc"
Provides-Extra: build
Requires-Dist: build<2,>=1.2.2; extra == "build"
Requires-Dist: pkginfo<2,>=1.12.1.2; extra == "build"
Requires-Dist: twine<7,>=6.1.0; extra == "build"
Dynamic: license-file

================================================
Welcome to Geospatial Analysis Pipelines (GAPs)!
================================================

|Docs| |Tests| |Linter| |Codecov|
|PyPi| |PythonV| |Ruff| |Pixi|
|License| |SWR|

.. |Docs| image:: https://github.com/NatLabRockies/gaps/workflows/Documentation/badge.svg
    :target: https://natlabrockies.github.io/gaps/

.. |Tests| image:: https://github.com/NatLabRockies/gaps/workflows/Pytests/badge.svg
    :target: https://github.com/NatLabRockies/gaps/actions?query=workflow%3A%22Pytests%22

.. |Linter| image:: https://github.com/NatLabRockies/gaps/workflows/Lint%20Code%20Base/badge.svg
    :target: https://github.com/NatLabRockies/gaps/actions?query=workflow%3A%22Lint+Code+Base%22

.. |PyPi| image:: https://img.shields.io/pypi/pyversions/NLR-GAPs.svg
    :target: https://pypi.org/project/NLR-GAPs/

.. |PythonV| image:: https://badge.fury.io/py/NLR-GAPs.svg
    :target: https://badge.fury.io/py/NLR-GAPs

.. |Codecov| image:: https://codecov.io/gh/NatLabRockies/gaps/branch/main/graph/badge.svg?token=6VZK0Q2QNQ
    :target: https://codecov.io/gh/NatLabRockies/gaps

.. |Ruff| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json
    :target: https://github.com/astral-sh/ruff

.. |License| image:: https://img.shields.io/badge/License-BSD_3--Clause-blue.svg
    :target: https://opensource.org/licenses/BSD-3-Clause

.. |Pixi| image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/prefix-dev/pixi/main/assets/badge/v0.json
    :target: https://pixi.sh

.. |SWR| image:: https://img.shields.io/badge/SWR--23--28_-blue?label=NLR
    :alt: Static Badge

.. inclusion-intro

Geospatial Analysis Pipelines (GAPs) is a framework designed
to assist researchers and software developers add execution
tools to their geospatial python models. Born from the
open-source `reV <https://github.com/NatLabRockies/reV>`_ model, GAPs is a
robust and easy-to-use engine that provides a rich set of features
such as command-line interface (CLI) generation and documentation,
basic High-Performance Computing (HPC) scaling capabilities,
configuration file generation, job status monitoring, and more.


Who should use GAPs
===================
GAPs is intended to be used by researchers and/or software developers
who have implemented a working python model but have not yet added any
external model execution tools. Within minimal effort, developers can
use GAPs to add a variety of utility for end-users, including a complete
set of CLI commands and documentation pulled from the model run function
docstrings. In addition, GAPs provides basic HPC execution capabilities,
particularly catered towards embarrassingly parallel geospatial models
(e.g. single-location models such as the `System Advisor Model <https://sam.nlr.gov>`_).
GAPs can automatically distribute the execution of such models over a large
geospatial extent (e.g. CONUS) across many parallel HPC nodes.

GAPs is **NOT** a workflow management system (WMS), and therefore does not
provide any of the in-depth tools/capabilities expected from a proper WMS.
However, GAPs-supported models can sometimes be included as part of the workflow in
WMS tools like `Torc <https://pages.github.natlabrockies.gov/viz/wms/index.html#/>`_.

To get started, take a look at the examples for
`analysts <https://natlabrockies.github.io/gaps/misc/examples.users.html>`_ or
`model developers <https://natlabrockies.github.io/gaps/misc/examples.developers.html>`_
or dive straight into the full `documentation <https://natlabrockies.github.io/gaps/>`_.


Installing GAPs
===============

The quickest way to install GAPs for users is from PyPi:

.. code-block:: shell

    pip install nlr-gaps

If you are a developer contributing to GAPs, we recommend using `pixi <https://pixi.sh/latest/>`_:

.. code-block:: shell

    pixi shell

For detailed instructions, see the `installation documentation <https://natlabrockies.github.io/gaps/misc/installation.html>`_.

Development
===========
Please see the `Development Guidelines <https://natlabrockies.github.io/gaps/dev/index.html>`_
if you wish to contribute code to this repository.


Acknowledgments
===============
.. inclusion-ack

Paul Pinchuk and Grant Buster. Geospatial Analysis Pipelines. 2023. https://doi.org/10.11578/dc.20230426.7

The authors of this code would like to thank ExxonMobil Corporation for their contributions to this effort.
