9 #include "../../IndexBinaryFlat.h"
10 #include "../../utils.h"
11 #include "../GpuIndexBinaryFlat.h"
12 #include "../StandardGpuResources.h"
13 #include "../test/TestUtils.h"
14 #include "../utils/DeviceTensor.cuh"
15 #include "../utils/DeviceUtils.h"
16 #include "../utils/HostTensor.cuh"
17 #include "../utils/Timer.h"
18 #include <gflags/gflags.h>
23 #include <cuda_profiler_api.h>
25 DEFINE_int32(k, 3,
"final number of closest results returned");
26 DEFINE_int32(num, 128,
"# of vecs");
27 DEFINE_int32(dim, 128,
"# of dimensions");
28 DEFINE_int32(num_queries, 3,
"number of query vectors");
29 DEFINE_int64(seed, -1,
"specify random seed");
30 DEFINE_int64(pinned_mem, 0,
"pinned memory allocation to use");
31 DEFINE_bool(cpu,
true,
"run the CPU code for timing and comparison");
32 DEFINE_bool(use_unified_mem,
false,
"use Pascal unified memory for the index");
34 using namespace faiss::gpu;
36 int main(
int argc,
char** argv) {
37 gflags::ParseCommandLineFlags(&argc, &argv,
true);
41 auto seed = FLAGS_seed != -1L ? FLAGS_seed : time(
nullptr);
42 printf(
"using seed %ld\n", seed);
44 auto numQueries = FLAGS_num_queries;
46 auto index = std::unique_ptr<faiss::IndexBinaryFlat>(
50 faiss::byte_rand(vecs.data(), vecs.numElements(), seed);
52 index->add(FLAGS_num, vecs.data());
54 printf(
"Database: dim %d num vecs %d\n", FLAGS_dim, FLAGS_num);
55 printf(
"Hamming lookup: %d queries, total k %d\n",
59 printf(
"Copying index to GPU...\n");
63 MemorySpace::Unified : MemorySpace::Device;
70 printf(
"copy done\n");
74 faiss::byte_rand(cpuQuery.data(), cpuQuery.numElements(), seed);
78 cpuDistances({numQueries, FLAGS_k});
80 cpuIndices({numQueries, FLAGS_k});
86 index->search(numQueries,
93 printf(
"CPU time %.3f ms\n", cpuTime);
99 CUDA_VERIFY(cudaProfilerStart());
100 faiss::gpu::synchronizeAllDevices();
102 float gpuTime = 0.0f;
108 gpuIndex.search(cpuQuery.getSize(0),
119 CUDA_VERIFY(cudaProfilerStop());
120 printf(
"GPU time %.3f ms\n", gpuTime);
122 CUDA_VERIFY(cudaDeviceSynchronize());
float elapsedMilliseconds()
Returns elapsed time in milliseconds.
CPU wallclock elapsed timer.