12 #include "../../IndexFlat.h"
13 #include "../GpuIndexFlat.h"
14 #include "../StandardGpuResources.h"
15 #include "../utils/DeviceUtils.h"
16 #include "../test/TestUtils.h"
17 #include <gtest/gtest.h>
22 constexpr
float kF16MaxRelErr = 0.07f;
23 constexpr
float kF32MaxRelErr = 6e-3f;
25 void testFlat(
bool useL2,
bool useFloat16,
int kOverride = -1) {
26 int numVecs = faiss::gpu::randVal(1000, 20000);
27 int dim = faiss::gpu::randVal(50, 800);
28 int numQuery = faiss::gpu::randVal(1, 512);
34 std::min(faiss::gpu::randVal(1, 50), numVecs) :
35 std::min(faiss::gpu::randVal(1, 1024), numVecs);
48 int device = faiss::gpu::randVal(0, faiss::gpu::getNumDevices() - 1);
59 std::vector<float> vecs = faiss::gpu::randVecs(numVecs, dim);
60 cpuIndex->
add(numVecs, vecs.data());
61 gpuIndex->
add(numVecs, vecs.data());
63 std::stringstream str;
64 str << (useL2 ?
"L2" :
"IP") <<
" numVecs " << numVecs
66 <<
" useFloat16 " << useFloat16
67 <<
" numQuery " << numQuery
72 faiss::gpu::compareIndices(*cpuIndex, *gpuIndex, numQuery, dim, k, str.str(),
73 useFloat16 ? kF16MaxRelErr : kF32MaxRelErr,
77 useFloat16 ? 0.99f : 0.1f,
78 useFloat16 ? 0.65f : 0.015f);
81 TEST(TestGpuIndexFlat, IP_Float32) {
82 for (
int tries = 0; tries < 10; ++tries) {
83 faiss::gpu::newTestSeed();
84 testFlat(
false,
false);
88 TEST(TestGpuIndexFlat, L2_Float32) {
89 for (
int tries = 0; tries < 10; ++tries) {
90 faiss::gpu::newTestSeed();
91 testFlat(
true,
false);
96 TEST(TestGpuIndexFlat, L2_Float32_K1) {
97 for (
int tries = 0; tries < 5; ++tries) {
98 faiss::gpu::newTestSeed();
99 testFlat(
true,
false, 1);
103 TEST(TestGpuIndexFlat, IP_Float16) {
104 for (
int tries = 0; tries < 10; ++tries) {
105 faiss::gpu::newTestSeed();
106 testFlat(
false,
true);
110 TEST(TestGpuIndexFlat, L2_Float16) {
111 for (
int tries = 0; tries < 10; ++tries) {
112 faiss::gpu::newTestSeed();
113 testFlat(
true,
true);
118 TEST(TestGpuIndexFlat, L2_Float16_K1) {
119 for (
int tries = 0; tries < 5; ++tries) {
120 faiss::gpu::newTestSeed();
121 testFlat(
true,
true, 1);
125 TEST(TestGpuIndexFlat, QueryEmpty) {
136 std::vector<float> queries(numQuery * dim, 1.0f);
138 std::vector<float> dist(numQuery * k, 0);
139 std::vector<faiss::Index::idx_t> ind(numQuery * k);
141 gpuIndex.
search(numQuery, queries.data(), k, dist.data(), ind.data());
143 for (
auto d : dist) {
144 EXPECT_EQ(d, std::numeric_limits<float>::max());
152 TEST(TestGpuIndexFlat, CopyFrom) {
153 faiss::gpu::newTestSeed();
155 int numVecs = faiss::gpu::randVal(100, 200);
156 int dim = faiss::gpu::randVal(1, 1000);
160 std::vector<float> vecs = faiss::gpu::randVecs(numVecs, dim);
161 cpuIndex.
add(numVecs, vecs.data());
167 int device = faiss::gpu::randVal(0, faiss::gpu::getNumDevices() - 1);
172 EXPECT_EQ(gpuIndex.
ntotal, numVecs);
174 EXPECT_EQ(cpuIndex.
d, gpuIndex.
d);
175 EXPECT_EQ(cpuIndex.
d, dim);
177 int idx = faiss::gpu::randVal(0, numVecs - 1);
179 std::vector<float> gpuVals(dim);
182 std::vector<float> cpuVals(dim);
185 EXPECT_EQ(gpuVals, cpuVals);
188 TEST(TestGpuIndexFlat, CopyTo) {
189 faiss::gpu::newTestSeed();
194 int numVecs = faiss::gpu::randVal(100, 200);
195 int dim = faiss::gpu::randVal(1, 1000);
197 int device = faiss::gpu::randVal(0, faiss::gpu::getNumDevices() - 1);
200 std::vector<float> vecs = faiss::gpu::randVecs(numVecs, dim);
201 gpuIndex.
add(numVecs, vecs.data());
205 gpuIndex.
copyTo(&cpuIndex);
208 EXPECT_EQ(gpuIndex.
ntotal, numVecs);
210 EXPECT_EQ(cpuIndex.
d, gpuIndex.
d);
211 EXPECT_EQ(cpuIndex.
d, dim);
213 int idx = faiss::gpu::randVal(0, numVecs - 1);
215 std::vector<float> gpuVals(dim);
218 std::vector<float> cpuVals(dim);
221 EXPECT_EQ(gpuVals, cpuVals);
void copyTo(faiss::IndexFlat *index) const
virtual void reconstruct(idx_t key, float *recons) const override
void reconstruct(faiss::Index::idx_t key, float *out) const override
idx_t ntotal
total nb of indexed vectors
virtual void add(idx_t n, const float *x) override
void copyFrom(const faiss::IndexFlat *index)
void add(Index::idx_t n, const float *x) override
void search(faiss::Index::idx_t n, const float *x, faiss::Index::idx_t k, float *distances, faiss::Index::idx_t *labels) const override