First I will provide my own favorite definition of a continuous wavelet transform, which I wrote down in 1986 to rederive the results in Goupillaud et al . (At the time, I was working down the hall from Pierre Goupillaud.) This continuous transform seemed much better suited to geophysical and acoustic applications than certain discrete transforms popular at the time, particularly Daubechies wavelets. Many wavelets have a broader spectrum than necessary, more suitable for compressing photographic images with sharp edges. A continuous transform can use simple Gaussian tapered monochromatic waves (one or multi-dimensional) which maximizes the locality in both time/space and frequency/wavenumber.
First, I will give the definition of what constitutes a valid “wavelet” for the transform. Second, the inverse of a wavelet transform will be derived to demonstrate why the transform works. Next, I will show how a wavelet-transform of a stretched function can be written as a simple function of the wavelet-transform of the original unstretched function. Such stretching is very useful in pseudo-spectral solutions of differential equations with spatially varying coefficients.
Next I dwell on the original Morlet wavelet, a Gaussian-tapered sinusoid, to show how resolution can be managed explicitly in both time and frequency domains.
(This is an expansion of a much older document  that stressed the application of wavelet transforms to seismic imaging. I have removed the geophysical details and have extended the discussion.)
I will closely imitate the continuous transform originally provided by Goupillaud, Grossman, and Morlet . They provide forward and inverse transforms for related transforms, but without derivation.
Use the following Fourier convention to link a
wavelet and its Fourier transform :
The following integral must exist for a wavelet to be suitable for a continuous transform
over all frequencies.
In fact many useful wavelets (such as the Morlet wavelet) will be non-zero at zero frequency and will not be valid for an infinite range of frequencies. Discrete transforms will prefer damped least-squares optimizations rather than simple integrals for transformations and will not require an analytic constant for normalization.
This wavelet need not correspond to any specific feature in our data. Rather, when convolved with data, the wavelet should suppress all but a band of frequencies. Because of the uncertainty principle, I must balance the narrowness of the bandwidth with the narrowness in time.
I recommend a Gaussian-tapered sinusoid, such as . Such a wavelet is reasonably compact in both the time and frequency domain. (The constant adjusts the relative compactness, within the limits of the uncertainty principle.)
A valid wavelet can be used in an unfamiliar construction
of a delta function.
The constraint of symmetry will also simplify the definition
of a wavelet transform in the following section, but
this assumption is optional:
Define a wavelet transform of an function by
Goupillaud et all  prefer or instead of as the stretch factor. If you prefer an asymmetric wavelet, then you must use two transforms--the above, and the integral with the time-reversed wavelet.)
I find the following inverse, which simply scales and sums the transform
with uniform weight over local frequency :
Most all these equations were implicit in Goupillaud et al , although I personally found it nontrivial to fill in the missing derivation of the results. I was also happy to stumble on equation (4), which continues to fascinate me.
One application that frequently appears is a differential stretching of a function.
We will write
Equation (22) is the result which allows us to perform the stretch directly on the wavelet-transformed function.
A preferred standard wavelet is the Morlet wavelet
, constructed from a symmetric cosine tapered by a Gaussian.
The cosine has a base frequency of and a wavelength of . The inclusion of a variable for central frequency is just a convenience for managing units; can be set to a constant without loss of generality. When we scan frequencies with a wavelet transform (11), we can set to 1 and substitute as frequency.
The envelope has a peak value of 1 at and drops to approximately half of this value
at a separation of wavelengths.
The integral of the Gaussian envelope in time is
As an example, figure 1 shows one Morlet wavelet. We assume a time sampling interval of for a maximum Nyquist frequency of . We choose a central frequency of , and a halfwidth in wavelengths of . We can see that one wavelength is time samples in length. The positive lobes at times of (third most positive values) are half the height of the peak. These half-strength peaks are separated by four wavelengths, as appropriate for . The two peaks are also 16 time samples apart, as appropriate for four wavelengths of 4 samples each ( ).
We can take the Fourier transform (1) of the Gaussian envelope as
Notice that the frequency half-width is directly proportional to the reference frequency . As we scan frequencies with a wavelet transform, we will see lower frequencies resolved with narrower ranges of frequencies. The resolution is constant in the log of frequency, which is why Morlet recommends sampling frequencies geometrically in octaves rather than linearly in frequency. When we construct a discrete basis of these wavelets for a discrete transform, there is no need to sample frequencies much more densely than this half-width.
The Fourier transform of the cosine is
Figure 2 shows the Fourier transform of the Morlet wavelet in figure 1, also with and .
The resolution we care about is the narrowness of the spectrum about the central frequency . If we measure the standard deviation of one side of the Fourier transform (44), we are effectively measuring the width of the Fourier transformed envelope (39):
For quantifying resolution tradeoffs, a useful measure is the normalized second moment, or dispersion, in each domain.
In time, the integral of the squared Gaussian taper is
Similarly we can measure second moments in the frequency domain.
The uncertainty relation for resolution in time and frequency simplifies to