Python 信号处理——短时傅里叶变换(STFT)


前言

实际中,有些信号是非平稳信号,这就导致我们在使用傅里叶变换时会出现频率混叠的现象。为实现非平稳信号的频率分析,短时傅里叶变化由此诞生。


一、短时傅里叶变换原理和用途

短时傅里叶变换原理是将单条非平稳信号切片成多个信号片段,然后分别对每个信号片段做傅里叶变换,最后将每个信号片段的频谱合为一个整体。短时傅里变换后的信号谱图中,横坐标是时间,纵坐标是频率,谱图颜色的深浅表示频率的大小。

二、使用步骤

1.主要代码

代码如下(示例):

import numpy as np
from scipy import signal
import matplotlib.pyplot as plt


def STFT(x, fs, n):
    f, t, amp = signal.stft(x, fs, nperseg=n)
    z = np.abs(amp.copy())
    return f, t, z

2.示例Demo

代码如下(示例):

import numpy as np
from scipy import signal
import matplotlib.pyplot as plt


def STFT(x, fs, n):
    f, t, amp = signal.stft(x, fs, nperseg=n)
    z = np.abs(amp.copy())
    return f, t, z


if __name__ == '__main__':
    w = 5
    z = 30
    fs = 1024
    fsw = 5
    time = 10
    f = w * z
    t = np.linspace(0, time - 1 / fs, int(time * fs))
    x = (1 + 1 * np.sin(2 * np.pi * 20 * t)) * np.sin(2 * np.pi * f * t)
    fre, ts, amp = STFT(x, fs, 512)
    plt.subplot(2, 1, 1)
    plt.plot(t, x)
    plt.ylabel('Amplitude')
    plt.xlabel('time')
    plt.subplot(2, 1, 2)
    plt.pcolormesh(ts, fre, amp)
    plt.ylabel('Frequency')
    plt.xlabel('time')
    plt.show()

总结

欢迎各位交流,后续有啥想实现的信号处理功能,请在下方评论区留言,或者关注公众号:不说话上代码

  • 5
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不说话上代码

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值