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

python实现一维傅里叶变换——冈萨雷斯数字图像处理

原理

傅立叶变换,表示能将满足一定条件的某个函数表示成三角函数(正弦和/或余弦函数)或者它们的积分的线性组合。在不同的研究领域,傅立叶变换具有多种不同的变体形式,如连续傅立叶变换和离散傅立叶变换。最初傅立叶分析是作为热过程的解析分析的工具被提出的。

定义:给定一个函数 f(t),傅立叶变换将这个函数从时域(时间域)转换到频域(频率域)上的函数 。傅立叶变换的数学表示如下:
在这里插入图片描述

在这个表示中,F(ω) 表示频域上的复数函数,f(t) 表示时域上的函数,ω 表示频率,j 表示虚数单位。这个公式描述了将时域信号 f(t) 转换为频域信号 F(ω) 的过程。

原理:
复指数函数:傅立叶变换的核心是复指数函数ω,它表示在不同频率上的正弦和余弦振荡。傅立叶变换实际上是将信号分解为不同频率的复振幅和相位。

积分:傅立叶变换中的积分操作将时域函数给定范围内的所有时间点考虑在内,以获得频率域上的表示。这表示我们考虑了信号的所有时间信息以获取频率信息。

频谱:F(ω)表示了信号在频率ω处的振幅和相位信息。频谱显示了信号中各个频率分量的重要性。

逆变换:傅立叶变换不仅可以将信号从时域转换到频域,还可以进行逆变换,将信号从频域还原回时域,这允许我们在频域上对信号进行操作后再转换回时域。

输出如下图所示的结果:

生成包含1个、5个和10个正弦波信号的时域图和它们的FFT(傅立叶变换)的频域图,将它们放置在3x2的子图布局中。比较不同数量的正弦波信号在时域和频域上的表示。

在这里插入图片描述

代码展示

import numpy as np
from matplotlib import pyplot as plt# 时间长度为1,采样间隔为0.005
x = np.arange(0, 1, 0.005)
# 采样点数
n = len(x)
# 由于对称性,只取单边频谱,又由于我们事先知道实验中信号的频率小于20,所以只取前20个
freq = np.arange(20)y = []
F = []
# 分别取1,5,10个正弦波叠加
for num in [1, 5, 10]:y_signal = 0for i in range(num):# 正弦波的频率为1,3,5,7...y_signal += np.sin(2*np.pi*(2*i+1)*x)/(2*i+1)y.append(y_signal)F_signal = np.fft.fft(y_signal)# 取abs是为了计算复数的幅度谱,/n是为了归一化F.append(np.abs(F_signal[range(20)])/n)_, axs = plt.subplots(3, 2)for i in range(3):axs[i, 0].plot(x, y[i])axs[i, 0].set_xlabel('time')axs[i, 0].set_ylabel('amplitude')axs[i, 1].stem(freq, F[i])axs[i, 1].set_xlabel('frequency')axs[i, 1].set_ylabel('FFT')plt.savefig('1D_FFT.jpg')
plt.show()

结果展示

在这里插入图片描述

主要代码解释

创建时间向量 x:
x = np.arange(0, 1, 0.005):创建一个从0到1的时间向量 x,采样间隔为0.005秒,用于表示信号的时间范围。
获取采样点数 n:
n = len(x):计算时间向量 x 中的采样点数,以便在后续的FFT归一化中使用。
创建频率向量 freq
freq = np.arange(20):创建一个频率向量 freq,包含从0到19的整数值,表示将计算的频率范围。
创建信号和频域数据:
使用for循环分别取1、5和10个正弦波信号,并在每个循环中生成信号,并计算其FFT。
y_signal = 0:初始化一个信号变量y_signal,用于存储叠加的正弦波信号。
在内部的for循环中,叠加不同频率的正弦波信号到y_signal。
F_signal = np.fft.fft(y_signal):计算y_signal的傅立叶变换,结果存储在F_signal中。
F.append(np.abs(F_signal[range(20)])/n):将计算的FFT结果归一化并存储在列表F中,仅保留前20个频率成分。

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

相关文章:

  • 表单(HTML)
  • spripng 三级缓存,三级缓存的作用是什么? Spring 中哪些情况下,不能解决循环依赖问题有哪些
  • elasticsearch系列六:索引重建
  • GitOps实践指南:GitOps能为我们带来什么?
  • D3485国产芯片+5V工作电压, 内置失效保护电路采用SOP8封装
  • devops使用
  • AI训练师常用的ChatGPT通用提示词模板
  • Java加密算法工具类(AES、DES、MD5、RSA)
  • 探索Go语言的魅力:一门简洁高效的编程语言
  • 【用unity实现100个游戏之19】制作一个3D传送门游戏,实现类似鬼打墙,迷宫,镜子,任意门效果
  • DRF(Django Rest Framework)框架基于restAPI协议规范的知识点总结
  • Linux磁盘与文件系统管理
  • 数字魔法AI绘画的艺术奇迹-用Stable Diffusion挑战无限可能【文末送书-12】
  • 【docker实战】02 用docker安装mysql
  • 循环渲染ForEach
  • 纷享销客华为云:如何让企业多一个选择?
  • 前端实现断点续传文件
  • 复试 || 就业day01(2023.12.27)算法篇
  • JavaWeb——JQuery
  • Python教程:查询Py模块的版本号,有哪些方法?
  • 第一节 初始化项目
  • idea提示unable to import maven project
  • 【Spring】SpringBoot日志
  • HTML+CSS制作动漫绿巨人
  • AGV智能搬运机器人-替代人工工位让物流行业降本增效
  • 【办公技巧】怎么批量提取文件名到excel
  • uniapp实现前端银行卡隐藏中间的数字,及隐藏姓名后两位
  • HPCC:高精度拥塞控制
  • centos 配置 git 连接 github
  • SpringBoot发布项目到docker