Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use CUDA math wheels #5966

Merged
10 changes: 9 additions & 1 deletion ci/build_wheel.sh
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,14 @@ SKBUILD_CMAKE_ARGS="-DDETECT_CONDA_ENV=OFF;-DDISABLE_DEPRECATION_WARNINGS=ON;-DC
--disable-pip-version-check

mkdir -p final_dist
python -m auditwheel repair -w final_dist dist/*
python -m auditwheel repair -w final_dist \
--exclude "libcublas.so.12" \
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
--exclude "libcublasLt.so.12" \
--exclude "libcufft.so.11" \
--exclude "libcurand.so.10" \
--exclude "libcusolver.so.11" \
--exclude "libcusparse.so.12" \
--exclude "libnvJitLink.so.12" \
dist/*

RAPIDS_PY_WHEEL_NAME="cuml_${RAPIDS_PY_CUDA_SUFFIX}" rapids-upload-wheels-to-s3 final_dist
21 changes: 21 additions & 0 deletions dependencies.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -89,6 +89,7 @@ files:
table: project
includes:
- py_run
- cuda
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
py_test:
output: pyproject
pyproject_dir: python/cuml
Expand Down Expand Up @@ -370,6 +371,26 @@ dependencies:
- *libcusolver114
- *libcusparse_dev114
- *libcusparse114
- output_types: pyproject
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
matrices:
- matrix:
cuda: "12.*"
packages:
- nvidia-cublas-cu12
- nvidia-cufft-cu12
- nvidia-curand-cu12
- nvidia-cusparse-cu12
- nvidia-cusolver-cu12
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
- matrix:
cuda: "11.*"
packages:
- matrix:
packages:
- nvidia-cublas
msarahan marked this conversation as resolved.
Show resolved Hide resolved
- nvidia-cufft
- nvidia-curand
- nvidia-cusparse
- nvidia-cusolver
docs:
common:
- output_types: [conda, requirements]
Expand Down
22 changes: 20 additions & 2 deletions python/cuml/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,10 @@ include(rapids-cython-core)

set(CUML_PYTHON_TREELITE_TARGET treelite::treelite)

if(NOT ${CUML_CPU})
if(NOT CUML_CPU)
if(NOT cuml_FOUND)
find_package(CUDAToolkit REQUIRED)

set(BUILD_CUML_TESTS OFF)
set(BUILD_PRIMS_TESTS OFF)
set(BUILD_CUML_C_LIBRARY OFF)
Expand All @@ -85,11 +87,16 @@ if(NOT ${CUML_CPU})

# Statically link dependencies if building wheels
set(CUDA_STATIC_RUNTIME ON)
set(CUDA_STATIC_MATH_LIBRARIES ON)
set(CUML_USE_RAFT_STATIC ON)
set(CUML_USE_FAISS_STATIC ON)
set(CUML_USE_TREELITE_STATIC ON)
set(CUML_USE_CUMLPRIMS_MG_STATIC ON)
# Use the CUDA library wheels if possible
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
if(CUDAToolkit_VERSION VERSION_GREATER_EQUAL 12.0)
set(CUDA_STATIC_MATH_LIBRARIES OFF)
else()
set(CUDA_STATIC_MATH_LIBRARIES ON)
endif()
# Don't install the static libs into wheels
set(CUML_EXCLUDE_RAFT_FROM_ALL ON)
set(RAFT_EXCLUDE_FAISS_FROM_ALL ON)
Expand All @@ -98,6 +105,17 @@ if(NOT ${CUML_CPU})

add_subdirectory(${CUML_CPP_SRC} cuml-cpp EXCLUDE_FROM_ALL)

if(NOT CUDA_STATIC_MATH_LIBRARIES)
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
set_property(TARGET ${CUML_CPP_TARGET} PROPERTY INSTALL_RPATH
"$ORIGIN/../nvidia/cublas/lib"
"$ORIGIN/../nvidia/cufft/lib"
"$ORIGIN/../nvidia/curand/lib"
"$ORIGIN/../nvidia/cusolver/lib"
"$ORIGIN/../nvidia/cusparse/lib"
"$ORIGIN/../nvidia/nvjitlink/lib"
)
endif()

set(cython_lib_dir cuml)
install(TARGETS ${CUML_CPP_TARGET} DESTINATION ${cython_lib_dir})
endif()
Expand Down
5 changes: 5 additions & 0 deletions python/cuml/pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,11 @@ dependencies = [
"dask-cudf==24.8.*,>=0.0.0a0",
"joblib>=0.11",
"numba>=0.57",
"nvidia-cublas",
KyleFromNVIDIA marked this conversation as resolved.
Show resolved Hide resolved
"nvidia-cufft",
"nvidia-curand",
"nvidia-cusolver",
"nvidia-cusparse",
"packaging",
"pylibraft==24.8.*,>=0.0.0a0",
"raft-dask==24.8.*,>=0.0.0a0",
Expand Down
Loading