Woops, one should not test with input of all zeros

This commit is contained in:
Mark Borgerding 2003-10-29 04:29:01 +00:00
parent 97b18f3fef
commit ca4c74e07c
6 changed files with 96 additions and 70 deletions

View File

@ -7,5 +7,5 @@ tarball: clean
clean:
cd sample_code && make clean
rm -f kiss_fft.tar.gz *~ *.pyc kiss_fft.zip
rm -f kiss_fft.tar.gz *~ *.pyc kiss_fft.zip fft.py

View File

@ -269,8 +269,8 @@ void * kiss_fft_alloc(int nfft,int inverse_fft)
}
while (nfft>1) {
/* If you add a new radix, don't forget to put it here */
const int primes[] = {4,2,-1};
/* If you want a new radix, don't forget to put it here */
const int primes[] = {4,2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,-1};
int p=nfft;
i=0;
while ( primes[i] != -1 ) {

View File

@ -3,7 +3,6 @@ ifeq "$(NFFT)" ""
NFFT=1024
endif
ALLUTILS=kfft kffts kfftd
ifeq "$(NUMFFTS)" ""
NUMFFTS=10000
@ -13,50 +12,54 @@ UTILSRC=../kiss_fft.c fftutil.c
CFLAGS=-Wall -O3 -lm -I.. -ansi -pedantic
all: $(ALLUTILS)
ifeq "$(DATATYPE)" ""
DATATYPE=float
endif
UTIL=fftutil_$(DATATYPE)
kfft: $(UTILSRC)
echo $(FUNCDECL)
gcc -o $@ $(CFLAGS) $(UTILSRC)
kffts: $(UTILSRC)
gcc -o $@ $(CFLAGS) -DFIXED_POINT $(UTILSRC)
kfftd: $(UTILSRC)
gcc -o $@ $(CFLAGS) -Dkiss_fft_scalar=double $(UTILSRC)
time: all
@echo
all: $(UTIL)
ifeq "$(DATATYPE)" "short"
TYPEFLAGS=-DFIXED_POINT -Dkiss_fft_scalar=short
else
TYPEFLAGS=-Dkiss_fft_scalar=$(DATATYPE)
endif
$(UTIL): $(UTILSRC)
gcc -o $@ $(CFLAGS) $(TYPEFLAGS) $(UTILSRC)
RANDDAT=rand_$(DATATYPE)_$(NUMFFTS)_$(NFFT).dat
$(RANDDAT):
./rand_fft_data.py -n $(NUMFFTS) -N $(NFFT) -t $(DATATYPE) > $(RANDDAT)
time: all $(RANDDAT)
@echo
@echo -n "#### timing $(NUMFFTS) x $(NFFT) point FFTs. "; factor $(NFFT)
@echo "#### DOUBLE"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((16*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kfftd>/dev/null'
@echo "#### FLOAT"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((8*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kfft>/dev/null'
@echo "#### SHORT"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((4*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kffts>/dev/null'
@if [ -x ~/fftw/st ] && [ $(DATATYPE) == "double" ]; then \
echo "#### FFTW FFT $(DATATYPE)"; \
time ~/fftw/st -n $(NFFT) < $(RANDDAT) > /dev/null;\
fi
@echo "#### KISS FFT $(DATATYPE)"
@time ./$(UTIL) -n $(NFFT) < $(RANDDAT) > /dev/null
@rm $(RANDDAT)
POW2=256 512 1024 2048
POW3=243 729 2187
mtime: all
@for n in $(POW2) ;do \
@for n in $(POW2) $(POW3) ;do \
export NFFT=$$n;make time; \
done
snr: all
@which octave
@echo
@echo "### testing SNR for $(NFFT) point FFTs"
@echo "#### DOUBLE"
@echo "testkiss($(NFFT),'double',1,1/$(NFFT));" | octave -q
@echo "#### FLOAT"
@echo "testkiss($(NFFT),'float',1,1/$(NFFT));" | octave -q
@echo "#### SHORT"
@echo "testkiss($(NFFT),'short',$(NFFT),$(NFFT));" | octave -q
@echo "### testing SNR for $(NFFT) point FFTs"
@echo "#### $(DATATYPE)"
@echo "testkiss($(NFFT),'$(DATATYPE)',1,1/$(NFFT));" | octave -q
test: snr time
clean:
rm -f $(ALLUTILS) *.dat *~
rm -f *.dat *~ fftutil_*

26
test/rand_fft_data.py Executable file
View File

@ -0,0 +1,26 @@
#!/usr/local/bin/python2.3
import sys
import random
import struct
def main():
from getopt import getopt
opts,args = getopt(sys.argv[1:],'n:N:t:l:h:')
opts=dict(opts)
nbufs = int( opts.get('-n','10000') )
nfft = int( opts.get('-N','1024') )
type = opts.get('-t','f')
lo = float(opts.get('-l','-32768') )
hi = float(opts.get('-h','32767') )
format = {'float':'f','short':'h','double':'d'}[type]
nums = [ random.uniform(lo,hi) for i in range(nfft*2) ]
buf = struct.pack( '%d%s' % ( len( nums ) , format ) , *nums )
for i in range(nbufs):
sys.stdout.write( buf )
if __name__ == '__main__':
main()

View File

@ -8,13 +8,7 @@ endif
if nargin<4, scale_f2t=1
endif
if strcmp(prec,'short'),
kfft='./kffts';
elseif strcmp(prec,'double')
kfft='./kfftd';
else
kfft='./kfft';
endif
kfft= sprintf('./fftutil_%s',prec);
siglen = nfft;
sig=floor(32767*rand(1,siglen)) + j*floor(32767*rand(1,siglen));

View File

@ -3,7 +3,6 @@ ifeq "$(NFFT)" ""
NFFT=1024
endif
ALLUTILS=kfft kffts kfftd
ifeq "$(NUMFFTS)" ""
NUMFFTS=10000
@ -13,50 +12,54 @@ UTILSRC=../kiss_fft.c fftutil.c
CFLAGS=-Wall -O3 -lm -I.. -ansi -pedantic
all: $(ALLUTILS)
ifeq "$(DATATYPE)" ""
DATATYPE=float
endif
UTIL=fftutil_$(DATATYPE)
kfft: $(UTILSRC)
echo $(FUNCDECL)
gcc -o $@ $(CFLAGS) $(UTILSRC)
kffts: $(UTILSRC)
gcc -o $@ $(CFLAGS) -DFIXED_POINT $(UTILSRC)
kfftd: $(UTILSRC)
gcc -o $@ $(CFLAGS) -Dkiss_fft_scalar=double $(UTILSRC)
time: all
@echo
all: $(UTIL)
ifeq "$(DATATYPE)" "short"
TYPEFLAGS=-DFIXED_POINT -Dkiss_fft_scalar=short
else
TYPEFLAGS=-Dkiss_fft_scalar=$(DATATYPE)
endif
$(UTIL): $(UTILSRC)
gcc -o $@ $(CFLAGS) $(TYPEFLAGS) $(UTILSRC)
RANDDAT=rand_$(DATATYPE)_$(NUMFFTS)_$(NFFT).dat
$(RANDDAT):
./rand_fft_data.py -n $(NUMFFTS) -N $(NFFT) -t $(DATATYPE) > $(RANDDAT)
time: all $(RANDDAT)
@echo
@echo -n "#### timing $(NUMFFTS) x $(NFFT) point FFTs. "; factor $(NFFT)
@echo "#### DOUBLE"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((16*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kfftd>/dev/null'
@echo "#### FLOAT"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((8*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kfft>/dev/null'
@echo "#### SHORT"
@time -f 'Elapsed:%E user:%U sys:%S' \
sh -c 'dd if=/dev/zero bs=$$((4*$(NFFT))) count=$(NUMFFTS) 2>/dev/null |./kffts>/dev/null'
@if [ -x ~/fftw/st ] && [ $(DATATYPE) == "double" ]; then \
echo "#### FFTW FFT $(DATATYPE)"; \
time ~/fftw/st -n $(NFFT) < $(RANDDAT) > /dev/null;\
fi
@echo "#### KISS FFT $(DATATYPE)"
@time ./$(UTIL) -n $(NFFT) < $(RANDDAT) > /dev/null
@rm $(RANDDAT)
POW2=256 512 1024 2048
POW3=243 729 2187
mtime: all
@for n in $(POW2) ;do \
@for n in $(POW2) $(POW3) ;do \
export NFFT=$$n;make time; \
done
snr: all
@which octave
@echo
@echo "### testing SNR for $(NFFT) point FFTs"
@echo "#### DOUBLE"
@echo "testkiss($(NFFT),'double',1,1/$(NFFT));" | octave -q
@echo "#### FLOAT"
@echo "testkiss($(NFFT),'float',1,1/$(NFFT));" | octave -q
@echo "#### SHORT"
@echo "testkiss($(NFFT),'short',$(NFFT),$(NFFT));" | octave -q
@echo "### testing SNR for $(NFFT) point FFTs"
@echo "#### $(DATATYPE)"
@echo "testkiss($(NFFT),'$(DATATYPE)',1,1/$(NFFT));" | octave -q
test: snr time
clean:
rm -f $(ALLUTILS) *.dat *~
rm -f *.dat *~ fftutil_*