Share on Facebook Tweet on Twitter Share on LinkedIn Share by email
GRAMPS: A programming model for graphics pipelines

Jeremy Sugerman, Kayvon Fatahalian, Solomon Boulos, Kurt Akeley, and Pat Hanrahan

Abstract

We introduce GRAMPS, a programming model that generalizes concepts from modern real-time graphics pipelines by exposing a model of execution containing both fixed-function and application-programmable processing stages that exchange data via queues. GRAMPS allows the number, type, and connectivity of these processing stages to be defined by software, permitting arbitrary processing pipelines or even processing graphs. Applications achieve high performance using GRAMPS by expressing advanced rendering algorithms as custom pipelines, then using the pipeline as a rendering engine. We describe the design of GRAMPS, then evaluate it by implementing three pipelines, that is, Direct3D, a ray tracer, and a hybridization of the two, and running them on emulations of two different GRAMPS implementations: a traditional GPU-like architecture and a CPU-like multicore architecture. In our tests, our GRAMPS schedulers run our pipelines with 500 to 1500KB of queue usage at their peaks.

Details

Publication typeArticle
Published inACM Trans. Graph.
URLhttp://doi.acm.org/10.1145/1477926.1477930
Pages1–11
Volume28
Number1
AddressNew York, NY, USA
PublisherACM
> Publications > GRAMPS: A programming model for graphics pipelines