nalgebra_glm/
trigonometric.rs1use crate::RealNumber;
2use crate::aliases::TVec;
3
4pub fn acos<T: RealNumber, const D: usize>(x: &TVec<T, D>) -> TVec<T, D> {
6 x.map(|e| e.acos())
7}
8
9pub fn acosh<T: RealNumber, const D: usize>(x: &TVec<T, D>) -> TVec<T, D> {
11 x.map(|e| e.acosh())
12}
13
14pub fn asin<T: RealNumber, const D: usize>(x: &TVec<T, D>) -> TVec<T, D> {
16 x.map(|e| e.asin())
17}
18
19pub fn asinh<T: RealNumber, const D: usize>(x: &TVec<T, D>) -> TVec<T, D> {
21 x.map(|e| e.asinh())
22}
23
24pub fn atan2<T: RealNumber, const D: usize>(y: &TVec<T, D>, x: &TVec<T, D>) -> TVec<T, D> {
26 y.zip_map(x, |y, x| y.atan2(x))
27}
28
29pub fn atan<T: RealNumber, const D: usize>(y_over_x: &TVec<T, D>) -> TVec<T, D> {
31 y_over_x.map(|e| e.atan())
32}
33
34pub fn atanh<T: RealNumber, const D: usize>(x: &TVec<T, D>) -> TVec<T, D> {
36 x.map(|e| e.atanh())
37}
38
39pub fn cos<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
41 angle.map(|e| e.cos())
42}
43
44pub fn cosh<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
46 angle.map(|e| e.cosh())
47}
48
49pub fn degrees<T: RealNumber, const D: usize>(radians: &TVec<T, D>) -> TVec<T, D> {
51 radians.map(|e| e * na::convert(180.0) / T::pi())
52}
53
54pub fn radians<T: RealNumber, const D: usize>(degrees: &TVec<T, D>) -> TVec<T, D> {
56 degrees.map(|e| e * T::pi() / na::convert(180.0))
57}
58
59pub fn sin<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
61 angle.map(|e| e.sin())
62}
63
64pub fn sinh<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
66 angle.map(|e| e.sinh())
67}
68
69pub fn tan<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
71 angle.map(|e| e.tan())
72}
73
74pub fn tanh<T: RealNumber, const D: usize>(angle: &TVec<T, D>) -> TVec<T, D> {
76 angle.map(|e| e.tanh())
77}