forked from M-Labs/nalgebra
Various documentation fixes.
This commit is contained in:
parent
41fb5403b5
commit
b8b86e72b5
@ -134,5 +134,5 @@ pub fn mat4<N: Scalar>(m11: N, m12: N, m13: N, m14: N, m21: N, m22: N, m23: N, m
|
|||||||
|
|
||||||
/// Creates a new quaternion.
|
/// Creates a new quaternion.
|
||||||
pub fn quat<N: Real>(x: N, y: N, z: N, w: N) -> Qua<N> {
|
pub fn quat<N: Real>(x: N, y: N, z: N, w: N) -> Qua<N> {
|
||||||
Qua::new(x, y, z, w)
|
Qua::new(w, x, y, z)
|
||||||
}
|
}
|
||||||
|
@ -12,12 +12,12 @@ pub fn max4_scalar<N: Number>(a: N, b: N, c: N, d: N) -> N {
|
|||||||
na::sup(&na::sup(&a, &b), &na::sup(&c, &d))
|
na::sup(&na::sup(&a, &b), &na::sup(&c, &d))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the maximum among three values.
|
/// Returns the minimum among three values.
|
||||||
pub fn min3_scalar<N: Number>(a: N, b: N, c: N) -> N {
|
pub fn min3_scalar<N: Number>(a: N, b: N, c: N) -> N {
|
||||||
na::inf(&na::inf(&a, &b), &c)
|
na::inf(&na::inf(&a, &b), &c)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the maximum among four values.
|
/// Returns the minimum among four values.
|
||||||
pub fn min4_scalar<N: Number>(a: N, b: N, c: N, d: N) -> N {
|
pub fn min4_scalar<N: Number>(a: N, b: N, c: N, d: N) -> N {
|
||||||
na::inf(&na::inf(&a, &b), &na::inf(&c, &d))
|
na::inf(&na::inf(&a, &b), &na::inf(&c, &d))
|
||||||
}
|
}
|
@ -1,7 +1,7 @@
|
|||||||
use approx::AbsDiffEq;
|
use approx::AbsDiffEq;
|
||||||
use na::Real;
|
use na::Real;
|
||||||
|
|
||||||
/// Default epsilon value used for apporximate comparison.
|
/// Default epsilon value used for approximate comparison.
|
||||||
pub fn epsilon<N: AbsDiffEq<Epsilon = N>>() -> N {
|
pub fn epsilon<N: AbsDiffEq<Epsilon = N>>() -> N {
|
||||||
N::default_epsilon()
|
N::default_epsilon()
|
||||||
}
|
}
|
||||||
|
@ -78,7 +78,7 @@ pub fn root_half_pi<N: Real>() -> N {
|
|||||||
|
|
||||||
/// Returns `sqrt(ln(4))`.
|
/// Returns `sqrt(ln(4))`.
|
||||||
pub fn root_ln_four<N: Real>() -> N {
|
pub fn root_ln_four<N: Real>() -> N {
|
||||||
na::convert::<_, N>(4.0).sqrt()
|
na::convert::<_, N>(4.0).ln().sqrt()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns the square root of pi.
|
/// Returns the square root of pi.
|
||||||
@ -104,7 +104,7 @@ pub fn root_two_pi<N: Real>() -> N {
|
|||||||
|
|
||||||
/// Returns `1 / 3`.
|
/// Returns `1 / 3`.
|
||||||
pub fn third<N: Real>() -> N {
|
pub fn third<N: Real>() -> N {
|
||||||
na::convert(1.0 / 2.0)
|
na::convert(1.0 / 3.0)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns `3 / (2pi)`.
|
/// Returns `3 / (2pi)`.
|
||||||
@ -119,7 +119,7 @@ pub fn two_over_pi<N: Real>() -> N {
|
|||||||
|
|
||||||
/// Returns `2 / sqrt(pi)`.
|
/// Returns `2 / sqrt(pi)`.
|
||||||
pub fn two_over_root_pi<N: Real>() -> N {
|
pub fn two_over_root_pi<N: Real>() -> N {
|
||||||
N::frac_2_pi()
|
N::frac_2_sqrt_pi()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns `2pi`.
|
/// Returns `2pi`.
|
||||||
|
@ -34,6 +34,7 @@ pub fn quat_less_than_equal<N: Real>(x: &Qua<N>, y: &Qua<N>) -> TVec<bool, U4> {
|
|||||||
pub fn quat_cast<N: Real>(x: &Qua<N>) -> TMat4<N> {
|
pub fn quat_cast<N: Real>(x: &Qua<N>) -> TMat4<N> {
|
||||||
::quat_to_mat4(x)
|
::quat_to_mat4(x)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Computes a right-handed look-at quaternion (equivalent to a right-handed look-at matrix).
|
/// Computes a right-handed look-at quaternion (equivalent to a right-handed look-at matrix).
|
||||||
pub fn quat_look_at<N: Real>(direction: &TVec3<N>, up: &TVec3<N>) -> Qua<N> {
|
pub fn quat_look_at<N: Real>(direction: &TVec3<N>, up: &TVec3<N>) -> Qua<N> {
|
||||||
quat_look_at_rh(direction, up)
|
quat_look_at_rh(direction, up)
|
||||||
|
@ -9,13 +9,5 @@ pub fn matrix_cross3<N: Real>(x: &TVec3<N>) -> TMat3<N> {
|
|||||||
|
|
||||||
/// Builds a 4x4 matrix `m` such that for any `v`: `m * v == cross(x, v)`.
|
/// Builds a 4x4 matrix `m` such that for any `v`: `m * v == cross(x, v)`.
|
||||||
pub fn matrix_cross<N: Real>(x: &TVec3<N>) -> TMat4<N> {
|
pub fn matrix_cross<N: Real>(x: &TVec3<N>) -> TMat4<N> {
|
||||||
let m = x.cross_matrix();
|
::mat3_to_mat4(&x.cross_matrix())
|
||||||
|
|
||||||
// FIXME: use a dedicated constructor from Matrix3 to Matrix4.
|
|
||||||
TMat4::new(
|
|
||||||
m.m11, m.m12, m.m13, N::zero(),
|
|
||||||
m.m21, m.m22, m.m23, N::zero(),
|
|
||||||
m.m31, m.m32, m.m33, N::zero(),
|
|
||||||
N::zero(), N::zero(), N::zero(), N::one(),
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ pub fn diagonal2x4<N: Number>(v: &TVec2<N>) -> TMat2x4<N> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Builds a 3x2 diagonal matrix.
|
/// Builds a 3x2 diagonal matrix.
|
||||||
pub fn diagonal3x2<N: Number>(v: &TVec3<N>) -> TMat3x2<N> {
|
pub fn diagonal3x2<N: Number>(v: &TVec2<N>) -> TMat3x2<N> {
|
||||||
TMat3x2::from_partial_diagonal(v.as_slice())
|
TMat3x2::from_partial_diagonal(v.as_slice())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -32,12 +32,12 @@ pub fn diagonal3x4<N: Number>(v: &TVec3<N>) -> TMat3x4<N> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Builds a 4x2 diagonal matrix.
|
/// Builds a 4x2 diagonal matrix.
|
||||||
pub fn diagonal4x2<N: Number>(v: &TVec4<N>) -> TMat4x2<N> {
|
pub fn diagonal4x2<N: Number>(v: &TVec2<N>) -> TMat4x2<N> {
|
||||||
TMat4x2::from_partial_diagonal(v.as_slice())
|
TMat4x2::from_partial_diagonal(v.as_slice())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Builds a 4x3 diagonal matrix.
|
/// Builds a 4x3 diagonal matrix.
|
||||||
pub fn diagonal4x3<N: Number>(v: &TVec4<N>) -> TMat4x3<N> {
|
pub fn diagonal4x3<N: Number>(v: &TVec3<N>) -> TMat4x3<N> {
|
||||||
TMat4x3::from_partial_diagonal(v.as_slice())
|
TMat4x3::from_partial_diagonal(v.as_slice())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@ pub fn distance2<N: Real, D: Dimension>(p0: &TVec<N, D>, p1: &TVec<N, D>) -> N
|
|||||||
/// The l1-norm of `x - y`.
|
/// The l1-norm of `x - y`.
|
||||||
pub fn l1_distance<N: Real, D: Dimension>(x: &TVec<N, D>, y: &TVec<N, D>) -> N
|
pub fn l1_distance<N: Real, D: Dimension>(x: &TVec<N, D>, y: &TVec<N, D>) -> N
|
||||||
where DefaultAllocator: Alloc<N, D> {
|
where DefaultAllocator: Alloc<N, D> {
|
||||||
l1_norm(&(x - y))
|
l1_norm(&(y - x))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// The l1-norm of `v`.
|
/// The l1-norm of `v`.
|
||||||
|
@ -48,7 +48,6 @@ pub fn quat_rotate_vec3<N: Real>(q: &Qua<N>, v: &TVec3<N>) -> TVec3<N> {
|
|||||||
|
|
||||||
/// Rotates a vector in homogeneous coordinates by a quaternion assumed to be normalized.
|
/// Rotates a vector in homogeneous coordinates by a quaternion assumed to be normalized.
|
||||||
pub fn quat_rotate_vec<N: Real>(q: &Qua<N>, v: &TVec4<N>) -> TVec4<N> {
|
pub fn quat_rotate_vec<N: Real>(q: &Qua<N>, v: &TVec4<N>) -> TVec4<N> {
|
||||||
// UnitQuaternion::new_unchecked(*q) * v
|
|
||||||
let rotated = Unit::new_unchecked(*q) * v.fixed_rows::<U3>(0);
|
let rotated = Unit::new_unchecked(*q) * v.fixed_rows::<U3>(0);
|
||||||
TVec4::new(rotated.x, rotated.y, rotated.z, v.w)
|
TVec4::new(rotated.x, rotated.y, rotated.z, v.w)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user