【python数字信号处理】——线性卷积

目录

一、公式概念

二、代码

1、numpy库

2、自定义打印出每一步结果

 三、结果


一、公式概念

线性卷积_百度百科线性卷积(linear convolution) 在时域描述线性系统输入和输出之间关系的一种运算。这种运算在线性系统分析和信号处理中应用很多,通常简称卷积。中文名:数字信号处理https://baike.baidu.com/item/%E7%BA%BF%E6%80%A7%E5%8D%B7%E7%A7%AF/5908978?fr=aladdin

二、代码

1、numpy库

import numpy as np
 
# nunpy自带的一维线性卷积
r2 = np.convolve(v, a, mode="full")
print(r2)

2、自定义打印出每一步结果

# 时域上求两个序列的线性卷积
def lc(x1,x2):
	N1 = len(x1)
	N2 = len(x2)
	x1 = dict(enumerate(x1))
	x2 = dict(enumerate(x2))
	N = N1 + N2 - 1 # 线性卷积结果序列长度
	x0 = [0 for _ in range(N)]
	# 保存每一步的卷积结果
	X = []
	for i in range(N):
		s = 0
		for j in range(N1):
			s += x1[j] * x2.get(i - j, 0)  # 卷积核下标不存在时返回0
		x0[i] = s
		X.append(x0)
	return X

 三、结果

if __name__ == '__main__':
	x = [1,1,1,1]
	y = [4,3,2,1]
	print(np.convolve(x,y,mode="full"))
	print(lc(x,y)[-1])

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

有情怀的机械男

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

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

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

打赏作者

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

抵扣说明:

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

余额充值