Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van...

42
Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed

Transcript of Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van...

Page 1: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Surfels : Surface Elements as Rendering Primitives

Hanspeter Pfister

Matthias Zwicker

Jeroen van Baar

Markus GrossPresented by Kevin Reed

Page 2: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Introduction

Page 3: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Problems with Current Graphics Rendering Systems

• Interactive computer graphics has not reached the level of realism that allows true immersion into a virtual world

• 3D models are usually minimalistic polygon models that often exhibit faceting artifacts, such as angular silhouettes

• Rendering realistic, organic looking models requires highly complex shapes with a huge number of triangles

• Processing many small triangles leads to bandwidth bottlenecks and excessive floating point and rasterization requirements

Page 4: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Texture Mapping

• Texture mapping can be used to convey more details inside a polygon and allow fewer triangles to be used, however, this still doesn’t solve all the problems

• Texture maps have to follow the underlying geometry of the polygon model and work best on flat or slightly curved surfaces

• Realistic surface frequently require a large number of textures that have to be applied in multiple passes during rasterization

• Phenomena such as smoke, fire, and water are difficult to render using texture triangles

Page 5: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

New Solution: Surfels

• This paper proposes a new method of rendering objects with rich shapes and textures at interactive frame rates

• The method of rendering presented is based on using simple surface elements (surfels) as rendering primitives.

• Surfels are point samples of a graphics model– This paper defines a surfel as a zero-dimensional n-tuple with shape and

shade attributes that locally approximate an object’s surface

• In a preprocessing step, surface samples of a model are taken along three orthographic views, and at the same time, computation-intensive calculations such as texture, bump, or displacement mapping are done

• By moving rasterization and texturing to a preprocessing step, rendering cost is dramatically reduced

Page 6: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More Surfel Introduction

• Surfel representation provides a discretization of the geometry and reduces the object representation to the essentials needed for rendering, where triangle primitives implicitly store connectivity information, such as vertex valence or adjacency - data not needed for rendering

• Shading and transformations applied per surfel result in Phong illumination, bump, and displacement mapping, as well as other advanced rendering features

• The surfel rendering pipeline is intended to compliment the existing graphics pipeline, not replace it

• Surfels are not well suited to represent flat surfaces like walls or scene backgrounds, but work well for models with rich, organic shapes or high surface details and for applications where preprocessing is not an issue

Page 7: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Related Work

• Points have been used as rendering primitives in computer graphics for a long time

• Particles have been used to represent objects that can’t be rendered with geometry, such as clouds, explosions, and fire

• Image based rendering has recently become popular

• Visually complex objects have been represented by dynamically generated image sprites

• A similar approach was used by the Talisman rendering system

• Mapping objects to planar polygons leads to visibility errors and doesn’t allow for parallax and disocclusion effects

• Storing per pixel depth information can fix some of these problems, but still these techniques don’t provide a complete object model that can be illuminated and rendered from arbitrary points of view

Page 8: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More image based methods

• Other image based methods represent objects without explicitly storing any geometry or depth

• View interpolation, Quicktime VR, and plenoptic modeling create views from a collection of 2D images

• Lightfield or lumigraph techniques describe the radiance of a scene or object as a function of position and direction in a four or higher dimensional space

• All these methods use view-dependent samples, which don’t work for dynamic scenes with motion of objects and changes in material properties and light sources

• Surfels, unlike these methods, represent and object in a view-independent, object-centered fashion

Page 9: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Inspiration for Research

• Animatek’s Caviar player, which provides interactive frame rates for surface voxel models on a Pentium class PC

• Levoy and Whitted use points to model objects for the special case of continuous, differentiable surfaces

• Max uses point samples from orthographic views to render trees

• Dally et al. introduce delta trees as an object centered approach to image-based rendering

• Grossman and Dally describe a point sample representation for fast rendering of complex objects

• Chang et al. Presented the LDI tree, a hierarchical space-partitioning data structure for image-based rendering

Page 10: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Conceptual Overview

• Process consists of two main steps: sampling and surfel rendering

Page 11: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Preprocessing• Sampling of geometry and textures is done during preprocessing,

which may also include other view-independent methods like bump and displacement mapping– The sampling process converts geometric objects and their textures to

