solana/sdk/src/timing.rs

65 lines
1.9 KiB
Rust
Raw Normal View History

2018-06-06 16:36:54 -07:00
//! The `timing` module provides std::time utility functions.
use std::time::{Duration, SystemTime, UNIX_EPOCH};
pub fn duration_as_ns(d: &Duration) -> u64 {
d.as_secs() * 1_000_000_000 + u64::from(d.subsec_nanos())
}
2018-06-22 10:44:31 -07:00
pub fn duration_as_us(d: &Duration) -> u64 {
2018-07-11 13:40:46 -07:00
(d.as_secs() * 1000 * 1000) + (u64::from(d.subsec_nanos()) / 1_000)
2018-06-22 10:44:31 -07:00
}
pub fn duration_as_ms(d: &Duration) -> u64 {
2018-07-11 13:40:46 -07:00
(d.as_secs() * 1000) + (u64::from(d.subsec_nanos()) / 1_000_000)
}
pub fn duration_as_s(d: &Duration) -> f32 {
2018-07-11 13:40:46 -07:00
d.as_secs() as f32 + (d.subsec_nanos() as f32 / 1_000_000_000.0)
}
pub fn timestamp() -> u64 {
2018-05-11 11:38:52 -07:00
let now = SystemTime::now()
.duration_since(UNIX_EPOCH)
.expect("create timestamp in timing");
2018-07-11 13:40:46 -07:00
duration_as_ms(&now)
}
pub const SECONDS_PER_YEAR: f64 = (365.242_199 * 24.0 * 60.0 * 60.0);
/// from years to slots
pub fn years_as_slots(years: f64, tick_duration: &Duration, ticks_per_slot: u64) -> f64 {
// slots is years * slots/year
years *
// slots/year is seconds/year ...
SECONDS_PER_YEAR
// * (ns/s)/(ns/tick) / ticks/slot = 1/s/1/tick = ticks/s
*(1_000_000_000.0 / duration_as_ns(tick_duration) as f64)
// / ticks/slot
/ ticks_per_slot as f64
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_years_as_slots() {
let tick_duration = Duration::from_millis(1000 / 160);
// interestingly large numbers with 160 ticks/second
assert_eq!(years_as_slots(0.0, &tick_duration, 4) as u64, 0);
assert_eq!(
years_as_slots(1.0 / 12f64, &tick_duration, 4) as u64,
109_572_659
);
assert_eq!(years_as_slots(1.0, &tick_duration, 4) as u64, 1_314_871_916);
let tick_duration = Duration::from_millis(1000);
// one second in years with one tick per second + one tick per slot
assert_eq!(
years_as_slots(1.0 / SECONDS_PER_YEAR, &tick_duration, 1),
1.0
);
}
}