660 likes | 834 Views
General Triangle Models: Representations and Collision. David Johnson. Triangle Models. Boundary-representation (B-rep) Collection of surfaces to represent a volume Manifold Closed model Every edge has two triangles. Polygon Modeling.
E N D
General Triangle Models:Representations and Collision David Johnson
Triangle Models • Boundary-representation (B-rep) • Collection of surfaces to represent a volume • Manifold • Closed model • Every edge has two triangles
Polygon Modeling • Polygons are the dominant force in modeling for real-time graphics • Why?
Polygons Dominate • Everything can be turned into polygons (almost everything) • Normally an error associated with the conversion, but with time and space it may be possible to reduce this error • We know how to render polygons quickly • Many operations are easy to do with polygons • Memory and disk space is cheap • Simplicity and inertia
What’s Bad About Polygons? • What are some disadvantages of polygonal representations?
Polygons Aren’t Great • They are always an approximation to curved surfaces • But can be as good as you want, if you are willing to pay in size • Normal vectors are approximate • They throw away information • They can be very unstructured • They are hard to globally parameterize • How do we parameterize them for texture mapping? • It is difficult to perform many geometric operations
Polygon Meshes • A mesh is a set of polygons connected to form an object • A mesh has several components, or geometric entities: • Faces • Edges, the boundary between faces • Vertices, the boundaries between edges, or where three or more faces meet • Normals, Texture coordinates, colors, shading coefficients, etc • Some components are implicit, given the others • For instance, given faces and vertices can determine edges
Polygonal Data Structures • Polygon mesh data structures are application dependent • Different applications require different operations to be fast • Find the neighbor of a given face • Find the faces that surround a vertex • You typically choose: • Which features to store explicitly (vertices, faces, normals, etc) • Which relationships you want to be explicit (vertices belonging to faces, neighbors, faces at a vertex, etc)
Triangle Meshes • We will look at triangle mesh data structures • Can triangulate general polygon
Triangle Soup • Many models are just lists of triangles • What does the model below look like in a floating point computer? T4 T1: v1, v2, v3 T2: v4, v5, v6 T3: v7, v8, v9 T4: v10, v11, v12 etc… T6 T1 T5 T2 T3
Triangle Soup • No connection between triangles • Some models are produced like this, so may have to work with it T4 T1: v1, v2, v3 T2: v4, v5, v6 T3: v7, v8, v9 T4: v10, v11, v12 etc… T6 T1 T5 T2 T3
Triangle Soup Evaluation • What are the advantages? • It’s very simple to read, write, transmit, etc. • A common output format from CAD modelers • BIG disadvantage: No higher order information • No information about neighbors • No open/closed information • No guarantees on degeneracies/manifoldness
Vertex-Face Mesh v0 v4 • There are reasons not to store the vertices explicitly at each polygon • Wastes memory - each vertex repeated many times • Very messy to find neighboring polygons • Difficult to ensure that polygons meet correctly • Solution: Indirection • Put all the vertices in a list • Each face stores the list indices of its vertices • Advantages? Disadvantages? vertices v0 v1 v2 v3 v4 v1 faces 0 2 1 0 1 4 1 2 3 1 3 4 v2 v3
Vertex-Face Evaluation • Advantages: • Saving in storage: • Vertex index might be only 2 bytes, and a vertex is probably 12 bytes • Each vertex gets used at least 3 and generally 4-6 times, but is only stored once • Normals, texture coordinates, colors etc. can all be stored the same way • Disadvantages: • Connectivity information is not explicit • How would you find a neighbor face/shared vertex?
Add more data • Face data structure • Face: • Neighbors = [find1, find2, find3] • Vertices = [vind1, vind2, vind3] • Vertex: • Coords = [x,y,z] • Neighborfaces = [find1,..,findn];
Some problems • Edges are implicit • Number of neighbors to vertex is variable • Use vertex-edge-face structures • Winged edge • Half-edge
Half-edge • Half-edge • leading vertex • Face on left • Edge ahead • Flipped Edge • Everything points to one thing
Collision Methods for Triangle Models • Models may have millions of triangles • For two models with m and n triangles • Brute force: m*n triangle-triangle intersections • > 1012 intersection computations for two objects • Need an acceleration structure
Bounding Volumes • Objects are often not colliding • Need fast reject for this case • Surround with some bounding object • Like a sphere • Why stop with one layer of rejection testing? • Build a bounding volume hierarchy (BVH) • A tree
Bounding Volume Hierarchies • Model Hierarchy: • each node has a simple volume that bounds a set of triangles • children contain volumes that each bound a different portion of the parent’s triangles • The leaves of the hierarchy usually contain individual triangles • A binary bounding volume hierarchy:
Type of Bounding Volumes • Spheres • Ellipsoids • Axis-Aligned Bounding Boxes (AABB) • Oriented Bounding Boxes (OBBs) • Convex Hulls • k-Discrete Orientation Polytopes (k-dop) • Spherical Shells • Swept-Sphere Volumes (SSVs) • Point Swetp Spheres (PSS) • Line Swept Spheres (LSS) • Rectangle Swept Spheres (RSS) • Triangle Swept Spheres (TSS)
Observations • Simple primitives (spheres, AABBs, etc.) do very well with respect to the overlap cost. But they cannot fit some long skinny primitives tightly. • More complex primitives (minimal ellipsoids, OBBs, etc.) provide tight fits, but checking for overlap between them is relatively expensive. • Cost of BV updates needs to be considered.
Convex Hull AABB OBB Sphere 6-dop Trade-off in Choosing BV’s increasing complexity & tightness of fit decreasing cost of (overlap tests + BV update)
Bounding Volume Hierarchies (Example: k-DOPs, k=6,14,18,26) Level 0 Note: k=6 is a AABB.
Bounding Volume Hierarchies (Example: k-DOPs, k=6,14,18,26) Level 1
Bounding Volume Hierarchies (Example: k-DOPs, k=6,14,18,26) Level 2
Bounding Volume Hierarchies (Example: k-DOPs, k=6,14,18,26) Level 5
Bounding Volume Hierarchies (Example: k-DOPs, k=6,14,18,26) Level 8
Building Hierarchies • Choices of Bounding Volumes • cost function & constraints • Top-Down vs. Bottom-up • speed vs. fitting • Depth vs. breadth • branching factors • Splitting factors • where & how
Sphere-Trees • A sphere-tree is a hierarchy of sets of spheres, used to approximate an object • Advantages: • Simplicity in checking overlaps between two bounding spheres • Invariant to rotations and can apply the same transformation to the centers, if objects are rigid • Shortcomings: • Not always the best approximation (esp bad for long, skinny objects) • Lack of good methods on building sphere-trees
Methods for Building Sphere-Trees • “Tile” the triangles and build the tree bottom-up • Covering each vertex with a sphere and group them together • Compute the medial axis and use it as a skeleton for multi-res sphere-covering • Others……
Recursive top-down construction: partition and refit Building an OBBTree
Given some polygons, consider their vertices... Building an OBB Tree
… and an arbitrary line Building an OBB Tree
Building an OBB Tree Project onto the line Consider variance of distribution on the line
Building an OBB Tree Different line, different variance
Maximum Variance Building an OBB Tree
Minimal Variance Building an OBB Tree
Given by eigenvectors of covariance matrix of coordinates of original points Building an OBB Tree
Choose bounding box oriented this way Building an OBB Tree
Building an OBB Tree: Fitting Covariance matrix of point coordinates describes statistical spread of cloud. OBB is aligned with directions of greatest and least spread (which are guaranteed to be orthogonal).
Good Box Building an OBB Tree
Add points: worse Box Building an OBB Tree
More points: terrible box Building an OBB Tree
Compute with extremal points only Building an OBB Tree
Building an OBB Tree “Even” distribution: good box
“Uneven” distribution: bad box Building an OBB Tree