2018-02-02 19:26:35 +08:00
|
|
|
use num::{One, Zero};
|
2016-12-05 05:44:42 +08:00
|
|
|
|
2020-03-21 19:16:46 +08:00
|
|
|
use simba::scalar::{ClosedAdd, ClosedMul};
|
2016-12-05 05:44:42 +08:00
|
|
|
|
2019-03-23 21:29:07 +08:00
|
|
|
use crate::base::allocator::Allocator;
|
|
|
|
use crate::base::dimension::DimName;
|
|
|
|
use crate::base::{DefaultAllocator, MatrixN, Scalar};
|
2016-12-05 05:44:42 +08:00
|
|
|
|
2019-03-23 21:29:07 +08:00
|
|
|
use crate::geometry::Rotation;
|
2016-12-05 05:44:42 +08:00
|
|
|
|
2017-08-03 01:37:44 +08:00
|
|
|
impl<N, D: DimName> Rotation<N, D>
|
2018-02-02 19:26:35 +08:00
|
|
|
where
|
2019-12-17 07:09:14 +08:00
|
|
|
N: Scalar + Zero + One,
|
2018-02-02 19:26:35 +08:00
|
|
|
DefaultAllocator: Allocator<N, D, D>,
|
|
|
|
{
|
2016-12-05 05:44:42 +08:00
|
|
|
/// Creates a new square identity rotation of the given `dimension`.
|
2018-11-04 14:20:49 +08:00
|
|
|
///
|
|
|
|
/// # Example
|
|
|
|
/// ```
|
|
|
|
/// # use nalgebra::Quaternion;
|
|
|
|
/// let rot1 = Quaternion::identity();
|
|
|
|
/// let rot2 = Quaternion::new(1.0, 2.0, 3.0, 4.0);
|
|
|
|
///
|
|
|
|
/// assert_eq!(rot1 * rot2, rot2);
|
|
|
|
/// assert_eq!(rot2 * rot1, rot2);
|
|
|
|
/// ```
|
2016-12-05 05:44:42 +08:00
|
|
|
#[inline]
|
2017-08-03 01:37:44 +08:00
|
|
|
pub fn identity() -> Rotation<N, D> {
|
|
|
|
Self::from_matrix_unchecked(MatrixN::<N, D>::identity())
|
2016-12-05 05:44:42 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-03 01:37:44 +08:00
|
|
|
impl<N, D: DimName> One for Rotation<N, D>
|
2018-02-02 19:26:35 +08:00
|
|
|
where
|
2019-12-17 07:09:14 +08:00
|
|
|
N: Scalar + Zero + One + ClosedAdd + ClosedMul,
|
2018-02-02 19:26:35 +08:00
|
|
|
DefaultAllocator: Allocator<N, D, D>,
|
|
|
|
{
|
2016-12-05 05:44:42 +08:00
|
|
|
#[inline]
|
|
|
|
fn one() -> Self {
|
|
|
|
Self::identity()
|
|
|
|
}
|
|
|
|
}
|