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

Slides:



Advertisements
Similar presentations
COMPUTER GRAPHICS SOFTWARE.
Advertisements

Parallax-Interpolated Shadow Map Occlusion
Object Space EWA Surface Splatting: A Hardware Accelerated Approach to High Quality Point Rendering Liu Ren Hanspeter Pfister Matthias Zwicker CMU.
Exploration of bump, parallax, relief and displacement mapping
RealityEngine Graphics Kurt Akeley Silicon Graphics Computer Systems.
03/16/2009Dinesh Manocha, COMP770 Texturing Surface’s texture: its look & feel Graphics: a process that takes a surface and modifies its appearance using.
3D Graphics Rendering and Terrain Modeling
Real-Time Rendering TEXTURING Lecture 02 Marina Gavrilova.
Computer Graphics Bing-Yu Chen National Taiwan University.
CS447/ Realistic Rendering -- Solids Modeling -- Introduction to 2D and 3D Computer Graphics.
HCI 530 : Seminar (HCI) Damian Schofield.
Chapter 6: Vertices to Fragments Part 2 E. Angel and D. Shreiner: Interactive Computer Graphics 6E © Addison-Wesley Mohan Sridharan Based on Slides.
Plenoptic Stitching: A Scalable Method for Reconstructing 3D Interactive Walkthroughs Daniel G. Aliaga Ingrid Carlbom
Sampling, Aliasing, & Mipmaps
Computer Graphics (Fall 2005) COMS 4160, Lecture 21: Ray Tracing
Advanced Computer Graphics (Spring 2005) COMS 4162, Lecture 21: Image-Based Rendering Ravi Ramamoorthi
(conventional Cartesian reference system)
Copyright  Philipp Slusallek IBR: View Interpolation Philipp Slusallek.
CSCE 641: Computer Graphics Image-based Rendering Jinxiang Chai.
The Story So Far The algorithms presented so far exploit: –Sparse sets of images (some data may not be available) –User help with correspondences (time.
University of Texas at Austin CS 378 – Game Technology Don Fussell CS 378: Computer Game Technology Beyond Meshes Spring 2012.
MULTIMEDIA TECHNOLOGY SMM 3001 MEDIA - GRAPHICS. In this chapter how the computer creates, stores, and displays graphic images how the computer creates,
Modeling and representation 1 – comparative review and polygon mesh models 2.1 Introduction 2.2 Polygonal representation of three-dimensional objects 2.3.
Ray Tracing Primer Ref: SIGGRAPH HyperGraphHyperGraph.
COMP 175: Computer Graphics March 24, 2015
Computer Graphics Panos Trahanias ΗΥ358 Spring 2009.
Technology and Historical Overview. Introduction to 3d Computer Graphics  3D computer graphics is the science, study, and method of projecting a mathematical.
Computer graphics & visualization REYES Render Everything Your Eyes Ever Saw.
11/11/04© University of Wisconsin, CS559 Fall 2004 Last Time Shading Interpolation Texture mapping –Barycentric coordinates for triangles.
C O M P U T E R G R A P H I C S Guoying Zhao 1 / 14 C O M P U T E R G R A P H I C S Guoying Zhao 1 / 14 Going-through.
CS 450: COMPUTER GRAPHICS REVIEW: INTRODUCTION TO COMPUTER GRAPHICS – PART 2 SPRING 2015 DR. MICHAEL J. REALE.
Week 2 - Friday.  What did we talk about last time?  Graphics rendering pipeline  Geometry Stage.
CS447/ Realistic Rendering -- Radiosity Methods-- Introduction to 2D and 3D Computer Graphics.
1 Rendering Geometry with Relief Textures L.Baboud X.Décoret ARTIS-GRAVIR/IMAG-INRIA.
Image-based Rendering. © 2002 James K. Hahn2 Image-based Rendering Usually based on 2-D imagesUsually based on 2-D images Pre-calculationPre-calculation.
Rendering Overview CSE 3541 Matt Boggus. Rendering Algorithmically generating a 2D image from 3D models Raster graphics.
03/24/03© 2003 University of Wisconsin Last Time Image Based Rendering from Sparse Data.
1 Texture Mapping. 2 Texture Aliasing MIPmaps Environment Mapping Bump Mapping Displacement Mapping Shadow Maps Solid Textures Antialiasing.
Real-time Graphics for VR Chapter 23. What is it about? In this part of the course we will look at how to render images given the constrains of VR: –we.
Computer Graphics Chapter 6 Andreas Savva. 2 Interactive Graphics Graphics provides one of the most natural means of communicating with a computer. Interactive.
03/15/03© 2005 University of Wisconsin Where We’ve Been Photo-realistic rendering –Accurate modeling and rendering of light transport and surface reflectance.
04/23/03© 2003 University of Wisconsin Where We’ve Been Photo-realistic rendering –Accurate modeling and rendering of light transport and surface reflectance.
- Laboratoire d'InfoRmatique en Image et Systèmes d'information
112/5/ :54 Graphics II Image Based Rendering Session 11.
Advanced Computer Graphics Spring 2014 K. H. Ko School of Mechatronics Gwangju Institute of Science and Technology.
Review on Graphics Basics. Outline Polygon rendering pipeline Affine transformations Projective transformations Lighting and shading From vertices to.
Subject Name: Computer Graphics Subject Code: Textbook: “Computer Graphics”, C Version By Hearn and Baker Credits: 6 1.
Ray Tracing Fall, Introduction Simple idea  Forward Mapping  Natural phenomenon infinite number of rays from light source to object to viewer.
Real-Time Relief Mapping on Arbitrary Polygonal Surfaces Fabio Policarpo Manuel M. Oliveira Joao L. D. Comba.
Discontinuous Displacement Mapping for Volume Graphics, Volume Graphics 2006, July 30, Boston, MA Discontinuous Displacement Mapping for Volume Graphics.
CS559: Computer Graphics Final Review Li Zhang Spring 2010.
CSCE 641 Computer Graphics: Image-based Rendering (cont.) Jinxiang Chai.
COMPUTER GRAPHICS CS 482 – FALL 2015 SEPTEMBER 29, 2015 RENDERING RASTERIZATION RAY CASTING PROGRAMMABLE SHADERS.
Real-Time Dynamic Shadow Algorithms Evan Closson CSE 528.
Image-Based Rendering Geometry and light interaction may be difficult and expensive to model –Think of how hard radiosity is –Imagine the complexity of.
RENDERING : Global Illumination
Computer Graphics One of the central components of three-dimensional graphics has been a basic system that renders objects represented by a set of polygons.
Real-Time Relief Mapping on Arbitrary Polygonal Surfaces Fabio Policarpo Manuel M. Oliveira Joao L. D. Comba.
3D Object Representations 2009, Fall. Introduction What is CG?  Imaging : Representing 2D images  Modeling : Representing 3D objects  Rendering : Constructing.
Presented by 翁丞世  View Interpolation  Layered Depth Images  Light Fields and Lumigraphs  Environment Mattes  Video-Based.
Real-time Walkthrough of Virtual Space using Environment Map
POLYGON MESH Advance Computer Graphics
Image-Based Rendering
3D Graphics Rendering PPT By Ricardo Veguilla.
3D Object Representations
The Graphics Rendering Pipeline
UMBC Graphics for Games
Adding Surface Detail 고려대학교 컴퓨터 그래픽스 연구실.
Adding Surface Detail 고려대학교 컴퓨터 그래픽스 연구실.
Interactive Sampling and Rendering for Complex and Procedural Geometry
Presentation transcript:

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

Introduction

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

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

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

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

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

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

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

Conceptual Overview Process consists of two main steps: sampling and surfel rendering

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

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

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

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

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

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

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

Adequate Sampling Resolution Given a pixel spacing of h 0 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 s max of  3h 0 and minimum sidelength s min 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 s max is less that the radius r rec 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

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

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 r 0 pre = s max 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, r k pre = s max 2 k, are mapped to texture space and used to compute colors –Because of its similarity to mipmapping, this is called a surfel mipmap

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

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 h 0, the LDC at level n has a pixel spacing of h n = h 0 2 n –The LDC is subdivided into blocks with user-specified dimension b

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

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

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

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

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 i n max, the maximum distance between adjacent surfels in image space –i n max 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

Block Warping, cont. For each block, i n max is compared to the radius r rec of the desired pixel reconstruction filter If i n max is smaller than r rec, then the blocks children are traversed The block whose i n max is smaller than r rec 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

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

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 r n t = s max 2 n, where s max 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

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

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

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

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 r rec slightly larger than i max, 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

Implementation and Results Sampling was implemented using the Blue Moon Rendering Tools (BMRT) ray tracer –Sampling resolution of for the LDC for 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

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

More Results

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

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

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

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

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