Geometry: 3D coordinates Attributes. e.g. normal, color, texture coordinate. Connectivity

Size: px
Start display at page:

Download "Geometry: 3D coordinates Attributes. e.g. normal, color, texture coordinate. Connectivity"

Transcription

1 Mesh Data Structures res

2 Data Structures What should be stored? Geometry: 3D coordinates Attributes eg normal, color, texture coordinate Per vertex, per face, per edge Connectivity Adjacency relationships

3 Data Structures What should it support? Rendering Geometry queries What are the vertices of face #2? Is vertex A adjacent to vertex H? Which faces are adjacent to face #? Modifications o Remove/add a vertex/face Vertex split, edge collapse

4 Data Structures How good is a data structure? Time to construct (preprocessing) Time to answer a query Time to perform an operation Space complexity Redundancy

5 Mesh Data Structures Face Set Shared Vertex Half Edge Face Based Connectivity Edge Based Connectivity Adjacency Matrix Corner Table

6 Face Set TRIANGLES Vertex coord Vertex coord Vertex coord [ ] [ ] [0 4 3] Simple STL File No connectivity Redundancy

7 Shared Vertex TRIANGLES Vertex Index Vertex Index Vertex Index 2 3 Connectivity No neighborhood VERTICES Vertex Coord [ ] [ ] [0 4 3]

8 Shared Vertex v v 6 3 TRIANGLES f v f 2 f 4 f 2 3 v v 3 VERTICES [20 0 0] [9 20 0] [4 5 0]

9 Shared Vertex v v 6 3 TRIANGLES f v f 2 f 4 f 2 3 v v 3 VERTICES [20 0 0] [9 20 0] [4 5 0] What are the vertices of face f? O() first triplet from face list

10 Shared Vertex v v 6 3 TRIANGLES f v f 2 f 4 f 2 3 v v 3 VERTICES [20 0 0] [9 20 0] [4 5 0] What are the one ring neighbors of v 3? Requires a full pass over all vertices

11 Shared Vertex v v 6 3 TRIANGLES f v f 2 f 4 f 2 3 v v 3 VERTICES [20 0 0] [9 20 0] [4 5 0] Are vertices v and adjacent? Requires a full pass over all faces

12 Half Edge Data Structure Vertex stores Position outgoing halfedge vertex outgoing halfedge

13 Half Edge Data Structure Hlfd Halfedge stores origin vertex index incident face index next, prev, twin halfedge indices halfedge twin origin vertex next

14 Half Edge Data Structure Face stores adjacent halfedge index adjacent halfedge face

15 Half Edge Data Structure Nihb Neighborhood h dtraversal a) b) c) d)

16 Face Based Connectivity Vertex: position adjacent face index Face: 3 vertex indices 3 neighboring face indices No (explicit) edge information

17 Edge Based Connectivity Vertex position adjacent edge index Edge 2 vertex indices 2 neighboring face indices 4 edges Face edge index No edge orientation information

18 Adjacency Matrix v v 6 3 v v 3 v 6 v f v f 2 f 4 A = v 3 v 5 Adjacency Matrix A If there is an edge between v i & v j then A ij = v 6

19 Adjacency Matrix Symmetric for undirected simple graphs (A n ) ij = # paths of length n from v i to v j Pros: Canrepresent non manifold meshes Cons: N i b d i No connection between a vertex and its adjacent faces

20 Corner Table Corner is a vertex with one of its indicent triangles v 3 v 6 c 3 c 4 c 9 c 7 c2 v c f f 2 c 6 c f 0 4 c 2 c 5 c c 8

21 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c c 3 c 4 c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

22 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct c 3 c 4 c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

23 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv c 3 c 4 c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

24 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv c 3 c 4 c 9 c 7 c2 Next corner in ct(ccw) ct cn cn f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

25 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv Next corner in ct(ccw) ct cn cn Previous corner cp(== cnn) c 3 c 4 c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

26 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv Next corner in ct(ccw) ct cn cn Previous corner cp(== cnn) Corner opposite c co Edge E opposite c not incident on cv Triangle T adjacent to ct across E cov vertex of T that is not incident on E c 3 c 4 c 9 c 7 c2 f v c E c 8 T f 4 c 6 c 0 c 2 c 5 c

27 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv Next corner in ct(ccw) ct cn cn Previous corner cp(== cnn) Corner opposite c co Edge E opposite c not incident on cv c 3 c 4 Triangle T adjacent to ct across E cov vertex of T that is not incident on E Right corner cr corner opposite cn (== cno) c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

28 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 Corner c Triangle ct Vertex cv Next corner in ct(ccw) ct cn cn Previous corner cp(== cnn) Corner opposite c co Edge E opposite c not incident on cv c 3 c 4 Triangle T adjacent to ct across E cov vertex of T that is not incident on E Right corner cr corner opposite cn (== cno) Left corner cl (== cpo == cnno) c 9 c 7 c2 f c v c 8 f 2 f 4 c 6 c 0 c 2 c 5 c

29 Corner Table Corner is a vertex with one of its indicent triangles Corner c Triangle ct Vertex cv Next corner in ct(ccw) ct cn cn Previous corner cp (== cnn) Corner opposite c co Edge E opposite c not incident on cv Triangle T adjacent to ct across E cov vertex of T that is not incident on E Right corner cr corner opposite cn (== cno) Left corner cl (== cpo == cnno)

30 Corner Table Corner is a vertex with one of its indicent triangles v v 6 3 c c 7 corner cv ct cn cp co cr cl 9 c c2 3 c 4 c v f c 2 c 3 c 6 f v c f 2 f 4 c 6 c 0 c 2 c 5 c c 8

