Skip to main content

DiskSearchStrategy

Struct DiskSearchStrategy 

Source
pub struct DiskSearchStrategy<'a, Data, ProviderFactory>
where Data: GraphDataType<VectorIdType = u32>, ProviderFactory: VertexProviderFactory<Data>,
{ /* private fields */ }
Expand description

The search strategy for the disk provider. This is used to create the search accessor for use in search in quant space and post_process function to reorder with full precision vectors.

§Why vertex_provider_factory and scratch_pool are here instead of DiskProvider

The DataProvider trait requires ’static bounds for multi-threaded async contexts, but vertex_provider_factory may have non-’static lifetime bounds (e.g., borrowing from local data structures). Moving these components to the search strategy allows DiskProvider to satisfy ’static constraints while enabling flexible per-search resource management.

Trait Implementations§

Source§

impl<'this, Data, ProviderFactory> SearchStrategy<DiskProvider<Data>, [<Data as GraphDataType>::VectorDataType], (<DiskProvider<Data> as DataProvider>::InternalId, <Data as GraphDataType>::AssociatedDataType)> for DiskSearchStrategy<'this, Data, ProviderFactory>
where Data: GraphDataType<VectorIdType = u32>, ProviderFactory: VertexProviderFactory<Data>,

Source§

type QueryComputer = DiskQueryComputer

The computer used by the associated accessor. Read more
Source§

type SearchAccessor<'a> = DiskAccessor<'a, Data, <ProviderFactory as VertexProviderFactory<Data>>::VertexProviderType>

The concrete type of the accessor that is used to access Self during the greedy graph search. The query will be provided to the accessor exactly once during search to construct the query computer.
Source§

type SearchAccessorError = ANNError

An error that can occur when getting a search_accessor.
Source§

type PostProcessor = RerankAndFilter<'this>

The associated SearchPostProcessor for the final results.
Source§

fn search_accessor<'a>( &'a self, provider: &'a DiskProvider<Data>, _context: &DefaultContext, ) -> Result<Self::SearchAccessor<'a>, Self::SearchAccessorError>

Construct and return the search accessor.
Source§

fn post_processor(&self) -> Self::PostProcessor

Construct the SearchPostProcess struct to post-process the results of search and store them into the output container.

Auto Trait Implementations§

§

impl<'a, Data, ProviderFactory> !Freeze for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> !RefUnwindSafe for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> Send for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> Sync for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> Unpin for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> UnsafeUnpin for DiskSearchStrategy<'a, Data, ProviderFactory>

§

impl<'a, Data, ProviderFactory> !UnwindSafe for DiskSearchStrategy<'a, Data, ProviderFactory>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> ByRef<T> for T

Source§

fn by_ref(&self) -> &T

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> AsyncFriendly for T
where T: Send + Sync + 'static,