Skip to main content

Scheduling Algorithms Gathered - collection of task graph scheduling algorithms

Project description

SAGA

CI PyPI version Python 3.11+

SAGA: Scheduling Algorithms Gathered.

Open in GitHub Codespaces

Introduction

SAGA – Scheduling Algorithms Gathered – is a Python toolkit/library for designing, comparing, and visualising DAG-based computational workflow-scheduler performance on heterogeneous compute networks (also known as dispersed computing). It ships with a collection of scheduling algorithms, including classic heuristics (HEFT, CPOP), brute-force baselines, SMT-based optimisers, and more, all under one cohesive API.

The algorithms are all implemented in Python using a common interface. Scripts for validating and comparing the performance of the algorithms are also provided.

Prerequisites

Python Version

All components of this repository have been tested with Python 3.11. To ensure compatibility and ease of environment management, we recommend using Conda.

To create a new Conda environment with Python 3.11:

conda create -n saga-env python=3.11
conda activate saga-env

For more information on managing Python versions with Conda, refer to the Conda documentation. (Managing Python — conda 25.3.0 documentation)

Usage

Installation

Local Installation

Clone the repository and install the requirements:

git clone https://github.com/ANRGUSC/saga.git
cd saga
pip install -e .

Running the Tests

Unit tests generate random task graphs and networks to verify scheduler correctness. They also check the RandomVariable utilities used for stochastic scheduling.

Locally

You can run the tests using pytest:

pytest ./tests

You may want to skip some of the tests that are too slow. You can do this ddirectly:

pytest ./tests -k "not (branching and (BruteForceScheduler or SMTScheduler))"

or by setting a timeout for the tests:

pytest ./tests --timeout=60

To run a specific test or scheduler-task combination, use the -k option. For example, to run the HeftScheduler tests on the diamond task graph:

pytest ./tests -k "HeftScheduler and diamond"

Running the Algorithms

The algorithms are implemented as Python modules. The following example shows how to run the HEFT algorithm on a workflow:

from saga.schedulers import HeftScheduler

scheduler = HeftScheduler()
network: Network = ...
task_graph: TaskGraph = ...
scheduler.schedule(network, task_graph)

Examples

The repository contains several example scripts illustrating different algorithms and scenarios. You can find them under scripts/examples. To run an example, use:

python scripts/examples/<example_name>/main.py

The table of contents in scripts/examples/Readme.md lists examples ranging from basic usage to dynamic networks and scheduler comparisons.

Experiments

To reproduce the experiments from papers using SAGA, see the experiments directory.

Acknowledgements

This work was supported in part by Army Research Laboratory under Cooperative Agreement W911NF-17-2-0196. This material is based upon work supported by the National Science Foundation under Award No. 2451267.

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

anrg_saga-2.0.3.tar.gz (69.7 kB view details)

Uploaded Source

Built Distribution

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

anrg_saga-2.0.3-py3-none-any.whl (90.9 kB view details)

Uploaded Python 3

File details

Details for the file anrg_saga-2.0.3.tar.gz.

File metadata

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

File hashes

Hashes for anrg_saga-2.0.3.tar.gz
Algorithm Hash digest
SHA256 dbad47250e85cc60664270155ccee3befe6068f3fe9fa703b3f402a36fd47c54
MD5 0b0d86423859237ae18c599a77b6ddc6
BLAKE2b-256 0f711e7edf274551b4007838cd2e1db933edbd9b8346ae35f945c3e64038fc31

See more details on using hashes here.

Provenance

The following attestation bundles were made for anrg_saga-2.0.3.tar.gz:

Publisher: publish.yml on ANRGUSC/saga

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

File details

Details for the file anrg_saga-2.0.3-py3-none-any.whl.

File metadata

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

File hashes

Hashes for anrg_saga-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 2ca372fac51aea85ef94e5f5c1ce1c80154380a493b4b8bc7d68637709d83bb9
MD5 139c8fe706c1116bcb5b4a35adef081c
BLAKE2b-256 070df630572de87630aae59f67aa072cecfeb39dcbc6e2f108c578cd770d112b

See more details on using hashes here.

Provenance

The following attestation bundles were made for anrg_saga-2.0.3-py3-none-any.whl:

Publisher: publish.yml on ANRGUSC/saga

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