surfels.

– The surfels created store both shape, such as surface position and orientation, and shade, such as multiple levels of prefiltered texture colors

• This hierarchical color information is called a surfel mipmap because of its similarities to traditional texture mipmap

Page 12: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Preprocessing, cont.• Ray casting is done to create three orthogonal layered depth images

(LDIs). The LDIs store multiple surfels along each ray, one for each ray-surface intersection point. – Lischinski and Rappaport call this arrangement of three orthogonal LDIs a

layered depth cube (LDC).

• The LDCs are organized into an efficient hierarchical data structure called and LDC tree.– This structure is based on the LDI tree, an octree with an LDI attached to

each node, introduced by Chang et al.

– The LDC tree uses the same structure but stores an LDC at each node

– Each node is called a block

Page 13: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More Preprocessing

• In a step called 3-1 reduction, the LDCs can be optionally reduced to single LDIs on a block-by-block basis for faster rendering

Page 14: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Rendering• The rendering pipeline hierarchically projects blocks to screen space

using a perspective projection

• Rendering is accelerated by block culling and fast incremental forward warping

• The projected surfel density in the output image is estimated to control rendering speed and quality of image reconstruction

• A conventional z-buffer together with a method called visibility splatting solves the visibility problem.

• Texture colors of visible surfels are filtered using linear interpolation between appropriate levels of the surfel mipmap

Page 15: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Rendering, cont.

• Each visible surfel is shaded (paper mentions Phong illumination and reflection mapping)

• Finally image reconstruction is done from visible surfels, including filling holes and antialiasing

Page 16: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Sampling

• The goal during sampling is to find an optimal surfel representation of the geometry with minimal redundancy

• Most sampling methods perform object discretization as a function of geometric parameters of the surface, such as curvature or silhouettes– This object space discretization typically leads to too many or too few

primitives for rendering

• In a surfel representation, object sampling is aligned to image space and matches the expected output resolution of the image

Page 17: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

LDC Sampling

• Geometric models are sampled from three sides of a cube into three orthogonal LDIs, called a layered depth cube or block

• Ray casting records all intersections, including those with back-facing sufels

• At each intersection, a surfel is created with floating point depth and other shape and shade properties

• Perturbations of the surface normal or of geometry for bump and displacement mapping can be done before sampling or during ray casting using procedural shaders

Page 18: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Adequate Sampling Resolution• Given a pixel spacing of h0 for the full resolution LDC used for sampling,

we can determine the resulting sampling density on the surface

• If we construct a Delaunay triangulation on the object surface using the generated surfels as triangle vertices, the imaginary triangle mesh generated by this process has a maximum sidelength smax of 3h0 and minimum sidelength smin of 0 when two or three sampling rays intersect at the same surface position.

• The object is adequately sampled if we can guarantee that at least one surfel is projected into the support of each output pixel filter for othographic projection and unit magnification

– That condition is met if smax is less that the radius rrec of the desired pixel reconstruction filter

– Typically, the LDI resolution is chosen to be slightly higher than this because of the effects of magnification and perspective projection

Page 19: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Texture Prefiltering

• In surfel rendering, textures are prefiltered and mapped to object space during preprocessing

• View-independent texture filtering is used

• To prevent view-dependent texture aliasing, per surfel texture filtering is also applied during rendering

• To determine the extent of the filter footprint in texture space, a circle is centered around each surfel on its tangent plane– These circles are called tangent disks

• The Tangent disks are then mapped to ellipses in texture space using a predefined texture parameterization of the surface

Page 20: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Texture Prefiltering, cont.• An EWA filter is applied to filter the texture and the resulting color is

assigned to the surfel

• For adequate texture reconstruction, the filter footprints in texture space must overlap each other– Choosing r0

pre = smax as the radius for the tangent disks usually guarantees that this condition is met

• Since a modified z-buffer algorithm is used to resolve visibility, not all surfels may be used for image reconstruction, which can lead to texture aliasing artifacts– To account for this problem, several, typically 3 or 4, prefiltered textures

per surfel are stored

– Tangent disks with larger radii, rkpre = smax2k, are mapped to texture space

and used to compute colors

