iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >基于python的快速傅里叶变换FFT(
  • 159
分享到

基于python的快速傅里叶变换FFT(

快速pythonFFT 2023-01-30 22:01:52 159人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

基于python的快速傅里叶变换FFT(二)本文在上一篇博客的基础上进一步探究正弦函数及其FFT变换。 知识点  FFT变换,其实就是快速离散傅里叶变换,傅立叶变换是数字信号处理领域一种很重要的算法。要知道傅立叶变换算法的意义,首先要了解

基于python的快速傅里叶变换FFT(二)
本文在上一篇博客的基础上进一步探究正弦函数及其FFT变换。

知识点
  FFT变换,其实就是快速离散傅里叶变换,傅立叶变换是数字信号处理领域一种很重要的算法。要知道傅立叶变换算法的意义,首先要了解傅立叶原理的意义。傅立叶原理表明:任何连续测量的时序或信号,都可以表示为不同频率的正弦波信号的无限叠加。而根据该原理创立的傅立叶变换算法利用直接测量到的原始信号,以累加方式来计算该信号中不同正弦波信号的频率、振幅和相位。

  和傅立叶变换算法对应的是反傅立叶变换算法。该反变换从本质上说也是一种累加处理,这样就可以将单独改变的正弦波信号转换成一个信号。因此,可以说,傅立叶变换将原来难以处理的时域信号转换成了易于分析的频域信号(信号的频谱),可以利用一些工具对这些频域信号进行处理、加工。最后还可以利用傅立叶反变换将这些频域信号转换成时域信号。

  假设FFT之后某点n用复数a+bi表示,那么这个复数的模就是An=sqrt(a*a+b*b)(某点处的幅度值An = A*(N/2))

代码实现
包的安装步骤见上一篇博客。

y = sin(2*pi*fs*t);Fs=150Hz,fs=25Hz。具体代码如下:

import matplotlib.pyplot as plt
import numpy as np
import seaborn

 

Fs = 150.0; # sampling rate采样率
Ts = 1.0/Fs; # sampling interval 采样区间
t = np.arange(0,1,Ts) # time vector,这里Ts也是步长

ff = 25; # frequency of the signal信号频率
y = np.sin(2*np.pi*ff*t)

n = len(y) # length of the signal
k = np.arange(n)
T = n/Fs
frq = k/T # two sides frequency range
frq1 = frq[range(int(n/2))] # one side frequency range

YY = np.fft.fft(y) # 未归一化
Y = np.fft.fft(y)/n # fft computing and nORMalization 归一化
Y1 = Y[range(int(n/2))]

fig, ax = plt.subplots(4, 1)

ax[0].plot(t,y)
ax[0].set_xlabel('Time')
ax[0].set_ylabel('Amplitude')

ax[1].plot(frq,abs(YY),'r') # plotting the spectrum
ax[1].set_xlabel('Freq (Hz)')
ax[1].set_ylabel('|Y(freq)|')

ax[2].plot(frq,abs(Y),'G') # plotting the spectrum
ax[2].set_xlabel('Freq (Hz)')
ax[2].set_ylabel('|Y(freq)|')

ax[3].plot(frq1,abs(Y1),'B') # plotting the spectrum
ax[3].set_xlabel('Freq (Hz)')
ax[3].set_ylabel('|Y(freq)|')

plt.show()

 

结果

结果验证

某点处的幅度值An = A*(N/2),A表示原始信号的幅值,N表示采样点。
1、原函数频率fs=25Hz,所以ts=1/25=0.04。与图中第一个波形相同。
2、已知A=1,N=150,由此可以计算出An=75。与图中第二个波形相同。
3、归一化幅度值=An/n=75/100=0.75。
---------------------
作者:赵至柔
来源:CSDN
原文:https://blog.csdn.net/qq_39516859/article/details/79770564
版权声明:本文为博主原创文章,转载请附上博文链接!

--结束END--

本文标题: 基于python的快速傅里叶变换FFT(

本文链接: https://www.lsjlt.com/news/180248.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 基于python的快速傅里叶变换FFT(
    基于python的快速傅里叶变换FFT(二)本文在上一篇博客的基础上进一步探究正弦函数及其FFT变换。 知识点  FFT变换,其实就是快速离散傅里叶变换,傅立叶变换是数字信号处理领域一种很重要的算法。要知道傅立叶变换算法的意义,首先要了解...
    99+
    2023-01-30
    快速 python FFT
  • Python实现快速傅里叶变换(FFT)
    相关文章:傅立叶级数展开初探(Python) 这里做一下记录,关于FFT就不做介绍了,直接贴上代码,有详细注释的了: import numpy as np from scipy.fftpack import fft,ifft im...
    99+
    2023-01-31
    快速 Python FFT
  • Python中利用FFT(快速傅里叶变换)进行频谱分析
    本文将从实例的角度出发讲解fft函数的基本使用,不包含复杂的理论推导。 一、基本条件 要对一个信号进行频谱分析,首先需要知道几个基本条件。 采样频率fs信号长度N(信号的点数) 采样频率fs:根据采样定理可知,采样频率应当大于等于被测...
    99+
    2023-09-09
    python numpy 开发语言 傅里叶分析
  • 基于Python实现图像的傅里叶变换
    目录前言(1)基本概念(2)读取图像信息1. 傅里叶变换(1)基本概念(2)numpy实现(3)OpevCV实现 2. 傅里叶逆变换(1)基本概念(2)代码实现前言 首先是本文总体代...
    99+
    2024-04-02
  • 如何基于Python实现图像的傅里叶变换
    这篇文章主要介绍了如何基于Python实现图像的傅里叶变换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言首先是本文总体代码,改一下图像的读取路径就可以运行了,但我还是建议...
    99+
    2023-06-22
  • Python与Matlab实现快速傅里叶变化的区别
    注:两种语言的fft算法是有区别的,最后细聊! Matlab的fftlw函数 输入是信号序列、对应的时间序列、以及是否作图,输出可以得到单边归一化之后的频率与对应的振幅,通过输出可以...
    99+
    2024-04-02
  • python中怎么使用scipy.fftpack模块计算快速傅里叶变换
    这篇文章将为大家详细讲解有关python中怎么使用scipy.fftpack模块计算快速傅里叶变换,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。python可以做什么Python是一种编程语言,内置了许多...
    99+
    2023-06-14
  • Python OpenCV实现图像傅里叶变换
    目录二维离散傅里叶变换(DFT)OpenCV 实现图像傅里叶变换(cv.dft)示例代码二维离散傅里叶变换(DFT) 对于二维图像处理,通常使用 x , y x, yx,y 表示离散...
    99+
    2024-04-02
  • opencv 傅里叶变换的实现
    目录傅里叶变换理论基础Numpy实现傅里叶变换实现傅里叶变换实现逆傅里叶变换高通滤波示例OpenCV实现傅里叶变换实现逆傅里叶变换低通滤波示例傅里叶变换 图像处理一般分为空间域处理和...
    99+
    2024-04-02
  • OpenCV-Python使用cv2实现傅里叶变换
    前言 在前一篇的博文中,我们详细讲解了傅里叶变换的原理以及使用Numpy库实现傅里叶变换。但是其实OpenCV有直接实现傅里叶变换的函数。 在OpenCV中,我们通过cv2.dft(...
    99+
    2024-04-02
  • Apache Commons Math3探索之快速傅立叶变换代码示例
    上一篇文章中我们了解了Apache Commons Math4探索之多项式曲线拟合实现代码,今天我们就来看看如何通过apache commons math4实现快速傅里叶变换,下面是具体内容。傅立叶变换:org.apache.commons...
    99+
    2023-05-30
    java math3 he
  • Python OpenCV如何实现图像傅里叶变换
    这篇文章给大家分享的是有关Python OpenCV如何实现图像傅里叶变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。二维离散傅里叶变换(DFT)对于二维图像处理,通常使用 x , y x, yx,y...
    99+
    2023-06-28
  • OpenCV图像变换之傅里叶变换的一些应用
    目录前言1. 效果图 2. 原理 3. 源码 3.1 Numpy实现傅里叶变换3.2 OpenCV实现傅里叶变换3.3 HPF or LPF?参考总结前言 这篇博客将介绍OpenCV...
    99+
    2024-04-02
  • OpenCV半小时掌握基本操作之傅里叶变换
    目录概述高频 vs 低频傅里叶变换代码详解输入转换傅里叶变换获取幅度谱傅里叶逆变换获取低频获取高频概述 OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白...
    99+
    2024-04-02
  • 为什么我的两个正弦波的离散傅里叶变换在零处有一个巨大的尖峰?
    偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《为什么我的两个正弦波的离散傅里叶变换在零处有一个巨大的尖峰?》,这篇文章主要会讲到等等知识点,不知道大家对其都...
    99+
    2024-04-05
  • Python Opencv基于透视变换的图像矫正
    本文实例为大家分享了Python Opencv基于透视变换的图像矫正,供大家参考,具体内容如下 一、自动获取图像顶点变换(获取图像轮廓顶点矫正) 图像旋转校正思路如下 1、以灰度图读...
    99+
    2024-04-02
  • Python OpenCV基于霍夫圈变换算法如何检测图像中的圆形
    小编给大家分享一下Python OpenCV基于霍夫圈变换算法如何检测图像中的圆形,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!第一章:霍夫变换检测圆①...
    99+
    2023-06-22
  • 基于阿里云物联网平台的Android物联网软件框架(快速开发)
    Android 物联网APP 提示:该工程是连接阿里云物联网平台的模板代码,将MQTT连接、JSON数据的订阅发布等操作封装,并且能够迅速将获取到的数据显示到手机界面上。使用了Servier进行网络连接的逻辑操作,并且使用自定义控件,绑定对...
    99+
    2023-08-16
    android 阿里云 物联网
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作