Python реализует «частотно-временную диаграмму EMD\EEMD\VMD+Гильберта» и «частотно-временную диаграмму вейвлета CWT».
Python реализует «частотно-временную диаграмму EMD\EEMD\VMD+Гильберта» и «частотно-временную диаграмму вейвлета CWT».

Всем привет, мы снова встретились, я ваш друг Цюаньчжаньцзюнь.

Python реализует «частотно-временную диаграмму EMD\EEMD\VMD+Гильберта» и «частотно-временную диаграмму вейвлета CWT».

  При обработке сигналов часто необходимо анализировать статистику и частотные компоненты во временной области. Однако формы сигналов нестационарных сигналов во временной области часто бывают сложными и неупорядоченными, а частотные компоненты, полученные с помощью преобразования Фурье, представляют собой средние частоты в течение периода времени, что составляет невозможно проанализировать частоту изменения во времени изменяющихся обстоятельств. Впоследствии один за другим появились методы частотно-временного анализа, такие как кратковременное преобразование Фурье (STFT), вейвлет-преобразование (WT) и преобразование Гильберта (HHT).   в,STFTЗависит от временного окна、WT необходимо выбрать вейвлет самостоятельно、HHTСигнал необходимо заранее разложить на стационарный сигнал во время преобразования.。Поскольку существуют толькоCWTВейвлет-частотно-временная диаграммаpythonкод,Для их сравнения автор собрал коды разных алгоритмов декомпозиции + частотно-временную диаграмму Гильберта.

моделируемый сигнал

 Постройте сигнал, частота которого меняется со временем следующим образом:

Язык кода:javascript
копировать
#Создаем тестовый сигнал
import nump as np
Fs=1000   #частота выборки
t = np.arange(0, 1.0, 1.0 / Fs)
f1,f2,f3 = 100,200,300
signal = np.piecewise(t, [t < 1, t < 0.8, t < 0.3],
[lambda t: np.sin(2 * np.pi * f1 * t), lambda t: np.sin(2 * np.pi * f2 * t),
lambda t: np.sin(2 * np.pi * f3 * t)])                       #моделируемый сигнал1

ˆДиаграмма формы сигнала исходного сигнала во временной области:

Из исходной диаграммы спектра сигнала видно, что частотные составляющие включают в себя 100, 200 и 300 Гц, однако неизвестно, когда появятся эти частоты:

1. Разложение EMD\EEMD\VMD + частотно-временная диаграмма Гильберта

Эмпирическая модовая декомпозиция (EMD) была предложена Гильбертом. Ее цель - разложить нестационарные сигналы на стационарные компоненты IMF. Однако ее недостатки, такие как «эффект конечной точки» и «модальное совмещение», очевидны. На его основе интегрированная эмпирическая модовая декомпозиция (EEMD) добавляет перед разложением EMD различные гауссовские белые шумы, что в определенной степени подавляет «модальное наложение спектров», но увеличивает вычислительные затраты. Вариационная модовая декомпозиция (VMD) может реализовать адаптивную сегментацию каждого компонента в частотной области сигнала, но для нее необходимо указать такие параметры, как количество мод K. Вы можете изучить конкретные принципы самостоятельно. Все коды в этой статье основаны на Python 3.9. Для разложения EMD\EEMD используется набор инструментов PyEMD (обратите внимание! Для разложения VMD используется код vmdpy на GitHub). fftlw — это код быстрого преобразования Фурье, написанный автором. предыдущий пост в блоге. Загрузите его самостоятельно. Функциональный код разложения EMD\EEMD\VMD + частотно-временная диаграмма Гильберта выглядит следующим образом. Вам нужно только изменить метод при вызове decompose_lw(), чтобы перейти к другим методам разложения:

