11

我坚持使用 Swift 中的插值。任何人都可以帮助我吗?

我想将浮点数组(比如[0, 0, 100, 25, 0, 0, 0, 25, 0, 0, 0])插入到另一个具有给定大小(例如128)的数组中。我找到了一篇文章(使用线性插值构造新数据点),展示了如何实现这些东西。

有两种方法(你可以看到下面的结果,它们是如何执行的):

  • vDSP_vgenp使用和进行线性插值
  • 更平滑(但不是出于我的目的)插值使用vDSP_vlint

问题是这两种技术都没有实现我的期望,如屏幕截图 3所示。如何使我的插值分布更平滑?我想看到一个立方体状的曲线

初始情节:

截图 1

线性插值:

import Accelerate

let n = vDSP_Length(128)
let stride = vDSP_Stride(1)

let values: [Float] = [0, 0, 100, 25, 0, 0, 0, 25, 0, 0, 0]
let indices: [Float] = [0, 11, 23, 34, 46, 58, 69, 81, 93, 104, 116]

var result = [Float](repeating: 0, count: Int(n))

vDSP_vgenp(values, stride, indices, stride, &result, stride, n, vDSP_Length(values.count))

截图 2

平滑插值:

import Accelerate
import AVFoundation

let n = vDSP_Length(1024)
let stride = vDSP_Stride(1)

let values: [Float] = [0, 0, 100, 25, 0, 0, 0, 25, 0, 0, 0]
let denominator = Float(n) / Float(values.count - 1)

let control: [Float] = (0 ... n).map {
    let x = Float($0) / denominator
    return floor(x) + simd_smoothstep(0, 1, simd_fract(x))
}

var result = [Float](repeating: 0, count: Int(n))

vDSP_vlint(values, control, stride, &result, stride, n, vDSP_Length(values.count))

截图 3

4

1 回答 1

0

在我看来,vDSP_vqint二次插值函数可以解决这个问题。请参阅https://developer.apple.com/documentation/accelerate/1449942-vdsp_vqint上的讨论。

于 2020-09-12T20:01:33.503 回答