Пакетный метод вейвлета является обобщением разложения вейвлета, которое предлагает более богатый анализ сигнала.
Пакетные атомы вейвлета являются формами волны, индексированными тремя естественно интерпретированными параметрами: положение, шкала (как в разложении вейвлета), и частота.
Для данной ортогональной функции вейвлета мы генерируем библиотеку названных пакетных основ вейвлета основ. Каждая из этих основ предлагает конкретный способ закодировать сигналы, сохраняя глобальную энергию, и восстанавливая точные функции. Пакеты вейвлета могут использоваться для многочисленных расширений данного сигнала. Мы затем выбираем самое подходящее разложение данного сигнала относительно основанного на энтропии критерия.
Там существуйте простые и эффективные алгоритмы и для пакетного разложения вейвлета и для оптимального выбора разложения. Мы можем затем произвести адаптивные алгоритмы фильтрации с прямыми приложениями в оптимальном кодировании сигнала и сжатии данных.
В ортогональной процедуре разложения вейвлета типовой шаг разделяет коэффициенты приближения в две части. После разделения мы получаем вектор из коэффициентов приближения и вектор из коэффициентов детали, обоих в более грубой шкале. Информация, потерянная между двумя последовательными приближениями, получена в коэффициентах детали. Затем следующий шаг состоит из разделения нового вектора коэффициентов приближения; последовательные детали никогда не повторно анализируются.
В соответствующей пакетной ситуации с вейвлетом каждый вектор коэффициентов детали также разложен на две части с помощью того же подхода в качестве в разделении вектора приближения. Это предлагает самый богатый анализ: полное двоичное дерево производится как показано в следующем рисунке.
Пакетное дерево разложения вейвлета на уровне 3
Идея этого разложения состоит в том, чтобы начать с ориентированного на шкалу разложения, и затем анализировать полученные сигналы на поддиапазонах частоты.
Следующие простые примеры иллюстрируют определенные различия между анализом вейвлета и пакетным анализом вейвлета.
Спектральный анализ широкого смысла стационарные сигналы с помощью преобразования Фурье известен. Для неустановившихся сигналов там существуйте локальные методы Фурье, такие как кратковременное преобразование Фурье (STFT). Смотрите Кратковременное преобразование Фурье для краткого описания.
Поскольку вейвлеты локализуются вовремя и частота, возможно использовать основанные на вейвлете дубликаты для STFT для частотно-временного анализа неустановившихся сигналов. Например, возможно создать scalogram (wscalogram
) на основе непрерывного вейвлета преобразовывает (CWT). Однако потенциальный недостаток использования CWT - то, что это в вычислительном отношении дорого.
Дискретный вейвлет преобразовывает (DWT) разрешает разложение частоты времени входного сигнала, но степень разрешения частоты в DWT обычно рассматривается слишком крупной для практического частотно-временного анализа.
Как компромисс между DWT-и основанными на CWT методами, пакеты вейвлета предоставляют в вычислительном отношении эффективной альтернативе достаточное разрешение частоты. Можно использовать wpspectrum
выполнять частотно-временной анализ вашего сигнала с помощью пакетов вейвлета.
Следующие примеры иллюстрируют использование пакетов вейвлета, чтобы выполнить локальный спектральный анализ. Следующие примеры также используют spectrogram
(Signal Processing Toolbox) из программного обеспечения Signal Processing Toolbox™ как сравнительный тест, чтобы выдержать сравнение с пакетным спектром вейвлета. Если у вас нет программного обеспечения Signal Processing Toolbox, можно просто запустить пакетные примеры спектра вейвлета.
Пакетный спектр вейвлета синусоиды.
fs = 1000; % sampling rate t = 0:1/fs:2; % 2 secs at 1kHz sample rate y = sin(256*pi*t); % sine of period 128 level = 6; wpt = wpdec(y,level,'sym8'); [Spec,Time,Freq] = wpspectrum(wpt,fs,'plot');
Если у вас есть программное обеспечение Signal Processing Toolbox, можно вычислить кратковременное преобразование Фурье.
figure; windowsize = 128; window = hanning(windowsize); nfft = windowsize; noverlap = windowsize-1; [S,F,T] = spectrogram(y,window,noverlap,nfft,fs); imagesc(T,F,log10(abs(S))) set(gca,'YDir','Normal') xlabel('Time (secs)') ylabel('Freq (Hz)') title('Short-time Fourier Transform spectrum')
Сумма двух синусоид с частотами 64 и 128 герц.
fs = 1000; t = 0:1/fs:2; y = sin(128*pi*t) + sin(256*pi*t); % sine of periods 64 and 128. level = 6; wpt = wpdec(y,level,'sym8'); [Spec,Time,Freq] = wpspectrum(wpt,fs,'plot');
Если у вас есть программное обеспечение Signal Processing Toolbox, можно вычислить кратковременное преобразование Фурье.
figure; windowsize = 128; window = hanning(windowsize); nfft = windowsize; noverlap = windowsize-1; [S,F,T] = spectrogram(y,window,noverlap,nfft,fs); imagesc(T,F,log10(abs(S))) set(gca,'YDir','Normal') xlabel('Time (secs)') ylabel('Freq (Hz)') title('Short-time Fourier Transform spectrum')
Сигнал с резким изменением в частоте от 16 до 64 герц в две секунды.
fs = 500; t = 0:1/fs:4; y = sin(32*pi*t).*(t<2) + sin(128*pi*t).*(t>=2); level = 6; wpt = wpdec(y,level,'sym8'); [Spec,Time,Freq] = wpspectrum(wpt,fs,'plot');
Если у вас есть программное обеспечение Signal Processing Toolbox, можно вычислить кратковременное преобразование Фурье.
figure; windowsize = 128; window = hanning(windowsize); nfft = windowsize; noverlap = windowsize-1; [S,F,T] = spectrogram(y,window,noverlap,nfft,fs); imagesc(T,F,log10(abs(S))) set(gca,'YDir','Normal') xlabel('Time (secs)') ylabel('Freq (Hz)') title('Short-time Fourier Transform spectrum')
Пакетный спектр вейвлета линейного щебета.
fs = 1000; t = 0:1/fs:2; y = sin(256*pi*t.^2); level = 6; wpt = wpdec(y,level,'sym8'); [Spec,Time,Freq] = wpspectrum(wpt,fs,'plot');
Если у вас есть программное обеспечение Signal Processing Toolbox, можно вычислить кратковременное преобразование Фурье.
figure; windowsize = 128; window = hanning(windowsize); nfft = windowsize; noverlap = windowsize-1; [S,F,T] = spectrogram(y,window,noverlap,nfft,fs); imagesc(T,F,log10(abs(S))) set(gca,'YDir','Normal') xlabel('Time (secs)') ylabel('Freq (Hz)') title('Short-time Fourier Transform spectrum')
Пакетный спектр вейвлета квадратичного щебета.
y = wnoise('quadchirp',10); len = length(y); t = linspace(0,5,len); fs = 1/t(2); level = 6; wpt = wpdec(y,level,'sym8'); [Spec,Time,Freq] = wpspectrum(wpt,fs,'plot');
Если у вас есть программное обеспечение Signal Processing Toolbox, можно вычислить кратковременное преобразование Фурье.
windowsize = 128; window = hanning(windowsize); nfft = windowsize; noverlap = windowsize-1; imagesc(T,F,log10(abs(S))) set(gca,'YDir','Normal') xlabel('Time (secs)') ylabel('Freq (Hz)') title('Short-time Fourier Transform spectrum')
Схема расчета пакетной генерации вейвлета легка при использовании ортогонального вейвлета. Мы начинаем с двух фильтров длины 2N, где h (n)
и g (n)
, соответствуйте вейвлету.
Теперь индукцией позволяют нам задать следующую последовательность функций:
(W n (x), n = 0, 1, 2...)
где W 0(x)
= φ(x)
масштабирующаяся функция и W 1(x)
= ψ(x)
функция вейвлета.
Например, для вейвлета Хаара мы имеем
и
Уравнения становятся
и
W 0(x)
= φ(x)
Хаар, масштабирующий функцию и W 1(x)
= ψ(x)
вейвлет Хаара, оба поддержанные в [0, 1]. Затем мы можем получить W 2n путем добавления два 1/2-scaled версии Wn с отличными поддержками [0,1/2] и [1/2,1] и получить W 2n+1 путем вычитания тех же версий Wn.
Для n = от 0 до 7, у нас есть W - функции показанные на рисунке Пакеты Вейвлета Хаара.
Пакеты вейвлета Хаара
Это может быть получено используя следующую команду:
[wfun,xgrid] = wpfun('db1',7,5);
который возвращается в wfun
приближенные значения Wn для n = от 0 до 7, вычисленный на 1/25 сетка поддержки xgrid
.
Начиная с более регулярных исходных вейвлетов и использования подобной конструкции, мы получаем сглаживавшие версии этой системы W - функции, все с поддержкой в интервале [0, 2N–1]. Пакеты Вейвлета фигуры db2 представляют систему W - функционирует для исходного db2
вейвлет.
Пакеты Вейвлета db2
Запуск с функций и после того же продвижения линии к ортогональным вейвлетам, мы рассматриваем трехиндексируемое семейство анализа функций (формы волны):
где n ∊N и (j, k) ∊Z2.
Как в среде вейвлета, k может быть интерпретирован как параметр локализации времени и j как масштабный коэффициент. Таким образом, какова интерпретация n?
Основная идея о пакетах вейвлета состоит в том, что для фиксированных значений j и k, Wj,n,k анализирует колебания сигнала примерно вокруг положения 2j· k, в шкале 2j и на различных частотах для различных допустимых значений последнего параметра n.
На самом деле, исследуя тщательно пакеты вейвлета, отображенные в Пакетах Вейвлета Хаара и db2 Пакетах Вейвлета, естественно упорядоченный Wn для n = 0, 1..., 7, не совпадает точно с порядком, заданным количеством колебаний. Более точно, считая количество нулевых пересечений (-пересечения и вниз-пересечения) для db1
пакеты вейвлета, у нас есть следующее.
Так, чтобы восстановить свойство, которое основная частота увеличивает монотонно с порядком, удобно задать порядок частоты, полученный из естественного рекурсивно.
Как видно на предыдущих рисунках, Wr (n) (x)
“колеблется” приблизительно времена n.
Чтобы анализировать сигнал (щебет Примера 2, например), лучше построить пакетные коэффициенты вейвлета, выполняющие приказ частоты от низких частот в нижней части к высоким частотам наверху, а не естественно упорядоченные коэффициенты.
При графическом выводе коэффициентов различные варианты, связанные с “Частотой” или “Естественным” выбором порядка, являются доступным использованием приложения Wavelet Analyzer.
Эти опции также доступны от режима командной строки при использовании wpviewcf
функция.
Набор функций W j, n = (Wj,n,k(x),k∊Z)
(j, n) пакет вейвлета. Для положительных значений целых чисел j и n, пакеты вейвлета организованы в деревьях. Дерево в Пакетах Вейвлета фигуры, Организованных в Дереве; Масштабируйтесь j Задает Глубину, и Частота n Задает Положение в Дереве, создается, чтобы дать разложение максимального уровня, равное 3. Для каждой шкалы j возможные значения параметра n 0, 1..., 2j–1.
Пакеты вейвлета, Организованные в Дереве; Масштабируйтесь j Задает Глубину, и Частота n Задает Положение в Дереве
Обозначение Wj,n, где j обозначает масштабный коэффициент и n параметр частоты, сопоставимо с обычной позиционной глубиной древовидной маркировкой.
Мы имеем , и .
Оказывается, что библиотека пакетных основ вейвлета содержит базис вейвлета и также несколько других основ. Давайте взглянем на некоторые из тех основ. Более точно позвольте V 0, обозначают пробел (заполненный семейством W 0,0), в котором находится сигнал анализироваться; затем (W d, 1; d ≥ 1) является ортогональным базисом V 0.
Для каждого строго положительного целочисленного D, (W D, 0, (W d, 1; 1 ≤ d ≤ D)), ортогональный базис V 0.
Мы также знаем, что семейство функций {(Wj +1,2n), (Wj +1,2n+1)} является ортогональным базисом пробела, заполненного Wj,n, который разделен в два подпространства: Wj +1,2n охватывает первое подпространство и Wj +1,2n+1 второй.
Это последнее свойство дает точную интерпретацию разделения в пакетном организационном дереве вейвлета, потому что все разработанные узлы имеют форму показанное на рисунке Пакетное Дерево Вейвлета: Разделите и Слияние.
Из этого следует, что листы каждого связанного бинарного поддерева полного дерева соответствуют ортогональному базису начального пробела.
Для конечного энергетического сигнала, принадлежащего V 0, любой пакетный базис вейвлета обеспечит точную реконструкцию и предложит особенный метод кодирования сигнала, с помощью информационного выделения в поддиапазонах шкалы частоты.
На основе организации пакетной библиотеки вейвлета естественно считать разложения выпущенными от данного ортогонального вейвлета.
Сигнал длины N = 2L может быть расширен α различными способами, где α является количеством бинарных поддеревьев полного двоичного дерева глубины L. В результате (см. страницу 323 [Mal98]).
Когда этот номер может быть очень большим, и поскольку явное перечисление обычно неуправляемо, интересно найти оптимальное разложение относительно удобного критерия, вычислимого эффективным алгоритмом. Мы ищем минимум критерия.
Функции, проверяющие свойство типа аддитивности, хорошо подходят для эффективного поиска структур двоичного дерева и основного разделения. Классические основанные на энтропии критерии совпадают с этими условиями и описывают информационно-связанные свойства для точного представления данного сигнала. Энтропия является общей концепцией во многих полях, в основном в обработке сигналов. Давайте перечислим четыре различных энтропийных критерия (см. [CoiW92]); многие другие доступны и могут быть легко интегрированы (введите help
wentropy
). В следующих выражениях s является сигналом, и (si) коэффициенты s в ортонормированном базисе.
Энтропийный E должен быть аддитивной функцией стоимости, таким образом что E (0) = 0 и
(Ненормированная) шенноновская энтропия
так
с соглашением 0log (0) = 0.
Концентрация в lp норма с 1 ℜ ≤ p
так
Логарифм “энергетической” энтропии
так
с журналом соглашения (0) = 0.
Пороговая энтропия
если и 0 в другом месте, таким образом, E 4 (s) = # {i, таким образом, что } номер моментов времени, когда сигнал больше порога ε.
Эти энтропийные функции являются доступным использованием wentropy
файл.
Сгенерируйте сигнал энергии, равной 1.
s = ones(1,16)*0.25;
Вычислите шенноновскую энтропию s.
e1 = wentropy(s,'shannon') e1 = 2.7726
Вычислите l1.5 энтропия s, эквивалентного norm(s,1.5)
1.5.
e2 = wentropy(s,'norm',1.5) e2 = 2
Вычислите “логарифмическую энергетическую энтропию” s.
e3 = wentropy(s,'log energy') e3 = -44.3614
Вычислите пороговую энтропию s с помощью порогового значения 0,24.
e4 = wentropy(s,'threshold', 0.24) e4 = 16
Этот простой пример иллюстрирует использование энтропии, чтобы определить, представляет ли новое разделение интерес получить минимально-энтропийное разложение.
Мы начинаем с постоянного исходного сигнала. Два данных достаточны, чтобы задать и восстановить сигнал (i.e., длина и постоянное значение).
w00 = ones(1,16)*0.25;
Вычислите энтропию исходного сигнала.
e00 = wentropy(w00,'shannon') e00 = 2.7726
Затем разделите w00
использование вейвлета Хаара.
[w10,w11] = dwt(w00,'db1');
Вычислите энтропию приближения на уровне 1.
e10 = wentropy(w10,'shannon') e10 = 2.0794
Деталь уровня 1, w11
, нуль; энтропийный e11
нуль. Из-за свойства аддитивности энтропия разложения дана e10+e11=2.0794
. Это должно сравниться с начальным энтропийным e00=2.7726
. У нас есть e10 + e11 < e00
, таким образом, разделение интересно.
Теперь разделите w10
(не w11
потому что разделение пустого вектора без интереса, поскольку энтропия является нулем).
[w20,w21] = dwt(w10,'db1');
У нас есть w20=0.5*ones(1,4)
и w21
нуль. Энтропия уровня 2 приближения
e20 = wentropy(w20,'shannon') e20 = 1.3863
Снова у нас есть e20 + 0 < e10
, так разделение делает энтропийное уменьшение.
То
[w30,w31] = dwt(w20,'db1'); e30 = wentropy(w30,'shannon') e30 = 0.6931 [w40,w41] = dwt(w30,'db1') w40 = 1.0000 w41 = 0 e40 = wentropy(w40,'shannon') e40 = 0
В последней операции разделения мы находим, что только одни данные необходимы, чтобы восстановить исходный сигнал. Базисом вейвлета на уровне 4 является лучший базис согласно шенноновской энтропии (с пустой оптимальной энтропией начиная с e40+e41+e31+e21+e11 = 0
).
Выполните пакетное разложение вейвлета s сигнала, заданного в примере 1.
t = wpdec(s,4,'haar','shannon');
Пакетное дерево вейвлета в Энтропийных Значениях показывает узлы, помеченные исходными энтропийными числами.
Энтропийные значения
Вычислите лучшее дерево.
bt = besttree(t);
Лучшее дерево показывают в следующем рисунке. В этом случае лучшее дерево соответствует дереву вейвлета. Узлы помечены оптимальной энтропией.
Оптимальные энтропийные значения
Используя вейвлет пакеты требует связанных с деревом действий и маркировки. Реализация пользовательского интерфейса создается вокруг этого фактора. Для получения дополнительной информации о технических деталях смотрите страницы с описанием.
Полное двоичное дерево глубины D, соответствующий пакетному дереву разложения вейвлета, разработанному на уровне D, обозначается WPT.
У нас есть следующие интересные поддеревья.
Дерево разложения | Поддерево, таким образом, что набором листов является базис |
---|---|
Пакетное дерево разложения вейвлета | Полное двоичное дерево: WPT глубины D |
Пакеты вейвлета оптимальное дерево разложения | Бинарное поддерево WPT |
Пакетное дерево лучшего уровня вейвлета | Завершите бинарное поддерево WPT |
Дерево разложения вейвлета | Оставленное одностороннее бинарное поддерево WPT глубины D |
Дерево лучшего базиса вейвлета | Оставленное одностороннее бинарное поддерево WPT |
Мы выводим следующие определения оптимальных разложений относительно энтропийного критерия E.
Разложения | Оптимальное разложение | |
---|---|---|
Пакетные разложения вейвлета | Поиск среди 2D деревья | Поиск среди деревьев D |
Разложения вейвлета | Поиск среди деревьев D | Поиск среди деревьев D |
Для любого нетерминального узла мы используем выполняющий основной шаг, чтобы найти оптимальное поддерево относительно данного энтропийного критерия E (где Eopt обозначает оптимальное энтропийное значение).
Энтропийное условие | Действие с деревом и с энтропийной маркировкой |
---|---|
| Если (node≠root), слияние и набор Eopt (node) = E (node) |
Разделите и установите |
с естественным начальным условием на ссылочном дереве, Eopt (t)
= E (t)
для каждого терминального узла t.
Можно использовать функцию wprcoef
восстановить приближение к вашему сигналу от любого узла в пакетном дереве вейвлета. Это верно независимо от того, работаете ли вы с полным пакетным деревом вейвлета или поддеревом, определенным критерием оптимальности. Использование wpcoef
если вы хотите извлечь пакетные коэффициенты вейвлета из узла, не восстанавливая приближение к сигналу.
Загрузите шумный Доплеровский сигнал.
load noisdopp
Вычислите пакетное разложение вейвлета вниз к уровню 5 с помощью sym4
вейвлет. Используйте periodization режим.
dwtmode('per'); T = wpdec(noisdopp,5,'sym4'); plot(T)
Постройте бинарное пакетное дерево вейвлета и нажмите (4,1) копия (узел 16).
Извлеките пакетные коэффициенты вейвлета из узла 16.
wpc = wpcoef(T,16); % wpc is length 64
Получите приближение к сигналу от узла 16.
rwpc = wprcoef(T,16); % rwpc is length 1024 plot(noisdopp,'k'); hold on; plot(rwpc,'b','linewidth',2); axis tight;
Определите оптимальное бинарное пакетное дерево вейвлета.
Topt = besttree(T); % plot the best tree plot(Topt)
Восстановите приближение к сигналу от (3,0) копия (узел 7).
rsig = wprcoef(Topt,7); % rsig is length 1024 plot(noisdopp,'k'); hold on; plot(rsig,'b','linewidth',2); axis tight;
Если вы знаете, какую копию в бинарном пакетном дереве вейвлета вы хотите извлечь, можно определить узел, соответствующий той копии с depo2ind
.
Например, чтобы определить узел, соответствующий копии (3,0), введите:
Node = depo2ind(2,[3 0]);
Точно так же, как в случае разложения вейвлета, предыдущая 1D среда может быть расширена к анализу изображения. Незначительные прямые модификации приводят к четверичным связанным с деревом определениям. Примеру показывают следующую фигуру для глубины 2.
Четвертичное дерево глубины 2
В пакетной среде вейвлета сжатие и идеи шумоподавления идентичны разработанным в среде вейвлета. Единственной новой возможностью является более полный анализ, который обеспечивает увеличенную гибкость. Одно разложение с помощью пакетов вейвлета генерирует большое количество основ. Можно затем искать лучшее представление относительно цели проекта, с помощью besttree
с энтропийной функцией.