Язык кода:javascript
копировать
# -*- coding: utf-8 -*-
""" Created on Fri Dec 17 21:18:48 2021 @author: lw """
import matplotlib.pyplot as plt
import numpy as np
from PyEMD import EEMD,EMD,Visualisation
from scipy.signal import hilbert
# from fftlw import fftlw
from vmdpy import VMD
#Метод декомпозиции (emd, eemd, vmd)
def decompose_lw(signal,t,method='eemd',K=5,draw=1):
names=['emd','eemd','vmd']
idx=names.index(method)
#emd разложение
if idx==0:
emd = EMD()
IMFs= emd.emd(signal)
#vmddecomposition
elif idx==2:
alpha = 2000       # moderate bandwidth constraint
tau = 0.            # noise-tolerance (no strict fidelity enforcement)
DC = 0             # no DC part imposed
init = 1           # initialize omegas uniformly
tol = 1e-7
# Run actual VMD code
IMFs, _, _ = VMD(signal, alpha, tau, K, DC, init, tol)
#eeemd разложение
else:
eemd = EEMD()
emd = eemd.EMD
emd.extrema_detection="parabol"
IMFs= eemd.eemd(signal,t)
#визуализация
if draw==1:
plt.figure()
for i in range(len(IMFs)):
plt.subplot(len(IMFs),1,i+1)
plt.plot(t,IMFs[i])
if i==0:
plt.rcParams['font.sans-serif']='Times New Roman'
plt.title('Decomposition Signal',fontsize=14)
elif i==len(IMFs)-1:
plt.rcParams['font.sans-serif']='Times New Roman'
plt.xlabel('Time/s')
# plt.tight_layout()
return IMFs       
#Преобразование Гильберта и рисование временного спектра
def hhtlw(IMFs,t,f_range=[0,500],t_range=[0,1],ft_size=[128,128],draw=1):
fmin,fmax=f_range[0],f_range[1]         #Диапазон частот, отображаемый частотно-временной диаграммой
tmin,tmax=t_range[0],t_range[1]         #диапазон времени
fdim,tdim=ft_size[0],ft_size[1]         #Размер (разрешение) частотно-временного графика
dt=(tmax-tmin)/(tdim-1)
df=(fmax-fmin)/(fdim-1)
vis = Visualisation()
#hilbertchange
c_matrix=np.zeros((fdim,tdim))
for imf in IMFs:
imf=np.array([imf])
#Находим мгновенную частоту
freqs = abs(vis._calc_inst_freq(imf, t, order=False, alpha=None))
#Находим мгновенную амплитуду
amp= abs(hilbert(imf))
#Удалить размерность 1
freqs=np.squeeze(freqs)
amp=np.squeeze(amp)
#Преобразовать в матрицу
temp_matrix=np.zeros((fdim,tdim))
n_matrix=np.zeros((fdim,tdim))
for i,j,k in zip(t,freqs,amp):
if i>=tmin and i<=tmax and j>=fmin and j<=fmax:
temp_matrix[round((j-fmin)/df)][round((i-tmin)/dt)]+=k
n_matrix[round((j-fmin)/df)][round((i-tmin)/dt)]+=1
n_matrix=n_matrix.reshape(-1)
idx=np.where(n_matrix==0)[0]
n_matrix[idx]=1
n_matrix=n_matrix.reshape(fdim,tdim)
temp_matrix=temp_matrix/n_matrix
c_matrix+=temp_matrix
t=np.linspace(tmin,tmax,tdim)
f=np.linspace(fmin,fmax,fdim)
#визуализация
if draw==1:
fig,axes=plt.subplots()
plt.rcParams['font.sans-serif']='Times New Roman'
plt.contourf(t, f, c_matrix,cmap="jet")
plt.xlabel('Time/s',fontsize=16)
plt.ylabel('Frequency/Hz',fontsize=16)
plt.title('Hilbert spectrum',fontsize=20)
x_labels=axes.get_xticklabels()
[label.set_fontname('Times New Roman') for label in x_labels]
y_labels=axes.get_yticklabels()
[label.set_fontname('Times New Roman') for label in y_labels]
# plt.show()
return t,f,c_matrix
#%%Тестовая функция
if __name__=='__main__':
#Создаем тестовый сигнал
Fs=1000   #частота выборки
t = np.arange(0, 1.0, 1.0 / Fs)
f1,f2,f3 = 100,200,300
signal = np.piecewise(t, [t < 1, t < 0.8, t < 0.3],
[lambda t: np.sin(2 * np.pi * f1 * t), lambda t: np.sin(2 * np.pi * f2 * t),
lambda t: np.sin(2 * np.pi * f3 * t)])                       #моделируемый сигнал1
# signal = 3*np.sin(2*np.pi*f1*t)+6*np.sin(2*np.pi*f2*t)+5*np.sin(2*np.pi*f3*t) #моделируемый сигнал2
# signal = 3*t*np.sin(2*np.pi*f1*t) #моделируемый сигнал3
#рисовать диаграмму во временной области
plt.figure()
plt.plot(t,signal)
plt.rcParams['font.sans-serif']='Times New Roman'
plt.xlabel('Time/s',fontsize=16)
plt.title('Original Signal',fontsize=20) plt.show()
#рисованиемоделируемый сигнальная спектрограмма
# _,_=fftlw(Fs,signal,1)
IMFs=decompose_lw(signal,t,method='vmd',K=10)                                    #сигнал разложения
tt,ff,c_matrix=hhtlw(IMFs,t,f_range=[0,500],t_range=[0,1],ft_size=[128,128])     #drawhilbertspectrum

