File: Stats.swift

package info (click to toggle)
swiftlang 6.1.3-4
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 2,791,644 kB
  • sloc: cpp: 9,901,738; ansic: 2,201,433; asm: 1,091,827; python: 308,252; objc: 82,166; f90: 80,126; lisp: 38,358; pascal: 25,559; sh: 20,429; ml: 5,058; perl: 4,745; makefile: 4,484; awk: 3,535; javascript: 3,018; xml: 918; fortran: 664; cs: 573; ruby: 396
file content (26 lines) | stat: -rw-r--r-- 818 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import Foundation

enum Stats {}

extension Stats {
  // Maximum allowed standard deviation is 7.5% of the median runtime
  static let maxAllowedStdev = 0.075

  static func tTest(_ a: Measurement, _ b: Measurement) -> Bool {
    // Student's t-test
    // Since we should generally have similar variances across runs
    let n1 = Double(a.samples)
    let n2 = Double(b.samples)
    let sPNumerator = (n1 - 1) * pow(a.stdev, 2) + (n2 - 1) * pow(b.stdev, 2)
    let sPDenominator = n1 + n2 - 2
    let sP = (sPNumerator/sPDenominator).squareRoot()
    let tVal = (a.median.seconds - b.median.seconds) / (sP * (pow(n1, -1) + pow(n2, -1)).squareRoot())
    return abs(tVal) > 2
  }
}

extension BenchmarkResult {
  var runtimeIsTooVariant: Bool {
    runtime.stdev > Stats.maxAllowedStdev * runtime.median.seconds
  }
}