A device picker for machine learning frameworks like PyTorch, TensorFlow, and JAX.
Project description
Device Picker
Description
Device Picker is a Python package designed to automatically select the appropriate computational device for machine learning tasks. It supports various frameworks like PyTorch, TensorFlow, and JAX. This tool is particularly useful in environments where multiple computational backends are available, as it simplifies the process of device selection based on the user's preferences and system capabilities.
Installation
To install Device Picker, use the following pip command:
pip install device-picker
For users on macOS with Apple Silicon (M1, M2 chips), to enable Metal support:
# for jax
pip install device-picker[jax_metal_support]
# for tensorflow
pip install device-picker[tensorflow_metal_support]
Usage
To use the Device Picker in your project, import the DevicePicker
class and create an instance of it. The class methods pytorch_device
, tensorflow_device
, and jax_device
can optionally take a device name as an argument. If a device name is given, the Device Picker will attempt to use the specified device if it is available. If no device name is provided or if the specified device is not available, the Device Picker will automatically select a suitable default device.
from device_picker import DevicePicker
# Create an instance of DevicePicker
device_picker = DevicePicker()
# Select a specific device for PyTorch, or let the picker choose automatically
pytorch_device = device_picker.pytorch_device('cuda') # You can specify 'cuda', 'mps', or leave it empty
# Select a specific device for TensorFlow
tensorflow_device = device_picker.tensorflow_device('GPU') # Options could be 'GPU', 'CPU', etc.
# Select a specific device for JAX
jax_device = device_picker.jax_device('gpu') # Choose 'gpu', 'tpu', or others
Running Tests
To run the unit tests for Device Picker, execute the following command in the root directory of the project:
make test
Contributing
Contributions to Device Picker are welcome! Please feel free to submit pull requests, open issues, or suggest improvements.
License
Device Picker is released under the MIT License. See the LICENSE file for more details.
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 device_picker-0.1.2.tar.gz
.
File metadata
- Download URL: device_picker-0.1.2.tar.gz
- Upload date:
- Size: 2.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dcc20fb90f7b7e8775e5cdab9b88adc2b98cdd8af54a9b933a27a1adb4d5ad74 |
|
MD5 | a660ac7e8b63a37c3e850cc76165f6c8 |
|
BLAKE2b-256 | 150d3b2f782c82560f018a73369b494cb6465932b4d051ffe87fb2e4fbd1c024 |
File details
Details for the file device_picker-0.1.2-py3-none-any.whl
.
File metadata
- Download URL: device_picker-0.1.2-py3-none-any.whl
- Upload date:
- Size: 3.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 05781bdc304198478e76ddce90126fdea6cd98e22ed7a7c37c4ba6ef1a23722c |
|
MD5 | 7f702c1ba259c7966a03576058d08677 |
|
BLAKE2b-256 | 016cc345c27d877f746bd4087f439bb0024d05e43f8553b8f68a4a2ee3a4bab7 |