Graphics cards for personal computers have recently undergone a radical transformation from fixed-function graphics pipelines to multi-processor, programmable architectures. Multi-processor architectures are clearly advantageous for graphics for the simple reason that graphics computations are naturally concurrent, mapping well to stateless stream processing. They therefore parallelize easily and need no random access to memory with its problematic latencies.This paper presents Vertigo, a purely functional, Haskell-embedded language for 3D graphics and an optimizing compiler that generates graphics processor code. The language integrates procedural surface modeling, shading, and texture generation, and the compiler exploits the unusual processor architecture. The shading sub-language is based on a simple and precise semantic model, in contrast to previous shading languages. Geometry and textures are also defined via a very simple denotational semantics. The formal semantics yields not only programs that are easy to understand and reason about, but also very efficient implementation, thanks to a compiler based on partial evaluation and symbolic optimization, much in the style of Pan [2].Haskell's overloading facility is extremely useful throughout Vertigo. For instance, math operators are used not just for floating point numbers, but also expressions (for differentiation and compilation), tuples, and functions. Typically, these overloadings cascade, as in the case of surfaces, which may be combined via math operators, though they are really functions over tuples of expressions on floating point numbers. Shaders may be composed with the same notational convenience. Functional dependencies are exploited for vector spaces, cross products, and derivatives.
[1]
Jerzy Karczmarczuk,et al.
Geometric Modelling in Functional Style
,
1999
.
[2]
Pat Hanrahan.
Why is graphics hardware so fast?
,
2005,
PPOPP.
[3]
Pat Hanrahan,et al.
A real-time procedural shading system for programmable graphics hardware
,
2001,
SIGGRAPH.
[4]
Alfred V. Aho,et al.
Compilers: Principles, Techniques, and Tools
,
1986,
Addison-Wesley series in computer science / World student series edition.
[5]
Pat Hanrahan,et al.
A language for shading and lighting calculations
,
1990,
SIGGRAPH.
[6]
John M. Snyder,et al.
Generative Modeling for Computer Graphics and Cad: Symbolic Shape Design Using Interval Analysis
,
1992
.
[7]
John Launchbury,et al.
Implicit parameters: dynamic scoping with static types
,
2000,
POPL '00.
[8]
J. Munkres,et al.
Calculus on Manifolds
,
1965
.
[9]
Erik Lindholm,et al.
A user-programmable vertex engine
,
2001,
SIGGRAPH.
[10]
Oege de Moor,et al.
Compiling embedded languages
,
2003,
J. Funct. Program..
[11]
John M. Snyder,et al.
Generative modeling: a symbolic system for geometric modeling
,
1992,
SIGGRAPH.
[12]
Randima Fernando,et al.
The CG Tutorial: The Definitive Guide to Programmable Real-Time Graphics
,
2003
.