Expand description
fugit
provides a comprehensive library of Duration
and Instant
for the handling of
time in embedded systems. The library is specifically designed to maximize const-ification
which allows for most comparisons and changes of time-base to be made at compile time, rather
than run time.
The library is aimed at ease-of-use and performance first.
use fugit::{Duration, ExtU32};
// Efficient short-hands (`.millis()`, ...)
let d = Duration::<u32, 1, 1_000>::from_ticks(111);
let sum1 = d + 300.millis();
// ^^^ Compile time move of base, only a sum is needed and no change of base
// -----------------------
// Best effort for fixed types
fn bar(d1: Duration<u32, 1, 1_000>, d2: Duration<u32, 1, 1_000_000>) {
let sum = d1 + d2.convert();
// ^^^^^^^ Run time move of base, will use a `mul` and `div` instruction (Cortex-M3+) to
// perform the move of base.
// The `.convert()` explicitly signals the move of base.
let ops = d1 > d2;
// ^^^^^^^ Run time comparison of different base, will use 2 `mul` instructions
// (Cortex-M3+) to perform the comparison.
}
fn baz(d1: Duration<u64, 1, 1_000>, d2: Duration<u64, 1, 1_000_000>) {
let sum = d1 + d2.convert();
// ^^^^^^^ Run time move of base, will use a `mul` insruction and `div`
// soft-impl (Cortex-M3+) to perform the move of base.
// The `.convert()` explicitly signals the move of base.
let ops = d1 > d2;
// ^^^^^^^ Run time comparison of different base, will use 4 `mul` instructions
// (Cortex-M3+) to perform the comparison.
}
Structs§
- Duration
- Represents a duration of time.
- Instant
- Represents an instant in time.
- Rate
- Represents a frequency.
Traits§
- ExtU32
- Extension trait for simple short-hands for u32 Durations
- ExtU64
- Extension trait for simple short-hands for u64 Durations
- ExtU32
Ceil - Extension trait for simple short-hands for u32 Durations (ceil rounded)
- ExtU64
Ceil - Extension trait for simple short-hands for u64 Durations (ceil rounded)
- Rate
ExtU32 - Extension trait for simple short-hands for u32 Rate
- Rate
ExtU64 - Extension trait for simple short-hands for u64 Rate
Type Aliases§
- Hertz
- Alias for hertz rate
- Hertz
U32 - Alias for hertz rate (
u32
backing storage) - Hertz
U64 - Alias for hertz rate (
u64
backing storage) - Hours
Duration - Alias for hours duration
- Hours
Duration U32 - Alias for hours duration (
u32
backing storage) - Hours
Duration U64 - Alias for hours duration (
u64
backing storage) - Kilohertz
- Alias for kilohertz rate
- Kilohertz
U32 - Alias for kilohertz rate (
u32
backing storage) - Kilohertz
U64 - Alias for kilohertz rate (
u64
backing storage) - Megahertz
- Alias for megahertz rate
- Megahertz
U32 - Alias for megahertz rate (
u32
backing storage) - Megahertz
U64 - Alias for megahertz rate (
u64
backing storage) - Micros
Duration - Alias for microsecond duration
- Micros
Duration U32 - Alias for microsecond duration (
u32
backing storage) - Micros
Duration U64 - Alias for microsecond duration (
u64
backing storage) - Millis
Duration - Alias for millisecond duration
- Millis
Duration U32 - Alias for millisecond duration (
u32
backing storage) - Millis
Duration U64 - Alias for millisecond duration (
u64
backing storage) - Minutes
Duration - Alias for minutes duration
- Minutes
Duration U32 - Alias for minutes duration (
u32
backing storage) - Minutes
Duration U64 - Alias for minutes duration (
u64
backing storage) - Nanos
Duration - Alias for nanosecond duration
- Nanos
Duration U32 - Alias for nanosecond duration (
u32
backing storage) - Nanos
Duration U64 - Alias for nanosecond duration (
u64
backing storage) - Secs
Duration - Alias for second duration
- Secs
Duration U32 - Alias for second duration (
u32
backing storage) - Secs
Duration U64 - Alias for second duration (
u64
backing storage) - Timer
Duration - Alias for durations that come from timers with a specific frequency
- Timer
Duration U32 - Alias for durations that come from timers with a specific frequency (
u32
backing storage) - Timer
Duration U64 - Alias for durations that come from timers with a specific frequency (
u64
backing storage) - Timer
Instant - Alias for instants that come from timers with a specific frequency
- Timer
Instant U32 - Alias for instants that come from timers with a specific frequency (
u32
backing storage) - Timer
Instant U64 - Alias for instants that come from timers with a specific frequency (
u64
backing storage) - Timer
Rate - Alias for rate that come from timers with a specific frequency
- Timer
Rate U32 - Alias for rate that come from timers with a specific frequency (
u32
backing storage) - Timer
Rate U64 - Alias for rate that come from timers with a specific frequency (
u64
backing storage)