Skip to content

Workflow file for this run

name: oneDAL DPCPP nightly sklearnex
on:
workflow_dispatch:
env:
PYTHON_VERSION: 3.9
SKLEARN_VERSION: 1.1
TBB_VERSION: 2021.13
DPCPP_VERSION: 2024.2
DPCTL_VERSION: 0.17.0
DPNP_VERSION: 0.15.0
jobs:
sklearn_lnx:
name: lnx_Python3.9_Sklearn1.1
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Python
uses: actions/setup-python@v5
with:
python-version: ${{ env.PYTHON_VERSION }}
- name: Get run ID of "oneDAL-nightly" workflow
id: get-run-id
run: |
OTHER_REPO="${{ github.repository }}"
WF_NAME="oneDAL-nightly"
RUN_ID=`gh run --repo ${OTHER_REPO} list --workflow "${WF_NAME}" --json databaseId --status completed --jq .[0].databaseId`
echo "Detected latest run id of ${RUN_ID} for workflow ${WF_NAME}"
echo "run-id=${RUN_ID}" >> "$GITHUB_OUTPUT"
env:
GH_TOKEN: ${{ github.token }}
- name: Download oneDAL build artifact
uses: actions/download-artifact@v4
with:
name: __release_lnx
github-token: ${{ github.token }}
repository: ${{ github.repository }}
run-id: ${{ steps.get-run-id.outputs.run-id }}
path: ./__release_lnx
- name: apt-get
run: sudo apt-get update && sudo apt-get install -y clang-format
- name: dpcpp installation
run: bash .ci/scripts/install_dpcpp.sh
- name: describe system
run: bash .ci/scripts/describe_system.sh
- name: Install develop requirements
run: |
python -m venv env2
source ./env2/bin/activate
pip install -r dependencies-dev
pip list
echo "DPCPPROOT=/opt/intel/oneapi/compiler/latest" >> "$GITHUB_ENV"
echo "NO_DIST=1" >> "$GITHUB_ENV"
- name: Build daal4py/sklearnex
run: |
source ./env2/bin/activate
source /opt/intel/oneapi/compiler/latest/env/vars.sh # prepare icpx
source /opt/intel/oneapi/tbb/latest/env/vars.sh # prepare tbb
source ./__release_lnx/daal/latest/env/vars.sh # prepare oneDAL
python setup.py install --single-version-externally-managed --record=record.txt
python setup_sklearnex.py install --single-version-externally-managed --record=record_sklearnex.txt
- name: Install testing requirements
run: |
source ./env2/bin/activate
source /opt/intel/oneapi/compiler/latest/env/vars.sh # prepare icpx
source /opt/intel/oneapi/tbb/latest/env/vars.sh # prepare tbb
source ./__release_lnx/daal/latest/env/vars.sh # prepare oneDAL
bash .ci/scripts/setup_sklearn.sh ${{ env.SKLEARN_VERSION }}
pip install --upgrade -r requirements-test.txt
pip install $(python .ci/scripts/get_compatible_scipy_version.py) pyyaml
if [ $(echo ${{ env.PYTHON_VERSION }} | grep '3.9\|3.11') ]; then pip install dpctl==${{ env.DPCTL_VERSION }} dpnp==${{ env.DPNP_VERSION }}; fi
pip list
- name: Sklearnex testing
working-directory: ./.ci
run: |
source ../env2/bin/activate
source /opt/intel/oneapi/compiler/latest/env/vars.sh # prepare icpx
source /opt/intel/oneapi/tbb/latest/env/vars.sh # prepare tbb
source ../__release_lnx/daal/latest/env/vars.sh # prepare oneDAL
../conda-recipe/run_test.sh
- name: Sklearn testing
run: |
source env2/bin/activate
source /opt/intel/oneapi/compiler/latest/env/vars.sh # prepare icpx
source /opt/intel/oneapi/tbb/latest/env/vars.sh # prepare tbb
source __release_lnx/daal/latest/env/vars.sh # prepare oneDAL
bash .ci/scripts/run_sklearn_tests.sh cpu
- name: Sklearn testing [preview]
run: |
source env2/bin/activate
source /opt/intel/oneapi/compiler/latest/env/vars.sh # prepare icpx
source /opt/intel/oneapi/tbb/latest/env/vars.sh # prepare tbb
source __release_lnx/daal/latest/env/vars.sh # prepare oneDAL
export SKLEARNEX_PREVIEW='YES'
bash .ci/scripts/run_sklearn_tests.sh cpu
sklearn_win:
name: win_Python3.9_Sklearn1.1
runs-on: windows-2022
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Python
uses: actions/setup-python@v5
with:
python-version: ${{ env.PYTHON_VERSION }}
- name: Get run ID of "oneDAL-nightly" workflow
id: get-run-id
shell: bash
run: |
OTHER_REPO="${{ github.repository }}"
WF_NAME="oneDAL-nightly"
RUN_ID=`gh run --repo ${OTHER_REPO} list --workflow "${WF_NAME}" --json databaseId --status completed --jq .[0].databaseId`
echo "Detected latest run id of ${RUN_ID} for workflow ${WF_NAME}"
echo "run-id=${RUN_ID}" >> "$GITHUB_OUTPUT"
env:
GH_TOKEN: ${{ github.token }}
- name: Download oneDAL build artifact
uses: actions/download-artifact@v4
with:
name: __release_win
github-token: ${{ github.token }}
repository: ${{ github.repository }}
run-id: ${{ steps.get-run-id.outputs.run-id }}
path: .\__release_win
- name: Download DPCPP compiler artifact
uses: actions/download-artifact@v4
with:
name: icx_compiler
github-token: ${{ github.token }}
repository: ${{ github.repository }}
run-id: ${{ steps.get-run-id.outputs.run-id }}
path: .
- name: Download Intel OpenCL CPU Runtime artifact
uses: actions/download-artifact@v4
with:
name: opencl_rt_installer
github-token: ${{ github.token }}
repository: ${{ github.repository }}
run-id: ${{ steps.get-run-id.outputs.run-id }}
path: .
- name: Unzip Compiler
shell: cmd
run: |
tar -xvzf icx.zip
echo "Unzip complete"
- name: Install Intel OpenCL CPU Runtime
run: |
echo "Installing OpenCL Runtime"
Start-Process msiexec -ArgumentList "/i .\opencl_rt.msi /qn" -Wait
- name: Set Environment Variables
shell: bash
run: |
echo "C:\msys64\usr\bin;C:\Program Files (x86)\Common Files\Intel\Shared Libraries\bin;" >> $GITHUB_PATH
# Disable SPMD testing
echo "NO_DIST=1" >> "$GITHUB_ENV"
- name: Install dependencies
shell: cmd
run: |
python -m venv env2
call .\env2\Scripts\activate.bat
pip install --upgrade setuptools
pip install cpufeature clang-format pyyaml
pip install -r dependencies-dev
- name: System info
shell: cmd
run: |
call .\dpcpp\compiler\${{ env.DPCPP_VERSION }}\env\vars.bat
call .\dpcpp\compiler\${{ env.DPCPP_VERSION }}\bin\sycl-ls.exe
dir .
bash .ci/scripts/describe_system.sh
- name: Build daal4py/sklearnex
shell: cmd
run: |
call .\env2\Scripts\activate.bat
call .\.github\scripts\activate_components.bat ${{ env.DPCPP_VERSION }} ${{ env.TBB_VERSION }}
set PREFIX=.
set PYTHON=python
call .\conda-recipe\bld.bat
IF %ERRORLEVEL% neq 0 EXIT /b %ERRORLEVEL%
set CONDA_PREFIX=%DALROOT%
python setup_sklearnex.py install --single-version-externally-managed --record=record_sklearnex.txt
- name: Install testing requirements
shell: cmd
run: |
call .\env2\Scripts\activate.bat
call .\.github\scripts\activate_components.bat ${{ env.DPCPP_VERSION }} ${{ env.TBB_VERSION }}
bash .ci/scripts/setup_sklearn.sh ${{ env.SKLEARN_VERSION }}
pip install --upgrade -r requirements-test.txt
for /f "delims=" %%c in ('python .ci\scripts\get_compatible_scipy_version.py') do set SCIPY_VERSION=%%c
pip install %SCIPY_VERSION%
# TEMPORARY FIX FOR ISSUES IN DPCTL PIP INSTALLATION
set DPCTL_SUPPORTED=3.9 3.11
for %%i in (%DPCTL_SUPPORTED%) do if ${{ env.PYTHON_VERSION }}==%%i pip install dpctl==${{ env.DPCTL_VERSION }} dpnp==${{ env.DPNP_VERSION }}
pip list
- name: Sklearnex testing
shell: cmd
run: |
call .\env2\Scripts\activate.bat
call .\.github\scripts\activate_components.bat ${{ env.DPCPP_VERSION }} ${{ env.TBB_VERSION }}
set PYTHON=python
cd ..
call scikit-learn-intelex\conda-recipe\run_test.bat scikit-learn-intelex
- name: Sklearn testing
shell: cmd
run: |
call .\env2\Scripts\activate.bat
call .\.github\scripts\activate_components.bat ${{ env.DPCPP_VERSION }} ${{ env.TBB_VERSION }}
bash .ci/scripts/run_sklearn_tests.sh
- name: Sklearn testing [preview]
shell: cmd
run: |
call .\env2\Scripts\activate.bat
call .\.github\scripts\activate_components.bat ${{ env.DPCPP_VERSION }} ${{ env.TBB_VERSION }}
set SKLEARNEX_PREVIEW=YES
bash .ci/scripts/run_sklearn_tests.sh
dpctl:
name: dpctl_test
runs-on: windows-2022
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Python
uses: actions/setup-python@v5
with:
python-version: ${{ env.PYTHON_VERSION }}
- name: Install intel opencl_rt
run: |
$env:PATH="C:\msys64\usr\bin;$env:PATH"
echo $env:PATH=C:\msys64\usr\bin;$env:PATH >> $env.GITHUB_ENV
pip install cpufeature
echo "Download intel opencl runtime"
wget -q -O opencl_installer.exe https://registrationcenter-download.intel.com/akdlm/IRC_NAS/d9883ab0-0e26-47fd-9612-950b95460d72/w_opencl_runtime_p_2024.2.0.980.exe
echo "Unpacking opencl runtime installer"
Start-Process ".\opencl_installer.exe" -ArgumentList "--s --x --f ocl" -Wait
echo "Installing opencl runtime"
Start-Process msiexec -ArgumentList "/i ocl\w_opencl_runtime_p_2024.2.0.980.msi /qn" -Wait
echo "opencl installed"
$env:PATH="C:\Program Files (x86)\Common Files\Intel\Shared Libraries\bin";$env:PATH >> $env.GITHUB_ENV
- name: Install dpctl pip venv
shell: cmd
run: |
echo %PATH%
set PATH="C:\msys64\usr\bin;C:\Program Files (x86)\Common Files\Intel\Shared Libraries\bin;"%PATH%
python -m venv env2
call .\env2\Scripts\activate.bat
set DPCTL_SUPPORTED=3.9 3.11
set CONDA_PREFIX=.\env2
FOR %%i IN (%DPCTL_SUPPORTED%) DO if ${{ env.PYTHON_VERSION }}==%%i python -m pip install --index-url https://pypi.anaconda.org/intel/simple dpctl==${{ env.DPCTL_VERSION }} dpnp==${{ env.DPNP_VERSION }}
Powershell.exe -executionpolicy bypass -File .\env2\Scripts\set-intel-ocl-icd-registry.ps1
python -c "import os, os.path, site; path_to_env = site.getsitepackages()[0]; path_to_libs = os.path.join(path_to_env, 'Library', 'bin'); temp=os.add_dll_directory(path_to_libs) if os.path.exists(path_to_libs) else None; import dpctl; print(dpctl.lsplatform(2))"
python -c "import dpctl; print(dpctl.lsplatform(2))"
python -c "import site; print(site.USER_SITE)"
pip list
- name: Install dpctl conda
shell: cmd
run: |
set PATH=C:\msys64\usr\bin;%PATH%
call C:\Miniconda\condabin\conda.bat config --add channels https://software.repos.intel.com/python/conda/
call C:\Miniconda\condabin\conda.bat config --append channels conda-forge
call C:\Miniconda\condabin\conda.bat create --name dpctl_env dpctl
call C:\Miniconda\condabin\conda.bat activate dpctl_env
echo %CONDA_PREFIX%
python -c "import os, os.path, site; path_to_env = site.getsitepackages()[0]; print(path_to_env); path_to_libs = os.path.join(path_to_env, 'Library', 'bin'); os.add_dll_directory(path_to_libs);os.add_dll_directory(os.path.join(path_to_env, 'Lib', 'site-packages', 'dpctl')); import dpctl; print(dpctl.lsplatform(2))"
python -c "import dpctl; print(dpctl.lsplatform(2))"
python -c "import site; print(site.USER_SITE)"