2023-07-14 18:00:07 +00:00
|
|
|
use crate::err::Error;
|
2023-07-16 13:04:22 +00:00
|
|
|
use crate::fnc::util::math::vector::{
|
|
|
|
Add, Angle, CrossProduct, Divide, DotProduct, Magnitude, Multiply, Normalize, Project, Subtract,
|
|
|
|
};
|
2023-07-14 18:00:07 +00:00
|
|
|
use crate::sql::{Number, Value};
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn add((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.add(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn angle((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.angle(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn divide((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.divide(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn cross((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.cross(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn dot((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.dot(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn magnitude((a,): (Vec<Number>,)) -> Result<Value, Error> {
|
|
|
|
Ok(a.magnitude().into())
|
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn multiply((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.multiply(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn normalize((a,): (Vec<Number>,)) -> Result<Value, Error> {
|
|
|
|
Ok(a.normalize().into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn project((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.project(&b)?.into())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn subtract((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.subtract(&b)?.into())
|
|
|
|
}
|
|
|
|
|
2023-07-14 18:00:07 +00:00
|
|
|
pub mod distance {
|
|
|
|
|
|
|
|
use crate::err::Error;
|
2023-07-16 13:04:22 +00:00
|
|
|
use crate::fnc::util::math::vector::{
|
|
|
|
ChebyshevDistance, EuclideanDistance, HammingDistance, ManhattanDistance, MinkowskiDistance,
|
|
|
|
};
|
2023-07-14 18:00:07 +00:00
|
|
|
use crate::sql::{Number, Value};
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn chebyshev((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.chebyshev_distance(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn euclidean((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
2023-07-16 13:04:22 +00:00
|
|
|
Ok(a.euclidean_distance(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn hamming((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.hamming_distance(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn mahalanobis((_, _): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Err(Error::FeatureNotYetImplemented {
|
|
|
|
feature: "vector::distance::mahalanobis() function",
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn manhattan((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.manhattan_distance(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn minkowski((a, b, o): (Vec<Number>, Vec<Number>, Number)) -> Result<Value, Error> {
|
|
|
|
Ok(a.minkowski_distance(&b, o)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub mod similarity {
|
|
|
|
|
|
|
|
use crate::err::Error;
|
2023-07-16 13:04:22 +00:00
|
|
|
use crate::fnc::util::math::vector::{CosineSimilarity, JaccardSimilarity, PearsonSimilarity};
|
2023-07-14 18:00:07 +00:00
|
|
|
use crate::sql::{Number, Value};
|
|
|
|
|
|
|
|
pub fn cosine((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
2023-07-16 13:04:22 +00:00
|
|
|
Ok(a.cosine_similarity(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn jaccard((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.jaccard_similarity(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
2023-07-16 13:04:22 +00:00
|
|
|
pub fn pearson((a, b): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Ok(a.pearson_similarity(&b)?.into())
|
2023-07-14 18:00:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn spearman((_, _): (Vec<Number>, Vec<Number>)) -> Result<Value, Error> {
|
|
|
|
Err(Error::FeatureNotYetImplemented {
|
|
|
|
feature: "vector::similarity::spearman() function",
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|