use std::fmt;
use bytemuck::{Pod, Zeroable};
use crate::distance::Distance;
use crate::node::Item;
use crate::spaces::simple::{dot_product, euclidean_distance};
use crate::unaligned_vector::UnalignedVector;
#[derive(Debug, Clone)]
pub enum Euclidean {}
#[repr(C)]
#[derive(Pod, Zeroable, Clone, Copy)]
pub struct NodeHeaderEuclidean {
bias: f32,
}
impl fmt::Debug for NodeHeaderEuclidean {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_struct("NodeHeaderEuclidean").field("bias", &format!("{:.4}", self.bias)).finish()
}
}
impl Distance for Euclidean {
type Header = NodeHeaderEuclidean;
type VectorCodec = f32;
fn name() -> &'static str {
"euclidean"
}
fn new_header(_vector: &UnalignedVector<Self::VectorCodec>) -> Self::Header {
NodeHeaderEuclidean { bias: 0.0 }
}
fn distance(p: &Item<Self>, q: &Item<Self>) -> f32 {
euclidean_distance(&p.vector, &q.vector)
}
fn norm_no_header(v: &UnalignedVector<Self::VectorCodec>) -> f32 {
dot_product(v, v).sqrt()
}
}