Refinable function

From HandWiki

In mathematics, in the area of wavelet analysis, a refinable function is a function which fulfils some kind of self-similarity. A function [math]\displaystyle{ \varphi }[/math] is called refinable with respect to the mask [math]\displaystyle{ h }[/math] if

[math]\displaystyle{ \varphi(x)=2\cdot\sum_{k=0}^{N-1} h_k\cdot\varphi(2\cdot x-k) }[/math]

This condition is called refinement equation, dilation equation or two-scale equation.

Using the convolution (denoted by a star, *) of a function with a discrete mask and the dilation operator [math]\displaystyle{ D }[/math] one can write more concisely:

[math]\displaystyle{ \varphi=2\cdot D_{1/2} (h * \varphi) }[/math]

It means that one obtains the function, again, if you convolve the function with a discrete mask and then scale it back. There is a similarity to iterated function systems and de Rham curves.

The operator [math]\displaystyle{ \varphi\mapsto 2\cdot D_{1/2} (h * \varphi) }[/math] is linear. A refinable function is an eigenfunction of that operator. Its absolute value is not uniquely defined. That is, if [math]\displaystyle{ \varphi }[/math] is a refinable function, then for every [math]\displaystyle{ c }[/math] the function [math]\displaystyle{ c\cdot\varphi }[/math] is refinable, too.

These functions play a fundamental role in wavelet theory as scaling functions.

Properties

Values at integral points

A refinable function is defined only implicitly. It may also be that there are several functions which are refinable with respect to the same mask. If [math]\displaystyle{ \varphi }[/math] shall have finite support and the function values at integer arguments are wanted, then the two scale equation becomes a system of simultaneous linear equations.

Let [math]\displaystyle{ a }[/math] be the minimum index and [math]\displaystyle{ b }[/math] be the maximum index of non-zero elements of [math]\displaystyle{ h }[/math], then one obtains [math]\displaystyle{ \begin{pmatrix} \varphi(a)\\ \varphi(a+1)\\ \vdots\\ \varphi(b) \end{pmatrix} = \begin{pmatrix} h_{a } & & & & & \\ h_{a+2} & h_{a+1} & h_{a } & & & \\ h_{a+4} & h_{a+3} & h_{a+2} & h_{a+1} & h_{a } & \\ \ddots & \ddots & \ddots & \ddots & \ddots & \ddots \\ & h_{b } & h_{b-1} & h_{b-2} & h_{b-3} & h_{b-4} \\ & & & h_{b } & h_{b-1} & h_{b-2} \\ & & & & & h_{b } \end{pmatrix} \begin{pmatrix} \varphi(a)\\ \varphi(a+1)\\ \vdots\\ \varphi(b) \end{pmatrix}. }[/math]

Using the discretization operator, call it [math]\displaystyle{ Q }[/math] here, and the transfer matrix of [math]\displaystyle{ h }[/math], named [math]\displaystyle{ T_h }[/math], this can be written concisely as [math]\displaystyle{ Q\varphi = T_h Q\varphi. }[/math]

This is again a fixed-point equation. But this one can now be considered as an eigenvector-eigenvalue problem. That is, a finitely supported refinable function exists only (but not necessarily), if [math]\displaystyle{ T_h }[/math] has the eigenvalue 1.

Values at dyadic points

From the values at integral points you can derive the values at dyadic points, i.e. points of the form [math]\displaystyle{ k\cdot 2^{-j} }[/math], with [math]\displaystyle{ k\in\Z }[/math] and [math]\displaystyle{ j\in\N }[/math].

[math]\displaystyle{ \varphi = D_{1/2} (2\cdot (h * \varphi)) }[/math]
[math]\displaystyle{ D_2 \varphi = 2\cdot (h * \varphi) }[/math]
[math]\displaystyle{ Q(D_2 \varphi) = Q(2\cdot (h * \varphi)) = 2\cdot (h * Q\varphi) }[/math]

The star denotes the convolution of a discrete filter with a function. With this step you can compute the values at points of the form [math]\displaystyle{ \frac{k}{2} }[/math]. By replacing iteratedly [math]\displaystyle{ \varphi }[/math] by [math]\displaystyle{ D_2 \varphi }[/math] you get the values at all finer scales.

[math]\displaystyle{ Q(D_{2^{j+1}}\varphi) = 2\cdot (h * Q(D_{2^j}\varphi)) }[/math]

