From 2e2367aa7236f75323749554e8bd6bc428691a30 Mon Sep 17 00:00:00 2001 From: Seunghwa Kang Date: Sun, 11 Jul 2021 19:28:39 -0700 Subject: [PATCH 1/2] remove the unused/out-dated any_of_adj_matrix_row graph primitive --- .../cugraph/prims/any_of_adj_matrix_row.cuh | 73 ------------------- cpp/src/experimental/pagerank.cu | 1 - 2 files changed, 74 deletions(-) delete mode 100644 cpp/include/cugraph/prims/any_of_adj_matrix_row.cuh diff --git a/cpp/include/cugraph/prims/any_of_adj_matrix_row.cuh b/cpp/include/cugraph/prims/any_of_adj_matrix_row.cuh deleted file mode 100644 index 94cdae1ec95..00000000000 --- a/cpp/include/cugraph/prims/any_of_adj_matrix_row.cuh +++ /dev/null @@ -1,73 +0,0 @@ -/* - * Copyright (c) 2020-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. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -#pragma once - -#include -#include -#include - -#include -#include - -#include -#include - -namespace cugraph { -namespace experimental { - -/** - * @brief Check any of graph adjacency matrix row properties satisfy the given predicate. - * - * Returns true if @p row_op returns true for at least once (in any process in multi-GPU), returns - * false otherwise. This function is inspired by thrust::any_of(). - * - * @tparam GraphViewType Type of the passed non-owning graph object. - * @tparam AdjMatrixRowValueInputIterator Type of the iterator for graph adjacency matrix row - * input properties. - * @tparam RowOp Type of the unary predicate operator. - * @param handle RAFT handle object to encapsulate resources (e.g. CUDA stream, communicator, and - * handles to various CUDA libraries) to run graph algorithms. - * @param graph_view Non-owning graph object. - * @param adj_matrix_row_value_input_first Iterator pointing to the adjacency matrix row properties - * for the first (inclusive) row (assigned to this process in multi-GPU). - * `adj_matrix_row_value_input_last` (exclusive) is deduced as @p adj_matrix_row_value_input_first + - * @p graph_view.get_number_of_local_adj_matrix_partition_rows(). - * @param row_op Unary predicate operator that takes *(@p adj_matrix_row_value_input_first + i) - * (where i = [0, @p graph_view.get_number_of_local_adj_matrix_partition_rows()) and returns either - * true or false. - * @return true If the predicate returns true at least once (in any process in multi-GPU). - * @return false If the predicate never returns true (in any process in multi-GPU). - */ -template -bool any_of_adj_matrix_row(raft::handle_t const& handle, - GraphViewType const& graph_view, - AdjMatrixRowValueInputIterator adj_matrix_row_value_input_first, - RowOp row_op) -{ - // better use thrust::any_of once https://github.com/thrust/thrust/issues/1016 is resolved - auto count = thrust::count_if( - rmm::exec_policy(handle.get_stream())->on(handle.get_stream()), - adj_matrix_row_value_input_first, - adj_matrix_row_value_input_first + graph_view.get_number_of_local_adj_matrix_partition_rows(), - row_op); - if (GraphViewType::is_multi_gpu) { - count = host_scalar_allreduce(handle.get_comms(), count, handle.get_stream()); - } - return (count > 0); -} - -} // namespace experimental -} // namespace cugraph diff --git a/cpp/src/experimental/pagerank.cu b/cpp/src/experimental/pagerank.cu index 999a25b01c9..7c3e4b03e9e 100644 --- a/cpp/src/experimental/pagerank.cu +++ b/cpp/src/experimental/pagerank.cu @@ -16,7 +16,6 @@ #include #include -#include #include #include #include From 649dfed93bb5b05f5e969b4fc8f5745ab0887fcd Mon Sep 17 00:00:00 2001 From: Seunghwa Kang Date: Sun, 11 Jul 2021 19:37:14 -0700 Subject: [PATCH 2/2] delete unused primitive --- ...transform_reduce_v_with_adj_matrix_row.cuh | 120 ------------------ 1 file changed, 120 deletions(-) delete mode 100644 cpp/include/cugraph/prims/transform_reduce_v_with_adj_matrix_row.cuh diff --git a/cpp/include/cugraph/prims/transform_reduce_v_with_adj_matrix_row.cuh b/cpp/include/cugraph/prims/transform_reduce_v_with_adj_matrix_row.cuh deleted file mode 100644 index bfb6f296075..00000000000 --- a/cpp/include/cugraph/prims/transform_reduce_v_with_adj_matrix_row.cuh +++ /dev/null @@ -1,120 +0,0 @@ -/* - * Copyright (c) 2020-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. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ -#pragma once - -#include -#include -#include - -#include - -#include -#include -#include - -namespace cugraph { -namespace experimental { - -/** - * @brief Apply an operator to the matching vertex and adjacency matrix row properties and reduce. - * - * i'th vertex matches with the i'th row in the graph adjacency matrix. @p v_op takes vertex - * properties and adjacency matrix row properties for the matching row, and @p v_op outputs are - * reduced. This function is inspired by thrust::transform_reduce(). - * - * @tparam GraphViewType Type of the passed non-owning graph object. - * @tparam VertexValueInputIterator Type of the iterator for vertex properties. - * @tparam AdjMatrixRowValueInputIterator Type of the iterator for graph adjacency matrix column - * input properties. - * @tparam VertexOp Type of the binary vertex operator. - * @tparam T Type of the initial value. - * @param handle RAFT handle object to encapsulate resources (e.g. CUDA stream, communicator, and - * handles to various CUDA libraries) to run graph algorithms. - * @param graph_view Non-owning graph object. - * @param vertex_value_input_first Iterator pointing to the vertex properties for the first - * (inclusive) vertex (assigned to this process in multi-GPU). `vertex_value_input_last` (exclusive) - * is deduced as @p vertex_value_input_first + @p graph_view.get_number_of_local_vertices(). - * @param adj_matrix_row_value_input_first Iterator pointing to the adjacency matrix row input - * properties for the first (inclusive) row (assigned to this process in multi-GPU). - * `adj_matrix_row_value_input_last` (exclusive) is deduced as @p adj_matrix_row_value_input_first + - * @p graph_view.get_number_of_local_adj_matrix_partition_rows(). - * @param v_op Binary operator takes *(@p vertex_value_input_first + i) and *(@p - * adj_matrix_row_value_input_first + j) (where i and j are set for a vertex and the matching row) - * and returns a transformed value to be reduced. - * @param init Initial value to be added to the transform-reduced input vertex properties. - * @return T Reduction of the @p v_op outputs. - */ -template -T transform_reduce_v_with_adj_matrix_row( - raft::handle_t const& handle, - GraphViewType const& graph_view, - VertexValueInputIterator vertex_value_input_first, - AdjMatrixRowValueInputIterator adj_matrix_row_value_input_first, - VertexOp v_op, - T init) -{ - using vertex_t = GraphViewtype::vertex_type; - using edge_t = GraphViewtype::edge_type; - using weight_t = GraphViewtype::weight_type; - - T ret{}; - - auto vertex_first = graph_view.get_local_vertex_first(); - auto vertex_last = graph_view.get_local_vertex_last(); - for (size_t i = 0; i < graph_view.get_number_of_local_adj_matrix_partitions(); ++i) { - auto row_first = graph_view.get_local_adj_matrix_partition_row_first(i); - auto row_last = graph_view.get_local_adj_matrix_partition_row_last(i); - - auto range_first = std::max(vertex_first, row_first); - auto range_last = std::min(vertex_last, row_last); - - if (range_last > range_first) { - auto matrix_partition = - matrix_partition_device_view_t( - graph_view.get_matrix_partition_view(i)); - auto row_value_input_offset = GraphViewType::is_adj_matrix_transposed - ? 0 - : matrix_partition.get_major_value_start_offset(); - - auto input_first = thrust::make_zip_iterator(thrust::make_tuple( - vertex_value_input_first + (range_first - vertex_first), - adj_matrix_row_value_input_first + row_value_input_offset + (range_first - row_first))); - auto v_op_wrapper = [v_op] __device__(auto v_and_row_val) { - return v_op(thrust::get<0>(v_and_row_val), thrust::get<1>(v_and_row_val)); - }; - ret += - thrust::transform_reduce(rmm::exec_policy(handle.get_stream())->on(handle.get_stream()), - input_first, - input_first + (range_last - range_first), - v_op_wrapper, - T{}, - thrust::plus()); - } - } - - if (GraphViewType::is_multi_gpu) { - ret = host_scalar_allreduce(handle.get_comms(), ret, handle.get_stream()); - } - - return init + ret; -} - -} // namespace experimental -} // namespace cugraph