1 unstable release

0.0.1 Aug 9, 2020

#163 in #function

Custom license

7KB
109 lines

rjwindow

Super simple data structure. A window. Put data into it, if it reaches the max capacity, the oldest items are removed. Blam.

Example

use rjwindow::Window;

let my_data = vec![1, 2, 3, 4, 5];

let mut window = Window::<usize>::new(5);

window.stack(1);
window.stack(2);
window.extend(my_data);

assert_eq!(window.len(), 5);

Use cases?

In a project of mine I use an MCP3008 analog to digital coverter chip to read capacitive soil moisture sensors. I read them every 3 seconds. However, they are sensitive and a single drop of water can cause them to go from a reading of 20 to 900 instantly (in the range of 0 - 1024). So to solve this, I stack the readings onto a window and look at the average of the window! For example:

// example not intended to be rust accurate

let history = Window::new(100);

loop {

  for _ in 0..5 {
    history.stack(read_sensor());
    thread::sleep(Duration::from_millis(10));
  }

  let avg = average(history.peek(10));

  thread::sleep(Duration::from_secs(3));
}

Now what I have is the average of the sensors over a specific period of time. Each time the sensor is read (except for the first time) the readings that are averaged are [0-5 ... 3 seconds later ... 0-5] and each value is spaced out by 10 milliseconds. This helps is stablizing the sensors in case little electron fairies produce a weird value from a bad moisture fairy.

But, feel free to use the data structure however you want! Good luck!!

No runtime deps