音频(一)时域图、 频谱图 Spectrum

1. 时域图

1.1 声音信号是一维的时域信号,无法观察出频率随时间的变化规律。

在这里插入图片描述
动态信号x(t): 是描述信号在不同时刻取值的函数, 其中t是自变量;

即横轴代表时间, 纵轴是信号的变化(振幅)。

2. 信号的频域分析

信号通过傅里叶变换把它变到频域上,可以看出信号的频率成分;

横轴代表各个频率成分, 纵轴: 信号的幅度值。
是一个时间平均(time average)概念。

2.1 频谱图

简单地说,任何信号(当然要满足一定的数学条件),都可以通过傅立叶变换而分解成一个直流分量(也就是一个常数)和若干个(一般是无穷多个)正弦信号的和。

每个正弦分量都有自己的频率和幅值;
这样,以频率值作横轴,以幅值作纵轴,
把上述若干个正弦信号的幅值画在其所对应的频率上,就做出了信号的幅频分布图,也就是所谓频谱图 。
频谱图

2.3 频谱图类型

在实际使用中,频谱图有三种,即

  1. 线性振幅谱、
  2. 对数振幅谱、
  3. 自功率谱.

其中, 对数振幅谱中各谱线的振幅都作了对数计算,所以其纵坐标的单位是dB(分贝), 这个变换的目的是使那些振幅较低的成分相对高振幅成分得以拉高,以便观察掩盖在低幅噪声中的周期信号。

2.4 相频分布:

横坐标: 频率 ;
纵坐标: 相位;
在这里插入图片描述

3. 功率谱

3.1 功率谱定义

功率谱可以从两方面来定义,

  1. 一个是自相关函数的傅立叶变换,第一种定义就是常说的维纳辛钦定理。

  2. 另一个是时域信号傅氏变换模平方然后除以时间长度。

第二种其实从能量谱密度来的。
根据parseval定理,信号傅氏变换模平方被定义为能量谱,能量谱密度在时间上平均就得到了功率谱。

3.2 功率谱性质

  1. 功率谱的概念是针对功率有限信号的(能量有限信号可用能量谱分析),所表现的是单位频带内信号功率随频率的变换情况。保留频谱的幅度信息,但是丢掉了相位信息,所以频谱不同的信号其功率谱是可能相同的。

  2. 功率谱是随机过程的统计平均概念,平稳随机过程的功率谱是一个确定函数;而频谱是随机过程样本的Fourier变换,对于一个随机过程而言,频谱也是一个“随机过程”。(随机的频域序列)

  3. 功率概念和幅度概念的差别。此外,只能对宽平稳的各态历经的二阶矩过程谈功率谱,其存在性取决于二阶局是否存在并且二阶矩的Fourier变换收敛;而频谱的存在性仅仅取决于该随机过程的该样本的Fourier变换是否收敛。

  4. 在频域分析信号分两种:
    (1).对确定性信号进行傅里叶变换,分析频谱信息。
    (2).随机信号的傅里叶信号不存在,转向研究它的功率谱。随机信号的功率谱和自相关函数是傅里叶变换对(即维纳辛钦定理)。功率谱估计有很多种方法;

4. 时域与频域的关系 (FFT)

4.1 相位与振幅

如下面静态图所示:

正弦波就是一个圆周运动在一条直线上的投影。
任意时刻的相位 为 ϕ \phi ϕ ;
任意时间的 幅度值: 振幅A × sin ϕ \phi ϕ

sin = 对边/ 斜边;
对边 = sin × 斜边
在这里插入图片描述

4.2 频域的基本单元

如下图所示:
频域的基本单元也可以理解为一个始终在旋转的圆。

在这里插入图片描述

4.3 FFT过程

举例, 矩形波的 FFT过程:
在这里插入图片描述

任意波形FFT:

在这里插入图片描述

4.4 相位差:

相位差 = (时间差 / 周期 ) × 2 π \pi π
图中, 小红点是距离频率轴最近的波峰, 我们将红色的点投影到下平面,投影点我们用粉色点来表示。当然,这些粉色的点只标注了波峰距离频率轴的距离,并不是相位。时间差并不是相位差。如果将全部周期看作2Π或者360度的话,相位差则是时间差在一个周期中所占的比例。我们将时间差除周期再乘 2Π,就得到了相位差。在这里插入图片描述

4.5 矩形波在时域、频域和相位的表现形式:

在这里插入图片描述

5. 时频域分析

5.1 时频域分析:

频谱虽然可以看出信号的频率分布, 但是丢失了时域信息,无法看出频率分布随时间的变化。

为了解决这个问题,很多时频域分析手段应运而生。

短时傅里叶,小波,Wigner分布等都是常用的时频域分析方法。

5.2 STFT的原理:

  1. 把一段长信号分帧、加窗,
  2. 对每一帧做傅里叶变换(FFT).

