From acf12ca1b2ea3eba0c4f183408fb063ce5c397af Mon Sep 17 00:00:00 2001 From: Jonah <47046556+jwbonner@users.noreply.github.com> Date: Sun, 20 Oct 2024 18:43:07 -0400 Subject: [PATCH] Fix statistics calculation edge cases (#238) --- src/hub/controllers/StatisticsController.ts | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/hub/controllers/StatisticsController.ts b/src/hub/controllers/StatisticsController.ts index 41134ca6..c4c5d048 100644 --- a/src/hub/controllers/StatisticsController.ts +++ b/src/hub/controllers/StatisticsController.ts @@ -266,6 +266,8 @@ export default class StatisticsController implements TabController { }); // Get statistics + let samplesNonNegative = samples.filter((x) => x >= 0); + let samplesPositive = samples.filter((x) => x > 0); let statistics: StatisticsRendererCommand_Stats = { count: samples.length, min: samples.length === 0 ? NaN : stats.minSorted(samples), @@ -273,13 +275,13 @@ export default class StatisticsController implements TabController { mean: samples.length === 0 ? NaN : stats.mean(samples), median: samples.length === 0 ? NaN : stats.medianSorted(samples), mode: samples.length === 0 ? NaN : stats.modeSorted(samples), - geometricMean: samples.length === 0 ? NaN : logAverage(samples.filter((x) => x >= 0)), - harmonicMean: samples.length === 0 ? NaN : stats.harmonicMean(samples.filter((x) => x > 0)), + geometricMean: samplesNonNegative.length === 0 ? NaN : logAverage(samplesNonNegative), + harmonicMean: samplesPositive.length === 0 ? NaN : stats.harmonicMean(samplesPositive), quadraticMean: samples.length === 0 ? NaN : stats.rootMeanSquare(samples), - standardDeviation: samples.length === 0 ? NaN : stats.sampleStandardDeviation(samples), + standardDeviation: samples.length < 2 ? NaN : stats.sampleStandardDeviation(samples), medianAbsoluteDeviation: samples.length === 0 ? NaN : stats.medianAbsoluteDeviation(samples), interquartileRange: samples.length === 0 ? NaN : stats.interquartileRange(samples), - skewness: samples.length === 0 ? NaN : stats.sampleSkewness(samples), + skewness: samples.length < 3 ? NaN : stats.sampleSkewness(samples), percentile01: samples.length === 0 ? NaN : stats.quantileSorted(samples, 0.01), percentile05: samples.length === 0 ? NaN : stats.quantileSorted(samples, 0.05), percentile10: samples.length === 0 ? NaN : stats.quantileSorted(samples, 0.1),