FFT_SERIAL
Fast Fourier Transform


FFT_SERIAL is a C program which demonstrates the computation of a Fast Fourier Transform, and is intended as a starting point for developing a parallel version using OpenMP.

On an Apple PowerPC G5 with two processors, the following results were observed:
NTimeMegaFLOPS
24.943500e-0720.2
41.217550e-0632.8
82.283850e-0652.5
165.334400e-0659.9
321.051800e-0576.0
642.125550e-0590.3
1283.229850e-05138.7
2567.576800e-05135.1
5121.544650e-04149.1
10243.537100e-04144.7
20487.222600e-04155.9
40961.636675e-03150.1
81923.392550e-03156.9
163847.518900e-03152.5
327681.601240e-02153.4
655363.534380e-02148.3
1310727.358900e-02151.3
2621441.712250e-01137.78
5242883.547840e-01140.3
10485767.744890e-01135.3

Related Data and Programs:

BT_SERIAL is a FORTRAN90 program which is a serial version of the NAS Parallel Benchmark BT (block tridiagonal solver for a 3D PDE).

CG_SERIAL is a FORTRAN77 program which is a serial version of the NAS Parallel Benchmark CG (conjugate gradient solver).

EP_SERIAL is a FORTRAN77 program which is a serial version of the NAS Parallel Benchmark EP (embarassingly parallel).

FFT_OPEN_MP is a C program which computes a Fast Fourier Transform using OpenMP.

FFT_SERIAL is available in a C version and a C++ version and a FORTRAN77 version and a FORTRAN90 version and a MATLAB version.

HEATED_PLATE is a C program which solves the steady state heat equation in a 2D rectangular region, and is intended as a starting point for implementing an OpenMP parallel version.

IS_SERIAL is a C program which is a serial version of the NAS Parallel Benchmark IS (integer sort).

MD is a C program which carries out a molecular dynamics simulation, and is intended as a starting point for developing a parallel version using OpenMP.

OPEN_MP is a directory of C examples which illustrate the use of the OpenMP application program interface for carrying out parallel computations in a shared memory environment.

Reference:

  1. Wesley Petersen, Peter Arbenz,
    Introduction to Parallel Computing - A practical guide with examples in C,
    Oxford University Press,
    ISBN: 0-19-851576-6,
    LC: QA76.58.P47.
  2. Rohit Chandra, Leonardo Dagum, Dave Kohr, Dror Maydan, Jeff McDonald, Ramesh Menon,
    Parallel Programming in OpenMP,
    Morgan Kaufmann, 2001,
    ISBN: 1-55860-671-8,
    LC: QA76.642.P32.
  3. Barbara Chapman, Gabriele Jost, Ruud vanderPas, David Kuck,
    Using OpenMP: Portable Shared Memory Parallel Processing,
    MIT Press, 2007,
    ISBN13: 978-0262533027,
    LC: QA76.642.C49.

Source Code:

Examples and Tests:

List of Routines:

You can go up one level to the C source codes.


Last revised on 29 March 2009.