Hilbert transform

From testwiki
Revision as of 16:52, 3 February 2025 by imported>Meno25 (See also)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Template:Short description In mathematics and signal processing, the Hilbert transform is a specific singular integral that takes a function, Template:Math of a real variable and produces another function of a real variable Template:Math. The Hilbert transform is given by the Cauchy principal value of the convolution with the function 1/(πt) (see Template:Slink). The Hilbert transform has a particularly simple representation in the frequency domain: It imparts a phase shift of ±90° (Template:Pi/2 radians) to every frequency component of a function, the sign of the shift depending on the sign of the frequency (see Template:Slink). The Hilbert transform is important in signal processing, where it is a component of the analytic representation of a real-valued signal Template:Math. The Hilbert transform was first introduced by David Hilbert in this setting, to solve a special case of the Riemann–Hilbert problem for analytic functions.

Definition

The Hilbert transform of Template:Mvar can be thought of as the convolution of Template:Math with the function Template:Math, known as the Cauchy kernel. Because 1/Template:Mvar is not integrable across Template:Math, the integral defining the convolution does not always converge. Instead, the Hilbert transform is defined using the Cauchy principal value (denoted here by Template:Math). Explicitly, the Hilbert transform of a function (or signal) Template:Math is given by

H(u)(t)=1πp.v.+u(τ)tτdτ,

provided this integral exists as a principal value. This is precisely the convolution of Template:Mvar with the tempered distribution Template:Math.[1] Alternatively, by changing variables, the principal-value integral can be written explicitly[2] as

H(u)(t)=2πlimε0εu(tτ)u(t+τ)2τdτ.

When the Hilbert transform is applied twice in succession to a function Template:Mvar, the result is

H(H(u))(t)=u(t),

provided the integrals defining both iterations converge in a suitable sense. In particular, the inverse transform is H. This fact can most easily be seen by considering the effect of the Hilbert transform on the Fourier transform of Template:Math (see Template:Slink below).

For an analytic function in the upper half-plane, the Hilbert transform describes the relationship between the real part and the imaginary part of the boundary values. That is, if Template:Math is analytic in the upper half complex plane Template:Math, and Template:Math, then Template:Math up to an additive constant, provided this Hilbert transform exists.

Notation

In signal processing the Hilbert transform of Template:Math is commonly denoted by u^(t).[3] However, in mathematics, this notation is already extensively used to denote the Fourier transform of Template:Math.[4] Occasionally, the Hilbert transform may be denoted by u~(t). Furthermore, many sources define the Hilbert transform as the negative of the one defined here.[5]

History

The Hilbert transform arose in Hilbert's 1905 work on a problem Riemann posed concerning analytic functions,Template:SfnTemplate:Sfn which has come to be known as the Riemann–Hilbert problem. Hilbert's work was mainly concerned with the Hilbert transform for functions defined on the circle.Template:SfnTemplate:Sfn Some of his earlier work related to the Discrete Hilbert Transform dates back to lectures he gave in Göttingen. The results were later published by Hermann Weyl in his dissertation.Template:Sfn Schur improved Hilbert's results about the discrete Hilbert transform and extended them to the integral case.Template:Sfn These results were restricted to the spaces [[Lp space|Template:Math and Template:Math]]. In 1928, Marcel Riesz proved that the Hilbert transform can be defined for u in Lp() (Lp space) for Template:Math, that the Hilbert transform is a bounded operator on Lp() for Template:Math, and that similar results hold for the Hilbert transform on the circle as well as the discrete Hilbert transform.Template:Sfn The Hilbert transform was a motivating example for Antoni Zygmund and Alberto Calderón during their study of singular integrals.Template:Sfn Their investigations have played a fundamental role in modern harmonic analysis. Various generalizations of the Hilbert transform, such as the bilinear and trilinear Hilbert transforms are still active areas of research today.

Relationship with the Fourier transform

The Hilbert transform is a multiplier operator.Template:Sfn The multiplier of Template:Math is Template:Math, where Template:Math is the signum function. Therefore:

