Commit e1d127c
authored
[FEA] IVF-PQ Build Factories for Precomputed Centroids and Codebooks (rapidsai#1483)
IVF-PQ Index Build API Enhancements and PIMPL Refactoring
## Summary
This PR adds new build APIs for IVF-PQ indices using precomputed centroids and implements a complete PIMPL refactoring with owning/view semantics
## Key Changes
1. New Build APIs for Precomputed Centroids
Added `cuvs::neighbors::ivf_pq::build()` overloads that accept precomputed cluster centroids, PQ codebooks, and rotation matrices
Enables building indices from pre-trained models without re-training
Supports both device and host input data with automatic memory transfer
2. PIMPL Refactoring with Owning/View Semantics
`owning_impl`: Owns centroid and codebook data (traditional behavior)
`view_impl`: References external centroid data without copying
Maintains identical search behavior with zero data copying
3. Enhanced Helper Functions
Removed mutator functions that directly modify the state of the index. Instead we have helpers for the user to fetch and own the transformed data
View indices avoid copying large centroid arrays
Backward Compatibility: All existing APIs work unchanged
[Updates] (as of 12/23/2025):
The non-const getters that allow direct modification of the state of the index:
`pq_centers()`, `centers()`, `centers_rot()` and `rotation_matrix()` have been removed from the interface and the user-facing class.
Authors:
- Tarang Jain (https://github.com/tarang-jain)
- Corey J. Nolet (https://github.com/cjnolet)
- Vyas Ramasubramani (https://github.com/vyasr)
- Lorenzo Dematté (https://github.com/ldematte)
- Divye Gala (https://github.com/divyegala)
Approvers:
- Kyle Edwards (https://github.com/KyleFromNVIDIA)
- Micka (https://github.com/lowener)
URL: rapidsai#14831 parent 1c67635 commit e1d127c
File tree
13 files changed
+1765
-461
lines changed- cpp
- cmake/patches
- include/cuvs/neighbors
- src/neighbors
- ivf_pq
- detail
- tests/neighbors
- ann_ivf_pq
13 files changed
+1765
-461
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| |||
492 | 492 | | |
493 | 493 | | |
494 | 494 | | |
| 495 | + | |
495 | 496 | | |
496 | 497 | | |
497 | 498 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
9 | 9 | | |
10 | 10 | | |
11 | 11 | | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
12 | 17 | | |
13 | 18 | | |
14 | 19 | | |
| |||
0 commit comments