iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python实现快速傅里叶变换(FFT)
  • 501
分享到

Python实现快速傅里叶变换(FFT)

快速PythonFFT 2023-01-31 01:01:59 501人浏览 泡泡鱼

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

摘要

相关文章:傅立叶级数展开初探(python) 这里做一下记录,关于FFT就不做介绍了,直接贴上代码,有详细注释的了: import numpy as np from scipy.fftpack import fft,ifft im

相关文章:傅立叶级数展开初探(python)

这里做一下记录,关于FFT就不做介绍了,直接贴上代码,有详细注释的了:

import numpy as np
from scipy.fftpack import fft,ifft
import matplotlib.pyplot as plt
import seaborn


#采样点选择1400个,因为设置的信号频率分量最高为600赫兹,根据采样定理知采样频率要大于信号频率2倍,所以这里设置采样频率为1400赫兹(即一秒内有1400个采样点,一样意思的)
x=np.linspace(0,1,1400)      

#设置需要采样的信号,频率分量有180,390和600
y=7*np.sin(2*np.pi*180*x) + 2.8*np.sin(2*np.pi*390*x)+5.1*np.sin(2*np.pi*600*x)

yy=fft(y)                     #快速傅里叶变换
yreal = yy.real               # 获取实数部分
yimag = yy.imag               # 获取虚数部分

yf=abs(fft(y))                # 取绝对值
yf1=abs(fft(y))/len(x)           #归一化处理
yf2 = yf1[range(int(len(x)/2))]  #由于对称性,只取一半区间

xf = np.arange(len(y))        # 频率
xf1 = xf
xf2 = xf[range(int(len(x)/2))]  #取一半区间


plt.subplot(221)
plt.plot(x[0:50],y[0:50])   
plt.title('Original wave')

plt.subplot(222)
plt.plot(xf,yf,'r')
plt.title('FFT of Mixed wave(two sides frequency range)',fontsize=7,color='#7A378B')  #注意这里的颜色可以查询颜色代码表

plt.subplot(223)
plt.plot(xf1,yf1,'g')
plt.title('FFT of Mixed wave(nORMalization)',fontsize=9,color='r')

plt.subplot(224)
plt.plot(xf2,yf2,'b')
plt.title('FFT of Mixed wave)',fontsize=10,color='#F08080')


plt.show()

结果:这里写图片描述


2017/7/11更新

再添加一个简单的例子

# -*- coding: utf-8 -*-
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()

这里写图片描述

--结束END--

本文标题: Python实现快速傅里叶变换(FFT)

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

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

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

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

