1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
use number_traits::Num; #[inline] pub fn sub<'a, 'b, T: Copy + Num>(out: &'a mut [T; 2], a: &'b [T; 2], b: &'b [T; 2]) -> &'a mut [T; 2] { out[0] = a[0] - b[0]; out[1] = a[1] - b[1]; out } #[test] fn test_sub() { let mut v = [0, 0]; sub(&mut v, &[1, 1], &[1, 1]); assert!(v[0] == 0); assert!(v[1] == 0); } #[inline] pub fn ssub<'a, 'b, T: Copy + Num>(out: &'a mut [T; 2], a: &'b [T; 2], s: T) -> &'a mut [T; 2] { out[0] = a[0] - s; out[1] = a[1] - s; out } #[test] fn test_ssub() { let mut v = [0, 0]; ssub(&mut v, &[1, 1], 1); assert!(v[0] == 0); assert!(v[1] == 0); }