Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use...
Transcript of Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use...
![Page 1: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/1.jpg)
Polygon Meshes and Implicit Surfaces
Polygon MeshesParametr ic Sur facesImplicit Sur facesConstructive Solid Geometry
Polygon MeshesParametr ic Sur facesImplicit Sur facesConstructive Solid Geometry
10/01/02
![Page 2: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/2.jpg)
2
Modeling Complex Shapes
• We want to build models of very complicated objects
• An equation for a sphere is possible, but how about an equation for a telephone, or a face?
• Complexity is achieved using simple pieces– polygons, parametric surfaces, or implicit surfaces
• Goals– Model anything with arbitrary precision (in principle)
– Easy to build and modify
– Efficient computations (for rendering, collisions, etc.)
– Easy to implement (a minor consideration...)
![Page 3: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/3.jpg)
3
What do we need from shapesin Computer Graphics?
• Local control of shape for modeling• Ability to model what we need• Smoothness and continuity• Ability to evaluate derivatives• Ability to do collision detection• Ease of rendering
No one technique solves all problems
![Page 4: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/4.jpg)
4
Curve Representations
Polygon MeshesParametric SurfacesImplicit Surfaces
![Page 5: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/5.jpg)
5
Polygon Meshes
• Any shape can be modeled out of polygons
– if you use enough of them…
• Polygons with how many sides?– Can use triangles, quadrilaterals, pentagons, … n-
gons– Triangles are most common.– When > 3 sides are used, ambiguity about what to do
when polygon nonplanar, or concave, or self-intersecting.
• Polygon meshes are built out of– vertices (points)– edges (line segments between vertices)– faces (polygons bounded by edges)
vertices
edgesfaces
![Page 6: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/6.jpg)
6
Polygon Models in OpenGL
• for faceted shadingglNormal3fv(n);glBegin(GL_POLYGONS);
glVertex3fv(vert1);glVertex3fv(vert2);
glVertex3fv(vert3);glEnd();
• for smooth shadingglBegin(GL_POLYGONS);glNormal3fv(normal1);
glVertex3fv(vert1);glNormal3fv(normal2);
glVertex3fv(vert2);glNormal3fv(normal3);glVertex3fv(vert3);
glEnd();
![Page 7: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/7.jpg)
7
Normals
![Page 8: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/8.jpg)
8
Where Meshes Come From• Specify manually
– Write out all polygons
– Write some code to generate them
– Interactive editing: move vertices in space
• Acquisition from real objects– Laser scanners, vision systems
– Generate set of points on the surface
– Need to convert to polygons
![Page 9: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/9.jpg)
9
Data Structures for Polygon Meshes• Simplest (but dumb)
– float triangle[n][3][3]; (each triangle stores 3 (x,y,z) points)– redundant: each vertex stored multiple times
• Vertex List, Face List– List of vertices, each vertex consists of (x,y,z) geometric (shape)
info only– List of triangles, each a triple of vertex id’s (or pointers) topological
(connectivity, adjacency) info only
Fine for many purposes, but finding the faces adjacent to a vertex takes O(F) time for a model with F faces. Such queries are important for topological editing.
• Fancier schemes:Store more topological info so adjacency queries can be answered in
O(1) time.Winged-edge data structure – edge structures contain all topological
info (pointers to adjacent vertices, edges, and faces).
![Page 10: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/10.jpg)
10
A File Format for Polygon Models: OBJ
# OBJ file for a 2x2x2 cubev -1.0 1.0 1.0 - vertex 1v -1.0 -1.0 1.0 - vertex 2v 1.0 -1.0 1.0 - vertex 3v 1.0 1.0 1.0 - …v -1.0 1.0 -1.0v -1.0 -1.0 -1.0v 1.0 -1.0 -1.0v 1.0 1.0 -1.0f 1 2 3 4f 8 7 6 5f 4 3 7 8f 5 1 4 8f 5 6 2 1f 2 6 7 3
Syntax:
v x y z - a vertex at (x,y,z)
f v1 v2 … vna face with vertices v1, v2, … vn
# anything - comment
![Page 11: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/11.jpg)
11
How Many Polygons to Use?
![Page 12: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/12.jpg)
12
Why Level of Detail?
• Different models for near and far objects• Different models for rendering and collision detection• Compression of data recorded from the real world
We need automatic algorithms for reducing the polygon count without • losing key features • getting artifacts in the silhouette • popping
![Page 13: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/13.jpg)
13
Problems with Triangular Meshes?
• Need a lot of polygons to represent smooth shapes• Need a lot of polygons to represent detailed shapes
• Hard to edit• Need to move individual vertices• Intersection test? Inside/outside test?
![Page 14: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/14.jpg)
14
Curve Representations
Polygon MeshesParametric SurfacesImplicit Surfaces
![Page 15: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/15.jpg)
15
Parametric Surfaces
– e.g. plane, cylinder, bicubic surface, swept surface
p(u,v) = [x(u,v), y(u,v), z(u,v)]
bezier patch
![Page 16: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/16.jpg)
16
Parametric Surfaces
– e.g. plane, cylinder, bicubic surface, swept surface
p(u,v) = [x(u,v), y(u,v), z(u,v)]
![Page 17: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/17.jpg)
17
Parametric Surfaces
– Much more compact– More convenient to control --- just edit control points– Easy to construct from control points
Why better than polygon meshes?
What are the problems?– Work well for smooth surfaces– Must still split surfaces into discrete number of patches– Rendering times are higher than for polygons– Intersection test? Inside/outside test?
![Page 18: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/18.jpg)
18
Curve Representations
Polygon MeshesParametric SurfacesImplicit Surfaces
![Page 19: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/19.jpg)
19
Two Ways to Define a CircleParametr ic
u
x = f(u) = r cos (u)y = g(u) = r sin (u)
Implicit
F(x,y) = x² + y² - r ²
F<0
F>0
F=0
![Page 20: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/20.jpg)
20
Surface Representations
• Implicit surface: F(x,y,z) = 0– e.g. plane, sphere, cylinder, quadric, torus, blobby models
sphere with radius r : F(x,y,z) = x2+y2+z2-r = 0
– terrible for iterating over the surface– great for intersections, inside/outside test
well defined inside/outsidepolygons and splines do not have this information
Computing is hard:
implicit functions for a cube?
telephone?
![Page 21: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/21.jpg)
21
Quadric Classes
ellipsoid parabolic
cylinderconehyperboloids
F(x,y,z) = ax2+by2+cz2+2fyz+2gzx+2hxy+2px+2qy+2rz+d=0
![Page 22: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/22.jpg)
22
What Implicit Functions are Good For
F < 0 ? F = 0 ? F > 0 ?
Inside/Outside Test
X
X + kV
F(X + kV) = 0
Ray - Surface Intersection Test
![Page 23: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/23.jpg)
23
Surfaces from Implicit Functions• Constant Value Surfaces are called
(depending on whom you ask):– constant value surfaces– level sets– isosurfaces
• Nice Feature: you can add them! (and other tricks)
– this merges the shapes– When you use this with spherical exponential potentials, it’s
called Blobs, Metaballs, or Soft Objects. Great for modeling animals.
![Page 24: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/24.jpg)
24
Blobby Models
[f(x,y,z) = 1.0 / (x^2 + y^2 + z^2)] graph for 1/r^2
form blobs if close
![Page 25: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/25.jpg)
25
Blobby Models
[f(x,y,z) = 1.0 / (x^2 + y^2 + z^2)] graph for 1/r^2
form blobs if close
![Page 26: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/26.jpg)
26
Blobby Models
![Page 27: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/27.jpg)
27
Blobby Models
• Implicit function is the sum of Gaussians centered at several points in space, minus a threshold
• varying the standard deviations of the Gaussians makes each blob bigger
• varying the threshold makes blobs merge or separate
![Page 28: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/28.jpg)
28
Blobby Models
![Page 29: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/29.jpg)
29
How to draw implicit surfaces?
• It’s easy to ray trace implicit surfaces– because of that easy intersection test
• Volume Rendering can display them• Convert to polygons: the Marching Cubes
algorithm– Divide space into cubes– Evaluate implicit function at each cube vertex– Do root finding or linear interpolation along each
edge– Polygonize on a cube-by-cube basis
![Page 30: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/30.jpg)
30
Constructive Solid Geometry (CSG)Generate complex shapes with basic building blocks
machine an object - saw parts off, drill holes
glue pieces together
![Page 31: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/31.jpg)
31
Constructive Solid Geometry (CSG)Generate complex shapes with basic building blocks
machine an object - saw parts off, drill holes
glue pieces together
This is sensible for objects that are actually made that way (human-made, particularly machined objects)
![Page 32: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/32.jpg)
32
A CSG Train
Brian Wyvill & students, Univ. of Calgary
![Page 33: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/33.jpg)
33
Negative Objects•Use point-by-point boolean functions
– remove a volume by using a negative object
– e.g. drill a hole by subtracting a cylinder
Subtract From
To get
Inside(BLOCK-CYL) = Inside(BLOCK) And Not(Inside(CYL))
![Page 34: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/34.jpg)
34
Set Operations• UNION: Inside(A) || Inside(B)
— Join A and B
• INTERSECTION: Inside(A) && Inside(B)— Chop off any part of A that sticks out of B.
• SUBTRACTION: Inside(A) && (! Inside(B))— Use B to Cut A
Examples:– Use cylinders to drill holes
– Use rectangular blocks to cut slots
– Use half-spaces to cut planar faces
– Use surfaces swept from curves as jigsaws, etc.
![Page 35: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/35.jpg)
35
Implicit Functions for Booleans
•Recall the implicit function for a solid: F(x,y,z)<0
•Boolean operations are replaced by arithmetic:– MAX replaces AND (intersection)
– MIN replaces OR (union)
– MINUS replaces NOT(unary subtraction)
•Thus– F(Intersect(A,B)) = MAX(F(A),F(B))
– F(Union(A,B)) = MIN(F(A),F(B))
– F(Subtract(A,B)) = MAX(F(A), -F(B))
F1<0 F2<0
F1<0 F2<0
A B
![Page 36: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/36.jpg)
36
Implicit Surfaces
– Good for smoothly blending multiple components– Clearly defined solid along with its boundary– Intersection test and Inside/outside test are easy
– Need to polygonaze to render --- expensive– Interactive control is not easy– Fitting to real world data is not easy– Always smooth
![Page 37: Polygon Meshes and Implicit Surfacesjkh/462_s07/09_meshes.pdf · 2007. 2. 18. · – Can use triangles, quadrilaterals, pentagons, … n-gons – Triangles are most common. – When](https://reader036.fdocuments.in/reader036/viewer/2022062510/61334c6cdfd10f4dd73aff5f/html5/thumbnails/37.jpg)
37
Announcements
Graded:Written Assignment – Joel
Michael is out this week
Written part of the second programming assignment is due Today before the class or Friday before 9am in Jessica’s mailbox