pub mod f32 {
#[inline]
pub fn db_to_amp(db: f32) -> f32 {
if db == f32::NEG_INFINITY {
0.0
} else {
10.0f32.powf(0.05 * db)
}
}
#[inline]
pub fn amp_to_db(amp: f32) -> f32 {
if amp == 0.0 {
f32::NEG_INFINITY
} else {
20.0 * amp.log10()
}
}
#[inline]
pub fn db_to_amp_clamped(db: f32, db_epsilon: f32) -> f32 {
if db == f32::NEG_INFINITY || db <= db_epsilon {
0.0
} else {
db_to_amp(db)
}
}
#[inline]
pub fn amp_to_db_clamped(amp: f32, amp_epsilon: f32) -> f32 {
if amp <= amp_epsilon {
f32::NEG_INFINITY
} else {
amp_to_db(amp)
}
}
#[inline]
pub fn linear_volume_to_amp_clamped(linear_volume: f32, amp_epsilon: f32) -> f32 {
let v = linear_volume * linear_volume;
if v <= amp_epsilon {
0.0
} else {
v
}
}
#[inline]
pub fn amp_to_linear_volume_clamped(amp: f32, amp_epsilon: f32) -> f32 {
if amp <= amp_epsilon {
0.0
} else {
amp.sqrt()
}
}
}
pub mod f64 {
#[inline]
pub fn db_to_amp(db: f64) -> f64 {
if db == f64::NEG_INFINITY {
0.0
} else {
10.0f64.powf(0.05 * db)
}
}
#[inline]
pub fn amp_to_db(amp: f64) -> f64 {
if amp == 0.0 {
f64::NEG_INFINITY
} else {
20.0 * amp.log10()
}
}
#[inline]
pub fn db_to_amp_clamped(db: f64, db_epsilon: f64) -> f64 {
if db == f64::NEG_INFINITY || db <= db_epsilon {
0.0
} else {
db_to_amp(db)
}
}
#[inline]
pub fn amp_to_db_clamped(amp: f64, amp_epsilon: f64) -> f64 {
if amp <= amp_epsilon {
f64::NEG_INFINITY
} else {
amp_to_db(amp)
}
}
#[inline]
pub fn linear_volume_to_amp_clamped(linear_volume: f64, amp_epsilon: f64) -> f64 {
let v = linear_volume * linear_volume;
if v <= amp_epsilon {
0.0
} else {
v
}
}
#[inline]
pub fn amp_to_linear_volume_clamped(amp: f64, amp_epsilon: f64) -> f64 {
if amp <= amp_epsilon {
0.0
} else {
amp.sqrt()
}
}
}