eazy_data/easing/polynomial/
quintic.rs

1//! # The Quintic Curve.
2//!
3//! An algebric curve of degree five.
4//!
5//! #### formula.
6//!
7//! `p^5`
8
9use crate::easing::Curve;
10
11/// ### The [`InQuintic`] Easing Function.
12///
13/// #### examples.
14///
15/// ```
16/// use eazy::Curve;
17/// use eazy::polynomial::quintic::InQuintic;
18///
19/// let p = InQuintic.y(1.0);
20/// ```
21#[derive(Debug)]
22pub struct InQuintic;
23
24impl Curve for InQuintic {
25  #[inline(always)]
26  fn y(&self, p: f32) -> f32 {
27    p * p * p * p * p
28  }
29}
30
31#[test]
32fn test_in_quintic() {
33  let p = InQuintic.y(1.0);
34
35  assert_eq!(p, 1.0);
36}
37
38/// ### The [`OutQuintic`] Easing Function.
39///
40/// #### examples.
41///
42/// ```
43/// use eazy::Curve;
44/// use eazy::polynomial::quintic::OutQuintic;
45///
46/// let p = OutQuintic.y(1.0);
47/// ```
48#[derive(Debug)]
49pub struct OutQuintic;
50
51impl Curve for OutQuintic {
52  #[inline(always)]
53  fn y(&self, p: f32) -> f32 {
54    let m = p - 1.0;
55
56    1.0 + m * m * m * m * m
57  }
58}
59
60#[test]
61fn test_out_quintic() {
62  let p = OutQuintic.y(1.0);
63
64  assert_eq!(p, 1.0);
65}
66
67/// ### The [`InOutQuintic`] Easing Function.
68///
69/// #### examples.
70///
71/// ```
72/// use eazy::Curve;
73/// use eazy::polynomial::quintic::InOutQuintic;
74///
75/// let p = InOutQuintic.y(1.0);
76/// ```   
77#[derive(Debug)]
78pub struct InOutQuintic;
79
80impl Curve for InOutQuintic {
81  #[inline(always)]
82  fn y(&self, p: f32) -> f32 {
83    let m = p - 1.0;
84    let t = p * 2.0;
85
86    if t < 1.0 {
87      return p * t * t * t * t;
88    }
89
90    1.0 + m * m * m * m * m * 16.0
91  }
92}
93
94#[test]
95fn test_in_out_quintic() {
96  let p = InOutQuintic.y(1.0);
97
98  assert_eq!(p, 1.0);
99}