mirror of
https://github.com/facebookresearch/faiss.git
synced 2025-06-03 21:54:02 +08:00
Summary: Pull Request resolved: https://github.com/facebookresearch/faiss/pull/2992 Reviewed By: mdouze Differential Revision: D48391366 Pulled By: algoriddle fbshipit-source-id: 94b7f62afc8a09a9feaea47bf60e5358d89fcde5
34 lines
969 B
C++
34 lines
969 B
C++
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <faiss/utils/AlignedTable.h>
|
|
#include <faiss/utils/partitioning.h>
|
|
|
|
using namespace faiss;
|
|
|
|
typedef AlignedTable<uint16_t> AlignedTableUint16;
|
|
|
|
// TODO: This test fails when Faiss is compiled with
|
|
// GCC 13.2 from conda-forge with AVX2 enabled. This may be
|
|
// a GCC bug that needs to be investigated further.
|
|
// As of 16-AUG-2023 the Faiss conda packages are built
|
|
// with GCC 11.2, so the published binaries are not affected.
|
|
TEST(TestPartitioning, TestPartitioningBigRange) {
|
|
auto n = 1024;
|
|
AlignedTableUint16 tab(n);
|
|
for (auto i = 0; i < n; i++) {
|
|
tab[i] = i * 64;
|
|
}
|
|
int32_t hist[16]{};
|
|
simd_histogram_16(tab.get(), n, 0, 12, hist);
|
|
for (auto i = 0; i < 16; i++) {
|
|
ASSERT_EQ(hist[i], 64);
|
|
}
|
|
}
|