#[allow(unused_imports)] use std::cmp::Ordering; #[allow(unused_imports)] use std::ops::Div; use i_comparable::IComparableError; #[test] fn test_mat1x4() { use mat::Mat1x4; use mat::Mat4; { let v = Mat1x4 { _val: [10f64; 4] }; assert!(v.size().expect("size result invalid") == 4); let v2 = Mat1x4 { _val: [2f64; 4] }; { let v3 = v.mul_elem(&v2).expect("mul result invalid"); assert!(v3 .is_equal(&Mat1x4 { _val: [20f64; 4] }, 0.0001f64) .expect("Mat1x4 is_equal invalid")); } { let v3 = v.div(&v2).expect("div result invalid"); assert!(v3 .is_equal(&Mat1x4 { _val: [5f64; 4] }, 0.0001f64) .expect("Mat1x4 is_equal invalid")); } { let v3 = v.plus(&v2).expect("plus result invalid"); assert!(v3 .is_equal(&Mat1x4 { _val: [12f64; 4] }, 0.0001f64) .expect("Mat1x4 is_equal invalid")); } { let v3 = v.minus(&v2).expect("plus result invalid"); assert!(v3 .is_equal(&Mat1x4 { _val: [8f64; 4] }, 0.0001f64) .expect("Mat1x4 is_equal invalid")); } assert!(v2.magnitude().expect("magnitude invalid") == ((2f64 * 2f64) * 4f64).sqrt()); let v4 = v2.normalize().expect("normalize invalid"); assert!(v4 .is_equal( &Mat1x4 { _val: [2f64.div((2f64 * 2f64 * 4f64).sqrt()); 4] }, 0.0001f64 ) .expect("Mat1x4 is_equal invalid")); let v5 = v2.scale(4f64).expect("scale invalid"); assert!(v5 .is_equal(&Mat1x4 { _val: [8f64; 4] }, 0.0001f64) .expect("Mat1x4 is_equal invalid")); let v6 = Mat1x4 { _val: [5.0f64, 5.3f64, 7.7f64, 20f64], }; let v7 = Mat1x4 { _val: [5.1f64, 5.4f64, 7.8f64, 19.9f64], }; assert!(v6 .is_equal(&v7, 0.1001f64) .expect("Mat1x4 is_equal invalid")); assert!( v6.is_equal(&v7, 0.0999f64) .expect("Mat1x4 is_equal invalid") == false ); } { //mat1x4 mul mat4x4 let v2 = Mat1x4 { _val: [1f64, 2f64, -4f64, 5f64], }; let mut arr = [0f64; 16]; for x in 0..16 { arr[x] = x as f64; } let is_row_major = true; let v1 = Mat4::::init(arr, is_row_major); let v3 = v2.mul_mat4x4(&v1).expect("mat1x4 mul mat4x4 invalid"); assert!(v3 .is_equal( &Mat1x4 { _val: [36f64, 40f64, 44f64, 48f64] }, 0.00001f64 ) .expect("mat1x4 is_equal invalid")); } }