data:image/s3,"s3://crabby-images/906b1/906b10c8e8460bee6a4b1ab113859a1ee6c00a58" alt="" |
data:image/s3,"s3://crabby-images/b3256/b325620d1202b3d2463a5e78b42420710e055145" alt=""
Submitted by , posted on 02 July 2001
|
data:image/s3,"s3://crabby-images/d1451/d14515f195ef99c05308ad64ac4cdc0ad29bb195" alt="" |
Image Description, by
data:image/s3,"s3://crabby-images/69965/69965670d518d2aa7fd31d9ef6b86f987323433f" alt=""
I haven't done any graphics programming in way too long, so tonight I
finally decided to get around to playing with an idea for
hardware-accelerated radiosity algorithm I've been pondering for a while.
These are two screenshots from the 6-hour hacking session, both with two
passes of my algorithm applied.
The algorithm is actually quite simple. Basically, for every vertex in the
scene, render a low-resolution version of the scene from its viewpoint.
Take the average of all the pixels and add in the surface's emission, and
there you have the light value. I played with various weighted averages to
try to account for angle of incidence and such, but I actually got the best
results by just taking an unweighted average of the pixels on a 128x128
image rendered with a 60-degree field of view.
The algorithm is pretty slow. Each pass took about a minute and a half for
the top image (the bottom image was a lot faster, though I didn't time it).
However, once the lighting is computed, it renders at about 150FPS on my
machine (Matrox G400 running under Linux on a Duron 850). Of course, after
the radiosity is calculated, the engine is a pure polygon-pusher, so the
framerate isn't really *that* impressive. :)
A fun thing about the implementation is that you get to watch the radiosity
calculations as they're going. I got pretty dizzy when it was working on
the spheres though. :)
--
Joshua Shagam
joshagam@cs.nmsu.edu
www.cs.nmsu.edu/~joshagam
|
|