ironcalc_base 0.7.1

Open source spreadsheet engine
Documentation
#![allow(clippy::unwrap_used)]

use crate::test::util::new_empty_model;

#[test]
fn test_fn_poisson_dist_smoke() {
    let mut model = new_empty_model();

    // λ = 2, x = 3
    // P(X = 3)  ≈ 0.180447045
    // P(X <= 3) ≈ 0.857123461
    model._set("A1", "=POISSON.DIST(3, 2, FALSE)");
    model._set("A2", "=POISSON.DIST(3, 2, TRUE)");

    // Wrong arg count
    model._set("A3", "=POISSON.DIST(3, 2)");
    model._set("A4", "=POISSON.DIST(3, 2, TRUE, FALSE)");

    // Domain errors
    model._set("A5", "=POISSON.DIST(-1, 2, TRUE)"); // x < 0
    model._set("A6", "=POISSON.DIST(3, -2, TRUE)"); // mean < 0

    // λ = 0 special cases
    model._set("A7", "=POISSON.DIST(0, 0, FALSE)"); // 1
    model._set("A8", "=POISSON.DIST(1, 0, FALSE)"); // 0
    model._set("A9", "=POISSON.DIST(5, 0, TRUE)"); // 1

    model.evaluate();

    assert_eq!(model._get_text("A1"), *"0.180447044");
    assert_eq!(model._get_text("A2"), *"0.85712346");

    assert_eq!(model._get_text("A3"), *"#ERROR!");
    assert_eq!(model._get_text("A4"), *"#ERROR!");
    assert_eq!(model._get_text("A5"), *"#NUM!");
    assert_eq!(model._get_text("A6"), *"#NUM!");

    assert_eq!(model._get_text("A7"), *"1");
    assert_eq!(model._get_text("A8"), *"0");
    assert_eq!(model._get_text("A9"), *"1");
}