Pytorch Integration Guide#
Overview#
This guide explains how to integrate PyTorch with pixi
, it supports multiple ways of installing PyTorch.
- Install PyTorch using
conda-forge
Conda channel (Recommended) - Install PyTorch using
pypi
, using ouruv
's integration. (Most versions available) - Install PyTorch using
pytorch
Conda channel (Legacy)
With these options you can choose the best way to install PyTorch based on your requirements.
System requirements#
In the context of PyTorch, system requirements help pixi understand whether it can install and use CUDA-related packages. These requirements ensure compatibility during dependency resolution.
The key mechanism here is the use of virtual packages like __cuda.
Virtual packages signal the available system capabilities (e.g., CUDA version).
By specifying system-requirements.cuda = "12"
, you are telling pixi that CUDA version 12 is available and can be used during resolution.
For example:
- If a package depends on
__cuda >= 12
, pixi will resolve the correct version. - If a package depends on
__cuda
without version constraints, any available CUDA version can be used.
Without setting the appropriate system-requirements.cuda
, pixi will default to installing the CPU-only versions of PyTorch and its dependencies.
A more indepth explanation of system requirements can be found here.
Installing from Conda-forge#
You can install PyTorch using the conda-forge
channel.
These are the conda-forge community maintained builds of PyTorch.
You can make direct use of the Nvidia provided packages to make sure the packages can work together.
To deliberately install a specific version of the cuda
packages you can depend on the cuda-version
package which will then be interpreted by the other packages during resolution.
The cuda-version
package constraints the version of the __cuda
virtual package and cudatoolkit
package.
This ensures that the correct version of the cudatoolkit
package is installed and the tree of dependencies is resolved correctly.
With conda-forge
you can also install the cpu
version of PyTorch.
A common use-case is having two environments, one for CUDA machines and one for non-CUDA machines.
[project]
channels = ["https://prefix.dev/conda-forge"]
name = "pytorch-conda-forge"
platforms = ["linux-64"]
[feature.gpu.system-requirements]
cuda = "12.0"
[feature.gpu.dependencies]
cuda-version = "12.6.*"
pytorch-gpu = "*"
[feature.cpu.dependencies]
pytorch-cpu = "*"
[environments]
cpu = ["cpu"]
default = ["gpu"]
[project]
name = "pytorch-conda-forge"
[tool.pixi.project]
channels = ["https://prefix.dev/conda-forge"]
platforms = ["linux-64"]
[tool.pixi.feature.gpu.system-requirements]
cuda = "12.0"
[tool.pixi.feature.gpu.dependencies]
cuda-version = "12.6"
pytorch-gpu = "*"
[tool.pixi.feature.cpu.dependencies]
pytorch-cpu = "*"
[tool.pixi.environments]
cpu = ["cpu"]
default = ["gpu"]
Running these environments then can be done with the pixi run
command.
pixi run --environment cpu python -c "import torch; print(torch.cuda.is_available())"
pixi run -e gpu python -c "import torch; print(torch.cuda.is_available())"
Now you should be able to extend that with your dependencies and tasks.
Here are some links to notable packages:
Installing from PyPi#
Thanks to the integration with uv
we can also install PyTorch from pypi
.
Mixing [dependencies]
and [pypi-dependencies]
When using this approach for the torch
package, you should also install the packages that depend on torch
from pypi
.
Thus, not mix the PyPI packages with Conda packages if there are dependencies from the Conda packages to the PyPI ones.
The reason for this is that our resolving is a two step process, first resolve the Conda packages and then the PyPI packages. Thus this can not succeed if we require a Conda package to depend on a PyPI package.
Pytorch index#
PyTorch packages are provided through a custom index, these are similar to Conda channels, which are maintained by the PyTorch team. To install PyTorch from the PyTorch index, you need to add the indexes to manifest. Best to do this per dependency to force the index to be used.
- CPU only: https://download.pytorch.org/whl/cpu
- CUDA 11.8: https://download.pytorch.org/whl/cu118
- CUDA 12.1: https://download.pytorch.org/whl/cu121
- CUDA 12.4: https://download.pytorch.org/whl/cu124
- ROCm6: https://download.pytorch.org/whl/rocm6.2
[project]
channels = ["https://prefix.dev/conda-forge"]
name = "pytorch-pypi"
platforms = ["osx-arm64", "linux-64", "win-64"]
[dependencies]
# We need a python version that is compatible with pytorch
python = ">=3.11,<3.13"
[pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cu124" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cu124" }
[target.osx.pypi-dependencies]
# OSX has no CUDA support so use the CPU here
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cpu" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cpu" }
[project]
name = "pytorch-pypi"
# We need a python version that is compatible with pytorch
requires-python = ">= 3.11,<3.13"
[tool.pixi.project]
channels = ["https://prefix.dev/conda-forge"]
platforms = ["osx-arm64", "linux-64", "win-64"]
[tool.pixi.pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cu124" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cu124" }
[tool.pixi.target.osx.pypi-dependencies]
# OSX has no CUDA support so use the CPU here
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cpu" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cpu" }
You can tell pixi to use multiple environment for the multiple versions of PyTorch, either cpu
or gpu
.
[project]
channels = ["https://prefix.dev/conda-forge"]
name = "pytorch-pypi-envs"
platforms = ["linux-64", "win-64"]
[dependencies]
# We need a python version that is compatible with pytorch
python = ">=3.11,<3.13"
[feature.gpu]
system-requirements = { cuda = "12.0" }
[feature.gpu.pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cu124" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cu124" }
[feature.cpu.pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cpu" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cpu" }
[environments]
gpu = { features = ["gpu"] }
# Make CPU the default environment
default = { features = ["cpu"] }
[project]
name = "pytorch-pypi-envs"
# We need a python version that is compatible with pytorch
requires-python = ">= 3.11,<3.13"
[tool.pixi.project]
channels = ["https://prefix.dev/conda-forge"]
platforms = ["linux-64", "win-64"]
[tool.pixi.feature.gpu]
system-requirements = { cuda = "12.0" }
[tool.pixi.feature.gpu.pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cu124" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cu124" }
[tool.pixi.feature.cpu.pypi-dependencies]
torch = { version = ">=2.5.1", index = "https://download.pytorch.org/whl/cpu" }
torchvision = { version = ">=0.20.1", index = "https://download.pytorch.org/whl/cpu" }
[tool.pixi.environments]
gpu = { features = ["gpu"] }
# Make CPU the default environment
default = { features = ["cpu"] }
Running these environments then can be done with the pixi run
command.
pixi run --environment cpu python -c "import torch; print(torch.__version__); print(torch.cuda.is_available())"
pixi run -e gpu python -c "import torch; print(torch.__version__); print(torch.cuda.is_available())"
Mixing MacOS and CUDA with pypi-dependencies
#
When using pypi-dependencies, pixi creates a “solve” environment to resolve the PyPI dependencies. This process involves installing the Conda dependencies first and then resolving the PyPI packages within that environment.
This can become problematic if you’re on a macOS machine and trying to resolve the CUDA version of PyTorch for Linux or Windows. Since macOS doesn’t support those environments, the Conda dependencies for CUDA will fail to install, preventing proper resolution.
Current Status: The pixi maintainers are aware of this limitation and are actively working on a solution to enable cross-platform dependency resolution for such cases.
In the meantime, you may need to run the resolution process on a machine that supports CUDA, such as a Linux or Windows host.
Installing from PyTorch channel#
Warning
This depends on the non-free main
channel from Anaconda and mixing it with conda-forge
can lead to conflicts.
Note
This is the legacy way of installing pytorch, this will not be updated to later versions as pytorch has discontinued their channel.
[project]
name = "pytorch-from-pytorch-channel"
# `main` is not free! It's a paid channel for organizations over 200 people.
channels = ["main", "nvidia", "pytorch"]
platforms = ["osx-arm64", "linux-64", "win-64"]
[feature.gpu.system-requirements]
cuda = "12.0"
[dependencies]
pytorch = "*"
[environments]
gpu = ["gpu"]
[project]
name = "pytorch-from-pytorch-channel"
requires-python = ">= 3.11, < 3.13"
version = "0.1.0"
[tool.pixi.project]
# `main` is not free! It's a paid channel for organizations over 200 people.
channels = ["main", "nvidia", "pytorch"]
platforms = ["osx-arm64", "linux-64", "win-64"]
[tool.pixi.feature.gpu.system-requirements]
cuda = "12.0"
[tool.pixi.dependencies]
pytorch = "*"
[tool.pixi.environments]
gpu = ["gpu"]
Troubleshooting#
When you had trouble figuring out why your PyTorch installation is not working, please share your solution or tips with the community by creating a PR to this documentation.
Testing the pytorch
installation#
You can verify your PyTorch installation with this command:
Checking the CUDA version of your machine#
To check which CUDA version pixi detects on your machine, run:
Example output:
If __cuda
is missing, you can verify your system’s CUDA version using NVIDIA tools:
To check the version of the CUDA toolkit installed in your environment:
Reasons for broken installations#
Broken installations often result from mixing incompatible channels or package sources:
-
Mixing Conda Channels
Using both
conda-forge
and the legacypytorch
channel can cause conflicts. Choose one channel and stick with it to avoid issues in the installed environment. -
Mixing Conda and PyPI Packages
If you install PyTorch from pypi, all packages that depend on torch must also come from PyPI. Mixing Conda and PyPI packages within the same dependency chain leads to conflicts.
To summarize:
- Pick one Conda channel (conda-forge or pytorch) to fetch
pytorch
from, and avoid mixing. - For PyPI installations, ensure all related packages come from PyPI.
GPU version of pytorch
not installing:#
- Using conda-Forge
- Ensure
system-requirements.cuda
is set to inform pixi to install CUDA-enabled packages. - Use the
cuda-version
package to pin the desired CUDA version.
- Ensure
- Using PyPI
- Use the appropriate PyPI index to fetch the correct CUDA-enabled wheels.
Environment Resolution Failures#
If you see an error like this: ABI tag mismatch
├─▶ failed to resolve pypi dependencies
╰─▶ Because only the following versions of torch are available:
torch<=2.5.1
torch==2.5.1+cpu
and torch==2.5.1 has no wheels with a matching Python ABI tag, we can conclude that torch>=2.5.1,<2.5.1+cpu cannot be used.
And because torch==2.5.1+cpu has no wheels with a matching platform tag and you require torch>=2.5.1, we can conclude that your requirements are
unsatisfiable.
Solution:
- Check your Python version and ensure it’s compatible with the PyPI wheels for
torch
. The ABI tag is based on the Python version is embedded in the wheel filename, e.g.cp312
for Python 3.12. - If needed, lower the
requires-python
orpython
version in your configuration. - For example, as of now, PyTorch doesn’t fully support Python 3.13; use Python 3.12 or earlier.
Platform tag mismatch
├─▶ failed to resolve pypi dependencies
╰─▶ Because only the following versions of torch are available:
torch<=2.5.1
torch==2.5.1+cu124
and torch>=2.5.1 has no wheels with a matching platform tag, we can conclude that torch>=2.5.1,<2.5.1+cu124 cannot be used.
And because you require torch>=2.5.1, we can conclude that your requirements are unsatisfiable.
Example Issue:
torch==2.5.1+cu124
(CUDA 12.4) was attempted on an osx
machine, but this version is only available for linux-64
and win-64
.
Solution: - Use the correct PyPI index for your platform: - CPU-only: Use the cpu index for all platforms. - CUDA versions: Use cu124 for linux-64 and win-64.
Correct Indexes: - CPU: https://download.pytorch.org/whl/cpu - CUDA 12.4: https://download.pytorch.org/whl/cu124
This ensures PyTorch installations are compatible with your system’s platform and Python version.