– Because of its similarity to mipmapping, this is called a surfel mipmap

Page 21: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Data Structure

• An LDC tree is used to store the LDCs acquired during sampling

• This data structure allows for the number of projected surfels per pixel to be estimated and to trade rendering speed for higher image quality

Page 22: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

The LDC Tree

• The LDC octree is recursively constructed from the bottom up, with a height selected by the user– The highest resolution LDC, acquired during sampling, is stored at the

lowest level n = 0

– If the highest resolution LDC has a pixel spacing of h0, the LDC at level n has a pixel spacing of hn = h02n

– The LDC is subdivided into blocks with user-specified dimension b

Page 23: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

3-to-1 Reduction

• To reduce storage and rendering time, LDCs can be reduced to LDIs on a block by block basis– This is called 3-to-1 reduction because it usually triples warping speed

• Surfels are first resampled to integer grid locations of ray intersections and then stored in a single LDI– Currently nearest neighbor interpolation is used, but a more sophisticated

filter could easily be implemented

Page 24: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

3-to-1 Reduction, cont.

• The reduction and resampling process degrades the quality of both the shape and shade of the surfel representation– Resampled sufels may have very different texture colors and normals

– This can cause color and shading artifacts that are worsened during object motion

• In practice, however, severe artifacts due to 3-to-1 reduction are generally not encountered

• Since the rendering pipeline handles LDCs and LDIs the same way, some blocks can be stored as LDCs (blocks with thin structures) while others are stored as LDIs

Page 25: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

The Rendering Pipeline

• The rendering pipeline takes the surfel LDC tree and renders it using hierarchical visibility culling and forward warping of blocks

• Hierarchical rendering also allows the estimation of the number of projected surfels per pixel output– For maximum rendering efficiency, approximately one surfel per pixel is

projected and the same resolution is used for the z-buffer as the output image

– For maximum image quality, multiple surfels per pixel are projected and a finer resolution fo the z-buffer is used

Page 26: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Block Culling

• The LDC tree is traversed from top (lowest resolution blocks) to bottom– For each block, first view frustum culling is done using the block’s

bounding box

– Next, visibility cones are used to perform the equivalence of backface culling of blocks

Page 27: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Block Warping

• During rendering, the LDC tree is traversed top to bottom

• To choose the octree level to be projected, the number of surfels per pixel for each block is estimated– One surfel per pixel is used for fast rendering

– Multiple surfels per pixel are used for supersampling

– For each block at tree level n, the number of surfels per pixel is determined by in

max, the maximum distance between adjacent surfels in image space

– inmax is estimated by dividing the maximum length of the projected four

major diagonals of the block bounding box by the block dimension. This is correct for orthographic projections and the error for perspective projections is small because a block usually only projects to a small number of pixels

Page 28: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Block Warping, cont.

• For each block, inmax is compared to the radius rrec of the desired pixel

reconstruction filter

• If inmax is smaller than rrec, then the blocks children are traversed

• The block whose inmax is smaller than rrec is projected, rendering

approximately one surfel per pixel.

• Warping blocks to screen space is done using the incremental block warping algorithm by Grossman and Dally– This algorithm is highly efficient due to the regularity of LDCs

– The LDIs in each LDC block are warped independently, which allows easy rendering of an LDC tree where some or all blocks have been reduced to LDIs with 3-to-1 reduction

Page 29: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Visibility Testing

• Because of perspective projection, high z-buffer resolution, and magnification, undersampling, or holes, in the z-buffer may occur– A z-buffer pixel is a hole if it doesn’t contain a visible surfel or

background pixel

– Holes have to be marked before image reconstruction

• Each pixel of the z-buffer stores a pointer to the closest surfel and the current minimum depth

• Surfel depths are projected into the z-buffer using nearest neighbor interpolation

Page 30: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Visibility Testing, cont.

• The orthographic projection of the surfel tangent disks into the z-buffer is scan-converted

• The tangent disks have a radius or rnt = smax2n, where smax is the

maximum distance between adjacent surfels in object space and n is the level of the block

• This approach is called visibility splatting– It effectively separates visibility calculations and reconstruction of the

image, which produces high quality images and is amenable to hardware implementation

Page 31: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Visibility Testing, cont.

