common_function/scalars/vector/distance/
dot.rs1use nalgebra::DVectorView;
16
17pub fn dot(lhs: &[f32], rhs: &[f32]) -> f32 {
21 let lhs = DVectorView::from_slice(lhs, lhs.len());
22 let rhs = DVectorView::from_slice(rhs, rhs.len());
23
24 lhs.dot(&rhs)
25}
26
27#[cfg(test)]
28mod tests {
29 use approx::assert_relative_eq;
30
31 use super::*;
32
33 #[test]
34 fn test_dot_scalar() {
35 let lhs = vec![1.0, 2.0, 3.0];
36 let rhs = vec![1.0, 2.0, 3.0];
37 assert_relative_eq!(dot(&lhs, &rhs), 14.0, epsilon = 1e-2);
38
39 let lhs = vec![1.0, 2.0, 3.0];
40 let rhs = vec![4.0, 5.0, 6.0];
41 assert_relative_eq!(dot(&lhs, &rhs), 32.0, epsilon = 1e-2);
42
43 let lhs = vec![1.0, 2.0, 3.0];
44 let rhs = vec![7.0, 8.0, 9.0];
45 assert_relative_eq!(dot(&lhs, &rhs), 50.0, epsilon = 1e-2);
46
47 let lhs = vec![0.0, 0.0, 0.0];
48 let rhs = vec![1.0, 2.0, 3.0];
49 assert_relative_eq!(dot(&lhs, &rhs), 0.0, epsilon = 1e-2);
50
51 let lhs = vec![0.0, 0.0, 0.0];
52 let rhs = vec![4.0, 5.0, 6.0];
53 assert_relative_eq!(dot(&lhs, &rhs), 0.0, epsilon = 1e-2);
54
55 let lhs = vec![0.0, 0.0, 0.0];
56 let rhs = vec![7.0, 8.0, 9.0];
57 assert_relative_eq!(dot(&lhs, &rhs), 0.0, epsilon = 1e-2);
58
59 let lhs = vec![7.0, 8.0, 9.0];
60 let rhs = vec![1.0, 2.0, 3.0];
61 assert_relative_eq!(dot(&lhs, &rhs), 50.0, epsilon = 1e-2);
62
63 let lhs = vec![7.0, 8.0, 9.0];
64 let rhs = vec![4.0, 5.0, 6.0];
65 assert_relative_eq!(dot(&lhs, &rhs), 122.0, epsilon = 1e-2);
66
67 let lhs = vec![7.0, 8.0, 9.0];
68 let rhs = vec![7.0, 8.0, 9.0];
69 assert_relative_eq!(dot(&lhs, &rhs), 194.0, epsilon = 1e-2);
70 }
71}