From 06d284f5fcc97e5a9cd1d64cacc9a25a76022c26 Mon Sep 17 00:00:00 2001 From: achirkin Date: Fri, 17 Dec 2021 10:16:50 +0100 Subject: [PATCH 1/3] Fix C++ doxygen documentation --- build.sh | 8 +++++++- cpp/include/raft/handle.hpp | 7 ++++--- cpp/include/raft/matrix/math.hpp | 3 ++- cpp/include/raft/matrix/matrix.hpp | 5 +++-- cpp/include/raft/random/rng.hpp | 3 ++- cpp/include/raft/sparse/op/filter.hpp | 1 - cpp/include/raft/sparse/op/reduce.hpp | 2 +- cpp/include/raft/sparse/op/slice.hpp | 6 +++--- cpp/include/raft/sparse/selection/connect_components.hpp | 6 ++++-- cpp/include/raft/sparse/selection/knn.hpp | 5 +++-- cpp/include/raft/sparse/selection/knn_graph.hpp | 1 - 11 files changed, 29 insertions(+), 18 deletions(-) diff --git a/build.sh b/build.sh index 7dff773b67..a609670419 100755 --- a/build.sh +++ b/build.sh @@ -18,13 +18,14 @@ ARGS=$* # script, and that this script resides in the repo dir! REPODIR=$(cd $(dirname $0); pwd) -VALIDARGS="clean cppraft pyraft -v -g --allgpuarch --nvtx --show_depr_warn -h --buildgtest --buildfaiss" +VALIDARGS="clean cppraft pyraft cppdocs -v -g --allgpuarch --nvtx --show_depr_warn -h --buildgtest --buildfaiss" HELP="$0 [ ...] [ ...] where is: clean - remove all existing build artifacts and configuration (start over) cppraft - build the cuml C++ code only. Also builds the C-wrapper library around the C++ code. pyraft - build the cuml Python package + cppdocs - build the C++ doxygen documentation and is: -v - verbose build mode -g - build for debug @@ -130,6 +131,11 @@ if (( ${CLEAN} == 1 )); then cd ${REPODIR} fi +if hasArg cppdocs; then + cd ${CPP_RAFT_BUILD_DIR} + cmake --build ${CPP_RAFT_BUILD_DIR} --target docs_raft +fi + ################################################################################ # Configure for building all C++ targets if (( ${NUMARGS} == 0 )) || hasArg cppraft; then diff --git a/cpp/include/raft/handle.hpp b/cpp/include/raft/handle.hpp index 996c56ca9d..6421ba5344 100644 --- a/cpp/include/raft/handle.hpp +++ b/cpp/include/raft/handle.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019-2020, NVIDIA CORPORATION. + * Copyright (c) 2019-2021, NVIDIA CORPORATION. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -58,7 +58,8 @@ class handle_t { /** * @brief Construct a handle with a stream view and stream pool * - * @param[in] stream the default stream (which has the default per-thread stream if unspecified) + * @param[in] stream_view the default stream (which has the default per-thread stream if + * unspecified) * @param[in] stream_pool the stream pool used (which has default of nullptr if unspecified) */ handle_t(rmm::cuda_stream_view stream_view = rmm::cuda_stream_per_thread, @@ -184,7 +185,7 @@ class handle_t { /** * @brief return stream from pool at index if size > 0, else main stream on handle * - * @param[in] stream_index the required index of the stream in the stream pool if available + * @param[in] stream_idx the required index of the stream in the stream pool if available */ rmm::cuda_stream_view get_next_usable_stream(std::size_t stream_idx) const { diff --git a/cpp/include/raft/matrix/math.hpp b/cpp/include/raft/matrix/math.hpp index c3f591202a..8639cdfb02 100644 --- a/cpp/include/raft/matrix/math.hpp +++ b/cpp/include/raft/matrix/math.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018-2020, NVIDIA CORPORATION. + * Copyright (c) 2018-2021, NVIDIA CORPORATION. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -308,6 +308,7 @@ void setValue(math_t* out, const math_t* in, math_t scalar, int len, cudaStream_ * @brief ratio of every element over sum of input vector is calculated * @tparam math_t data-type upon which the math operation will be performed * @tparam IdxType Integer type used to for addressing + * @param handle * @param src: input matrix * @param dest: output matrix. The result is stored in the dest matrix * @param len: number elements of input matrix diff --git a/cpp/include/raft/matrix/matrix.hpp b/cpp/include/raft/matrix/matrix.hpp index dac2afb5a0..a89c28ab80 100644 --- a/cpp/include/raft/matrix/matrix.hpp +++ b/cpp/include/raft/matrix/matrix.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018-2020, NVIDIA CORPORATION. + * Copyright (c) 2018-2021, NVIDIA CORPORATION. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -169,6 +169,7 @@ void rowReverse(m_t* inout, idx_t n_rows, idx_t n_cols, cudaStream_t stream) * @param n_cols: number of columns of input matrix * @param h_separator: horizontal separator character * @param v_separator: vertical separator character + * @param stream: cuda stream */ template void print(const m_t* in, @@ -275,9 +276,9 @@ void getDiagonalInverseMatrix(m_t* in, idx_t len, cudaStream_t stream) /** * @brief Get the L2/F-norm of a matrix/vector + * @param handle * @param in: input matrix/vector with totally size elements * @param size: size of the matrix/vector - * @param cublasH cublas handle * @param stream: cuda stream */ template diff --git a/cpp/include/raft/random/rng.hpp b/cpp/include/raft/random/rng.hpp index 0cced7c626..4ec25e71a2 100644 --- a/cpp/include/raft/random/rng.hpp +++ b/cpp/include/raft/random/rng.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018-2020, NVIDIA CORPORATION. + * Copyright (c) 2018-2021, NVIDIA CORPORATION. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -335,6 +335,7 @@ class Rng : public detail::RngImpl { * @tparam DataT data type * @tparam WeightsT weights type * @tparam IdxT index type + * @param handle * @param out output sampled array (of length 'sampledLen') * @param outIdx indices of the sampled array (of length 'sampledLen'). Pass * a nullptr if this is not required. diff --git a/cpp/include/raft/sparse/op/filter.hpp b/cpp/include/raft/sparse/op/filter.hpp index 8e57f53d9a..0dff063e91 100644 --- a/cpp/include/raft/sparse/op/filter.hpp +++ b/cpp/include/raft/sparse/op/filter.hpp @@ -38,7 +38,6 @@ namespace op { * @param cur_cnnz array of counts per row * @param scalar: scalar to remove from arrays * @param n: number of rows in dense matrix - * @param d_alloc device allocator for temporary buffers * @param stream: cuda stream to use */ template diff --git a/cpp/include/raft/sparse/op/reduce.hpp b/cpp/include/raft/sparse/op/reduce.hpp index 094968b11c..b181f1c46f 100644 --- a/cpp/include/raft/sparse/op/reduce.hpp +++ b/cpp/include/raft/sparse/op/reduce.hpp @@ -57,6 +57,7 @@ void compute_duplicates_mask( * the sorting of values. * @tparam value_idx * @tparam value_t + * @param[in] handle * @param[out] out output COO, the nnz will be computed allocate() will be called in this function. * @param[in] rows COO rows array, size nnz * @param[in] cols COO cols array, size nnz @@ -64,7 +65,6 @@ void compute_duplicates_mask( * @param[in] nnz number of nonzeros in COO input arrays * @param[in] m number of rows in COO input matrix * @param[in] n number of columns in COO input matrix - * @param[in] stream cuda ops will be ordered wrt this stream */ template void max_duplicates(const raft::handle_t& handle, diff --git a/cpp/include/raft/sparse/op/slice.hpp b/cpp/include/raft/sparse/op/slice.hpp index e73063d0d6..917233319c 100644 --- a/cpp/include/raft/sparse/op/slice.hpp +++ b/cpp/include/raft/sparse/op/slice.hpp @@ -49,8 +49,8 @@ void csr_row_slice_indptr(value_idx start_row, /** * Slice rows from a CSR, populate column and data arrays - * @tparam[in] value_idx : data type of CSR index arrays - * @tparam[in] value_t : data type of CSR data array + * @tparam value_idx : data type of CSR index arrays + * @tparam value_t : data type of CSR data array * @param[in] start_offset : beginning column offset to slice * @param[in] stop_offset : ending column offset to slice * @param[in] indices : column indices array from input CSR @@ -74,4 +74,4 @@ void csr_row_slice_populate(value_idx start_offset, }; // namespace op }; // end NAMESPACE sparse -}; // end NAMESPACE raft \ No newline at end of file +}; // end NAMESPACE raft diff --git a/cpp/include/raft/sparse/selection/connect_components.hpp b/cpp/include/raft/sparse/selection/connect_components.hpp index bc03cd56e2..23d247b50e 100644 --- a/cpp/include/raft/sparse/selection/connect_components.hpp +++ b/cpp/include/raft/sparse/selection/connect_components.hpp @@ -54,9 +54,11 @@ value_idx get_n_components(value_idx* colors, size_t n_rows, cudaStream_t stream * @param[out] out output edge list containing nearest cross-component * edges. * @param[in] X original (row-major) dense matrix for which knn graph should be constructed. - * @param[in] colors array containing component number for each row of X + * @param[in] orig_colors array containing component number for each row of X * @param[in] n_rows number of rows in X * @param[in] n_cols number of cols in X + * @param[in] reduction_op + * @param[in] metric */ template void connect_components( @@ -73,4 +75,4 @@ void connect_components( } }; // end namespace linkage -}; // end namespace raft \ No newline at end of file +}; // end namespace raft diff --git a/cpp/include/raft/sparse/selection/knn.hpp b/cpp/include/raft/sparse/selection/knn.hpp index 63d9da6114..ddfb74dedc 100644 --- a/cpp/include/raft/sparse/selection/knn.hpp +++ b/cpp/include/raft/sparse/selection/knn.hpp @@ -30,8 +30,9 @@ namespace selection { * @param[in] idxIndptr csr indptr of the index matrix (size n_idx_rows + 1) * @param[in] idxIndices csr column indices array of the index matrix (size n_idx_nnz) * @param[in] idxData csr data array of the index matrix (size idxNNZ) - * @param[in] idxNNA number of non-zeros for sparse index matrix + * @param[in] idxNNZ number of non-zeros for sparse index matrix * @param[in] n_idx_rows number of data samples in index matrix + * @param[in] n_idx_cols * @param[in] queryIndptr csr indptr of the query matrix (size n_query_rows + 1) * @param[in] queryIndices csr indices array of the query matrix (size queryNNZ) * @param[in] queryData csr data array of the query matrix (size queryNNZ) @@ -41,7 +42,7 @@ namespace selection { * @param[out] output_indices dense matrix for output indices (size n_query_rows * k) * @param[out] output_dists dense matrix for output distances (size n_query_rows * k) * @param[in] k the number of neighbors to query - * @param[in] handle.get_stream() CUDA handle.get_stream() to order operations with respect to + * @param[in] handle CUDA handle.get_stream() to order operations with respect to * @param[in] batch_size_index maximum number of rows to use from index matrix per batch * @param[in] batch_size_query maximum number of rows to use from query matrix per batch * @param[in] metric distance metric/measure to use diff --git a/cpp/include/raft/sparse/selection/knn_graph.hpp b/cpp/include/raft/sparse/selection/knn_graph.hpp index 96ce02e06a..64b7797277 100644 --- a/cpp/include/raft/sparse/selection/knn_graph.hpp +++ b/cpp/include/raft/sparse/selection/knn_graph.hpp @@ -39,7 +39,6 @@ namespace selection { * @param[in] n number of observations (columns) in X * @param[in] metric distance metric to use when constructing neighborhoods * @param[out] out output edge list - * @param[out] out output edge list * @param c */ template From 9efcf33959d94f25bac64e48cad3de2febc8e2fd Mon Sep 17 00:00:00 2001 From: achirkin Date: Fri, 17 Dec 2021 10:39:02 +0100 Subject: [PATCH 2/3] Add doxygen target to CI --- ci/gpu/build.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ci/gpu/build.sh b/ci/gpu/build.sh index c8d526703f..f68e49e9a6 100644 --- a/ci/gpu/build.sh +++ b/ci/gpu/build.sh @@ -1,5 +1,5 @@ #!/bin/bash -# Copyright (c) 2020, NVIDIA CORPORATION. +# Copyright (c) 2020-2021, NVIDIA CORPORATION. ######################################### # cuML GPU build and test script for CI # ######################################### @@ -88,7 +88,7 @@ export LD_LIBRARY_PATH_CACHED=$LD_LIBRARY_PATH export LD_LIBRARY_PATH=$CONDA_PREFIX/lib:$LD_LIBRARY_PATH gpuci_logger "Build C++ and Python targets" -"$WORKSPACE/build.sh" cppraft pyraft -v +"$WORKSPACE/build.sh" cppraft pyraft cppdocs -v gpuci_logger "Resetting LD_LIBRARY_PATH" From 5bf1f59556bc98fd38c90a325df98005b96138d3 Mon Sep 17 00:00:00 2001 From: achirkin Date: Fri, 17 Dec 2021 13:27:05 +0100 Subject: [PATCH 3/3] Build docs after the project is built. --- ci/gpu/build.sh | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/ci/gpu/build.sh b/ci/gpu/build.sh index f68e49e9a6..83cc6fdaef 100644 --- a/ci/gpu/build.sh +++ b/ci/gpu/build.sh @@ -88,7 +88,10 @@ export LD_LIBRARY_PATH_CACHED=$LD_LIBRARY_PATH export LD_LIBRARY_PATH=$CONDA_PREFIX/lib:$LD_LIBRARY_PATH gpuci_logger "Build C++ and Python targets" -"$WORKSPACE/build.sh" cppraft pyraft cppdocs -v +"$WORKSPACE/build.sh" cppraft pyraft -v + +gpuci_logger "Building doxygen C++ docs" +"$WORKSPACE/build.sh" cppdocs -v gpuci_logger "Resetting LD_LIBRARY_PATH"