Convolution

If [math]\displaystyle{ \varphi }[/math] is refinable with respect to [math]\displaystyle{ h }[/math], and [math]\displaystyle{ \psi }[/math] is refinable with respect to [math]\displaystyle{ g }[/math], then [math]\displaystyle{ \varphi*\psi }[/math] is refinable with respect to [math]\displaystyle{ h*g }[/math].

Differentiation

If [math]\displaystyle{ \varphi }[/math] is refinable with respect to [math]\displaystyle{ h }[/math], and the derivative [math]\displaystyle{ \varphi' }[/math] exists, then [math]\displaystyle{ \varphi' }[/math] is refinable with respect to [math]\displaystyle{ 2\cdot h }[/math]. This can be interpreted as a special case of the convolution property, where one of the convolution operands is a derivative of the Dirac impulse.

Integration

If [math]\displaystyle{ \varphi }[/math] is refinable with respect to [math]\displaystyle{ h }[/math], and there is an antiderivative [math]\displaystyle{ \Phi }[/math] with [math]\displaystyle{ \Phi(t) = \int_0^{t}\varphi(\tau)\,\mathrm{d}\tau }[/math], then the antiderivative [math]\displaystyle{ t \mapsto \Phi(t) + c }[/math] is refinable with respect to mask [math]\displaystyle{ \frac{1}{2}\cdot h }[/math] where the constant [math]\displaystyle{ c }[/math] must fulfill [math]\displaystyle{ c\cdot \left(1 - \sum_j h_j\right) = \sum_j h_j \cdot \Phi(-j) }[/math].

If [math]\displaystyle{ \varphi }[/math] has bounded support, then we can interpret integration as convolution with the Heaviside function and apply the convolution law.

Scalar products

Computing the scalar products of two refinable functions and their translates can be broken down to the two above properties. Let [math]\displaystyle{ T }[/math] be the translation operator. It holds [math]\displaystyle{ \langle \varphi, T_k \psi\rangle = \langle \varphi * \psi^*, T_k\delta\rangle = (\varphi*\psi^*)(k) }[/math] where [math]\displaystyle{ \psi^* }[/math] is the adjoint of [math]\displaystyle{ \psi }[/math] with respect to convolution, i.e., [math]\displaystyle{ \psi^* }[/math] is the flipped and complex conjugated version of [math]\displaystyle{ \psi }[/math], i.e., [math]\displaystyle{ \psi^*(t) = \overline{\psi(-t)} }[/math].

Because of the above property, [math]\displaystyle{ \varphi*\psi^* }[/math] is refinable with respect to [math]\displaystyle{ h*g^* }[/math], and its values at integral arguments can be computed as eigenvectors of the transfer matrix. This idea can be easily generalized to integrals of products of more than two refinable functions.[1]

Smoothness

A refinable function usually has a fractal shape. The design of continuous or smooth refinable functions is not obvious. Before dealing with forcing smoothness it is necessary to measure smoothness of refinable functions. Using the Villemoes machine[2] one can compute the smoothness of refinable functions in terms of Sobolev exponents.

In a first step the refinement mask [math]\displaystyle{ h }[/math] is divided into a filter [math]\displaystyle{ b }[/math], which is a power of the smoothness factor [math]\displaystyle{ (1,1) }[/math] (this is a binomial mask) and a rest [math]\displaystyle{ q }[/math]. Roughly spoken, the binomial mask [math]\displaystyle{ b }[/math] makes smoothness and [math]\displaystyle{ q }[/math] represents a fractal component, which reduces smoothness again. Now the Sobolev exponent is roughly the order of [math]\displaystyle{ b }[/math] minus logarithm of the spectral radius of [math]\displaystyle{ T_{q*q^*} }[/math].

Generalization

The concept of refinable functions can be generalized to functions of more than one variable, that is functions from [math]\displaystyle{ \R^d \to \R }[/math]. The most simple generalization is about tensor products. If [math]\displaystyle{ \varphi }[/math] and [math]\displaystyle{ \psi }[/math] are refinable with respect to [math]\displaystyle{ h }[/math] and [math]\displaystyle{ g }[/math], respectively, then [math]\displaystyle{ \varphi\otimes\psi }[/math] is refinable with respect to [math]\displaystyle{ h\otimes g }[/math].

