Excel·VBA卷积

76 篇文章 26 订阅
Function convolve(arr1, arr2)
    'arr1、arr2一维数组,卷积运算返回一维数组(数组从1开始计数)
    Dim i&, j&, n1&, n2&, max_n&
    '转为从1开始计数
    If LBound(arr1) = 0 Then arr1 = WorksheetFunction.Transpose(WorksheetFunction.Transpose(arr1))
    If LBound(arr2) = 0 Then arr2 = WorksheetFunction.Transpose(WorksheetFunction.Transpose(arr2))
    n1 = UBound(arr1): n2 = UBound(arr2)
    max_n = n1 + n2 - 1: ReDim result(1 To max_n)  '返回数组大小
    For i = 1 To max_n
        For j = 1 To n1
            If i - j >= 0 And i - j < n2 Then result(i) = result(i) + arr1(j) * arr2(i - j + 1)
        Next
    Next
    convolve = result
End Function

举例

用复利理解卷积,假设每年存入100元,年利率5%,按复利计算每年结束时的累计本息总额

1年本息=100*1.05=1052年本息=100*1.05^2+100*1.05=215.253年本息=100*1.05^3+100*1.05^2+100*1.05=331.01254年本息=100*1.05^4+100*1.05^3+100*1.05^2+100*1.05=452.5631255年本息=100*1.05^5+100*1.05^4+100*1.05^3+100*1.05^2+100*1.05=580.19128125

卷积运算

Sub 卷积测试()
    a = Array(100, 100, 100, 100, 100)
    b = Array(1.05, 1.05 ^ 2, 1.05 ^ 3, 1.05 ^ 4, 1.05 ^ 5)
    Debug.Print Join(convolve(a, b), ", ")
End Sub
105, 215.25, 331.0125, 452.563125, 580.19128125, 475.19128125, 364.94128125, 249.17878125, 127.62815625

得到9个结果,前5个就是5年每年累计本息总额

参考资料
《百度百科-卷积》
《知乎-如何通俗易懂地解释卷积?》

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

薛定谔_51

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值