Metadata-Version: 2.4
Name: piperabm
Version: 0.2.0
Summary: An Agent-Based Model Framework for Simulating Resilience in Python
Author-email: Aslan Noorghasemi <aslann@cmu.edu>, Sierra Hicks <sh2337@cornell.edu>, Christopher McComb <ccm@cmu.edu>
License: MIT
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Scientific/Engineering
Requires-Python: >=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: keepdelta
Requires-Dist: matplotlib==3.10.1
Requires-Dist: networkx==3.4.2
Requires-Dist: numpy==2.2.5
Requires-Dist: scipy==1.15.2
Dynamic: license-file

<h1 align="center">
    <br>
    Pied Piper
</h1>

<h3 align="center">
    An Agent-Based Model Framework for Simulating Societal Resilience
</h3>

<div align="center">

[![Documentation](https://img.shields.io/badge/Documentation-30363f?logo=read-the-docs&logoColor=white)](https://pied-piper.readthedocs.io/)
![Python Version](https://img.shields.io/badge/Python-≥3.10-blue)
[![PyPI Version](https://img.shields.io/pypi/v/piperabm?label=PyPI)](https://pypi.org/project/piperabm/)
[![GitHub](https://img.shields.io/badge/GitHub-30363f?logo=github&logoColor=white)](https://github.com/cmudrc/pied-piper)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)<br>
[![Coverage](https://img.shields.io/coveralls/github/cmudrc/pied-piper/main?label=Coverage)](https://coveralls.io/github/cmudrc/pied-piper?branch=main)
[![status](https://joss.theoj.org/papers/482e67b36285c6a9e5c00b15cc26607f/status.svg)](https://joss.theoj.org/papers/482e67b36285c6a9e5c00b15cc26607f)

</div>

<div align="center">
    <img src="https://raw.githubusercontent.com/cmudrc/pied-piper/refs/heads/main/assets/960px-Pied_Piper2.jpg" alt="KeePied Piper of HamelinpDelta" width="520">
    </br>
    <em>
        Illustration by Kate Greenaway for Robert Browning's "The Pied Piper of Hamelin"
    </em>
</div>

## Introduction

Living beings exist in perpetual tension with their environment, continually adapting to changes in their surroundings. This project aims to model the interdependent nature of life between humans and their environment.

## Documentation

Full documentation, including installation instructions, usage guides, API reference, examples, and contributor guidelines, is available at:
**[PiperABM Documentation](https://pied-piper.readthedocs.io)**

## Installation

Install the package using pip:
```sh
pip install piperabm
```
For advanced installation options, including animation support,
see the [Installation guide](https://pied-piper.readthedocs.io/latest/usage/installation.html).

## Usage

Once a `Model` instance is created, it automatically includes interconnected `infrastructure` and `society` components. The simulation is designed to explore how changes in one domain, such as agent behavior or infrastructure layout, affect the other over time. This interdependence forms the core of agent-based modeling within `PiperABM`.

```python
import piperabm as pa

model = pa.Model()
model.infrastructure.add_street(pos_1=[0, 0], pos_2=[-60, 40], name='road')
model.infrastructure.add_home(pos=[5, 0], id=1, name='home 1')
model.infrastructure.add_home(pos=[-60, 40], id=1, name='home 2')
model.infrastructure.bake()
model.society.generate(num=2, gini_index=0.4, average_balance=1000)
model.run(n=100, step_size=60)
```

For a guided walkthrough, see the
[step-by-step usage guide](https://pied-piper.readthedocs.io/latest/usage/step-by-step.html),
and for additional examples, refer to the
[examples](https://github.com/cmudrc/pied-piper/tree/main/examples) folder in the repository.

## Supported Python Versions

It has been tested and verified to work with Python versions **3.10** to **3.13**. While it is expected to work with older versions of Python (given compatible dependency versions), these environments have not been tested and are not officially supported.

## Contributing

Contributions are welcome, including bug fixes, documentation improvements, and extensions to existing model components.

Please see the full contributor guide in the documentation:
[Contributing Guide](https://pied-piper.readthedocs.io/latest/contributing.html)

This guide explains:
- Where to make changes in the codebase
- How tests are organized and run
- How to build the documentation locally

## License

Distributed under the MIT License. See [`LICENSE.txt`](https://github.com/cmudrc/pied-piper/blob/main/LICENSE) for more information.
