Skip to content

Commit

Permalink
Support MV only for HNSW
Browse files Browse the repository at this point in the history
Signed-off-by: chasingegg <[email protected]>
  • Loading branch information
chasingegg committed Jan 9, 2025
1 parent 8380a96 commit 96d5ecc
Show file tree
Hide file tree
Showing 11 changed files with 2,166 additions and 1,127 deletions.
32 changes: 32 additions & 0 deletions include/knowhere/bitsetview.h
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,38 @@ class BitsetView {
return ret;
}

size_t
get_first_valid_index() const {
size_t ret = 0;
auto len_uint8 = byte_size();
auto len_uint64 = len_uint8 >> 3;

uint64_t* p_uint64 = (uint64_t*)bits_;
for (size_t i = 0; i < len_uint64; i++) {
uint64_t value = (~(*p_uint64));
if (value == 0) {
p_uint64++;
continue;
}
ret = __builtin_ctzll(value);
return i * 64 + ret;
}

// calculate remainder
uint8_t* p_uint8 = (uint8_t*)bits_ + (len_uint64 << 3);
for (size_t i = (len_uint64 << 3); i < len_uint8; i++) {
uint8_t value = (~(*p_uint8));
if (value == 0) {
p_uint8++;
continue;
}
ret = __builtin_ctz(value);
return len_uint64 * 64 + i * 8 + ret;
}

return num_bits_;
}

std::string
to_string(size_t from, size_t to) const {
if (empty()) {
Expand Down
11 changes: 8 additions & 3 deletions include/knowhere/bitsetview_idselector.h
Original file line number Diff line number Diff line change
Expand Up @@ -20,15 +20,20 @@ namespace knowhere {
struct BitsetViewIDSelector final : faiss::IDSelector {
const BitsetView bitset_view;
const size_t id_offset;
const uint32_t* out_id_mapping;

inline BitsetViewIDSelector(BitsetView bitset_view, const size_t offset = 0)
: bitset_view{bitset_view}, id_offset(offset) {
inline BitsetViewIDSelector(BitsetView bitset_view, const size_t offset = 0,
const uint32_t* out_id_mapping = nullptr)
: bitset_view{bitset_view}, id_offset(offset), out_id_mapping(out_id_mapping) {
}

inline bool
is_member(faiss::idx_t id) const override final {
// it is by design that bitset_view.empty() is not tested here
return (!bitset_view.test(id + id_offset));
if (out_id_mapping == nullptr) {
return (!bitset_view.test(id + id_offset));
}
return (!bitset_view.test(out_id_mapping[id + id_offset]));
}
};

Expand Down
2 changes: 2 additions & 0 deletions include/knowhere/comp/index_param.h
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,8 @@ constexpr const char* JSON_ID_SET = "json_id_set";
constexpr const char* TRACE_ID = "trace_id";
constexpr const char* SPAN_ID = "span_id";
constexpr const char* TRACE_FLAGS = "trace_flags";
constexpr const char* SCALAR_INFO = "scalar_info";
constexpr const char* MV_ONLY_ENABLED = "mv_only_enabled";
constexpr const char* MATERIALIZED_VIEW_SEARCH_INFO = "materialized_view_search_info";
constexpr const char* MATERIALIZED_VIEW_OPT_FIELDS_PATH = "opt_fields_path";
constexpr const char* MAX_EMPTY_RESULT_BUCKETS = "max_empty_result_buckets";
Expand Down
Loading

0 comments on commit 96d5ecc

Please sign in to comment.