Managing virtual packages

"Virtual" packages are injected into the conda solver to allow real packages to depend on features present on the system that cannot be managed directly by conda, like system driver versions or CPU features. Virtual packages are not real packages and not displayed by conda list. Instead conda runs a small bit of code to detect the presence or absence of the system feature that corresponds to the package. The currently supported list of virtual packages includes:

  • __cuda: Maximum version of CUDA supported by the display driver.

  • __osx: OSX version if applicable.

  • __glibc: Version of glibc supported by the OS.

  • __linux: Available when running on Linux.

  • __unix: Available when running on OSX or Linux.

  • __win: Available when running on Win.

Other virtual packages will be added in future conda releases. These are denoted by a leading double-underscore in the package name.

Note

Note that as of version 22.11.0, virtual packages are implemented as conda plugins.

Listing detected virtual packages

Use the terminal or an Anaconda Prompt for the following steps.

To see the list of detected virtual packages, run:

conda info

If a package is detected, you will see it listed in the virtual packages section, as shown in this example:

    active environment : base
   active env location : /Users/demo/dev/conda/devenv
           shell level : 1
      user config file : /Users/demo/.condarc
populated config files : /Users/demo/.condarc
         conda version : 4.6.3.post8+8f640d35a
   conda-build version : 3.17.8
        python version : 3.7.2.final.0
      virtual packages : __cuda=10.0
      base environment : /Users/demo/dev/conda/devenv (writable)
          channel URLs : https://repo.anaconda.com/pkgs/main/osx-64
                         https://repo.anaconda.com/pkgs/main/noarch
                         https://repo.anaconda.com/pkgs/free/osx-64
                         https://repo.anaconda.com/pkgs/free/noarch
                         https://repo.anaconda.com/pkgs/r/osx-64
                         https://repo.anaconda.com/pkgs/r/noarch
         package cache : /Users/demo/dev/conda/devenv/pkgs
                         /Users/demo/.conda/pkgs
      envs directories : /Users/demo/dev/conda/devenv/envs
                         /Users/demo/.conda/envs
              platform : osx-64
            user-agent : conda/4.6.3.post8+8f640d35a requests/2.21.0 CPython/3.7.2 Darwin/17.7.0 OSX/10.13.6
               UID:GID : 502:20
            netrc file : None
          offline mode : False

Overriding detected packages

For troubleshooting, it is possible to override virtual package detection using an environment variable. Supported variables include:

  • CONDA_OVERRIDE_CUDA - CUDA version number or set to "" for no CUDA detected.

  • CONDA_OVERRIDE_OSX - OSX version number or set to "" for no OSX detected.

  • CONDA_OVERRIDE_GLIBC - GLIBC version number or set to "" for no GLIBC. This only applies on Linux.