[Numpy-discussion] Bug or surprising undocumented behaviour in irfft
Charles R Harris
Wed Aug 29 18:44:09 CDT 2007
On 8/29/07, Charles R Harris <email@example.com> wrote:
> On 8/29/07, Anne Archibald <firstname.lastname@example.org> wrote:
> > Hi,
> > numpy's Fourier transforms have the handy feature of being able to
> > upsample and downsample signals; for example the documentation cites
> > irfft(rfft(A),16*len(A)) as a way to get a Fourier interpolation of A.
> > However, there is a peculiarity with the way numpy handles the
> > highest-frequency coefficient.
> The upshot is, if I correctly understand what is going on, that the
> > last coefficient needs to be treated somewhat differently from the
> > others; when one pads with zeros in order to upsample the signal, one
> > should multiply the last coefficient by 0.5. Should this be done in
> > numpy's upsampling code? Should it at least be documented?
> What is going on is that the coefficient at the Nyquist frequency appears
> once in the unextended array, but twice when the array is extended with
> zeros because of the Hermitean symmetry. That should probably be fixed in
> the upsampling code.
The inverse irfft also scales by dividing by the new transform size instead
of the original size, so the result needs to be scaled up for the
interpolation to work. It is easy to go wrong with fft's when the correct
sampling/frequency scales aren't carried with the data. I always do that
myself so that the results are independent of transform size/interpolation
and expressed in some standard units.
In : a = array([1, 0, 0, 0], dtype=double)
In : b = rfft(a)
In : b *= .5
In : irfft(b,8)
array([ 0.5 , 0.3017767, 0. , -0.0517767, 0. ,
-0.0517767, 0. , 0.3017767])
In : 2*irfft(b,8)
array([ 1. , 0.60355339, 0. , -0.10355339, 0. ,
-0.10355339, 0. , 0.60355339])
I don't know where that should be fixed.
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Numpy-discussion