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

Enable distance return for NN Descent #2345

Merged
merged 31 commits into from
Jun 14, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
242d725
enable nn descent dist return
jinsolp May 29, 2024
0977947
change bool to int
jinsolp May 29, 2024
ea30245
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp May 29, 2024
a7749ac
add test for distance
jinsolp May 30, 2024
a753e45
test for indices and distances with one func
jinsolp May 30, 2024
1d96e17
fix styling
jinsolp May 30, 2024
66a7678
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp May 30, 2024
11379f7
change return_distances to bool
jinsolp May 31, 2024
e993d7c
change distances to optional
jinsolp May 31, 2024
4578dc0
fix styling:
jinsolp May 31, 2024
c9048a5
handle bad access error
jinsolp Jun 5, 2024
bdb74a5
remove unnecessary dist allocation
jinsolp Jun 5, 2024
c71e97a
change to device matrix
jinsolp Jun 5, 2024
0327ce5
change template param for index
jinsolp Jun 5, 2024
3f49752
update test
jinsolp Jun 6, 2024
50e2cf8
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp Jun 6, 2024
a6a8ad2
remove comment
jinsolp Jun 6, 2024
2cfda3c
fix styling
jinsolp Jun 6, 2024
2efae1a
fix header
jinsolp Jun 6, 2024
931158c
add documentation for return_distances
jinsolp Jun 6, 2024
9f17b5c
add documentation
jinsolp Jun 7, 2024
e33019c
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp Jun 7, 2024
e28c2f9
add tparam doc
jinsolp Jun 10, 2024
2d74f89
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp Jun 11, 2024
fd65442
remove redundancy
jinsolp Jun 12, 2024
3ce8cdf
return optional for distances()
jinsolp Jun 13, 2024
4ec3ab0
fix styling
jinsolp Jun 13, 2024
b0347a7
remove raft_expects
jinsolp Jun 13, 2024
84abd96
fix type template and bring back raft_expects
jinsolp Jun 13, 2024
75b82df
Merge branch 'rapidsai:branch-24.08' into fea-nndescent-api
jinsolp Jun 13, 2024
ec44b4d
fix raft_expects
jinsolp Jun 13, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix styling
  • Loading branch information
jinsolp committed Jun 13, 2024
commit 4ec3ab0a8583abc2c8ed98f0cc9ff36a3278ed0e
14 changes: 7 additions & 7 deletions cpp/include/raft/neighbors/detail/nn_descent.cuh
Original file line number Diff line number Diff line change
Expand Up @@ -1435,16 +1435,16 @@ void build(raft::resources const& res,

GNND<const T, int> nnd(res, build_config);

if(idx.distances().has_value()) {
if (idx.distances().has_value()) {
nnd.build(dataset.data_handle(),
dataset.extent(0),
int_graph.data_handle(),
params.return_distances,
idx.distances().value().data_handle());
dataset.extent(0),
int_graph.data_handle(),
params.return_distances,
idx.distances().value().data_handle());
} else {
RAFT_EXPECTS(false, "Distance view not allocated. Using NN Descent requires return_distances to be true");
RAFT_EXPECTS(
false, "Distance view not allocated. Using NN Descent requires return_distances to be true");
jinsolp marked this conversation as resolved.
Show resolved Hide resolved
}


#pragma omp parallel for
for (size_t i = 0; i < static_cast<size_t>(dataset.extent(0)); i++) {
Expand Down
3 changes: 2 additions & 1 deletion cpp/include/raft/neighbors/nn_descent_types.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,8 @@ struct index : ann::index {
}

/** neighborhood graph distances [size, graph-degree] */
[[nodiscard]] inline auto distances() noexcept -> std::optional<device_matrix_view<T, int64_t, row_major>>
[[nodiscard]] inline auto distances() noexcept
-> std::optional<device_matrix_view<T, int64_t, row_major>>
{
return distances_view_;
}
Expand Down
18 changes: 11 additions & 7 deletions cpp/test/neighbors/ann_nn_descent.cuh
Original file line number Diff line number Diff line change
Expand Up @@ -108,18 +108,22 @@ class AnnNNDescentTest : public ::testing::TestWithParam<AnnNNDescentInputs> {
auto index = nn_descent::build<DataT, IdxT>(handle_, index_params, database_host_view);
raft::copy(
indices_NNDescent.data(), index.graph().data_handle(), queries_size, stream_);
if(index.distances().has_value()) {
raft::copy(
distances_NNDescent.data(), index.distances().value().data_handle(), queries_size, stream_);
if (index.distances().has_value()) {
raft::copy(distances_NNDescent.data(),
index.distances().value().data_handle(),
queries_size,
stream_);
}

} else {
auto index = nn_descent::build<DataT, IdxT>(handle_, index_params, database_view);
raft::copy(
indices_NNDescent.data(), index.graph().data_handle(), queries_size, stream_);
if(index.distances().has_value()) {
raft::copy(
distances_NNDescent.data(), index.distances().value().data_handle(), queries_size, stream_);
if (index.distances().has_value()) {
raft::copy(distances_NNDescent.data(),
index.distances().value().data_handle(),
queries_size,
stream_);
}
};
}
Expand Down
Loading