To install Intel(R) Extension for Scikit-learn*, use one of the following scenarios:
- Before You Begin
- Install via PIP
- Install from Anaconda Cloud
- Build from Sources
- Build from Sources with
conda-build
- Next Steps
NOTE: Intel(R) Extension for Scikit-learn* is also available as a part of Intel® AI Tools. If you already have it installed, you do not need to separately install the extension.
Check System and Memory Requirements.
- Operating systems: Linux*, Windows*
- Python versions: 3.9 through 3.13
- Devices: CPU, GPU
- Distribution channels:
- PyPI
- Anaconda Cloud from Conda-Forge Channel
- Anaconda Cloud from Intel Channel (https://software.repos.intel.com/python/conda/)
To prevent version conflicts, create and activate a new environment:
-
On Linux:
python -m venv env source env/bin/activate
-
On Windows:
python -m venv env .\env\Scripts\activate
Install scikit-learn-intelex
:
pip install scikit-learn-intelex
To prevent version conflicts, we recommend to create and activate a new environment.
-
Install into a newly created environment (recommended):
conda config --add channels conda-forge conda config --set channel_priority strict conda create -n env python=3.10 scikit-learn-intelex
NOTE: If you do not specify the Python version, the latest one is downloaded.
-
Install into your current environment:
conda config --add channels conda-forge conda config --set channel_priority strict conda install scikit-learn-intelex
We recommend this installation for the users of Intel® Distribution for Python.
-
Install into a newly created environment (recommended):
conda config --add channels https://software.repos.intel.com/python/conda/ conda config --set channel_priority strict conda create -n env python=3.10 scikit-learn-intelex
NOTE: If you do not specify the Python version, the latest one is downloaded.
-
Install into your current environment:
conda config --add channels https://software.repos.intel.com/python/conda/ conda config --set channel_priority strict conda install scikit-learn-intelex
NOTE: If you do not specify the version of Python, the latest one is downloaded.
-
Install into your current environment:
conda install scikit-learn-intelex
Intel(R) Extension for Scikit-learn* is easily built from the sources with the majority of the necessary prerequisites available with conda or pip.
The package is available for Windows* OS, Linux* OS, and macOS*.
Multi-node (distributed) and streaming support can be disabled if needed.
The build-process (using setup.py) happens in 4 stages:
- Creating C++ and Cython sources from oneDAL C++ headers
- Building oneDAL Python interfaces via cmake and pybind11
- Running Cython on generated sources
- Compiling and linking them
- Python version >= 3.9
- Jinja2
- Cython
- Numpy
- cmake and pybind11
- A C++ compiler with C++11 support
- Clang-Format version >=14
- Intel® oneAPI Data Analytics Library (oneDAL) version 2021.1 or later, but be mindful that the oneDAL version must be <= than that of scikit-learn-intelex (it's backwards compatible but not forwards compatible).
- You can use the pre-built
dal-devel
conda package from conda-forge channel
- You can use the pre-built
- MPI (optional, needed for distributed mode)
- You can use the pre-built
impi_rt
andimpi-devel
conda packages from conda-forge channel
- You can use the pre-built
- A DPC++ compiler (optional, needed for DPC++ interfaces)
SKLEARNEX_VERSION
: sets the package versionDALROOT
: sets the oneAPI Data Analytics Library pathMPIROOT
: sets the path to the MPI library that will be used for distributed mode support. Not used when usingNO_DIST=1
NO_DIST
: set to '1', 'yes' or alike to build without support for distributed modeNO_STREAM
: set to '1', 'yes' or alike to build without support for streaming modeNO_DPC
: set to '1', 'yes' or alike to build without support of oneDAL DPC++ interfacesOFF_ONEDAL_IFACE
: set to '1' to build without the support of oneDAL interfacesMAKEFLAGS
: the last-j
flag determines the number of threads for building the onedal extension. It will default to the number of CPU threads when not set.
Note: in order to use distributed mode, mpi4py
is also required, and needs to be built with the same MPI backend as scikit-learn-intelex.
Note: The -j
flag in the MAKEFLAGS
environment variable is superseded in setup.py
modes which support the --parallel
and -j
command line flags.
-
To install the package:
cd <checkout-dir> python setup.py install
-
To install the package in the development mode:
cd <checkout-dir> python setup.py develop
-
To install scikit-learn-intelex without checking for dependencies:
cd <checkout-dir> python setup.py install --single-version-externally-managed --record=record.txt
cd <checkout-dir> python setup.py develop --no-deps
Where:
- Keys
--single-version-externally-managed
and--no-deps
are required to not download daal4py after the installation of Intel(R) Extension for Scikit-learn. - The
develop
mode does not install the package but creates a.egg-link
in the deployment directory back to the project source-code directory. That way, you can edit the source code and see the changes without reinstalling the package after a small change. --single-version-externally-managed
is an option for Python packages instructing the setuptools module to create a package that the host's package manager can easily manage.
-
To build the python module without installing it:
cd <checkout-dir> python setup.py build_ext --inplace --force python setup.py build
Note: the setup.py
file will accept an optional argument --abs-rpath
on linux (for all of build
/install
/develop
/etc.) which will make it add the absolute path to oneDAL's shared objects (.so files) to the rpath of the scikit-learn-intelex extension's shared object files in order to load them automatically. This is not necessary when installing from pip or conda, but can be helpful for development purposes when using a from-source build of oneDAL that resides in a custom folder, as it won't assume that oneDAL's files will be found under default system paths. Example:
python setup.py build_ext --inplace --force --abs-rpath
python setup.py build --abs-rpath
Note: when building scikit-learn-intelex
from source with this option, it will use the oneDAL library with which it was compiled. oneDAL has dependencies on other libraries such as TBB, which is also distributed as a python package through pip
and as a conda
package. By default, a conda environment will first try to load TBB from its own packages if it is installed in the environment, which might cause issues if oneDAL was compiled with a system TBB instead of a conda one. In such cases, it is advised to either uninstall TBB from pip/conda (it will be loaded from the oneDAL library which links to it), or modify the order of search paths in environment variables like ${LD_LIBRARY_PATH}
.
Intel(R) Extension for Scikit-learn* is easily built from the sources using only one command and conda-build
utility.
- any
conda
distribution (miniforge
is recommended) conda-build
andconda-verify
installed in a conda environment- (Windows only) Microsoft Visual Studio*
- (optional) Intel(R) oneAPI DPC++/C++ Compiler
conda-build
config requires 2022 version of Microsoft Visual Studio* by default, you can specify another version in conda-recipe/conda_build_config.yaml
if needed.
In order to enable DPC++ interfaces support on Windows, you need to set DPCPPROOT
environment variable pointing to DPC++/C++ Compiler distribution.
Conda-forge distribution of DPC++ compiler is used by default on Linux, but you still can set your own distribution via DPCPPROOT
variable.
Create and verify scikit-learn-intelex
conda package with next command executed from root of sklearnex repo:
conda build .