mirror of
https://github.com/apple/swift.git
synced 2025-12-21 12:14:44 +01:00
218 lines
7.7 KiB
Swift
218 lines
7.7 KiB
Swift
// RUN: %target-run-simple-swift
|
|
// REQUIRES: executable_test
|
|
|
|
// REQUIRES: objc_interop
|
|
// UNSUPPORTED: OS=watchos
|
|
|
|
import StdlibUnittest
|
|
import Accelerate
|
|
|
|
var AccelerateTests = TestSuite("Accelerate")
|
|
|
|
if #available(iOS 10.0, OSX 10.12, tvOS 10.0, watchOS 4.0, *) {
|
|
|
|
AccelerateTests.test("BNNS/ImageStackDescriptor") {
|
|
var succeed = BNNSImageStackDescriptor(width: 0, height: 0, channels: 0,
|
|
row_stride: 0, image_stride: 0,
|
|
data_type: .int8)
|
|
expectEqual(succeed.data_scale, 1)
|
|
expectEqual(succeed.data_bias, 0)
|
|
succeed = BNNSImageStackDescriptor(width: 0, height: 0, channels: 0,
|
|
row_stride: 0, image_stride: 0,
|
|
data_type: .int16,
|
|
data_scale: 0.5, data_bias: 0.5)
|
|
expectEqual(succeed.data_scale, 0.5)
|
|
expectEqual(succeed.data_bias, 0.5)
|
|
expectCrashLater()
|
|
// indexed8 is not allowed as an imageStack data type.
|
|
let _ = BNNSImageStackDescriptor(width: 0, height: 0, channels: 0,
|
|
row_stride: 0, image_stride: 0,
|
|
data_type: .indexed8)
|
|
}
|
|
|
|
AccelerateTests.test("BNNS/VectorDescriptor") {
|
|
var succeed = BNNSVectorDescriptor(size: 0, data_type: .int8)
|
|
expectEqual(succeed.data_scale, 1)
|
|
expectEqual(succeed.data_bias, 0)
|
|
succeed = BNNSVectorDescriptor(size: 0, data_type: .int8,
|
|
data_scale: 0.5, data_bias: 0.5)
|
|
expectEqual(succeed.data_scale, 0.5)
|
|
expectEqual(succeed.data_bias, 0.5)
|
|
expectCrashLater()
|
|
// indexed8 is not allowed as a vector data type.
|
|
let _ = BNNSVectorDescriptor(size: 0, data_type: .indexed8)
|
|
}
|
|
|
|
AccelerateTests.test("BNNS/LayerData") {
|
|
// The zero layer should have data == nil.
|
|
expectEqual(BNNSLayerData.zero.data, nil)
|
|
var succeed = BNNSLayerData(data: nil, data_type: .int8)
|
|
expectEqual(succeed.data_scale, 1)
|
|
expectEqual(succeed.data_bias, 0)
|
|
succeed = BNNSLayerData(data: nil, data_type: .int8, data_scale: 0.5,
|
|
data_bias: 0.5, data_table: nil)
|
|
expectEqual(succeed.data_scale, 0.5)
|
|
expectEqual(succeed.data_bias, 0.5)
|
|
var table: [Float] = [1.0]
|
|
succeed = BNNSLayerData.indexed8(data: nil, data_table: &table)
|
|
expectCrashLater()
|
|
// indexed8 requires a non-nil data table.
|
|
let _ = BNNSLayerData(data: nil, data_type: .indexed8)
|
|
}
|
|
|
|
AccelerateTests.test("BNNS/Activation") {
|
|
expectEqual(BNNSActivation.identity.function, .identity)
|
|
let id = BNNSActivation(function: .identity)
|
|
expectTrue(id.alpha.isNaN)
|
|
expectTrue(id.beta.isNaN)
|
|
}
|
|
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Linear interpolation
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
if #available(iOS 9999, macOS 9999, tvOS 9999, watchOS 9999, *) {
|
|
|
|
let n = 1024
|
|
|
|
AccelerateTests.test("vDSP/SinglePrecisionInterpolateBetweenVectors") {
|
|
var result = [Float](repeating: 0, count: n)
|
|
var legacyResult = [Float](repeating: -1, count: n)
|
|
|
|
let a: [Float] = (0 ..< n).map{ i in
|
|
return sin(Float(i) * 0.025)
|
|
}
|
|
|
|
let b: [Float] = (0 ..< n).map{ i in
|
|
return sin(Float(i) * 0.05)
|
|
}
|
|
|
|
let interpolationConstant: Float = 0.5
|
|
|
|
vDSP.linearInterpolate(a, b,
|
|
using: interpolationConstant,
|
|
result: &result)
|
|
|
|
vDSP_vintb(a, 1,
|
|
b, 1,
|
|
[interpolationConstant],
|
|
&legacyResult, 1,
|
|
vDSP_Length(n))
|
|
|
|
let returnedResult = vDSP.linearInterpolate(a, b,
|
|
using: interpolationConstant)
|
|
|
|
expectTrue(result.elementsEqual(legacyResult))
|
|
expectTrue(result.elementsEqual(returnedResult))
|
|
}
|
|
|
|
AccelerateTests.test("vDSP/SinglePrecisionInterpolateBetweenNeighbours") {
|
|
var result = [Float](repeating: 0, count: n)
|
|
var legacyResult = [Float](repeating: -1, count: n)
|
|
|
|
let shortSignal: [Float] = (0 ... 10).map{ i in
|
|
return sin(Float(i) * 0.1 * .pi * 4)
|
|
}
|
|
|
|
let controlVector: [Float] = {
|
|
var controlVector = [Float](repeating: 0, count: 1024)
|
|
|
|
vDSP_vgen([0],
|
|
[Float(shortSignal.count)],
|
|
&controlVector, 1,
|
|
vDSP_Length(n))
|
|
|
|
return controlVector
|
|
}()
|
|
|
|
vDSP.linearInterpolate(elementsOf: shortSignal,
|
|
using: controlVector,
|
|
result: &result)
|
|
|
|
vDSP_vlint(shortSignal,
|
|
controlVector, 1,
|
|
&legacyResult, 1,
|
|
vDSP_Length(n),
|
|
vDSP_Length(shortSignal.count))
|
|
|
|
let returnedResult = vDSP.linearInterpolate(elementsOf: shortSignal,
|
|
using: controlVector)
|
|
|
|
expectTrue(result.elementsEqual(legacyResult))
|
|
expectTrue(result.elementsEqual(returnedResult))
|
|
}
|
|
|
|
AccelerateTests.test("vDSP/DoublePrecisionInterpolateBetweenVectors") {
|
|
var result = [Double](repeating: 0, count: n)
|
|
var legacyResult = [Double](repeating: -1, count: n)
|
|
|
|
let a: [Double] = (0 ..< n).map{ i in
|
|
return sin(Double(i) * 0.025)
|
|
}
|
|
|
|
let b: [Double] = (0 ..< n).map{ i in
|
|
return sin(Double(i) * 0.05)
|
|
}
|
|
|
|
let interpolationConstant: Double = 0.5
|
|
|
|
vDSP.linearInterpolate(a, b,
|
|
using: interpolationConstant,
|
|
result: &result)
|
|
|
|
vDSP_vintbD(a, 1,
|
|
b, 1,
|
|
[interpolationConstant],
|
|
&legacyResult, 1,
|
|
vDSP_Length(n))
|
|
|
|
let returnedResult = vDSP.linearInterpolate(a, b,
|
|
using: interpolationConstant)
|
|
|
|
expectTrue(result.elementsEqual(legacyResult))
|
|
expectTrue(result.elementsEqual(returnedResult))
|
|
}
|
|
|
|
AccelerateTests.test("vDSP/DoublePrecisionInterpolateBetweenNeighbours") {
|
|
var result = [Double](repeating: 0, count: n)
|
|
var legacyResult = [Double](repeating: -1, count: n)
|
|
|
|
let shortSignal: [Double] = (0 ... 10).map{ i in
|
|
return sin(Double(i) * 0.1 * .pi * 4)
|
|
}
|
|
|
|
let controlVector: [Double] = {
|
|
var controlVector = [Double](repeating: 0, count: 1024)
|
|
|
|
vDSP_vgenD([0],
|
|
[Double(shortSignal.count)],
|
|
&controlVector, 1,
|
|
vDSP_Length(n))
|
|
|
|
return controlVector
|
|
}()
|
|
|
|
vDSP.linearInterpolate(elementsOf: shortSignal,
|
|
using: controlVector,
|
|
result: &result)
|
|
|
|
vDSP_vlintD(shortSignal,
|
|
controlVector, 1,
|
|
&legacyResult, 1,
|
|
vDSP_Length(n),
|
|
vDSP_Length(shortSignal.count))
|
|
|
|
let returnedResult = vDSP.linearInterpolate(elementsOf: shortSignal,
|
|
using: controlVector)
|
|
|
|
expectTrue(result.elementsEqual(legacyResult))
|
|
expectTrue(result.elementsEqual(returnedResult))
|
|
}
|
|
}
|
|
|
|
runAllTests()
|