Settings

Theme

Rendering Worlds with Two Triangles on the GPU [pdf]

iquilezles.org

109 points by muyyatin 11 years ago · 25 comments

Reader

algorias 11 years ago

Ah, the classic presentation that got me started in the demoscene a couple of years back.

The Google cache version of the pdf doesn't include any images, so I put up a copy over here:

https://dl.dropboxusercontent.com/u/2173295/rwwtt.pdf

userbinator 11 years ago

I think the most elegant thing about this method is that it describes a scene in terms of its basic mathematical 3D objects and transformations on them (list here: http://www.iquilezles.org/www/articles/distfunctions/distfun... ) and then exploits the massive parallelism of the GPU for rendering all the pixels.

Here's a demo of someone playing around with it, complete with a Slisesix-inspired scene: http://www.rpenalva.com/blog/?p=254

This set of slides is also related: http://www.iquilezles.org/www/material/function2009/function...

rogerallen 11 years ago

And if you want to try things out yourself, iq has created a playground for you here: https://www.shadertoy.com/

DanBC 11 years ago

I love these.

People might enjoy noodling around the Geisswerks pages which have many code snippets around ray tracing; graphic demos; and so on.

http://www.geisswerks.com/

sp332 11 years ago

You can download it from here http://www.pouet.net/prod.php?which=51074 It's been updated to run more reliably (edit: on Vista) but I can't find a version that will run on Win7.

Edit: I found a similar one on Shadertoy https://www.shadertoy.com/view/lsf3zr

hughes 11 years ago

I was working with distance fields back in 2008, and the idea of inverting the process blew my mind.

I had no idea Iñigo Quilez's image was produced this way and I'm so glad I had the chance to see how it was made.

Thanks for posting!!

yzzxy 11 years ago

Is the demoscene a good place to get into graphics programming? The prevalence of older methods leads me to believe one could learn in a similar progression to the graphics gurus of today, moving from simpler old methods with performance and size optimization to modern techniques?

DanAndersen 11 years ago

This is a really impressive presentation -- after looking on from afar at the seemingly magical works of the demoscene, this finally helped me understand a little bit of how the magic happens. I've only got a bit of GLSL experience so far but now I want to learn a lot more.

thisjepisje 11 years ago

Could someone explain to me what the "two triangles that cover the entire screen area" have to do with anything?

  • falsedan 11 years ago

    Two triangles make a flat screen (a 'quad'), which is sized to fill your actual screen. When you run a pixel shader over the quad, it ends up running for every pixel on your screen. The result is you have the visual effect of the pixel shader giving a very detailed-looking scene, when the actual geometry is as simple as it gets.

    Here's an old experiment I did where the pixel shader is running on the faces of a cube http://dgholz.github.io/GLSLSphere/ The cube edges are highlighted in red so you can see them. I like green.

  • greggman 11 years ago

    Basically you draw a single quad (2 triangles) covering the entire screen using OpenGL (or DirectX).

    A Pixel shader is run when rendering each pixel of the quad. It's only input is often `time` and `resolution`.

    At least in GLSL there's a global variable, `gl_Fragcoord` and provides the integer position of the pixel currently being drawn. So for example the pixel at the bottom left is gl_Fragcoord = vec2(0,0). The one directly to the right of that is gl_Fragcoord = vec2(0,1)

    Given you're also passed the resolution can get a value that goes from 0 to 1 over the screen with

       vec2 zeroToOne = gl_Fragcoord.xy / resolution;
    
    If you were to dump that value directly do the screen you'd get a red gradient going black to red from left to right and a green gradient from black to green going from bottom to top. See http://glsl.heroku.com/e#18516.0

    Now it's up to you to use more creative math that given just gl_Fragcoord, resolution, and time write a function that generates an image.

    You can play with that in your browser here, http://glsl.heroku.com and here http://shadertoy.com

    • 3rd3 11 years ago

      Wouldn't it be even easier to draw one triangle that extends beyond the screen so that it covers it entirely and let the pipeline clip it to the screen size?

    • thisjepisje 11 years ago

      So the whole point of using a shader is that it's the GPU that's doing all the work?

      • NickPollard 11 years ago

        Yes, that's what this trick is for.

        In most standard 3D graphics, the CPU passes a description of the scene as polygons to the GPU, which then does two[1] shader steps - vertex and fragment[2] shading. The vertex shading works at the level of triangle vertices, effectively translating and and transforming the vertices, and then the fragment shader colors in each individual pixel.

        So for a standard scene, the CPU tells the GPU: 'Right, we've got a room, with some pillars, and a monster, and a few lights, positioned like this', and then the CPU calculates what that looks like.

        What Inigo is doing is that the CPU only knows there are two triangles - a quad covering the scene - so it just tells the GPU to draw a flat rectangle. The vertex shader does nothing but maintain the flat rectangle. However, because the fragment shader can be arbitrary logic, rather than just painting it with a solid color or even a texture, it is running its own simulation that involves drawing an entire scene.

        ----

        [1] More these days with Geometry shaders, but that's another topic

        [2] Sometimes called a pixel shader, although really that's incorrect - Fragment is a more accurate term

  • bratsche 11 years ago

    It basically means everything is happening in the shaders, not in geometry. There has to be some vertexes though, and the minimum you can have to cover the screen is two triangles.

    • musawirali 11 years ago

      That is incorrect. You can cover the screen with a single triangle ... just make it big enough. The corners get clipped and the middle region of the big triangle will cover the screen.

      • lotsofmangos 11 years ago

        You can get around the clipping problem by displaying it on an old Interocitor.

      • dualogy 11 years ago

        True, both approaches are equally valid and being used. Every once in a while some gfx haxors also spend baffling amounts of effort on humorously "benchmarking" both approaches against each other.. ;)

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection