Metadata-Version: 2.1
Name: phydra
Version: 0.0.2
Summary: A library of marine ecosystem models using the XSO frammework (xarray-simlab-ode)
License: BSD 3-Clause
Author: Benjamin Post
Requires-Python: >=3.9,<4.0
Classifier: License :: Other/Proprietary License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Description-Content-Type: text/markdown

# phydra

A library of plankton community models utilizing the XSO frammework ([Xarray-simlab-ODE](https://github.com/ben1post/xarray-simlab-ode)). 

> Disclaimer: The library and framework are in the early stages of development. Feedback, testing, and contributions are very welcome.



## What is phydra?
Phydra is a Python package that provides a library of modular plankton community models built using the XSO framework. XSO provides a streamlined, interactive and reproducible workflow for building and running models. The model input and output data is an Xarray-Dataset directly compatible with a wealth of tools of the Python scientific ecosystem.


![00_schematics_PhydraXSO.png](docs%2F_static%2F00_schematics_PhydraXSO.png)

## Usage

See the included [notebooks](https://github.com/ben1post/phydra/tree/master/notebooks) for an interactive presentation of the usage of the Phydra library.

## Package structure
The plankton community models included in the Phydra package are available to the user at multiple hierarchical levels: as a library of pre-built XSO model _components_, as pre-assembled _model objects_, and as exemplary model simulations in interactive Jupyter notebooks. These levels are described below.


- _**Components**_: The first version of the library will contain all _components_ used to create the three model applications presented in the notebooks.
    
- _**Model objects**_: The first release of Phydra contains the _model objects_ defined in the three model applications presented in section _UseCases_. The _model objects_ can be imported from the library and can be readily setup, modified, and run by a user.
    
- _**Example notebooks**_: _Model objects_ only define the collection of _components_. To run a model, the input parameters still need to be defined and supplied at runtime. The Phydra library comes with three fully documented model applications that are presented in interactive Jupyter notebooks. These notebooks show all steps from creating the _model setup_ object to analyzing model output and provide a template for further exploration and experimentation with the provided plankton community models.
    

# Motivation

The open-source and extensible nature of Phydra and XSO enables users to customize and develop processes that accurately describe a particular ecosystem. In a collaborative effort to promote efficient, transparent, and reproducible marine ecosystem modeling, Phydra encourages users to contribute their own _components_ and _models_ to the core library. The Phydra library could potentially offer a comprehensive, well-documented, and peer-reviewed codebase for the scientific exploration of marine ecosystem models.

## Installation

```bash
$ pip install phydra
```

## Contributing

Interested in contributing? Check out the contributing guidelines. Please note that this project is released with a Code of Conduct. By contributing to this project, you agree to abide by its terms.

## License

`phydra` was created by Benjamin Post. It is licensed under the terms of the BSD 3-Clause license.

## Credits

`phydra` was created with [`cookiecutter`](https://cookiecutter.readthedocs.io/en/latest/) and the `py-pkgs-cookiecutter` [template](https://github.com/py-pkgs/py-pkgs-cookiecutter).

