• 【Python】Python 时域到频域的变换方法


    Python 时域到频域的变换方法

    时域到频域的变换方法是信号处理中一个非常重要的概念,它将时域上的信号转换为频域上的信号,方便我们对信号频率特性的分析和处理。

    一、傅里叶变换

    傅里叶变换是时域到频域转换的一种常用方法,它将时域上的信号转换成一个连续的复数函数,表示信号在各个频率上的成分。在具体的实现中,可以使用Python中的numpy.fft库来进行傅里叶变换:

    import numpy as np

    t = np.linspace(-1, 1, 200)
    y = np.sin(2 * np.pi * 10 * t) + 2 * np.sin(2 * np.pi * 20 * t)
    y_fft = np.fft.fft(y)

    绘制频谱图

    import matplotlib.pyplot as plt

    plt.plot(np.abs(y_fft))
    plt.show()
    上述代码实现了对一个由10Hz和20Hz正弦波构成的信号进行傅里叶变换,并绘制了其频谱图。使用numpy.fft库的fft函数可以对信号进行变换,而np.abs则可以得到其幅值,即频谱图。

    二、快速傅里叶变换

    快速傅里叶变换是一种高效的傅里叶变换算法,它能够大幅度减少计算时间,广泛应用于信号处理领域。下面是使用Python中numpy.fft库实现的快速傅里叶变换:

    import numpy as np

    t = np.linspace(-1, 1, 200)
    y = np.sin(2 * np.pi * 10 * t) + 2 * np.sin(2 * np.pi * 20 * t)
    y_fft = np.fft.fft(y)

    绘制频谱图

    import matplotlib.pyplot as plt

    plt.plot(np.abs(y_fft))
    plt.show()
    与傅里叶变换的实现类似,使用numpy.fft库的fft函数可以进行快速傅里叶变换。

    三、小波变换

    小波变换也是一种常用的时域到频域变换方法,它与傅里叶变换不同的是,它能够捕捉信号中的瞬态特征,而不仅仅是频域上的信息。下面是使用Python中pywt库实现的小波变换:

    import pywt

    t = np.linspace(-1, 1, 200)
    y = np.sin(2 * np.pi * 10 * t) + 2 * np.sin(2 * np.pi * 20 * t)
    (cA, cD) = pywt.dwt(y, ‘db1’)
    y_wav = pywt.idwt(cA, cD, ‘db1’)

    绘制小波变换后的信号与原信号对比图

    import matplotlib.pyplot as plt

    plt.subplot(2, 1, 1)
    plt.plot(y)
    plt.subplot(2, 1, 2)
    plt.plot(y_wav)
    plt.show()
    上述代码实现了对一个由10Hz和20Hz正弦波构成的信号进行小波变换,并绘制了小波变换后的信号与原信号的对比图。使用pywt库的dwt和idwt函数可以对信号进行小波变换,其中’db1’是小波基名称。

    四、总结

    时域到频域的变换方法有很多种,傅里叶变换和快速傅里叶变换是最常用的方法,而小波变换则能够更好地捕捉信号的瞬态特征。在具体的实现中,可以使用Python中的numpy.fft和pywt库来进行相应的变换。

  • 相关阅读:
    百度智能云千帆大模型平台黑客马拉松报名开启!
    ECCV 2022 | FPN:You Should Look at All Objects
    企业应用架构研究系列一:业务拆分
    MAC安装JDK8
    windows 各种inject/hook学习材料(自用)
    程序连接oracle查询数据的环境配置
    vue/composition-api 的使用
    Mysql数据库基础:DML数据操作语言
    Java安全之Mojarra JSF反序列化
    保存业务的修改记录(对象字段差异对比)
  • 原文地址:https://blog.csdn.net/wjianwei666/article/details/133139920