#stream-processing #stream #aggregation #no-std

no-std indicator

流聚合的抽象,我们称之为 Indicator

41 个版本

0.4.4 2023年11月29日
0.4.2 2023年10月30日
0.4.0 2023年6月5日
0.4.0-rc.1 2022年11月23日
0.1.2 2021年11月18日

#325 in Rust 模式

44 每月下载量
用于 6 个包 (2 直接)

MIT 许可证

180KB
5K SLoC

Indicator

流聚合的抽象,我们称之为 Indicator

Crates.io MIT licensed Build Status

API 文档

示例

indicator 添加为项目的依赖项。

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

然后,您可以尝试以下代码。

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)
}

依赖项

~0.7–2.2MB
~40K SLoC