scipy numpy convolve

本文介绍了Python中scipy和numpy库的卷积功能,包括卷积的基本概念、不同模式(full, same, valid)的工作原理,并强调了时域卷积与频域乘积的关系。此外,提到了二维卷积的处理方式,但傅立叶变换实现的卷积则作为后续讨论的内容。" 48493233,1254913,Docker中使用Nvidia GPU进行计算,"['Docker', 'GPU', 'CUDA', '虚拟化', 'Nvidia']

两种实现版本,一种是正常的卷积计算,一种是利用傅立叶变换实现,时域的卷积等于频域的乘积。

记住卷积计算是一个窗口滑动的计算过程就行。

(a * v)[n] = \sum_{m = -\infty}^{\infty} a[m] v[n - m]

scipy.signal.convolve(in1in2mode='full'method='auto')

对文档中的计算做一些解释:

1.默认mode为full的模式,

>>> np.convolve([1, 2, 3], [0, 1, 0.5])
array([ 0. ,  1. ,  2.5,  4. ,  1.5])

2.same模式

>>> np.convolve([1,2,3],[0,1,0.5], 'same')
array([ 1. ,  2.5,  4. ])

3.valid模式

>>> np.convolve([1,2,3],[0,1,0.5], 'valid')
array([ 2.5])

解释:

计算的过程首先将in2 (kenel)翻转[0.5,1,0],然后以滑动窗口的方式 在in1上进行相乘相加的操作,超出的用0补充

最简单的valid模式:1*0.5 + 2*1 + 3*0 =2.5

same模式:0*0.5 +1*1 + 2*0 = 1

                  1*0.5 +2*1 + 3*0 = 2.5

                  2*0.5 +3*1 + 0*0 = 4

full模式类推;二维卷积也需要将卷积核翻转;

傅立叶变换的实现就不在此文中讲了,内容较多,另起博文。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值