Crates.io | owmath |
lib.rs | owmath |
version | 0.0.8 |
source | src |
created_at | 2021-08-23 16:19:29.707371 |
updated_at | 2021-08-29 07:17:41.802523 |
description | Quaternions, basic functions |
homepage | https://ajoinfinity.com/ |
repository | https://github.com/andy-ow/owmath |
max_upload_size | |
id | 441272 |
size | 30,558 |
Quaternions
use owmath::quaternion::Quaternion;
fn main() {
let a = Quaternion::new(1.0, 2.0, 3.0, 4.0);
let b: Quaternion<f64> = (2.0, 3.0, 4.0, 5.0).into();
println!("{} + {} = {}", a, b, a+b);
println!("{} * {} = {}", a, b, a*b);
println!("{} * {} = {}", b, a, b*a);
println!("2 * {} = {}", a, 2.0*a); // works only for Quaternion<f32> and Quaternion<f64>
println!("{} * 2 = {}", a, a*2.0);
println!("{}⁻¹ = {}", a, a.inverse());
println!("{}.norm() = {}", a, a.norm());
println!("{}.conjugate() = {}", a, a.conjugate());
}
(1, 2, 3, 4) + (2, 3, 4, 5) = (3, 5, 7, 9)
(1, 2, 3, 4) * (2, 3, 4, 5) = (-36, 6, 12, 12)
(2, 3, 4, 5) * (1, 2, 3, 4) = (-36, 8, 8, 14)
2 * (1, 2, 3, 4) = (2, 4, 6, 8)
(1, 2, 3, 4) * 2 = (2, 4, 6, 8)
(1, 2, 3, 4)⁻¹ = (0.03333333333333333, -0.06666666666666667, -0.1, -0.13333333333333333)
(1, 2, 3, 4).norm() = 5.477225575051661
(1, 2, 3, 4).conjugate() = (1, -2, -3, -4)