Struct Mat4

Source
#[repr(C)]
pub struct Mat4<F> { pub x: Vec4<F>, pub y: Vec4<F>, pub z: Vec4<F>, pub p: Vec4<F>, }
Expand description

A 4x4 matrix

This matrix is internally stored column-major (as that is better for GPU compatibility and possibly other reasons), but the API (e.g. the order of function parameters to the new() function) is row-major, since that is how people write matrices on paper.

Fields§

§x: Vec4<F>§y: Vec4<F>§z: Vec4<F>§p: Vec4<F>

Implementations§

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn new( r0c0: F, r0c1: F, r0c2: F, r0c3: F, r1c0: F, r1c1: F, r1c2: F, r1c3: F, r2c0: F, r2c1: F, r2c2: F, r2c3: F, r3c0: F, r3c1: F, r3c2: F, r3c3: F, ) -> Mat4<F>

Create a new 4x4 Matrix. Specify parameters in row-major order (as typically written on paper and in math texts)

Source

pub fn from_cols(x: Vec4<F>, y: Vec4<F>, z: Vec4<F>, p: Vec4<F>) -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn from_components( x_dir: Direction3<F>, y_dir: Direction3<F>, z_dir: Direction3<F>, pos: Point3<F>, ) -> Mat4<F>

Source

pub fn from_mat3(mat3: Mat3<F>, pos: Point3<F>) -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn zero() -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn identity() -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn transpose(&mut self)

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn determinant(&self) -> F

Source

pub fn inverse(&self) -> Option<Mat4<F>>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn is_diagonal(&self) -> bool

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn is_symmetric(&self) -> bool

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn is_skew_symmetric(&self) -> bool

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn get_translation(&self) -> Point3<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn set_translation(&mut self, p: Point3<F>)

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn from_angle_x(theta: Angle<F>) -> Mat4<F>

Source

pub fn from_angle_y(theta: Angle<F>) -> Mat4<F>

Source

pub fn from_angle_z(theta: Angle<F>) -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn rotate_axis_angle(axis: Direction3<F>, theta: Angle<F>) -> Mat4<F>

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn scale(a: &Vec4<F>) -> Mat4<F>

Scale matrix

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn get_x_scale(&self) -> F

Source

pub fn get_y_scale(&self) -> F

Source

pub fn get_z_scale(&self) -> F

Source§

impl<F: FullFloat> Mat4<F>

Source

pub fn as_mat3(&self) -> Mat3<F>

Trait Implementations§

Source§

impl<'a, 'b, F: FullFloat> Add<&'b Mat4<F>> for &'a Mat4<F>

Source§

type Output = Mat4<F>

The resulting type after applying the + operator.
Source§

fn add(self, rhs: &Mat4<F>) -> Mat4<F>

Performs the + operation. Read more
Source§

impl<F: FullFloat> ApproxEq for Mat4<F>

Source§

type Flt = F

Source§

fn approx_eq( &self, other: &Self, epsilon: <F as ApproxEq>::Flt, ulps: <<F as ApproxEq>::Flt as Ulps>::U, ) -> bool

This method tests for self and other values to be approximately equal using two methods: epsilon and ulps. If the values differ by less than the given epsilon, they will be considered equal. If the values differ by more than epsilon, but by less than the given ulps, they will also be considered equal. Otherwise they are unequal. Read more
Source§

fn approx_ne( &self, other: &Self, epsilon: Self::Flt, ulps: <Self::Flt as Ulps>::U, ) -> bool

This method tests for self and other values to be not approximately equal using two methods: epsilon and ulps. If the values differ by less than the given epsilon, they will be considered equal. If the values differ by more than epsilon, but by less than the given ulps, they will also be considered equal. Otherwise they are unequal. Read more
Source§

impl<F: Clone> Clone for Mat4<F>

Source§

fn clone(&self) -> Mat4<F>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<F: Debug> Debug for Mat4<F>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<F: FullFloat> Default for Mat4<F>

Source§

fn default() -> Mat4<F>

Returns the “default value” for a type. Read more
Source§

impl<'de, F> Deserialize<'de> for Mat4<F>
where F: Deserialize<'de>,

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<Mat4<f32>> for Mat4<f64>

Source§

fn from(m: Mat4<f32>) -> Mat4<f64>

Converts to this type from the input type.
Source§

impl From<Mat4<f64>> for Mat4<f32>

Source§

fn from(m: Mat4<f64>) -> Mat4<f32>

Converts to this type from the input type.
Source§

impl<F: Hash> Hash for Mat4<F>

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<F: FullFloat> Index<(usize, usize)> for Mat4<F>

Source§

type Output = F

The returned type after indexing.
Source§

fn index(&self, (row, col): (usize, usize)) -> &F

Performs the indexing (container[index]) operation. Read more
Source§

impl<F: FullFloat> IndexMut<(usize, usize)> for Mat4<F>

Source§

fn index_mut(&mut self, (row, col): (usize, usize)) -> &mut F

Performs the mutable indexing (container[index]) operation. Read more
Source§

impl<'a, 'b, F: FullFloat> Mul<&'b Mat4<F>> for &'a Mat4<F>

Source§

type Output = Mat4<F>

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: &Mat4<F>) -> Mat4<F>

Performs the * operation. Read more
Source§

impl<'a, 'b, F: FullFloat> Mul<&'a Mat4<F>> for &'a Vec4<F>

Source§

type Output = Vec4<F>

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: &Mat4<F>) -> Vec4<F>

Performs the * operation. Read more
Source§

impl<'a, 'b, F: FullFloat> Mul<&'a Vec4<F>> for &'b Mat4<F>

Source§

type Output = Vec4<F>

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: &Vec4<F>) -> Vec4<F>

Performs the * operation. Read more
Source§

impl<'a, F: FullFloat> Mul<F> for &'a Mat4<F>

Source§

type Output = Mat4<F>

The resulting type after applying the * operator.
Source§

fn mul(self, rhs: F) -> Mat4<F>

Performs the * operation. Read more
Source§

impl<F: PartialEq> PartialEq for Mat4<F>

Source§

fn eq(&self, other: &Mat4<F>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<F> Serialize for Mat4<F>
where F: Serialize,

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl<F: Copy> Copy for Mat4<F>

Source§

impl<F: Eq> Eq for Mat4<F>

Source§

impl<F> StructuralPartialEq for Mat4<F>

Auto Trait Implementations§

§

impl<F> Freeze for Mat4<F>
where F: Freeze,

§

impl<F> RefUnwindSafe for Mat4<F>
where F: RefUnwindSafe,

§

impl<F> Send for Mat4<F>
where F: Send,

§

impl<F> Sync for Mat4<F>
where F: Sync,

§

impl<F> Unpin for Mat4<F>
where F: Unpin,

§

impl<F> UnwindSafe for Mat4<F>
where F: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,