news | Major Feature Added | 2008-08-26 |
A Major Feature has been added to picogen
Last week I sat down and wrote yet another incarnation of a Quadtree Acceleration Structure. A quadtree is a hierarchy of nodes, which makes selecting those parts of the heightmap that actually contribute to the image very fast and effective.
A primitive like Quadtree enables the users of picogen to render heightmaps of high resolution in a relatively small amount of time. The biggest limit I discovered was actually the address space of 32bit CPUs, and as such CPUs are not uncommon even in these times with 64bit CPUs I have to add several features to the Quadtree:
- Lazy Building: Build nodes in the hierarchy only if they are actually needed. Tests have shown that the size of the Quadtree can be reduced to 1/6th of the original size, and even less.
- Explicit Paging: Enable storage of rarely used nodes on harddisk (or similar) devices so that RAM pressure is reduced.
- Sub Pixel LOD: It is common that nodes in the Quadtree are much smaller than a Pixel, so determine the maximum (sane) level of detail for nodes. This will also help out the Explicit Paging above.
81932 ~= 130 MTriangles
This image reminds of a place where there has been a glacier hundreds of years ago, malming this chaos into stone.
Rendered with picogen. This image is a presentation of the quad-tree implementation I have hacked this week. It was capable of rendering this image with 800 samples per pixel in around 7 hours, on one crappy Athlon XP singlecore (2400+). The resolution of the heightfield is 8193*8193, or around 130 Million Triangles. I believe in that I can render 16385*16385 on my box, with smaller nodes maybe even more.
Note that this quadtree has to do with the upcoming release of picogen 0.2, the first release that is capable of rendering userspace stuff; until now all images were pure programmers art, hardcoded into the sourcecode; what you see heree is fully defined in a so called SSDF-file (==static scene description format), exactly like this:
The actual scene definition file for this image is rather small:
list{
brdf = lambertian(reflectance:0.8)
hs-heightfield(resolution:8193; center:0,-5,0; size:50,5,50; code: (^ (- 1 (abs ([2 LayeredNoise frequency(15) layercount(12) seed(123) persistence((* 0.56 (-1 (abs x))))] (* x 0.5) (* y 0.5)))) 3) )
}
camera-yaw-pitch-roll(position:20,-4.0,-20.0; yaw:-0.7; pitch:0.0)
sunsky (turbidity:2.2)
sunsky (direction: 0.01,0.7,1.0)
sunsky (color-filter-rgb: 0.2, 0.2, 0.2 )
sunsky (sun-color-rgb: 900, 800, 700)
sunsky (fog-exponent: 0.05; fog-max-distance:100000)
163852 ~= 536 Million Triangles
interesting: i had to boot up my box in windoze because i had to scan some sheet of paper. so i did hibernate my running session, where 'session' includes the ongoing rendition of the above image. i do my hibernation via s2disk, which, unllike tuxonice, does not pump everything back into ram after un-hibernation. so the job of paging stuff from swap back into RAM is left to the kernel.
the point now is: the above render took 2.7 GiB of my 2.0 GiB RAM, what is above is paged out into swap, actually there was 1.8 GiB in RAM, before hibernation. after un-hibernation and relaxing back, picogen was running in only 470 MB. so what I conclude is that even in this scene, where i set the size to xyz(50.0, 5.0, 50.0), only a good 1/6 of the acceleration structure is actually needed (and so paged back into RAM). what i condlude from that is that it should be highly worthful to support some kind of explicit paging directly in the AS, as Thatcher Ulrich suggested it.
when you think of it, and that 1/6 ratio is common for such scenes (but i expect even lower ratios for larger terrain) good paging should enable me to render 32^2k-heightmaps and more, resulting in 2 GiTris and more .... *buff* :D
some stats:
- 666 samples, so this is an unholy rendition (pure accident, really)
- 8 hours of rendition (including 30 minutes of quad-tree creation (itself including the sampling of the heightfunction))
- one core (Athlon XP 2200+, uh oh)
Rendition vs. Heightmap
Here you can see a comparison of a top-down rendition of a heightmap, and the according heightmap.
Finis
If I made you at least a bit snoopy, have a look at the Roadmap.
Thanks for keeping up, ciao!