Skip to content

Commit

Permalink
Merge pull request #35 from cval26/dct-interface
Browse files Browse the repository at this point in the history
Combine dct and qct interfaces
  • Loading branch information
zoziha authored Mar 8, 2023
2 parents 6a53d6f + 62396ea commit b745bb8
Show file tree
Hide file tree
Showing 12 changed files with 512 additions and 620 deletions.
755 changes: 351 additions & 404 deletions doc/specs/fftpack.md

Large diffs are not rendered by default.

2 changes: 0 additions & 2 deletions src/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -31,9 +31,7 @@ set(FFTPACK_SOURCES
${dir}/fftpack_fftshift.f90
${dir}/fftpack_ifft.f90
${dir}/fftpack_ifftshift.f90
${dir}/fftpack_iqct.f90
${dir}/fftpack_irfft.f90
${dir}/fftpack_qct.f90
${dir}/fftpack_rfft.f90
${dir}/fftpack_utils.f90
${dir}/passb.f90
Expand Down
4 changes: 0 additions & 4 deletions src/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -57,8 +57,6 @@ SRCF90 = \
fftpack_irfft.f90\
fftpack_fftshift.f90\
fftpack_ifftshift.f90\
fftpack_qct.f90\
fftpack_iqct.f90\
fftpack_dct.f90\
rk.f90\
fftpack_utils.f90
Expand All @@ -82,8 +80,6 @@ fftpack_fft.o: fftpack.o rk.o
fftpack_ifft.o: fftpack.o rk.o
fftpack_rfft.o: fftpack.o rk.o
fftpack_irfft.o: fftpack.o rk.o
fftpack_qct.o: fftpack.o rk.o
fftpack_iqct.o: fftpack.o rk.o
fftpack_dct.o: fftpack.o rk.o
fftpack_fftshift.o: fftpack.o rk.o
fftpack_ifftshift.o: fftpack.o rk.o
Expand Down
40 changes: 10 additions & 30 deletions src/fftpack.f90
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,6 @@ module fftpack
public :: dzffti, dzfftf, dzfftb

public :: dcosqi, dcosqf, dcosqb
public :: qct, iqct

public :: dcosti, dcost
public :: dct, idct

Expand Down Expand Up @@ -246,46 +244,28 @@ end function irfft_rk

!> Version: experimental
!>
!> Forward transform of quarter wave data.
!> ([Specifiction](../page/specs/fftpack.html#qct))
interface qct
pure module function qct_rk(x, n) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
real(kind=rk), allocatable :: result(:)
end function qct_rk
end interface qct

!> Version: experimental
!>
!> Backward transform of quarter wave data.
!> ([Specifiction](../page/specs/fftpack.html#iqct))
interface iqct
pure module function iqct_rk(x, n) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
real(kind=rk), allocatable :: result(:)
end function iqct_rk
end interface iqct

!> Version: experimental
!>
!> Discrete fourier cosine (forward) transform of an even sequence.
!> Dsicrete cosine transforms.
!> ([Specification](../page/specs/fftpack.html#dct))
interface dct
pure module function dct_rk(x, n) result(result)
pure module function dct_rk(x, n, type) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
integer, intent(in), optional :: type
real(kind=rk), allocatable :: result(:)
end function dct_rk
end interface dct

!> Version: experimental
!>
!> Discrete fourier cosine (backward) transform of an even sequence.
!> Inverse discrete cosine transforms.
!> ([Specification](../page/specs/fftpack.html#idct))
interface idct
module procedure :: dct_rk
pure module function idct_rk(x, n, type) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
integer, intent(in), optional :: type
real(kind=rk), allocatable :: result(:)
end function idct_rk
end interface idct

!> Version: experimental
Expand Down
85 changes: 76 additions & 9 deletions src/fftpack_dct.f90
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,11 @@

contains

!> Discrete fourier cosine transform of an even sequence.
pure module function dct_rk(x, n) result(result)
!> Discrete cosine transforms of types 1, 2, 3.
pure module function dct_rk(x, n, type) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
integer, intent(in), optional :: type
real(kind=rk), allocatable :: result(:)

integer :: lenseq, lensav, i
Expand All @@ -23,14 +24,80 @@ pure module function dct_rk(x, n) result(result)
result = x
end if

!> Initialize FFT
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosti(lenseq, wsave)

!> Discrete fourier cosine transformation
call dcost(lenseq, result, wsave)
! Default to DCT-2
if (.not.present(type)) then
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqb(lenseq, result, wsave)
return
end if

if (type == 1) then ! DCT-1
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosti(lenseq, wsave)
call dcost(lenseq, result, wsave)
else if (type == 2) then ! DCT-2
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqb(lenseq, result, wsave)
else if (type == 3) then ! DCT-3
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqf(lenseq, result, wsave)
end if
end function dct_rk

!> Inverse discrete cosine transforms of types 1, 2, 3.
pure module function idct_rk(x, n, type) result(result)
real(kind=rk), intent(in) :: x(:)
integer, intent(in), optional :: n
integer, intent(in), optional :: type
real(kind=rk), allocatable :: result(:)

integer :: lenseq, lensav, i
real(kind=rk), allocatable :: wsave(:)

if (present(n)) then
lenseq = n
if (lenseq <= size(x)) then
result = x(:lenseq)
else if (lenseq > size(x)) then
result = [x, (0.0_rk, i=1, lenseq - size(x))]
end if
else
lenseq = size(x)
result = x
end if

! Default to t=2; inverse DCT-2 is DCT-3
if (.not.present(type)) then
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqf(lenseq, result, wsave)
return
end if

if (type == 1) then ! inverse DCT-1 is DCT-1
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosti(lenseq, wsave)
call dcost(lenseq, result, wsave)
else if (type == 2) then ! inverse DCT-2 is DCT-3
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqf(lenseq, result, wsave)
else if (type == 3) then ! inverse DCT-3 is DCT-2
lensav = 3*lenseq + 15
allocate (wsave(lensav))
call dcosqi(lenseq, wsave)
call dcosqb(lenseq, result, wsave)
end if
end function idct_rk

end submodule fftpack_dct
36 changes: 0 additions & 36 deletions src/fftpack_iqct.f90

This file was deleted.

36 changes: 0 additions & 36 deletions src/fftpack_qct.f90

This file was deleted.

1 change: 0 additions & 1 deletion test/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ endmacro()
set(FFTPACK_TEST_SOURCES
test_fftpack_dct.f90
test_fftpack_fft.f90
test_fftpack_qct.f90
test_fftpack_rfft.f90
test_fftpack_utils.f90
test_fftpack.f90
Expand Down
9 changes: 3 additions & 6 deletions test/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,11 @@ FETCH = curl -L
SRC = \
test_fftpack_fft.f90 \
test_fftpack_rfft.f90 \
test_fftpack_qct.f90 \
test_fftpack_dct.f90 \
test_fftpack_utils.f90 \
test_fftpack.f90 \
testdrive.F90

OBJ = $(SRC:.f90=.o)
OBJ := $(OBJ:.F90=.o)

Expand All @@ -24,10 +23,10 @@ tstfft: tstfft.f
test_fftpack: $(OBJ)
$(FC) $(FFLAGS) $(OBJ) -L../src -l$(LIB) -I../src -o $@.x
./test_fftpack.x

testdrive.F90:
$(FETCH) https://github.com/fortran-lang/test-drive/raw/v0.4.0/src/testdrive.F90 > $@

%.o: %.F90
$(FC) $(FFLAGS) -c $<

Expand All @@ -36,14 +35,12 @@ testdrive.F90:

test_fftpack.o: test_fftpack_fft.o \
test_fftpack_rfft.o \
test_fftpack_qct.o \
test_fftpack_dct.o \
test_fftpack_utils.o \
testdrive.o

test_fftpack_fft.o: testdrive.o
test_fftpack_rfft.o: testdrive.o
test_fftpack_qct.o: testdrive.o
test_fftpack_dct.o: testdrive.o
test_fftpack_utils.o: testdrive.o

Expand Down
2 changes: 0 additions & 2 deletions test/test_fftpack.f90
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ program test_fftpack
use testdrive, only: run_testsuite, new_testsuite, testsuite_type
use test_fftpack_fft, only: collect_fft
use test_fftpack_rfft, only: collect_rfft
use test_fftpack_qct, only: collect_qct
use test_fftpack_dct, only: collect_dct
use test_fftpack_utils, only: collect_utils
implicit none
Expand All @@ -16,7 +15,6 @@ program test_fftpack
testsuites = [ &
new_testsuite("fft", collect_fft), &
new_testsuite("rfft", collect_rfft), &
new_testsuite("qct", collect_qct), &
new_testsuite("dct", collect_dct), &
new_testsuite("utils", collect_utils) &
]
Expand Down
Loading

0 comments on commit b745bb8

Please sign in to comment.