特征提取(Feature Extraction)常见频域特征笔记(四)

分类: 365bet注册送18 发布时间: 2026-01-04 18:51:18 作者: admin

频域特征是指将数据转换到频率域进行分析的特征。在频域分析中,我们可以看到信号在不同频率下的成分,这对于理解信号的周期性、周期性强度以及频率分布非常有用。常见的频域特征包括傅里叶变换、功率谱密度等。下面我会详细解释每个频域特征,并给出相应的Python代码。

傅里叶变换(Fourier Transform) :将信号从时域(时间域)转换到频域(频率域),它将信号分解成一系列正弦和余弦函数的组合。傅里叶变换可以帮助我们了解信号中各种频率成分的强度和相位信息。

复制代码

import numpy as np

import matplotlib.pyplot as plt

def fourier_transform(signal, sampling_rate):

n = len(signal)

frequencies = np.fft.fftfreq(n, d=1/sampling_rate)

fft_values = np.fft.fft(signal)

return frequencies, fft_values

# Example

t = np.linspace(0, 1, 1000) # Time array from 0 to 1 with 1000 points

signal = np.sin(2 * np.pi * 5 * t) + np.sin(2 * np.pi * 10 * t) # Signal with two frequencies

sampling_rate = 1000 # Sampling rate in Hz

frequencies, fft_values = fourier_transform(signal, sampling_rate)

plt.plot(frequencies, np.abs(fft_values))

plt.xlabel('Frequency (Hz)')

plt.ylabel('Amplitude')

plt.title('Fourier Transform')

plt.show()

功率谱密度(Power Spectral Density) :表示信号在不同频率上的能量分布。功率谱密度可以帮助我们确定信号中哪些频率成分具有更高的能量。

复制代码

from scipy.signal import welch

def power_spectral_density(signal, sampling_rate):

frequencies, psd = welch(signal, fs=sampling_rate)

return frequencies, psd

# Example

t = np.linspace(0, 1, 1000) # Time array from 0 to 1 with 1000 points

signal = np.sin(2 * np.pi * 5 * t) + np.sin(2 * np.pi * 10 * t) # Signal with two frequencies

sampling_rate = 1000 # Sampling rate in Hz

frequencies, psd = power_spectral_density(signal, sampling_rate)

plt.semilogy(frequencies, psd)

plt.xlabel('Frequency (Hz)')

plt.ylabel('Power Spectral Density')

plt.title('Power Spectral Density')

plt.show()

这些是常见的频域特征及其相应的Python实现。在信号处理和频域分析中,这些特征对于理解信号的频率成分、周期性以及能量分布非常重要。

上一篇: 商陆花进销存软件购买指南,商陆花进销存软件哪里买? 下一篇: 【益智游戏】益智游戏儿童

相关文章

个人更换手机指南v1.0

个人更换手机指南v1.0

“兰博”多功能刀,因《第一滴血》风靡世界,硬汉们的最爱

“兰博”多功能刀,因《第一滴血》风靡世界,硬汉们的最爱

扩阴器怎么做

扩阴器怎么做

圈养羊怎么样养才是科学的?圈养羊的正确喂养方法,注意这四点

圈养羊怎么样养才是科学的?圈养羊的正确喂养方法,注意这四点

市场传闻“两融业务降低门槛”,多家券商表示未收到通知

市场传闻“两融业务降低门槛”,多家券商表示未收到通知

手机怎么设置红包来了

手机怎么设置红包来了