use na::{self, DefaultAllocator}; use crate::aliases::TMat; use crate::traits::{Alloc, Dimension, Number}; /// The sum of every component of the given matrix or vector. /// /// # Examples: /// /// ``` /// # use nalgebra_glm as glm; /// let vec = glm::vec2(3.0, 4.0); /// assert_eq!(7.0, glm::comp_add(&vec)); /// /// let mat = glm::mat2(0.0, 1.0, -3.0, 3.0); /// assert_eq!(1.0, glm::comp_add(&mat)); /// ``` /// /// # See also: /// /// * [`comp_max`](fn.comp_max.html) /// * [`comp_min`](fn.comp_min.html) /// * [`comp_mul`](fn.comp_mul.html) pub fn comp_add(m: &TMat) -> N where DefaultAllocator: Alloc, { m.iter().fold(N::zero(), |x, y| x + *y) } /// The maximum of every component of the given matrix or vector. /// /// # Examples: /// /// ``` /// # use nalgebra_glm as glm; /// let vec = glm::vec2(3.0, 4.0); /// assert_eq!(4.0, glm::comp_max(&vec)); /// /// let mat = glm::mat2(0.0, 1.0, -3.0, 3.0); /// assert_eq!(3.0, glm::comp_max(&mat)); /// ``` /// /// # See also: /// /// * [`comp_add`](fn.comp_add.html) /// * [`comp_max`](fn.comp_max.html) /// * [`comp_min`](fn.comp_min.html) /// * [`max`](fn.max.html) /// * [`max2`](fn.max2.html) /// * [`max3`](fn.max3.html) /// * [`max4`](fn.max4.html) pub fn comp_max(m: &TMat) -> N where DefaultAllocator: Alloc, { m.iter() .fold(N::min_value(), |x, y| crate::max2_scalar(x, *y)) } /// The minimum of every component of the given matrix or vector. /// /// # Examples: /// /// ``` /// # use nalgebra_glm as glm; /// let vec = glm::vec2(3.0, 4.0); /// assert_eq!(3.0, glm::comp_min(&vec)); /// /// let mat = glm::mat2(0.0, 1.0, -3.0, 3.0); /// assert_eq!(-3.0, glm::comp_min(&mat)); /// ``` /// /// # See also: /// /// * [`comp_add`](fn.comp_add.html) /// * [`comp_max`](fn.comp_max.html) /// * [`comp_mul`](fn.comp_mul.html) /// * [`min`](fn.min.html) /// * [`min2`](fn.min2.html) /// * [`min3`](fn.min3.html) /// * [`min4`](fn.min4.html) pub fn comp_min(m: &TMat) -> N where DefaultAllocator: Alloc, { m.iter() .fold(N::max_value(), |x, y| crate::min2_scalar(x, *y)) } /// The product of every component of the given matrix or vector. /// /// # Examples: /// /// ``` /// # use nalgebra_glm as glm; /// let vec = glm::vec2(3.0, 4.0); /// assert_eq!(12.0, glm::comp_mul(&vec)); /// /// let mat = glm::mat2(1.0, 1.0, -3.0, 3.0); /// assert_eq!(-9.0, glm::comp_mul(&mat)); /// ``` /// /// # See also: /// /// * [`comp_add`](fn.comp_add.html) /// * [`comp_max`](fn.comp_max.html) /// * [`comp_min`](fn.comp_min.html) pub fn comp_mul(m: &TMat) -> N where DefaultAllocator: Alloc, { m.iter().fold(N::one(), |x, y| x * *y) } //pub fn vec< L, floatType, Q > compNormalize (vec< L, T, Q > const &v) //pub fn vec< L, T, Q > compScale (vec< L, floatType, Q > const &v)