Zusammenfassende Statistiken, Lagemaße, Streuungsmaße, Quantile, Formkennzahlen, Häufigkeitsanalyse und Streaming-Berechnungen in kstats-core.
kstats-core stellt deskriptive Statistiken als Erweiterungsfunktionen auf DoubleArray und Iterable<Double> bereit. Zusätzlich sind Int- und Long-Überladungen für die gängigsten Operationen verfügbar.
describe() ist der schnellste Weg, ein vollständiges Bild einer Stichprobe zu erhalten. Die Methode gibt ein DescriptiveStatistics-Objekt zurück, das Anzahl, Lagemaße, Streuung, Quartile, Formkennzahlen und Standardfehler kombiniert.
variance() und standardDeviation() verwenden standardmäßig die Stichprobenformel (Division durch n−1). Übergeben Sie PopulationKind.POPULATION, um die Populationsformel (Division durch n) zu verwenden.
Verschiedene Begriffe von „Mitte” passen zu verschiedenen Datenformen. mean() ist das arithmetische Mittel, median() ist der Positionsmittelwert, mode() gibt die häufigsten Werte zurück, und die getrimmten sowie gewichteten Varianten behandeln Ausreißer und Gewichtungen.
Geometrisches Mittel — geeignet für Wachstumsraten und Verhältnisse. Erfordert ausschließlich positive Werte.
Harmonisches Mittel — geeignet für Raten und Geschwindigkeitsdurchschnitte. Erfordert ausschließlich positive Werte.
Getrimmtes Mittel — entfernt einen Anteil von jedem Ende, bevor der Durchschnitt berechnet wird. Robust gegenüber Ausreißern.
Gewichtetes Mittel — jede Beobachtung trägt proportional zu ihrem Gewicht bei.
Mathematische Details
xˉ=n1i=1∑nxixˉgeo=(i=1∏nxi)1/nxˉharm=∑i=1nxi1nxˉw=∑i=1nwi∑i=1nwixiDas getrimmte Mittel entfernt ⌊p⋅n⌋ Beobachtungen von jedem Ende der sortierten Stichprobe und berechnet anschließend das arithmetische Mittel der verbleibenden Werte.
semiVariance misst die Variabilität auf einer Seite eines Schwellenwerts. DOWNSIDE erfasst das Risiko unterhalb des Schwellenwerts; UPSIDE erfasst die Variabilität oberhalb davon.
Quantile teilen die Daten an bestimmten Wahrscheinlichkeitsschwellen. percentile() erwartet einen Wert auf der Skala 0–100; quantile() erwartet einen Wert auf der Skala 0–1.
quantile() unterstützt einen QuantileInterpolation-Parameter mit den Optionen: LINEAR (Standard), LOWER, HIGHER, NEAREST und MIDPOINT. Diese steuern, wie der Wert interpoliert wird, wenn das Quantil zwischen zwei Datenpunkten liegt.
Mathematische Details
Bei linearer Interpolation (Standardverfahren) wird das Quantil an der Wahrscheinlichkeit p für sortierte Daten x(1),…,x(n) wie folgt berechnet:Q(p)=x(⌊h⌋)+(h−⌊h⌋)(x(⌈h⌉)−x(⌊h⌋))wobei h=p(n−1)+1.
Formkennzahlen beschreiben Asymmetrie und Randschwere über Mittelwert und Varianz hinaus.
Kopieren
val data = doubleArrayOf(2.0, 4.0, 4.0, 4.0, 5.0, 5.0, 7.0, 9.0)data.skewness() // 0.6563 — positive: right tail is longerdata.kurtosis() // -0.1640 — negative excess: lighter tails than normaldata.kurtosis(excess = false) // raw kurtosis (not centered at 0)data.centralMoment(2) // 4.0 (equals population variance)data.centralMoment(3) // 5.25data.centralMoment(4) // 44.5data.kStatistic(1) // 5.0 (equals mean)data.kStatistic(2) // 4.5714 (equals sample variance)
Eine Schiefe nahe null deutet auf Symmetrie hin. Positive Schiefe weist auf einen längeren rechten Rand hin; negative auf einen längeren linken Rand. Exzess-Kurtosis nahe null ähnelt einer Normalverteilung; positive Werte deuten auf schwerere Ränder hin.
kurtosis() gibt standardmäßig die Exzess-Kurtosis zurück (excess = true), d.h. der Wert ist so verschoben, dass eine Normalverteilung eine Exzess-Kurtosis von 0 hat. Übergeben Sie excess = false für das rohe vierte standardisierte Moment.
Mathematische Details
g1=(n−1)(n−2)ni=1∑n(sxi−xˉ)3g2=(n−1)(n−2)(n−3)n(n+1)i=1∑n(sxi−xˉ)4−(n−2)(n−3)3(n−1)2Das r-te zentrale Moment ist μr=n1∑i=1n(xi−xˉ)r. K-Statistiken (kr) sind erwartungstreue Schätzer der entsprechenden Kumulanten.
Die Klasse Frequency zählt Vorkommen, Anteile und kumulative Häufigkeiten für beliebige Comparable-Typen. frequencyTable() gruppiert numerische Daten in gleich breite Klassen.
val data = doubleArrayOf(1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0)val bins = data.asIterable().frequencyTable(3)// Each FrequencyBin has: range, count, relativeFrequency, cumulativeFrequencybins[0].count // number of values in the first binbins[0].relativeFrequency // proportion of total
Frequency funktioniert mit jedem Comparable-Typ — Strings, Enums, Ganzzahlen oder eigene Klassen. Für numerische Klasseneinteilung verwenden Sie frequencyTable() mit einer Klassenanzahl oder einer Klassenbreite.
OnlineStatistics berechnet Mittelwert, Varianz, Schiefe und Kurtosis inkrementell, ohne die gesamte Stichprobe zu speichern. Werte können einzeln oder als Stapel hinzugefügt werden.
Verwenden Sie OnlineStatistics, wenn Daten inkrementell eintreffen (Streaming, ereignisgesteuerte Systeme) oder wenn das Speichern der gesamten Stichprobe im Arbeitsspeicher nicht praktikabel ist.
Mathematische Details
OnlineStatistics verwendet Welfords Algorithmus mit der Terriberry-Erweiterung für numerisch stabile Einpass-Berechnung höherer Momente. Der Algorithmus aktualisiert laufende Summen von Potenzen der Abweichungen vom aktuellen Mittelwert und vermeidet so die katastrophale Auslöschung, die naive Zweipass-Formeln bei großen Datensätzen betrifft.
Leere Arrays lösen eine InsufficientDataException aus. Funktionen, die mindestens zwei Beobachtungen erfordern (Varianz, Standardabweichung, Schiefe), lösen bei Eingaben mit nur einem Element eine InsufficientDataException aus. Funktionen, die positive Daten erfordern (geometricMean, harmonicMean), lösen bei nicht-positiven Werten eine InvalidParameterException aus.