mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
IterateData has setup overhead of 480 μs (10%). There remained strange setup overhead after extracting the data into setUpFunction, because of of-by-one error in the main loop. It should be either: `for _ 1…10*N` or: `for _ 0..<10*N`. It’s error to use 0…m*N, because this will result in `m*N + 1` iterations that will be divided by N in the reported measurement. The extra iteration then manifests as a mysterious setup overhead!
39 lines
1.0 KiB
Swift
39 lines
1.0 KiB
Swift
//===--- IterateData.swift ------------------------------------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2017 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
|
|
import Foundation
|
|
|
|
public let IterateData = BenchmarkInfo(
|
|
name: "IterateData",
|
|
runFunction: run_IterateData,
|
|
tags: [.validation, .api, .Data],
|
|
setUpFunction: { blackHole(data) })
|
|
|
|
let data: Data = {
|
|
var data = Data(count: 16 * 1024)
|
|
let n = data.count
|
|
data.withUnsafeMutableBytes { (ptr: UnsafeMutablePointer<UInt8>) -> () in
|
|
for i in 0..<n {
|
|
ptr[i] = UInt8(i % 23)
|
|
}
|
|
}
|
|
return data
|
|
}()
|
|
|
|
@inline(never)
|
|
public func run_IterateData(_ N: Int) {
|
|
for _ in 1...10*N {
|
|
_ = data.reduce(0, &+)
|
|
}
|
|
}
|