gpt4 book ai didi

vba - Excel线性插值VBA

转载 作者:行者123 更新时间:2023-12-04 21:16:05 72 4
gpt4 key购买 nike

此函数内插/外推已知 x,y 的表
例如,

x y
1 10
2 15
3 20

Linterp(A1:B3, -1) = 0

但是,这段代码只能做两个相邻的数组。
我想修改这段代码,以便我可以
选择两个单独的数组,例如 N106:N109,P106:P109。
如何在此代码中进行此调整?
Function Linterp(r As Range, x As Double) As Double
' linear interpolator / extrapolator
' R is a two-column range containing known x, known y
Dim lR As Long, l1 As Long, l2 As Long
Dim nR As Long
'If x = 1.5 Then Stop

nR = r.Rows.Count
If nR < 2 Then Exit Function

If x < r(1, 1) Then ' x < xmin, extrapolate
l1 = 1: l2 = 2: GoTo Interp

ElseIf x > r(nR, 1) Then ' x > xmax, extrapolate
l1 = nR - 1: l2 = nR: GoTo Interp

Else
' a binary search would be better here
For lR = 1 To nR
If r(lR, 1) = x Then ' x is exact from table
Linterp = r(lR, 2)
Exit Function

ElseIf r(lR, 1) > x Then ' x is between tabulated values, interpolate
l1 = lR: l2 = lR - 1: GoTo Interp

End If
Next
End If

Interp:
Linterp = r(l1, 2) _
+ (r(l2, 2) - r(l1, 2)) _
* (x - r(l1, 1)) _
/ (r(l2, 1) - r(l1, 1))

End Function

最佳答案

一种非常简单的方法是让函数在输入中接受两个范围,一个用于 X 值(例如 rX),一个用于 Y 值(例如 rY),然后更改每次出现的 r(foo,1)rX(foo)r(foo,2)rY(foo)
如下

Option Explicit

Function Linterp2(rX As Range, rY As Range, x As Double) As Double
' linear interpolator / extrapolator
' R is a two-column range containing known x, known y
Dim lR As Long, l1 As Long, l2 As Long
Dim nR As Long
'If x = 1.5 Then Stop

nR = rX.Rows.Count
If nR < 2 Then Exit Function

If x < rX(1) Then ' x < xmin, extrapolate
l1 = 1: l2 = 2: GoTo Interp

ElseIf x > rX(nR) Then ' x > xmax, extrapolate
l1 = nR - 1: l2 = nR: GoTo Interp

Else
' a binary search would be better here
For lR = 1 To nR
If rX(lR) = x Then ' x is exact from table
Linterp2 = rY(lR)
Exit Function

ElseIf rX(lR) > x Then ' x is between tabulated values, interpolate
l1 = lR: l2 = lR - 1: GoTo Interp

End If
Next
End If

Interp:
Linterp2 = rY(l1) _
+ (rY(l2) - rY(l1)) _
* (x - rX(l1)) _
/ (rX(l2) - rX(l1))

End Function

但是您必须实现代码来检查两个范围的一致性,例如每个列都具有相同的行数

关于vba - Excel线性插值VBA,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36455864/

72 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com