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

[BUG] refine_device fails to compile for idx_t != matrix_idx #537

Open
wphicks opened this issue Nov 1, 2023 · 1 comment · May be fixed by #563
Open

[BUG] refine_device fails to compile for idx_t != matrix_idx #537

wphicks opened this issue Nov 1, 2023 · 1 comment · May be fixed by #563
Labels
bug Something isn't working vector search

Comments

@wphicks
Copy link

wphicks commented Nov 1, 2023

Calling raft::neighbors::refine on input which uses a different indexing type for the input matrices than for the vector ids results in a compilation failure in raft::neighbors::ivf_flat::detail::fill_refinement_index. This comes up in attempting to refine output from some of our supported CAGRA instantiations, which use int64_t for the input matrices' indexes but some other type for the vector ids.

To trace through the problem:

  1. refine can be instantiated with different idx_t and matrix_idx here.
  2. This calls refine_device with the same type instantiations here.
  3. refine_device calls fill_refinement_index here.
  4. fill_refinement_index has only a single indexing type in its template. This is deduced to be idx_t from refine_device due to this argument, but matrix_idx due to this argument. Because these two do not match, no instantiation matches the template, and we fail to compile.
@lowener
Copy link
Contributor

lowener commented Dec 17, 2024

I transferred this issue from raft because it is still relevant today, and it can lead to errors while building Milvus:
In cuVS the refine function is not compatible with CAGRA because CAGRA only support uint32_t as neighbors data type, and refine only support int64_t (see here) as neighbors data type.

@lowener lowener linked a pull request Jan 10, 2025 that will close this issue
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working vector search
Projects
Status: No status
Development

Successfully merging a pull request may close this issue.

3 participants