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 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
|
//===--- BinaryFloatingPointProperties.swift ------------------------------===//
//
// This source file is part of the Swift.org open source project
//
// Copyright (c) 2014 - 2018 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
//
//===----------------------------------------------------------------------===//
import TestsUtils
public let benchmarks = [
BenchmarkInfo(
name: "BinaryFloatingPointPropertiesBinade",
runFunction: run_BinaryFloatingPointPropertiesBinade,
tags: [.validation, .algorithm]
),
BenchmarkInfo(
name: "BinaryFloatingPointPropertiesNextUp",
runFunction: run_BinaryFloatingPointPropertiesNextUp,
tags: [.validation, .algorithm]
),
BenchmarkInfo(
name: "BinaryFloatingPointPropertiesUlp",
runFunction: run_BinaryFloatingPointPropertiesUlp,
tags: [.validation, .algorithm]
)
]
@inline(never)
public func run_BinaryFloatingPointPropertiesBinade(_ n: Int) {
var xs = [Double]()
xs.reserveCapacity(n)
for _ in 1...n {
var x = 0 as Double
for i in 0..<10000 {
x += Double(getInt(i)).binade
}
xs.append(x)
}
check(xs[getInt(0)] == 37180757)
}
@inline(never)
public func run_BinaryFloatingPointPropertiesNextUp(_ n: Int) {
var xs = [Int]()
xs.reserveCapacity(n)
for _ in 1...n {
var x = 0 as Int
for i in 0..<10000 {
x += Int(Double(getInt(i)).nextUp)
}
xs.append(x)
}
check(xs[getInt(0)] == 49995000)
}
@inline(never)
public func run_BinaryFloatingPointPropertiesUlp(_ n: Int) {
var xs = [Int]()
xs.reserveCapacity(n)
for _ in 1...n {
var x = 0 as Int
for i in 0..<10000 {
x += Int(Double(getInt(i)).ulp)
}
xs.append(x)
}
check(xs[getInt(0)] == 0)
}
|