31 Corner Table Corner is a vertex with one of its indicent triangles v 3 v 6 corner c c 7 9 c c2 3 c 4 c v f c 2 c 3 c f3 6 c 2 f c 3 c c6 c 8 c 3 v 3 f c c 2 c 6 c 4 v 3 f 2 c 5 c 6 c 7 c 4 c 2 c 5 c c 5 f 2 c 6 c 4 c 7 c c 6 f 2 c 4 c 5 c c 7 f v c f 2 f 4 c 6 c 0 cv ct cn cp co cr cl

32 Corner Table Store: Corner table For each vertex a list of all its corners Corner number j*3 2, j*3 and j*3 match Corner number j 3 2, j 3 and j 3 match face number j

33 Corner Table What are the vertices of face #3? Check cv of corners 9, 8, 7 v 3 v 6 c 3 c 4 c 9 c 7 c2 c 8 f v c f 2 c 6 c 0 f 4 c 2 c 5 c

34 Corner Table Are vertices 2and 6adjacent? Scan all corners of vertex 2, check if cpv or cnv are 6 v 3 v 6 c 3 c 4 c 9 c 7 c2 c 8 f v c f 2 c 6 c 0 f 4 c 2 c 5 c

35 Corner Table Which faces are adjacent to vertex 3? Check ct of all corners of vertex 3 v 3 v 6 c 3 c 4 c 9 c 7 c2 c 8 f v c f 2 c 6 c 0 f 4 c 2 c 5 c

36 Corner Table One ring neighbors of vertex? Get the corners c 6 c 8 c 0 of this vertex Go to c i nv and c i pv for i = 6, 8, 0 Remove duplicates v v 6 3 c 3 c 4 c 9 c 7 c2 f v c f 2 f 4 c 6 c 0 c 2 c 5 2 c 8 c

37 Corner Table Pros: All queries in O() time Most operations are O() Convenient for rendering Cons: Only triangular, manifold meshes Redundancy

Mesh and Mesh Simplification

Mesh and Mesh Simplification Slide Credit: Mirela Ben-Chen Mesh and Mesh Simplification Qixing Huang Mar. 21 st 2018 Mesh DataStructures Data Structures What should bestored? Geometry: 3D coordinates Attributes e.g. normal, color,

More information

Mesh Basics: Definitions, Topology & Data Structures. Standard Graph Definitions

