当前位置: 首页 > news >正文

OpenCV自学笔记十七:傅里叶变换

1、Numpy实现傅里叶变换

傅里叶变换(Fourier Transform)是一种将信号从时域转换到频域的数学变换。它将一个连续或离散的时域信号分解为一组正弦和余弦函数的复合。

在Python中,可以使用NumPy库来实现傅里叶变换。具体步骤如下:

1. 导入NumPy库:

import numpy as np

2. 准备输入信号数据,可以是离散的时间序列数据或连续的函数。假设我们有一个离散的信号`x`,包含N个采样点:

x = np.array([5, 3, 6, 2, 8, 7])

3. 使用NumPy的`fft.fft()`函数进行傅里叶变换:

X = np.fft.fft(x)

这将返回一个复数数组`X`,其中包含了信号在频域的表示。

4. 对结果进行频谱转换,得到幅度谱和相位谱。可以使用`np.abs()`函数计算幅度谱,使用`np.angle()`函数计算相位谱:

amplitude_spectrum = np.abs(X)phase_spectrum = np.angle(X)

5. 可选:对频域信号做其他处理。例如,可以将某些频率设置为零,然后使用逆傅立叶变换(`np.fft.ifft()`)将信号从频域转换回时域。

下面是一个完整的示例代码,演示了如何使用NumPy进行傅里叶变换:

import numpy as np# 输入信号x = np.array([5, 3, 6, 2, 8, 7])# 傅里叶变换X = np.fft.fft(x)# 频谱转换amplitude_spectrum = np.abs(X)phase_spectrum = np.angle(X)print("Amplitude Spectrum:", amplitude_spectrum)print("Phase Spectrum:", phase_spectrum)

这个示例将计算输入信号`x`的傅里叶变换,并输出幅度谱和相位谱。

需要注意的是,以上示例是针对离散信号的傅里叶变换。如果要处理连续信号,可以使用NumPy中的`fft.fft()`函数的连续版本`np.fft.fftn()`或`np.fft.fftshift()`来进行相应的处理。

2、OpenCV实现傅里叶变换

傅里叶变换(Fourier Transform)是一种将时域信号转换为频域信号的数学工具,常用于图像处理和信号处理领域。OpenCV库提供了对傅里叶变换的支持。下面是傅里叶变换的原理和一个示例:

傅里叶变换将一个连续时间域信号表示为一组正弦和余弦函数的加权和。在图像处理中,我们可以将二维图像看作是一个二维离散信号。使用傅里叶变换,我们可以将图像从空域(时域)转换到频域。频域中的每个点表示了相应频率的成分在图像中的贡献。

示例:

下面是一个使用OpenCV实现傅里叶变换的简单示例代码:

​
import cv2import numpy as npfrom matplotlib import pyplot as plt# 读取图像img = cv2.imread('image.jpg', 0)# 进行傅里叶变换f = np.fft.fft2(img)fshift = np.fft.fftshift(f)magnitude_spectrum = 20 * np.log(np.abs(fshift))# 显示原始图像和频谱图plt.subplot(121), plt.imshow(img, cmap='gray')plt.title('Input Image'), plt.xticks([]), plt.yticks([])plt.subplot(122), plt.imshow(magnitude_spectrum, cmap='gray')plt.title('Magnitude Spectrum'), plt.xticks([]), plt.yticks([])plt.show()​ 

在上面的示例中,我们首先使用`cv2.imread()`函数读取图像,并将其转换为灰度图像。然后使用`np.fft.fft2()`函数对灰度图像进行二维傅里叶变换。接下来,使用`np.fft.fftshift()`函数将频谱移到中心位置,并使用`20 * np.log(np.abs())`计算频谱的幅度谱(以对数尺度显示)。最后,使用`plt.subplot()`和`plt.imshow()`函数显示原始图像和频谱图。

运行上述代码,你将得到原始图像和对应的频谱图。频谱图中的亮度表示相应频率的成分在图像中的贡献大小。

http://www.lryc.cn/news/174115.html

相关文章:

  • uniapp如何判断是哪个(微信/APP)平台
  • 网络安全——(黑客)自学
  • 一拖三快充线(USB-C转三充)的解决方案--LDR6020P
  • 2024年考研教育专业的教育综合考试大纲、样题和往年真题
  • 算法之斐波那契数列
  • 关于Pandas数据分析
  • Go 并发可视化解释 - sync.Mute
  • 十几张高清世界地图
  • Python 逢七拍手游戏
  • Windows安装Mysql--免安装版
  • TypeScript中常见的操作符运算符总结
  • 什么是泛型约束?
  • 代码随想录算法训练营 动态规划part11
  • 新概念英语(第二册)复习——Lesson 16 - Lesson20
  • [题] n-皇后问题 #深搜 #DFS
  • 十小时开源了一个加密算法仓库,功能强大,后端开发人员狂喜!
  • 标准化套利的使用
  • 【MySQL数据库事务操作、主从复制及Redis数据库读写分离、主从同步的实现机制】
  • 十五、红外遥控器
  • diot函数解析
  • Python函数绘图与高等代数互融实例(一):正弦函数与余弦函数
  • Python 判断回文数
  • 人工智能在金融领域的五个应用案例
  • java 工程管理系统源码+项目说明+功能描述+前后端分离 + 二次开发
  • Effective C++看书笔记(2):构造/析构/赋值运算
  • 交换奇偶位:交换一个整数的二进制的奇偶位置(仅考虑正数情况)
  • Unity中的两种ScriptingBackend
  • vue3硅谷甄选01 | 使用vite创建vue3项目及项目的配置 环境准备 ESLint配置 prettier配置 husky配置 项目集成
  • 蓝牙核心规范(V5.4)10.5-BLE 入门笔记之HCI
  • 【计算机毕业设计】基于SpringBoot+Vue记帐理财系统的设计与实现