Skip to main content

Simple GPU Queue: For running lots of smaller experiments on your handful of GPUs, designed for JAX

Project description

Simple GPU Queue

Simple GPU Queue: For running lots of smaller experiments on your handful of GPUs

Functional, minimal.

Quickstart

pip install simple_gpu_queue
simpleq_start 4 --memfrac-per-proc=0.45 # Start 2 processes per gpu, each taking 0.45 the total amount of GPU RAM available

Example python launch script

from simple_gpu_queue.simple_gpu_queue import GPUQueueClient
queue = GPUQueueClient(git_commit_id="most_recent")

# Send commands as a list of (command, stdout_file) tuples. Stdoutfile can be "" for no saving of stdout logging.
commands = [
    ("python -c 'import time; import jax.numpy as jnp; a=jnp.ones(5); time.sleep(1); print(\"I SLEPT HAPPY 1\")'", "testlogs/v1.txt"),
    ("python -c 'import time; import jax.numpy as jnp; a=jnp.ones(5); time.sleep(2); print(\"I SLEPT HAPPY 2\")'", ""),
    ("python -c 'import time; import jax.numpy as jnp; a=jnp.ones(5); time.sleep(3); print(\"I SLEPT HAPPY 3\")'", "testlogs/v3.txt"),
]

if queue.git_repo.is_dirty():
    user_input = input("Repo has uncommitted changes: continue? [Y/n] ").strip().lower()
    if user_input == 'n':
        raise ValueError("Aborting due to uncommitted changes in the repository.") 

queue.send_command_list(commands)

For Development

conda env create -f environment.yml
conda activate simple-gpu-queue
pip install -r requirements.txt
# pip install -r requirements-dev.txt

Check the server is running, navigate to http://localhost:5034/docs, test the routes

Upload to pypi (reference)

rm -rf dist/
python setup.py sdist bdist_wheel
twine upload dist/*

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

simple_gpu_queue-0.1.1.tar.gz (8.9 kB view details)

Uploaded Source

Built Distribution

simple_gpu_queue-0.1.1-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file simple_gpu_queue-0.1.1.tar.gz.

File metadata

  • Download URL: simple_gpu_queue-0.1.1.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.10.14

File hashes

Hashes for simple_gpu_queue-0.1.1.tar.gz
Algorithm Hash digest
SHA256 126589bf2df343253610ddef81bef6dbd2efa630c3014e8b059a30ee0d8e2cd7
MD5 7f32ad46bf9b2b22dcc7a29d2fdf3463
BLAKE2b-256 89744d617eb8aec68b8b2988e80e6e39931b605ef54c9612c5f0fb909c2c9f02

See more details on using hashes here.

File details

Details for the file simple_gpu_queue-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for simple_gpu_queue-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 008f865d9e83eb06c2bf90638c1944b07caa59350c115c10381f4a902f1d1e61
MD5 59ad2556a9c9cf1ce9279d2815a36e91
BLAKE2b-256 b98b852d671900d1838bb3d4e931966666cb9df52c970c203dd9e8d91ed62b76

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page