#counter #invocation #data-structures

invocation-counter

Datastructure to answer to: how many times a function has been called in the last X minutes?

1 unstable release

0.1.0 Dec 6, 2024

#207 in Concurrency

Download history 105/week @ 2024-12-02 33/week @ 2024-12-09

138 downloads per month

Apache-2.0

24KB
335 lines

Invocation counter

Rust

This data structure responses the following question: how many times a function has been called in the last X minutes?

Installation

cargo add invocation-counter

Example

use invocation_counter::Counter;

fn main() {
    // 4 is the group_shift_factor
    // 16 is the number of buckets
    let counter = Counter::<16, 4>::new(4);

    let mut now = 0; // Instant::now().elapsed().as_secs();
    counter.increment_by_one(now);

    now += 1; // Simulate a second passing
    counter.increment_by_one(now);

    assert_eq!(counter.get_count_till(now), 2);

    now += 2_u64.pow(4); // Simulate 16 seconds passing
    counter.increment_by_one(now);

    now += 1; // Simulate a second passing
    counter.increment_by_one(now);

    assert_eq!(counter.get_count_till(now), 4);

    now += 2_u64.pow(4) * 16; // Move foward for a while...
    counter.increment_by_one(now);
    assert_eq!(counter.get_count_till(now), 1); // The counter should have reset
}

No runtime deps