A Methodology for Speeding Up Fast Fourier Transform Focusing on Memory Architecture Utilization
Autor: | Vasilios Kelefouras, Angeliki Kritikakou, N. Alachiotis, Constantinos E. Goutis, George Athanasiou, Harris E. Michail |
---|---|
Rok vydání: | 2011 |
Předmět: |
Computer science
Cache coloring CPU cache Cache memory Fast Fourier transform Pentium Parallel computing Cache-oblivious algorithm Cache pollution symbols.namesake Cache invalidation Memory architecture Multiplication Electrical and Electronic Engineering Page Cache algorithms Compilers (Computer programs) Hardware_MEMORYSTRUCTURES Memory hierarchy Electrical Engineering - Electronic Engineering - Information Engineering Embedded computer systems Fourier transform Memory management Signal Processing symbols Engineering and Technology Cache Twiddle factor |
Zdroj: | IEEE Transactions on Signal Processing. 59:6217-6226 |
ISSN: | 1941-0476 1053-587X |
DOI: | 10.1109/tsp.2011.2168525 |
Popis: | Several SOA (state of the art) self-tuning software libraries exist, such as the Fastest Fourier Transform in the West (FFTW) for fast Fourier transform (FFT). FFT is a highly important kernel and the performance of its software implementations depends on the memory hierarchy's utilization. FFTW minimizes register spills and data cache accesses by finding a schedule that is independent of the number of the registers and of the number of levels and size of the cache, which is a serious drawback. In this paper, a new methodology is presented, achieving improved performance by focusing on memory hierarchy utilization. The proposed methodology has three major advantages. First, the combination of production and consumption of butterflies' results, data reuse, FFT parallelism, symmetries of twiddle factors and also additions by zeros and multiplications by zeros and ones when twiddle factors are zero or one, are fully and simultaneously exploited. Second, the optimal solution is found according to the number of the registers, the data cache sizes, the number of the levels of data cache hierarchy, the main memory page size, the associativity of the data caches and the data cache line sizes, which are also considered simultaneously and not separate. Third, compilation time and source code size are very small compared with FFTW. The proposed methodology achieves performance gain about 40% (speed-up of 1.7) for architectures with small data cache sizes where memory management has a larger effect on performance and 20% (speed-up of 1.25) on average for architectures with large data cache sizes (Pentium) in comparison with FFTW. |
Databáze: | OpenAIRE |
Externí odkaz: |