lotus_script/math.rs
1use crate::time::{delta, delta_f64};
2
3pub use lotus_shared::math::*;
4
5pub fn exponential_approach(old_value: f32, exponent: f32, target: f32) -> f32 {
6 let factor = 1.0 - (-delta() * exponent).exp();
7 old_value + factor * (target - old_value)
8}
9
10pub fn exponential_approach_64(old_value: f64, exponent: f64, target: f64) -> f64 {
11 let factor = 1.0 - (-delta_f64() * exponent).exp();
12 old_value + factor * (target - old_value)
13}