为多维数据和OpenMP创建FFTW计划

时间:2015-02-19 23:56:45

标签: multidimensional-array fortran openmp fftw

我在openMP环境中使用fftw_plan例程来处理2D数据时遇到问题。我的编译器是gfortran,我的操作系统是Ubuntu 12.04。我使用--enable-openmp选项编译了fftw,并且库似乎正确链接。但是,当我运行以下最小例子时遇到麻烦:

   PROGRAM test_fft_OMP

    USE, intrinsic :: iso_c_binding
    USE OMP_LIB
    IMPLICIT NONE
    INCLUDE 'fftw3.f03' 

    INTEGER*4, PARAMETER :: N=512

    REAL(C_DOUBLE),            DIMENSION(N)      :: dbgr   
    COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N/2+1)  :: dbgc     
    COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N)      :: dbgcc      
    COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N,N)    :: D2CA     
    COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N,N)    :: D2CB 
    REAL(C_DOUBLE),            DIMENSION(N,N)    :: D2R
    COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N/2+1,N):: D2C
    INTEGER                         :: nthreads, void
    TYPE(C_PTR) :: plan
    INTEGER(C_INT), DIMENSION(2) :: n2 = [N,N]
    INTEGER(C_INT), DIMENSION(1) :: n1 = [N]

    nthreads = omp_get_num_threads()
    void = fftw_init_threads()
    CALL fftw_plan_with_nthreads(nthreads)

    plan=fftw_plan_dft_c2r_1d(N,  dbgc , dbgr,FFTW_MEASURE)
   !plan=fftw_plan_dft_c2r_2d(N,N, D2C , D2R ,FFTW_MEASURE)
    plan=fftw_plan_dft_1d(N,  dbgcc , dbgcc,FFTW_FORWARD,FFTW_MEASURE)
    plan=fftw_plan_dft_2d(N,N, D2CA , D2CA ,FFTW_FORWARD,FFTW_MEASURE)
    plan=fftw_plan_dft(1,n1,   dbgc , dbgc ,FFTW_FORWARD,FFTW_MEASURE)
    plan=fftw_plan_dft(2,n2,   D2CA , D2CA ,FFTW_FORWARD,FFTW_MEASURE)
   !plan=fftw_plan_dft_2d(N,N, D2CA , D2CB ,FFTW_FORWARD,FFTW_MEASURE)
   !plan=fftw_plan_dft(2,n2,   D2CA , D2CB ,FFTW_FORWARD,FFTW_MEASURE)

    END PROGRAM test_fft_OMP

代码编译很好,使用

gfortran -fopenmp -o execmp test.f90 -I/usr/local/lib/ -L/usr/local/lib/ -lfftw3_omp -lfftw3 -lm -lpthread

但是,如果我取消注释三个!plan行中的任何一行,如果运行可执行文件,则会出现分段错误。 如果我总结一下我的问题:

  • 我可以为1D变换或2D就地变换创建计划

  • 无论使用何种语法,我都会因2D异常变换而出现seg错误

1 个答案:

答案 0 :(得分:1)

如果数组是静态声明而不是使用ALLOCATE进行动态内存分配,那么FFTW规划器会崩溃大数组(因此我的2D数组问题,但只能超过~512x512)。

更具体地说,这个变量声明会在调用fftw_plan时使程序崩溃,

COMPLEX(C_DOUBLE_COMPLEX), DIMENSION(N,N)    :: D2C

然而这个工作正常:

COMPLEX(C_DOUBLE_COMPLEX), ALLOCATABLE, DIMENSION(:,:)    :: D2C
ALLOCATE(D2C(N,N))