INF574 - Lecture 5 - Reconstruction
INF574 - Lecture 5 - Reconstruction
INF 574
Geometric Modeling: Digital Representation
and Analysis of Shapes
• Mesh terminology
simplification
1
11/8/2022
Reconstruction
inferring a surface from points
2
11/8/2022
Motivation
Scanners provide highly detailed pointsets of 3D shapes
http://www.jhu.edu/digitalhammurabi/ http://graphics.stanford.edu/projects/mich/
Cuneiform tablets
Motivation
Scanners provide highly detailed pointsets of 3D shapes
• computer-aided analysis
• rapid prototyping
• rendering
and so much more…
3
11/8/2022
Surface Reconstruction
How to generate a mesh from a set of surface samples?
Surface Reconstruction
How to generate a mesh from a set of surface samples?
Three general approaches:
Computational Geometry (often “interpolating” reconstruction)
Boissonnat, 1984 Edelsbrunner, 1984
Amenta et al., 1998 Dey et al., 2003
variational surface fitting (for a given topology and smoothness)
Terzopoulos et al., 1991 Chen et al., 1995
Implicit function fitting
Hoppe et al., 1992 Curless et al., 1996
Whitaker, 1998 Carr et al., 2001
Davis et al., 2002 Ohtake et al., 2004
Turk et al., 2004 Shen et al., 2004
Kazhdan, 2005 and many more!
4
11/8/2022
Reconstruction
using Computational Geometry
Early Approaches
How to make sense of a pointset?
Idea 1: ball rolling [Edelsbrunner et al.]
alpha-shape: created by a radius-α ball rolled along the pointset
• space delineated by point pairs touched by an empty disc of radius α
interesting for topology analysis too
but finding a fixed alpha is “mission: impossible”
10
5
11/8/2022
Early Approaches
How to make sense of a pointset?
Idea 1: ball rolling [Edelsbrunner et al.]
alpha-shape: created by a radius-α ball rolled along the pointset
• space delineated by point pairs touched by an empty disc of radius α
interesting for topology analysis too
but finding a fixed alpha is “mission: impossible”
11
12
6
11/8/2022
13
V
o
r
o
n
o
i
14
7
11/8/2022
Beautiful Duality
Voronoi diagrams are only half the picture
connectivity of Voronoi regions is nice… Georgy Voronoï Boris Delaunay
(1868-1908) (1890-1980)
introducing Delaunay triangulation!
• dual of Voronoi diagram
• Voronoi vs. Delaunay edges are orthogonal!
canonical construction, just from points!
Delaunay triangulation
Voronoi diagram
15
16
8
11/8/2022
17
18
9
11/8/2022
3D Case
In 3D, some Voronoi vertices are not near medial axis…
spurious Voronoi vertices create issues!
luckily, we can “filter them out…
• for each Voronoi cell, pick the two extremes
• called “poles”
• this subset of Voronoi vertices
are good approximation of skeleton
19
3D Surface Reconstruction
Compute Delaunay triangulations of input points and poles…
and keep only triangle on each triple of sample points
extensions: cocone and power crust
• to reduce complexity
issues with this family of approaches:
• can break down in case of non-smooth surfaces
• sensitive to noise, outliers, and sparsity of data
20
10
11/8/2022
Reconstruction
via Implicit Functions
21
22
11
11/8/2022
23
24
12
11/8/2022
but how? 0
0
imagine a smoothed indicator function…
• its gradient looks suspiciously like our input! 0 0
Indicator gradient
M
Oriented points
(points+normals)
25
26
13
11/8/2022
Simple Implementation
Given the points:
set regular grid, or octree
compute vector field
compute indicator function
extract isosurface
27
28
14
11/8/2022
29
30
15
11/8/2022
31
32
16
11/8/2022
33
34
17
11/8/2022
Implementation: Extraction
Given the points:
set regular grid, or octree
compute vector field
compute indicator function
extract iso-surface
35
Michelangelo’s David
36
18
11/8/2022
37
38
19
11/8/2022
David – Eye
39
VRIP Poisson
40
20
11/8/2022
Medical Data
Arbitrary topology
41
42
21
11/8/2022
43
44
22
11/8/2022
45
46
23
11/8/2022
Result I
Poisson reconstruction
47
Result II
Poisson reconstruction
48
24
11/8/2022
49
Voronoi-based Eigen-Reconstruction
Use covariance matrix of Voronoi cells
50
25
11/8/2022
Voronoi-based Eigen-Reconstruction
Use covariance matrix of Voronoi cells [Alliez et al., Merigot et al.]
in case of noise, using union of k cells instead (automated selection)
anisotropy
51
Voronoi-based Eigen-Reconstruction
Use covariance matrix of Voronoi cells [Alliez et al., Merigot et al.]
in case of noise, using union of k cells instead (automated selection)
deduce normal tensor C (direction and anisotropy to measure uncertainty)
Variational formulation to orient normal and reconstruct mesh
Find f whose gradient best aligns to principal component of tensors Ci
Biharmonic energy
Anisotropic Dirichlet energy Measures smoothness of f
Measures alignment with tensors
for well-posedness
(regularization)
52
26
11/8/2022
Voronoi-based Eigen-Reconstruction
Use covariance matrix of Voronoi cells [Alliez et al., Merigot et al.]
in case of noise, using union of k cells instead (automated selection)
deduce normal tensor C (direction and anisotropy to measure uncertainty)
Variational formulation to orient normal and reconstruct mesh
Find f whose gradient best aligns to principal component of tensors Ci
53
Results
Poisson Generalized
reconstruction eigenvalue
54
27
11/8/2022
Questions?
55
28