From 26fb3c8c91048b76987ed2b9256ae37b1afdc43b Mon Sep 17 00:00:00 2001 From: Naveen Tatikonda Date: Tue, 21 Jan 2025 19:54:56 -0600 Subject: [PATCH] Revert "Bump Faiss commit from 1f42e81 to 0cbc2a8 (#2381)" This reverts commit 7991350f5333c1386ba0e45cd1f0d19e89597507. --- CHANGELOG.md | 3 ++ jni/external/faiss | 2 +- ...ble-precomp-table-to-be-shared-ivfpq.patch | 46 +++++++++---------- 3 files changed, 27 insertions(+), 24 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 61f94e79a..2081b4e15 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -53,6 +53,9 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), * Added null checks for fieldInfo in ExactSearcher to avoid NPE while running exact search for segments with no vector field (#2278)[https://github.com/opensearch-project/k-NN/pull/2278] * Added Lucene BWC tests (#2313)[https://github.com/opensearch-project/k-NN/pull/2313] * Upgrade jsonpath from 2.8.0 to 2.9.0[2325](https://github.com/opensearch-project/k-NN/pull/2325) +<<<<<<< HEAD * Bump Faiss commit from 1f42e81 to 0cbc2a8 to accelerate hamming distance calculation using _mm512_popcnt_epi64 intrinsic and also add avx512-fp16 instructions to boost performance [#2381](https://github.com/opensearch-project/k-NN/pull/2381) * Enabled indices.breaker.total.use_real_memory setting via build.gradle for integTest Cluster to catch heap CB in local ITs and github CI actions [#2395](https://github.com/opensearch-project/k-NN/pull/2395/) +======= +>>>>>>> parent of 7991350f (Bump Faiss commit from 1f42e81 to 0cbc2a8 (#2381)) ### Refactoring diff --git a/jni/external/faiss b/jni/external/faiss index 0cbc2a885..1f42e815d 160000 --- a/jni/external/faiss +++ b/jni/external/faiss @@ -1 +1 @@ -Subproject commit 0cbc2a885cde923d80c4bf9c9d6f4d81665f3f64 +Subproject commit 1f42e815db7754297e3b4467763352b829b6cde0 diff --git a/jni/patches/faiss/0002-Enable-precomp-table-to-be-shared-ivfpq.patch b/jni/patches/faiss/0002-Enable-precomp-table-to-be-shared-ivfpq.patch index c0dc4509c..88e6a8106 100644 --- a/jni/patches/faiss/0002-Enable-precomp-table-to-be-shared-ivfpq.patch +++ b/jni/patches/faiss/0002-Enable-precomp-table-to-be-shared-ivfpq.patch @@ -1,4 +1,4 @@ -From 1605542c1f4f7982fe0c5447090ae96f84f27484 Mon Sep 17 00:00:00 2001 +From 9b33874562c9e62abf4a863657c54f0d349b0f67 Mon Sep 17 00:00:00 2001 From: John Mazanec Date: Wed, 21 Feb 2024 15:34:15 -0800 Subject: [PATCH] Enable precomp table to be shared ivfpq @@ -22,10 +22,10 @@ Signed-off-by: John Mazanec create mode 100644 tests/test_ivfpq_share_table.cpp diff --git a/faiss/IndexIVFPQ.cpp b/faiss/IndexIVFPQ.cpp -index e9d6eead2..97c8c010d 100644 +index 100f499c..09508890 100644 --- a/faiss/IndexIVFPQ.cpp +++ b/faiss/IndexIVFPQ.cpp -@@ -58,6 +58,29 @@ IndexIVFPQ::IndexIVFPQ( +@@ -59,6 +59,29 @@ IndexIVFPQ::IndexIVFPQ( polysemous_training = nullptr; do_polysemous_training = false; polysemous_ht = 0; @@ -55,7 +55,7 @@ index e9d6eead2..97c8c010d 100644 } /**************************************************************** -@@ -463,11 +486,23 @@ void IndexIVFPQ::precompute_table() { +@@ -464,11 +487,23 @@ void IndexIVFPQ::precompute_table() { use_precomputed_table, quantizer, pq, @@ -80,7 +80,7 @@ index e9d6eead2..97c8c010d 100644 namespace { #define TIC t0 = get_cycles() -@@ -647,7 +682,7 @@ struct QueryTables { +@@ -648,7 +683,7 @@ struct QueryTables { fvec_madd( pq.M * pq.ksub, @@ -89,7 +89,7 @@ index e9d6eead2..97c8c010d 100644 -2.0, sim_table_2, sim_table); -@@ -676,7 +711,7 @@ struct QueryTables { +@@ -677,7 +712,7 @@ struct QueryTables { k >>= cpq.nbits; // get corresponding table @@ -98,7 +98,7 @@ index e9d6eead2..97c8c010d 100644 (ki * pq.M + cm * Mf) * pq.ksub; if (polysemous_ht == 0) { -@@ -706,7 +741,7 @@ struct QueryTables { +@@ -707,7 +742,7 @@ struct QueryTables { dis0 = coarse_dis; const float* s = @@ -107,7 +107,7 @@ index e9d6eead2..97c8c010d 100644 for (int m = 0; m < pq.M; m++) { sim_table_ptrs[m] = s; s += pq.ksub; -@@ -726,7 +761,7 @@ struct QueryTables { +@@ -727,7 +762,7 @@ struct QueryTables { int ki = k & ((uint64_t(1) << cpq.nbits) - 1); k >>= cpq.nbits; @@ -116,7 +116,7 @@ index e9d6eead2..97c8c010d 100644 (ki * pq.M + cm * Mf) * pq.ksub; for (int m = m0; m < m0 + Mf; m++) { -@@ -1343,6 +1378,8 @@ IndexIVFPQ::IndexIVFPQ() { +@@ -1344,6 +1379,8 @@ IndexIVFPQ::IndexIVFPQ() { do_polysemous_training = false; polysemous_ht = 0; polysemous_training = nullptr; @@ -126,7 +126,7 @@ index e9d6eead2..97c8c010d 100644 struct CodeCmp { diff --git a/faiss/IndexIVFPQ.h b/faiss/IndexIVFPQ.h -index 7bf97ec0f..f647e5f87 100644 +index d5d21da4..850bbe44 100644 --- a/faiss/IndexIVFPQ.h +++ b/faiss/IndexIVFPQ.h @@ -48,7 +48,8 @@ struct IndexIVFPQ : IndexIVF { @@ -167,10 +167,10 @@ index 7bf97ec0f..f647e5f87 100644 }; diff --git a/faiss/IndexIVFPQFastScan.cpp b/faiss/IndexIVFPQFastScan.cpp -index 9d1cdfcae..647644e36 100644 +index 2844ae49..895df342 100644 --- a/faiss/IndexIVFPQFastScan.cpp +++ b/faiss/IndexIVFPQFastScan.cpp -@@ -42,6 +42,8 @@ IndexIVFPQFastScan::IndexIVFPQFastScan( +@@ -46,6 +46,8 @@ IndexIVFPQFastScan::IndexIVFPQFastScan( : IndexIVFFastScan(quantizer, d, nlist, 0, metric), pq(d, M, nbits) { by_residual = false; // set to false by default because it's faster @@ -179,7 +179,7 @@ index 9d1cdfcae..647644e36 100644 init_fastscan(M, nbits, nlist, metric, bbs); } -@@ -49,6 +51,17 @@ IndexIVFPQFastScan::IndexIVFPQFastScan() { +@@ -53,6 +55,17 @@ IndexIVFPQFastScan::IndexIVFPQFastScan() { by_residual = false; bbs = 0; M2 = 0; @@ -197,7 +197,7 @@ index 9d1cdfcae..647644e36 100644 } IndexIVFPQFastScan::IndexIVFPQFastScan(const IndexIVFPQ& orig, int bbs) -@@ -67,13 +80,15 @@ IndexIVFPQFastScan::IndexIVFPQFastScan(const IndexIVFPQ& orig, int bbs) +@@ -71,13 +84,15 @@ IndexIVFPQFastScan::IndexIVFPQFastScan(const IndexIVFPQ& orig, int bbs) ntotal = orig.ntotal; is_trained = orig.is_trained; nprobe = orig.nprobe; @@ -218,7 +218,7 @@ index 9d1cdfcae..647644e36 100644 } for (size_t i = 0; i < nlist; i++) { -@@ -98,6 +113,12 @@ IndexIVFPQFastScan::IndexIVFPQFastScan(const IndexIVFPQ& orig, int bbs) +@@ -102,6 +117,12 @@ IndexIVFPQFastScan::IndexIVFPQFastScan(const IndexIVFPQ& orig, int bbs) orig_invlists = orig.invlists; } @@ -231,7 +231,7 @@ index 9d1cdfcae..647644e36 100644 /********************************************************* * Training *********************************************************/ -@@ -123,11 +144,23 @@ void IndexIVFPQFastScan::precompute_table() { +@@ -127,11 +148,23 @@ void IndexIVFPQFastScan::precompute_table() { use_precomputed_table, quantizer, pq, @@ -256,7 +256,7 @@ index 9d1cdfcae..647644e36 100644 /********************************************************* * Code management functions *********************************************************/ -@@ -225,7 +258,7 @@ void IndexIVFPQFastScan::compute_LUT( +@@ -229,7 +262,7 @@ void IndexIVFPQFastScan::compute_LUT( if (cij >= 0) { fvec_madd_simd( dim12, @@ -266,7 +266,7 @@ index 9d1cdfcae..647644e36 100644 ip_table.get() + i * dim12, tab); diff --git a/faiss/IndexIVFPQFastScan.h b/faiss/IndexIVFPQFastScan.h -index a2cce3266..1e1f0049c 100644 +index 00dd2f11..91f35a6e 100644 --- a/faiss/IndexIVFPQFastScan.h +++ b/faiss/IndexIVFPQFastScan.h @@ -38,7 +38,8 @@ struct IndexIVFPQFastScan : IndexIVFFastScan { @@ -302,19 +302,19 @@ index a2cce3266..1e1f0049c 100644 /// same as the regular IVFPQ encoder. The codes are not reorganized by /// blocks a that point diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt -index ae6cc7878..16c99e04d 100644 +index 87ab2020..a859516c 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -38,6 +38,7 @@ set(FAISS_TEST_SRC + test_common_ivf_empty_index.cpp test_callback.cpp test_utils.cpp - test_hamming.cpp + test_ivfpq_share_table.cpp ) add_executable(faiss_test ${FAISS_TEST_SRC}) diff --git a/tests/test_disable_pq_sdc_tables.cpp b/tests/test_disable_pq_sdc_tables.cpp -index f94aac870..60c59d7ba 100644 +index b211a5c4..a27973d5 100644 --- a/tests/test_disable_pq_sdc_tables.cpp +++ b/tests/test_disable_pq_sdc_tables.cpp @@ -15,7 +15,9 @@ @@ -327,10 +327,10 @@ index f94aac870..60c59d7ba 100644 +} TEST(IO, TestReadHNSWPQ_whenSDCDisabledFlagPassed_thenDisableSDCTable) { - // Create a temp file name with a randomized component for stress runs + Tempfilename index_filename(&temp_file_mutex, "/tmp/faiss_TestReadHNSWPQ"); diff --git a/tests/test_ivfpq_share_table.cpp b/tests/test_ivfpq_share_table.cpp new file mode 100644 -index 000000000..f827315d8 +index 00000000..f827315d --- /dev/null +++ b/tests/test_ivfpq_share_table.cpp @@ -0,0 +1,173 @@