Haar-Wavelet

Haar-Wavelet

Das Haar-Wavelet ist das erste in der Literatur bekannt gewordene Wavelet und wurde 1909 von Alfréd Haar eingeführt.[1] Es ist außerdem das einfachste bekannte Wavelet und kann aus der Kombination zweier Rechteckfunktionen gebildet werden.

Vorteilhaft am Haar-Wavelet ist die einfache Implementierbarkeit der zugehörigen Wavelet-Transformation als schnelle Wavelet-Transformation (FWT). Der Nachteil des Haar-Wavelets ist, dass es unstetig und daher auch nicht differenzierbar ist.

Die Funktionen der Haar-Wavelet-Basis

Skalierungsfunktion

Die Skalierungsfunktion bzw. „Vater-Wavelet“-Funktion der Haar-Wavelet-Basis ist die Indikatorfunktion des Intervalls [ 0 , 1 ) {\displaystyle [0,1)} .

ϕ ( x ) = χ [ 0 , 1 ) ( x ) = { 1 0 x < 1 0 sonst {\displaystyle \phi (x)=\chi _{[0,1)}(x)={\begin{cases}1&0\leq x<1\\0&{\mbox{sonst}}\end{cases}}}

Sie erfüllt die Funktionalgleichung

ϕ ( x ) = ϕ ( 2 x ) + ϕ ( 2 x 1 ) = 2 ( a 0 ϕ ( 2 x ) + a 1 ϕ ( 2 x 1 ) ) {\displaystyle \phi (x)=\phi (2x)+\phi (2x-1)={\sqrt {2}}\left(a_{0}\phi (2x)+a_{1}\phi (2x-1)\right)} mit a 0 = a 1 = 1 2 {\displaystyle a_{0}=a_{1}={\frac {1}{\sqrt {2}}}} .

Waveletfunktion

Die Waveletfunktion ist die „zusammengeschobene“ Differenz zweier aufeinanderfolgender Skalierungsfunktionen:

ψ ( x ) = ϕ ( 2 x ) ϕ ( 2 x 1 ) = 2 ( b 0 ϕ ( 2 x ) + b 1 ϕ ( 2 x 1 ) ) = { 1 0 x < 1 / 2 1 1 / 2 x < 1 0 sonst {\displaystyle \psi (x)=\phi (2x)-\phi (2x-1)={\sqrt {2}}\left(b_{0}\phi (2x)+b_{1}\phi (2x-1)\right)={\begin{cases}1&0\leq x<1/2\\-1&1/2\leq x<1\\0&{\mbox{sonst}}\end{cases}}} ,

wobei ( b 0 , b 1 ) = ( 1 2 , 1 2 ) {\displaystyle (b_{0},b_{1})=({\tfrac {1}{\sqrt {2}}},-{\tfrac {1}{\sqrt {2}}})} .

Die Schreibweise mit Vorfaktor sorgt dafür, dass die Matrix

H = ( a 0 a 1 b 0 b 1 ) = 1 2 ( 1 1 1 1 ) {\displaystyle H={\begin{pmatrix}a_{0}&a_{1}\\b_{0}&b_{1}\end{pmatrix}}={\frac {1}{\sqrt {2}}}\,{\begin{pmatrix}1&1\\1&-1\end{pmatrix}}}

eine orthogonale Matrix ist. Dies ist Teil der Bedingungen, die orthogonale Wavelets erfordern.

Multiskalenanalyse

Diese Funktion erzeugt die Multiskalenanalyse der Stufenfunktionen. In dieser wird jeder Funktion f L 2 ( R ) {\displaystyle f\in L^{2}(\mathbb {R} )} mit „endlicher Energie“ auf jeder Skala J Z {\displaystyle J\in \mathbb {Z} } die folgende Projektion zugewiesen:

f P J ( f ) {\displaystyle f\mapsto P_{J}(f)} mit P J ( f ) ( x ) = n Z ( 0 1 f ( 2 J ( n + t ) ) d t ) ϕ ( 2 J x n ) {\displaystyle P_{J}(f)(x)=\sum _{n\in \mathbb {Z} }\left(\int _{0}^{1}f\left(2^{-J}(n+t)\right)\,\mathrm {d} t\right)\cdot \phi (2^{J}x-n)} .

Die Differenz zwischen zwei Skalen lässt sich dann durch das „Mutter-Wavelet“ bzw. die eigentliche Waveletfunktion ausdrücken:

P J + 1 ( f ) ( x ) P J ( f ) ( x ) = n Z ( 0 1 f ( 2 J 1 ( 2 n + t ) ) d t 0 1 f ( 2 J 1 ( 2 n + 1 + t ) ) d t ) ψ ( 2 J x n ) {\displaystyle P_{J+1}(f)(x)-P_{J}(f)(x)=\sum _{n\in \mathbb {Z} }\left(\int _{0}^{1}f\left(2^{-J-1}(2n+t)\right)\,\mathrm {d} t-\int _{0}^{1}f\left(2^{-J-1}(2n+1+t)\right)\,\mathrm {d} t\right)\cdot \psi (2^{J}x-n)} .

Mit ϕ j , k ( x ) = 2 j ϕ ( 2 j x k ) {\displaystyle \phi _{j,k}(x)={{\sqrt {2}}\,}^{j}\phi ({2\,}^{j}x-k)} und ψ j , k ( x ) = 2 j ψ ( 2 j x k ) {\displaystyle \psi _{j,k}(x)={{\sqrt {2}}\,}^{j}\psi ({2\,}^{j}x-k)} als Funktionen im Hilbertraum L 2 ( R ) {\displaystyle L^{2}(\mathbb {R} )} gilt

  • alle diese Funktionen haben L 2 {\displaystyle L^{2}} -Norm 1,
  • ϕ j , k {\displaystyle \phi _{j,k}} ist senkrecht zu ϕ j , l {\displaystyle \phi _{j,l}} falls k l {\displaystyle k\not =l} ,
  • ψ i , k {\displaystyle \psi _{i,k}} ist senkrecht zu ψ j , l {\displaystyle \psi _{j,l}} falls i j {\displaystyle i\not =j} oder k l {\displaystyle k\not =l} ,
  • die ψ i , k {\displaystyle \psi _{i,k}} bilden eine Hilbertbasis von L 2 ( R ) {\displaystyle L^{2}(\mathbb {R} )} .

Schnelle Haar-Wavelet-Transformation

Gegeben sei ein diskretes Signal f, welches durch eine endliche oder quadratsummierbare Folge

f = ( , f 2 , f 1 , f 0 , f 1 , f 2 , f 3 , ) {\displaystyle f=(\dots ,f_{-2},f_{-1},f_{0},f_{1},f_{2},f_{3},\dots )}

dargestellt ist. Ihm ist als kontinuierliches Signal die Treppenfunktion

F ( x ) = + f 1 ϕ 0 , 1 ( x ) + f 0 ϕ 0 , 0 ( x ) + f 1 ϕ 0 , 1 ( x ) + f 2 ϕ 0 , 2 ( x ) + {\displaystyle F(x)=\dots +f_{-1}\phi _{0,-1}(x)+f_{0}\phi _{0,0}(x)+f_{1}\phi _{0,1}(x)+f_{2}\phi _{0,2}(x)+\dots }

zugeordnet.

Vorwärtstransformation

Aus dem diskreten Signal wird durch paarweises „Senkrechtstellen“ ein vektorwertiges Signal, die sogenannte Polyphasenzerlegung, erzeugt:

f p = ( , ( f 2 f 1 ) , ( f 0 f 1 ) , ( f 2 f 3 ) , ) {\displaystyle f_{p}=\left(\dots ,\left({f_{-2} \atop f_{-1}}\right),\left({f_{0} \atop f_{1}}\right),\left({f_{2} \atop f_{3}}\right),\dots \right)} .

Dieser wird nun gliedweise mit der Haar-Transformationsmatrix H := 1 2 ( 1 1 1 1 ) {\displaystyle H:={\frac {1}{\sqrt {2}}}{\begin{pmatrix}1&1\\1&-1\end{pmatrix}}} multipliziert

( s d ) =: H f p = ( , ( s 1 d 1 ) , ( s 0 d 0 ) , ( s 1 d 1 ) , ) {\displaystyle \left({s \atop d}\right)=:Hf_{p}=\left(\dots ,\left({s_{-1} \atop d_{-1}}\right),\left({s_{0} \atop d_{0}}\right),\left({s_{1} \atop d_{1}}\right),\dots \right)} ,

dabei ist s k = f 2 k + 1 + f 2 k 2 {\displaystyle s_{k}={\frac {f_{2k+1}+f_{2k}}{\sqrt {2}}}} und d k = f 2 k + 1 f 2 k 2 {\displaystyle d_{k}={\frac {f_{2k+1}-f_{2k}}{\sqrt {2}}}} .

Rücktransformation

Wir erhalten ein Mittelwertsignal s {\displaystyle s} und ein Differenzsignal d {\displaystyle d} , aus denen durch einfache Umkehr der vorgenommenen Schritte das Ausgangssignal zurückgewonnen werden kann:

f 2 k = s k d k 2 {\displaystyle f_{2k}={\frac {s_{k}-d_{k}}{\sqrt {2}}}} und f 2 k + 1 = s k + d k 2 {\displaystyle f_{2k+1}={\frac {s_{k}+d_{k}}{\sqrt {2}}}}

Ist die Schwankung von Glied zu Glied im Ausgangssignal durch ein kleines ϵ > 0 {\displaystyle \epsilon >0} beschränkt, so ist die Schwankung in s {\displaystyle s} durch 2 ϵ {\displaystyle {\sqrt {2}}\epsilon } beschränkt, also immer noch klein, die Größe der Glieder in d {\displaystyle d} jedoch durch ϵ / 2 {\displaystyle \epsilon /{\sqrt {2}}} . Ein glattes Signal wird also in ein immer noch glattes Signal halber Abtastfrequenz und in ein kleines Differenzsignal zerlegt. Dies ist der Ausgangspunkt für die Wavelet-Kompression.

Rekursive Filterbank

Wir können den Vorgang wiederholen, indem wir s zum Ausgangssignal erklären und mit obigem Vorgehen zerlegen, wir erhalten eine Folge von Zerlegungen s 0 := f , ( s 1 , d 1 ) , ( s 2 , d 2 , d 1 ) , , ( s T , d T , , d 2 , d 1 ) {\displaystyle s^{0}:=f,\;(s^{1},d^{1}),\;(s^{2},d^{2},d^{1}),\;\dots ,(s^{T},d^{T},\dots ,d^{2},d^{1})} , s k {\displaystyle s^{k}} hat ein 2 k {\displaystyle 2^{k}} -tel der ursprünglichen Abtastfrequenz und eine durch 2 k / 2 ϵ {\displaystyle 2^{k/2}\epsilon } beschränkte Schwankung, d k {\displaystyle d^{k}} hat ebenfalls ein 2 k {\displaystyle 2^{k}} -tel der ursprünglichen Abtastfrequenz und durch 2 k / 2 ϵ {\displaystyle 2^{-k/2}\epsilon } beschränkte Glieder.

Interpretation

Als diskretes Signal f {\displaystyle f} wird meist eine reelle Folge ( f n ) {\displaystyle (f_{n})} über Z {\displaystyle Z} mit endlicher Energie betrachtet,

n = | f n | 2 < {\displaystyle \sum _{n=-\infty }^{\infty }\,|f_{n}|^{2}<\infty } .

Unter diesen gibt es einige sehr einfache Folgen δn, Kronecker- oder Dirac-Delta genannt, eine für jedes n Z {\displaystyle n\in Z} . Für deren Folgenglieder gilt, dass das jeweils n {\displaystyle n} -te den Wert 1 {\displaystyle 1} hat, δ n n = 1 {\displaystyle \delta ^{n}{}_{n}=1} , und alle anderen den Wert 0 {\displaystyle 0} , δ n k = 0 {\displaystyle \delta ^{n}{}_{k}=0} falls k n {\displaystyle k\not =n} .

Jetzt können wir jedes Signal trivial als Reihe im Signalraum schreiben

f = n = f n δ n {\displaystyle f=\sum _{n=-\infty }^{\infty }\,f_{n}\cdot \delta ^{n}}

oder als Summe zweier Reihen

f = n = f 2 n δ 2 n + n = f 2 n + 1 δ 2 n + 1 {\displaystyle f=\sum _{n=-\infty }^{\infty }\,f_{2n}\cdot \delta ^{2n}+\sum _{n=-\infty }^{\infty }\,f_{2n+1}\cdot \delta ^{2n+1}} .

In vielen praktisch relevanten Signalklassen, z. B. bei überabgetasteten bandbeschränkten kontinuierlichen Signalen, sind Werte benachbarter Folgenglieder auch benachbart, d. h. im Allgemeinen liegen f 2 n {\displaystyle f_{2n}} und f 2 n + 1 {\displaystyle f_{2n+1}} dicht beisammen, relativ zu ihrem Absolutbetrag. Dies wird in der obigen Reihen aber überhaupt nicht berücksichtigt. In Mittelwert und Differenz von f 2 n {\displaystyle f_{2n}} und f 2 n + 1 {\displaystyle f_{2n+1}} käme deren Ähnlichkeit stärker zum Ausdruck, der Mittelwert ist beiden Werten ähnlich und die Differenz klein. Benutzen wir die Identität

a c + b d = 1 2 ( a + b ) ( c + d ) + 1 2 ( a b ) ( c d ) {\displaystyle ac+bd={\frac {1}{2}}(a+b)(c+d)+{\frac {1}{2}}(a-b)(c-d)}

um benachbarte Glieder der ersten Reihe bzw. korrespondierende Glieder in der zweiten Zerlegung zusammenzufassen in (skalierten) Mittelwerten und Differenzen:

f = n = f 2 n + f 2 n + 1 2 δ 2 n + δ 2 n + 1 2 + n = f 2 n f 2 n + 1 2 δ 2 n δ 2 n + 1 2 {\displaystyle f=\sum _{n=-\infty }^{\infty }\,{\frac {f_{2n}+f_{2n+1}}{\sqrt {2}}}\cdot {\frac {\delta ^{2n}+\delta ^{2n+1}}{\sqrt {2}}}+\sum _{n=-\infty }^{\infty }\,{\frac {f_{2n}-f_{2n+1}}{\sqrt {2}}}\cdot {\frac {\delta ^{2n}-\delta ^{2n+1}}{\sqrt {2}}}}

Jetzt führen wir neue Bezeichnungen ein:

  • die neuen Basisfolgen
a n := δ 2 n + δ 2 n + 1 2 {\displaystyle a^{n}:={\frac {\delta ^{2n}+\delta ^{2n+1}}{\sqrt {2}}}} und b n := δ 2 n δ 2 n + 1 2 {\displaystyle b^{n}:={\frac {\delta ^{2n}-\delta ^{2n+1}}{\sqrt {2}}}}
  • mit den neuen transformierten Koeffizienten
s n := f 2 n + f 2 n + 1 2 {\displaystyle s_{n}:={\frac {f_{2n}+f_{2n+1}}{\sqrt {2}}}} und d n := f 2 n f 2 n + 1 2 {\displaystyle d_{n}:={\frac {f_{2n}-f_{2n+1}}{\sqrt {2}}}} .

Wir erhalten somit die Zerlegung der Haar-Wavelet-Transformation

f = n = s n a n + n = d n b n {\displaystyle f=\sum _{n=-\infty }^{\infty }\,s_{n}\cdot a^{n}+\sum _{n=-\infty }^{\infty }\,d_{n}\cdot b^{n}} .

und mittels des unendlichen euklidischen Skalarproduktes können wir schreiben

s n = f , a n {\displaystyle s_{n}=\langle f,\,a^{n}\rangle } und d n = f , b n {\displaystyle d_{n}=\langle f,\,b^{n}\rangle } .

Die letzten drei Identitäten beschreiben eine „Conjugate Quadrature Filterbank (CQF)“, welche so auch für allgemeinere Basisfolgen a n {\displaystyle a^{n}} und b n {\displaystyle b^{n}} definiert werden kann. Die Basisfolgen a n {\displaystyle a^{n}} entstehen alle durch Verschiebung um das jeweilige 2 n {\displaystyle 2n} aus a 0 {\displaystyle a^{0}} , die b n {\displaystyle b^{n}} durch Verschiebung aus b 0 {\displaystyle b^{0}} . Weiteres dazu im Artikel Daubechies-Wavelets.

Nun enthält die Folge s = ( s n ) {\displaystyle s=(s^{n})} eine geglättete Version des Ausgangssignals bei halber Abtastrate, man kann also auch s {\displaystyle s} nach dieser Vorschrift zerlegen und dieses Vorgehen über eine bestimmte Tiefe rekursiv fortsetzen. Aus einem Ausgangssignal s 0 = f {\displaystyle s^{0}=f} werden also nacheinander die Tupel

( s 1 , d 1 ) {\displaystyle (s^{1},d^{1})} , ( s 2 , d 2 , d 1 ) {\displaystyle (s^{2},d^{2},d^{1})} , ( s 3 , d 3 , d 2 , d 1 ) {\displaystyle (s^{3},d^{3},d^{2},d^{1})} , …

Ist f {\displaystyle f} endlich, also fast überall Null, mit Länge N {\displaystyle N} , dann haben die Folgen in der Zerlegung im Wesentlichen, d. h. bis auf additive Konstanten, die Längen

( N 2 , N 2 ) {\displaystyle \left({\tfrac {N}{2}},{\tfrac {N}{2}}\right)} , ( N 4 , N 4 , N 2 ) {\displaystyle \left({\tfrac {N}{4}},{\tfrac {N}{4}},{\tfrac {N}{2}}\right)} , ( N 8 , N 8 , N 4 , N 2 ) {\displaystyle \left({\tfrac {N}{8}},{\tfrac {N}{8}},{\tfrac {N}{4}},{\tfrac {N}{2}}\right)} , …

so dass die Gesamtzahl wesentlicher Koeffizienten erhalten bleibt. Die Folgen in der Zerlegung eignen sich meist besser zur Weiterverarbeitung wie Kompression oder Suche nach bestimmtem Merkmalen als das rohe Ausgangssignal.

Modifikationen

Die Polyphasenzerlegung des Ausgangssignals kann auch zu einer anderen Blockgröße s als 2 erfolgen, von der entsprechenden Haar-Matrix ist zu fordern, dass sie eine orthogonale Matrix ist und ihre erste Zeile nur aus Einträgen 1 / s {\displaystyle 1/{\sqrt {s}}} besteht. Diese Anforderung erfüllen die Matrizen der diskreten Kosinustransformation und die der Walsh-Hadamard-Transformation.

Die Haar-Wavelet-Transformation entspricht einer diskreten Kosinustransformation zur Blockgröße s = 2 {\displaystyle s=2} , welche im Bild=Pixelrechteck nacheinander in horizontaler und vertikaler Richtung angewandt wird.

Siehe auch

Literatur

  • Alfréd Haar: Zur Theorie der orthogonalen Funktionensysteme, Mathematische Annalen 69, 331–371, 1910, doi:10.1007/BF01456927, insbesondere Kapitel 3 (ab S. 361).
Commons: Haar-Wavelet – Sammlung von Bildern, Videos und Audiodateien

Einzelnachweise

  1. Alfred Haar: Zur Theorie der orthogonalen Funktionensysteme. In: Mathematische Annalen. 69. Jahrgang, Nr. 3, 1910, S. 331–371, doi:10.1007/BF01456326.