(H(u))(ω)=isgn(ω)(u)(ω),

where denotes the Fourier transform. Since Template:Math, it follows that this result applies to the three common definitions of .

By Euler's formula, σH(ω)={i=e+iπ/2,for ω<0,0,for ω=0,i=eiπ/2,for ω>0.

Therefore, Template:Math has the effect of shifting the phase of the negative frequency components of Template:Math by +90° (Template:Frac radians) and the phase of the positive frequency components by −90°, and Template:Math has the effect of restoring the positive frequency components while shifting the negative frequency ones an additional +90°, resulting in their negation (i.e., a multiplication by −1).

When the Hilbert transform is applied twice, the phase of the negative and positive frequency components of Template:Math are respectively shifted by +180° and −180°, which are equivalent amounts. The signal is negated; i.e., Template:Math, because

(σH(ω))2=e±iπ=1for ω0.

Table of selected Hilbert transforms

In the following table, the frequency parameter ω is real.

Signal
u(t)
Hilbert transform[fn 1]
H(u)(t)
sin(ωt+φ) [fn 2]

sin(ωt+φπ2)=cos(ωt+φ),ω>0sin(ωt+φ+π2)=cos(ωt+φ),ω<0

cos(ωt+φ) [fn 2]

cos(ωt+φπ2)=sin(ωt+φ),ω>0cos(ωt+φ+π2)=sin(ωt+φ),ω<0

eiωt

ei(ωtπ2),ω>0ei(ωt+π2),ω<0

eiωt

ei(ωtπ2),ω>0ei(ωt+π2),ω<0

1t2+1 tt2+1
et2 2πF(t)
(see Dawson function)
Sinc function
sin(t)t
1cos(t)t
Dirac delta function
δ(t)
1πt
Characteristic function
χ[a,b](t)
1πln|tatb|

Notes

  1. Some authors (e.g., Bracewell) use our Template:Math as their definition of the forward transform. A consequence is that the right column of this table would be negated.
  2. 2.0 2.1 The Hilbert transform of the sin and cos functions can be defined by taking the principal value of the integral at infinity. This definition agrees with the result of defining the Hilbert transform distributionally.

An extensive table of Hilbert transforms is available.Template:Sfn Note that the Hilbert transform of a constant is zero.

Domain of definition

It is by no means obvious that the Hilbert transform is well-defined at all, as the improper integral defining it must converge in a suitable sense. However, the Hilbert transform is well-defined for a broad class of functions, namely those in Lp() for Template:Math.

More precisely, if Template:Mvar is in Lp() for Template:Math, then the limit defining the improper integral

H(u)(t)=2πlimε0εu(tτ)u(t+τ)2τdτ

exists for almost every Template:Mvar. The limit function is also in Lp() and is in fact the limit in the mean of the improper integral as well. That is,

2πεu(tτ)u(t+τ)2τdτH(u)(t)

as Template:Math in the Template:Mvar norm, as well as pointwise almost everywhere, by the Titchmarsh theorem.Template:Sfn

In the case Template:Math, the Hilbert transform still converges pointwise almost everywhere, but may itself fail to be integrable, even locally.Template:Sfn In particular, convergence in the mean does not in general happen in this case. The Hilbert transform of an Template:Math function does converge, however, in Template:Math-weak, and the Hilbert transform is a bounded operator from Template:Math to Template:Math.Template:Sfn (In particular, since the Hilbert transform is also a multiplier operator on Template:Math, Marcinkiewicz interpolation and a duality argument furnishes an alternative proof that Template:Mvar is bounded on Template:Math.)

Properties

Boundedness

If Template:Math, then the Hilbert transform on Lp() is a bounded linear operator, meaning that there exists a constant Template:Mvar such that

HupCpup

for all Template:Nowrap[6]

