Skip to main content

DistanceMetric

Enum DistanceMetric 

Source
pub enum DistanceMetric {
    L2,
    Cosine,
    Dot,
}
Expand description

Distance metric used by the HNSW index. Must match what the surrounding vec_distance_* SQL function would compute on the same pair of vectors — otherwise the index probe and the brute-force fallback would disagree on which rows are “nearest”. See src/sql/executor.rs’s vec_distance_l2 / _cosine / _dot for the canonical implementations.

Variants§

§

L2

§

Cosine

§

Dot

Implementations§

Source§

impl DistanceMetric

Source

pub fn from_sql_name(name: &str) -> Option<Self>

Parses the metric name from the CREATE INDEX … WITH (metric = '<name>') clause. Case-insensitive. Returns None for unknown values; the parser surfaces that as a user-visible error so a typo doesn’t silently fall back to L2.

Source

pub fn sql_name(self) -> &'static str

The canonical SQL-surface name for this metric. Used when synthesizing CREATE INDEX SQL back into sqlrite_master.

Source

pub fn matching_distance_fn(self) -> &'static str

The vec_distance_* SQL function whose result this metric orders by. The optimizer’s HNSW shortcut only fires when the query’s ORDER BY expression names this exact function.

Source

pub fn compute(self, a: &[f32], b: &[f32]) -> f32

Computes the configured distance between two equal-dimension vectors. Returns f32::INFINITY for the cosine/zero-magnitude edge case; HNSW treats infinity as “worst possible candidate” and will prefer any finite alternative, which matches the SQL-level behaviour where vec_distance_cosine errors but the optimizer’s fallback path simply skips the offending row.

Trait Implementations§

Source§

impl Clone for DistanceMetric

Source§

fn clone(&self) -> DistanceMetric

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DistanceMetric

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for DistanceMetric

Source§

fn eq(&self, other: &DistanceMetric) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Copy for DistanceMetric

Source§

impl Eq for DistanceMetric

Source§

impl StructuralPartialEq for DistanceMetric

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.