Use this file to discover all available pages before exploring further.
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.
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.
Prozessfähigkeitsindizes quantifizieren, wie gut ein Prozess innerhalb seiner liegt. processCapability(lsl, usl) liefert vier SPC-Indizes in einem Aufruf:
Cp, Cpk — potentielle und tatsächliche Fähigkeit mit der Stichproben-Standardabweichung (kurzfristige, innerhalb von Untergruppen auftretende Streuung).
Pp, Ppk — dieselben Formeln mit der Populations-Standardabweichung (langfristige Gesamtstreuung).
Die -k-Varianten bestrafen einen Prozess, der relativ zur Spezifikationsmitte dezentriert ist, sodass Cpk nie größer als Cp ist.
// Ten parts measured against a spec window of [48, 52]val measurements = doubleArrayOf( 50.0, 50.5, 49.5, 50.2, 49.8, 50.1, 49.9, 50.3, 49.7, 50.0)val capability = measurements.processCapability(lsl = 48.0, usl = 52.0)capability.cp // 2.2646 — potential capability (spread vs tolerance)capability.cpk // 2.2646 — actual capability (penalizes off-centering)capability.pp // 2.3870 — overall (population σ) counterpart of Cpcapability.ppk // 2.3870 — overall counterpart of Cpk
Verwenden Sie diese Indizes nur für einen bereits statistisch beherrschten Prozess (stabil über die Zeit — siehe Shewhart-Kontrollkarten unten). Für einen instabilen Prozess ist die gemessene Streuung keine feste Prozesseigenschaft.
Werte ≥ 1.33 gelten üblicherweise als fähig, ≥ 1.67 als hochgradig fähig. Wenn Cpk ≪ Cp, sollten Sie den Prozess zuerst neu zentrieren, bevor Sie versuchen, die Varianz zu reduzieren.
Mathematische Details
Cp=6σsUSL−LSL,Cpk=min(3σsUSL−xˉ,3σsxˉ−LSL)Pp und Ppk verwenden die Populations-Standardabweichung σp (Divisor n) anstelle der Stichproben-Standardabweichung σs (Divisor n−1). processCapability berechnet beide in einem einzigen numerisch stabilen Welford-Durchlauf.
Shewhart- zeichnen Untergruppenstatistiken über die Zeit mit Drei-Sigma-Grenzen auf. xBarRChart() überwacht den Prozessmittelwert zusammen mit der Spannweite innerhalb jeder Untergruppe; xBarSChart() nutzt stattdessen die Stichproben-Standardabweichung — effizienter für Untergruppengrößen über 10. Beide benötigen gleich große Untergruppen mit 2–25 Beobachtungen.
// Five subgroups of four parts; bracket width monitored per batchval subgroups = listOf( doubleArrayOf(72.0, 84.0, 79.0, 49.0), doubleArrayOf(56.0, 87.0, 33.0, 42.0), doubleArrayOf(55.0, 73.0, 22.0, 60.0), doubleArrayOf(44.0, 80.0, 54.0, 74.0), doubleArrayOf(97.0, 26.0, 48.0, 58.0),)val chart = xBarRChart(subgroups)chart.centerLine // 59.65 — grand mean (x-double-bar)chart.ucl // 95.6626 — upper control limit for the meanchart.lcl // 23.6374 — lower control limit for the meanchart.rChart.centerLine // 49.4 — average range (R-bar)chart.rChart.ucl // 112.7308 — upper limit for within-subgroup rangechart.rChart.lcl // 0.0 — lower limit (D₃ = 0 for n ≤ 6)
Die Kontrollgrenzen basieren auf den Standard-SPC-Konstanten A2,A3,D3,D4,B3,B4,c4 (Montgomery, Introduction to Statistical Quality Control, Anhang VI), tabelliert für Untergruppengrößen 2–25 und direkt über spcConstants(n) verfügbar.
Mathematische Details
Für k Untergruppen der Größe n mit Untergruppenmittelwerten xˉi, Spannweiten Ri und Standardabweichungen si:xˉ-R:UCL/LCL=xˉˉ±A2Rˉ,R-Karte: [D3Rˉ,D4Rˉ]xˉ-S:UCL/LCL=xˉˉ±A3sˉ,S-Karte: [B3sˉ,B4sˉ]
Eine Shewhart-Karte reagiert langsam auf Drifts unter 2σ, weil jeder Punkt isoliert bewertet wird. cusum() akkumuliert Abweichungen vom Zielwert über die Zeit, sodass eine Drift von 0.5σ–1σ innerhalb weniger Beobachtungen erkannt wird. Die zweiseitige tabellarische Form verfolgt eine obere Summe C+ für Aufwärtsverschiebungen und eine untere Summe C− für Abwärtsverschiebungen. Ein Alarm wird beim ersten Index ausgelöst, an dem eine der Summen das Entscheidungsintervall H überschreitet.
// Individual measurements from a process with target 10, drifting upwardval observations = doubleArrayOf(10.2, 10.4, 10.6, 10.9, 11.2, 11.5, 11.8, 12.0)val result = cusum(observations, target = 10.0, k = 0.5, h = 3.0)result.sPlus // [0.0, 0.0, 0.1, 0.5, 1.2, 2.2, 3.5, 5.0]result.sMinus // all zero — no downward driftresult.alarmIndex // 6 — first index where C⁺ > H
Stellen Sie k auf die Hälfte der zu erkennenden Verschiebungsgröße in Einheiten von σ ein — gebräuchlicher Standard ist K≈0.5σ, was auf eine 1σ-Drift abzielt. Setzen Sie h auf 4σ–5σ, um die mittlere Lauflänge in-Kontrolle einer 3σ-Shewhart-Karte zu erreichen, bei deutlich schnellerer Reaktion auf kleine Verschiebungen.
Mathematische Details
Ci+=max(0,Ci−1++(xi−μ0−K)),Ci−=max(0,Ci−1−+(μ0−K−xi))startend mit C0±=0, Alarm beim ersten Ci+>H bzw. Ci−>H.
EWMA (Roberts, 1959) ist das zweite klassische Werkzeug zur Erkennung kleiner Verschiebungen. Statt einer unbeschränkten laufenden Summe führt ewma() einen gewichteten gleitenden Mittelwert, der aktuellen Beobachtungen mehr Gewicht gibt, aber ein Gedächtnis der Vergangenheit behält. Die Kontrollgrenzen weiten sich mit der Zeit, bis sie einen stationären Wert erreichen — die Karte ist früh am empfindlichsten, was eine anfängliche Verschiebung zuverlässig erfasst.
λ=0.2 mit L≈2.7–3.0 ist ein gebräuchlicher Standard. Kleineres λ betont das Gedächtnis und erkennt kleinere Verschiebungen; λ=1 reduziert EWMA auf eine Shewhart-Einzelwertkarte.
westernElectricRules() erweitert eine Shewhart-Karte über den einfachen ±3σ-Check hinaus mit vier Lauflängen-Heuristiken, die Trends, Cluster und anhaltende einseitige Läufe erkennen.
Regel
Muster
Erkennt
1
1 Punkt jenseits ±3σ
extreme Einzelausschläge
2
2 der letzten 3 Punkte jenseits ±2σ, gleiche Seite
starke Verschiebung
3
4 der letzten 5 Punkte jenseits ±1σ, gleiche Seite
mittlere Verschiebung
4
8 aufeinanderfolgende Punkte auf derselben Seite der Mittellinie
anhaltende Verschiebung beliebiger Größe
Das Array jeder Regel enthält die Auslöseindizes — jene Beobachtung, deren Eintreffen das betreffende Muster vervollständigt.
// Process drifting upward in the last four observationsval observations = doubleArrayOf( 0.1, 0.2, -0.3, 0.0, 1.4, 1.2, 2.4, 2.6, 3.5, 2.2)val violations = westernElectricRules(observations, center = 0.0, sigma = 1.0)violations.rule1 // indices of points beyond ±3σviolations.rule2 // indices where 2 of last 3 points are beyond ±2σ (same side)violations.rule3 // indices where 4 of last 5 points are beyond ±1σ (same side)violations.rule4 // indices where 8 consecutive points fall on the same side
Kombinieren Sie eine Shewhart-Karte (große Verschiebungen) mit CUSUM oder EWMA (kleine Verschiebungen) und den Western-Electric-Regeln (Muster) — die drei Sichtweisen zusammen decken die breiteste Palette außer-Kontrolle-Zustände ab.
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.