Linear Analysis and Optimization of Stream Programs

  • Andrew A. Lamb ,
  • Bill Thies ,
  • Saman Amarasinghe

Conference on Programming Language Design and Implementation (PLDI 2003). San Diego, CA |

Publication

As more complex DSP algorithms are realized in practice, there is an increasing need for high-level stream abstractions that can be compiled without sacri ficing efficiency. Toward this end, we present a set of aggressive optimizations that target linear sections of a stream program. Our input language is StreamIt, which represents programs as a hierarchical graph of autonomous fi lters. A fi lter is linear if each of its outputs can be represented as an affine combination of its inputs. Linearity is common in DSP components; examples include FIR fi lters, expanders, compressors, FFTs and DCTs.

We demonstrate that several algorithmic transformations, traditionally hand-tuned by DSP experts, can be completely automated by the compiler. First, we present a linear extraction analysis that automatically detects linear filters from the C-like code in their work function. Then, we give a procedure for combining adjacent linear filters into a single filter, as well as for translating a linear fi lter to operate in the frequency domain. We also present an optimization selection algorithm, which finds the sequence of combination  and frequency transformations that will give the maximal benefi t.

We have completed a fully-automatic implementation of the above techniques as part of the StreamIt compiler, and we demonstrate a 450% performance improvement over our benchmark suite.