pub struct SimdVectorSearch { /* private fields */ }Expand description
SIMD-accelerated flat (brute-force) vector search.
Stores all vectors in memory and computes cosine distances to a query
using scirs2_core’s SIMD dot-product primitive. Parallel execution
is used for batches that exceed the configured threshold.
Implementations§
Source§impl SimdVectorSearch
impl SimdVectorSearch
Sourcepub fn new(parallel_threshold: usize) -> Self
pub fn new(parallel_threshold: usize) -> Self
Create a new empty flat index with the given parallel threshold.
Sourcepub fn default_threshold() -> Self
pub fn default_threshold() -> Self
Create a flat index with the default threshold (256 vectors).
Sourcepub fn insert(&mut self, id: String, vector: Vec<f32>) -> Result<()>
pub fn insert(&mut self, id: String, vector: Vec<f32>) -> Result<()>
Insert a vector under id. If id already exists, the vector is
replaced.
Trait Implementations§
Source§impl Debug for SimdVectorSearch
impl Debug for SimdVectorSearch
Auto Trait Implementations§
impl Freeze for SimdVectorSearch
impl RefUnwindSafe for SimdVectorSearch
impl Send for SimdVectorSearch
impl Sync for SimdVectorSearch
impl Unpin for SimdVectorSearch
impl UnsafeUnpin for SimdVectorSearch
impl UnwindSafe for SimdVectorSearch
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> 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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<R, P> ReadPrimitive<R> for P
impl<R, P> ReadPrimitive<R> for P
Source§fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
fn read_from_little_endian(read: &mut R) -> Result<Self, Error>
Read this value from the supplied reader. Same as
ReadEndian::read_from_little_endian().Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.