#stream-processing #stream #aggregation

no-std indicator

Abstractions for stream aggregation, we call them Indicator s

41 releases

0.4.4 Nov 29, 2023
0.4.2 Oct 30, 2023
0.4.0 Jun 5, 2023
0.4.0-rc.1 Nov 23, 2022
0.1.2 Nov 18, 2021

#6 in #aggregation

Download history 22/week @ 2024-06-10 20/week @ 2024-06-17 14/week @ 2024-06-24 5/week @ 2024-07-01 2/week @ 2024-07-08 26/week @ 2024-07-15 8/week @ 2024-07-22 80/week @ 2024-07-29 20/week @ 2024-08-05 13/week @ 2024-08-12 8/week @ 2024-08-19 36/week @ 2024-08-26 5/week @ 2024-09-02 8/week @ 2024-09-09 4/week @ 2024-09-16 28/week @ 2024-09-23

54 downloads per month
Used in 6 crates (2 directly)

MIT license

180KB
5K SLoC

Indicator

Abstractions for stream aggregation, we call them Indicator s.

Crates.io MIT licensed Build Status

API Docs

Example

Add indicator as a dependency of your project.

[dependencies]
indicator = "0.4"
rust_decimal = "1.17.0"
rust_decimal_macros = "1.17.0"
time = { version = "0.3", default-features = false, features = ["macros"] }

And then, you can try these codes.

use arrayvec::ArrayVec;
use indicator::*;
use rust_decimal::Decimal;
use rust_decimal_macros::dec;
use time::macros::{datetime, offset};

/// Return an indicator that calculate `hl2` and `ohlc4` simultaneously.
fn hl2_ohlc4(period: Period) -> impl Operator<TickValue<Decimal>, Output = (Decimal, Decimal)> {
    tumbling(
        period,
        |_w: &ArrayVec<[Decimal; 4], 0>, y: &mut Option<[Decimal; 4]>, x| match y {
            Some(ohlc) => {
                ohlc[1] = ohlc[1].max(x);
                ohlc[2] = ohlc[2].min(x);
                ohlc[3] = x;
                *ohlc
            }
            None => {
                let ohlc = [x; 4];
                *y = Some(ohlc);
                ohlc
            }
        },
    )
    .then(facet_t(
        map_t(|ohlc: [Decimal; 4]| (ohlc[1] + ohlc[2]) / dec!(2)),
        map_t(|ohlc: [Decimal; 4]| (ohlc[0] + ohlc[1] + ohlc[2] + ohlc[3]) / dec!(4)),
    ))
    .map(|v| v.value)
}

Dependencies

~0.7–2.1MB
~39K SLoC