• After orthographic projection, the tangent discs form an ellipse around the surfel

• This ellipse is approximated with a partially axis-alligned bounding box, which can easily be scan converted, and each pixel is filled with the appropriate depth value, depending on the surfel normal

Page 32: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Texture Filtering

• During rendering, the surfel color is linearly interpolated from the surfel mipmap depending on the object minification and surface orientation

• To select the appropriate surfel mipmap level, traditional view-dependent texture filtering is used.

• The surfel color is computed by linear interpolation between the two closest mipmap levels

Page 33: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Shading

• Shading is done after visibility testing in order to avoid unnecessary work

• Per-surfel Phong illumination is calculated using cube reflectance and environmental maps

• Shading with per-surfel normals results in high quality specular highlights

Page 34: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Image Reconstruction and Antialiasing

• The simplest and fastest approach to image reconstruction is to choose the size of an output pixel to be the same as the z-buffer pixel– Surfels are mapped to pixel centers using neartest neighbor interpolation

– to interpolate the holes, a radially symmetric Gauss filter with a radius rrec slightly larger than imax, the estimated maximum distance between projected surfels of a block, is positioned at hole pixel centers

• A high quality alternative is to use supersampling, where the output image pixel size is any multiple of the z-buffer pixel size

Page 35: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Implementation and Results

• Sampling was implemented using the Blue Moon Rendering Tools (BMRT) ray tracer– Sampling resolution of 5122 for the LDC for 4802 expected output

resolution

• At each intersection point, a Renderman shader was used to perform view-independent calculations, such as texture filtering, displacement mapping, and bump mapping– The resulting surfels were then printed to a file

– Pre-processing for a typical object with 6 LOD surfel mipmaps takes about an hour

Page 36: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Implementation and Results, cont.

• A fundamental limitation of LDC sampling is that thin structures smaller than the sampling grid cannot be correctly represented and rendered– Spokes, thin wires, hair, etc. are hard to capture

• The surfel attributes acquired during sampling include a surface normal, specular color, shininess, and three texture mipmap levels

• Material properties are stored as an index into a table

• The system does not currently support translucency

• Normals are stored as an index into a quantized normal table

Page 37: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More Results

Page 38: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More Results

There is an increasing number of surfels per pixel towards the top of the image.

Page 39: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

More Results

• Frame rates in table measured on a 700 MHz Pentium III with 256 MB of SDRAM using an unoptimized C version of the program

• Performance numbers averaged over 1 minute of an animation that arbitrarily rotates the object centered at the origin

Page 40: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Even More Results

• To compare performance, the wasp model with 128k polygons and 2.3 MB for nine textures was rendered using a software only Windows NT viewing program– GL_LINEAR_MIPMAP_NEAREST was used for texture filtering to

achieve similar quality to the surfel renderer

– Average performance was 3 fps using Microsoft OpenGL implementation and 1.7 fps using Mesa OpenGL

• Further optimization should greatly improve performance

Page 41: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Future Extensions

• Extend sampling approach to include volume data, point clouds, and LDIs of non-synthetic objects

• Substantial compression of LDC trees may be possible using run length encoding or wavelet-based compression techniques

• Order-independent transparency and true volume rendering could be implemented using an occlusion compatible traversal of the LDC tree

• Design of hardware architecture for surfel rendering– Enhance an existing OpenGL pipeline to efficiently support surfel

rendering

Page 42: Surfels : Surface Elements as Rendering Primitives Hanspeter Pfister Matthias Zwicker Jeroen van Baar Markus Gross Presented by Kevin Reed.

Conclusions• Surfel rendering is ideal for models with very high shape and shade

complexity

• Moving rasterization and texturing from the core rendering pipeline to a preprocessing step dramatically reduces the rendering cost per pixel

• Rendering performance is essentially determined by warping, shading, and image reconstruction, which are all operations that can easily exploit vectorization, parallelism, and pipelining

• Visibility splatting is very effective at detecting holes and increasing image reconstruction performance

• Antialiasing and supersampling are naturally integrated into the surfel system

• Surfel rendering is capable of high image quality at interactive framerates

• Increasing processor speeds and hardware support could easily allow surfel rendering to be done with real-time performance