Skip to main content

SearchIndex

Struct SearchIndex 

Source
pub struct SearchIndex { /* private fields */ }
Expand description

In-memory inverted index mapping tokens to weighted (node_id, weight) pairs.

Built from a KnowledgeGraph via SearchIndex::build. Each node contributes tokens from its label, id, and source_file, each with a different base weight plus a degree-based boost.

Implementations§

Source§

impl SearchIndex

Source

pub fn build(graph: &KnowledgeGraph) -> Self

Build the inverted index from a knowledge graph.

Token weights:

  • Label token: 2.0 + ln_1p(degree) * 0.1
  • Id token: 1.0 + ln_1p(degree) * 0.1
  • Source file token: 0.5 + ln_1p(degree) * 0.1

Note: the same token from multiple fields (label + id) stacks additively, rewarding nodes whose token appears in multiple fields.

Source

pub fn search(&self, terms: &[String]) -> Vec<(f64, String)>

Search for nodes matching any of the given terms.

Each term is tokenized and matched against the index using exact and prefix matching. Scores are aggregated per node. Results are returned sorted by descending score.

Prefix matches receive half the weight of an exact match.

Auto Trait Implementations§

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> 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, 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<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