- Computer Science - Jul 29 First major database of non- native English
- Medicine - Jul 28 Plumbing the possibilities of seeing around corners?
- Computer Science - Jul 26 Password Perceptions Don’t Always Match Reality
- History - Jul 26 Websites with history can be just as conversational as chatting with a person
- Computer Science - Jul 21 Imaging software predicts how you look with different hair styles, colors, appearances
- Medicine - Jul 21 Hearing what the community has to say about e-health
- Physics - Jul 20 New Yale- developed device lengthens the life of quantum information
- Life Sciences - Jul 19 UW professor is digitizing every fish species in the world
- Mathematics - Jul 18 Computational Design Tool Transforms Flat Materials Into 3-D Shapes
- Physics - Jul 18 A Playful Approach to Quantum Computing
- Life Sciences - Jul 13 Exploring networks efficiently
- Life Sciences - Jul 11 Giving animals a voice - computer software that could tell us what they are thinking
- Computer Science - Jul 11 How to stay anonymous online
- Computer Science - Jul 11 Ethical Questions Must Be Asked About Use of Police Robot
- Computer Science - Jul 8 Solar Superstorms? invited to show at SIGGRAPH 2016
- Medicine - Jul 8 Phone calls can forecast dengue fever outbreaks

# The faster-than-fast Fourier transform

18 January 2012

** For a large range of practically useful cases, MIT researchers find a way to increase the speed of one of the most important algorithms in the information sciences. **

The reason the Fourier transform is so prevalent is an algorithm called the fast Fourier transform (FFT), devised in the mid-1960s, which made it practical to calculate Fourier transforms on the fly. Ever since the FFT was proposed, however, people have wondered whether an even faster algorithm could be found.

At the Association for Computing Machinery’s Symposium on Discrete Algorithms (SODA) this week, a group of MIT researchers will present a new algorithm that, in a large range of practically important cases, improves on the fast Fourier transform. Under some circumstances, the improvement can be dramatic -- a tenfold increase in speed. The new algorithm could be particularly useful for image compression, enabling, say, smartphones to wirelessly transmit large video files without draining their batteries or consuming their monthly bandwidth allotments.

Like the FFT, the new algorithm works on digital signals. A digital signal is just a series of numbers -- discrete samples of an analog signal, such as the sound of a musical instrument. The FFT takes a digital signal containing a certain number of samples and expresses it as the weighted sum of an equivalent number of frequencies.

"Weighted" means that some of those frequencies count more toward the total than others. Indeed, many of the frequencies may have such low weights that they can be safely disregarded. That’s why the Fourier transform is useful for compression. An eight-by-eight block of pixels can be thought of as a 64-sample signal, and thus as the sum of 64 different frequencies. But as the researchers point out in their new paper, empirical studies show that on average, 57 of those frequencies can be discarded with minimal loss of image quality.

**Heavyweight division**

Signals whose Fourier transforms include a relatively small number of heavily weighted frequencies are called "sparse." The new algorithm determines the weights of a signal’s most heavily weighted frequencies; the sparser the signal, the greater the speedup the algorithm provides. Indeed, if the signal is sparse enough, the algorithm can simply sample it randomly rather than reading it in its entirety.

"In nature, most of the normal signals are sparse," says Dina Katabi, one of the developers of the new algorithm. Consider, for instance, a recording of a piece of chamber music: The composite signal consists of only a few instruments each playing only one note at a time. A recording, on the other hand, of all possible instruments each playing all possible notes at once wouldn’t be sparse -- but neither would it be a signal that anyone cares about.

The new algorithm -- which associate professor Katabi and professor Piotr Indyk, both of MIT’s Computer Science and Artificial Intelligence Laboratory (CSAIL), developed together with their students Eric Price and Haitham Hassanieh -- relies on two key ideas. The first is to divide a signal into narrower slices of bandwidth, sized so that a slice will generally contain only one frequency with a heavy weight.

In signal processing, the basic tool for isolating particular frequencies is a filter. But filters tend to have blurry boundaries: One range of frequencies will pass through the filter more or less intact; frequencies just outside that range will be somewhat attenuated; frequencies outside that range will be attenuated still more; and so on, until you reach the frequencies that are filtered out almost perfectly.

If it so happens that the one frequency with a heavy weight is at the edge of the filter, however, it could end up so attenuated that it can’t be identified. So the researchers’ first contribution was to find a computationally efficient way to combine filters so that they overlap, ensuring that no frequencies inside the target range will be unduly attenuated, but that the boundaries between slices of spectrum are still fairly sharp.

**Zeroing in**

Once they’ve isolated a slice of spectrum, however, the researchers still have to identify the most heavily weighted frequency in that slice. In the SODA paper, they do this by repeatedly cutting the slice of spectrum into smaller pieces and keeping only those in which most of the signal power is concentrated. But in an as-yet-unpublished paper , they describe a much more efficient technique, which borrows a signal-processing strategy from 4G cellular networks. Frequencies are generally represented as up-and-down squiggles, but they can also be though of as oscillations; by sampling the same slice of bandwidth at different times, the researchers can determine where the dominant frequency is in its oscillatory cycle.

**Written by:**Larry Hardesty

» Comment on this page.

**Last job offers**

- Computer Science/Telecom - 20.7

Forschungsdozentin / Forschungsdozent mit Schwerpunkt IT Security - Computer Science/Telecom - 14.7

Wissensch. Assistent/in Programmierung - Mathematics - 13.7

Wissenschaftliche/r Mitarbeiter/in 80-100% - Mathematics - 8.7

Faculty Position in Statistics - Mathematics - 8.7

Faculty Position in Mathematics - Computer Science/Telecom - 5.7

Doktoranden / Doktorandin im Fachbereich Data Intelligence (70%) - Life Sciences - 22.7

Asst./Assoc. Professor of Bioinformatics for Human Diseases - Computer Science/Telecom - 13.7

Professor of Emerging Dependable Computing Technologies - Computer Science/Telecom - 19.7

§ 98 Professur - Computer Science/Telecom - 27.8

Professur für Praktische Informatik, mit Schwerpunkt Computational Life Science - Mathematics - 29.7

Professur für Mathematik mit dem Schwerpunkt Analysis - Computer Science/Telecom - 28.7

Professur (W3) für Informatik mit dem Schwerpunkt "IT-Sicherheit, Privacy und Kryptographie", Kennziffer... - Computer Science/Telecom - 27.7

Assistant Professor in Computer Science - Mechanical Engineering - 27.7

Associate Professor (TF) in Engineering Science - Computational Fluid Dynamics - Mathematics - 28.7

Assistant Professor - Mathematics - 22.7

Assistant or Associate Professor of Statistics / Biostatistics of Health Care Policy