Triangle Meshes Notation Validity of Triangle Meshes Topology/Geometry

Total Page:16

File Type:pdf, Size:1020Kb

Triangle Meshes Notation Validity of Triangle Meshes Topology/Geometry Notation • nT = #tris; nV = #verts; nE = #edges • Euler: nV – nE + nT = 2 for a simple closed surface Triangle meshes – and in general sums to small integer – argument for implication that nT:nE:nV is about 2:3:1 CS 4620 Lecture 11 y et al.] ole [F Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 1 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 2 Validity of triangle meshes Topology/geometry examples • in many cases we care about the mesh being able to • same geometry, different mesh topology: bound a region of space nicely • in other cases we want triangle meshes to fulfill assumptions of algorithms that will operate on them (and may fail on malformed input) • two completely separate issues: • same mesh topology, different geometry: – topology: how the triangles are connected (ignoring the positions entirely) – geometry: where the triangles are in 3D space Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 3 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 4 Topological validity Geometric validity • strongest property, and most simple: be a manifold • generally want non-self-intersecting surface – this means that no points should be "special" • hard to guarantee in general – interior points are fine – because far-apart parts of mesh might intersect – edge points: each edge should have exactly 2 triangles – vertex points: each vertex should have one loop of triangles • not too hard to weaken this to allow boundaries y et al.] ole [F Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 5 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 6 Representation of triangle meshes Representations for triangle meshes • Compactness • Separate triangles • Efficiency for rendering • Indexed triangle set – enumerate all triangles as triples of 3D points – shared vertices • Efficiency of queries • Triangle strips and triangle fans – all vertices of a triangle – compression schemes for transmission to hardware" – all triangles around a vertex • Triangle-neighbor data structure – neighboring triangles of a triangle – supports adjacency queries – (need depends on application) • Winged-edge data structure • finding triangle strips – supports general polygon meshes • computing subdivision surfaces • mesh editing Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 7 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 8 Separate triangles Separate triangles • array of triples of points – float[nT][3][3]: about 72 bytes per vertex • 2 triangles per vertex (on average) • 3 vertices per triangle • 3 coordinates per vertex • 4 bytes per coordinate (float) • various problems – wastes space (each vertex stored 6 times) – cracks due to roundoff – difficulty of finding neighbors at all Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 9 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 10 Indexed triangle set Indexed triangle set • Store each vertex once • Store each vertex once • Each triangle points to its three vertices • Each triangle points to its three vertices Triangle { Triangle { Vertex vertex[3]; Vertex vertex[3]; } } Vertex { Vertex { float position[3]; // or other data float position[3]; // or other data } } // ... or ... // ... or ... Mesh { Mesh { float verts[nv][3]; // vertex positions (or other data) float verts[nv][3]; // vertex positions (or other data) int tInd[nt][3]; // vertex indices int tInd[nt][3]; // vertex indices } } Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 11 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 11 Indexed triangle set Indexed triangle set • array of vertex positions – float[nV][3]: 12 bytes per vertex • (3 coordinates x 4 bytes) per vertex • array of triples of indices (per triangle) – int[nT][3]: about 24 bytes per vertex • 2 triangles per vertex (on average) • (3 indices x 4 bytes) per triangle • total storage: 36 bytes per vertex (factor of 2 savings) • represents topology and geometry separately • finding neighbors is at least well defined Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 12 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 13 Triangle strips Triangle strips • Take advantage of the mesh property – each triangle is usually adjacent to the previous – let every vertex create a triangle by reusing the second and third vertices of the previous triangle 4, 0 – every sequence of three vertices produces a triangle (but not in the same order) – e. g., 0, 1, 2, 3, 4, 5, 6, 7, … leads to # (0 1 2), (2 1 3), (2 3 4), (4 3 5), (4 5 6), (6 5 7), … – for long strips, this requires about one index per triangle Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 14 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 15 Triangle strips Triangle strips • array of vertex positions – float[nV][3]: 12 bytes per vertex • (3 coordinates x 4 bytes) per vertex • array of index lists – int[n ][variable]: 2 + n indices per strip 4, 0 S – on average, (1 + !) indices per triangle (assuming long strips) • 2 triangles per vertex (on average) • about 4 bytes per triangle (on average) • total is 20 bytes per vertex (limiting best case) – factor of 3.6 over separate triangles; 1.8 over indexed mesh Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 15 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 16 Triangle fans Triangle neighbor structure • Same idea as triangle strips, but keep oldest rather than • Extension to indexed newest triangle set – every sequence of three vertices produces a triangle • Triangle points to its three – e. g., 0, 1, 2, 3, 4, 5, … leads to neighboring triangles # (0 1 2), (0 2 3), (0 3 4), (0 3 5), … • Vertex points to a single – for long fans, this requires neighboring triangle about one index per triangle • Can now enumerate • Memory considerations exactly the same as triangle strip triangles around a vertex Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 17 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 18 Triangle neighbor structure Triangle neighbor structure • Extension to indexed • Extension to indexed triangle set triangle set • Triangle points to its three • Triangle points to its three neighboring triangles neighboring triangles • Vertex points to a single • Vertex points to a single neighboring triangle neighboring triangle • Can now enumerate • Can now enumerate triangles around a vertex triangles around a vertex Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 18 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 18 Triangle neighbor structure Triangle neighbor structure Triangle { Triangle neighbor[3]; Vertex vertex[3]; } // t.neighbor[i] is adjacent // across the edge from i to i+1 Vertex { // ... per-vertex data ... Triangle t; // any adjacent tri } // ... or ... Mesh { // ... per-vertex data ... int tInd[nt][3]; // vertex indices int tNbr[nt][3]; // indices of neighbor triangles int vTri[nv]; // index of any adjacent triangle } Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 19 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 20 Triangle neighbor structure Triangle neighbor structure Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 20 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 20 Triangle neighbor structure Triangle neighbor structure Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 20 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 20 Triangle neighbor structure Triangle neighbor structure TrianglesOfVertex(v) { • indexed mesh was 36 bytes per vertex t = v.t; do { • add an array of triples of indices (per triangle) find t.vertex[i] == v; t = t.nbr[pred(i)]; – int[n ][3]: about 24 bytes per vertex } while (t != v.t); T } • 2 triangles per vertex (on average) pred(i) = (i+2) % 3; • (3 indices x 4 bytes) per triangle succ(i) = (i+1) % 3; • add an array of representative triangle per vertex – int[nV]: 4 bytes per vertex • total storage: 64 bytes per vertex – still not as much as separate triangles Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 21 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 22 Triangle neighbor structure—refined Triangle neighbor structure—refined Triangle { Triangle { Edge nbr[3]; Edge nbr[3]; Vertex vertex[3]; Vertex vertex[3]; } } // if t.nbr[i].i == j // if t.nbr[i].i == j // then t.nbr[i].t.nbr[j] == t // then t.nbr[i].t.nbr[j] == t Edge { Edge { // the i-th edge of triangle t // the i-th edge of triangle t Triangle t; Triangle t; int i; // in {0,1,2} int i; // in {0,1,2} // in practice t and i share 32 bits // in practice t and i share 32 bits } } Vertex { Vertex { // ... per-vertex data ... // ... per-vertex data ... Edge e; // any edge leaving vertex Edge e; // any edge leaving vertex } T0.nbr[0] = { T1, 2 } } T0.nbr[0] = { T1, 2 } T1.nbr[2] = { T0, 0 } T1.nbr[2] = { T0, 0 } V0.e = { T1, 0 } V0.e = { T1, 0 } Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 23 Cornell CS4620 Fall 2006 •!Lecture 11 © 2008 Steve Marschner • 23 Triangle neighbor structure Winged-edge mesh TrianglesOfVertex(v) { • Edge-centric rather than {t, i} = v.e; do { face-centric {t, i} = t.nbr[pred(i)]; } while (t != v.t); – therefore also works for } polygon meshes pred(i) = (i+2) % 3; • Each (oriented) edge points to: succ(i) = (i+1) % 3; – left and right forward edges – left and right backward edges – front and back vertices – left and right faces • Each face or vertex points to
Recommended publications
  • 1 Lifts of Polytopes
    Lecture 5: Lifts of polytopes and non-negative rank CSE 599S: Entropy optimality, Winter 2016 Instructor: James R. Lee Last updated: January 24, 2016 1 Lifts of polytopes 1.1 Polytopes and inequalities Recall that the convex hull of a subset X n is defined by ⊆ conv X λx + 1 λ x0 : x; x0 X; λ 0; 1 : ( ) f ( − ) 2 2 [ ]g A d-dimensional convex polytope P d is the convex hull of a finite set of points in d: ⊆ P conv x1;:::; xk (f g) d for some x1;:::; xk . 2 Every polytope has a dual representation: It is a closed and bounded set defined by a family of linear inequalities P x d : Ax 6 b f 2 g for some matrix A m d. 2 × Let us define a measure of complexity for P: Define γ P to be the smallest number m such that for some C s d ; y s ; A m d ; b m, we have ( ) 2 × 2 2 × 2 P x d : Cx y and Ax 6 b : f 2 g In other words, this is the minimum number of inequalities needed to describe P. If P is full- dimensional, then this is precisely the number of facets of P (a facet is a maximal proper face of P). Thinking of γ P as a measure of complexity makes sense from the point of view of optimization: Interior point( methods) can efficiently optimize linear functions over P (to arbitrary accuracy) in time that is polynomial in γ P . ( ) 1.2 Lifts of polytopes Many simple polytopes require a large number of inequalities to describe.
    [Show full text]
  • Geometry © 2000 Springer-Verlag New York Inc
    Discrete Comput Geom OF1–OF15 (2000) Discrete & Computational DOI: 10.1007/s004540010046 Geometry © 2000 Springer-Verlag New York Inc. Convex and Linear Orientations of Polytopal Graphs J. Mihalisin and V. Klee Department of Mathematics, University of Washington, Box 354350, Seattle, WA 98195-4350, USA {mihalisi,klee}@math.washington.edu Abstract. This paper examines directed graphs related to convex polytopes. For each fixed d-polytope and any acyclic orientation of its graph, we prove there exist both convex and concave functions that induce the given orientation. For each combinatorial class of 3-polytopes, we provide a good characterization of the orientations that are induced by an affine function acting on some member of the class. Introduction A graph is d-polytopal if it is isomorphic to the graph G(P) formed by the vertices and edges of some (convex) d-polytope P. As the term is used here, a digraph is d-polytopal if it is isomorphic to a digraph that results when the graph G(P) of some d-polytope P is oriented by means of some affine function on P. 3-Polytopes and their graphs have been objects of research since the time of Euler. The most important result concerning 3-polytopal graphs is the theorem of Steinitz [SR], [Gr1], asserting that a graph is 3-polytopal if and only if it is planar and 3-connected. Also important is the related fact that the combinatorial type (i.e., the entire face-lattice) of a 3-polytope P is determined by the graph G(P). Steinitz’s theorem has been very useful in studying the combinatorial structure of 3-polytopes because it makes it easy to recognize the 3-polytopality of a graph and to construct graphs that represent 3-polytopes without producing an explicit geometric realization.
    [Show full text]
  • Archimedean Solids
    University of Nebraska - Lincoln DigitalCommons@University of Nebraska - Lincoln MAT Exam Expository Papers Math in the Middle Institute Partnership 7-2008 Archimedean Solids Anna Anderson University of Nebraska-Lincoln Follow this and additional works at: https://digitalcommons.unl.edu/mathmidexppap Part of the Science and Mathematics Education Commons Anderson, Anna, "Archimedean Solids" (2008). MAT Exam Expository Papers. 4. https://digitalcommons.unl.edu/mathmidexppap/4 This Article is brought to you for free and open access by the Math in the Middle Institute Partnership at DigitalCommons@University of Nebraska - Lincoln. It has been accepted for inclusion in MAT Exam Expository Papers by an authorized administrator of DigitalCommons@University of Nebraska - Lincoln. Archimedean Solids Anna Anderson In partial fulfillment of the requirements for the Master of Arts in Teaching with a Specialization in the Teaching of Middle Level Mathematics in the Department of Mathematics. Jim Lewis, Advisor July 2008 2 Archimedean Solids A polygon is a simple, closed, planar figure with sides formed by joining line segments, where each line segment intersects exactly two others. If all of the sides have the same length and all of the angles are congruent, the polygon is called regular. The sum of the angles of a regular polygon with n sides, where n is 3 or more, is 180° x (n – 2) degrees. If a regular polygon were connected with other regular polygons in three dimensional space, a polyhedron could be created. In geometry, a polyhedron is a three- dimensional solid which consists of a collection of polygons joined at their edges. The word polyhedron is derived from the Greek word poly (many) and the Indo-European term hedron (seat).
    [Show full text]
  • Steinitz's Theorem Project Report §1 Introduction §2 Basic Definitions
    Steinitz's Theorem Project Report Jon Hillery May 17, 2019 §1 Introduction Looking at the vertices and edges of polyhedra gives a family of graphs that we might expect has nice properties. It turns out that there is actually a very nice characterization of these graphs! We can use this characterization to find useful representations of certain graphs. §2 Basic Definitions We define a space to be convex if the line segment connecting any two points in the space remains entirely inside the space. This works for two-dimensional sets: and three-dimensional sets: Given a polyhedron, we define its 1-skeleton to be the graph formed from the vertices and edges of the polyhedron. For example, the 1-skeleton of a tetrahedron is K4: 1 Jon Hillery (May 17, 2019) Steinitz's Theorem Project Report Here are some further examples of the 1-skeleton of an icosahedron and a dodecahedron: §3 Properties of 1-Skeletons What properties do we know the 1-skeleton of a convex polyhedron must have? First, it must be planar. To see this, imagine moving your eye towards one of the faces until you are close enough that all of the other faces appear \inside" the face you are looking through, as shown here: This is always possible because the polyedron is convex, meaning intuitively it doesn't have any parts that \jut out". The graph formed from viewing in this way will have no intersections because the polyhedron is convex, so the straight-line rays our eyes see are not allowed to leave via an edge on the boundary of the polyhedron and then go back inside.
    [Show full text]
  • Edge Energies and S S of Nan O Pred P I Tatt
    SAND2007-0238 .. j c..* Edge Energies and S s of Nan o pred p i tatt dexim 87185 and Llverm ,ultIprogramlabora lartln Company, for Y'S 11 Nuclear Security Admini 85000. Approved for Inallon unlimited. Issued by Sandia National Laboratories, operated for the United States Department of Energy by Sandia Corporation. NOTICE: This report was prepared as an account of work sponsored by an agency of the United States Government. Neither the United States Government, nor any agency thereof, nor any of their employees, nor any of their contractors, subcontractors, or their employees, make any warranty, express or implied, or assume any legal liability or responsibility for the accuracy, completeness, or usefidness of any information, apparatus, product, or process disclosed, or represent that its use would not infringe privately owned rights. Reference herein to any specific commercial product, process, or service by trade name, trademark, manufacturer, or otherwise, does not necessarily constitute or imply its endorsement, recommendation, or favoring by the United States Government, any agency thereof, or any of their contractors or subcontractors. The views and opinions expressed herein do not necessarily state or reflect those of the United States Government, any agency thereof, or any of their contractors. Printed in the United States of America. This report has been reproduced directly from the best available copy. Available to DOE and DOE contractors from U.S. Department of Energy Office of Scientific and Technical Information P.O. Box 62 Oak Ridge, TN 3783 1 Telephone: (865) 576-8401 Facsimile: (865) 576-5728 E-Mail: reDorts(cL.adonls.os(I.oov Online ordering: htto://www.osti.ao\ /bridge Available to the public from U.S.
    [Show full text]
  • 15 BASIC PROPERTIES of CONVEX POLYTOPES Martin Henk, J¨Urgenrichter-Gebert, and G¨Unterm
    15 BASIC PROPERTIES OF CONVEX POLYTOPES Martin Henk, J¨urgenRichter-Gebert, and G¨unterM. Ziegler INTRODUCTION Convex polytopes are fundamental geometric objects that have been investigated since antiquity. The beauty of their theory is nowadays complemented by their im- portance for many other mathematical subjects, ranging from integration theory, algebraic topology, and algebraic geometry to linear and combinatorial optimiza- tion. In this chapter we try to give a short introduction, provide a sketch of \what polytopes look like" and \how they behave," with many explicit examples, and briefly state some main results (where further details are given in subsequent chap- ters of this Handbook). We concentrate on two main topics: • Combinatorial properties: faces (vertices, edges, . , facets) of polytopes and their relations, with special treatments of the classes of low-dimensional poly- topes and of polytopes \with few vertices;" • Geometric properties: volume and surface area, mixed volumes, and quer- massintegrals, including explicit formulas for the cases of the regular simplices, cubes, and cross-polytopes. We refer to Gr¨unbaum [Gr¨u67]for a comprehensive view of polytope theory, and to Ziegler [Zie95] respectively to Gruber [Gru07] and Schneider [Sch14] for detailed treatments of the combinatorial and of the convex geometric aspects of polytope theory. 15.1 COMBINATORIAL STRUCTURE GLOSSARY d V-polytope: The convex hull of a finite set X = fx1; : : : ; xng of points in R , n n X i X P = conv(X) := λix λ1; : : : ; λn ≥ 0; λi = 1 : i=1 i=1 H-polytope: The solution set of a finite system of linear inequalities, d T P = P (A; b) := x 2 R j ai x ≤ bi for 1 ≤ i ≤ m ; with the extra condition that the set of solutions is bounded, that is, such that m×d there is a constant N such that jjxjj ≤ N holds for all x 2 P .
    [Show full text]
  • What Is a Polyhedron?
    3. POLYHEDRA, GRAPHS AND SURFACES 3.1. From Polyhedra to Graphs What is a Polyhedron? Now that we’ve covered lots of geometry in two dimensions, let’s make things just a little more difficult. We’re going to consider geometric objects in three dimensions which can be made from two-dimensional pieces. For example, you can take six squares all the same size and glue them together to produce the shape which we call a cube. More generally, if you take a bunch of polygons and glue them together so that no side gets left unglued, then the resulting object is usually called a polyhedron.1 The corners of the polygons are called vertices, the sides of the polygons are called edges and the polygons themselves are called faces. So, for example, the cube has 8 vertices, 12 edges and 6 faces. Different people seem to define polyhedra in very slightly different ways. For our purposes, we will need to add one little extra condition — that the volume bound by a polyhedron “has no holes”. For example, consider the shape obtained by drilling a square hole straight through the centre of a cube. Even though the surface of such a shape can be constructed by gluing together polygons, we don’t consider this shape to be a polyhedron, because of the hole. We say that a polyhedron is convex if, for each plane which lies along a face, the polyhedron lies on one side of that plane. So, for example, the cube is a convex polyhedron while the more complicated spec- imen of a polyhedron pictured on the right is certainly not convex.
    [Show full text]
  • Graphs of Polyhedra and the Theorem of Steinitz by António Guedes De Oliveira*
    Graphs of polyhedra and the theorem of Steinitz by António Guedes de Oliveira* The theorem of Steinitz characterizes in simple terms the graphs of the polyhedra. In fact, the characteristic properties of such graphs, according to the theorem, are not only simple but “very natural”, in that they occur in various different contexts. As a consequence, for exam- ple, polyhedra and typical polyhedral constructions can be used for finding rectangles that can be decomposed in non-congruent squares (see Figure 1). The extraordi- nary theorem behind this relation is due to Steinitz and is the main topic of the present paper. Steinitz’s theorem was first published in a scientific encyclopaedia, in 1922 [16], and later, in 1934, in a book [17], after Steinitz’s death. It was ignored for a long time, but after “being discovered” its importance never ceased to increase and it is the starting point for active research even to our days. In the middle of the last century, two very important books were published in Polytope The- ory. The first one, by Alexander D. Alexandrov, which was published in Russian in 1950 and in German, under the title “Konvexe Polyeder” [1], in 1958, does not men- Figure 1.— Decomposition of a rectangle in tion this theorem. The second one, by Branko Grünbaum, non-congruent squares “Convex Polytopes”, published for the first time in 1967 (and dedicated exactly to the “memory of the extraordi- nary geometer Ernst Steinitz”), considers this theorem as the “most important and the deepest of the known results about polyhedra” [9, p.
    [Show full text]
  • Steinitz's Theorem, I
    Steinitz’s Theorem, I Realization Spaces of Polytopes Winter Semester 2020/2021 Marta Panizzut November 24, 2020 1 / 20 Steinitz’s Theorem Theorem 8 [Steinitz ’22] A finite graph is the edge-graph of a 3-polytope if and only if it is simple, planar and 3-connected. “only if”: radial projection to the sphere from an interior point or Schlegel diagram + Balinski’s theorem. 2 / 20 Theorem 9 Let G be a graph. (i) [Menger’s Theorem] If G is 3-connected, then between any pair of vertices there are three paths G1, G2 and G3 that are disjoint except for the endpoints. (ii) If there are three vertices u,v,w that are connected by three different Y -graphs Y1, Y2 and Y3 that are disjoint except for u, v and w, then G is not planar. (iii) [Whitney’s Theorem] If G is planar and 3-connected then the set cells(G ,D) is independent on the particular choice of a drawing D of G. (iv) [Euler’s Theorem] If G is planar and 2-connected and D is a drawing of G, then the numbers of cells c cells(G ,D) , Æ j j vertices v V , and edges e E are related by Æ j j Æ j j v c e 2. Å Æ Å 3 / 20 Idea of the proof Draw a 3-connected planar graph such that its edges are Ï represented by line segments, and the cells are convex polygons. If the boundary of the drawing of G is a triangle, then the Ï figure is a Schlegel diagram of a 3-polytope with edge-graph G.
    [Show full text]
  • Quantitative Steinitz's Theorems with Applications to Multi Ngered
    Quantitative Steinitzs Theorems with Applications to Multingered Grasping David Kirkpatrick Bhubaneswar Mishra and CheeKeng Yap Courant Institute of Mathematical Sciences New York University New York NY Abstract We prove the following quantitative form of a classical theorem of Steinitz Let m b e suciently large If the convex hull of a subset S of Euclidean dspace contains a unit ball centered on the origin then there is a subset of S with at most m p oints whose convex hull contains a solid ball also centered on the origin and having residual radius 2 d1 d d m The case m d was rst considered by Barany Katchalski and Pach We also show an upp er b ound on the achievable radius the residual radius must b e less than 2 d1 d m These results have applications in the problem of computing the socalled closure grasps by an mngered rob ot hand The ab ove quantitative form of Steinitzs the orem gives a notion of eciency for closure grasps The theorem also gives rise to some new problems in computational geometry We present some ecient algorithms for these problems esp ecially in the two dimensional case Septemb er 1 Supp orted by NSF Grants DCR and DCR ONR Grant NJ NSF Grant Sub contract CMU Chee Yap is supp orted in part by the German Research Foundation DFG and by the ESPRIT II Basic Research Actions Program of the EC under contract No pro ject ALCOM 2 Department of Computer Science University of British Columbia Vancouver Canada Section Intro duction d Caratheo dorys theorem states that given a subset S of Euclidean
    [Show full text]
  • REGULAR POLYTOPES in Zn Contents 1. Introduction 1 2. Some
    REGULAR POLYTOPES IN Zn ANDREI MARKOV Abstract. In [3], all embeddings of regular polyhedra in the three dimen- sional integer lattice were characterized. Here, we prove some results toward solving this problem for all higher dimensions. Similarly to [3], we consider a few special polytopes in dimension 4 that do not have analogues in higher dimensions. We then begin a classification of hypercubes, and consequently regular cross polytopes in terms of the generalized duality between the two. Fi- nally, we investigate lattice embeddings of regular simplices, specifically when such simplices can be inscribed in hypercubes of the same dimension. Contents 1. Introduction 1 2. Some special cases, and a word on convexity. 2 3. Hypercubes and Cross Polytopes 4 4. Simplices 4 5. Corrections 6 Acknowledgments 7 References 7 1. Introduction Definition 1.1. A regular polytope is a polytope such that its symmetry group action is transitive on its flags. This definition is not all that important to what we wish to accomplish, as the classification of all such polytopes is well known, and can be found, for example, in [2]. The particulars will be introduced as each case comes up. Definition 1.2. The dual of a polytope of dimension n is the polytope formed by taking the centroids of the n − 1 cells to be its vertices. The dual of the dual of a regular polytope is homothetic to the original with respect to their mutual center. We will say that a polytope is \in Zn" if one can choose a set of points in the lattice of integer points in Rn such that the points can form the vertices of said polytope.
    [Show full text]
  • Basic Concepts Today
    Basic Concepts Today • Mesh basics – Zoo – Definitions – Important properties • Mesh data structures • HW1 Polygonal Meshes • Piecewise linear approximation – Error is O(h2) 3 6 12 24 25% 6.5% 1.7% 0.4% Polygonal Meshes • Polygonal meshes are a good representation – approximation O(h2) – arbitrary topology – piecewise smooth surfaces – adtidaptive refinemen t – efficient rendering Triangle Meshes • Connectivity: vertices, edges, triangles • Geometry: vertex positions Mesh Zoo Single component, With boundaries Not orientable closed, triangular, orientable manifold Multiple components Not only triangles Non manifold Mesh Definitions • Need vocabulary to describe zoo meshes • The connectivity of a mesh is just a graph • We’ll start with some graph theory Graph Definitions B A G = graph = <VEV, E> E F C D V = vertices = {A, B, C, …, K} E = edges = {(AB), (AE), (CD), …} H I F ABE DHJG G = faces = {( ), ( ), …} J K Graph Definitions B A Vertex degree or valence = number of incident edges E deg(A) = 4 F C D deg(E) = 5 H I G Regular mesh = all vertex degrees are equal J K Connectivity Connected = B A path of edges connecting every two vertices E F C D H I G J K Connectivity Connected = B A path of edges connecting every two vertices E F Subgraph = C D G’=<VV,E’,E’> is a subgraph of G=<V,E> if I H V’ is a subset of V and G E’ is the subset of E incident on V J K Connectivity Connected = B A path of edges connecting every two vertices E F Subgraph = C D G’=<VV,E’,E’> is a subgraph of G=<V,E> if I H V’ is a subset of V and G E’ is a subset of E incident
    [Show full text]