ndhistogram 0.2.1

multi-dimensional histogramming for Rust
Documentation
use std::f64::NAN;

use ndhistogram::axis::{Axis, BinInterval, VariableNoFlow};

#[test]
fn test_variablenoflow_numbins() {
    let ax = VariableNoFlow::new(vec![0.0, 1.0, 4.0, 8.0]);
    assert_eq!(ax.numbins(), 3)
}

#[test]
#[should_panic]
fn test_variablenoflow_noedges_panics() {
    VariableNoFlow::<f64>::new(vec![]);
}

#[test]
#[should_panic]
fn test_variablenoflow_oneedges_panics() {
    VariableNoFlow::new(vec![1.0]);
}

#[test]
#[should_panic]
fn test_variablenoflow_nan_edges_panics() {
    VariableNoFlow::new(vec![1.0, NAN, 2.0]);
}

#[test]
fn test_variablenoflow_low() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    assert_eq!(ax.low(), &0)
}

#[test]
fn test_variablenoflow_high() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    assert_eq!(ax.high(), &8)
}

#[test]
fn test_variablenoflow_get_index() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    let actual: Vec<_> = (-1..10).map(|coord| ax.index(&coord)).flatten().collect();
    let expected = vec![0, 1, 1, 1, 2, 2, 2, 2];
    assert_eq!(actual, expected);
}

#[test]
fn test_variablenoflow_get_bin() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    let actual: Vec<_> = (0..4).map(|index| ax.bin(index)).collect();
    let expected = vec![
        Some(BinInterval::new(0, 1)),
        Some(BinInterval::new(1, 4)),
        Some(BinInterval::new(4, 8)),
        None,
    ];
    assert_eq!(actual, expected);
}

#[test]
fn test_variablenoflow_clone() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    assert_eq!(ax.clone(), ax)
}

#[test]
fn test_variablenoflow_debug_display() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    println!("{:?}", ax);
}

#[test]
fn test_variablenoflow_display() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    println!("{}", ax);
}

#[test]
fn test_variablenoflow_iterate_indices() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    let actual: Vec<_> = ax.indices().collect();
    let expected = vec![0, 1, 2];
    assert_eq!(actual, expected)
}

#[test]
fn test_variablenoflow_iterate_bins() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    let actual: Vec<_> = ax.bins().collect();
    let expected = vec![
        BinInterval::new(0, 1),
        BinInterval::new(1, 4),
        BinInterval::new(4, 8),
    ];
    assert_eq!(actual, expected)
}

#[test]
fn test_variablenoflow_iterate_items() {
    let ax = VariableNoFlow::new(vec![0, 1, 4, 8]);
    let actual: Vec<_> = ax.into_iter().collect();
    let expected: Vec<_> = ax.indices().zip(ax.bins()).collect();
    assert_eq!(actual, expected)
}

#[test]
fn test_negative_axis_index() {
    let axis = VariableNoFlow::new(vec![-3, -1, 0, 1]);
    let actual: Vec<_> = (-4..3).map(|loc| axis.index(&loc)).flatten().collect();
    let expected = vec![0, 0, 1, 2];
    assert_eq!(actual, expected)
}

#[test]
fn test_negative_axis_bin() {
    let axis = VariableNoFlow::new(vec![-3, -1, 0, 1]);
    let actual: Vec<_> = (0..4).map(|index| axis.bin(index)).collect();
    let expected = vec![
        Some(BinInterval::new(-3, -1)),
        Some(BinInterval::new(-1, 0)),
        Some(BinInterval::new(0, 1)),
        None,
    ];
    assert_eq!(actual, expected)
}