如何将float数组的插值平滑到更大的数组中?

问题描述

我在Swift中一直插值。有人可以帮我吗?

我想将float数组(例如[0,100,25,0])插入到具有给定大小(例如 128 )的另一个数组中。我找到了一篇文章Use Linear Interpolation to Construct New Data Points),其中显示了如何实现这些目标。

有两种方法(您可以在下面看到结果的显示方式):

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

问题是两种技术都无法实现我的期望,Screenshot 3中对此进行了说明。如何使插值分布更平滑?我想看到一个类似立方体的曲线

初始图:

Screenshot 1

线性插值:

import Accelerate

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

let values: [Float] = [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,&result,n,vDSP_Length(values.count))

Screenshot 2

平滑插值:

import Accelerate
import AVFoundation

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

let values: [Float] = [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,vDSP_Length(values.count))

Screenshot 3

解决方法

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...