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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 126589bf2df343253610ddef81bef6dbd2efa630c3014e8b059a30ee0d8e2cd7 |
|
MD5 | 7f32ad46bf9b2b22dcc7a29d2fdf3463 |
|
BLAKE2b-256 | 89744d617eb8aec68b8b2988e80e6e39931b605ef54c9612c5f0fb909c2c9f02 |
File details
Details for the file simple_gpu_queue-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: simple_gpu_queue-0.1.1-py3-none-any.whl
- Upload date:
- Size: 9.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.10.14
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 008f865d9e83eb06c2bf90638c1944b07caa59350c115c10381f4a902f1d1e61 |
|
MD5 | 59ad2556a9c9cf1ce9279d2815a36e91 |
|
BLAKE2b-256 | b98b852d671900d1838bb3d4e931966666cb9df52c970c203dd9e8d91ed62b76 |