diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 6a9e0b14..9674abb7 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -15,7 +15,7 @@ jobs: strategy: matrix: os: [ubuntu-latest, windows-latest] - python-version: ["3.8", "3.9", "3.10"] + python-version: ["3.7", "3.8", "3.9", "3.10"] steps: - uses: actions/checkout@v3 - uses: actions/setup-python@v4 diff --git a/hnswlib/hnswalg.h b/hnswlib/hnswalg.h index e4e8150f..fd0e723b 100644 --- a/hnswlib/hnswalg.h +++ b/hnswlib/hnswalg.h @@ -1835,14 +1835,14 @@ namespace hnswlib std::unordered_set s; for (int j = 0; j < size; j++) { - if (data[j] < 0 || data[j] >= cur_element_count || data[j] == i) - throw std::runtime_error("HNSW Integrity failure: invalid neighbor index"); + assert(data[j] > 0); + assert(data[j] < cur_element_count); + assert(data[j] != i); inbound_connections_num[data[j]]++; s.insert(data[j]); connections_checked++; } - if (s.size() != size) - throw std::runtime_error("HNSW Integrity failure: duplicate neighbor index"); + assert(s.size() == size); } } if (cur_element_count > 1) @@ -1850,7 +1850,6 @@ namespace hnswlib int min1 = inbound_connections_num[0], max1 = inbound_connections_num[0]; for (int i = 0; i < cur_element_count; i++) { - // This should always be true regardless the data is corrupted or not assert(inbound_connections_num[i] > 0); min1 = std::min(inbound_connections_num[i], min1); max1 = std::max(inbound_connections_num[i], max1);