Metadata-Version: 2.4
Name: pumaguard
Version: 20.post101
Author-email: Nicolas Bock <nicolasbock@gmail.com>
Project-URL: Homepage, http://pumaguard.rtfd.io/
Project-URL: Repository, https://github.com/PEEC-Nature-Youth-Group/pumaguard
Requires-Python: <4.0,>=3.10
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: flask~=3.1
Requires-Dist: flask-cors~=6.0
Requires-Dist: matplotlib~=3.10
Requires-Dist: packaging~=25.0
Requires-Dist: pillow~=11.1
Requires-Dist: pyyaml~=6.0
Requires-Dist: tensorflow-cpu~=2.20; platform_machine != "aarch64" and platform_machine != "arm64"
Requires-Dist: tensorflow~=2.20; platform_machine == "aarch64" or platform_machine == "arm64"
Requires-Dist: torch~=2.9
Requires-Dist: ultralytics~=8.3
Requires-Dist: requests~=2.32
Provides-Extra: dev
Requires-Dist: ansible-lint~=25.2; platform_system != "Windows" and extra == "dev"
Requires-Dist: ansible~=10.7; extra == "dev"
Requires-Dist: bashate~=2.1; extra == "dev"
Requires-Dist: black~=25.9; extra == "dev"
Requires-Dist: build~=1.3; extra == "dev"
Requires-Dist: isort~=6.0; extra == "dev"
Requires-Dist: mypy~=1.18; extra == "dev"
Requires-Dist: passlib~=1.7; extra == "dev"
Requires-Dist: pylint~=3.3; extra == "dev"
Requires-Dist: pytest-cov~=7.0; extra == "dev"
Requires-Dist: pytest~=8.3; extra == "dev"
Provides-Extra: extra-dev
Requires-Dist: ipykernel~=6.29; extra == "extra-dev"
Requires-Dist: plotly~=6.0; extra == "extra-dev"
Dynamic: license-file

# PumaGuard

[![Build and Test Webpage](https://github.com/PEEC-Nature-Youth-Group/pumaguard/actions/workflows/build-webpage.yaml/badge.svg)](https://github.com/PEEC-Nature-Youth-Group/pumaguard/actions/workflows/build-webpage.yaml)

[![Test and package code](https://github.com/PEEC-Nature-Youth-Group/pumaguard/actions/workflows/test-and-package.yaml/badge.svg)](https://github.com/PEEC-Nature-Youth-Group/pumaguard/actions/workflows/test-and-package.yaml)

[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/PEEC-Nature-Youth-Group/pumaguard)

[![Open in Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com)

## Introduction

Please visit <http://pumaguard.rtfd.io/> for more information.

## Get PumaGuard

[![PyPI - Version](https://img.shields.io/pypi/v/pumaguard)](https://pypi.org/project/pumaguard/)

## GitHub Codespaces

If you do not want to install any new software on your computer you can use
GitHub Codespaces, which provide a development environment in your browser.

[![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/PEEC-Nature-Youth-Group/pumaguard/)

## Local Development Environment

You can set up a local development environment using either `uv` (recommended for speed) or `poetry`.

### Using uv (Recommended)

[uv](https://github.com/astral-sh/uv) is an extremely fast Python package installer and resolver.

Install `uv`:

```console
curl -LsSf https://astral.sh/uv/install.sh | sh
```

Or on Windows:

```console
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
```

Create a virtual environment and install dependencies:

```console
uv venv
source .venv/bin/activate  # On Linux/macOS
# or
.venv\Scripts\activate  # On Windows

# Install with development dependencies
uv pip install -e ".[dev,extra-dev]"
```

Or use `uv sync` for automatic environment management:

```console
uv sync --extra dev --extra extra-dev
```

### Using Poetry

Alternatively, you can use `poetry`:

```console
sudo apt install python3-poetry
poetry install
```

## Running the scripts on colab.research.google.com

[Google Colab](https://colab.research.google.com/) offers runtimes with GPUs
and TPUs, which make training a model much faster. In order to run the
[training script](scripts/train.py) in [Google
Colab](https://colab.research.google.com/), do the following from the terminal:

```console
git clone https://github.com/PEEC-Nature-Youth-Group/pumaguard.git
cd pumaguard
scripts/train.py --help
```

For example, if you want to train the model from row 1 in the notebook,

```console
scripts/train.py --notebook 1
```

## Running the server

The `pumaguard-server` watches a folder and classifies new files as they are
added to that folder. Run with

**Using uv:**

```console
uv run pumaguard-server FOLDER
```

**Using poetry:**

```console
poetry run pumaguard-server FOLDER
```

Where `FOLDER` is the folder to watch.

![Server Demo Session](docs/source/_static/server-demo.gif)

## Training new models

For reproducibility, training new models should be done via the train script
and all necessary data, i.e. images, and the resulting weights and history
should be committed to the repository.

1. Get a TPU instance on Colab or run the script on your local machine.
2. Open a terminal and run

   ```console
   git clone https://github.com/PEEC-Nature-Youth-Group/pumaguard.git
   cd pumaguard
   ```

3. Get help on how to use the script

   On Colab, run

   ```console
   ./scripts/pumaguard --help
   ./scripts/pumaguard train --help
   ```

   On your local machine with uv:

   ```console
   sudo apt install nvidia-cudnn
   uv sync --extra dev --extra extra-dev
   uv run pumaguard --help
   uv run pumaguard train --help
   ```

   Or with poetry:

   ```console
   sudo apt install nvidia-cudnn
   poetry install
   poetry run pumaguard --help
   poetry run pumaguard train --help
   ```

4. Train the model from scratch

   ```console
   ./scripts/pumaguard train --no-load --settings pumaguard-models/model_settings_6_pre-trained_512_512.yaml
   ```
