pub struct ParallelSearcher<'a> { /* private fields */ }Expand description
Parallel searcher for multi-index queries.
Wraps an IndexRegistry and provides parallel search operations.
§Example
ⓘ
use rag_plusplus_core::index::{IndexRegistry, ParallelSearcher, FlatIndex, IndexConfig};
let mut registry = IndexRegistry::new();
registry.register("text", FlatIndex::new(IndexConfig::new(768)))?;
registry.register("code", FlatIndex::new(IndexConfig::new(512)))?;
let searcher = ParallelSearcher::new(®istry);
let results = searcher.search_parallel(&query, 10)?;Implementations§
Source§impl<'a> ParallelSearcher<'a>
impl<'a> ParallelSearcher<'a>
Sourcepub fn new(registry: &'a IndexRegistry) -> Self
pub fn new(registry: &'a IndexRegistry) -> Self
Create a new parallel searcher with default config.
Sourcepub fn with_config(
registry: &'a IndexRegistry,
config: ParallelSearchConfig,
) -> Self
pub fn with_config( registry: &'a IndexRegistry, config: ParallelSearchConfig, ) -> Self
Create a new parallel searcher with custom config.
Sourcepub fn search_parallel(
&self,
query: &[f32],
k: usize,
) -> Result<MultiIndexResults>
pub fn search_parallel( &self, query: &[f32], k: usize, ) -> Result<MultiIndexResults>
Sourcepub fn search_indexes_parallel(
&self,
names: &[&str],
query: &[f32],
k: usize,
) -> Result<MultiIndexResults>
pub fn search_indexes_parallel( &self, names: &[&str], query: &[f32], k: usize, ) -> Result<MultiIndexResults>
Search specific indexes in parallel.
§Arguments
names- Index names to searchquery- Query vectork- Number of results per index
Sourcepub fn search_batch(
&self,
queries: &[Vec<f32>],
k: usize,
) -> Vec<Result<MultiIndexResults>> ⓘ
pub fn search_batch( &self, queries: &[Vec<f32>], k: usize, ) -> Vec<Result<MultiIndexResults>> ⓘ
Sourcepub fn search_indexes_batch(
&self,
names: &[&str],
queries: &[Vec<f32>],
k: usize,
) -> Vec<Result<MultiIndexResults>> ⓘ
pub fn search_indexes_batch( &self, names: &[&str], queries: &[Vec<f32>], k: usize, ) -> Vec<Result<MultiIndexResults>> ⓘ
Batch search specific indexes.
Auto Trait Implementations§
impl<'a> Freeze for ParallelSearcher<'a>
impl<'a> !RefUnwindSafe for ParallelSearcher<'a>
impl<'a> Send for ParallelSearcher<'a>
impl<'a> Sync for ParallelSearcher<'a>
impl<'a> Unpin for ParallelSearcher<'a>
impl<'a> !UnwindSafe for ParallelSearcher<'a>
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Gets the layout of the type.