短时傅里叶变换,是对短时的信号做傅里叶变换。
短时的信号怎么得到? —> 是长时的信号分帧得来的。

5.3 实现:

python可以使用scipy库中的signal模块。

如果做STFT分解的音频信号(wav文件)的路径存在path变量中,可通过下面的代码得到STFT数据。

import wavio
import numpy as np
from scipy import signal

wav_struct=wavio.read(path)
wav=wav_struct.data.astype(float)/np.power(2,wav_struct.sampwidth*8-1)
[f,t,X]=signal.spectral.spectrogram(wav,np.hamming(1024),nperseg=1024,noverlap=0,detrend=False,return_onesided=True,mode='magnitude')

关于signal模块中spectrogram的使用方法和各个参数的具体意义,参见

https://docs.scipy.org/doc/scipy/reference/generated/scipy.signal.spectrogram.html#scipy.signal.spectrogram

  • 64
    点赞
  • 349
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 要绘制声音频像,你需要使用MATLAB中的FFT函数将音频信号转换为频域信号,然后使用plot函数绘制频谱图像。以下是一个简单的MATLAB程序示例,可以实现这个功能: ```matlab % 读取音频文件 [y, Fs] = audioread('audio.wav'); % 计算信号的FFT N = length(y); Y = fft(y); P2 = abs(Y/N); P1 = P2(1:N/2+1); P1(2:end-1) = 2*P1(2:end-1); f = Fs*(0:(N/2))/N; % 绘制频谱图 plot(f, P1) title('Single-Sided Amplitude Spectrum of Audio') xlabel('f (Hz)') ylabel('|P1(f)|') ``` 在此示例中,我们首先使用audioread函数读取名为'audio.wav'的音频文件。然后,我们使用FFT函数计算音频信号的FFT,并使用abs函数计算频域信号的幅度。接下来,我们通过将频域信号P2除以信号长度N来归一化频域信号。然后,我们只使用P1的前一半,即0到N/2的数据点,并使用plot函数绘制频谱图。最后,我们添加一些标题和标签来提高像的可读性。 请注意,上述示例仅适用于单声道音频文件。如果你需要处理立体声音频,请首先将其转换为单声道信号。 ### 回答2: 要使用Matlab编程绘制声音频像,我们可以按照以下步骤进行操作: 1. 导入声音数据:使用`audioread`函数导入声音文件,并将其存储为音频信号。 2. 计算频谱:使用`fft`函数对音频信号进行傅里叶变换,得到频谱数据。频谱数据包含了声音在不同频率上的能量分布。 3. 绘制频谱图像:使用`plot`函数将频谱数据进行可视化。横坐标表示频率,纵坐标表示能量(或者功率)。 以下是一个具体的示例代码: ```matlab % 导入声音数据 [x, fs] = audioread('audio.wav'); % 计算频谱 N = length(x); % 信号长度 X = abs(fft(x)) / N; % 傅里叶变换并归一化 % 绘制频谱图像 f = (0:N-1) * (fs / N); % 计算频率 plot(f, 20*log10(X)) % 使用对数坐标来显示能量(以分贝为单位) xlabel('Frequency (Hz)') ylabel('Power (dB)') title('Spectrum of Audio Signal') grid on ``` 这段代码首先使用`audioread`函数将声音文件(例如`audio.wav`)导入为音频信号。然后,对音频信号应用傅里叶变换,得到频谱数据`X`。最后,使用`plot`函数将频谱数据进行可视化,并为像添加轴标签和标题。 需要注意的是,频谱图像的横坐标表示的是频率,纵坐标表示的是能量(或者功率)。为了更好地显示能量范围,可以使用对数坐标,并使用`20*log10`函数对能量进行转换。另外,为了更好地观察频谱的细节,可以打开网格线(`grid on`)。 ### 回答3: 在MATLAB中编程绘制声音频像可以通过以下步骤实现: 1. 导入声音文件:使用`audioread`函数将声音文件导入到MATLAB中,并获得声音波形数据和采样率。 2. 计算频谱:使用`fft`函数对声音波形数据进行傅里叶变换,将时域信号转换为频域信号。得到频域信号后,可以计算得到频谱。 3. 绘制频谱图像:使用`plot`函数将频域信号的幅度谱绘制成像。横轴表示频率,纵轴表示幅度。 以下是实现上述步骤的代码: ```matlab % 导入声音文件 [soundData, sampleRate] = audioread('filename.wav'); % 计算频谱 frequencySpectrum = abs(fft(soundData)); % 创建频率向量 N = length(soundData); frequencyVector = (0:N-1)*(sampleRate/N); % 绘制频谱图像 plot(frequencyVector, frequencySpectrum) title('声音频像') xlabel('频率(Hz)') ylabel('幅度') ``` 以上代码中,应将`filename.wav`替换为实际的声音文件名。运行代码后,即可在MATLAB中绘制出指定声音文件的频谱图像。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值