The scheme can be generalized even more to different scaling factors with respect to different dimensions or even to mixing data between dimensions.[3] Instead of scaling by scalar factor like 2 the signal the coordinates are transformed by a matrix [math]\displaystyle{ M }[/math] of integers. In order to let the scheme work, the absolute values of all eigenvalues of [math]\displaystyle{ M }[/math] must be larger than one. (Maybe it also suffices that [math]\displaystyle{ \left|\det M\right|\gt 1 }[/math].)

Formally the two-scale equation does not change very much: [math]\displaystyle{ \varphi(x)=\left|\det M\right|\cdot\sum_{k\in\Z^d} h_k\cdot\varphi(M\cdot x-k) }[/math] [math]\displaystyle{ \varphi=\left|\det M\right|\cdot D_{M^{-1}} (h * \varphi) }[/math]

Examples

  • If the definition is extended to distributions, then the Dirac impulse is refinable with respect to the unit vector [math]\displaystyle{ \delta }[/math], that is known as Kronecker delta. The [math]\displaystyle{ n }[/math]-th derivative of the Dirac distribution is refinable with respect to [math]\displaystyle{ 2^n\cdot\delta }[/math].
  • The Heaviside function is refinable with respect to [math]\displaystyle{ \frac{1}{2}\cdot\delta }[/math].
  • The truncated power functions with exponent [math]\displaystyle{ n }[/math] are refinable with respect to [math]\displaystyle{ \frac{1}{2^{n+1}}\cdot\delta }[/math].
  • The triangular function is a refinable function.[4] B-spline functions with successive integral nodes are refinable, because of the convolution theorem and the refinability of the characteristic function for the interval [math]\displaystyle{ [0,1) }[/math] (a boxcar function).
  • All polynomial functions are refinable. For every refinement mask there is a polynomial that is uniquely defined up to a constant factor. For every polynomial of degree [math]\displaystyle{ n }[/math] there are many refinement masks that all differ by a mask of type [math]\displaystyle{ v * (1,-1)^{n+1} }[/math] for any mask [math]\displaystyle{ v }[/math] and the convolutional power [math]\displaystyle{ (1,-1)^{n+1} }[/math].[5]
  • A rational function [math]\displaystyle{ \varphi }[/math] is refinable if and only if it can be represented using partial fractions as [math]\displaystyle{ \varphi(x) = \sum_{i\in\mathbb{Z}} \frac{s_i}{(x-i)^k} }[/math], where [math]\displaystyle{ k }[/math] is a positive natural number and [math]\displaystyle{ s }[/math] is a real sequence with finitely many non-zero elements (a Laurent polynomial) such that [math]\displaystyle{ s | (s \uparrow 2) }[/math] (read: [math]\displaystyle{ \exists h(z)\in\mathbb{R}[z,z^{-1}]\ h(z)\cdot s(z) = s(z^2) }[/math]). The Laurent polynomial [math]\displaystyle{ 2^{k-1}\cdot h }[/math] is the associated refinement mask.[6]

References

  1. Dahmen, Wolfgang; Micchelli, Charles A. (1993). "Using the refinement equation for evaluating integrals of wavelets". Journal Numerical Analysis (SIAM) 30 (2): 507–537. doi:10.1137/0730024. 
  2. Villemoes, Lars. "Sobolev regularity of wavelets and stability of iterated filter banks" (PostScript). http://www.math.kth.se/~larsv/paper3.ps.Z. 
  3. Berger, Marc A.; Wang, Yang (1992), "Multidimensional two-scale dilation equations (chapter IV)", in Chui, Charles K., Wavelets: A Tutorial in Theory and Applications, Wavelet Analysis and its Applications, 2, Academic Press, Inc., pp. 295–323 
  4. Nathanael, Berglund. "Reconstructing Refinable Functions". http://www.math.gatech.edu/~berglund/Refinable/index.html. 
  5. Thielemann, Henning (2012-01-29). "How to refine polynomial functions". arXiv:1012.2453 [math.FA].
  6. Gustafson, Paul; Savir, Nathan; Spears, Ely (2006-11-14), "A Characterization of Refinable Rational Functions", American Journal of Undergraduate Research 5 (3): 11–20, doi:10.33697/ajur.2006.021, http://www.uni.edu/ajur/v5n3/Gufstafson%20et%20al%20new%20pp%2011-20.pdf 

See also