[数字信号处理][Python] numpy.gradient()函数的算法实现

先看实例

import numpy as np
signal = [3,2,1,3,8,10]
grad = np.gradient(signal)
print(grad)

输出结果是
[-1. -1. 0.5 3.5 3.5 2. ]

这个结果是怎么来的呢?
np.gradient 计算信号的数值梯度,也就是信号值的变化率。它使用中心差分法来计算中间点的梯度,并使用前向差分法和后向差分法来计算边界点的梯度。
一、边界点:
grad[0]=signal[1]−signal[0]=2−3=−1grad[0] = signal[1] - signal[0] = 2 - 3 = -1grad[0]=signal[1]signal[0]=23=1
grad[5]=signal[5]−signal[4]=10−8=2grad[5] = signal[5] - signal[4] = 10-8 = 2grad[5]=signal[5]signal[4]=108=2
二、中间点:
grad[i]=signal[i+1]−signal[i−1]2grad[i] =\frac{signal[i+1]-signal[i-1]}{2}grad[i]=2signal[i+1]signal[i1],由此可知
grad[1]=signal[2]−signal[0]2=−1grad[1] =\frac{signal[2]-signal[0]}{2} = -1grad[1]=2signal[2]signal[0]=1
其他略。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值