use crate::logging::types::ErrorReductionSummary;

pub fn compute_error_reduction_summary(
    iter_no: usize,
    col: usize,
    error_reductions: &[f64],
) -> ErrorReductionSummary {
    let mut min = f64::INFINITY;
    let mut max = f64::NEG_INFINITY;
    let mut sum = 0.0;
    let mut nan_count = 0;
    let mut valid_count = 0;

    for &val in error_reductions {
        if val.is_nan() {
            nan_count += 1;
        } else {
            min = min.min(val);
            max = max.max(val);
            sum += val;
            valid_count += 1;
        }
    }

    let mean = if valid_count > 0 {
        sum / valid_count as f64
    } else {
        f64::NAN
    };

    if valid_count == 0 {
        min = f64::NAN;
        max = f64::NAN;
    }

    ErrorReductionSummary {
        epoch: None,
        tree_id: None,
        iter_no,
        col,
        min,
        max,
        mean,
        nan_count,
        total_count: error_reductions.len(),
    }
}
