卷积运算和卷积定理

卷积运算

卷积运算是信号处理、图像处理和深度学习中的核心概念,用于表示两个函数之间的相互作用。它将一个函数通过滑动窗口的方式与另一个函数结合,产生一个新的函数,反映两者的重叠程度。


1. 定义
  • 连续信号的卷积: 给定两个连续函数 f(t) 和 g(t) ,它们的卷积定义为:

    其中:

    • t 是输出信号的时间变量。
    • 是中间变量,用于计算 f 和 g 的重叠。
  • 离散信号的卷积: 给定两个离散序列 f[n] 和 g[n] ,它们的卷积定义为:

    在实际计算中,信号长度通常有限,求和区间取有限范围。


2. 卷积运算的直观理解

卷积可以理解为:

  1. 将一个信号 g(t) 翻转后平移,与另一个信号 f(t) 逐点相乘并求和,得到新的信号。
  2. 在图像处理中,卷积用于提取特征,比如边缘检测、模糊化等。

卷积定理

卷积定理揭示了卷积运算在时域和频域之间的重要关系,是信号处理和傅里叶分析的重要理论。


1. 定理陈述

卷积定理说明:两个信号在时域中的卷积等价于它们在频域中的乘积

  • 连续信号的卷积定理: 如果 F(ω) 和 G(ω) 分别是 f(t) 和 g(t) 的傅里叶变换,则有:

    即,时域卷积对应于频域相乘。

  • 离散信号的卷积定理: 如果 F[k] 和 G[k] 分别是 f[n] 和 g[n] 的离散傅里叶变换(DFT),则:

    同样,时域卷积等价于频域相乘。


2. 定理的逆向形式

卷积定理的逆向形式: 两个信号在频域中的卷积等价于它们在时域中的乘积

卷积的计算示例

1. 离散卷积的计算

给定两个序列:

计算它们的离散卷积:

手动计算结果:

  • 对 n=0 :
  • 对 n=1 :
  • 对 n=2 :
  • 对 n=3 :
  • 对 n=4 :

最终结果:

2. Python实现卷积

使用numpy库计算卷积:

python 复制代码
import numpy as np

# 定义两个信号
f = np.array([1, 2, 3])
g = np.array([0, 1, 0.5])

# 计算卷积
result = np.convolve(f, g, mode='full')
print("卷积结果:", result)
相关推荐
2401_8384725144 分钟前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
CoLiuRs1 小时前
语义搜索系统原理与实现
redis·python·向量·es
咋吃都不胖lyh1 小时前
CLIP 不是一个 “自主判断图像内容” 的图像分类模型,而是一个 “图文语义相似度匹配模型”—
人工智能·深度学习·机器学习
zhihuaba1 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
u0109272711 小时前
Python Web爬虫入门:使用Requests和BeautifulSoup
jvm·数据库·python
Stream_Silver2 小时前
【Agent学习笔记3:使用Python开发简单MCP服务】
笔记·python
穿过锁扣的风2 小时前
零基础入门 Python 爬虫:从基础到实战,爬取虎扑 / 豆瓣 / 图片全掌握
开发语言·爬虫·python
Stream_Silver2 小时前
【Agent学习笔记2:深入理解Function Calling技术:从原理到实践】
笔记·python
love530love2 小时前
技术复盘:llama-cpp-python CUDA 编译实战 (Windows)
人工智能·windows·python·llama·aitechlab·cpp-python·cuda版本
逄逄不是胖胖3 小时前
《动手学深度学习》-60translate实现
人工智能·python·深度学习