下载Word文档
猜你喜欢
  • Python实现快速傅里叶变换(FFT)
    相关文章:傅立叶级数展开初探(Python) 这里做一下记录,关于FFT就不做介绍了,直接贴上代码,有详细注释的了: import numpy as np from scipy.fftpack import fft,ifft im...
    99+
    2023-01-31
    快速 Python FFT
  • 基于python的快速傅里叶变换FFT(
    基于python的快速傅里叶变换FFT(二)本文在上一篇博客的基础上进一步探究正弦函数及其FFT变换。 知识点  FFT变换,其实就是快速离散傅里叶变换,傅立叶变换是数字信号处理领域一种很重要的算法。要知道傅立叶变换算法的意义,首先要了解...
    99+
    2023-01-30
    快速 python FFT
  • Python中利用FFT(快速傅里叶变换)进行频谱分析
    本文将从实例的角度出发讲解fft函数的基本使用,不包含复杂的理论推导。 一、基本条件 要对一个信号进行频谱分析,首先需要知道几个基本条件。 采样频率fs信号长度N(信号的点数) 采样频率fs:根据采样定理可知,采样频率应当大于等于被测...
    99+
    2023-09-09
    python numpy 开发语言 傅里叶分析
  • Python OpenCV实现图像傅里叶变换
    目录二维离散傅里叶变换(DFT)OpenCV 实现图像傅里叶变换(cv.dft)示例代码二维离散傅里叶变换(DFT) 对于二维图像处理,通常使用 x , y x, yx,y 表示离散...
    99+
    2024-04-02
  • Python与Matlab实现快速傅里叶变化的区别
    注:两种语言的fft算法是有区别的,最后细聊! Matlab的fftlw函数 输入是信号序列、对应的时间序列、以及是否作图,输出可以得到单边归一化之后的频率与对应的振幅,通过输出可以...
    99+
    2024-04-02
  • opencv 傅里叶变换的实现
    目录傅里叶变换理论基础Numpy实现傅里叶变换实现傅里叶变换实现逆傅里叶变换高通滤波示例OpenCV实现傅里叶变换实现逆傅里叶变换低通滤波示例傅里叶变换 图像处理一般分为空间域处理和...
    99+
    2024-04-02
  • OpenCV-Python使用cv2实现傅里叶变换
    前言 在前一篇的博文中,我们详细讲解了傅里叶变换的原理以及使用Numpy库实现傅里叶变换。但是其实OpenCV有直接实现傅里叶变换的函数。 在OpenCV中,我们通过cv2.dft(...
    99+
    2024-04-02
  • opencv傅里叶变换如何实现
    今天小编给大家分享一下opencv傅里叶变换如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。傅里叶变换图像处理一般分为...
    99+
    2023-06-30
  • 基于Python实现图像的傅里叶变换
    目录前言(1)基本概念(2)读取图像信息1. 傅里叶变换(1)基本概念(2)numpy实现(3)OpevCV实现 2. 傅里叶逆变换(1)基本概念(2)代码实现前言 首先是本文总体代...
    99+
    2024-04-02
  • Python OpenCV如何实现图像傅里叶变换
    这篇文章给大家分享的是有关Python OpenCV如何实现图像傅里叶变换的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。二维离散傅里叶变换(DFT)对于二维图像处理,通常使用 x , y x, yx,y...
    99+
    2023-06-28
  • python中怎么使用scipy.fftpack模块计算快速傅里叶变换
    这篇文章将为大家详细讲解有关python中怎么使用scipy.fftpack模块计算快速傅里叶变换,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。python可以做什么Python是一种编程语言,内置了许多...
    99+
    2023-06-14
  • 如何基于Python实现图像的傅里叶变换
    这篇文章主要介绍了如何基于Python实现图像的傅里叶变换,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言首先是本文总体代码,改一下图像的读取路径就可以运行了,但我还是建议...
    99+
    2023-06-22
  • Apache Commons Math3探索之快速傅立叶变换代码示例
    上一篇文章中我们了解了Apache Commons Math4探索之多项式曲线拟合实现代码,今天我们就来看看如何通过apache commons math4实现快速傅里叶变换,下面是具体内容。傅立叶变换:org.apache.commons...
    99+
    2023-05-30
    java math3 he
  • matlab傅里叶变换函数怎么使用
    在MATLAB中,可以使用fft函数进行傅里叶变换。fft函数的基本使用方式如下:Y = fft(X) % 对输入信号X进行傅里叶...
    99+
    2023-09-14
    matlab
  • 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
  • python如何快速交换变量值
    这篇文章主要为大家展示了“python如何快速交换变量值”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python如何快速交换变量值”这篇文章吧。快速交换变量值x, y =&...
    99+
    2023-06-27
  • 为什么我的两个正弦波的离散傅里叶变换在零处有一个巨大的尖峰?
    偷偷努力,悄无声息地变强,然后惊艳所有人!哈哈,小伙伴们又来学习啦~今天我将给大家介绍《为什么我的两个正弦波的离散傅里叶变换在零处有一个巨大的尖峰?》,这篇文章主要会讲到等等知识点,不知道大家对其都...
    99+
    2024-04-05
  • python 快速排序实现
    import random num_list = []for x in range(30):    num_list.append(random.randint(1, 500))list_len = ...
    99+
    2023-06-02
  • 利用Python实现快速批量转换HEIC文件
    目录1. 前言2. 准备3. 实战4.最后1. 前言 最近打算做一批日历给亲朋好友,但是从 iPhone 上导出的照片格式是 HEIC 格式,而商家的在线制作网站不支持这种图片格式 ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作