73 lines
1.6 KiB
ReStructuredText
73 lines
1.6 KiB
ReStructuredText
:orphan:
|
|
|
|
################################
|
|
Accelerate your code with Fabric
|
|
################################
|
|
|
|
|
|
***************************
|
|
Set accelerator and devices
|
|
***************************
|
|
|
|
Fabric enables you to take full advantage of the hardware on your system. It supports
|
|
|
|
- CPU
|
|
- GPU (NVIDIA, AMD, Apple Silicon)
|
|
- TPU
|
|
|
|
By default, Fabric recognizes the accelerator(s) on your system
|
|
|
|
.. code-block:: python
|
|
|
|
# Default settings
|
|
fabric = Fabric(accelerator="auto", devices="auto")
|
|
|
|
# Same as
|
|
fabric = Fabric()
|
|
|
|
This is the most flexible option and makes your code run on most systems.
|
|
You can also specifically set which accelerator to use:
|
|
|
|
.. code-block:: python
|
|
|
|
# CPU (slow)
|
|
fabric = Fabric(accelerator="cpu")
|
|
|
|
# GPU
|
|
fabric = Fabric(accelerator="gpu", devices=1)
|
|
|
|
# GPU (multiple)
|
|
fabric = Fabric(accelerator="gpu", devices=8)
|
|
|
|
# GPU: Apple M1/M2 only
|
|
fabric = Fabric(accelerator="mps", devices=8)
|
|
|
|
# GPU: NVIDIA CUDA only
|
|
fabric = Fabric(accelerator="cuda", devices=8)
|
|
|
|
# TPU
|
|
fabric = Fabric(accelerator="tpu", devices=8)
|
|
|
|
|
|
For running on multiple devices in parallel, also known as "distributed", read our guide for :doc:`Launching Multiple Processes <./launch>`.
|
|
|
|
|
|
----------
|
|
|
|
|
|
*****************
|
|
Access the Device
|
|
*****************
|
|
|
|
You can access the device at any time through ``fabric.device``.
|
|
This let's you replace boilerplate code like this:
|
|
|
|
.. code-block:: diff
|
|
|
|
- if torch.cuda.is_available():
|
|
- device = torch.device("cuda")
|
|
- else:
|
|
- device = torch.device("cpu")
|
|
|
|
+ device = fabric.device
|