The best constant Cp is given by[7] Cp={tanπ2pfor1<p2,cotπ2pfor2<p<.

An easy way to find the best Cp for p being a power of 2 is through the so-called Cotlar's identity that (Hf)2=f2+2H(fHf) for all real valued Template:Mvar. The same best constants hold for the periodic Hilbert transform.

The boundedness of the Hilbert transform implies the Lp() convergence of the symmetric partial sum operator SRf=RRf^(ξ)e2πixξdξ

to Template:Mvar in Template:Nowrap[8]

Anti-self adjointness

The Hilbert transform is an anti-self adjoint operator relative to the duality pairing between Lp() and the dual space Template:Nowrap where Template:Mvar and Template:Mvar are Hölder conjugates and Template:Math. Symbolically,

Hu,v=u,Hv

for uLp() and Template:NowrapTemplate:Sfn

Inverse transform

The Hilbert transform is an anti-involution,Template:Sfn meaning that

H(H(u))=u

provided each transform is well-defined. Since Template:Math preserves the space Template:Nowrap this implies in particular that the Hilbert transform is invertible on Template:Nowrap and that

H1=H

Complex structure

Because Template:Math ("Template:Math" is the identity operator) on the real Banach space of real-valued functions in Template:Nowrap the Hilbert transform defines a linear complex structure on this Banach space. In particular, when Template:Math, the Hilbert transform gives the Hilbert space of real-valued functions in L2() the structure of a complex Hilbert space.

The (complex) eigenstates of the Hilbert transform admit representations as holomorphic functions in the upper and lower half-planes in the Hardy space [[H square|Template:Math]] by the Paley–Wiener theorem.

Differentiation

Formally, the derivative of the Hilbert transform is the Hilbert transform of the derivative, i.e. these two linear operators commute:

H(dudt)=ddtH(u)

Iterating this identity,

H(dkudtk)=dkdtkH(u)

This is rigorously true as stated provided Template:Mvar and its first Template:Mvar derivatives belong to Template:NowrapTemplate:Sfn One can check this easily in the frequency domain, where differentiation becomes multiplication by Template:Mvar.

Convolutions

The Hilbert transform can formally be realized as a convolution with the tempered distributionTemplate:Sfn

h(t)=p.v.1πt

Thus formally,

H(u)=h*u

However, a priori this may only be defined for Template:Mvar a distribution of compact support. It is possible to work somewhat rigorously with this since compactly supported functions (which are distributions a fortiori) are dense in Template:Math. Alternatively, one may use the fact that h(t) is the distributional derivative of the function Template:Math; to wit

H(u)(t)=ddt(1π(u*log||)(t))

For most operational purposes the Hilbert transform can be treated as a convolution. For example, in a formal sense, the Hilbert transform of a convolution is the convolution of the Hilbert transform applied on only one of either of the factors:

H(u*v)=H(u)*v=u*H(v)

This is rigorously true if Template:Mvar and Template:Mvar are compactly supported distributions since, in that case,

h*(u*v)=(h*u)*v=u*(h*v)

By passing to an appropriate limit, it is thus also true if Template:Math and Template:Math provided that

1<1p+1q

from a theorem due to Titchmarsh.Template:Sfn

Invariance

The Hilbert transform has the following invariance properties on L2().

Up to a multiplicative constant, the Hilbert transform is the only bounded operator on Template:Mvar2 with these properties.Template:Sfn

In fact there is a wider set of operators that commute with the Hilbert transform. The group SL(2,) acts by unitary operators Template:Math on the space L2() by the formula

Ug1f(x)=1cx+df(ax+bcx+d),g=[abcd], for adbc=±1.

This unitary representation is an example of a principal series representation of SL(2,). In this case it is reducible, splitting as the orthogonal sum of two invariant subspaces, Hardy space H2() and its conjugate. These are the spaces of Template:Math boundary values of holomorphic functions on the upper and lower halfplanes. H2() and its conjugate consist of exactly those Template:Math functions with Fourier transforms vanishing on the negative and positive parts of the real axis respectively. Since the Hilbert transform is equal to Template:Math, with Template:Mvar being the orthogonal projection from L2() onto H2(), and Template:Math the identity operator, it follows that H2() and its orthogonal complement are eigenspaces of Template:Math for the eigenvalues Template:Math. In other words, Template:Math commutes with the operators Template:Mvar. The restrictions of the operators Template:Mvar to H2() and its conjugate give irreducible representations of SL(2,) – the so-called limit of discrete series representations.[9]

Extending the domain of definition

Hilbert transform of distributions

It is further possible to extend the Hilbert transform to certain spaces of distributions Template:Harv. Since the Hilbert transform commutes with differentiation, and is a bounded operator on Template:Mvar, Template:Mvar restricts to give a continuous transform on the inverse limit of Sobolev spaces:

𝒟Lp=limnWn,p()

The Hilbert transform can then be defined on the dual space of 𝒟Lp, denoted 𝒟Lp, consisting of Template:Mvar distributions. This is accomplished by the duality pairing:
For Template:Nowrap define:

H(u)𝒟'Lp=Hu,v  u,Hv, for all v𝒟Lp.

It is possible to define the Hilbert transform on the space of tempered distributions as well by an approach due to Gel'fand and Shilov,Template:Sfn but considerably more care is needed because of the singularity in the integral.

Hilbert transform of bounded functions

The Hilbert transform can be defined for functions in L() as well, but it requires some modifications and caveats. Properly understood, the Hilbert transform maps L() to the Banach space of bounded mean oscillation (BMO) classes.

Interpreted naïvely, the Hilbert transform of a bounded function is clearly ill-defined. For instance, with Template:Math, the integral defining Template:Math diverges almost everywhere to Template:Math. To alleviate such difficulties, the Hilbert transform of an Template:Math function is therefore defined by the following regularized form of the integral

H(u)(t)=p.v.u(τ){h(tτ)h0(τ)}dτ

where as above Template:Math and

h0(x)={0for|x|<11πxfor|x|1

The modified transform Template:Math agrees with the original transform up to an additive constant on functions of compact support from a general result by Calderón and Zygmund.[10] Furthermore, the resulting integral converges pointwise almost everywhere, and with respect to the BMO norm, to a function of bounded mean oscillation.

A deep result of Fefferman's work[11] is that a function is of bounded mean oscillation if and only if it has the form Template:Nowrap for some Template:Nowrap

Conjugate functions

The Hilbert transform can be understood in terms of a pair of functions Template:Math and Template:Math such that the function F(x)=f(x)+ig(x) is the boundary value of a holomorphic function Template:Math in the upper half-plane.Template:Sfn Under these circumstances, if Template:Mvar and Template:Mvar are sufficiently integrable, then one is the Hilbert transform of the other.

Suppose that fLp(). Then, by the theory of the Poisson integral, Template:Mvar admits a unique harmonic extension into the upper half-plane, and this extension is given by

u(x+iy)=u(x,y)=1πf(s)y(xs)2+y2ds

which is the convolution of Template:Mvar with the Poisson kernel

P(x,y)=yπ(x2+y2)

Furthermore, there is a unique harmonic function Template:Mvar defined in the upper half-plane such that Template:Math is holomorphic and limyv(x+iy)=0

This harmonic function is obtained from Template:Mvar by taking a convolution with the conjugate Poisson kernel

Q(x,y)=xπ(x2+y2).

Thus v(x,y)=1πf(s)xs(xs)2+y2ds.

Indeed, the real and imaginary parts of the Cauchy kernel are iπz=P(x,y)+iQ(x,y)

so that Template:Math is holomorphic by Cauchy's integral formula.

The function Template:Mvar obtained from Template:Mvar in this way is called the harmonic conjugate of Template:Mvar. The (non-tangential) boundary limit of Template:Math as Template:Math is the Hilbert transform of Template:Mvar. Thus, succinctly, H(f)=limy0Q(,y)f

Titchmarsh's theorem

Titchmarsh's theorem (named for E. C. Titchmarsh who included it in his 1937 work) makes precise the relationship between the boundary values of holomorphic functions in the upper half-plane and the Hilbert transform.Template:Sfn It gives necessary and sufficient conditions for a complex-valued square-integrable function Template:Math on the real line to be the boundary value of a function in the Hardy space Template:Math of holomorphic functions in the upper half-plane Template:Mvar.

The theorem states that the following conditions for a complex-valued square-integrable function F: are equivalent:

A weaker result is true for functions of class Template:Mvar for Template:Math.Template:Sfn Specifically, if Template:Math is a holomorphic function such that

|F(x+iy)|pdx<K

for all Template:Mvar, then there is a complex-valued function Template:Math in Lp() such that Template:Math in the Template:Mvar norm as Template:Math (as well as holding pointwise almost everywhere). Furthermore,

F(x)=f(x)ig(x)

where Template:Mvar is a real-valued function in Lp() and Template:Mvar is the Hilbert transform (of class Template:Mvar) of Template:Mvar.

This is not true in the case Template:Math. In fact, the Hilbert transform of an Template:Math function Template:Mvar need not converge in the mean to another Template:Math function. Nevertheless,Template:Sfn the Hilbert transform of Template:Mvar does converge almost everywhere to a finite function Template:Mvar such that

|g(x)|p1+x2dx<

This result is directly analogous to one by Andrey Kolmogorov for Hardy functions in the disc.Template:Sfn Although usually called Titchmarsh's theorem, the result aggregates much work of others, including Hardy, Paley and Wiener (see Paley–Wiener theorem), as well as work by Riesz, Hille, and Tamarkin[12]

Riemann–Hilbert problem

One form of the Riemann–Hilbert problem seeks to identify pairs of functions Template:Math and Template:Math such that Template:Math is holomorphic on the upper half-plane and Template:Math is holomorphic on the lower half-plane, such that for Template:Mvar along the real axis, F+(x)F(x)=f(x)

where Template:Math is some given real-valued function of Template:Nowrap The left-hand side of this equation may be understood either as the difference of the limits of Template:Math from the appropriate half-planes, or as a hyperfunction distribution. Two functions of this form are a solution of the Riemann–Hilbert problem.

Formally, if Template:Math solve the Riemann–Hilbert problem f(x)=F+(x)F(x)

then the Hilbert transform of Template:Math is given byTemplate:Sfn H(f)(x)=i(F+(x)+F(x)).

Hilbert transform on the circle

Template:See also For a periodic function Template:Mvar the circular Hilbert transform is defined:

f~(x)12πp.v.02πf(t)cot(xt2)dt

The circular Hilbert transform is used in giving a characterization of Hardy space and in the study of the conjugate function in Fourier series. The kernel, cot(xt2) is known as the Hilbert kernel since it was in this form the Hilbert transform was originally studied.Template:Sfn

The Hilbert kernel (for the circular Hilbert transform) can be obtained by making the Cauchy kernel Template:Frac periodic. More precisely, for Template:Math

12cot(x2)=1x+n=1(1x+2nπ+1x2nπ)

Many results about the circular Hilbert transform may be derived from the corresponding results for the Hilbert transform from this correspondence.

Another more direct connection is provided by the Cayley transform Template:Math, which carries the real line onto the circle and the upper half plane onto the unit disk. It induces a unitary map

Uf(x)=1(x+i)πf(C(x))

of Template:Math onto L2(). The operator Template:Mvar carries the Hardy space Template:Math onto the Hardy space H2().Template:Sfn

Hilbert transform in signal processing

Bedrosian's theorem

Bedrosian's theorem states that the Hilbert transform of the product of a low-pass and a high-pass signal with non-overlapping spectra is given by the product of the low-pass signal and the Hilbert transform of the high-pass signal, or

H(fLP(t)fHP(t))=fLP(t)H(fHP(t)),

where Template:Math and Template:Math are the low- and high-pass signals respectively.Template:Sfn A category of communication signals to which this applies is called the narrowband signal model. A member of that category is amplitude modulation of a high-frequency sinusoidal "carrier":

u(t)=um(t)cos(ωt+φ),

where Template:Math is the narrow bandwidth "message" waveform, such as voice or music. Then by Bedrosian's theorem:Template:Sfn

H(u)(t)={+um(t)sin(ωt+φ),ω>0,um(t)sin(ωt+φ),ω<0.

Analytic representation

Template:Main article A specific type of conjugate function is:

ua(t)u(t)+iH(u)(t),

known as the analytic representation of u(t). The name reflects its mathematical tractability, due largely to Euler's formula. Applying Bedrosian's theorem to the narrowband model, the analytic representation is:[13]

A Fourier transform property indicates that this complex heterodyne operation can shift all the negative frequency components of Template:Math above 0 Hz. In that case, the imaginary part of the result is a Hilbert transform of the real part. This is an indirect way to produce Hilbert transforms.

Template:Anchor Angle (phase/frequency) modulation

The form:[14]

u(t)=Acos(ωt+φm(t))

is called angle modulation, which includes both phase modulation and frequency modulation. The instantaneous frequency is  ω+φm(t).  For sufficiently large Template:Mvar, compared to Template:Nowrap

H(u)(t)Asin(ωt+φm(t)) and: ua(t)Aei(ωt+φm(t)).

Single sideband modulation (SSB)

Template:Main article When Template:Math in Template:EquationNote is also an analytic representation (of a message waveform), that is:

um(t)=m(t)+im^(t)

the result is single-sideband modulation:

ua(t)=(m(t)+im^(t))ei(ωt+φ)

whose transmitted component is:[15][16]

u(t)=Re{ua(t)}=m(t)cos(ωt+φ)m^(t)sin(ωt+φ)

Causality

The function h(t)=1/(πt) presents two causality-based challenges to practical implementation in a convolution (in addition to its undefined value at 0):

  • Its duration is infinite (technically infinite support). Finite-length windowing reduces the effective frequency range of the transform; shorter windows result in greater losses at low and high frequencies. See also quadrature filter.
  • It is a non-causal filter. So a delayed version, h(tτ), is required. The corresponding output is subsequently delayed by τ. When creating the imaginary part of an analytic signal, the source (real part) must also be delayed by τ.

Discrete Hilbert transform

Figure 1: Filter whose frequency response is bandlimited to about 95% of the Nyquist frequency
Figure 2: Hilbert transform filter with a highpass frequency response
Figure 3.
Figure 4. The Hilbert transform of Template:Math is Template:Math. This figure shows Template:Math and two approximate Hilbert transforms computed by the MATLAB library function, Template:Mono
Figure 5. Discrete Hilbert transforms of a cosine function, using piecewise convolution

For a discrete function, u[n], with discrete-time Fourier transform (DTFT), U(ω), and discrete Hilbert transform u^[n], the DTFT of u^[n] in the region Template:Math is given by:

DTFT(u^)=U(ω)(isgn(ω)).

The inverse DTFT, using the convolution theorem, is:[17][18]

u^[n]=DTFT1(U(ω)) * DTFT1(isgn(ω))=u[n] * 12πππ(isgn(ω))eiωndω=u[n] * 12π[π0ieiωndω0πieiωndω]h[n],

where

h[n]  {0,for n even2πnfor n odd,

which is an infinite impulse response (IIR).

Practical considerations[19]

Method 1: Direct convolution of streaming u[n] data with an FIR approximation of h[n], which we will designate by h~[n]. Examples of truncated h[n] are shown in figures 1 and 2. Fig 1 has an odd number of anti-symmetric coefficients and is called Type III.[20] This type inherently exhibits responses of zero magnitude at frequencies 0 and Nyquist, resulting in a bandpass filter shape.[21][22] A Type IV design (even number of anti-symmetric coefficients) is shown in Fig 2.[23][24] It has a highpass frequency response.[25] Type III is the usual choice.[26][27] for these reasons:

  • A typical (i.e. properly filtered and sampled) u[n] sequence has no useful components at the Nyquist frequency.
  • The Type IV impulse response requires a 12 sample shift in the h[n] sequence. That causes the zero-valued coefficients to become non-zero, as seen in Figure 2. So a Type III design is potentially twice as efficient as Type IV.
  • The group delay of a Type III design is an integer number of samples, which facilitates aligning u^[n] with u[n] to create an analytic signal. The group delay of Type IV is halfway between two samples.

The abrupt truncation of h[n] creates a rippling (Gibbs effect) of the flat frequency response. That can be mitigated by use of a window function to taper h~[n] to zero.[28]

Method 2: Piecewise convolution. It is well known that direct convolution is computationally much more intensive than methods like overlap-save that give access to the efficiencies of the Fast Fourier transform via the convolution theorem.[29] Specifically, the discrete Fourier transform (DFT) of a segment of u[n] is multiplied pointwise with a DFT of the h~[n] sequence. An inverse DFT is done on the product, and the transient artifacts at the leading and trailing edges of the segment are discarded. Over-lapping input segments prevent gaps in the output stream. An equivalent time domain description is that segments of length N (an arbitrary parameter) are convolved with the periodic function:

h~N[n] m=h~[nmN].

When the duration of non-zero values of h~[n] is M<N, the output sequence includes NM+1 samples of u^.  M1 outputs are discarded from each block of N, and the input blocks are overlapped by that amount to prevent gaps.

Method 3: Same as method 2, except the DFT of h~[n] is replaced by samples of the isgn(ω) distribution (whose real and imaginary components are all just 0 or ±1.) That convolves u[n] with a periodic summation:Template:Efn-ua

hN[n] m=h[nmN],Template:SpacesTemplate:Efn-uaTemplate:Efn-ua

for some arbitrary parameter, N. h[n] is not an FIR, so the edge effects extend throughout the entire transform. Deciding what to delete and the corresponding amount of overlap is an application-dependent design issue.

Fig 3 depicts the difference between methods 2 and 3. Only half of the antisymmetric impulse response is shown, and only the non-zero coefficients. The blue graph corresponds to method 2 where h[n] is truncated by a rectangular window function, rather than tapered. It is generated by a Matlab function, hilb(65). Its transient effects are exactly known and readily discarded. The frequency response, which is determined by the function argument, is the only application-dependent design issue.

The red graph is h512[n], corresponding to method 3. It is the inverse DFT of the isgn(ω) distribution. Specifically, it is the function that is convolved with a segment of u[n] by the MATLAB function, hilbert(u,512).[30] The real part of the output sequence is the original input sequence, so that the complex output is an analytic representation of u[n].

When the input is a segment of a pure cosine, the resulting convolution for two different values of N is depicted in Fig 4 (red and blue plots). Edge effects prevent the result from being a pure sine function (green plot). Since hN[n] is not an FIR sequence, the theoretical extent of the effects is the entire output sequence. But the differences from a sine function diminish with distance from the edges. Parameter N is the output sequence length. If it exceeds the length of the input sequence, the input is modified by appending zero-valued elements. In most cases, that reduces the magnitude of the edge distortions. But their duration is dominated by the inherent rise and fall times of the h[n] impulse response.

Fig 5 is an example of piecewise convolution, using both methods 2 (in blue) and 3 (red dots). A sine function is created by computing the Discrete Hilbert transform of a cosine function, which was processed in four overlapping segments, and pieced back together. As the FIR result (blue) shows, the distortions apparent in the IIR result (red) are not caused by the difference between h[n] and hN[n] (green and red in Fig 3). The fact that hN[n] is tapered (windowed) is actually helpful in this context. The real problem is that it's not windowed enough. Effectively, M=N, whereas the overlap-save method needs M<N.

Number-theoretic Hilbert transform

The number theoretic Hilbert transform is an extensionTemplate:Sfn of the discrete Hilbert transform to integers modulo an appropriate prime number. In this it follows the generalization of discrete Fourier transform to number theoretic transforms. The number theoretic Hilbert transform can be used to generate sets of orthogonal discrete sequences.Template:Sfn

See also

Notes

Template:Notelist-ua

Page citations

Template:Reflist

References

Template:Sfn whitelist Template:Refbegin

Template:Refend


Further reading

Template:Refbegin

Template:Refend

Template:Commons category