а. Разложение EMD + частотно-временная диаграмма Гильберта.

Из компонента IMF, полученного путем разложения EMD, видно, что компонент 1 имеет модальное наложение:

 Частотно-временная диаграмма:

б. Разложение EEMD + частотно-временная диаграмма Гильберта.

Из компонента IMF, полученного путем разложения EEMD, видно, что компонент 1 все еще имеет модальный псевдоним:

 Частотно-временная диаграмма, по сравнению с EMD, 300Гц более концентрированная:

c. Разложение VMD + частотно-временная диаграмма Гильберта.

Компонент IMF, полученный путем разложения VMD, по умолчанию установлен на 10. Видно, что компоненты 100, 200 и 300 Гц могут быть в основном точно разделены, но эффект конечной точки все еще существует:

  Частотно-временная диаграмма, частотные компоненты более концентрированы и эффект лучше:

2. Частотно-временная диаграмма вейвлета CWT

 Непрерывная вейвлет-временно-частотная диаграмма представляет собой перепечатку статьи Зижиху.

Рисование частотно-временного графика непрерывного вейвлет-преобразования (CWT) реализация на Python

Язык кода:javascript
копировать
# -*- coding: utf-8 -*-
""" Created on Fri Dec 17 20:17:42 2021 @author: lw """
import matplotlib.pyplot as plt
import numpy as np
import pywt
# from matplotlib.font_manager import FontProperties
# chinese_font = FontProperties(fname='/usr/share/fonts/truetype/wqy/wqy-microhei.ttc')
sampling_rate = 1000
t = np.arange(0, 1.0, 1.0 / sampling_rate)
f1 = 100
f2 = 200
f3 = 300
data = np.piecewise(t, [t < 1, t < 0.8, t < 0.3],
[lambda t: np.sin(2 * np.pi * f1 * t), lambda t: np.sin(2 * np.pi * f2 * t),
lambda t: np.sin(2 * np.pi * f3 * t)])
wavename = 'cgau8'
totalscal = 256
fc = pywt.central_frequency(wavename)
cparam = 2 * fc * totalscal
scales = cparam / np.arange(totalscal, 1, -1)
[cwtmatr, frequencies] = pywt.cwt(data, scales, wavename, 1.0 / sampling_rate)
plt.figure(figsize=(8, 8))
plt.subplot(211)
plt.plot(t, data)
# plt.xlabel(u"Время (секунды)", fontproperties=chinese_font)
# plt.title(u"Сегментированные сигналы и временной спектр 300 Гц, 200 Гц и 100 Гц", fontproperties=chinese_font, fontsize=20)
plt.subplot(212)
plt.contourf(t, frequencies, abs(cwtmatr))
# plt.ylabel(u"частота (Гц)", fontproperties=chinese_font)
# plt.xlabel(u"Время (секунды)", fontproperties=chinese_font)
plt.subplots_adjust(hspace=0.4)
plt.tight_layout()
plt.show()

Исходный сигнал и частотно-временная диаграмма выглядят следующим образом. Видно, что частотные составляющие вейвлет-разложения относительно разбросаны, а амплитуда (цвет) несколько несовместима. Теоретически цвета 100, 200 и 300 Гц. должно быть одинаково ярким:

Заявление об авторских правах: Содержание этой статьи добровольно предоставлено пользователями Интернета, а мнения, выраженные в этой статье, представляют собой только точку зрения автора. Этот сайт предоставляет только услуги по хранению информации, не имеет никаких прав собственности и не принимает на себя соответствующие юридические обязательства. Если вы обнаружите на этом сайте какое-либо подозрительное нарушение авторских прав/незаконный контент, отправьте электронное письмо, чтобы сообщить. После проверки этот сайт будет немедленно удален.

Издатель: Full stack программист - пользователь IM, укажите источник для перепечатки: https://javaforall.cn/231289.html Исходная ссылка: https://javaforall.cn

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose