pub struct GraphMerger { /* private fields */ }Expand description
HNSW Graph Merger using IGTM algorithm
Merges a small graph into a large graph using strategic vertex selection. Expected 1.3-1.7x speedup over naive insertion.
Implementations§
Source§impl GraphMerger
impl GraphMerger
Sourcepub fn with_config(config: MergeConfig) -> Self
pub fn with_config(config: MergeConfig) -> Self
Create a new graph merger with custom configuration
Sourcepub fn merge_graphs(
&self,
large: &mut HNSWIndex,
small: &HNSWIndex,
) -> Result<MergeStats>
pub fn merge_graphs( &self, large: &mut HNSWIndex, small: &HNSWIndex, ) -> Result<MergeStats>
Merge a small graph into a large graph using IGTM algorithm
§Algorithm
- Compute join set: Find minimal vertex subset that covers all vertices
(every vertex has ≥
min_coverageneighbors in the join set) - Insert join set into large graph using standard insertion
- For remaining vertices, use join set neighbors as entry points for fast insertion
§Arguments
large- Target graph (will be modified)small- Source graph (vectors will be moved)
§Returns
Merge statistics including timing breakdown
Trait Implementations§
Auto Trait Implementations§
impl Freeze for GraphMerger
impl RefUnwindSafe for GraphMerger
impl Send for GraphMerger
impl Sync for GraphMerger
impl Unpin for GraphMerger
impl UnwindSafe for GraphMerger
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more