Mesh Basics: Definitions, Topology & Data Structures. Standard Graph Definitions Mesh : Definitions, Topology & Data Structures 1 Standard Graph Definitions G = V = vertices = {A,B,C,D,E,F,G,H,I,J,K,L} E = edges = {(A,B),(B,C),(C,D),(D,E),(E,F),(F,G), (G,H),(H,A),(A,J),(A,G),(B,J),(K,F),

More information

Surface reconstruction Introduction. Florent Lafarge Inria Sophia Antipolis - Mediterranee

Surface reconstruction Introduction. Florent Lafarge Inria Sophia Antipolis - Mediterranee Surface reconstruction Introduction Florent Lafarge Inria Sophia Antipolis - Mediterranee Outline Contents Introduction Smooth/piecewise-smooth reconstruction methods Primitive-based reconstruction methods

More information

Mesh Data Structures. Geometry processing. In this course. Mesh gallery. Mesh data

Mesh Data Structures. Geometry processing. In this course. Mesh gallery. Mesh data Gomtry procssing Msh Data Structurs Msh data Gomtry Connctivity Data structur slction dpnds on Msh typ Algorithm rquirmnts 2 Msh gallry In this cours Only orintabl, triangular, manifold mshs Singl componnt,

More information

: Mesh Processing. Chapter 2

: Mesh Processing. Chapter 2 600.657: Mesh Processing Chapter 2 Data Structures Polygon/Triangle Soup Indexed Polygon/Triangle Set Winged-Edge Half-Edge Directed-Edge List of faces Polygon Soup Each face represented independently

More information

Meshes. Mesh elements

Meshes. Mesh elements Meshes polygonal soup polygons specified one-by-one with no explicit information on shared vertices polygonal nonmanifold connectivity information is provided (which vertices are shared) no restrictions

More information

CS 532: 3D Computer Vision 12 th Set of Notes

CS 532: 3D Computer Vision 12 th Set of Notes 1 CS 532: 3D Computer Vision 12 th Set of Notes Instructor: Philippos Mordohai Webpage: www.cs.stevens.edu/~mordohai E-mail: Philippos.Mordohai@stevens.edu Office: Lieb 215 Lecture Outline Meshes Slides

More information

Applications. Oversampled 3D scan data. ~150k triangles ~80k triangles

Applications. Oversampled 3D scan data. ~150k triangles ~80k triangles Mesh Simplification Applications Oversampled 3D scan data ~150k triangles ~80k triangles 2 Applications Overtessellation: E.g. iso-surface extraction 3 Applications Multi-resolution hierarchies for efficient

More information

Geometric Modeling. Mesh Decimation. Mesh Decimation. Applications. Copyright 2010 Gotsman, Pauly Page 1. Oversampled 3D scan data

Geometric Modeling. Mesh Decimation. Mesh Decimation. Applications. Copyright 2010 Gotsman, Pauly Page 1. Oversampled 3D scan data Applications Oversampled 3D scan data ~150k triangles ~80k triangles 2 Copyright 2010 Gotsman, Pauly Page 1 Applications Overtessellation: E.g. iso-surface extraction 3 Applications Multi-resolution hierarchies

More information

1 - An initial focus on smeshes

1 - An initial focus on smeshes In this chapter, we define a subclass of triangle meshes, which we call smeshes. We introduce simple data structures for representing smeshes, low-level operators for building and accessing these representations,

More information

Lecture 3 Mesh. Dr. Shuang LIANG. School of Software Engineering Tongji University Spring 2013

Lecture 3 Mesh. Dr. Shuang LIANG. School of Software Engineering Tongji University Spring 2013 Lecture 3 Mesh Dr. Shuang LIANG School of Software Engineering Tongji University Spring 2013 Today s Topics Overview Mesh Acquisition Mesh Data Structures Subdivision Surfaces Today s Topics Overview Mesh

More information

Meshes and Manifolds. Computer Graphics CMU /15-662

Meshes and Manifolds. Computer Graphics CMU /15-662 Meshes and Manifolds Computer Graphics CMU 15-462/15-662 Fractal Quiz Last time: overview of geometry Many types of geometry in nature Geometry Demand sophisticated representations Two major categories:

More information

Appearance Preservation

Appearance Preservation CS 283 Advanced Computer Graphics Mesh Simplification James F. O Brien Professor U.C. Berkeley Based on slides by Ravi Ramamoorthi 1 Appearance Preservation Caltech & Stanford Graphics Labs and Jonathan

More information

Mesh Representations & Geometry Processing

Mesh Representations & Geometry Processing Lecture 10/11: Mesh Representations & Geometry Processing Computer Graphics and Imaging UC Berkeley A Small Triangle Mesh 8 vertices, 12 triangles A Large Triangle Mesh David Digital Michelangelo Project

More information

Compression of Tetrahedral Meshes

Compression of Tetrahedral Meshes Compression of Tetrahedral Meshes Geometry Processing CS 7960 Louis Bavoil 01/19/2006 Outline Corner Table Edgebreaker Efficiency Edgebreaker with Boundary Corner Table Two arrays of integers: V and O

More information

Geometry Processing & Geometric Queries. Computer Graphics CMU /15-662

Geometry Processing & Geometric Queries. Computer Graphics CMU /15-662 Geometry Processing & Geometric Queries Computer Graphics CMU 15-462/15-662 Last time: Meshes & Manifolds Mathematical description of geometry - simplifying assumption: manifold - for polygon meshes: fans,

More information

Graphs. Graph Structures

Graphs. Graph Structures Graphs A graph G consists of a set V of vertices and a set E of pairs of distinct vertices from V. These pairs of vertices are called edges. If the pairs of vertices are unordered, G is an undirected graph.

More information

Polygonal Mesh. Geometric object made of vertices, edges and faces. Faces are polygons. Polyhedron. Triangular mesh Quad mesh. Pyramid Cube Sphere (?

Polygonal Mesh. Geometric object made of vertices, edges and faces. Faces are polygons. Polyhedron. Triangular mesh Quad mesh. Pyramid Cube Sphere (? 1 Mesh Modeling Polygonal Mesh Geometric object made of vertices, edges and faces Polyhedron Pyramid Cube Sphere (?) Can also be 2D (although much less interesting) Faces are polygons Triangular mesh Quad

More information

DISCRETE DIFFERENTIAL GEOMETRY: AN APPLIED INTRODUCTION Keenan Crane CMU /858B Fall 2017

DISCRETE DIFFERENTIAL GEOMETRY: AN APPLIED INTRODUCTION Keenan Crane CMU /858B Fall 2017 DISCRETE DIFFERENTIAL GEOMETRY: AN APPLIED INTRODUCTION Keenan Crane CMU 15-458/858B Fall 2017 LECTURE 2: THE SIMPLICIAL COMPLEX DISCRETE DIFFERENTIAL GEOMETRY: AN APPLIED INTRODUCTION Keenan Crane CMU

More information

UNIVERSITY OF CALGARY. Subdivision Surfaces. Advanced Geometric Modeling Faramarz Samavati

UNIVERSITY OF CALGARY. Subdivision Surfaces. Advanced Geometric Modeling Faramarz Samavati Subdivision Surfaces Surfaces Having arbitrary Topologies Tensor Product Surfaces Non Tensor Surfaces We can t find u-curves and v-curves in general surfaces General Subdivision Coarse mesh Subdivision

More information

Geometric Modeling Based on Polygonal Meshes: OpenMesh

Geometric Modeling Based on Polygonal Meshes: OpenMesh Geometric Modeling Based on Polygonal Meshes: OpenMesh Prof. Dr. Mario Botsch Computer Graphics & Geometry Processing 2 OpenMesh 1.1.0 Developed at RWTH Aachen C++ library for polygonal / triangle meshes

More information

Adjacency Data Structures

Adjacency Data Structures Last Time? Simple Transformations Adjacency Data Structures material from Justin Legakis Classes of Transformations Representation homogeneous coordinates Composition not commutative Orthographic & Perspective

More information

ECE 158A - Data Networks

ECE 158A - Data Networks ECE 158A - Data Networks Homework 2 - due Tuesday Nov 5 in class Problem 1 - Clustering coefficient and diameter In this problem, we will compute the diameter and the clustering coefficient of a set of

More information

Digital Geometry Processing. Computer Graphics CMU /15-662

Digital Geometry Processing. Computer Graphics CMU /15-662 Digital Geometry Processing Computer Graphics CMU 15-462/15-662 Last time: Meshes & Manifolds Mathematical description of geometry - simplifying assumption: manifold - for polygon meshes: fans, not fins

More information

Hermite Curves. Hermite curves. Interpolation versus approximation Hermite curve interpolates the control points Piecewise cubic polynomials

Hermite Curves. Hermite curves. Interpolation versus approximation Hermite curve interpolates the control points Piecewise cubic polynomials Hermite Curves Hermite curves Interpolation versus approximation Hermite curve interpolates the control points Piecewise cubic polynomials Focus on one segment T1 P0 Q(t) T0 Control points of Bezier curve

More information

13 - Meshes. Acknowledgement: Enrico Puppo. CSCI-GA Computer Graphics - Fall 16 - Daniele Panozzo

13 - Meshes. Acknowledgement: Enrico Puppo. CSCI-GA Computer Graphics - Fall 16 - Daniele Panozzo 13 - Meshes Acknowledgement: Enrico Puppo What is a mesh? A surface made of polygonal faces glued at common edges Origin of Meshes In nature, meshes arise in a variety of contexts: Cells in organic tissues

More information

Mesh Repairing and Simplification. Gianpaolo Palma

Mesh Repairing and Simplification. Gianpaolo Palma Mesh Repairing and Simplification Gianpaolo Palma Mesh Repairing Removal of artifacts from geometric model such that it becomes suitable for further processing Input: a generic 3D model Output: (hopefully)a

More information

An Introduction to Geometric Modeling using Polygonal Meshes

An Introduction to Geometric Modeling using Polygonal Meshes An Introduction to Geometric Modeling using Polygonal Meshes Joaquim Madeira Version 0.2 October 2014 U. Aveiro, October 2014 1 Main topics CG and affine areas Geometric Modeling Polygonal meshes Exact

More information

Parameterization with Manifolds

Parameterization with Manifolds Parameterization with Manifolds Manifold What they are Why they re difficult to use When a mesh isn t good enough Problem areas besides surface models A simple manifold Sphere, torus, plane, etc. Using

More information

CGAL. Mesh Simplification. (Slides from Tom Funkhouser, Adam Finkelstein)

CGAL. Mesh Simplification. (Slides from Tom Funkhouser, Adam Finkelstein) CGAL Mesh Simplification (Slides from Tom Funkhouser, Adam Finkelstein) Siddhartha Chaudhuri http://www.cse.iitb.ac.in/~cs749 In a nutshell Problem: Meshes have too many polygons for storage, rendering,

More information

Scanning Real World Objects without Worries 3D Reconstruction

Scanning Real World Objects without Worries 3D Reconstruction Scanning Real World Objects without Worries 3D Reconstruction 1. Overview Feng Li 308262 Kuan Tian 308263 This document is written for the 3D reconstruction part in the course Scanning real world objects

More information

CS 468, Spring 2013 Differential Geometry for Computer Science Justin Solomon and Adrian Butscher

CS 468, Spring 2013 Differential Geometry for Computer Science Justin Solomon and Adrian Butscher http://alice.loria.fr/index.php/publications.html?redirect=0&paper=vsdm@2011&author=levy CS 468, Spring 2013 Differential Geometry for Computer Science Justin Solomon and Adrian Butscher µ R 3 µ R 2 http://upload.wikimedia.org/wikipedia/commons/b/bc/double_torus_illustration.png

More information

Mesh Decimation. Mark Pauly

Mesh Decimation. Mark Pauly Mesh Decimation Mark Pauly Applications Oversampled 3D scan data ~150k triangles ~80k triangles Mark Pauly - ETH Zurich 280 Applications Overtessellation: E.g. iso-surface extraction Mark Pauly - ETH Zurich

More information

Triangle meshes 2. CS 4620 Lecture Steve Marschner. Cornell CS4620 Fall 2018 Lecture 3

Triangle meshes 2. CS 4620 Lecture Steve Marschner. Cornell CS4620 Fall 2018 Lecture 3 Triangle meshes 2 CS 4620 Lecture 3 2018 Steve Marschner 1 Practical encoding of meshes OBJ file format widely used format for polygon meshes supports the usual attributes: position, normal, texture coordinate

More information

polygon meshes polygon meshes representation

polygon meshes polygon meshes representation polygon meshes computer graphics polygon meshes 2009 fabio pellacini 1 polygon meshes representation which representation is good? often triangles/quads only will work on triangles compact efficient for

More information

Higher Order Surfaces in OpenGL with NV_evaluators. Sébastien Dominé

Higher Order Surfaces in OpenGL with NV_evaluators. Sébastien Dominé Higher Order Surfaces in OpenGL with NV_evaluators Sébastien Dominé Why surfaces? Higher order primitives Animation Level of Detail Bandwidth Filtering 2 Overview What are the general evaluators defined

More information

Subdivision Curves and Surfaces: An Introduction

Subdivision Curves and Surfaces: An Introduction Subdivision Curves and Surfaces: An Introduction Corner Cutting De Casteljau s and de Boor s algorithms all use corner-cutting procedures. Corner cutting can be local or non-local. A cut is local if it

More information

Geometric Features for Non-photorealistiic Rendering

Geometric Features for Non-photorealistiic Rendering CS348a: Computer Graphics Handout # 6 Geometric Modeling and Processing Stanford University Monday, 27 February 2017 Homework #4: Due Date: Mesh simplification and expressive rendering [95 points] Wednesday,

More information

coding of various parts showing different features, the possibility of rotation or of hiding covering parts of the object's surface to gain an insight

coding of various parts showing different features, the possibility of rotation or of hiding covering parts of the object's surface to gain an insight Three-Dimensional Object Reconstruction from Layered Spatial Data Michael Dangl and Robert Sablatnig Vienna University of Technology, Institute of Computer Aided Automation, Pattern Recognition and Image

More information

Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees

Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees Alexander Greß and Reinhard Klein University of Bonn Institute of Computer Science II Römerstraße 164, 53117 Bonn, Germany

More information

Joint Advanced Student School 2007 Martin Dummer

Joint Advanced Student School 2007 Martin Dummer Sierpiński-Curves Joint Advanced Student School 2007 Martin Dummer Statement of the Problem What is the best way to store a triangle mesh efficiently in memory? The following points are desired : Easy

More information

Curve Corner Cutting

Curve Corner Cutting Subdivision ision Techniqueses Spring 2010 1 Curve Corner Cutting Take two points on different edges of a polygon and join them with a line segment. Then, use this line segment to replace all vertices

More information

Example: Loop Scheme. Example: Loop Scheme. What makes a good scheme? recursive application leads to a smooth surface.

Example: Loop Scheme. Example: Loop Scheme. What makes a good scheme? recursive application leads to a smooth surface. Example: Loop Scheme What makes a good scheme? recursive application leads to a smooth surface 200, Denis Zorin Example: Loop Scheme Refinement rule 200, Denis Zorin Example: Loop Scheme Two geometric

More information

CS 4620 Midterm 1. Tuesday 22 October minutes

CS 4620 Midterm 1. Tuesday 22 October minutes CS 4620 Midterm 1 Tuesday 22 October 2013 90 minutes Problem 1: Transformations (20 pts) Consider the affine transformation on R 3 defined in homogeneous coordinates by the matrix: 1 M = 1 0 0 2 0 1 0

More information

3D Mesh Compression in Open3DGC. Khaled MAMMOU

3D Mesh Compression in Open3DGC. Khaled MAMMOU 3D Mesh Compression in Open3DGC Khaled MAMMOU OPPORTUNITIES FOR COMPRESSION Indexed Face Set Geometry: positions Connectivity: of triangles Requires 192 bits per vertex! Redundancy Indexes repeated multiple

More information

Adjacency Data Structures

Adjacency Data Structures Assignment 1 Adjacency Data Structures Creative Ideas? Having Fun? Mailing list material from Justin Legakis Last Time? Simple Transformations How do we compute Average Normals? Illusion of smooth surfaces

More information

Shape Modeling and Geometry Processing Exercise 1: libigl Hello World

Shape Modeling and Geometry Processing Exercise 1: libigl Hello World Shape Modeling and Geometry Processing Exercise 1: libigl Hello World Acknowledgments: Olga Diamanti, Julian Panetta Exercise 1 - libigl Hello World! Experiment with the geometry processing library Exercise

More information

Some Graph Theory for Network Analysis. CS 249B: Science of Networks Week 01: Thursday, 01/31/08 Daniel Bilar Wellesley College Spring 2008

Some Graph Theory for Network Analysis. CS 249B: Science of Networks Week 01: Thursday, 01/31/08 Daniel Bilar Wellesley College Spring 2008 Some Graph Theory for Network Analysis CS 9B: Science of Networks Week 0: Thursday, 0//08 Daniel Bilar Wellesley College Spring 008 Goals this lecture Introduce you to some jargon what we call things in

More information

Shape Modeling and Geometry Processing Exercise 1 - libigl Hello World

Shape Modeling and Geometry Processing Exercise 1 - libigl Hello World Shape Modeling and Geometry Processing Exercise 1 - libigl Hello World michael.rabinovich@inf.ethz.ch Acknowledgments: Olga Diamanti 1 Exercise Sessions Friday from 09-10 at CAB, G 52 Exercise discussion

More information

Subdivision Surfaces

Subdivision Surfaces Subdivision Surfaces 1 Geometric Modeling Sometimes need more than polygon meshes Smooth surfaces Traditional geometric modeling used NURBS Non uniform rational B-Spline Demo 2 Problems with NURBS A single

More information

Geometric Modeling in Graphics

Geometric Modeling in Graphics Geometric Modeling in Graphics Part 1: Polygonal Meshes Martin Samuelčík www.sccg.sk/~samuelcik samuelcik@sccg.sk Geometric object Set of connected points in space Usually inside Euclidean space (orthonormal

More information

Notation. Triangle meshes. Topology/geometry examples. Validity of triangle meshes. n T = #tris; n V = #verts; n E = #edges

Notation. Triangle meshes. Topology/geometry examples. Validity of triangle meshes. n T = #tris; n V = #verts; n E = #edges Notation n T = #tris; n V = #verts; n E = #edges Triangle meshes Euler: n V n E + n T = 2 for a simple closed surface and in general sums to small integer argument for implication that n T :n E :n V is

More information

CS Object Representation. Aditi Majumder, CS 112 Slide 1

CS Object Representation. Aditi Majumder, CS 112 Slide 1 CS 112 - Object Representation Aditi Majumder, CS 112 Slide 1 What is Graphics? Modeling Computer representation of the 3D world Analysis For efficient rendering For catering the model to different applications..

More information

3D Modeling: Surfaces

3D Modeling: Surfaces CS 430/536 Computer Graphics I 3D Modeling: Surfaces Week 8, Lecture 16 David Breen, William Regli and Maxim Peysakhov Geometric and Intelligent Computing Laboratory Department of Computer Science Drexel

More information

Saab. Kyle McDonald. Polygon Meshes

Saab. Kyle McDonald. Polygon Meshes Saab Kyle McDonald Polygon Meshes Siddhartha Chaudhuri http://www.cse.iitb.ac.in/~cs749 What is a polygon mesh? Like a point cloud, it is a discrete sampling of a surface... but, it adds linear (flat)

More information

Graphs. Introduction To Graphs: Exercises. Definitions:

Graphs. Introduction To Graphs: Exercises. Definitions: Graphs Eng.Jehad Aldahdooh Introduction To Graphs: Definitions: A graph G = (V, E) consists of V, a nonempty set of vertices (or nodes) and E, a set of edges. Each edge has either one or two vertices associated

More information

Geometric Modeling and Processing

Geometric Modeling and Processing Geometric Modeling and Processing Tutorial of 3DIM&PVT 2011 (Hangzhou, China) May 16, 2011 6. Mesh Simplification Problems High resolution meshes becoming increasingly available 3D active scanners Computer

More information

An Efficient Data Structure for Representing Trilateral/Quadrilateral Subdivision Surfaces

An Efficient Data Structure for Representing Trilateral/Quadrilateral Subdivision Surfaces BULGARIAN ACADEMY OF SCIENCES CYBERNETICS AND INFORMATION TECHNOLOGIES Volume 3, No 3 Sofia 203 Print ISSN: 3-9702; Online ISSN: 34-408 DOI: 0.2478/cait-203-0023 An Efficient Data Structure for Representing

More information

Recollection. Models Pixels. Model transformation Viewport transformation Clipping Rasterization Texturing + Lights & shadows

Recollection. Models Pixels. Model transformation Viewport transformation Clipping Rasterization Texturing + Lights & shadows Recollection Models Pixels Model transformation Viewport transformation Clipping Rasterization Texturing + Lights & shadows Can be computed in different stages 1 So far we came to Geometry model 3 Surface

More information

Triangle meshes. Computer Graphics CSE 167 Lecture 8

Triangle meshes. Computer Graphics CSE 167 Lecture 8 Triangle meshes Computer Graphics CSE 167 Lecture 8 Examples Spheres Andrzej Barabasz Approximate sphere Rineau & Yvinec CGAL manual Based on slides courtesy of Steve Marschner 2 Examples Finite element

More information

Subdivision Surfaces. Homework 1: Questions on Homework? Last Time? Today. Tensor Product. What s an illegal edge collapse?

Subdivision Surfaces. Homework 1: Questions on Homework? Last Time? Today. Tensor Product. What s an illegal edge collapse? Homework 1: Questions/Comments? Subdivision Surfaces Questions on Homework? Last Time? What s an illegal edge collapse? Curves & Surfaces Continuity Definitions 2 3 C0, G1, C1, C 1 a b 4 Interpolation

More information

This controller extract information about Faces,Edges and Vertices of an Editable Mesh or Editable Poly object.

This controller extract information about Faces,Edges and Vertices of an Editable Mesh or Editable Poly object. Mesh Controller How to use: Filtering methods: Geometry: Pick Object: Reference Object: Use Sub-Object Selection: Use methods of : Search in: Vertex: Scalar Output: Vector Output: Matrix outputs: Edge

More information

CS 4620 Midterm, March 21, 2017

CS 4620 Midterm, March 21, 2017 CS 460 Midterm, March 1, 017 This 90-minute exam has 4 questions worth a total of 100 points. Use the back of the pages if you need more space. Academic Integrity is expected of all students of Cornell

More information

Subdivision Surfaces. Homework 1: Questions/Comments?

Subdivision Surfaces. Homework 1: Questions/Comments? Subdivision Surfaces Homework 1: Questions/Comments? 1 Questions on Homework? What s an illegal edge collapse? 1 2 3 a b 4 7 To be legal, the ring of vertex neighbors must be unique (have no duplicates)!

More information

Convex Hull Generation with Quick Hull. Randy Gaul Special thanks to Stan Melax and Dirk Gregorius for contributions on this topic

Convex Hull Generation with Quick Hull. Randy Gaul Special thanks to Stan Melax and Dirk Gregorius for contributions on this topic Convex Hull Generation with Quick Hull Randy Gaul Special thanks to Stan Melax and Dirk Gregorius for contributions on this topic Overview Quick Hull (QHull) Convex Hulls Why use them Computing a Convex

More information

Paolo Cignoni ISTI CNR

Paolo Cignoni ISTI CNR A mesh processing library Paolo Cignoni ISTI CNR Intro Intro Capabilities Design/Structure Examples What A C++ template based library Include only, no compilation hassle Research Driven Library The most

More information

Geometry Processing & Geometric Queries. Computer Graphics CMU /15-662

Geometry Processing & Geometric Queries. Computer Graphics CMU /15-662 Geometry Processing & Geometric Queries Computer Graphics CMU 15-462/15-662 Last time: Meshes & Manifolds Mathematical description of geometry - simplifying assumption: manifold - for polygon meshes: fans,

More information

Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees

Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees Efficient Representation and Extraction of 2-Manifold Isosurfaces Using kd-trees Alexander Greß gress@cs.uni-bonn.de Reinhard Klein rk@cs.uni-bonn.de University of Bonn Institute of Computer Science II

More information

A Developer s Survey of Polygonal Simplification algorithms. CS 563 Advanced Topics in Computer Graphics Fan Wu Mar. 31, 2005

A Developer s Survey of Polygonal Simplification algorithms. CS 563 Advanced Topics in Computer Graphics Fan Wu Mar. 31, 2005 A Developer s Survey of Polygonal Simplification algorithms CS 563 Advanced Topics in Computer Graphics Fan Wu Mar. 31, 2005 Some questions to ask Why simplification? What are my models like? What matters

More information

Geometric Modeling. Bing-Yu Chen National Taiwan University The University of Tokyo

Geometric Modeling. Bing-Yu Chen National Taiwan University The University of Tokyo Geometric Modeling Bing-Yu Chen National Taiwan University The University of Tokyo Surface Simplification Motivation Basic Idea of LOD Discrete LOD Continuous LOD Simplification Problem Characteristics

More information

View-dependent Polygonal Simplification

View-dependent Polygonal Simplification View-dependent Polygonal Simplification Pekka Kuismanen HUT pkuisman@cc.hut.fi Abstract This paper describes methods for view-dependent simplification of polygonal environments. A description of a refinement

More information

The Matrix-Tree Theorem and Its Applications to Complete and Complete Bipartite Graphs

The Matrix-Tree Theorem and Its Applications to Complete and Complete Bipartite Graphs The Matrix-Tree Theorem and Its Applications to Complete and Complete Bipartite Graphs Frankie Smith Nebraska Wesleyan University fsmith@nebrwesleyan.edu May 11, 2015 Abstract We will look at how to represent

More information

Compressing Volumes and Animations (Tutorial Notes)

Compressing Volumes and Animations (Tutorial Notes) EUROGRAPHICS 2004 Compressing Volumes and Animations (Tutorial Notes) Jarek Rossignac College of Computing, GVU Center, IRIS Cluster Georgia Institute of Technology, Atlanta, Georgia (USA) http://www.gvu.gatech.edu/~jarek

More information

Final Project, Digital Geometry Processing

Final Project, Digital Geometry Processing Final Project, Digital Geometry Processing Shayan Hoshyari Student #: 81382153 December 2016 Introduction In this project an adaptive surface remesher has been developed based on the paper [1]. An algorithm

More information

SHORTEST PATHS ON SURFACES GEODESICS IN HEAT

SHORTEST PATHS ON SURFACES GEODESICS IN HEAT SHORTEST PATHS ON SURFACES GEODESICS IN HEAT INF555 Digital Representation and Analysis of Shapes 28 novembre 2015 Ruoqi He & Chia-Man Hung 1 INTRODUCTION In this project we present the algorithm of a

More information

OpenMesh. ACG RWTH Aachen C++ library Implements half-edge data structure Integrated basic geometric operations 3-D model file reader/writer

OpenMesh. ACG RWTH Aachen C++ library Implements half-edge data structure Integrated basic geometric operations 3-D model file reader/writer Open Mesh Reference ACG RWTH Aachen C++ library Implements half-edge data structure Integrated basic geometric operations 3-D model file reader/writer Flexible Random access to vertices, edges, and faces

More information

NVMeshMender User Guide

NVMeshMender User Guide NVMeshMender User Guide The NVMeshMender library is designed to prepare meshes for per-pixel lighting, by generating normals, tangents and binormals. Some of the issues that the library can address are:

More information

Physics Experiment 13

Physics Experiment 13 Fig. 13-1 Equipment This side of the mirror is gray. Place this side on the baseline. You can see your reflection on this side of the mirror. Fig. 13-2 Mirror Placement: The "Plexi-Ray Kit" contains a

More information

Representing graphs. Share Tweet

Representing graphs. Share Tweet Representing graphs Share Tweet Email There are several ways to represent graphs, each with its advantages and disadvantages. Some situations, or algorithms that we want to run with graphs as input, call

More information

Algorithms for GIS. Spatial data: Models and representation (part I) Laura Toma. Bowdoin College

Algorithms for GIS. Spatial data: Models and representation (part I) Laura Toma. Bowdoin College Algorithms for GIS Spatial data: Models and representation (part I) Laura Toma Bowdoin College Outline Spatial data in GIS applications Point data Networks Terrains Planar maps and meshes Data structures

More information

Triangle meshes COMP575/COMP 770

Triangle meshes COMP575/COMP 770 Triangle meshes COMP575/COMP 770 1 [Foley et al.] Notation n T = #tris; n V = #verts; n E = #edges Euler: n V n E + n T = 2 for a simple closed surface and in general sums to small integer argument for

More information

Characterizing Graphs (3) Characterizing Graphs (1) Characterizing Graphs (2) Characterizing Graphs (4)

Characterizing Graphs (3) Characterizing Graphs (1) Characterizing Graphs (2) Characterizing Graphs (4) S-72.2420/T-79.5203 Basic Concepts 1 S-72.2420/T-79.5203 Basic Concepts 3 Characterizing Graphs (1) Characterizing Graphs (3) Characterizing a class G by a condition P means proving the equivalence G G

More information

Digital Geometry Processing

Digital Geometry Processing Digital Geometry Processing Spring 2011 physical model acquired point cloud reconstructed model 2 Digital Michelangelo Project Range Scanning Systems Passive: Stereo Matching Find and match features in

More information

More Texture Mapping. Texture Mapping 1/46

More Texture Mapping. Texture Mapping 1/46 More Texture Mapping Texture Mapping 1/46 Perturbing Normals Texture Mapping 2/46 Perturbing Normals Instead of fetching a texture for color, fetch a new perturbed normal vector Creates the appearance

More information

Subdivision Surfaces

Subdivision Surfaces Subdivision Surfaces CS 4620 Lecture 31 Cornell CS4620 Fall 2015 1 Administration A5 due on Friday Dreamworks visiting Thu/Fri Rest of class Surfaces, Animation, Rendering w/ prior instructor Steve Marschner

More information

B-rep for Triangle Meshes. Gino van den Bergen Dtecta

B-rep for Triangle Meshes. Gino van den Bergen Dtecta B-rep for Triangle Meshes Gino van den Bergen Dtecta To the memory of Jan Paul van Waveren (1977-2017) B-reps in Games Mesh cutting, e.g. Woodcutting in Farming Simulator 15 and Farming Simulator 17. B-reps

More information

Advanced Lighting Techniques Due: Monday November 2 at 10pm

Advanced Lighting Techniques Due: Monday November 2 at 10pm CMSC 23700 Autumn 2015 Introduction to Computer Graphics Project 3 October 20, 2015 Advanced Lighting Techniques Due: Monday November 2 at 10pm 1 Introduction This assignment is the third and final part

More information

THE HALF-EDGE DATA STRUCTURE MODELING AND ANIMATION

THE HALF-EDGE DATA STRUCTURE MODELING AND ANIMATION THE HALF-EDGE DATA STRUCTURE MODELING AND ANIMATION Dan Englesson danen344@student.liu.se Sunday 12th April, 2011 Abstract In this lab assignment which was done in the course TNM079, Modeling and animation,

More information

Mesh Morphing. Ligang Liu Graphics&Geometric Computing Lab USTC

Mesh Morphing. Ligang Liu Graphics&Geometric Computing Lab USTC Mesh Morphing Ligang Liu Graphics&Geometric Computing Lab USTC http://staff.ustc.edu.cn/~lgliu Morphing Given two objects produce sequence of intermediate objects that gradually evolve from one object

More information

3D Programming. 3D Programming Concepts. Outline. 3D Concepts. 3D Concepts -- Coordinate Systems. 3D Concepts Displaying 3D Models

3D Programming. 3D Programming Concepts. Outline. 3D Concepts. 3D Concepts -- Coordinate Systems. 3D Concepts Displaying 3D Models 3D Programming Concepts Outline 3D Concepts Displaying 3D Models 3D Programming CS 4390 3D Computer 1 2 3D Concepts 3D Model is a 3D simulation of an object. Coordinate Systems 3D Models 3D Shapes 3D Concepts

More information

Parallel Computation of Spherical Parameterizations for Mesh Analysis. Th. Athanasiadis and I. Fudos University of Ioannina, Greece

Parallel Computation of Spherical Parameterizations for Mesh Analysis. Th. Athanasiadis and I. Fudos University of Ioannina, Greece Parallel Computation of Spherical Parameterizations for Mesh Analysis Th. Athanasiadis and I. Fudos, Greece Introduction Mesh parameterization is a powerful geometry processing tool Applications Remeshing

More information

Geometric Modeling Assignment 3: Discrete Differential Quantities

Geometric Modeling Assignment 3: Discrete Differential Quantities Geometric Modeling Assignment : Discrete Differential Quantities Acknowledgements: Julian Panetta, Olga Diamanti Assignment (Optional) Topic: Discrete Differential Quantities with libigl Vertex Normals,

More information

Introduction to Geometry

Introduction to Geometry Introduction to Geometry Objective A: Problems involving lines and angles Three basic concepts of Geometry are: Points are a single place represented by a dot A Lines are a collection of points that continue

More information

Tutorial 3 Comparing Biological Shapes Patrice Koehl and Joel Hass

Tutorial 3 Comparing Biological Shapes Patrice Koehl and Joel Hass Tutorial 3 Comparing Biological Shapes Patrice Koehl and Joel Hass University of California, Davis, USA http://www.cs.ucdavis.edu/~koehl/ims2017/ What is a shape? A shape is a 2-manifold with a Riemannian

More information

Handles. The justification: For a 0 genus triangle mesh we can write the formula as follows:

Handles. The justification: For a 0 genus triangle mesh we can write the formula as follows: Handles A handle in a 3d mesh is a through hole. The number of handles can be extracted of the genus of the 3d mesh. Genus is the number of times we can cut 2k edges without disconnecting the 3d mesh.

More information

Geometric Modeling in Graphics

Geometric Modeling in Graphics Geometric Modeling in Graphics Part 2: Meshes properties Martin Samuelčík www.sccg.sk/~samuelcik samuelcik@sccg.sk Meshes properties Working with DCEL representation One connected component with simple

More information

Meshes. CS4620/5620: Lecture 17. Announcements. Prelim next Thursday. In the evening, closed book Including material of this week.

Meshes. CS4620/5620: Lecture 17. Announcements. Prelim next Thursday. In the evening, closed book Including material of this week. CS4620/5620: Lecture 17 Meshes 1 Announcements Prelim next Thursday In the evening, closed book Including material of this week 2 Representations for triangle meshes Separate triangles Indexed triangle

More information

Subdivision overview

Subdivision overview Subdivision overview CS4620 Lecture 16 2018 Steve Marschner 1 Introduction: corner cutting Piecewise linear curve too jagged for you? Lop off the corners! results in a curve with twice as many corners

More information

Special Topics in Visualization

Special Topics in Visualization Special Topics in Visualization Final Project Report Dual contouring of Hermite Data Submitted By S M Shahed Nejhum 8589-1199 May 19, 2008 Introduction Iso-surface extraction from 3D volumetric data is

More information

Triangle meshes I. CS 4620 Lecture Steve Marschner. Cornell CS4620 Spring 2017

Triangle meshes I. CS 4620 Lecture Steve Marschner. Cornell CS4620 Spring 2017 Triangle meshes I CS 4620 Lecture 2 2017 Steve Marschner 1 spheres Andrzej Barabasz approximate sphere Rineau & Yvinec CGAL manual 2017 Steve Marschner 2 finite element analysis PATRIOT Engineering 2017

More information