lol idk #1

Open
Quaternions wants to merge 826 commits from StrafesNET/strafe-project:master into master
Showing only changes of commit 9ad90cea2e - Show all commits

View File

@ -1,4 +1,4 @@
use crate::types::{Matrix3,Matrix3x2,Matrix3x4,Matrix4x2,Vector3}; use crate::types::{Matrix3,Matrix2x3,Matrix4x3,Matrix2x4,Vector3};
type Planar64=fixed_wide::types::I32F32; type Planar64=fixed_wide::types::I32F32;
type Planar64Wide1=fixed_wide::types::I64F64; type Planar64Wide1=fixed_wide::types::I64F64;
@ -12,7 +12,7 @@ fn wide_vec3(){
let v2=v1.wide_mul_2_2(v1); let v2=v1.wide_mul_2_2(v1);
let v3=v2.wide_mul_4_4(v2); let v3=v2.wide_mul_4_4(v2);
assert_eq!(v3,Vector3::from_value(Planar64Wide3::from(3i128.pow(8)))); assert_eq!(v3.array,Vector3::from_value(Planar64Wide3::from(3i128.pow(8))).array);
} }
#[test] #[test]
@ -35,32 +35,34 @@ fn wide_vec3_length_squared(){
assert_eq!(v3,Planar64Wide3::from(3i128.pow(8)*3)); assert_eq!(v3,Planar64Wide3::from(3i128.pow(8)*3));
} }
/*
#[test] #[test]
fn wide_matrix_dot(){ fn wide_matrix_dot(){
let lhs=Matrix3x4::new([ let lhs=Matrix4x3::new([
[Planar64::from(1),Planar64::from(2),Planar64::from(3),Planar64::from(4)], [Planar64::from(1),Planar64::from(2),Planar64::from(3),Planar64::from(4)],
[Planar64::from(5),Planar64::from(6),Planar64::from(7),Planar64::from(8)], [Planar64::from(5),Planar64::from(6),Planar64::from(7),Planar64::from(8)],
[Planar64::from(9),Planar64::from(10),Planar64::from(11),Planar64::from(12)], [Planar64::from(9),Planar64::from(10),Planar64::from(11),Planar64::from(12)],
]); ]);
let rhs=Matrix4x2::new([ let rhs=Matrix2x4::new([
[Planar64::from(1),Planar64::from(2)], [Planar64::from(1),Planar64::from(2)],
[Planar64::from(3),Planar64::from(4)], [Planar64::from(3),Planar64::from(4)],
[Planar64::from(5),Planar64::from(6)], [Planar64::from(5),Planar64::from(6)],
[Planar64::from(7),Planar64::from(8)], [Planar64::from(7),Planar64::from(8)],
]); ]);
// Mat3<Vec4>.dot(Mat4<Vec2>) -> Mat3<Vec2> // Mat3<Vec4>.dot(Mat4<Vec2>) -> Mat3<Vec2>
let m_dot=lhs.wide_dot_3x4_4x2_1_1(rhs); let m_dot=lhs.wide_dot_1_1(rhs);
//In[1]:= {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}} . {{1, 2}, {3, 4}, {5, 6}, {7, 8}} //In[1]:= {{1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}} . {{1, 2}, {3, 4}, {5, 6}, {7, 8}}
//Out[1]= {{50, 60}, {114, 140}, {178, 220}} //Out[1]= {{50, 60}, {114, 140}, {178, 220}}
assert_eq!( assert_eq!(
m_dot, m_dot.array,
Matrix3x2::new([ Matrix2x3::new([
[Planar64Wide1::from(50),Planar64Wide1::from(60)], [Planar64Wide1::from(50),Planar64Wide1::from(60)],
[Planar64Wide1::from(114),Planar64Wide1::from(140)], [Planar64Wide1::from(114),Planar64Wide1::from(140)],
[Planar64Wide1::from(178),Planar64Wide1::from(220)], [Planar64Wide1::from(178),Planar64Wide1::from(220)],
]) ]).array
); );
} }
*/
#[test] #[test]
fn wide_matrix_det(){ fn wide_matrix_det(){
@ -84,11 +86,11 @@ fn wide_matrix_adjugate(){
// In[6]:= Adjugate[{{1, 2, 3}, {4, 5, 7}, {6, 8, 9}}] // In[6]:= Adjugate[{{1, 2, 3}, {4, 5, 7}, {6, 8, 9}}]
// Out[6]= {{-11, 6, -1}, {6, -9, 5}, {2, 4, -3}} // Out[6]= {{-11, 6, -1}, {6, -9, 5}, {2, 4, -3}}
assert_eq!( assert_eq!(
m.wide_adjugate_3x3_1(), m.wide_adjugate_3x3_1().array,
Matrix3::new([ Matrix3::new([
[Planar64Wide1::from(-11),Planar64Wide1::from(6),Planar64Wide1::from(-1)], [Planar64Wide1::from(-11),Planar64Wide1::from(6),Planar64Wide1::from(-1)],
[Planar64Wide1::from(6),Planar64Wide1::from(-9),Planar64Wide1::from(5)], [Planar64Wide1::from(6),Planar64Wide1::from(-9),Planar64Wide1::from(5)],
[Planar64Wide1::from(2),Planar64Wide1::from(4),Planar64Wide1::from(-3)], [Planar64Wide1::from(2),Planar64Wide1::from(4),Planar64Wide1::from(-3)],
]) ]).array
); );
} }