pub struct SimdDistanceMetrics { /* private fields */ }Expand description
SIMD-accelerated distance computations
Implementations§
Source§impl SimdDistanceMetrics
impl SimdDistanceMetrics
Sourcepub fn with_config(config: HardwareAccelConfig) -> Self
pub fn with_config(config: HardwareAccelConfig) -> Self
Create with custom configuration
Sourcepub fn euclidean_distance_simd<F>(
&self,
a: &Array1<F>,
b: &Array1<F>,
) -> Result<F>
pub fn euclidean_distance_simd<F>( &self, a: &Array1<F>, b: &Array1<F>, ) -> Result<F>
Compute Euclidean distance using SIMD
Sourcepub fn manhattan_distance_simd<F>(
&self,
a: &Array1<F>,
b: &Array1<F>,
) -> Result<F>
pub fn manhattan_distance_simd<F>( &self, a: &Array1<F>, b: &Array1<F>, ) -> Result<F>
Compute Manhattan distance using SIMD
Sourcepub fn cosine_distance_simd<F>(&self, a: &Array1<F>, b: &Array1<F>) -> Result<F>
pub fn cosine_distance_simd<F>(&self, a: &Array1<F>, b: &Array1<F>) -> Result<F>
Compute cosine distance using SIMD
Sourcepub fn dot_product_simd<F>(&self, a: &Array1<F>, b: &Array1<F>) -> Result<F>
pub fn dot_product_simd<F>(&self, a: &Array1<F>, b: &Array1<F>) -> Result<F>
Compute dot product using SIMD
Sourcepub fn euclidean_norm_simd<F>(&self, a: &Array1<F>) -> Result<F>
pub fn euclidean_norm_simd<F>(&self, a: &Array1<F>) -> Result<F>
Compute Euclidean norm using SIMD
Trait Implementations§
Auto Trait Implementations§
impl Freeze for SimdDistanceMetrics
impl RefUnwindSafe for SimdDistanceMetrics
impl Send for SimdDistanceMetrics
impl Sync for SimdDistanceMetrics
impl Unpin for SimdDistanceMetrics
impl UnwindSafe for SimdDistanceMetrics
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> 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<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.