Schwerpunktkolloquium: Basic Techniques, Geometry Processing, Global Illumination (116 Karten)
What is a linear / affine / convex combination?
Linear:
data:image/s3,"s3://crabby-images/a92ac/a92acb4ffddb781618d76eebd305a5b617716652" alt=""
Affine:
where data:image/s3,"s3://crabby-images/24990/249904a78f581ae4aadfe07cdde5f672dcc83d85" alt=""
Convex:
where
and
and data:image/s3,"s3://crabby-images/6926e/6926ef28c2bb815441927d2d345aa079930cc023" alt=""
data:image/s3,"s3://crabby-images/a92ac/a92acb4ffddb781618d76eebd305a5b617716652" alt=""
Affine:
data:image/s3,"s3://crabby-images/a92ac/a92acb4ffddb781618d76eebd305a5b617716652" alt=""
data:image/s3,"s3://crabby-images/24990/249904a78f581ae4aadfe07cdde5f672dcc83d85" alt=""
Convex:
data:image/s3,"s3://crabby-images/a92ac/a92acb4ffddb781618d76eebd305a5b617716652" alt=""
data:image/s3,"s3://crabby-images/24990/249904a78f581ae4aadfe07cdde5f672dcc83d85" alt=""
data:image/s3,"s3://crabby-images/4551e/4551ef903240ceb84505ab95ab778cb985e2aba5" alt=""
data:image/s3,"s3://crabby-images/6926e/6926ef28c2bb815441927d2d345aa079930cc023" alt=""
How do you compute a reflected vector at a surface?
Given:
Normal vector
of the surface.
Input vector
pointing away from the surface.
Project
onto the normal:
data:image/s3,"s3://crabby-images/b1f1d/b1f1d14c5e21f96a3220baefed3700afbf2f2b87" alt=""
Double the length:
data:image/s3,"s3://crabby-images/b2c0d/b2c0d8fbcbbcdad90ac5791411163adbc9874b29" alt=""
Subtract the original vector from this:
data:image/s3,"s3://crabby-images/7f9de/7f9deac87c9026f8c7db305497c7b34cdb58f6c5" alt=""
Normal vector
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
Input vector
data:image/s3,"s3://crabby-images/27110/271106d9bf9e93f1f430f13629d765e47cf88746" alt=""
Project
data:image/s3,"s3://crabby-images/27110/271106d9bf9e93f1f430f13629d765e47cf88746" alt=""
data:image/s3,"s3://crabby-images/b1f1d/b1f1d14c5e21f96a3220baefed3700afbf2f2b87" alt=""
Double the length:
data:image/s3,"s3://crabby-images/b2c0d/b2c0d8fbcbbcdad90ac5791411163adbc9874b29" alt=""
Subtract the original vector from this:
data:image/s3,"s3://crabby-images/7f9de/7f9deac87c9026f8c7db305497c7b34cdb58f6c5" alt=""
Name all OpenGL shader stages in the correct order. Which data is passed from one stage to the next?
Vertex Shader
(mandatory)
Executed for every vertex
Input: Attribute values as defined by vertex data
Output: Attribute values
Tessellation Control Shader
Executed for every primitive (triangle, line, patch)
Input: Attribute values
Output: Attribute values, requested degree of tessellation
Tessellation Evaluation Shader
Executed for every vertex of the tessellated primitive
Input: Attribute values
Output: Attribute values, requested degree of tessellation
Geometry Shader
Executed for every primitive (triangle, line, point), possibly generated by the tessellation, possibly with information about adjacent primitives
Input: Array of attribute values
Output: Arbitrary number of primitives, each with possibly different attribute values
Fragment Shader
(mandatory)
Executed for every fragment
Input: Possibly interpolated attribute values
Output: Fragment data which is written to frame buffers
(mandatory)
Executed for every vertex
Input: Attribute values as defined by vertex data
Output: Attribute values
Tessellation Control Shader
Executed for every primitive (triangle, line, patch)
Input: Attribute values
Output: Attribute values, requested degree of tessellation
Tessellation Evaluation Shader
Executed for every vertex of the tessellated primitive
Input: Attribute values
Output: Attribute values, requested degree of tessellation
Geometry Shader
Executed for every primitive (triangle, line, point), possibly generated by the tessellation, possibly with information about adjacent primitives
Input: Array of attribute values
Output: Arbitrary number of primitives, each with possibly different attribute values
Fragment Shader
(mandatory)
Executed for every fragment
Input: Possibly interpolated attribute values
Output: Fragment data which is written to frame buffers
How many neighbors does each Voronoi cell have in a planar Voronoi diagram, on average?
In 2D, the Voronoi diagram is dual to the Delaunay triangulation. For each triangle mesh, we know that
data:image/s3,"s3://crabby-images/25fae/25fae18a279187d8adaa49ef5b2002d3f4b6599e" alt=""
i.e., each vertex is adjacent to 6 other vertices, on average. Since vertices in the Delaunay triangulation are dual to Voronoi cells, each Voronoi cell has 6 neighboring cells, on average.
data:image/s3,"s3://crabby-images/25fae/25fae18a279187d8adaa49ef5b2002d3f4b6599e" alt=""
i.e., each vertex is adjacent to 6 other vertices, on average. Since vertices in the Delaunay triangulation are dual to Voronoi cells, each Voronoi cell has 6 neighboring cells, on average.
Explain Parametrization-Based Quad Meshing (Mixed Integer Quadrangulation)
Input: Mesh of triangles
. For some triangles, we have a confident estimate of the local min / max curvature directions (e.g. computed using the Shape Operator) given by an angle
relative to some reference edge
.
Smooth Cross Field
We propagate a smooth cross field over the entire surface. For each edge
we can define a smoothness energy
data:image/s3,"s3://crabby-images/f1a13/f1a13809969ab662b96d435cd71bc1104387b4d6" alt=""
where
and
are the cross field directions given as an angle with the reference edges
and
, respectively.
denotes the angle between the two reference edges.
is an integer variable that allows
rotations of the cross fields.
For the entire mesh, we construct the system
data:image/s3,"s3://crabby-images/3263b/3263b85fb19501bdc860a86c37285bbe90bbd364" alt=""
We solve this system for the real variables
and the integer variables
. For those triangles where an input cross field direction is known, we fix the value:
.
Parametrization
For each triangle corner in the mesh, compute
coordinates such that for each triangle,
data:image/s3,"s3://crabby-images/502ea/502eae97909390fccfb045a07710b7afa169c200" alt=""
becomes small. Globally:
data:image/s3,"s3://crabby-images/548de/548de9473560910e5b824a1be0612a3d4dad2dae" alt=""
In order to obtain a disk topology for parametrization, the surface needs to be cut open. As an additional constraint, we thus introduce the requirement, that the parametrization should be consistent across boundary edges. That means that the transformation of parameters across an edge should be a grid automorphism.
Specifically, given a boundary edge
between two triangles
and
we constrain the
coordinates at the opposite sides of the vertices
to be equal up to grid automorphisms. That means:
data:image/s3,"s3://crabby-images/d6830/d68301b054a603831fa02bf5e7f115cc60db8cb5" alt=""
data:image/s3,"s3://crabby-images/d1d23/d1d23c9388caca1abba93ee9e54320e8164f9ad0" alt=""
The integer variable
is known from the smooth cross field. For
,
, we need to find integer solutions.
In order to ensure that the resulting mesh will be a quad mesh, we snap singularities to integer positions.
We can introduce additional hard alignment constraints in order to snap feature edges to integer iso-lines. If an edge
should be snapped to a
-integer-iso-line, we constrain the values of
for vertices of
to be integer.
Solving Mixed-Integer Problems
In general: NP-Hard. We approximate a solution by relaxing the problem: Find a real-valued solution. Snap integer variables to nearest possible value, repeat.
data:image/s3,"s3://crabby-images/73b06/73b069566e78787071567fe04a6130b3e83ece68" alt=""
data:image/s3,"s3://crabby-images/fdf8f/fdf8f53341a6fd5f9828db59477a32a455f003f1" alt=""
data:image/s3,"s3://crabby-images/eab7d/eab7d3a30157d89720b66aa990efdfea63091070" alt=""
Smooth Cross Field
We propagate a smooth cross field over the entire surface. For each edge
data:image/s3,"s3://crabby-images/65d6b/65d6b9311b87e3d08ccac8a2fb3fb465972a2b2e" alt=""
data:image/s3,"s3://crabby-images/f1a13/f1a13809969ab662b96d435cd71bc1104387b4d6" alt=""
where
data:image/s3,"s3://crabby-images/20de5/20de51769528580abd301da558c042d45d2784b9" alt=""
data:image/s3,"s3://crabby-images/7d104/7d104495a36ed31f51a6e12ecbfd4973539df470" alt=""
data:image/s3,"s3://crabby-images/a4ae6/a4ae6d3a1a33921e96bc679b19b8b113c1bcea47" alt=""
data:image/s3,"s3://crabby-images/32ff6/32ff69fc6c66ed708f4467ca7407a92a7f1d0f50" alt=""
data:image/s3,"s3://crabby-images/77f58/77f587cd44bfb709f9c1614a74c8f33abed72279" alt=""
data:image/s3,"s3://crabby-images/75b18/75b18c7c2f6530e31d3a511a4f04215462ba184b" alt=""
data:image/s3,"s3://crabby-images/60deb/60debcfed7aaa9a5078debd38a7d3df7d50a1a6c" alt=""
For the entire mesh, we construct the system
data:image/s3,"s3://crabby-images/3263b/3263b85fb19501bdc860a86c37285bbe90bbd364" alt=""
We solve this system for the real variables
data:image/s3,"s3://crabby-images/20de5/20de51769528580abd301da558c042d45d2784b9" alt=""
data:image/s3,"s3://crabby-images/75b18/75b18c7c2f6530e31d3a511a4f04215462ba184b" alt=""
data:image/s3,"s3://crabby-images/eaf17/eaf1756c58e59e64408ad05e2d7bed46affaeb25" alt=""
Parametrization
For each triangle corner in the mesh, compute
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/502ea/502eae97909390fccfb045a07710b7afa169c200" alt=""
becomes small. Globally:
data:image/s3,"s3://crabby-images/548de/548de9473560910e5b824a1be0612a3d4dad2dae" alt=""
In order to obtain a disk topology for parametrization, the surface needs to be cut open. As an additional constraint, we thus introduce the requirement, that the parametrization should be consistent across boundary edges. That means that the transformation of parameters across an edge should be a grid automorphism.
Specifically, given a boundary edge
data:image/s3,"s3://crabby-images/5c4e4/5c4e468726abcabff1a4da3a5812fbb3cf80a0a6" alt=""
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/5c4e4/5c4e468726abcabff1a4da3a5812fbb3cf80a0a6" alt=""
data:image/s3,"s3://crabby-images/d6830/d68301b054a603831fa02bf5e7f115cc60db8cb5" alt=""
data:image/s3,"s3://crabby-images/d1d23/d1d23c9388caca1abba93ee9e54320e8164f9ad0" alt=""
The integer variable
data:image/s3,"s3://crabby-images/b15c2/b15c2360d39a6d3c39d37aabe6742dacbc7cf9ee" alt=""
data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
data:image/s3,"s3://crabby-images/27184/2718409627f4ec0c7fd8721616986f099a0c7886" alt=""
In order to ensure that the resulting mesh will be a quad mesh, we snap singularities to integer positions.
We can introduce additional hard alignment constraints in order to snap feature edges to integer iso-lines. If an edge
data:image/s3,"s3://crabby-images/5c4e4/5c4e468726abcabff1a4da3a5812fbb3cf80a0a6" alt=""
data:image/s3,"s3://crabby-images/27110/271106d9bf9e93f1f430f13629d765e47cf88746" alt=""
data:image/s3,"s3://crabby-images/27110/271106d9bf9e93f1f430f13629d765e47cf88746" alt=""
data:image/s3,"s3://crabby-images/5c4e4/5c4e468726abcabff1a4da3a5812fbb3cf80a0a6" alt=""
Solving Mixed-Integer Problems
In general: NP-Hard. We approximate a solution by relaxing the problem: Find a real-valued solution. Snap integer variables to nearest possible value, repeat.
How can we classify surface curvature in the continuous case? What is a discrete approximation for triangle meshes?
If we have a parametric surface
, we can take its taylor expansion
data:image/s3,"s3://crabby-images/97b11/97b11d54a62269c50472b843e80a25e857e504d9" alt=""
We can now reparametrize
such that
lies in the origin and the plane
is parallel to data:image/s3,"s3://crabby-images/dca90/dca90b407089b3c23ca343e30470ec9318cd6916" alt=""
data:image/s3,"s3://crabby-images/4e81a/4e81a54b1926dc0f309550d5c296cabbc7613294" alt=""
data:image/s3,"s3://crabby-images/a3d04/a3d041c1bff2e4f4312603dadbdf60e4c5ab66f3" alt=""
data:image/s3,"s3://crabby-images/c2356/c2356b72c836a36a5ab9c9cc8a52ac6c455e481f" alt=""
Since this matrix is symmetric and real-valued, we can do an eigendecomposition:
data:image/s3,"s3://crabby-images/90c66/90c66b0efbe953c5f95db1ebb3e91aeb5bdf5fec" alt=""
From the eigenvalues
and
, we can derive two characteristics for local curvature:
Mean Curvature:data:image/s3,"s3://crabby-images/1847c/1847c078cc6e29015e4aa3b244ff58487424840a" alt=""
Gaussian Curvature:data:image/s3,"s3://crabby-images/ded1d/ded1d0cb03ed35be5a2005de553b85897db0c64c" alt=""
Which has the following interpretations:
: Cap / Peak / Valley (elliptic)
: Cylinder (parabolic)
: Saddle (hyperbolic)
The eigenvectors corresponding to
and
represent the respective curvature directions and are orthogonal.
Shape Operator
Approximates curvature for triangle meshes.
For each edge
: atomic shape operator
data:image/s3,"s3://crabby-images/aae10/aae10b985c44777eed528ab208d63b91d1b6845d" alt=""
where
is the angle between the triangle normals
.
Around a vertex, we compute the atomic shape operators of all edges in the vicinity
data:image/s3,"s3://crabby-images/b1303/b13037bb34fd3b31fadd88a476eee088e9b61029" alt=""
where
measures the length of the portion of the edge
inside
.
From this, we can compute:
The eigenvector to the largest eigenvalue of
points into the direction of minimum curvature.
The direction of maximum curvature is orthogonal to that and can be found by taking the cross product with the normal vector.
We cannot derive the exact curvature values
and
, but it is
data:image/s3,"s3://crabby-images/6feec/6feecf9d5badb52ef905f4d9f2e910e321504a95" alt=""
data:image/s3,"s3://crabby-images/b891c/b891ce1f4bcfbd26dab33b4ed20ddd43fb514231" alt=""
data:image/s3,"s3://crabby-images/97b11/97b11d54a62269c50472b843e80a25e857e504d9" alt=""
We can now reparametrize
data:image/s3,"s3://crabby-images/dc270/dc270a9ce3bf36537d2220eb25ae1e183561f873" alt=""
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/ff648/ff6484badddd57bb5452dfbabf6f0eabebd58723" alt=""
data:image/s3,"s3://crabby-images/dca90/dca90b407089b3c23ca343e30470ec9318cd6916" alt=""
data:image/s3,"s3://crabby-images/4e81a/4e81a54b1926dc0f309550d5c296cabbc7613294" alt=""
data:image/s3,"s3://crabby-images/a3d04/a3d041c1bff2e4f4312603dadbdf60e4c5ab66f3" alt=""
data:image/s3,"s3://crabby-images/c2356/c2356b72c836a36a5ab9c9cc8a52ac6c455e481f" alt=""
Since this matrix is symmetric and real-valued, we can do an eigendecomposition:
data:image/s3,"s3://crabby-images/90c66/90c66b0efbe953c5f95db1ebb3e91aeb5bdf5fec" alt=""
From the eigenvalues
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
Mean Curvature:
data:image/s3,"s3://crabby-images/1847c/1847c078cc6e29015e4aa3b244ff58487424840a" alt=""
Gaussian Curvature:
data:image/s3,"s3://crabby-images/ded1d/ded1d0cb03ed35be5a2005de553b85897db0c64c" alt=""
Which has the following interpretations:
data:image/s3,"s3://crabby-images/dd586/dd586f75338d917263a0ba846bef57f9315761a8" alt=""
data:image/s3,"s3://crabby-images/12fc5/12fc51ac21676fa53712ad49e5bc7dc92a27cd37" alt=""
data:image/s3,"s3://crabby-images/203e6/203e6153509e538132c14e2e63625cc0bdbed90d" alt=""
The eigenvectors corresponding to
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
Shape Operator
Approximates curvature for triangle meshes.
For each edge
data:image/s3,"s3://crabby-images/15836/15836072be85bcd6f0eac0a510a3c42c85adb882" alt=""
data:image/s3,"s3://crabby-images/aae10/aae10b985c44777eed528ab208d63b91d1b6845d" alt=""
where
data:image/s3,"s3://crabby-images/56d16/56d16d38b4dd17fec06db2784996315624d114f0" alt=""
data:image/s3,"s3://crabby-images/b4b5b/b4b5b1562c0573fd460e402154d93cb56689cfbc" alt=""
data:image/s3,"s3://crabby-images/af89d/af89da2e90f2847598afded3d84d49074533c695" alt=""
Around a vertex, we compute the atomic shape operators of all edges in the vicinity
data:image/s3,"s3://crabby-images/b1303/b13037bb34fd3b31fadd88a476eee088e9b61029" alt=""
where
data:image/s3,"s3://crabby-images/c95e5/c95e594a4e9429d0c684bd81d2a2ff8bdc6017f5" alt=""
data:image/s3,"s3://crabby-images/15836/15836072be85bcd6f0eac0a510a3c42c85adb882" alt=""
data:image/s3,"s3://crabby-images/2465a/2465a49cc536878fd2472cafb619218a32582ea8" alt=""
From this, we can compute:
The eigenvector to the largest eigenvalue of
data:image/s3,"s3://crabby-images/c5b20/c5b202bc6df15ee0453342fd2bf44ace4825c30a" alt=""
The direction of maximum curvature is orthogonal to that and can be found by taking the cross product with the normal vector.
We cannot derive the exact curvature values
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
data:image/s3,"s3://crabby-images/6feec/6feecf9d5badb52ef905f4d9f2e910e321504a95" alt=""
What are the properties of Uniform B-Splines? Give the definition of a B-Spline Curve!
Uniform B-Spline Basis Functions
data:image/s3,"s3://crabby-images/e1b25/e1b254cbb3cd45c7f2063c85b84666e9046559a9" alt=""
Uniform B-Spline Curve
data:image/s3,"s3://crabby-images/799df/799dfed4d4a15eabdcd1d8011e6f759e3b1c5b31" alt=""
with control pointsdata:image/s3,"s3://crabby-images/85835/8583509589cb1219e83fb4e3c08520e51cb5fdc0" alt=""
data:image/s3,"s3://crabby-images/e1b25/e1b254cbb3cd45c7f2063c85b84666e9046559a9" alt=""
- Piecewise polynomial of degree
-
continuous
- Partition of unity:
- Local support:
- Obtained by convolution:
data:image/s3,"s3://crabby-images/cb92c/cb92c591a35f3a146a24acc8b6de92319f055e6d" alt=""
Uniform B-Spline Curve
data:image/s3,"s3://crabby-images/799df/799dfed4d4a15eabdcd1d8011e6f759e3b1c5b31" alt=""
with control points
data:image/s3,"s3://crabby-images/85835/8583509589cb1219e83fb4e3c08520e51cb5fdc0" alt=""
What is the goal of Subdivision techniques? Explain Subdivision using the Lane-Riesenfeld technique!
We interpret a sequence of points
as the control points of a B-Spline curve
data:image/s3,"s3://crabby-images/ddac9/ddac9182ad008a1a9865836eda1557c182184430" alt=""
Now, we want to describe the same curve with a higher number of control points.
We define two operators on the sequence
data:image/s3,"s3://crabby-images/e0486/e048645969dcb951514ee13f4accad971f4edc46" alt=""
Doubling
data:image/s3,"s3://crabby-images/59ad4/59ad46650d87648d08201161428c0ee6e3a0a384" alt=""
Averaging
data:image/s3,"s3://crabby-images/c7abf/c7abf4b9abb9b4cca78fc53986ba318b9c8d4cab" alt=""
To determine the new vertex positions, we compute weighted positions based on even / odd rules.
Subdivision Operators
Linear (primal)
data:image/s3,"s3://crabby-images/81f3d/81f3d986431858b4a8aa05eea09bceb56ff03aca" alt=""
Quadratic Spline (dual)
data:image/s3,"s3://crabby-images/ae4fa/ae4fac02009088344efe793d25c89e884df276dd" alt=""
Cubic Spline (primal)
data:image/s3,"s3://crabby-images/b91b4/b91b4fc400f65fd6bf7ddb7033c842675e68ab86" alt=""
TODO: Fix this explanation
Consider the B-Spline basis function
.
It is a piecewise linear function between
data:image/s3,"s3://crabby-images/5cdbb/5cdbbb82af35a10853e9623c97827c8e7ffa9d70" alt=""
data:image/s3,"s3://crabby-images/0fb8b/0fb8b738011b382c8bbe318e6a1654b6a381a01c" alt=""
data:image/s3,"s3://crabby-images/34ac6/34ac6f85c2e04574255522b97b554abae0ae28f8" alt=""
We can write
as an affine combination of the same function with parameter
:
data:image/s3,"s3://crabby-images/674de/674deca98b41f34921794912461229086d0c39fe" alt=""
We can do this for uniform B-Spline basis functions in general:
data:image/s3,"s3://crabby-images/4a989/4a989ea95cb2fa86b3368f11a9309d69386c6ee9" alt=""
where
data:image/s3,"s3://crabby-images/66dba/66dba7adf4af54b6528b99b528f66dff1302f84b" alt=""
data:image/s3,"s3://crabby-images/85835/8583509589cb1219e83fb4e3c08520e51cb5fdc0" alt=""
data:image/s3,"s3://crabby-images/ddac9/ddac9182ad008a1a9865836eda1557c182184430" alt=""
Now, we want to describe the same curve with a higher number of control points.
We define two operators on the sequence
data:image/s3,"s3://crabby-images/e0486/e048645969dcb951514ee13f4accad971f4edc46" alt=""
Doubling
data:image/s3,"s3://crabby-images/59ad4/59ad46650d87648d08201161428c0ee6e3a0a384" alt=""
Averaging
data:image/s3,"s3://crabby-images/c7abf/c7abf4b9abb9b4cca78fc53986ba318b9c8d4cab" alt=""
To determine the new vertex positions, we compute weighted positions based on even / odd rules.
Subdivision Operators
Linear (primal)
data:image/s3,"s3://crabby-images/81f3d/81f3d986431858b4a8aa05eea09bceb56ff03aca" alt=""
Quadratic Spline (dual)
data:image/s3,"s3://crabby-images/ae4fa/ae4fac02009088344efe793d25c89e884df276dd" alt=""
Cubic Spline (primal)
data:image/s3,"s3://crabby-images/b91b4/b91b4fc400f65fd6bf7ddb7033c842675e68ab86" alt=""
TODO: Fix this explanation
Consider the B-Spline basis function
data:image/s3,"s3://crabby-images/b346e/b346e63065e1f018b638c3d47100aa63e8877a8e" alt=""
It is a piecewise linear function between
data:image/s3,"s3://crabby-images/5cdbb/5cdbbb82af35a10853e9623c97827c8e7ffa9d70" alt=""
data:image/s3,"s3://crabby-images/0fb8b/0fb8b738011b382c8bbe318e6a1654b6a381a01c" alt=""
data:image/s3,"s3://crabby-images/34ac6/34ac6f85c2e04574255522b97b554abae0ae28f8" alt=""
We can write
data:image/s3,"s3://crabby-images/b346e/b346e63065e1f018b638c3d47100aa63e8877a8e" alt=""
data:image/s3,"s3://crabby-images/18eb3/18eb396e9f7068db83555a3aa197bfaf111a08b1" alt=""
data:image/s3,"s3://crabby-images/674de/674deca98b41f34921794912461229086d0c39fe" alt=""
We can do this for uniform B-Spline basis functions in general:
data:image/s3,"s3://crabby-images/4a989/4a989ea95cb2fa86b3368f11a9309d69386c6ee9" alt=""
where
data:image/s3,"s3://crabby-images/66dba/66dba7adf4af54b6528b99b528f66dff1302f84b" alt=""
Prove why creating a Delaunay Triangulation using edge flipping terminates using Seidel's Parabolic Map!
Lift every vertex onto a parabola:
data:image/s3,"s3://crabby-images/c4451/c445138eb5551637dc997805c526227e10f90ae5" alt=""
A circle in the plane maps to an ellipsoid on the parabola. This ellipsoid lies in a plane. Every point on the ground which lies inside the circle lifts to a point below the plane. Every point on the ground which lies outside the circle lifts to a point above the plane.
Suppose have a non-Delaunay pair of triangles
,
in the plane, where
lies in
's circumcircle.
The lifted points
lie in the same plane as the lifted ellipse of
's circumcircle. Since
lies inside the circle,
lies below the plane of
. Thus, the edge
is reflex.
By flipping the edge
to
, we replace the reflex edge
by the convex edge
.
Note that the four points
form a tetrahedron. Before the flip, our triangulation corresponded to the upward-facing faces of the tetrahedron. After the flip, it corresponded to the downward-facing faces of the tetrahedron.
Thus, with each flip, we monotonically decrease the height of our triangulation on the paraboloid. Tetrahedral edges which lie on the upward-facing side are never considered again. Thus, the algorithm terminates eventually.
data:image/s3,"s3://crabby-images/c4451/c445138eb5551637dc997805c526227e10f90ae5" alt=""
A circle in the plane maps to an ellipsoid on the parabola. This ellipsoid lies in a plane. Every point on the ground which lies inside the circle lifts to a point below the plane. Every point on the ground which lies outside the circle lifts to a point above the plane.
Suppose have a non-Delaunay pair of triangles
data:image/s3,"s3://crabby-images/aacc5/aacc57e0c348775dff13884201788bc83c192c96" alt=""
data:image/s3,"s3://crabby-images/79d1b/79d1bb5b1a8b9a4ca4dec8d31211ef39e1f1268e" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/aacc5/aacc57e0c348775dff13884201788bc83c192c96" alt=""
The lifted points
data:image/s3,"s3://crabby-images/d407a/d407a5315407dbf91fc0b0ae6b32e2d7fca88e88" alt=""
data:image/s3,"s3://crabby-images/aacc5/aacc57e0c348775dff13884201788bc83c192c96" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/430e2/430e29fa94679e0008b53b86bdd32e1f3809e311" alt=""
data:image/s3,"s3://crabby-images/15f82/15f825911ca143040187a1f8f28fc2bc9d224bc8" alt=""
data:image/s3,"s3://crabby-images/bc8c0/bc8c0058d8625aaaf8cb267b799b9d060c0fb200" alt=""
By flipping the edge
data:image/s3,"s3://crabby-images/29203/292031feb5c7762da2187f1bad6330663e8db4f0" alt=""
data:image/s3,"s3://crabby-images/c57a8/c57a8b96f7a3b99d58cfb58b653ce97e8936f04c" alt=""
data:image/s3,"s3://crabby-images/bc8c0/bc8c0058d8625aaaf8cb267b799b9d060c0fb200" alt=""
data:image/s3,"s3://crabby-images/3bb44/3bb4420ebadaf0ceeba6635d8185c52875303061" alt=""
Note that the four points
data:image/s3,"s3://crabby-images/d2326/d23264f7aa3149da0bb747513cae7e9a509086f5" alt=""
Thus, with each flip, we monotonically decrease the height of our triangulation on the paraboloid. Tetrahedral edges which lie on the upward-facing side are never considered again. Thus, the algorithm terminates eventually.
Explain the idea of Free-Form Modeling!
General idea: The user defines two regions on a mesh:
A support region which should be affected by the modeling.
A handle region inside the support region which the user can transform freely. The support region between the handle and the rest of the mesh should interpolate smoothly.
Solution: Fix all vertex positions except those of the support region.
For the support region vertices, solve
data:image/s3,"s3://crabby-images/cb777/cb777385671002304d106c7b6d788b4e87e8ec42" alt=""
i.e. compute a smooth interpolating surface.
Problem: Smoothly interpolated surface loses detail.
Detail Preservation
Input mesh
.
Fix vertex positions in the handle and the non-support regions and compute smooth surface
.
Compute detail offset mesh
.
Let the user transform the handle region and compute a new smoothed mesh
.
Re-add the detail information:
.
For rotations: Store normal offsets instead of absolute position offsets.
A support region which should be affected by the modeling.
A handle region inside the support region which the user can transform freely. The support region between the handle and the rest of the mesh should interpolate smoothly.
Solution: Fix all vertex positions except those of the support region.
For the support region vertices, solve
data:image/s3,"s3://crabby-images/cb777/cb777385671002304d106c7b6d788b4e87e8ec42" alt=""
i.e. compute a smooth interpolating surface.
Problem: Smoothly interpolated surface loses detail.
Detail Preservation
Input mesh
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Fix vertex positions in the handle and the non-support regions and compute smooth surface
data:image/s3,"s3://crabby-images/42838/42838fe78f291bc228f49733c8cc63dc2feca84f" alt=""
Compute detail offset mesh
data:image/s3,"s3://crabby-images/19ede/19ede12f153cef8b288866f0fc8949947e993a58" alt=""
Let the user transform the handle region and compute a new smoothed mesh
data:image/s3,"s3://crabby-images/52ced/52ced0df2f96504e6d4f2d242f64a949a13f133e" alt=""
Re-add the detail information:
data:image/s3,"s3://crabby-images/435d2/435d2765a4bc4ef6c43aad009b1a20216e69693e" alt=""
For rotations: Store normal offsets instead of absolute position offsets.
Explain the idea of Laplace Reconstruction / Laplace Editing!
The global shape of a mesh is encoded in its positions
.
The local shape of a mesh is encoded in its Laplace vectors
.
Given all Laplace vectors
of a mesh, we can reconstruct a global shape
from the local shape:
data:image/s3,"s3://crabby-images/4eb5f/4eb5fd97e3f0c69dfd4c3fcb077f83b5c5dc469e" alt=""
We need to fix one intial vertex position
and solve for the remaining variables
.
We can also use this as an editing metaphor by letting the user prescribe desired positions
for certain vertices
. Incorporating this into the minimization formula gives
data:image/s3,"s3://crabby-images/0c737/0c737dcfa24f6ac082d87f66eded37e34e621127" alt=""
Additionally, we need to allow rotations of the detail vectors:
data:image/s3,"s3://crabby-images/817c3/817c3d686b3a5ffcc564519345cd0bc2ac5019a5" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
The local shape of a mesh is encoded in its Laplace vectors
data:image/s3,"s3://crabby-images/c4833/c4833d1ff9b33d9336c3a7e721e544d4cf079898" alt=""
Given all Laplace vectors
data:image/s3,"s3://crabby-images/c4833/c4833d1ff9b33d9336c3a7e721e544d4cf079898" alt=""
data:image/s3,"s3://crabby-images/ebf59/ebf59b6c14171c4c5a5204cafd169dd178978780" alt=""
data:image/s3,"s3://crabby-images/4eb5f/4eb5fd97e3f0c69dfd4c3fcb077f83b5c5dc469e" alt=""
We need to fix one intial vertex position
data:image/s3,"s3://crabby-images/a03ae/a03ae9407f5d034d0274cc17f9778db1754ed63b" alt=""
data:image/s3,"s3://crabby-images/ebf59/ebf59b6c14171c4c5a5204cafd169dd178978780" alt=""
We can also use this as an editing metaphor by letting the user prescribe desired positions
data:image/s3,"s3://crabby-images/bbdb5/bbdb5eef065803a3e708067b1dbaa76f105b7ca7" alt=""
data:image/s3,"s3://crabby-images/e4d79/e4d7992caac1bf4954c6bbe1cb907d9dd5405694" alt=""
data:image/s3,"s3://crabby-images/0c737/0c737dcfa24f6ac082d87f66eded37e34e621127" alt=""
Additionally, we need to allow rotations of the detail vectors:
data:image/s3,"s3://crabby-images/817c3/817c3d686b3a5ffcc564519345cd0bc2ac5019a5" alt=""
Explain the GIST descriptor!
Describes the spatial color distribution in an image. Robust to small camera movements.
Store the averaged intensity values. Per color channel:
values per image.
- Compute
blurred versions of the input image, e.g. by convolutions with Gaussian kernels of increasing size.
- For each blurred image, compute
convolutions with gradient filters of different directions.
- Partition each gradient image into
sectors and compute an average intensity value for each sector.
Store the averaged intensity values. Per color channel:
data:image/s3,"s3://crabby-images/bdb6a/bdb6a9f4d534fb3d108c9f751403064833fea86a" alt=""
How are Light Fields parametrized? How can we generate such a parametrization from a set of input images?
Two-Plane Parametrization
Assuming the scene is contained between two parallel planes, the camera plane and the object plane, we can parametrize each ray by a point
on the camera plane and a point
on the object plane. The radiance along that ray is given by
data:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Light Field Generation
1. Re-projection / Rectification of input images
2. Re-binning to produce uniform sampling on camera and object plane
Rectification
Each input image was taken at a camera position
with a projection matrix
projecting a point
to a point
on the camera plane.
is a transformation from 3D homogenous coordinates to 2D homogenous coordinates. Thus,
data:image/s3,"s3://crabby-images/df858/df858873a2e02e4fccb5670584bd016b7a734571" alt=""
We want to project
from the same camera position
onto a different projection plane given by another projection matrix
which has the same layout as data:image/s3,"s3://crabby-images/b147e/b147eb8dcc2396f703ed8cb8775d6458775d39f3" alt=""
Since the
coordinate of
is 1, we can write
data:image/s3,"s3://crabby-images/1f17a/1f17abfcbc321fa80b02ebf26f317283b4c2a4b9" alt=""
data:image/s3,"s3://crabby-images/a017b/a017baf64828d90be7859f756aa64af559279640" alt=""
We now multiply the first equation by
on both sides:
data:image/s3,"s3://crabby-images/fdded/fddedc18b73ddb782534f57a17d0976c770c8516" alt=""
data:image/s3,"s3://crabby-images/4ea86/4ea86f94a0de79eecbf8ac7f2e4b3767cf486061" alt=""
data:image/s3,"s3://crabby-images/f5ae2/f5ae2636f87ab95589d426a962683e34030b011e" alt=""
Thus, we can transform projected points
from the input image into projected points of the output image
by applying the
homography
data:image/s3,"s3://crabby-images/08a9d/08a9dc745dece516c75155cdbc5b15c7921af252" alt=""
Re-Binning
When rectifying several images from different viewpoints, we obtain an uneven sampling on the camera / object plane. We get a uniform sampling by discretizing the light field and applying the Pull-Push algorithm to provide a color value for every pixel.
Pull-Push algorithm
Explained in 2D here. For Light Fields, we need to do this in 4D. Given: 2D grid of cells and unevenly distributed color samples
which are assigned to cells
.
For each cell, store a color value
and a weight
.
Initialization
For each cell, compute an average color and an initial weight
data:image/s3,"s3://crabby-images/29ab5/29ab5c8c44491c34ea02d1b7dcff2eeddc6917c0" alt=""
data:image/s3,"s3://crabby-images/164d2/164d249aec5316f29de737f5ef93c0f7e428d551" alt=""
Pull
Average colors and sum weights onto higher levels
data:image/s3,"s3://crabby-images/96e8d/96e8ddeccff8d0c84e44f72ec951d8afd6a469bb" alt=""
data:image/s3,"s3://crabby-images/96698/96698f6d9bebedcb7c13aeecfd344b26e68e8106" alt=""
Push
For each cell on the base level, walk up the hierarchy until a cell with weight > 0 is found. Use the color of that cell.
Assuming the scene is contained between two parallel planes, the camera plane and the object plane, we can parametrize each ray by a point
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
data:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Light Field Generation
1. Re-projection / Rectification of input images
2. Re-binning to produce uniform sampling on camera and object plane
Rectification
Each input image was taken at a camera position
data:image/s3,"s3://crabby-images/75a3f/75a3fd7336e9b2e3dda086196170e82936d50d90" alt=""
data:image/s3,"s3://crabby-images/b147e/b147eb8dcc2396f703ed8cb8775d6458775d39f3" alt=""
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/c32cd/c32cd1199911455f3b9321dda9304107bb82b728" alt=""
data:image/s3,"s3://crabby-images/b147e/b147eb8dcc2396f703ed8cb8775d6458775d39f3" alt=""
data:image/s3,"s3://crabby-images/df858/df858873a2e02e4fccb5670584bd016b7a734571" alt=""
We want to project
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/75a3f/75a3fd7336e9b2e3dda086196170e82936d50d90" alt=""
data:image/s3,"s3://crabby-images/89a62/89a62eda11aaa6f97cb091e3939617fa2836ae6c" alt=""
data:image/s3,"s3://crabby-images/b147e/b147eb8dcc2396f703ed8cb8775d6458775d39f3" alt=""
Since the
data:image/s3,"s3://crabby-images/42600/42600efc8a2faad5d3c2795ed6b2249112b85d27" alt=""
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/1f17a/1f17abfcbc321fa80b02ebf26f317283b4c2a4b9" alt=""
data:image/s3,"s3://crabby-images/a017b/a017baf64828d90be7859f756aa64af559279640" alt=""
We now multiply the first equation by
data:image/s3,"s3://crabby-images/094fd/094fd1a80ce90c8a1a907414ef9d010d54e49c79" alt=""
data:image/s3,"s3://crabby-images/fdded/fddedc18b73ddb782534f57a17d0976c770c8516" alt=""
data:image/s3,"s3://crabby-images/4ea86/4ea86f94a0de79eecbf8ac7f2e4b3767cf486061" alt=""
data:image/s3,"s3://crabby-images/f5ae2/f5ae2636f87ab95589d426a962683e34030b011e" alt=""
Thus, we can transform projected points
data:image/s3,"s3://crabby-images/c32cd/c32cd1199911455f3b9321dda9304107bb82b728" alt=""
data:image/s3,"s3://crabby-images/499f7/499f7fe8f2a6f2fbb9478bb0a8d193b80c65b701" alt=""
data:image/s3,"s3://crabby-images/923c1/923c138996a5d254ba2549588868e04ceb9e5f80" alt=""
data:image/s3,"s3://crabby-images/08a9d/08a9dc745dece516c75155cdbc5b15c7921af252" alt=""
Re-Binning
When rectifying several images from different viewpoints, we obtain an uneven sampling on the camera / object plane. We get a uniform sampling by discretizing the light field and applying the Pull-Push algorithm to provide a color value for every pixel.
Pull-Push algorithm
Explained in 2D here. For Light Fields, we need to do this in 4D. Given: 2D grid of cells and unevenly distributed color samples
data:image/s3,"s3://crabby-images/f240c/f240ce79197e3d66e9e2c3db6f83968a176a9749" alt=""
data:image/s3,"s3://crabby-images/8bb65/8bb65230cb08e7ee9a971c240c3242bb6bc59a0c" alt=""
For each cell, store a color value
data:image/s3,"s3://crabby-images/ffc3f/ffc3f1f7dd568f26ac934b2a72e60a484f5da061" alt=""
data:image/s3,"s3://crabby-images/986fd/986fdfd959121186e41592340f85c0c0aed2fc4f" alt=""
Initialization
For each cell, compute an average color and an initial weight
data:image/s3,"s3://crabby-images/29ab5/29ab5c8c44491c34ea02d1b7dcff2eeddc6917c0" alt=""
data:image/s3,"s3://crabby-images/164d2/164d249aec5316f29de737f5ef93c0f7e428d551" alt=""
Pull
Average colors and sum weights onto higher levels
data:image/s3,"s3://crabby-images/96e8d/96e8ddeccff8d0c84e44f72ec951d8afd6a469bb" alt=""
data:image/s3,"s3://crabby-images/96698/96698f6d9bebedcb7c13aeecfd344b26e68e8106" alt=""
Push
For each cell on the base level, walk up the hierarchy until a cell with weight > 0 is found. Use the color of that cell.
How are Light Fields rendered? How can we do this on the GPU?
First, consider bi-linear interpolation. In order to determine the color at a position
lying between four grid samples. Each grid sample at a position
has an influence of
data:image/s3,"s3://crabby-images/43e40/43e40647b4984b9ad4fe8738700cb9dd7bbca630" alt=""
on
.
Given: Light Fielddata:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Let
be the coordinates of the four pixels around
on the camera plane and
the coordinates of the four pixels around
on the object plane.
For each
, we compute an interpolated color value
from the four neighboring samples
on the object plane based on the position
.
Then, we compute a interpolated color value from the
, based on the position
.
Since we do a linear interpolation twice, this is called quad-linear interpolation.
GPU Implementation
Obtaining
coordinates for every pixel
Draw two quads: One for the object plane, one for the camera plane. As a texture, use a smooth color gradient from
lower left to
upper right. The rasterized colors are the
coordinates for every pixel.
Bi-Linear Interpolation on the Object Plane
We get this for free through texture interpolation: For each camera plane pixel, render one quad. As texture coordinates for the quad, use the respective
coordinates at that position.
Quad-Linear Interpolation
Instead of rendering one quad per camera plane pixel, render four quads surrounding the pixel with alpha blending and fade out the contribution towards the outer edges.
data:image/s3,"s3://crabby-images/a0e2a/a0e2a3c0c28c3243b9442b68ac437d09b146c03c" alt=""
data:image/s3,"s3://crabby-images/f95d6/f95d6fcf7f434a979f8428c75667d282687da3e2" alt=""
data:image/s3,"s3://crabby-images/43e40/43e40647b4984b9ad4fe8738700cb9dd7bbca630" alt=""
on
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
Given: Light Field
data:image/s3,"s3://crabby-images/03dc6/03dc658a38b68a41a37b2c586882c5ec8efbe238" alt=""
Let
data:image/s3,"s3://crabby-images/4338e/4338e8bbe85d134f7316137b2f4573caf673dc50" alt=""
data:image/s3,"s3://crabby-images/7a015/7a01573831858ea62b3304a1c6b509741c7fb29c" alt=""
data:image/s3,"s3://crabby-images/8dbf7/8dbf7e6eade879cfb4acd81f7b6f5cdd5d1b6a36" alt=""
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
For each
data:image/s3,"s3://crabby-images/49ddd/49ddd0e352cd2d3c6e789f6411be01f1a8861fe0" alt=""
data:image/s3,"s3://crabby-images/0fea3/0fea3ac8b519fc7529a6e33214d5fe67c62eae06" alt=""
data:image/s3,"s3://crabby-images/8dbf7/8dbf7e6eade879cfb4acd81f7b6f5cdd5d1b6a36" alt=""
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
Then, we compute a interpolated color value from the
data:image/s3,"s3://crabby-images/0fea3/0fea3ac8b519fc7529a6e33214d5fe67c62eae06" alt=""
data:image/s3,"s3://crabby-images/a0e2a/a0e2a3c0c28c3243b9442b68ac437d09b146c03c" alt=""
Since we do a linear interpolation twice, this is called quad-linear interpolation.
GPU Implementation
Obtaining
data:image/s3,"s3://crabby-images/3cc17/3cc171d3b4ae6b14f3d805b5d015000b311df3a2" alt=""
Draw two quads: One for the object plane, one for the camera plane. As a texture, use a smooth color gradient from
data:image/s3,"s3://crabby-images/711c1/711c14d9c6e58dcfa9f67300ffbb48409cff1cb3" alt=""
data:image/s3,"s3://crabby-images/b1464/b1464056b84923e6fa7c12883c813c0c70e3ff4f" alt=""
data:image/s3,"s3://crabby-images/38794/38794db6de5332cf1c48f7653e557c6e0960b963" alt=""
Bi-Linear Interpolation on the Object Plane
We get this for free through texture interpolation: For each camera plane pixel, render one quad. As texture coordinates for the quad, use the respective
data:image/s3,"s3://crabby-images/6aa22/6aa2213088d56dd44328ee7be4e48a638b199714" alt=""
Quad-Linear Interpolation
Instead of rendering one quad per camera plane pixel, render four quads surrounding the pixel with alpha blending and fade out the contribution towards the outer edges.
What is a Lumigraph? How must we update our object plane coordinates for Lumigraph rendering?
Lumigraph
Light Field + depth information. For a ray
, we can compute a depth value
telling at which depth between the camera and object plane the ray intersects the geometry.
This allows us to do more accurate interpolation by offsetting sample coordinates on the object plane.
Coordinate Offset
Let's consider the 2D case where a ray is only parametrized by
and
.
For each grid point
around
, we would compute a interpolated color for
. However, if the ray through
and
intersects a surface at a distance of
to the camera plane, we could find a better ray from
to another point
which intersects the geometry at the same point.
This is easily found by comparing similar triangles:
data:image/s3,"s3://crabby-images/0b4f3/0b4f3e15ec4efbf4a83d8dfe25fad87836f5c519" alt=""
data:image/s3,"s3://crabby-images/c6b93/c6b93483bc80c1ba12653e29898744890f18dde6" alt=""
Light Field + depth information. For a ray
data:image/s3,"s3://crabby-images/38794/38794db6de5332cf1c48f7653e557c6e0960b963" alt=""
data:image/s3,"s3://crabby-images/0e1e7/0e1e7890d668d9ef1053498bc28bf5019164bf1f" alt=""
This allows us to do more accurate interpolation by offsetting sample coordinates on the object plane.
Coordinate Offset
Let's consider the 2D case where a ray is only parametrized by
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/f240c/f240ce79197e3d66e9e2c3db6f83968a176a9749" alt=""
For each grid point
data:image/s3,"s3://crabby-images/0f623/0f6239ad3c52d1311b6b1f2be71237b329936236" alt=""
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/f240c/f240ce79197e3d66e9e2c3db6f83968a176a9749" alt=""
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/f240c/f240ce79197e3d66e9e2c3db6f83968a176a9749" alt=""
data:image/s3,"s3://crabby-images/e56c6/e56c6d687475c5442a7bf578c09cff67e2aa1283" alt=""
data:image/s3,"s3://crabby-images/0f623/0f6239ad3c52d1311b6b1f2be71237b329936236" alt=""
data:image/s3,"s3://crabby-images/08f96/08f96d478dbc0b195b2c75886ec73f333ada2270" alt=""
This is easily found by comparing similar triangles:
data:image/s3,"s3://crabby-images/0b4f3/0b4f3e15ec4efbf4a83d8dfe25fad87836f5c519" alt=""
data:image/s3,"s3://crabby-images/c6b93/c6b93483bc80c1ba12653e29898744890f18dde6" alt=""
What is an Unstructured Lumigraph? How does Unstructured Lumigraph rendering work? How can we do this in hardware?
Input Data
Unstructured set of photos (with calibration information and camera positions)
Proxy Geometry
Requirements
Render interpolated views of the scene
Rendering
For each pixel of the output image, compute a blending of the input images. First, compute view ray by intersecting with proxy geometry, then find k-best input images.
For each input image
, compute the angle difference
at the intersection point.
We denote by
the angle difference of the k-best camera. Now, we can compute the color contribution of each image as
data:image/s3,"s3://crabby-images/2b4ae/2b4ae03aef5ca943998b0dd32ef162b7b9294a55" alt=""
and normalizing
data:image/s3,"s3://crabby-images/a0bc7/a0bc70742a03ce123d2425a66f209d02299660b8" alt=""
To improve consistency, we can emphasize weights where the angle is very small, e.g.:
data:image/s3,"s3://crabby-images/cc7c5/cc7c53b2d6e9a09f7ace34512db1949ab0e91bdb" alt=""
Hardware Implementation
Tessellate screen with a triangle grid. Insert into this grid:
Compute blending weights for triangle vertices. Render each triangle several times (at least
, at most
times) with the appropriate textures and additive blending.
Unstructured set of photos (with calibration information and camera positions)
Proxy Geometry
Requirements
Render interpolated views of the scene
- in real time
- with no pre-processing or re-sampling of the input images
- with smooth interpolation as the camera moves through the scene
- consistent (reproduce source image if desired viewpoint matches)
Rendering
For each pixel of the output image, compute a blending of the input images. First, compute view ray by intersecting with proxy geometry, then find k-best input images.
For each input image
data:image/s3,"s3://crabby-images/92ed4/92ed4f5be3550b4db2ab04eab3bff5d35042ca7b" alt=""
data:image/s3,"s3://crabby-images/2ddba/2ddbaec639213ead3595e9760a0dd50e8acf64f4" alt=""
We denote by
data:image/s3,"s3://crabby-images/242ae/242aebf004e0d7375cf2100d4efd2af8181cc33b" alt=""
data:image/s3,"s3://crabby-images/2b4ae/2b4ae03aef5ca943998b0dd32ef162b7b9294a55" alt=""
and normalizing
data:image/s3,"s3://crabby-images/a0bc7/a0bc70742a03ce123d2425a66f209d02299660b8" alt=""
To improve consistency, we can emphasize weights where the angle is very small, e.g.:
data:image/s3,"s3://crabby-images/cc7c5/cc7c53b2d6e9a09f7ace34512db1949ab0e91bdb" alt=""
Hardware Implementation
Tessellate screen with a triangle grid. Insert into this grid:
- Edges of the proxy geometry (here are discontinuities)
- Epipolar points of the cameras (we want the image to be consistent there)
Compute blending weights for triangle vertices. Render each triangle several times (at least
data:image/s3,"s3://crabby-images/b9903/b99032d10a48891bfc06721920c706cb818706cd" alt=""
data:image/s3,"s3://crabby-images/4b016/4b01674e8e0526d3168b96db536da33a554ded53" alt=""
What are Layered Depth Images? How to render them with correct occlusion?
Input: Set of images with colors and depth information.
Layered Depth Image: All of these input images combined into one image (from a new viewpoint), where along each viewing ray there may be several pixels with different depths and colors.
We can render an LDI by splatting all points. Points are transformed by the camera matrix:
data:image/s3,"s3://crabby-images/18eca/18eca4c5a35cd0ab460601336a685fc223e45051" alt=""
can be decomposed into 4 row vectors:
data:image/s3,"s3://crabby-images/bf5f9/bf5f94bc4e593afeda8fae0060487d52c558c0a5" alt=""
If we know a transformed point
, new points in the vicinity can be computed incrementally:
data:image/s3,"s3://crabby-images/91c57/91c570459119232a3cfe808cdd11be7d2ec55f36" alt=""
Correct occlusion can be ensured by projecting the camera position into the LDI. This point splits the LDI into 4 quadrants which are rendered row-wise outside-inwards towards the epipolar point.
Layered Depth Image: All of these input images combined into one image (from a new viewpoint), where along each viewing ray there may be several pixels with different depths and colors.
We can render an LDI by splatting all points. Points are transformed by the camera matrix:
data:image/s3,"s3://crabby-images/18eca/18eca4c5a35cd0ab460601336a685fc223e45051" alt=""
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
data:image/s3,"s3://crabby-images/bf5f9/bf5f94bc4e593afeda8fae0060487d52c558c0a5" alt=""
If we know a transformed point
data:image/s3,"s3://crabby-images/b43e8/b43e842a3cf1d7624e796137e1d8da51e4371732" alt=""
data:image/s3,"s3://crabby-images/91c57/91c570459119232a3cfe808cdd11be7d2ec55f36" alt=""
Correct occlusion can be ensured by projecting the camera position into the LDI. This point splits the LDI into 4 quadrants which are rendered row-wise outside-inwards towards the epipolar point.
What are Image-Based Visual Hulls?
Input: Set of images where on each image, there is an identifiable silhouette of the shown object. Each camera spans a generalized cone through the silhouette. The intersection of all these cones approximates the shape of the object.
Goal: For a new viewpoint, find out where the view ray intersects the approximated shape of the object.
In each source image, the projection of the view ray for one pixel in the target image is a line. We want to find the intersection points of this line with the silhouette. Thus, we discretize the silhouette into line segments and test for intersections:
complexity per source image.
Note that if the camera position is fixed, the projected view rays in the source images are a pencil of lines through the camera epipolar point. Every time the camera position changes, perform a binning of the polygon edges into sectors. This reduces the intersection complexity from
to
.
Goal: For a new viewpoint, find out where the view ray intersects the approximated shape of the object.
In each source image, the projection of the view ray for one pixel in the target image is a line. We want to find the intersection points of this line with the silhouette. Thus, we discretize the silhouette into line segments and test for intersections:
data:image/s3,"s3://crabby-images/09e6a/09e6a6aaadbc5e4d3e506824a790cc60641e2869" alt=""
Note that if the camera position is fixed, the projected view rays in the source images are a pencil of lines through the camera epipolar point. Every time the camera position changes, perform a binning of the polygon edges into sectors. This reduces the intersection complexity from
data:image/s3,"s3://crabby-images/09e6a/09e6a6aaadbc5e4d3e506824a790cc60641e2869" alt=""
data:image/s3,"s3://crabby-images/2438a/2438aa84ec1f11b6d16b9fb5d5126eba490890c6" alt=""
What is Image Retargeting? How can we do it?
Image Retargeting
Change of image dimensions without stretching / cropping in regions where there is interesting content.
We first need a salience measure that tells us which areas of an image are interesting or important and should be preserved. Generally involves some kind of gradient filter / Laplace filter / sobel filter, or similar.
Seam Carving
Assuming we want to reduce the width of the image.
Find continuous, monotonic path from top to bottom through the image (seam) which has minimal total salience. Remove this seam.
Repeat until target width reached.
We denote by
the lowest cost of a seam starting at pixel
and running to the bottom of the image (
).
Of course, for the bottom line pixels, this is just the local salience value:
data:image/s3,"s3://crabby-images/dc19e/dc19e62d77f4964f91370ee1e9a2580155736a8c" alt=""
For all other pixels, the minimum cost is computed as
data:image/s3,"s3://crabby-images/4f379/4f379fda82916be90b9eb6b93d2ac6e7f12592f6" alt=""
A solution to this can be computed using Dynamic Programming.
An alternative solution approach is to formulate the seam search as a min-cost graph cut problem.
Change of image dimensions without stretching / cropping in regions where there is interesting content.
We first need a salience measure that tells us which areas of an image are interesting or important and should be preserved. Generally involves some kind of gradient filter / Laplace filter / sobel filter, or similar.
Seam Carving
Assuming we want to reduce the width of the image.
Find continuous, monotonic path from top to bottom through the image (seam) which has minimal total salience. Remove this seam.
Repeat until target width reached.
We denote by
data:image/s3,"s3://crabby-images/5b8fd/5b8fd9a5ceb351da37dc6592e459c2c0e47261aa" alt=""
data:image/s3,"s3://crabby-images/c7fe3/c7fe3ddbdcce353d31d4704cef5e90ed53b68974" alt=""
data:image/s3,"s3://crabby-images/d1bf6/d1bf67b4c3ff1ed1527e850d6c172b98113471fd" alt=""
Of course, for the bottom line pixels, this is just the local salience value:
data:image/s3,"s3://crabby-images/dc19e/dc19e62d77f4964f91370ee1e9a2580155736a8c" alt=""
For all other pixels, the minimum cost is computed as
data:image/s3,"s3://crabby-images/4f379/4f379fda82916be90b9eb6b93d2ac6e7f12592f6" alt=""
A solution to this can be computed using Dynamic Programming.
An alternative solution approach is to formulate the seam search as a min-cost graph cut problem.
Explain Image Completion!
Problem
Input image with some area (the hole) which should be filled with data from the rest of the image.
Idea
Repeatedly shrink the hole by:
Selecting an area which overlaps both the hole and a part
of the image around it.
Finding a region (fragment) in the image which is similar to
.
Copying over the pixels from the fragment into the hole.
Finding
We search for an optimal pixel offset
such that
data:image/s3,"s3://crabby-images/39be3/39be329aacce28922b1d036d687d0c1cf7079604" alt=""
data:image/s3,"s3://crabby-images/55074/5507478809671882a3155fd9421feb2a08cf4a7c" alt=""
The first term is constant w.r.t.
.
The third term can be computed in
with some precomputations.
What remains is the middle term which corresponds to a convolution. We can compute this by transforming both the input image as well as the region
into the frequency domain and then doing the multiplication there. We then transform back to the pixel domain and find the maximum intensity pixel.
Compositing
After we have found the best source fragment, we compute an ideal seam for the fragment we copy over. This can be computed by a min-flow graph cut.
Color Correction
Additionally, we adjust the color of the copied-over pixels such that they match the hole boundary. We do this by prescribing that the color corrected pixels
should have the same color gradients as the source pixels data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/31405/314056ce29ed2fee475eacd4f1d504dab9f70203" alt=""
while on the boundary, there should be no color difference
data:image/s3,"s3://crabby-images/68499/68499c13a6e3634da601a6281817a18fca1b8467" alt=""
By applying the divergence on both sides, we turn this into a Poisson Equation
data:image/s3,"s3://crabby-images/31405/314056ce29ed2fee475eacd4f1d504dab9f70203" alt=""
data:image/s3,"s3://crabby-images/db2b1/db2b182c85176e305e1dd7dec5e3d7631d018232" alt=""
Perspective Correction
Sometimes, we want to reconstruct pixels from parts of the image which are viewed at an angle. Let the user define piecewise homographies by painting in the vertices of square patches. Flatten the image by applying the homographies and use this flattened image for the image completion.
Input image with some area (the hole) which should be filled with data from the rest of the image.
Idea
Repeatedly shrink the hole by:
Selecting an area which overlaps both the hole and a part
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Finding a region (fragment) in the image which is similar to
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Copying over the pixels from the fragment into the hole.
Finding
We search for an optimal pixel offset
data:image/s3,"s3://crabby-images/d5bef/d5bef767371964e9aa952a1ef376050e09d5416f" alt=""
data:image/s3,"s3://crabby-images/39be3/39be329aacce28922b1d036d687d0c1cf7079604" alt=""
data:image/s3,"s3://crabby-images/55074/5507478809671882a3155fd9421feb2a08cf4a7c" alt=""
The first term is constant w.r.t.
data:image/s3,"s3://crabby-images/cd661/cd6610a346e11d0226deccde9b01a381ded15a2f" alt=""
The third term can be computed in
data:image/s3,"s3://crabby-images/dad6f/dad6f013c76c965a96202b4bad1213e42006673e" alt=""
What remains is the middle term which corresponds to a convolution. We can compute this by transforming both the input image as well as the region
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Compositing
After we have found the best source fragment, we compute an ideal seam for the fragment we copy over. This can be computed by a min-flow graph cut.
Color Correction
Additionally, we adjust the color of the copied-over pixels such that they match the hole boundary. We do this by prescribing that the color corrected pixels
data:image/s3,"s3://crabby-images/afd21/afd216827a414cc4522095cd42927f0fb73efff9" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/31405/314056ce29ed2fee475eacd4f1d504dab9f70203" alt=""
while on the boundary, there should be no color difference
data:image/s3,"s3://crabby-images/68499/68499c13a6e3634da601a6281817a18fca1b8467" alt=""
By applying the divergence on both sides, we turn this into a Poisson Equation
data:image/s3,"s3://crabby-images/31405/314056ce29ed2fee475eacd4f1d504dab9f70203" alt=""
data:image/s3,"s3://crabby-images/db2b1/db2b182c85176e305e1dd7dec5e3d7631d018232" alt=""
Perspective Correction
Sometimes, we want to reconstruct pixels from parts of the image which are viewed at an angle. Let the user define piecewise homographies by painting in the vertices of square patches. Flatten the image by applying the homographies and use this flattened image for the image completion.
Give the smoothing operator for 3D meshes! Which weights can we use for this?
Smoothing Operator
data:image/s3,"s3://crabby-images/a7494/a7494a33d587643a2ae9905dfabf9d9fbcbf411c" alt=""
Uniform Weights
data:image/s3,"s3://crabby-images/ae93f/ae93f4c8719fec4d9031f9133956bfbfca385f85" alt=""
Move vertices into center of gravity of its 1-ring neighbors. Performs normal and tangential smoothing. Leads to a regular distribution of vertices.
Cotangent Weights
data:image/s3,"s3://crabby-images/5847b/5847ba3326381eb1c12a5249cb2c477ad6ee04a8" alt=""
Denoting the area of the 1-ring around
by
, cotangent weights move
into the direction of
. Since in a planar configuration, moving
does not change
,
is normal to the mesh. Thus, cotangent weights have linear precision. Cotangent weights mostly do normal smoothing. They can become negative for very long triangles. However, if the mesh is Delaunay, Cotangent weights are positive.
Mean Value Weights
data:image/s3,"s3://crabby-images/3517d/3517deaaf1d67a6940044a75cfe3d67eb341c498" alt=""
where
and
are the angles between the edge
and the edges to the previous and next 1-ring neighbor, respectively. MVW have linear precision, they are always positive, but they are non-symmetric:
, in general
data:image/s3,"s3://crabby-images/a7494/a7494a33d587643a2ae9905dfabf9d9fbcbf411c" alt=""
Uniform Weights
data:image/s3,"s3://crabby-images/ae93f/ae93f4c8719fec4d9031f9133956bfbfca385f85" alt=""
Move vertices into center of gravity of its 1-ring neighbors. Performs normal and tangential smoothing. Leads to a regular distribution of vertices.
Cotangent Weights
data:image/s3,"s3://crabby-images/5847b/5847ba3326381eb1c12a5249cb2c477ad6ee04a8" alt=""
Denoting the area of the 1-ring around
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/f00cd/f00cd94b0fc7b875a55fec334563c5f9c1e743ea" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/107bc/107bc9fe6414ac9d618677197a85739eeed9cb21" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/f00cd/f00cd94b0fc7b875a55fec334563c5f9c1e743ea" alt=""
data:image/s3,"s3://crabby-images/107bc/107bc9fe6414ac9d618677197a85739eeed9cb21" alt=""
Mean Value Weights
data:image/s3,"s3://crabby-images/3517d/3517deaaf1d67a6940044a75cfe3d67eb341c498" alt=""
where
data:image/s3,"s3://crabby-images/09cf8/09cf8ef7d0aab3d8250c6041c3b6dc44cd9eab89" alt=""
data:image/s3,"s3://crabby-images/77b64/77b64fc05a96ddd571cb4dcbf857196ea58ceafb" alt=""
data:image/s3,"s3://crabby-images/8fff9/8fff975fca0993bde1b924c7ef18a6781b398cde" alt=""
data:image/s3,"s3://crabby-images/77d6d/77d6d82f90d529a20af0206c33600e3ec4e65ccf" alt=""
How can you achieve only smoothing in the tangent direction?
Approach 1: Project update on tangent plane
data:image/s3,"s3://crabby-images/689f3/689f3148e3656dd79abf689e57394864ee1d6c19" alt=""
Approach 2: Different weights
Compute
with uniform weights (does both normal and tangential smoothing).
Compute
with cotangent weights (does mostly normal smoothing).
Update:
data:image/s3,"s3://crabby-images/dda40/dda4040c105d0006a268b14415c9e0b089be7208" alt=""
data:image/s3,"s3://crabby-images/689f3/689f3148e3656dd79abf689e57394864ee1d6c19" alt=""
Approach 2: Different weights
Compute
data:image/s3,"s3://crabby-images/283c8/283c8fbb08d0c5e3daf6ca4901bc0400cd232af6" alt=""
Compute
data:image/s3,"s3://crabby-images/54cca/54cca756c7eaf1bf7df7c9d712c1d45bf00cd79a" alt=""
Update:
data:image/s3,"s3://crabby-images/dda40/dda4040c105d0006a268b14415c9e0b089be7208" alt=""
Give a physical interpretation of smoothing operators!
If we iterate the smoothing operator
data:image/s3,"s3://crabby-images/c7acf/c7acf896529ff1e21dd39a66ee749e826911566d" alt=""
until convergence, the
will go to zero:
data:image/s3,"s3://crabby-images/c30e0/c30e043c14113c0e032bda4161053cc265a1b3cb" alt=""
We know that
approximates the Laplace of a function that interpolates the
. Thus
data:image/s3,"s3://crabby-images/62785/62785f929d1c3984ea201b6c9f32a84f9617dc1a" alt=""
The physical interpretation of
is an area-minimizing membrane surface, comparable to the surface of a soap film suspended inside a wire loop.
By constraining higher-order derivatives of
, we can model other surfaces such as a thin plate:
data:image/s3,"s3://crabby-images/844f3/844f3d64f72be18837b58724e310b086039a4343" alt=""
which gives
data:image/s3,"s3://crabby-images/13389/13389d47547cb5e1e4dd85dea81610146f2f08b3" alt=""
and produces a surface which minimizes curvature.
data:image/s3,"s3://crabby-images/c7acf/c7acf896529ff1e21dd39a66ee749e826911566d" alt=""
until convergence, the
data:image/s3,"s3://crabby-images/c4833/c4833d1ff9b33d9336c3a7e721e544d4cf079898" alt=""
data:image/s3,"s3://crabby-images/c30e0/c30e043c14113c0e032bda4161053cc265a1b3cb" alt=""
We know that
data:image/s3,"s3://crabby-images/c4833/c4833d1ff9b33d9336c3a7e721e544d4cf079898" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/62785/62785f929d1c3984ea201b6c9f32a84f9617dc1a" alt=""
The physical interpretation of
data:image/s3,"s3://crabby-images/dc270/dc270a9ce3bf36537d2220eb25ae1e183561f873" alt=""
By constraining higher-order derivatives of
data:image/s3,"s3://crabby-images/dc270/dc270a9ce3bf36537d2220eb25ae1e183561f873" alt=""
data:image/s3,"s3://crabby-images/844f3/844f3d64f72be18837b58724e310b086039a4343" alt=""
which gives
data:image/s3,"s3://crabby-images/13389/13389d47547cb5e1e4dd85dea81610146f2f08b3" alt=""
and produces a surface which minimizes curvature.
How to prevent a mesh from shrinking too much when applying smoothing?
Error Control
Constrain the positions of the vertices such that they can only move by a certain extent from their original position.
-Balls
A vertex
must not move by more than
from its original position
.
If
leaves its
ball after a smoothing iteration, it is projected back onto the closest point inside the ball:
data:image/s3,"s3://crabby-images/ec819/ec819732adf341dfe8beb2e33e30c091af354f2f" alt=""
Error Slabs
The movement of a vertex
is constrained to its original tangent plane. Its position may not deviate from the tangent plane by more than
. If it does, it is projected back:
data:image/s3,"s3://crabby-images/5da98/5da98a1de6c695a4407a6207c991f6a30cf6f3c3" alt=""
Constrain the positions of the vertices such that they can only move by a certain extent from their original position.
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
A vertex
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
data:image/s3,"s3://crabby-images/db682/db6823ccab089f64240380aa2b58683721695c8c" alt=""
If
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
data:image/s3,"s3://crabby-images/ec819/ec819732adf341dfe8beb2e33e30c091af354f2f" alt=""
Error Slabs
The movement of a vertex
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
data:image/s3,"s3://crabby-images/5da98/5da98a1de6c695a4407a6207c991f6a30cf6f3c3" alt=""
What is the difference between Smoothing, Refinement and Subdivision?
Smoothing
Geometrical operation: Affects vertex positions. Topology remains unchanged.
Refinement
Topological operation: Faces are split into smaller faces. Geometry remains unchanged.
Subdivision
Refinement + Smoothing
Geometrical operation: Affects vertex positions. Topology remains unchanged.
Refinement
Topological operation: Faces are split into smaller faces. Geometry remains unchanged.
Subdivision
Refinement + Smoothing
Explain the Incremental Decimation algorithm!
Algorithm Overview
for each local operator:
evaluate quality decrease
enqueue (quality decrease, op) into priority queue
repeat:
pop best operator from queue
apply
update queue
until target complexity reached or error too large
Operators
Error Metrics
Local Error Metrics: Plane distance, Volume change
Global Error Metrics: Hausdorff distance, Simplification Envelopes, Error Quadrics
Error Quadrics are particularly suitable because they can be evaluated locally: On the initial mesh, compute error quadrics for every vertex from its incident triangle planes. When two vertices are merged, the error quadrics stored in the original vertices are added. Note: Not 100% correct since some planes are added twice.
Fairness Criteria
To ensure a certain mesh quality, we can forbid some operators:
for each local operator:
evaluate quality decrease
enqueue (quality decrease, op) into priority queue
repeat:
pop best operator from queue
apply
update queue
until target complexity reached or error too large
Operators
- Vertex Removal: Remove center vertex from a 1-ring and re-triangulate. Topological operator. Degrees of freedom: Triangulation.
- Edge Collapse: Merge the two end vertices of one edge into one. Topological / geometrical operator. Degrees of freedom: Vertex position.
- Halfedge Collapse: Merge the start vertex and the end vertex of one edge. New position is the position of the end vertex. Topological operator. Degrees of freedom: None (which is preferable).
Error Metrics
Local Error Metrics: Plane distance, Volume change
Global Error Metrics: Hausdorff distance, Simplification Envelopes, Error Quadrics
Error Quadrics are particularly suitable because they can be evaluated locally: On the initial mesh, compute error quadrics for every vertex from its incident triangle planes. When two vertices are merged, the error quadrics stored in the original vertices are added. Note: Not 100% correct since some planes are added twice.
Fairness Criteria
To ensure a certain mesh quality, we can forbid some operators:
- Triangle Shape: Forbid operators which would produce triangles with too small interior angles
- Valence Balance: Forbid operators which would produce a triangulation where the valence of a vertex becomes very small or very large
- Normal Approximation
- Texture Distortion
How are Progressive Meshes generated, stored and reconstructed? How can we do Selective Refinement?
Original mesh: data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Incremental Decimation applies a series of decimation operators:
data:image/s3,"s3://crabby-images/a5045/a5045c3746cf141eb459f8bcbc6eee077bcb422a" alt=""
By reversing these operators, we can reconstruct
from the decimated mesh data:image/s3,"s3://crabby-images/b8cd0/b8cd0c5466514d285da4b6c17174080cb11350ad" alt=""
data:image/s3,"s3://crabby-images/7ab74/7ab74f07401a6b36dbc438a63a964e7d19f1d428" alt=""
In order to make a Halfedge Collapse operator
reversible, we need to store:
Thus, each operator is stored as
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
Selective Refinement
If we want to undo an operator
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
the problem might be that one of the opposite vertices
or
does not exist:
In order to solve this problem, we store the refined mesh as a binary forest where the leaf nodes are the unrefined vertices and each inner node corresponds to a decimation operator.
During decimation, we remember from which original vertices our mesh started out. Initially, we store at every triangle corner a pointer to the incident vertex. As we decimate the mesh, these triangle corner labels remain intact. When we store an operator, instead of storing
,
as the vertices in the decimated mesh, we store the values stored in the respective triangle corners.
If we want to refine at a vertex
, we find the two opposite vertices
,
in the currently refined mesh by walking up the binary forest of operators until we find vertices that have already been instantiated.
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Incremental Decimation applies a series of decimation operators:
data:image/s3,"s3://crabby-images/a5045/a5045c3746cf141eb459f8bcbc6eee077bcb422a" alt=""
By reversing these operators, we can reconstruct
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
data:image/s3,"s3://crabby-images/b8cd0/b8cd0c5466514d285da4b6c17174080cb11350ad" alt=""
data:image/s3,"s3://crabby-images/7ab74/7ab74f07401a6b36dbc438a63a964e7d19f1d428" alt=""
In order to make a Halfedge Collapse operator
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
- Position of the source vertex which was collapsed:
- A pointer to the target vertex towards which
was collapsed:
- Pointers to the two boundary vertices which were adjacent to both
and
before the collapse:
Thus, each operator is stored as
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
Selective Refinement
If we want to undo an operator
data:image/s3,"s3://crabby-images/6a056/6a0566db12c49cf15e152d3111254dd9b474b2f6" alt=""
the problem might be that one of the opposite vertices
data:image/s3,"s3://crabby-images/c17e4/c17e4e5be4e5b959bff8eb32caa25b424ee98edb" alt=""
data:image/s3,"s3://crabby-images/85028/850280873bde023b4a6e666d9f9849bdfcc97f49" alt=""
-
/
might not exist yet if it is still not expanded
-
/
might not exist anymore if it has previously been split
In order to solve this problem, we store the refined mesh as a binary forest where the leaf nodes are the unrefined vertices and each inner node corresponds to a decimation operator.
During decimation, we remember from which original vertices our mesh started out. Initially, we store at every triangle corner a pointer to the incident vertex. As we decimate the mesh, these triangle corner labels remain intact. When we store an operator, instead of storing
data:image/s3,"s3://crabby-images/e614f/e614ff7618866461b127d795f7eb785b8f855994" alt=""
data:image/s3,"s3://crabby-images/cf1a6/cf1a6b8a3f3502693312a15ac18bff41700f86bf" alt=""
If we want to refine at a vertex
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/c17e4/c17e4e5be4e5b959bff8eb32caa25b424ee98edb" alt=""
data:image/s3,"s3://crabby-images/85028/850280873bde023b4a6e666d9f9849bdfcc97f49" alt=""
Give a smoothing operator for a curve of vertices in 2D space! What analytical meaning does this operator have? How can we design a better smoothing operator?
Given: Line of vertices data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
An intuitive smoothing operator is
data:image/s3,"s3://crabby-images/e5639/e5639fade4f5f2c34979ef25e9fa487311eec9e9" alt=""
or
data:image/s3,"s3://crabby-images/633c1/633c1cda90ec2c7c9e01f02045ba88b2eae73474" alt=""
with
data:image/s3,"s3://crabby-images/5da5b/5da5bcb5a3dec6dff3d818ceae3d43062a0892c4" alt=""
Assuming the points are generated by an arc-length parametrized function
data:image/s3,"s3://crabby-images/95b1e/95b1ebc832de28c7e661118cf6213dab0d066768" alt=""
data:image/s3,"s3://crabby-images/6faa6/6faa6096e0e32e4b2ed4008b37c03aece35c60f9" alt=""
data:image/s3,"s3://crabby-images/4cfe3/4cfe3c04563f05958c12018333d41e7ef6ef0405" alt=""
we can approximate the first derivative by divided differences:
data:image/s3,"s3://crabby-images/32bad/32bad4d24f69e8d3f0d80b5e909b125daf0dc021" alt=""
data:image/s3,"s3://crabby-images/54579/54579a635e5e8c5ebd0ce0e0d195c2c1d2bf0820" alt=""
And the second derivative by again taking divided differences:
data:image/s3,"s3://crabby-images/eae15/eae155bd850d778344b36fc810223a1160d60a79" alt=""
data:image/s3,"s3://crabby-images/968da/968da00b84b609a63b0d4e60ca999917a97be6e7" alt=""
data:image/s3,"s3://crabby-images/6f34a/6f34a693fe58797aa4d30f9d82c6f0f47560974a" alt=""
Thus, the smoothing operator approximates the second derivative of the curve.
By writing the points as a matrix
data:image/s3,"s3://crabby-images/e0edf/e0edf4855482b8701804c1d08d4f41f10e3e1091" alt=""
We can write the smoothing operator as a matrix vector product
data:image/s3,"s3://crabby-images/68534/685343711c07a51af977b98cb8ecec7102344bdc" alt=""
where
is a sparse matrix with
on the main diagonal and
on the two minor diagonals.
is symmetric. Thus, it has an orthogonal basis of eigenvectors
. We can represent
in this basis:
data:image/s3,"s3://crabby-images/1f0ca/1f0cad73860145a2e53a2bb21f14e1965bf307a9" alt=""
where
are suitable (two-dimensional) coefficients.
Applying
to
can now be written as
data:image/s3,"s3://crabby-images/b319c/b319ca5a4fa03e43a797acfa7b6ffe13486ad9e1" alt=""
data:image/s3,"s3://crabby-images/c90f6/c90f6b857aae647156cdeab6d696178d962cba8c" alt=""
data:image/s3,"s3://crabby-images/965ee/965ee7ee3135d48d200c77b469848a1e538b46d1" alt=""
Thus, we can interpret smoothing as a scaling of the eigenvectors of
.
TODO: Eigenfunctions of U and DFT
Filter Design
Our smoothing operator reduces mid and high frequencies of the mesh. Thus,
data:image/s3,"s3://crabby-images/6fee8/6fee8a570c1087853f8a67a9faa550674124abcf" alt=""
only contains the low frequencies of the input. By subtraction, we get the mid and high frequency parts:
data:image/s3,"s3://crabby-images/a1412/a1412f94c0e9074d67ba922ddb26c6e98e3d9f44" alt=""
data:image/s3,"s3://crabby-images/df3e8/df3e85fe41ecb43f3d28054b021ef7e5a7cdbaad" alt=""
We now apply our smoothing operator only to those mid and high frequencies:
data:image/s3,"s3://crabby-images/434b1/434b101d69b8c2101aaf9b6af7666855c55a9f13" alt=""
data:image/s3,"s3://crabby-images/00c3a/00c3a72599d056d1332e346be6d27adb4d049910" alt=""
Combining the low and smoothed high frequency terms gives:
data:image/s3,"s3://crabby-images/5d06b/5d06b9e75bb17d00174f13945606050e5939c21d" alt=""
data:image/s3,"s3://crabby-images/937ec/937ec1bb971f15168163c2a29e09d302733b7d56" alt=""
Which is a smoothing operator which only dampens the mid and high frequencies.
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
An intuitive smoothing operator is
data:image/s3,"s3://crabby-images/e5639/e5639fade4f5f2c34979ef25e9fa487311eec9e9" alt=""
or
data:image/s3,"s3://crabby-images/633c1/633c1cda90ec2c7c9e01f02045ba88b2eae73474" alt=""
with
data:image/s3,"s3://crabby-images/5da5b/5da5bcb5a3dec6dff3d818ceae3d43062a0892c4" alt=""
Assuming the points are generated by an arc-length parametrized function
data:image/s3,"s3://crabby-images/95b1e/95b1ebc832de28c7e661118cf6213dab0d066768" alt=""
data:image/s3,"s3://crabby-images/6faa6/6faa6096e0e32e4b2ed4008b37c03aece35c60f9" alt=""
data:image/s3,"s3://crabby-images/4cfe3/4cfe3c04563f05958c12018333d41e7ef6ef0405" alt=""
we can approximate the first derivative by divided differences:
data:image/s3,"s3://crabby-images/32bad/32bad4d24f69e8d3f0d80b5e909b125daf0dc021" alt=""
data:image/s3,"s3://crabby-images/54579/54579a635e5e8c5ebd0ce0e0d195c2c1d2bf0820" alt=""
And the second derivative by again taking divided differences:
data:image/s3,"s3://crabby-images/eae15/eae155bd850d778344b36fc810223a1160d60a79" alt=""
data:image/s3,"s3://crabby-images/968da/968da00b84b609a63b0d4e60ca999917a97be6e7" alt=""
data:image/s3,"s3://crabby-images/6f34a/6f34a693fe58797aa4d30f9d82c6f0f47560974a" alt=""
Thus, the smoothing operator approximates the second derivative of the curve.
By writing the points as a matrix
data:image/s3,"s3://crabby-images/e0edf/e0edf4855482b8701804c1d08d4f41f10e3e1091" alt=""
We can write the smoothing operator as a matrix vector product
data:image/s3,"s3://crabby-images/68534/685343711c07a51af977b98cb8ecec7102344bdc" alt=""
where
data:image/s3,"s3://crabby-images/85393/853930f6cfd55abcacbac568d721d0a5139b06ed" alt=""
data:image/s3,"s3://crabby-images/24dbf/24dbf9c7b98093d3041aa47a42ffcf788fb030b9" alt=""
data:image/s3,"s3://crabby-images/a1139/a1139ab323e13e4df654dd60538577f752b9b49d" alt=""
data:image/s3,"s3://crabby-images/85393/853930f6cfd55abcacbac568d721d0a5139b06ed" alt=""
data:image/s3,"s3://crabby-images/2abfb/2abfbc1ad99da1e5ffd5236c4edc6b7bd7c0ffb0" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/1f0ca/1f0cad73860145a2e53a2bb21f14e1965bf307a9" alt=""
where
data:image/s3,"s3://crabby-images/bbdb5/bbdb5eef065803a3e708067b1dbaa76f105b7ca7" alt=""
Applying
data:image/s3,"s3://crabby-images/85393/853930f6cfd55abcacbac568d721d0a5139b06ed" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/b319c/b319ca5a4fa03e43a797acfa7b6ffe13486ad9e1" alt=""
data:image/s3,"s3://crabby-images/c90f6/c90f6b857aae647156cdeab6d696178d962cba8c" alt=""
data:image/s3,"s3://crabby-images/965ee/965ee7ee3135d48d200c77b469848a1e538b46d1" alt=""
Thus, we can interpret smoothing as a scaling of the eigenvectors of
data:image/s3,"s3://crabby-images/85393/853930f6cfd55abcacbac568d721d0a5139b06ed" alt=""
TODO: Eigenfunctions of U and DFT
Filter Design
Our smoothing operator reduces mid and high frequencies of the mesh. Thus,
data:image/s3,"s3://crabby-images/6fee8/6fee8a570c1087853f8a67a9faa550674124abcf" alt=""
only contains the low frequencies of the input. By subtraction, we get the mid and high frequency parts:
data:image/s3,"s3://crabby-images/a1412/a1412f94c0e9074d67ba922ddb26c6e98e3d9f44" alt=""
data:image/s3,"s3://crabby-images/df3e8/df3e85fe41ecb43f3d28054b021ef7e5a7cdbaad" alt=""
We now apply our smoothing operator only to those mid and high frequencies:
data:image/s3,"s3://crabby-images/434b1/434b101d69b8c2101aaf9b6af7666855c55a9f13" alt=""
data:image/s3,"s3://crabby-images/00c3a/00c3a72599d056d1332e346be6d27adb4d049910" alt=""
Combining the low and smoothed high frequency terms gives:
data:image/s3,"s3://crabby-images/5d06b/5d06b9e75bb17d00174f13945606050e5939c21d" alt=""
data:image/s3,"s3://crabby-images/937ec/937ec1bb971f15168163c2a29e09d302733b7d56" alt=""
Which is a smoothing operator which only dampens the mid and high frequencies.
What is Mesh Decimation? Which algorithms did we look at and what kind of control do they provide?
In Mesh Decimation, given an input mesh, we try to find another mesh which looks similar but consists of fewer vertices. We would like to bound the approximation error of the decimated mesh. Also, we want to be able to prescribe a target complexity by giving the desired amount of vertices.
Algorithm | Approximation Error | Target Complexity |
Vertex Clustering | yes | |
Incremental Decimation | yes | yes |
Remeshing | yes |
Explain how to use Error Quadrics to compute the closest point to a set of planes!
We can represent a plane by
data:image/s3,"s3://crabby-images/f9cf7/f9cf70c28b0edbd58fb90f6c9cda7846b6fec649" alt=""
ifdata:image/s3,"s3://crabby-images/8f313/8f313581343b9de01cfa1f5900a46dde0584172e" alt=""
and a point by
data:image/s3,"s3://crabby-images/6e8ed/6e8ed00bfecc648b6ecead9f538604956f2e64ba" alt=""
Then, the distance from
to the plane is given by
data:image/s3,"s3://crabby-images/a01ea/a01ea81c993ec59d7dafde03ddd486c89a5b627f" alt=""
Given a set of planes
, we want to find a point
which minimizes the squared distances to all planes:
data:image/s3,"s3://crabby-images/bec60/bec60e8c5f8ec04a945290845f3b5e9b0b3da53e" alt=""
data:image/s3,"s3://crabby-images/cac7a/cac7a6140034da489e92c588ab30b99f0c5d4538" alt=""
data:image/s3,"s3://crabby-images/e1fcb/e1fcbbe6ba669804afe956c2114484023770dc44" alt=""
data:image/s3,"s3://crabby-images/2be6d/2be6d91f6399e9b24d47787de886e0773d8e16c1" alt=""
data:image/s3,"s3://crabby-images/507e9/507e9532b5aedd5916a122f5aebbdffee6f561e5" alt=""
The matrices
are called fundamental error quadrics and are computed as
data:image/s3,"s3://crabby-images/54183/541834aa97b405815bf6a63bdd1d8f14d075923c" alt=""
From this definition, we see that the error quadrics of two sets of planes
,
can simply be merged into one error quadric by adding them:
data:image/s3,"s3://crabby-images/cbc31/cbc3163305bd47dfe9be9746a0b7fe1a993ec506" alt=""
Solution Approach 1
In order to find a minimum solution for
, we can find the eigenvector to the smallest eigenvalue of
.
Solution Approach 2
data:image/s3,"s3://crabby-images/d2345/d234565f8f7307e13fe35e242783320fa27348ee" alt=""
By computing
data:image/s3,"s3://crabby-images/89790/8979061bbdf446c80842edffdcc4d65c16069367" alt=""
we obtain the linear system
data:image/s3,"s3://crabby-images/8ab79/8ab798a8e0d6cc487854205327fbbc9120aaac2d" alt=""
data:image/s3,"s3://crabby-images/1cad0/1cad0e3eaa95b4d33c234b425cb4aa8f2f899def" alt=""
Which is easier to solve than computing the eigenvectors and eigenvalues of
.
data:image/s3,"s3://crabby-images/f9cf7/f9cf70c28b0edbd58fb90f6c9cda7846b6fec649" alt=""
if
data:image/s3,"s3://crabby-images/8f313/8f313581343b9de01cfa1f5900a46dde0584172e" alt=""
and a point by
data:image/s3,"s3://crabby-images/6e8ed/6e8ed00bfecc648b6ecead9f538604956f2e64ba" alt=""
Then, the distance from
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/a01ea/a01ea81c993ec59d7dafde03ddd486c89a5b627f" alt=""
Given a set of planes
data:image/s3,"s3://crabby-images/94310/943100a330aaff95e74b2e4b21f8f28c07b13ffe" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/bec60/bec60e8c5f8ec04a945290845f3b5e9b0b3da53e" alt=""
data:image/s3,"s3://crabby-images/cac7a/cac7a6140034da489e92c588ab30b99f0c5d4538" alt=""
data:image/s3,"s3://crabby-images/e1fcb/e1fcbbe6ba669804afe956c2114484023770dc44" alt=""
data:image/s3,"s3://crabby-images/2be6d/2be6d91f6399e9b24d47787de886e0773d8e16c1" alt=""
data:image/s3,"s3://crabby-images/507e9/507e9532b5aedd5916a122f5aebbdffee6f561e5" alt=""
The matrices
data:image/s3,"s3://crabby-images/546e4/546e408f7bfdf58d22c62289cf1c53764542c650" alt=""
data:image/s3,"s3://crabby-images/54183/541834aa97b405815bf6a63bdd1d8f14d075923c" alt=""
From this definition, we see that the error quadrics of two sets of planes
data:image/s3,"s3://crabby-images/3e3fc/3e3fc2c54cfa39788a7e57b03f3384b7b6cb5f9e" alt=""
data:image/s3,"s3://crabby-images/e696c/e696c5c8d4f29471c26c458a7f8dd71011152918" alt=""
data:image/s3,"s3://crabby-images/cbc31/cbc3163305bd47dfe9be9746a0b7fe1a993ec506" alt=""
Solution Approach 1
In order to find a minimum solution for
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
Solution Approach 2
data:image/s3,"s3://crabby-images/d2345/d234565f8f7307e13fe35e242783320fa27348ee" alt=""
By computing
data:image/s3,"s3://crabby-images/89790/8979061bbdf446c80842edffdcc4d65c16069367" alt=""
we obtain the linear system
data:image/s3,"s3://crabby-images/8ab79/8ab798a8e0d6cc487854205327fbbc9120aaac2d" alt=""
data:image/s3,"s3://crabby-images/1cad0/1cad0e3eaa95b4d33c234b425cb4aa8f2f899def" alt=""
Which is easier to solve than computing the eigenvectors and eigenvalues of
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
Explain Mesh Decimation using Vertex Clustering! What are the advantages / disadvantages of the method? How can Vertex Clustering be implemented out-of-core?
Idea
1. Impose a voxel grid on the input mesh.
2. For each cell containing vertices, compute a cell representative.
3. Create a new mesh which only has cell representatives as vertices. Three cell representatives are connected with a triangle if there was a triangle in the original mesh wich had one vertex in each of the three cells.
Quality Control
The approximation error is bounded by the voxel resolution
: Vertices are shifted by at most
.
Cell Representative
Advantages
Out-of-core implementation possible
Works on arbitrary geometry (no manifold required)
Disadvantages
Output mesh not guaranteed to be manifold
Loss of detail due to uniform sampling
Out-Of-Core Implementation
Required storage: One error quadric for every cell. Connectivity information (list of cells which need to be connected).
Processing: Read one triangle at a time. If the vertices fall into three different cells, keep a record on the connectivity list. Add the fundamental error quadric of the triangle to the cells of the vertices. After all triangles have been read, compute cell representatives and connect them.
1. Impose a voxel grid on the input mesh.
2. For each cell containing vertices, compute a cell representative.
3. Create a new mesh which only has cell representatives as vertices. Three cell representatives are connected with a triangle if there was a triangle in the original mesh wich had one vertex in each of the three cells.
Quality Control
The approximation error is bounded by the voxel resolution
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
data:image/s3,"s3://crabby-images/f0908/f09087679b2e3dafde863c213de37ab996036c4c" alt=""
Cell Representative
- Cell Center: Requires no computation but leads to bad approximation error and produces stair artifacts.
- Center of Gravity: Slightly better approximation. Introduces low-pass filter.
- Median: i.e. closest point to center of gravity. Less pronounced low pass.
- Error Quadric: Find least-squares closest point to all triangle planes in the cell. Produces best sampling of sharp features.
Advantages
Out-of-core implementation possible
Works on arbitrary geometry (no manifold required)
Disadvantages
Output mesh not guaranteed to be manifold
Loss of detail due to uniform sampling
Out-Of-Core Implementation
Required storage: One error quadric for every cell. Connectivity information (list of cells which need to be connected).
Processing: Read one triangle at a time. If the vertices fall into three different cells, keep a record on the connectivity list. Add the fundamental error quadric of the triangle to the cells of the vertices. After all triangles have been read, compute cell representatives and connect them.
How are rotations represented by quaternions?
Quaternions are hypercomplex numbers
data:image/s3,"s3://crabby-images/1b59d/1b59d4774aa52c095ef43bf11f0d1ab52e463aeb" alt=""
where
data:image/s3,"s3://crabby-images/01255/012555c5cf1f3bdffdc311770cdfcabd5e3529ef" alt=""
We define the conjugate
data:image/s3,"s3://crabby-images/1be0c/1be0c765f209fec29236992cbd1bea24868ecf8e" alt=""
the dot product
data:image/s3,"s3://crabby-images/0b46f/0b46f7e37e2c84d90d658a3dda50bfb4df205855" alt=""
and the norm
data:image/s3,"s3://crabby-images/b7c4c/b7c4cda4e64f3e65a42a4107571be252ee50a3d0" alt=""
By associating quaternions with vectors in
, the product of two quaternions
,
can be written as a matrix-vector product
data:image/s3,"s3://crabby-images/e2eb5/e2eb5e485e21e5a6cf538a44cfef043ef97c422c" alt=""
data:image/s3,"s3://crabby-images/9b040/9b0406517745b7aae4352e0de718cea89d2506a4" alt=""
From the structure of these matrices, we can show the dot product equivalence
data:image/s3,"s3://crabby-images/646ac/646ac412c12b951214c3284694058eae81ce0234" alt=""
data:image/s3,"s3://crabby-images/0783f/0783f1b86c8055fcbaa8a79c87ff3fe6d52f7808" alt=""
data:image/s3,"s3://crabby-images/4db50/4db50f9f1c875b32e0b1c020eaa568d538bb3497" alt=""
data:image/s3,"s3://crabby-images/ab620/ab620337b072385797a605842376346fd6335892" alt=""
data:image/s3,"s3://crabby-images/992ad/992ad1c8de7cdf3b5a4655800220d2aec17552f0" alt=""
We can embed points
into
as follows:
data:image/s3,"s3://crabby-images/1937d/1937dbefbf696dc09ebcc74ab4643bdb77734035" alt=""
It can be shown that unit quaternions represent rotations. In particular, given a rotation axis
where
and an angle
, we can construct
data:image/s3,"s3://crabby-images/8fcf2/8fcf24a0a2951a52f8b7d51e378df935e9915042" alt=""
Then, this rotation can be computed as
data:image/s3,"s3://crabby-images/7e57e/7e57ef13c72adcc10b2557624a035972a09f416f" alt=""
data:image/s3,"s3://crabby-images/80b55/80b55daf81798858c10724609430e32d8871b20d" alt=""
Note that
and
represent the same rotation since both the rotation axis as the magnitude are inverted.
It turns out that
data:image/s3,"s3://crabby-images/a3117/a311796285024f5357b11c7ba853f4b9cbd27d7d" alt=""
data:image/s3,"s3://crabby-images/1b59d/1b59d4774aa52c095ef43bf11f0d1ab52e463aeb" alt=""
where
data:image/s3,"s3://crabby-images/01255/012555c5cf1f3bdffdc311770cdfcabd5e3529ef" alt=""
We define the conjugate
data:image/s3,"s3://crabby-images/1be0c/1be0c765f209fec29236992cbd1bea24868ecf8e" alt=""
the dot product
data:image/s3,"s3://crabby-images/0b46f/0b46f7e37e2c84d90d658a3dda50bfb4df205855" alt=""
and the norm
data:image/s3,"s3://crabby-images/b7c4c/b7c4cda4e64f3e65a42a4107571be252ee50a3d0" alt=""
By associating quaternions with vectors in
data:image/s3,"s3://crabby-images/f11f9/f11f9b1284fca4a338fb98ab0345d35d3f16c6ef" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
data:image/s3,"s3://crabby-images/e2eb5/e2eb5e485e21e5a6cf538a44cfef043ef97c422c" alt=""
data:image/s3,"s3://crabby-images/9b040/9b0406517745b7aae4352e0de718cea89d2506a4" alt=""
From the structure of these matrices, we can show the dot product equivalence
data:image/s3,"s3://crabby-images/646ac/646ac412c12b951214c3284694058eae81ce0234" alt=""
data:image/s3,"s3://crabby-images/0783f/0783f1b86c8055fcbaa8a79c87ff3fe6d52f7808" alt=""
data:image/s3,"s3://crabby-images/4db50/4db50f9f1c875b32e0b1c020eaa568d538bb3497" alt=""
data:image/s3,"s3://crabby-images/ab620/ab620337b072385797a605842376346fd6335892" alt=""
data:image/s3,"s3://crabby-images/992ad/992ad1c8de7cdf3b5a4655800220d2aec17552f0" alt=""
We can embed points
data:image/s3,"s3://crabby-images/b7e7b/b7e7b71cc1b60e0d299b3788deeae16495074ae3" alt=""
data:image/s3,"s3://crabby-images/5b73e/5b73e869bf2778e9af64c78da75ec4497590ef5c" alt=""
data:image/s3,"s3://crabby-images/1937d/1937dbefbf696dc09ebcc74ab4643bdb77734035" alt=""
It can be shown that unit quaternions represent rotations. In particular, given a rotation axis
data:image/s3,"s3://crabby-images/2fb5d/2fb5df6b99e40c7331b4cc146c404e7b1fad94ad" alt=""
data:image/s3,"s3://crabby-images/87a11/87a1195fe989948348fcf81aa66412469a0f3bd0" alt=""
data:image/s3,"s3://crabby-images/597b6/597b6e48cfb58085fdf7428752d2f6a91198bce0" alt=""
data:image/s3,"s3://crabby-images/8fcf2/8fcf24a0a2951a52f8b7d51e378df935e9915042" alt=""
Then, this rotation can be computed as
data:image/s3,"s3://crabby-images/7e57e/7e57ef13c72adcc10b2557624a035972a09f416f" alt=""
data:image/s3,"s3://crabby-images/80b55/80b55daf81798858c10724609430e32d8871b20d" alt=""
Note that
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/c5fe7/c5fe7c3b9e9b02359a9282067cf27e87f6887034" alt=""
It turns out that
data:image/s3,"s3://crabby-images/a3117/a311796285024f5357b11c7ba853f4b9cbd27d7d" alt=""
How to register two patches obtained by a laser scanner using the Iterative Closest Point algorithm?
Assumption: Scanned patches have identical scale.
Goal: Find a rigid transformation (rotation and translation) for one of the patches to align it with the other.
Algorithm Overview
1. Initial alignment: Provided by the user
2. Matching: Find corresponding points in the two patches
3. Registration: Compute optimal translation and rotation
4. Repeat from step 2 until convergence.
Matching
Matching Strategy: Nearest Neighbor
For every vertex
in patch
, select the nearest neighbor vertex
from patch
.
Filtering: Remove those matchings where one vertex is a boundary vertex (since boundary vertices match to many points). Remove matchings with a high distance. Remove matchings with a high normal deviation.
Matching Strategy: Normal Piercing
From each vertex
in patch
, shoot a ray into normal direction. If this ray intersects with
in point
, add the correspondence
.
Registration
Given a list of corresponding verticesdata:image/s3,"s3://crabby-images/f7cfd/f7cfd5123c1116492b906a6ffda569dee0520c95" alt=""
we want to find a transformation
such that
data:image/s3,"s3://crabby-images/04c1b/04c1b38f782d0b0cd17b5d8838dc849bfd7e3d1f" alt=""
Finding the translational part
just amounts to shifting the center of gravity of the
into that of the
by adding an offset
data:image/s3,"s3://crabby-images/432dc/432dc213be19ad9ef93da62ab6a7d6d7fbe59c77" alt=""
data:image/s3,"s3://crabby-images/df16d/df16d5953576da6803fa7640739c477786d35fe5" alt=""
We just assume this translational registration has already taken place and just focus on the rotational alignment:
data:image/s3,"s3://crabby-images/67a55/67a550c918693b2c31d4c427908357e41fabb3a1" alt=""
data:image/s3,"s3://crabby-images/133ab/133ab37591e455b853d2b59f833d3b732af0bed3" alt=""
data:image/s3,"s3://crabby-images/b5d1b/b5d1b1221cb250baf6c14624365aeb5afb25c304" alt=""
The first and last term are independent ofdata:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/76f4b/76f4b7e581e9014fae8f0c98246b4c62c04f3c51" alt=""
data:image/s3,"s3://crabby-images/0604b/0604b3d5b3c46bb820861eacb538c74d7c32803c" alt=""
Problem: Finding a solution for the rotation matrix
requires finding 9 unknowns (of which 6 need to be constrained). Solution: Formulate the rotation as a quaternion (gives 4 unknowns with 1 additional constraint).
data:image/s3,"s3://crabby-images/ac5aa/ac5aa14f60209347c0e3574a4ca2543a427f6820" alt=""
data:image/s3,"s3://crabby-images/21efb/21efb0eb9abe2203396a18558c1bfa95326c87bb" alt=""
data:image/s3,"s3://crabby-images/bf545/bf54547ca1fc8ee3c64ccbc38f74054265304cd6" alt=""
data:image/s3,"s3://crabby-images/41f60/41f60d3ababcf8a1026756084a6abd4d68819ce6" alt=""
data:image/s3,"s3://crabby-images/187eb/187eb31c522dc0bf7547d93f1c96576bf42d5513" alt=""
data:image/s3,"s3://crabby-images/01e6f/01e6f517000120d085f8ede79ba4d1bd22ad6c06" alt=""
data:image/s3,"s3://crabby-images/03576/035762aaeb8dce18ad60ab05891a56c01557aadd" alt=""
is a symmetric matrix. To compute a solution for
, find the eigenvector to the largest eigenvalue. Normalize to obtain a rotation.
Goal: Find a rigid transformation (rotation and translation) for one of the patches to align it with the other.
Algorithm Overview
1. Initial alignment: Provided by the user
2. Matching: Find corresponding points in the two patches
3. Registration: Compute optimal translation and rotation
4. Repeat from step 2 until convergence.
Matching
Matching Strategy: Nearest Neighbor
For every vertex
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Filtering: Remove those matchings where one vertex is a boundary vertex (since boundary vertices match to many points). Remove matchings with a high distance. Remove matchings with a high normal deviation.
Matching Strategy: Normal Piercing
From each vertex
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
data:image/s3,"s3://crabby-images/906d0/906d09f5a3dcaac6ff74229b5fa84afa28259e37" alt=""
data:image/s3,"s3://crabby-images/45fdd/45fddaf0ed742478761dee70fe217257a753e8de" alt=""
Registration
Given a list of corresponding vertices
data:image/s3,"s3://crabby-images/f7cfd/f7cfd5123c1116492b906a6ffda569dee0520c95" alt=""
we want to find a transformation
data:image/s3,"s3://crabby-images/637aa/637aa2d12553a7b5899774b69524fc6ea3bed19b" alt=""
data:image/s3,"s3://crabby-images/04c1b/04c1b38f782d0b0cd17b5d8838dc849bfd7e3d1f" alt=""
Finding the translational part
data:image/s3,"s3://crabby-images/73b06/73b069566e78787071567fe04a6130b3e83ece68" alt=""
data:image/s3,"s3://crabby-images/fee80/fee801556efc62e71e539cf587130e6ad8563e7d" alt=""
data:image/s3,"s3://crabby-images/6f91a/6f91ae734d472f0c68f2ba46e8ef4e5b56691b92" alt=""
data:image/s3,"s3://crabby-images/432dc/432dc213be19ad9ef93da62ab6a7d6d7fbe59c77" alt=""
data:image/s3,"s3://crabby-images/df16d/df16d5953576da6803fa7640739c477786d35fe5" alt=""
We just assume this translational registration has already taken place and just focus on the rotational alignment:
data:image/s3,"s3://crabby-images/67a55/67a550c918693b2c31d4c427908357e41fabb3a1" alt=""
data:image/s3,"s3://crabby-images/133ab/133ab37591e455b853d2b59f833d3b732af0bed3" alt=""
data:image/s3,"s3://crabby-images/b5d1b/b5d1b1221cb250baf6c14624365aeb5afb25c304" alt=""
The first and last term are independent of
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/76f4b/76f4b7e581e9014fae8f0c98246b4c62c04f3c51" alt=""
data:image/s3,"s3://crabby-images/0604b/0604b3d5b3c46bb820861eacb538c74d7c32803c" alt=""
Problem: Finding a solution for the rotation matrix
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/ac5aa/ac5aa14f60209347c0e3574a4ca2543a427f6820" alt=""
data:image/s3,"s3://crabby-images/21efb/21efb0eb9abe2203396a18558c1bfa95326c87bb" alt=""
data:image/s3,"s3://crabby-images/bf545/bf54547ca1fc8ee3c64ccbc38f74054265304cd6" alt=""
data:image/s3,"s3://crabby-images/41f60/41f60d3ababcf8a1026756084a6abd4d68819ce6" alt=""
data:image/s3,"s3://crabby-images/187eb/187eb31c522dc0bf7547d93f1c96576bf42d5513" alt=""
data:image/s3,"s3://crabby-images/01e6f/01e6f517000120d085f8ede79ba4d1bd22ad6c06" alt=""
data:image/s3,"s3://crabby-images/03576/035762aaeb8dce18ad60ab05891a56c01557aadd" alt=""
data:image/s3,"s3://crabby-images/42838/42838fe78f291bc228f49733c8cc63dc2feca84f" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
After two mesh patches have been registered (e.g. using ICP), how are they integrated? Explain the two main approaches!
Given: Two aligned patches
and
with some overlap.
Zippering
Remove overlap: Shoot rays from vertices of
in normal direction. Remove triangles of
which are hit. Then, do the same thing the other way around.
Merge: Walk along the two new patch boundaries and insert triangles to connect them.
Problem: This approach throws away a significant amount of detail information near the overlap region.
Stitching
Move the boundary vertices of patch
along their normals so they lie on
.
Insert boundary vertices of patch
into
by splitting triangles.
Insert the boundary edges of patch
into
by splitting edges.
Remove the overlapping part of patch
.
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Zippering
Remove overlap: Shoot rays from vertices of
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Merge: Walk along the two new patch boundaries and insert triangles to connect them.
Problem: This approach throws away a significant amount of detail information near the overlap region.
Stitching
Move the boundary vertices of patch
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Insert boundary vertices of patch
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Insert the boundary edges of patch
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Remove the overlapping part of patch
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Name two approaches for Mesh Repair! What are their advantages and disadvantages?
Volumetric Mesh Repair | Surface-Based Mesh Repair |
resulting mesh is guaranteed to be watertight and manifold | no guarantee on output quality |
voxelization: may suffer from aliasing / sampling artifacts or loss of precision | structure-preserving: only modifies input mesh where necessary |
Explain Volumetric Mesh Repair!
Input: "Triangle Soup"
: Collection of surface parts which may contain gaps, intersections or other problems
Output: Watertight two-manifold meshdata:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
Parameters:
: approximation tolerance
: maximum hole / gap size
Requirements:
data:image/s3,"s3://crabby-images/70496/704968bef4c4411003d8e3c923715821e230997a" alt=""
"every point on the original mesh has a distance of at most
to a point on the reconstructed mesh"
also:
but only if the closest point on
is not a boundary point
data:image/s3,"s3://crabby-images/416e0/416e02d26f04a6f5a40bc78730cd4abf57751ccd" alt=""
"every point on the reconstructed mesh has a distance of at most
to a point on the original mesh"
Algorithm
Insert all mesh faces into a voxel grid.
Grow
-blobs from all boundary edges.
Flood fill the exterior.
Erode the
-blobs from outside.
Reconstruct the mesh using Marching Cubes.
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
Output: Watertight two-manifold mesh
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
Parameters:
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
data:image/s3,"s3://crabby-images/e732c/e732cc1ae1bd48a1def1ed46773269df48b3774a" alt=""
Requirements:
data:image/s3,"s3://crabby-images/70496/704968bef4c4411003d8e3c923715821e230997a" alt=""
"every point on the original mesh has a distance of at most
data:image/s3,"s3://crabby-images/fb90e/fb90e85aa4dd7320110deff1a87600e03df23bca" alt=""
also:
data:image/s3,"s3://crabby-images/42022/420227b7533abea900e5a227f5a78e4fdc8d2047" alt=""
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
data:image/s3,"s3://crabby-images/416e0/416e02d26f04a6f5a40bc78730cd4abf57751ccd" alt=""
"every point on the reconstructed mesh has a distance of at most
data:image/s3,"s3://crabby-images/e732c/e732cc1ae1bd48a1def1ed46773269df48b3774a" alt=""
Algorithm
Insert all mesh faces into a voxel grid.
Grow
data:image/s3,"s3://crabby-images/e732c/e732cc1ae1bd48a1def1ed46773269df48b3774a" alt=""
Flood fill the exterior.
Erode the
data:image/s3,"s3://crabby-images/e732c/e732cc1ae1bd48a1def1ed46773269df48b3774a" alt=""
Reconstruct the mesh using Marching Cubes.
Explain Surface-Based Hole Filling! What are some problems of this approach?
Input: Boundary loop consisting of vertices
.
Goal: Triangulation
of the loop interior which minimizes some triangulation cost
which is a combination of e.g.
which produces a hole filling with low area and low normal deviation.
We denote by
the cost of the best triangulation for only the vertices
.
Obviously:
data:image/s3,"s3://crabby-images/04e25/04e250fec3c8b9636d27f1fc1d2e4f8ded2ba074" alt=""
data:image/s3,"s3://crabby-images/7afc3/7afc336ab63b9b8d2765bc45b40630f229ec95d3" alt=""
data:image/s3,"s3://crabby-images/663d6/663d60300cb5851231515d053d24a8bc3b7c1b52" alt=""
Solve using dynamic programming.
Complexity:
(Compute table for
and
. For every entry, consider
possible middle triangles)
Optional post-processing steps
Refine the triangulation of the hole.
Apply smoothing to the hole region.
Problems
Does not work for islands.
Does not consider self-intersections.
data:image/s3,"s3://crabby-images/318eb/318ebb49faa98426487d9ced46cbe8c5985e988c" alt=""
Goal: Triangulation
data:image/s3,"s3://crabby-images/73b06/73b069566e78787071567fe04a6130b3e83ece68" alt=""
data:image/s3,"s3://crabby-images/42600/42600efc8a2faad5d3c2795ed6b2249112b85d27" alt=""
- the area of the triangles
- the maximum dihedral angle
which produces a hole filling with low area and low normal deviation.
We denote by
data:image/s3,"s3://crabby-images/ebc0d/ebc0daa2e8f6f97e0a3ce6e75504ce6e95ed2588" alt=""
data:image/s3,"s3://crabby-images/5cc33/5cc3355ec9015ad10bed60a04f0bbe9da807ec31" alt=""
Obviously:
data:image/s3,"s3://crabby-images/04e25/04e250fec3c8b9636d27f1fc1d2e4f8ded2ba074" alt=""
data:image/s3,"s3://crabby-images/7afc3/7afc336ab63b9b8d2765bc45b40630f229ec95d3" alt=""
data:image/s3,"s3://crabby-images/663d6/663d60300cb5851231515d053d24a8bc3b7c1b52" alt=""
Solve using dynamic programming.
Complexity:
data:image/s3,"s3://crabby-images/36c8b/36c8bdbb8f518b55dc6a127a7118b9e5e150131f" alt=""
data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
data:image/s3,"s3://crabby-images/27184/2718409627f4ec0c7fd8721616986f099a0c7886" alt=""
data:image/s3,"s3://crabby-images/2e60a/2e60a079a96880701d850911ec86480666a603cb" alt=""
Optional post-processing steps
Refine the triangulation of the hole.
Apply smoothing to the hole region.
Problems
Does not work for islands.
Does not consider self-intersections.
Explain Poisson reconstruction in the context of mesh generation!
We assume an underlying characteristic function
that represents the object
data:image/s3,"s3://crabby-images/4cb49/4cb49fbf90326f902437f8c5a5189518bbf5dae4" alt=""
By convoluting
with a smoothing kernel
, we obtained a blurred version
data:image/s3,"s3://crabby-images/5a1a0/5a1a008800bc39ba76d078b0d01fa1f4bf8165b9" alt=""
of which the gradient
coincides with the normals of the object we want to reconstruct.
Given points with estimated normals
, we can thus state that
data:image/s3,"s3://crabby-images/71004/71004a8ed02d7887ebc1f085d5bde0db2ad742f2" alt=""
data:image/s3,"s3://crabby-images/45fba/45fba413811b6a584b3e4187ef29d8b12d1f62ad" alt=""
In order to solve for
, we turn the problem into a Poisson equation:
data:image/s3,"s3://crabby-images/45fba/45fba413811b6a584b3e4187ef29d8b12d1f62ad" alt=""
data:image/s3,"s3://crabby-images/c5d71/c5d71e78b727559803f231d0b921eddb5c203342" alt=""
Which can be discretized into a linear system by taking finite differences.
Non-oriented normals
If we only have normal directions
without consistent orientations, we can state that
should be parallel to the normal directions:
data:image/s3,"s3://crabby-images/970bd/970bdef2f2bcbe245cf13883e6927cf4c31ff14a" alt=""
data:image/s3,"s3://crabby-images/29c88/29c8809cedbf7eb733b702e819f713963eed8a38" alt=""
data:image/s3,"s3://crabby-images/29b9e/29b9eaa45324546c522bdb736eba64fe5ecc3312" alt=""
data:image/s3,"s3://crabby-images/66100/661006a7d33f3ca661114180868a2e049739040f" alt=""
With the additonal smoothness constraint:
data:image/s3,"s3://crabby-images/b735a/b735a442ec452cfa0674fcecfbeba7535f701204" alt=""
data:image/s3,"s3://crabby-images/4ceab/4ceab41964b3ba14ac4b2d8b1afd7812c4449fba" alt=""
data:image/s3,"s3://crabby-images/4cb49/4cb49fbf90326f902437f8c5a5189518bbf5dae4" alt=""
By convoluting
data:image/s3,"s3://crabby-images/edce8/edce8d8e811137e111c709d1814bfccdadff81fa" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/5a1a0/5a1a008800bc39ba76d078b0d01fa1f4bf8165b9" alt=""
of which the gradient
data:image/s3,"s3://crabby-images/218f3/218f3ec7f0d8b3edc12145f83b53586cf75b0c69" alt=""
Given points with estimated normals
data:image/s3,"s3://crabby-images/6d7b9/6d7b92e8dd35f67c327b264792e74aeca035b81c" alt=""
data:image/s3,"s3://crabby-images/71004/71004a8ed02d7887ebc1f085d5bde0db2ad742f2" alt=""
data:image/s3,"s3://crabby-images/45fba/45fba413811b6a584b3e4187ef29d8b12d1f62ad" alt=""
In order to solve for
data:image/s3,"s3://crabby-images/38204/38204581e7f8bef5a01bf96b10d76b87166eb641" alt=""
data:image/s3,"s3://crabby-images/45fba/45fba413811b6a584b3e4187ef29d8b12d1f62ad" alt=""
data:image/s3,"s3://crabby-images/c5d71/c5d71e78b727559803f231d0b921eddb5c203342" alt=""
Which can be discretized into a linear system by taking finite differences.
Non-oriented normals
If we only have normal directions
data:image/s3,"s3://crabby-images/725ae/725ae61656d2ebf2b2f658fac258a08a0dc61de2" alt=""
data:image/s3,"s3://crabby-images/325f9/325f94067ebce8edfc75d2f56005151c446bee00" alt=""
data:image/s3,"s3://crabby-images/970bd/970bdef2f2bcbe245cf13883e6927cf4c31ff14a" alt=""
data:image/s3,"s3://crabby-images/29c88/29c8809cedbf7eb733b702e819f713963eed8a38" alt=""
data:image/s3,"s3://crabby-images/29b9e/29b9eaa45324546c522bdb736eba64fe5ecc3312" alt=""
data:image/s3,"s3://crabby-images/66100/661006a7d33f3ca661114180868a2e049739040f" alt=""
With the additonal smoothness constraint:
data:image/s3,"s3://crabby-images/b735a/b735a442ec452cfa0674fcecfbeba7535f701204" alt=""
How can graph cuts be applied for volumetric mesh generation?
Compute an unsigned distance field, e.g. by computing for each voxel the minimum / average / weighted distance to points from the input point cloud.
Create a graph from the voxel grid and propagate the voxel values to the edge weights.
Choose one point in the interior of the object as a source and the boundaries of the voxel grid as the sink. Compute a minimum weight graph cut.
Extract all faces of voxels through which edges of the cut graph pass through.
Create a graph from the voxel grid and propagate the voxel values to the edge weights.
Choose one point in the interior of the object as a source and the boundaries of the voxel grid as the sink. Compute a minimum weight graph cut.
Extract all faces of voxels through which edges of the cut graph pass through.
How to determine the position of a point using laser triangulation? What is the problem of this approach?
Provided we know the following information:
: Distance between camera and laser
: At the camera: Angle between direction to laser and direction to laser point
: At the laser: Angle between direction to camera and direction to laser point
We want to know:
: The distance from the camera to the laser point
Camera, laser and laser point form a triangle with inner angles
,
and
data:image/s3,"s3://crabby-images/8a6f4/8a6f4653869f8130af29a317ec60832f51062879" alt=""
We use the sine theorem which relates the length of triangle edges with their opposite angles:
data:image/s3,"s3://crabby-images/3dd38/3dd383593c04e68fc57e222c56d067fcec5450f2" alt=""
data:image/s3,"s3://crabby-images/1a1c5/1a1c5d526f6e06113693efa5e8753c46f7f82564" alt=""
data:image/s3,"s3://crabby-images/5c0cd/5c0cddd7ea8555b86a1eee7dfc9a7b34e517ea3f" alt=""
Problem
When the laser point is far away,
becomes close to
. Thus,
becomes close to 0 and the computation becomes unstable.
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
We want to know:
data:image/s3,"s3://crabby-images/e0b2a/e0b2ac5624daf6efbd18a59caf1e3a6900a080ae" alt=""
Camera, laser and laser point form a triangle with inner angles
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
data:image/s3,"s3://crabby-images/8a6f4/8a6f4653869f8130af29a317ec60832f51062879" alt=""
We use the sine theorem which relates the length of triangle edges with their opposite angles:
data:image/s3,"s3://crabby-images/3dd38/3dd383593c04e68fc57e222c56d067fcec5450f2" alt=""
data:image/s3,"s3://crabby-images/1a1c5/1a1c5d526f6e06113693efa5e8753c46f7f82564" alt=""
data:image/s3,"s3://crabby-images/5c0cd/5c0cddd7ea8555b86a1eee7dfc9a7b34e517ea3f" alt=""
Problem
When the laser point is far away,
data:image/s3,"s3://crabby-images/16886/1688650b851b2e96b6cbb3cd6a06d7f8463254de" alt=""
data:image/s3,"s3://crabby-images/1d967/1d9679f265a4baccfb12b6b8d470582f3ef22e21" alt=""
data:image/s3,"s3://crabby-images/f5793/f5793f781201b402b456cd9bce1ece1fb55be672" alt=""
Explain the Incremental Delaunay algorithm!
Start with one triangle that is large enough to contain all input points.
Invariant: The current triangulation is Delaunay.
Repeat: Pick next input vertex. Find triangle into which input vertex falls and split into three new triangles (1:3 split). Now, the newly inserted triangles might have lost their Delaunay property. Mark the edges of the triangle into which the current vertex was inserted.
For each marked edge, check the local Delaunay properties of the two incident triangles. If it is violated, flip the edge and mark the edges around the current quad configuration.
Complexity
We examine
points: data:image/s3,"s3://crabby-images/09e6a/09e6a6aaadbc5e4d3e506824a790cc60641e2869" alt=""
For each point, we find in which triangle it falls. Using a search tree:data:image/s3,"s3://crabby-images/c2a98/c2a98a269d2d49c778a542986cc5512407637cf9" alt=""
After each insertion, we flip some edges. It can be shown, that the number of flipped edges per insertion is constant on average:data:image/s3,"s3://crabby-images/2438a/2438aa84ec1f11b6d16b9fb5d5126eba490890c6" alt=""
Thus, the Incremental Delaunay algorithm has a complexity of
.
Invariant: The current triangulation is Delaunay.
Repeat: Pick next input vertex. Find triangle into which input vertex falls and split into three new triangles (1:3 split). Now, the newly inserted triangles might have lost their Delaunay property. Mark the edges of the triangle into which the current vertex was inserted.
For each marked edge, check the local Delaunay properties of the two incident triangles. If it is violated, flip the edge and mark the edges around the current quad configuration.
Complexity
We examine
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/09e6a/09e6a6aaadbc5e4d3e506824a790cc60641e2869" alt=""
For each point, we find in which triangle it falls. Using a search tree:
data:image/s3,"s3://crabby-images/c2a98/c2a98a269d2d49c778a542986cc5512407637cf9" alt=""
After each insertion, we flip some edges. It can be shown, that the number of flipped edges per insertion is constant on average:
data:image/s3,"s3://crabby-images/2438a/2438aa84ec1f11b6d16b9fb5d5126eba490890c6" alt=""
Thus, the Incremental Delaunay algorithm has a complexity of
data:image/s3,"s3://crabby-images/0853e/0853eace9364470e73f684c4ee16a620dc4d8b28" alt=""
Explain the Sweepline algorithm / Fortune's algorithm for generating Voronoi diagrams! How can we directly generate a Delaunay triangulation?
Algorithm idea: Voronoi diagram is equivalent to the highest points of a set of cones centered on the sites. By sweeping a
inclined plane through the set of cones, all points where at least 3 cones intersect (i.e., the Voronoi vertices) are enumerated.
The algorithm maintains:
Site event
Occurs when the sweep line crosses a site. This causes a new arc (of initially zero width) to be inserted at the position of the site. Find into which arc segment the new site falls. Split the arc segment. Insert new arc segment in between. Now, generate upcoming circle events: Consider the neighboring arc triples containing the new arc. If these triples have distinct sites, create a new circle event by computing the circumcircle of the three sites and insert a circle event at the outermost edge of the circumcircle (but only if this point lies still before the sweep line).
If the arc which was split by the insertion had a pending circle event, this circle event is removed and new circle events are computed based on the new neighborhood of the affected arcs.
Circle event
When the sweep line leaves the circumcircle of three sites the inclined halfplane passes a point that is equidistant to the three sites. At this time, the center arc of the three sites shrinks to zero. Thus, the arc is removed from the arc list and a new Voronoi vertex is created.
Generating a Delaunay triangulation
At every circle event, three sites lie on an empty circumcircle. By connecting the three sites, we obtain a triangle with the Delaunay property.
data:image/s3,"s3://crabby-images/4af6d/4af6d73c18b23c7452436061ff119dba87b74628" alt=""
The algorithm maintains:
- List of all currently active arc segments, each associated with one site
- An event priority queue, containing the positions of the next upcoming site events and circle events
Site event
Occurs when the sweep line crosses a site. This causes a new arc (of initially zero width) to be inserted at the position of the site. Find into which arc segment the new site falls. Split the arc segment. Insert new arc segment in between. Now, generate upcoming circle events: Consider the neighboring arc triples containing the new arc. If these triples have distinct sites, create a new circle event by computing the circumcircle of the three sites and insert a circle event at the outermost edge of the circumcircle (but only if this point lies still before the sweep line).
If the arc which was split by the insertion had a pending circle event, this circle event is removed and new circle events are computed based on the new neighborhood of the affected arcs.
Circle event
When the sweep line leaves the circumcircle of three sites the inclined halfplane passes a point that is equidistant to the three sites. At this time, the center arc of the three sites shrinks to zero. Thus, the arc is removed from the arc list and a new Voronoi vertex is created.
Generating a Delaunay triangulation
At every circle event, three sites lie on an empty circumcircle. By connecting the three sites, we obtain a triangle with the Delaunay property.
Give definitions for the Medial Axis and Local Feature Size. What is an R-Sample?
Given a shape
, the distance of a point
to
is defined as
data:image/s3,"s3://crabby-images/0d3af/0d3afcfbe011ab91810e6a0d03ec8765a7dfc7ee" alt=""
The Medial Axis of
is the set of points to which multiple points have minimal distance:
data:image/s3,"s3://crabby-images/8c682/8c682d59acfb818140c6dd840468475e1b65bc7e" alt=""
The Local Feature Size of a point
on the shape
is its distance to the Medial Axis:
data:image/s3,"s3://crabby-images/2b097/2b0975d8cf5affd4040e65f991af4e6e7d029c40" alt=""
A set of sample points
is called an R-Sample if every point on the shape
is next to a sample point which is at most
times the local feature size away:
data:image/s3,"s3://crabby-images/dccfb/dccfbfee36657d703b219475aefdd7270c82ce81" alt=""
data:image/s3,"s3://crabby-images/692a2/692a2a3655c8549566f226a44fdf5af3606d5e18" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/0d3af/0d3afcfbe011ab91810e6a0d03ec8765a7dfc7ee" alt=""
The Medial Axis of
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/8c682/8c682d59acfb818140c6dd840468475e1b65bc7e" alt=""
The Local Feature Size of a point
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/2b097/2b0975d8cf5affd4040e65f991af4e6e7d029c40" alt=""
A set of sample points
data:image/s3,"s3://crabby-images/e8191/e819118a0cd3cb8f9e3e0dd5a582a28f3ab7dcec" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/6657e/6657eddd026405e219877b544a89e1b46a4f8b1f" alt=""
data:image/s3,"s3://crabby-images/dccfb/dccfbfee36657d703b219475aefdd7270c82ce81" alt=""
Name the two main approaches to extract the surface of a 3D object from a point cloud!
Contour Tessellation
Create a Delaunay tetrahedralization of the point cloud. Try to keep only those faces which correspond to the object surface (Voronoi Filtering)
Volumetric Approaches
Take points as samples of a volumetric representation of the mesh. Reconstruct the density function (weighted averaging, Poisson reconstruction) and extract an isosurface (Marching Cubes).
Create a Delaunay tetrahedralization of the point cloud. Try to keep only those faces which correspond to the object surface (Voronoi Filtering)
Volumetric Approaches
Take points as samples of a volumetric representation of the mesh. Reconstruct the density function (weighted averaging, Poisson reconstruction) and extract an isosurface (Marching Cubes).
Explain Contour Tessellation using Voronoi Filtering!
Given: Point cloud of an object. Goal: Triangulation of the surface.
In 2D: We observe that the medial axis of a shape cuts through its interior (or, more general, through concave regions). The idea is to let the medial axis cut away interior edges of the Delaunay triangulation of the shape.
Another observation: The vertices of the Voronoi diagram of the contour points approximate the medial axis.
Strategy: Compute Voronoi vertices and add them to the input vertices. Compute Delaunay triangulation. Remove Voronoi vertices.
In 3D: Problem: Some Voronoi vertices lie not only near the medial axis but also close to the contour. Thus, only keep those Voronoi vertices (called poles) which lie at the innermost or outermost tips of their respective cells.
For each cell, identify one pole vertex
as the farthest vertex from the cell center
. For
, choose the most distant vertex to
for which
.
Voronoi cells of convex hull points are infinitely large. In order to find
, average the normals of the convex hull triangles at
and use as
an outward projection along this normal.
Like in 2D, add the pole vertices to the input vertices. Tetrahedralize and remove pole vertices (and their incident edges and faces). Some additional cleanup is required to remove non-manifold configurations on the surface.
In 2D: We observe that the medial axis of a shape cuts through its interior (or, more general, through concave regions). The idea is to let the medial axis cut away interior edges of the Delaunay triangulation of the shape.
Another observation: The vertices of the Voronoi diagram of the contour points approximate the medial axis.
Strategy: Compute Voronoi vertices and add them to the input vertices. Compute Delaunay triangulation. Remove Voronoi vertices.
In 3D: Problem: Some Voronoi vertices lie not only near the medial axis but also close to the contour. Thus, only keep those Voronoi vertices (called poles) which lie at the innermost or outermost tips of their respective cells.
For each cell, identify one pole vertex
data:image/s3,"s3://crabby-images/13b0e/13b0e7ed1cc9ca2d99806536fe99f5026c7fc25e" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/11fb7/11fb7f9358a047ef799ff6964ef2dfedaf875e09" alt=""
data:image/s3,"s3://crabby-images/13b0e/13b0e7ed1cc9ca2d99806536fe99f5026c7fc25e" alt=""
data:image/s3,"s3://crabby-images/39531/395314225b9e896cfc476585fd64f49b38961e71" alt=""
Voronoi cells of convex hull points are infinitely large. In order to find
data:image/s3,"s3://crabby-images/13b0e/13b0e7ed1cc9ca2d99806536fe99f5026c7fc25e" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/13b0e/13b0e7ed1cc9ca2d99806536fe99f5026c7fc25e" alt=""
Like in 2D, add the pole vertices to the input vertices. Tetrahedralize and remove pole vertices (and their incident edges and faces). Some additional cleanup is required to remove non-manifold configurations on the surface.
Explain volumetric approaches for extracting a surface from a point cloud!
General idea:
Tangent Plane Estimation
Given a local cloud of points
, we want to find a least-squares regression plane
data:image/s3,"s3://crabby-images/37b17/37b170ed90df4b9e64add6b30fd91fad6c6a8e36" alt=""
or, for more points:
data:image/s3,"s3://crabby-images/c8c13/c8c1305a07fade7ac321bac85ac01a2423256e8f" alt=""
data:image/s3,"s3://crabby-images/42712/42712729848598e67cf983a2d9544d852830d49c" alt=""
For a least-squares solution, we compute
data:image/s3,"s3://crabby-images/89d26/89d26838e39270f09f2dedfe139c975e409480e4" alt=""
data:image/s3,"s3://crabby-images/c97ce/c97ce1f5ac06c4755aaaf6fa1b6a389c8d50d0f3" alt=""
data:image/s3,"s3://crabby-images/284e5/284e539e69596661a416b8b443d0ac765b3661ef" alt=""
with
data:image/s3,"s3://crabby-images/b75ae/b75aec9d3d9d9e69a60706c9eac326e1e4212078" alt=""
If we shift all points into the center of gravity, this becomes
data:image/s3,"s3://crabby-images/b918d/b918d715ebb7f31989e2cfd73fe1788fab56579c" alt=""
Since
is constant, we can focus on the upper left
block
of
.
Find:
data:image/s3,"s3://crabby-images/a3267/a32676a61fba2583002267882d4bc7d272042c6e" alt=""
such that
.
Find smallest eigenvalue of
. Scale corresponding eigenvector to
.
Consistent Normal Orientation
Construct minimal spanning tree between all points with an edge weight
data:image/s3,"s3://crabby-images/135b4/135b447daa586cc3b83b20d62cb315ab50aa916b" alt=""
where
controls how points are penalized for being further away from each other, and
controls how points are penalized for having non-parallel normal directions.
Start at one point where the normal direction is known, e.g. the point with the lowest
coordinate. From there, walk over the spanning tree and flip normals to make them consistent.
Signed Distance Field Estimation
Impose a voxel grid on the input points. For each grid vertex, estimate the value of a signed distance function for the object.
For every voxel, consider some neighboring samples and compute a weighted average of the distance of the voxel center
to the respective tangent planes:
data:image/s3,"s3://crabby-images/c835a/c835a7c0cfa992db208f56d0ced083438f42fa11" alt=""
Iso-Surface Extraction
Using Marching Cubes. Output is a watertight two-manifold mesh.
- Estimate tangent planes from point cloud
- Consistently orient normals
- Construct signed distance field from point / normal samples
- Extract iso-surface mesh
Tangent Plane Estimation
Given a local cloud of points
data:image/s3,"s3://crabby-images/07ba8/07ba8dfa603d097230ed1e2e469bdfee19251a4f" alt=""
data:image/s3,"s3://crabby-images/37b17/37b170ed90df4b9e64add6b30fd91fad6c6a8e36" alt=""
or, for more points:
data:image/s3,"s3://crabby-images/c8c13/c8c1305a07fade7ac321bac85ac01a2423256e8f" alt=""
data:image/s3,"s3://crabby-images/42712/42712729848598e67cf983a2d9544d852830d49c" alt=""
For a least-squares solution, we compute
data:image/s3,"s3://crabby-images/89d26/89d26838e39270f09f2dedfe139c975e409480e4" alt=""
data:image/s3,"s3://crabby-images/c97ce/c97ce1f5ac06c4755aaaf6fa1b6a389c8d50d0f3" alt=""
data:image/s3,"s3://crabby-images/284e5/284e539e69596661a416b8b443d0ac765b3661ef" alt=""
with
data:image/s3,"s3://crabby-images/b75ae/b75aec9d3d9d9e69a60706c9eac326e1e4212078" alt=""
If we shift all points into the center of gravity, this becomes
data:image/s3,"s3://crabby-images/b918d/b918d715ebb7f31989e2cfd73fe1788fab56579c" alt=""
Since
data:image/s3,"s3://crabby-images/b9903/b99032d10a48891bfc06721920c706cb818706cd" alt=""
data:image/s3,"s3://crabby-images/923c1/923c138996a5d254ba2549588868e04ceb9e5f80" alt=""
data:image/s3,"s3://crabby-images/c1fd5/c1fd559c12eff398ee5a67d7d302fe89670efe8a" alt=""
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
Find:
data:image/s3,"s3://crabby-images/a3267/a32676a61fba2583002267882d4bc7d272042c6e" alt=""
such that
data:image/s3,"s3://crabby-images/12bb1/12bb1db55848e1b98b584ed94498f200bcd5ed9b" alt=""
Find smallest eigenvalue of
data:image/s3,"s3://crabby-images/c1fd5/c1fd559c12eff398ee5a67d7d302fe89670efe8a" alt=""
data:image/s3,"s3://crabby-images/6b2a2/6b2a2540a5b9333bc7ba1898234e00c9d0f1fd4f" alt=""
Consistent Normal Orientation
Construct minimal spanning tree between all points with an edge weight
data:image/s3,"s3://crabby-images/135b4/135b447daa586cc3b83b20d62cb315ab50aa916b" alt=""
where
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
Start at one point where the normal direction is known, e.g. the point with the lowest
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
Signed Distance Field Estimation
Impose a voxel grid on the input points. For each grid vertex, estimate the value of a signed distance function for the object.
For every voxel, consider some neighboring samples and compute a weighted average of the distance of the voxel center
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/c835a/c835a7c0cfa992db208f56d0ced083438f42fa11" alt=""
Iso-Surface Extraction
Using Marching Cubes. Output is a watertight two-manifold mesh.
Explain parametrization using Least Squares Conformal Maps!
A parametrization is called conformal iff it is angle-preserving:
data:image/s3,"s3://crabby-images/3874a/3874a48dcace6c7c6119210c4fede77457d9a2ae" alt=""
is conformal iff data:image/s3,"s3://crabby-images/b8ccc/b8ccc6178e346b71a2c833561a664bd33a514e1a" alt=""
or
data:image/s3,"s3://crabby-images/d8e6c/d8e6cf06e439819e37d04f4dc7c5336caff224a0" alt=""
or
is orthogonal:
data:image/s3,"s3://crabby-images/d94e8/d94e865730e5f6f8c0180533bdf652ff78a0854e" alt=""
Furthermore, it
is conformal iff its inverse
is conformal.
conformal
conformal
orthogonal
orthogonal
data:image/s3,"s3://crabby-images/6077f/6077ff02942501ecdb17474bd851993ed5bc92f8" alt=""
Solve least squares problem
data:image/s3,"s3://crabby-images/fc9f9/fc9f9d47c8ed2f9a6f8104b320a1a8ec0b3cb706" alt=""
for parameters
. In order to get a unique solution, fix at least two points.
Computing Discrete Gradients
Computing
data:image/s3,"s3://crabby-images/a0bfb/a0bfbb95df1294dd597d326790d42da0f20bb9f1" alt=""
over a triangle given by corner vertices
data:image/s3,"s3://crabby-images/76dbb/76dbb3891b5a7a390ab2d795f4e8eb7bdc75139e" alt=""
and parameter values
.
For a point
inside the triangle, the interpolated value of
is
data:image/s3,"s3://crabby-images/c0131/c0131874aec48b0eb0fa10d12cf036069888a804" alt=""
data:image/s3,"s3://crabby-images/1c299/1c299cde52d1a7eec4f1ad0cd696be063902281b" alt=""
data:image/s3,"s3://crabby-images/53b97/53b9734dc120610a6a31095122d2b99585961ddc" alt=""
Geometrical derivation of
: Consider the triangle edge
. Along
,
does not change. Along the direction
,
changes most. The magnitude of the change is
, where
is the height of
on
. Thus,
data:image/s3,"s3://crabby-images/82d9b/82d9b6b0d8fe4375dd173d8c96f50f8dd9af0a9c" alt=""
We can compute the height
from the triangle area and base length:
data:image/s3,"s3://crabby-images/0c6e7/0c6e7756a7ec5953e97c8ab7448e4c090f58ef07" alt=""
data:image/s3,"s3://crabby-images/c3040/c304017fb688715535f461bbb0939f7edd70f390" alt=""
Plugging this result back in gives
data:image/s3,"s3://crabby-images/44b9e/44b9ec26d8732956b4e33d8a8618e35c0d9dbccf" alt=""
With this result, we get
data:image/s3,"s3://crabby-images/26250/2625068183e5dd5ed39a79f93f0f9b54c61ddfc6" alt=""
data:image/s3,"s3://crabby-images/c7506/c7506ed6c6c3e08b59b69f5acaa43f75dea82635" alt=""
data:image/s3,"s3://crabby-images/3874a/3874a48dcace6c7c6119210c4fede77457d9a2ae" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/b8ccc/b8ccc6178e346b71a2c833561a664bd33a514e1a" alt=""
or
data:image/s3,"s3://crabby-images/d8e6c/d8e6cf06e439819e37d04f4dc7c5336caff224a0" alt=""
or
data:image/s3,"s3://crabby-images/876c1/876c1d67744c7737bcc67d10021211f0cf1716b0" alt=""
data:image/s3,"s3://crabby-images/d94e8/d94e865730e5f6f8c0180533bdf652ff78a0854e" alt=""
Furthermore, it
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/30ea5/30ea52c67c3ec660f6e9dc84d8d672dea55ab18c" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/0b15a/0b15a047ba790210e610bdb24ee615d4d9815b05" alt=""
data:image/s3,"s3://crabby-images/44b4c/44b4ce210ef3deefa4e7d93f05aa9c5aa2c11ae1" alt=""
data:image/s3,"s3://crabby-images/a05f8/a05f8c293519f5bc61bc7d4a2915444eee1c192c" alt=""
data:image/s3,"s3://crabby-images/6077f/6077ff02942501ecdb17474bd851993ed5bc92f8" alt=""
Solve least squares problem
data:image/s3,"s3://crabby-images/fc9f9/fc9f9d47c8ed2f9a6f8104b320a1a8ec0b3cb706" alt=""
for parameters
data:image/s3,"s3://crabby-images/96b39/96b3975e85b4c9ea5ccdb97ef13e3774c1c39f8b" alt=""
Computing Discrete Gradients
Computing
data:image/s3,"s3://crabby-images/a0bfb/a0bfbb95df1294dd597d326790d42da0f20bb9f1" alt=""
over a triangle given by corner vertices
data:image/s3,"s3://crabby-images/76dbb/76dbb3891b5a7a390ab2d795f4e8eb7bdc75139e" alt=""
and parameter values
data:image/s3,"s3://crabby-images/1596d/1596de34128e2919bc5b5e202ee2a71b7b07144b" alt=""
For a point
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/c0131/c0131874aec48b0eb0fa10d12cf036069888a804" alt=""
data:image/s3,"s3://crabby-images/1c299/1c299cde52d1a7eec4f1ad0cd696be063902281b" alt=""
data:image/s3,"s3://crabby-images/53b97/53b9734dc120610a6a31095122d2b99585961ddc" alt=""
Geometrical derivation of
data:image/s3,"s3://crabby-images/39dfc/39dfc7e975e9679d8a7f3a68f24aaa4155ac7f77" alt=""
data:image/s3,"s3://crabby-images/a8e38/a8e3885655a72290f9b91edec41ede3402f582b0" alt=""
data:image/s3,"s3://crabby-images/785d3/785d3213331f446c263bcb960d2a7dacf78d1db3" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/47a8b/47a8b0b3a5601c7f07072ccdb8963074925d2bc5" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/869a9/869a95c517e33aad4ec68f2befe8898fc2637c21" alt=""
data:image/s3,"s3://crabby-images/911a2/911a29bc975e324a409317ef1cbea1e246e27012" alt=""
data:image/s3,"s3://crabby-images/0632f/0632f85b991a20b6c261095b8653e506cad2fa16" alt=""
data:image/s3,"s3://crabby-images/785d3/785d3213331f446c263bcb960d2a7dacf78d1db3" alt=""
data:image/s3,"s3://crabby-images/82d9b/82d9b6b0d8fe4375dd173d8c96f50f8dd9af0a9c" alt=""
We can compute the height
data:image/s3,"s3://crabby-images/911a2/911a29bc975e324a409317ef1cbea1e246e27012" alt=""
data:image/s3,"s3://crabby-images/0c6e7/0c6e7756a7ec5953e97c8ab7448e4c090f58ef07" alt=""
data:image/s3,"s3://crabby-images/c3040/c304017fb688715535f461bbb0939f7edd70f390" alt=""
Plugging this result back in gives
data:image/s3,"s3://crabby-images/44b9e/44b9ec26d8732956b4e33d8a8618e35c0d9dbccf" alt=""
With this result, we get
data:image/s3,"s3://crabby-images/26250/2625068183e5dd5ed39a79f93f0f9b54c61ddfc6" alt=""
data:image/s3,"s3://crabby-images/c7506/c7506ed6c6c3e08b59b69f5acaa43f75dea82635" alt=""
Name all Parametrization algorithms we have discussed!
Discrete Harmonic Parametrization
Stretch Minimizing Parametrization
Globally Smooth Parametrization
Least Squares Conformal Maps
Mixed Integer Quadrangulation
Stretch Minimizing Parametrization
Globally Smooth Parametrization
Least Squares Conformal Maps
Mixed Integer Quadrangulation
How to create a Globally Smooth Parametrization?
Idea: Split input mesh into multiple (approximately quadratic) patches. Compute a discrete harmonic parametrization for each one. Some vertices will have neighbors which lie in another patch. The requirement for harmonic parametrization
data:image/s3,"s3://crabby-images/34ff9/34ff97c95a98d366446cd2637a36c427c0f3a2e9" alt=""
must take this into account.
Introduce transition functions
which represent the transformation between patches
and
.
transforms the parameter
which is given in the local coordinates of patch
into the local coordinate system of patch
.
Obviously,
and data:image/s3,"s3://crabby-images/d5b91/d5b91d52c970b1d3aad54c58cf9ec0c5eb471371" alt=""
Thus, the harmonic parametrization system becomes:
data:image/s3,"s3://crabby-images/ddeda/ddeda4e227167414afcafefbce306c827f689252" alt=""
Problem: For vertices close to patch corners, the transformation used to map neighbors to the local coordinate system might be ambiguous.
Solution: Fix parameters of corner vertices to the patch corners. Let the remaining vertices relax.
data:image/s3,"s3://crabby-images/34ff9/34ff97c95a98d366446cd2637a36c427c0f3a2e9" alt=""
must take this into account.
Introduce transition functions
data:image/s3,"s3://crabby-images/5d010/5d0109f0eeb735def7f0223985a8491d80c7039a" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
data:image/s3,"s3://crabby-images/a2d92/a2d922711fe007970d96aecb92eed090ae593cef" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/309f3/309f34f4a60011a101ae106e9ea42b84a2bab95e" alt=""
data:image/s3,"s3://crabby-images/f1bd7/f1bd7e9aad466e453dc0345f0c952abda5f02913" alt=""
Obviously,
data:image/s3,"s3://crabby-images/9c97a/9c97a26e4c7d3d257696776492b5ae5674a97d15" alt=""
data:image/s3,"s3://crabby-images/d5b91/d5b91d52c970b1d3aad54c58cf9ec0c5eb471371" alt=""
Thus, the harmonic parametrization system becomes:
data:image/s3,"s3://crabby-images/ddeda/ddeda4e227167414afcafefbce306c827f689252" alt=""
Problem: For vertices close to patch corners, the transformation used to map neighbors to the local coordinate system might be ambiguous.
Solution: Fix parameters of corner vertices to the patch corners. Let the remaining vertices relax.
What are the properties of a Delaunay triangulation?
The Delaunay triangulation maximizes the smallest interior angle.
The Delaunay triangulation of a point set is unique (unless a triangle circumcircle intersects more than 3 vertices).
Dual properties of Delaunay triangulations and Voronoi diagrams
The Delaunay triangulation of a point set is unique (unless a triangle circumcircle intersects more than 3 vertices).
Dual properties of Delaunay triangulations and Voronoi diagrams
Delauny triangulation | Voronoi diagram |
Each triangle circumcircle contains no other vertices in its interior. | Around each Voronoi vertex, there exists a smallest circumcircle touching at least 3 Voronoi sites and containing no sites in its interior. |
For every edge, there exists an empty circle containing both endpoints. | For every Voronoi edge, there exists a circle containing both adjacent Voronoi sites but no other sites. |
Give two definitions of the Voronoi diagram of a point set!
Given: Set of sites data:image/s3,"s3://crabby-images/e65f4/e65f46472c657adb9907f576405a60883a72eca7" alt=""
Closest Points
The Voronoi cell
of a site
is given by the set of all points which are closer to
than to any other site
:
data:image/s3,"s3://crabby-images/504f2/504f228044cc88c3d86a9d3f51600973f0447a4d" alt=""
Halfspace Intersection
Each pair of sites
divides the space into a halfspace points which are closer to
than to data:image/s3,"s3://crabby-images/d48c1/d48c14c4923c974f3bccaf760ab01ab5ea519773" alt=""
data:image/s3,"s3://crabby-images/9ab74/9ab74387a1385b5216eea8d257e4e410bed5b2bf" alt=""
Then,
can be described as the intersection of all halfspaces formed with other sites:
data:image/s3,"s3://crabby-images/9d41b/9d41b66008087a2a85c85655726e72bd0f1d82f3" alt=""
From this definition, it is obvious that all Voronoi cells are convex.
data:image/s3,"s3://crabby-images/e65f4/e65f46472c657adb9907f576405a60883a72eca7" alt=""
Closest Points
The Voronoi cell
data:image/s3,"s3://crabby-images/c9ee9/c9ee9c8b23d06ac37fb193f9db736b905853bffd" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/cf31a/cf31af916f081e2e63b65857cf524c732dd92c92" alt=""
data:image/s3,"s3://crabby-images/504f2/504f228044cc88c3d86a9d3f51600973f0447a4d" alt=""
Halfspace Intersection
Each pair of sites
data:image/s3,"s3://crabby-images/c2cde/c2cdeacc212124f4b150d0413ca4715a1c9046dd" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/d48c1/d48c14c4923c974f3bccaf760ab01ab5ea519773" alt=""
data:image/s3,"s3://crabby-images/9ab74/9ab74387a1385b5216eea8d257e4e410bed5b2bf" alt=""
Then,
data:image/s3,"s3://crabby-images/c9ee9/c9ee9c8b23d06ac37fb193f9db736b905853bffd" alt=""
data:image/s3,"s3://crabby-images/9d41b/9d41b66008087a2a85c85655726e72bd0f1d82f3" alt=""
From this definition, it is obvious that all Voronoi cells are convex.
How to compute a Discrete Harmonic Parametrization? Give three examples for weights!
Given a mesh with disk topology of points
in the mesh domain
, find points
in the parameter domain
.
A function
is harmonic if its Laplace is zero, i.e.
data:image/s3,"s3://crabby-images/9d94c/9d94c3e32988e853c957eb0b977c6574e328e8ff" alt=""
Use a spring model: Edges of the mesh are mapped to springs. Fix parameters of mesh boundary points. Relax remaining points to equilibrium by solving
data:image/s3,"s3://crabby-images/34ff9/34ff97c95a98d366446cd2637a36c427c0f3a2e9" alt=""
i.e.
data:image/s3,"s3://crabby-images/1b286/1b2860fb884ee09f539373c6e835546e05679417" alt=""
Solve two linear systems:
data:image/s3,"s3://crabby-images/e6831/e683113669f40bdbcfb281cea91d8a99ed91c958" alt=""
data:image/s3,"s3://crabby-images/10beb/10beb69b4a9f38b5987f8ec6980f94f3eaae0ece" alt=""
To satisfy Tutte's theorem (and thus ensure a valid parametrization), use a concave boundary shape (circle, square) and have only positive spring weights.
Uniform Weights
data:image/s3,"s3://crabby-images/ad32c/ad32c80232aba46c227caddce50f03c848456df2" alt=""
Distributes vertices regularly in the parameter domain. No mesh structure is considered. Strong length and angular distortion.
Chordal Weights
data:image/s3,"s3://crabby-images/1fbf8/1fbf86662e594fe6cf173daea28c7ffac8a75182" alt=""
Considers vertex distances. Low length distortion, but angular distortion is not controlled and thus high.
Cotangent Weights
data:image/s3,"s3://crabby-images/5b2d3/5b2d3024d3245ff72fb79f927f168af3ec189b4b" alt=""
In practice, low length and angular distortion. However, can lead to negative weights (violating Tutte's theorem).
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
data:image/s3,"s3://crabby-images/9aa81/9aa816fdc88f2ae8950bf02a017e3c7621ceb4b7" alt=""
data:image/s3,"s3://crabby-images/ebf59/ebf59b6c14171c4c5a5204cafd169dd178978780" alt=""
data:image/s3,"s3://crabby-images/a4012/a4012012d89919033926921bb6c57917fa55bcbc" alt=""
A function
data:image/s3,"s3://crabby-images/dc270/dc270a9ce3bf36537d2220eb25ae1e183561f873" alt=""
data:image/s3,"s3://crabby-images/9d94c/9d94c3e32988e853c957eb0b977c6574e328e8ff" alt=""
Use a spring model: Edges of the mesh are mapped to springs. Fix parameters of mesh boundary points. Relax remaining points to equilibrium by solving
data:image/s3,"s3://crabby-images/34ff9/34ff97c95a98d366446cd2637a36c427c0f3a2e9" alt=""
i.e.
data:image/s3,"s3://crabby-images/1b286/1b2860fb884ee09f539373c6e835546e05679417" alt=""
Solve two linear systems:
data:image/s3,"s3://crabby-images/e6831/e683113669f40bdbcfb281cea91d8a99ed91c958" alt=""
data:image/s3,"s3://crabby-images/10beb/10beb69b4a9f38b5987f8ec6980f94f3eaae0ece" alt=""
To satisfy Tutte's theorem (and thus ensure a valid parametrization), use a concave boundary shape (circle, square) and have only positive spring weights.
Uniform Weights
data:image/s3,"s3://crabby-images/ad32c/ad32c80232aba46c227caddce50f03c848456df2" alt=""
Distributes vertices regularly in the parameter domain. No mesh structure is considered. Strong length and angular distortion.
Chordal Weights
data:image/s3,"s3://crabby-images/1fbf8/1fbf86662e594fe6cf173daea28c7ffac8a75182" alt=""
Considers vertex distances. Low length distortion, but angular distortion is not controlled and thus high.
Cotangent Weights
data:image/s3,"s3://crabby-images/5b2d3/5b2d3024d3245ff72fb79f927f168af3ec189b4b" alt=""
In practice, low length and angular distortion. However, can lead to negative weights (violating Tutte's theorem).
How can you estimate the distortion introduced by a parametrization?
Given a parametrization
data:image/s3,"s3://crabby-images/6a740/6a740f82f3f896cf44790da669d4cd84b7ca3dfc" alt=""
consider the Jacobian of
at some point
:
data:image/s3,"s3://crabby-images/c5102/c5102c8bca5043e1731cff34ae4f674cb360d670" alt=""
and its Singular Value Decomposition
data:image/s3,"s3://crabby-images/39d72/39d72f57677fd278b93952c0db59b020b205ec89" alt=""
and
are orthonormal, i.e. rotation matrices.
is a diagonal matrix and corresponds to an axis-aligned scaling.
thus can be interpreted as a concatenation of a rotation, a scaling and again a rotation. The distortion at
can thus be inferred from
and
:
data:image/s3,"s3://crabby-images/6a740/6a740f82f3f896cf44790da669d4cd84b7ca3dfc" alt=""
consider the Jacobian of
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/c6702/c6702eb6401479d78515bae6ae7cbb196266a50a" alt=""
data:image/s3,"s3://crabby-images/c5102/c5102c8bca5043e1731cff34ae4f674cb360d670" alt=""
and its Singular Value Decomposition
data:image/s3,"s3://crabby-images/39d72/39d72f57677fd278b93952c0db59b020b205ec89" alt=""
data:image/s3,"s3://crabby-images/85393/853930f6cfd55abcacbac568d721d0a5139b06ed" alt=""
data:image/s3,"s3://crabby-images/388d6/388d6b6e0b40051764fe689fa810c8eb90201bdd" alt=""
data:image/s3,"s3://crabby-images/695cf/695cfa7dd2e4c0e3b1015feafc624bf53df55ffc" alt=""
data:image/s3,"s3://crabby-images/b5064/b5064a75af491568dd4dc10228e0d9d9acdb55f3" alt=""
data:image/s3,"s3://crabby-images/c6702/c6702eb6401479d78515bae6ae7cbb196266a50a" alt=""
data:image/s3,"s3://crabby-images/e8f13/e8f1373fd50220498138282a455103a74341c8a9" alt=""
data:image/s3,"s3://crabby-images/4e59d/4e59d95d41962d5bf177b954c1911765bbd3d590" alt=""
- Conformal / angle preserving:
- Area preserving:
- Isometry:
Explain Stretch Minimizing Parametrization!
Discrete Harmonic Parametrization may introduce unwanted stretch.
Idea: Repeat: Compute Harmonic Parametrization. Compute local stretch measures. Update weights
according to local stretch measures.
Stretch Measure
SVD of Jacobian ofdata:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/b0a36/b0a36293f63350df1790d66029d5a67252b47b87" alt=""
Stretch Measure:
data:image/s3,"s3://crabby-images/3bc57/3bc5708b5bb235923ef24e8c003f494926f8d76f" alt=""
: Ellipsoid in
is enlarged by
. In order to make it smaller, push parameter positions away from each other in
. To achieve this, decrease local spring weights.
: Ellipsoid in
is shrunk by
. In order to make it bigger, pull parameter positions closer together in
. To achieve this, increase local spring weights.
This gives the update rule:
data:image/s3,"s3://crabby-images/fd96b/fd96bd9b04aab7e4b8f11afe2ff5d3d893a41376" alt=""
Idea: Repeat: Compute Harmonic Parametrization. Compute local stretch measures. Update weights
data:image/s3,"s3://crabby-images/54259/5425972416d6d241c77d365a075d8b0b1f7f0752" alt=""
Stretch Measure
SVD of Jacobian of
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/b0a36/b0a36293f63350df1790d66029d5a67252b47b87" alt=""
Stretch Measure:
data:image/s3,"s3://crabby-images/3bc57/3bc5708b5bb235923ef24e8c003f494926f8d76f" alt=""
data:image/s3,"s3://crabby-images/0ee6b/0ee6b6b8cca7f231bb8a6bee9a4b9a29c203b480" alt=""
data:image/s3,"s3://crabby-images/c8ffd/c8ffdb8ceb67c1fa7426312d0d690f734e8db745" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/c8ffd/c8ffdb8ceb67c1fa7426312d0d690f734e8db745" alt=""
data:image/s3,"s3://crabby-images/f6ce6/f6ce6b2d21f3c52c14c03fddbc887c3880ac3477" alt=""
data:image/s3,"s3://crabby-images/c8ffd/c8ffdb8ceb67c1fa7426312d0d690f734e8db745" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/c8ffd/c8ffdb8ceb67c1fa7426312d0d690f734e8db745" alt=""
This gives the update rule:
data:image/s3,"s3://crabby-images/fd96b/fd96bd9b04aab7e4b8f11afe2ff5d3d893a41376" alt=""
What is Light Tracing? What is Instant Radiosity?
Light Tracing
Reverse Monte Carlo Path Tracing. Start pathes in random light sources. In the absorption case, connect from the current point to the viewer. Advantage: Can detect high energy pathes.
Instant Radiosity
Efficient diffuse illumination utilizing Light Tracing and hardware rasterization.
Shoot photons from light sources. At every bounce, place a point light source at the photon position and render the scene with diffuse lighting and shadow mapping. Accumulate the brightness values of all pixels in a buffer (weighted by current photon energy).
Corresponds to bi-directional evaluation of pathes:
Reverse Monte Carlo Path Tracing. Start pathes in random light sources. In the absorption case, connect from the current point to the viewer. Advantage: Can detect high energy pathes.
Instant Radiosity
Efficient diffuse illumination utilizing Light Tracing and hardware rasterization.
Shoot photons from light sources. At every bounce, place a point light source at the photon position and render the scene with diffuse lighting and shadow mapping. Accumulate the brightness values of all pixels in a buffer (weighted by current photon energy).
Corresponds to bi-directional evaluation of pathes:
data:image/s3,"s3://crabby-images/21e8c/21e8ce7cbe63141a590566d01245c559ac3bcafb" alt=""
Explain the photon path notation! Give expressions for Phong Lighting, Ray Tracing, Radiosity, Path Tracing and Photon Mapping!
-
absorption in the eye
-
diffuse reflection
-
glossy reflection
-
specular reflection
-
emission from a light source
Phong Lighting
data:image/s3,"s3://crabby-images/3649a/3649a5551abfe55167c37fb9e459ddcd71ba0d49" alt=""
One surface interaction. Diffuse or glossy.
Ray Tracing
data:image/s3,"s3://crabby-images/edfc8/edfc80164eba4be4e86ca268b242cac9aa898e28" alt=""
Tracing from the eye. Arbitrary many specular reflections, then one final Phong lighting step.
Radiosity
data:image/s3,"s3://crabby-images/f1771/f1771f42767bb126eb405882f7e084b8cfdaca9f" alt=""
Only diffuse reflections.
Path Tracing
data:image/s3,"s3://crabby-images/1c001/1c00198d38fe8c0af84d8f8a5e21add9d2705c3a" alt=""
A series of arbitrary reflections. Then, one final phong lighting step to connect to light source.
Photon Mapping
data:image/s3,"s3://crabby-images/26cde/26cde0d75e55d11e936050851bc4da45c8f0838d" alt=""
Arbitrary photon pathes.
Explain Photon Mapping!
Photon Generation
Shoot photons from all light sources:
Point light: Identical position. Uniform spherical distribution of directions.
Directional light: Identical direction. Uniform distribution of positions.
Area light: Uniform distribution of positions on the surface. Cos-thetha weighted distribution of directions.
For multiple light sources with different intensities: Adjust photon energy or photon frequency.
Optimization: Use projection maps to only shoot photons into directions where geometry is. Also requires scaling of energy:
data:image/s3,"s3://crabby-images/63de6/63de6c6e3835c1b897360d63c506922f52a16578" alt=""
Photon Tracing
On interaction with a surface with diffuse and specular reflection coefficients
,
:
Russian Roulette: Generate random numberdata:image/s3,"s3://crabby-images/ecf25/ecf2555b2632a66d2ae6d20604aeec0174a5c9cb" alt=""
Information stored in the photon map:data:image/s3,"s3://crabby-images/48356/4835615404425e455709096dfba5fde715966d4b" alt=""
: position
: photon power (flux per solid angle)
: angle of incidence
Radiance Estimate
Replace the recursive term in the Rendering Equation with a radiance estimate from the photon map. For a point
, find the
nearest neighbor samples from the photon map and compute
data:image/s3,"s3://crabby-images/fdb3c/fdb3c05b516f1918bbaac54c03443a34c80e7c4c" alt=""
data:image/s3,"s3://crabby-images/ccc2a/ccc2aec083d4393597f3543968e736293e79175a" alt=""
where
data:image/s3,"s3://crabby-images/79f7f/79f7fa2449e9eec64157ededf0e1d05372658aa1" alt=""
Rendering
Decompose the Rendering Equation
data:image/s3,"s3://crabby-images/3e6d2/3e6d26ff5775b0be736675bed15d309b1c7b1d72" alt=""
data:image/s3,"s3://crabby-images/86787/86787906bae506cbc670905ed2cab86fcc78da02" alt=""
data:image/s3,"s3://crabby-images/1dbe4/1dbe415ce8521cc1fd42b8d60374e648f36164aa" alt=""
Evaluate the following factorizations:
Shoot photons from all light sources:
Point light: Identical position. Uniform spherical distribution of directions.
Directional light: Identical direction. Uniform distribution of positions.
Area light: Uniform distribution of positions on the surface. Cos-thetha weighted distribution of directions.
For multiple light sources with different intensities: Adjust photon energy or photon frequency.
Optimization: Use projection maps to only shoot photons into directions where geometry is. Also requires scaling of energy:
data:image/s3,"s3://crabby-images/63de6/63de6c6e3835c1b897360d63c506922f52a16578" alt=""
Photon Tracing
On interaction with a surface with diffuse and specular reflection coefficients
data:image/s3,"s3://crabby-images/721b2/721b285a8802839d5e07156ca728da425abcf9e2" alt=""
data:image/s3,"s3://crabby-images/349b9/349b97d2ccbf3b42f238a778addce8df13125955" alt=""
Russian Roulette: Generate random number
data:image/s3,"s3://crabby-images/ecf25/ecf2555b2632a66d2ae6d20604aeec0174a5c9cb" alt=""
-
: Diffuse reflection. Store in photon map. Continue tracing (TODO: Which direction?).
-
: Specular reflection. Continue tracing (TODO: Which direction?).
-
: Absorption. Store in photon map.
Information stored in the photon map:
data:image/s3,"s3://crabby-images/48356/4835615404425e455709096dfba5fde715966d4b" alt=""
data:image/s3,"s3://crabby-images/309d4/309d4a32b5cfda07d6febdba00aa0ed429c056c9" alt=""
data:image/s3,"s3://crabby-images/c5b20/c5b202bc6df15ee0453342fd2bf44ace4825c30a" alt=""
data:image/s3,"s3://crabby-images/50eab/50eab9d1ee3cd1cc5cd5e8f88d0ddd60d3b70cf7" alt=""
Radiance Estimate
Replace the recursive term in the Rendering Equation with a radiance estimate from the photon map. For a point
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/b9903/b99032d10a48891bfc06721920c706cb818706cd" alt=""
data:image/s3,"s3://crabby-images/fdb3c/fdb3c05b516f1918bbaac54c03443a34c80e7c4c" alt=""
data:image/s3,"s3://crabby-images/ccc2a/ccc2aec083d4393597f3543968e736293e79175a" alt=""
where
data:image/s3,"s3://crabby-images/79f7f/79f7fa2449e9eec64157ededf0e1d05372658aa1" alt=""
Rendering
Decompose the Rendering Equation
data:image/s3,"s3://crabby-images/3e6d2/3e6d26ff5775b0be736675bed15d309b1c7b1d72" alt=""
data:image/s3,"s3://crabby-images/86787/86787906bae506cbc670905ed2cab86fcc78da02" alt=""
data:image/s3,"s3://crabby-images/1dbe4/1dbe415ce8521cc1fd42b8d60374e648f36164aa" alt=""
-
: Diffuse reflections. Direction independent.
-
: Specular reflections.
-
: Direct illumination.
-
: Diffuse illumination.
-
: Caustic illumination.
Evaluate the following factorizations:
-
Direct Illumination. Compute using ray casting / hemisphere sampling.
-
Specular / Glossy Reflections. Compute using MCPT.
-
Radiosity. Compute using radiance estimate from diffuse photon map.
-
Caustics. Compute using radiance estimate from caustic photon map.
How is the Photon Map stored? How are k-nearest-neighbor queries performed?
kD-Tree
Store photons in a balanced kD-Tree (i.e., a binary tree) with entries
. The two child nodes of an inner node
are
and
.
A balanced kD-Tree is constructed by successive median splits.
kD-Tree k-NN Search
Input:
: query point
: root node of subtree to be searched
Global variables:
: priority queue containing k-best search results
: distance from
to furthest result in
, or
if less than
results
knn(
,
):
if(
is a leaf)
insert
into data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
updatedata:image/s3,"s3://crabby-images/04fc8/04fc8cd9c289480d3ab47094174bc26ad676066d" alt=""
else
if
is left of split plane
knn(
,
)
if distance to split planedata:image/s3,"s3://crabby-images/744a6/744a6bfa3daf42d3433b3ad3cb4a2bb22c167e56" alt=""
knn(
,
)
else
knn(
,
)
if distance to split planedata:image/s3,"s3://crabby-images/744a6/744a6bfa3daf42d3433b3ad3cb4a2bb22c167e56" alt=""
knn(
,
)
More efficient: Compare squared distances
Store photons in a balanced kD-Tree (i.e., a binary tree) with entries
data:image/s3,"s3://crabby-images/674af/674afeee3da8c17939cb910cfb8aad53316847ce" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/b508d/b508dea60be9dded04c9da690792cef9e94701c5" alt=""
data:image/s3,"s3://crabby-images/e36e5/e36e5d862442b3627967f395ba4a0647c5dfa5ff" alt=""
A balanced kD-Tree is constructed by successive median splits.
kD-Tree k-NN Search
Input:
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
Global variables:
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
data:image/s3,"s3://crabby-images/04fc8/04fc8cd9c289480d3ab47094174bc26ad676066d" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
data:image/s3,"s3://crabby-images/56561/5656181d195c30da01783edbd7b71caab38cf39b" alt=""
data:image/s3,"s3://crabby-images/b9903/b99032d10a48891bfc06721920c706cb818706cd" alt=""
knn(
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
if(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
insert
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
update
data:image/s3,"s3://crabby-images/04fc8/04fc8cd9c289480d3ab47094174bc26ad676066d" alt=""
else
if
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
knn(
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/b508d/b508dea60be9dded04c9da690792cef9e94701c5" alt=""
if distance to split plane
data:image/s3,"s3://crabby-images/744a6/744a6bfa3daf42d3433b3ad3cb4a2bb22c167e56" alt=""
knn(
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/e36e5/e36e5d862442b3627967f395ba4a0647c5dfa5ff" alt=""
else
knn(
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/e36e5/e36e5d862442b3627967f395ba4a0647c5dfa5ff" alt=""
if distance to split plane
data:image/s3,"s3://crabby-images/744a6/744a6bfa3daf42d3433b3ad3cb4a2bb22c167e56" alt=""
knn(
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/b508d/b508dea60be9dded04c9da690792cef9e94701c5" alt=""
More efficient: Compare squared distances
Why is Hierarchical Radiosity more efficient than simple Shooting / Gathering?
Adaptive Refinement
Only refines patches whose form factors are large, thus generates fewer patches than uniform refinement.
Generate fewer links
For each element, there is only a constant number of other elements for which the form factor is large. All other elements are connected on different hierarchy levels. Thus, the number of links generated by Hierarchical Radiosity is linear in the number of elements while for classical Radiosity it is quadratic.
Only refines patches whose form factors are large, thus generates fewer patches than uniform refinement.
Generate fewer links
For each element, there is only a constant number of other elements for which the form factor is large. All other elements are connected on different hierarchy levels. Thus, the number of links generated by Hierarchical Radiosity is linear in the number of elements while for classical Radiosity it is quadratic.
Name three ways to estimate Form Factors for Radiosity computation!
Sampling
Monte Carlo Sampling: Generate random points
according to a distribution
and evaluate
data:image/s3,"s3://crabby-images/bcaa9/bcaa93ca720bb4198c703292f4968ed26a24bbac" alt=""
Nusselt Analogon
Given sender patch with area
.
Project sender patch onto hemisphere of receiving patch:
data:image/s3,"s3://crabby-images/401c9/401c941bf95c8782f9600c917d5aa42ad77169c5" alt=""
where
is the angle between sending patch normal and projection direction and
is the distance between the two patches.
Project result into plane:
data:image/s3,"s3://crabby-images/aea23/aea23128287e6138b50d5f40572dfe31204e3a19" alt=""
data:image/s3,"s3://crabby-images/f6a72/f6a722ec90751ca44621a81ce6149d436a946f93" alt=""
The form factor is the covered portion of the unit circle.
data:image/s3,"s3://crabby-images/8e868/8e8684a33c2468968610885c0e3ea15cca5fbe4b" alt=""
data:image/s3,"s3://crabby-images/0fb2b/0fb2b358081db1469f120c7d252921d8e52ef4bb" alt=""
Problem: Assumptions only hold for patches that are sufficiently far away.
Hemicube
Rasterize 5 sides of a hemicube placed around a point on
.
Denote by
the set of pixels that see patch
. Then,
data:image/s3,"s3://crabby-images/9d3f5/9d3f57e1e35fe7ef7e0e55dfb9173d3160c057ae" alt=""
where
are pre-calculated form factors for the individual pixels of the hemicube.
Monte Carlo Sampling: Generate random points
data:image/s3,"s3://crabby-images/6f61c/6f61c67115a59c4f0ffa84462dc8cb7631108a2e" alt=""
data:image/s3,"s3://crabby-images/4886d/4886d38e7a7c1fdeaabf453cbba1ebc9df4e3cb2" alt=""
data:image/s3,"s3://crabby-images/bcaa9/bcaa93ca720bb4198c703292f4968ed26a24bbac" alt=""
Nusselt Analogon
Given sender patch with area
data:image/s3,"s3://crabby-images/f49eb/f49eba7f4adb87e68e42ffa00330737aff445525" alt=""
Project sender patch onto hemisphere of receiving patch:
data:image/s3,"s3://crabby-images/401c9/401c941bf95c8782f9600c917d5aa42ad77169c5" alt=""
where
data:image/s3,"s3://crabby-images/33ffd/33ffd0b31a6e374006a2b895bc7d739f2a398df7" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
Project result into plane:
data:image/s3,"s3://crabby-images/aea23/aea23128287e6138b50d5f40572dfe31204e3a19" alt=""
data:image/s3,"s3://crabby-images/f6a72/f6a722ec90751ca44621a81ce6149d436a946f93" alt=""
The form factor is the covered portion of the unit circle.
data:image/s3,"s3://crabby-images/8e868/8e8684a33c2468968610885c0e3ea15cca5fbe4b" alt=""
data:image/s3,"s3://crabby-images/0fb2b/0fb2b358081db1469f120c7d252921d8e52ef4bb" alt=""
Problem: Assumptions only hold for patches that are sufficiently far away.
Hemicube
Rasterize 5 sides of a hemicube placed around a point on
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
Denote by
data:image/s3,"s3://crabby-images/55a39/55a399a32b593c66da668d81375edd46a5d5b351" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/9d3f5/9d3f57e1e35fe7ef7e0e55dfb9173d3160c057ae" alt=""
where
data:image/s3,"s3://crabby-images/4f510/4f5109bd956ec55ff8c5ed9389aa971f35c1d7c4" alt=""
Derive the formula for Monte Carlo Integration! When does MCI converge fast?
Given: values
distributed according to data:image/s3,"s3://crabby-images/62e30/62e30bae9ca2d50d091ccc66403efc2f3767bbd3" alt=""
and samples of a function
: data:image/s3,"s3://crabby-images/42ed0/42ed0e1c68c89a84e320ad8b80acf5d4779e5663" alt=""
data:image/s3,"s3://crabby-images/fb374/fb3744f0f0d936608c7cc4ea2649633585be2455" alt=""
data:image/s3,"s3://crabby-images/aa256/aa256371f0027dceb298763b165c59e8b7070109" alt=""
The more
, the smaller the variance of the quotient
,
thus MCI converges faster.
data:image/s3,"s3://crabby-images/6d735/6d735ff9df7aaef6121770a0db47895eedb70fa6" alt=""
data:image/s3,"s3://crabby-images/62e30/62e30bae9ca2d50d091ccc66403efc2f3767bbd3" alt=""
and samples of a function
data:image/s3,"s3://crabby-images/dc270/dc270a9ce3bf36537d2220eb25ae1e183561f873" alt=""
data:image/s3,"s3://crabby-images/42ed0/42ed0e1c68c89a84e320ad8b80acf5d4779e5663" alt=""
data:image/s3,"s3://crabby-images/fb374/fb3744f0f0d936608c7cc4ea2649633585be2455" alt=""
data:image/s3,"s3://crabby-images/aa256/aa256371f0027dceb298763b165c59e8b7070109" alt=""
The more
data:image/s3,"s3://crabby-images/e2b86/e2b863f4b5a3aec71a59f185bdb6f78273e8bd58" alt=""
data:image/s3,"s3://crabby-images/df527/df527f6d157516996bd59ac72d276576ec2f994e" alt=""
thus MCI converges faster.
How to create uniform samples on a unit sphere?
Rejection Method
Generate uniform samples
until
. Then, return
data:image/s3,"s3://crabby-images/44406/44406b901d8d9e53dee9d9ed604c1ea06e4d1c6a" alt=""
Transform of Variables
data:image/s3,"s3://crabby-images/bc45c/bc45cac8b2072f277dbc00f32bd76999f441c775" alt=""
data:image/s3,"s3://crabby-images/fd9d1/fd9d103624bfabc4e2d15bfc74c8f875c7751d75" alt=""
data:image/s3,"s3://crabby-images/7213a/7213a616166de2be0e2d4a2d39972bec0165b046" alt=""
data:image/s3,"s3://crabby-images/bb486/bb486104a013dd3d6f86c4dbe7c470a3ac371908" alt=""
flip sign of
with #p = 0.5##
Generate uniform samples
data:image/s3,"s3://crabby-images/1de22/1de22154048a0e87917dcb7ca1501ef9ca73e736" alt=""
data:image/s3,"s3://crabby-images/b0c88/b0c88abde021f885ebd79234890ea9e1342b8993" alt=""
data:image/s3,"s3://crabby-images/44406/44406b901d8d9e53dee9d9ed604c1ea06e4d1c6a" alt=""
Transform of Variables
data:image/s3,"s3://crabby-images/bc45c/bc45cac8b2072f277dbc00f32bd76999f441c775" alt=""
data:image/s3,"s3://crabby-images/fd9d1/fd9d103624bfabc4e2d15bfc74c8f875c7751d75" alt=""
data:image/s3,"s3://crabby-images/7213a/7213a616166de2be0e2d4a2d39972bec0165b046" alt=""
data:image/s3,"s3://crabby-images/bb486/bb486104a013dd3d6f86c4dbe7c470a3ac371908" alt=""
flip sign of
data:image/s3,"s3://crabby-images/e56c6/e56c6d687475c5442a7bf578c09cff67e2aa1283" alt=""
How to create a cos-theta-weighted sampling of a unit hemisphere?
Rejection Method
Create uniform samples
until
.
data:image/s3,"s3://crabby-images/37e85/37e853e374167b6b1078f1a57ef56fda59f72f34" alt=""
Transform of Variables
Create random point inside unit circle:
data:image/s3,"s3://crabby-images/770d0/770d09dbd1fc0ba6984781451149809e0a15a852" alt=""
data:image/s3,"s3://crabby-images/61824/618249b5c7c63ec74c4344c5be984943c7425db0" alt=""
data:image/s3,"s3://crabby-images/e9c3a/e9c3aa8e023c12d141b7cc317e2e6f2e6c224c8c" alt=""
Now project the generated point to the hemisphere and set
accordingly
data:image/s3,"s3://crabby-images/dbb1c/dbb1ce5cd858e0a003f01b465f1a6bf444f485e1" alt=""
returndata:image/s3,"s3://crabby-images/2c0f1/2c0f192dcd3629df51e0872f5cd2b6e5387920fa" alt=""
Create uniform samples
data:image/s3,"s3://crabby-images/a0396/a0396f68480c4154ba5a7ddf76e91ada2a4f272d" alt=""
data:image/s3,"s3://crabby-images/65d47/65d47c2ffc27c2de99bd3d75c3a69c1ee03797b4" alt=""
data:image/s3,"s3://crabby-images/37e85/37e853e374167b6b1078f1a57ef56fda59f72f34" alt=""
Transform of Variables
Create random point inside unit circle:
data:image/s3,"s3://crabby-images/770d0/770d09dbd1fc0ba6984781451149809e0a15a852" alt=""
data:image/s3,"s3://crabby-images/61824/618249b5c7c63ec74c4344c5be984943c7425db0" alt=""
data:image/s3,"s3://crabby-images/e9c3a/e9c3aa8e023c12d141b7cc317e2e6f2e6c224c8c" alt=""
Now project the generated point to the hemisphere and set
data:image/s3,"s3://crabby-images/597b6/597b6e48cfb58085fdf7428752d2f6a91198bce0" alt=""
data:image/s3,"s3://crabby-images/dbb1c/dbb1ce5cd858e0a003f01b465f1a6bf444f485e1" alt=""
return
data:image/s3,"s3://crabby-images/2c0f1/2c0f192dcd3629df51e0872f5cd2b6e5387920fa" alt=""
Explain Monte Carlo Path Tracing!
MCPT solves the Rendering Equation using Monte Carlo Integration. The space over which is integrated is the space of all photon paths. Relevant paths are only those which carry energy: Starting from the eye and ending in an emissive surface:
data:image/s3,"s3://crabby-images/530cd/530cd090886d2aed769a72d9a8e0320dcaaec9c1" alt=""
The radiance at the end of this path is
data:image/s3,"s3://crabby-images/e566d/e566d81ff10b80466e61dec539dce4862bcf7b4a" alt=""
(for every photon bounce, there is one term
)
MCPT():
for each pixel
data:image/s3,"s3://crabby-images/eed41/eed41d970ed8599358a2a66bd1fc47c648686f1c" alt=""
fordata:image/s3,"s3://crabby-images/37468/37468e699fe85706658eafa19da52dbd8de6be68" alt=""
data:image/s3,"s3://crabby-images/75f23/75f23c971b54477218a86e19a05d7affe0c9cf54" alt=""
data:image/s3,"s3://crabby-images/701ed/701ed81958e95183841591be237f292007d1b72a" alt=""
:
data:image/s3,"s3://crabby-images/b022e/b022e8a6814dd90ca0b448f47a1dc20602b2b2e9" alt=""
ifdata:image/s3,"s3://crabby-images/adf5d/adf5d1ed580559bedfff15a56fcbfb407f12400b" alt=""
(emit)
returndata:image/s3,"s3://crabby-images/86a2b/86a2bb6ed73fa8d62a6011ab297c92c61b7d71d8" alt=""
else
(reflect)
generate random direction
over data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
returndata:image/s3,"s3://crabby-images/4a29e/4a29e71595188ff169a3f8f2ac2a7de2c2531876" alt=""
If we choose
data:image/s3,"s3://crabby-images/ac808/ac8085394703b1228942064fc490552e5d19c789" alt=""
the return statement in the reflect case simplifies to just
data:image/s3,"s3://crabby-images/32e09/32e097c507b5836fcc08ec12bbaa214622731fcd" alt=""
data:image/s3,"s3://crabby-images/530cd/530cd090886d2aed769a72d9a8e0320dcaaec9c1" alt=""
The radiance at the end of this path is
data:image/s3,"s3://crabby-images/e566d/e566d81ff10b80466e61dec539dce4862bcf7b4a" alt=""
(for every photon bounce, there is one term
data:image/s3,"s3://crabby-images/228e7/228e756d747d9cdd38679b5cac4d7eec62347c4c" alt=""
MCPT():
for each pixel
data:image/s3,"s3://crabby-images/eed41/eed41d970ed8599358a2a66bd1fc47c648686f1c" alt=""
for
data:image/s3,"s3://crabby-images/37468/37468e699fe85706658eafa19da52dbd8de6be68" alt=""
data:image/s3,"s3://crabby-images/75f23/75f23c971b54477218a86e19a05d7affe0c9cf54" alt=""
data:image/s3,"s3://crabby-images/701ed/701ed81958e95183841591be237f292007d1b72a" alt=""
data:image/s3,"s3://crabby-images/a575a/a575ab70ef74eb59a342ee347499bae15eac4184" alt=""
data:image/s3,"s3://crabby-images/b022e/b022e8a6814dd90ca0b448f47a1dc20602b2b2e9" alt=""
if
data:image/s3,"s3://crabby-images/adf5d/adf5d1ed580559bedfff15a56fcbfb407f12400b" alt=""
(emit)
return
data:image/s3,"s3://crabby-images/86a2b/86a2bb6ed73fa8d62a6011ab297c92c61b7d71d8" alt=""
else
(reflect)
generate random direction
data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
return
data:image/s3,"s3://crabby-images/4a29e/4a29e71595188ff169a3f8f2ac2a7de2c2531876" alt=""
If we choose
data:image/s3,"s3://crabby-images/ac808/ac8085394703b1228942064fc490552e5d19c789" alt=""
the return statement in the reflect case simplifies to just
data:image/s3,"s3://crabby-images/32e09/32e097c507b5836fcc08ec12bbaa214622731fcd" alt=""
What are two possible extensions for Monte Carlo Path Tracing?
Direct Lighting
Force all paths to end in a light source: When a photon would normally die, compute the direct illumination at its current position.
Sub-Paths
At each bounce, add one path that ends there. Needs to count total number of pathes generated.
Force all paths to end in a light source: When a photon would normally die, compute the direct illumination at its current position.
Sub-Paths
At each bounce, add one path that ends there. Needs to count total number of pathes generated.
What is the difference between Global Illumination algorithms and Image-Based Rendering?
Global Illumination
Simulation of light based on a physical model and a geometric representation of a scene.
Image-Based Rendering
Interpolation of collected data to synthesize an of a new viewpoint. Often with few / no scene geometry.
Simulation of light based on a physical model and a geometric representation of a scene.
Image-Based Rendering
Interpolation of collected data to synthesize an of a new viewpoint. Often with few / no scene geometry.
Name the two ways to think about light in physics? What effects can be explained by which model? Which model is used for Global Illumination algorithms?
Waves
Interference
Diffraction
Polarization
Particle / Photon
Reflection
Refraction
Scattering
Photon model realizes more important effects and is thus used in Global Illumination
Interference
Diffraction
Polarization
Particle / Photon
Reflection
Refraction
Scattering
Photon model realizes more important effects and is thus used in Global Illumination
What are the basic physical quantities of illumination and what are their units?
Flux data:image/s3,"s3://crabby-images/3bebf/3bebf2c231bcffb5313b39f230a256b1fb951c6f" alt=""
(also known as "radiant power")
Amount of energy emitted by a light source in unit time
data:image/s3,"s3://crabby-images/356b9/356b9e29ea7410a7ae2e8b4b7cc9eea363e92516" alt=""
Radiositydata:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Flux emitted per unit surface area
data:image/s3,"s3://crabby-images/c4b7e/c4b7e0a429efb3483cb0acda97bde123273f5a39" alt=""
data:image/s3,"s3://crabby-images/46348/463485a68b70e23a4671b960c125f1394e8e3d03" alt=""
Radiancedata:image/s3,"s3://crabby-images/d44ee/d44ee16594cd8b7dd72ea393fdb20e76b8b19c82" alt=""
Radiosity per solid angle (steradian)
data:image/s3,"s3://crabby-images/c6a43/c6a43cfbafb7651e201f9de913c92e27c7f2212e" alt=""
data:image/s3,"s3://crabby-images/138cc/138cc2d3f3afd74ca29f612f719526c80dd26f8f" alt=""
data:image/s3,"s3://crabby-images/3bebf/3bebf2c231bcffb5313b39f230a256b1fb951c6f" alt=""
(also known as "radiant power")
Amount of energy emitted by a light source in unit time
data:image/s3,"s3://crabby-images/356b9/356b9e29ea7410a7ae2e8b4b7cc9eea363e92516" alt=""
Radiosity
data:image/s3,"s3://crabby-images/d6a75/d6a753e719b546adbe033c6afc3c6ace97b1fce5" alt=""
Flux emitted per unit surface area
data:image/s3,"s3://crabby-images/c4b7e/c4b7e0a429efb3483cb0acda97bde123273f5a39" alt=""
data:image/s3,"s3://crabby-images/46348/463485a68b70e23a4671b960c125f1394e8e3d03" alt=""
Radiance
data:image/s3,"s3://crabby-images/d44ee/d44ee16594cd8b7dd72ea393fdb20e76b8b19c82" alt=""
Radiosity per solid angle (steradian)
data:image/s3,"s3://crabby-images/c6a43/c6a43cfbafb7651e201f9de913c92e27c7f2212e" alt=""
data:image/s3,"s3://crabby-images/138cc/138cc2d3f3afd74ca29f612f719526c80dd26f8f" alt=""
Give the Rendering Equation in both formulations and explain all its terms!
Hemisphere Formulation
data:image/s3,"s3://crabby-images/5bfa4/5bfa41f446319a973ed6e99a18de989559e34036" alt=""
: Incoming radiance at point
from direction data:image/s3,"s3://crabby-images/2f888/2f888970b7c390e1f55092db83c0b848b0855ece" alt=""
: Emitted radiance
: Hemisphere over the surface at point data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
: Intersection point of ray starting at
with direction
with the scene
: BRDF: portion of light which enters from direction
at
that is reflected into direction data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
: Angle between
and the normal vector of the surface at data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
Surface Formulation
data:image/s3,"s3://crabby-images/9d450/9d45018ed7958624eb910ce98160b0ccb9ea09e5" alt=""
where
data:image/s3,"s3://crabby-images/56925/5692580a7b2671696efc5e4b96cf9abbf68e1dcd" alt=""
and
data:image/s3,"s3://crabby-images/d082b/d082ba8ec6c83c9f7418d0db35061f90f2e387ed" alt=""
data:image/s3,"s3://crabby-images/5bfa4/5bfa41f446319a973ed6e99a18de989559e34036" alt=""
data:image/s3,"s3://crabby-images/784f2/784f2653cffa870545a5023387b245ed0410351b" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/2f888/2f888970b7c390e1f55092db83c0b848b0855ece" alt=""
data:image/s3,"s3://crabby-images/fbc19/fbc194e684bb6aa8db9356222e32990c610c4eb2" alt=""
data:image/s3,"s3://crabby-images/c8ffd/c8ffdb8ceb67c1fa7426312d0d690f734e8db745" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/c45ab/c45ab7e7b0e66d6371819306a01e511a38200459" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
data:image/s3,"s3://crabby-images/1c2fe/1c2fea4b157fb9ee8e9cd5c83d90ae80273325c4" alt=""
data:image/s3,"s3://crabby-images/2f888/2f888970b7c390e1f55092db83c0b848b0855ece" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
data:image/s3,"s3://crabby-images/597b6/597b6e48cfb58085fdf7428752d2f6a91198bce0" alt=""
data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
Surface Formulation
data:image/s3,"s3://crabby-images/9d450/9d45018ed7958624eb910ce98160b0ccb9ea09e5" alt=""
where
data:image/s3,"s3://crabby-images/56925/5692580a7b2671696efc5e4b96cf9abbf68e1dcd" alt=""
and
data:image/s3,"s3://crabby-images/d082b/d082ba8ec6c83c9f7418d0db35061f90f2e387ed" alt=""
What is the recursive complexity of the Rendering Equation?
The RE contains one recursive 2-dimensional integral. Thus, evaluating the RE up to the
-th recursion gives a
-dimensional integral.
data:image/s3,"s3://crabby-images/b9903/b99032d10a48891bfc06721920c706cb818706cd" alt=""
data:image/s3,"s3://crabby-images/621f4/621f40ab9c3dbe000a87a9a96e3f7f91eb6f76a4" alt=""
What is the BRDF? What are its properties?
A probability density function
data:image/s3,"s3://crabby-images/1c2fe/1c2fea4b157fb9ee8e9cd5c83d90ae80273325c4" alt=""
that describes the probability of a photon hitting the surface at
from an incoming direction
to exit at a direction
.
Properties:
data:image/s3,"s3://crabby-images/1c2fe/1c2fea4b157fb9ee8e9cd5c83d90ae80273325c4" alt=""
that describes the probability of a photon hitting the surface at
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/2f888/2f888970b7c390e1f55092db83c0b848b0855ece" alt=""
data:image/s3,"s3://crabby-images/5fb90/5fb90b6591173d4a6bd74c539ec8cabdc25c809e" alt=""
Properties:
- Positivity
- Energy Conservation
- Reciprocity
data:image/s3,"s3://crabby-images/0a716/0a716444475718419336a970036d54c1f188c36e" alt=""
data:image/s3,"s3://crabby-images/9b646/9b64634ec8a2e5ea754505d9e8631444168d26ef" alt=""
data:image/s3,"s3://crabby-images/6e975/6e975b04daaad7f1b7b2f520db1902b6ae7a254c" alt=""
What simplifications are made for Radiosity? Derive the Radiosity Equation!
Simplification 1: Assume only diffuse surfaces.
Instead of BRDF
, use reflectance
.
Instead of radiances
, use radiosity
.
Resulting Radiosity Equation:
data:image/s3,"s3://crabby-images/dae73/dae73faaf299c432d23d7f14dffa815558d725a7" alt=""
data:image/s3,"s3://crabby-images/79000/79000923c9b0054e029e0f98ece7aed71a918020" alt=""
Simplification 2: Spatial Discretization
Assume scene consisting of patches
with constant radiosity
data:image/s3,"s3://crabby-images/cf36d/cf36d549738939cf2c2925587f13b5bf64f3e4ce" alt=""
Plug the Radiosity Equation into this:
data:image/s3,"s3://crabby-images/3b873/3b8732713ee5a6a78f392517f2b794caa5d24800" alt=""
data:image/s3,"s3://crabby-images/635ec/635ec7931b6c0bac0d17adda5ca4f5f0a7571684" alt=""
We know that
is constant over
(with value
), thus we can pull it out of the integral:
data:image/s3,"s3://crabby-images/9cfc6/9cfc6050d42374c0b5e48499e6371e0c0168df08" alt=""
data:image/s3,"s3://crabby-images/33d08/33d08273bd27cf1a9c2b361d41b3561cbc04686c" alt=""
data:image/s3,"s3://crabby-images/a4902/a4902e431c9c0f40b802d7896f51f24207c03c37" alt=""
with the Form Factors
data:image/s3,"s3://crabby-images/8337a/8337aa9ce84fe2e2f3e1e137233c5247b633fc3a" alt=""
Instead of BRDF
data:image/s3,"s3://crabby-images/1c2fe/1c2fea4b157fb9ee8e9cd5c83d90ae80273325c4" alt=""
data:image/s3,"s3://crabby-images/0837e/0837e9ee29533f4661917a38ec08a01e9522c86f" alt=""
Instead of radiances
data:image/s3,"s3://crabby-images/784f2/784f2653cffa870545a5023387b245ed0410351b" alt=""
data:image/s3,"s3://crabby-images/14797/1479778648f86b05e40da1d421b89fdcab962407" alt=""
Resulting Radiosity Equation:
data:image/s3,"s3://crabby-images/dae73/dae73faaf299c432d23d7f14dffa815558d725a7" alt=""
data:image/s3,"s3://crabby-images/79000/79000923c9b0054e029e0f98ece7aed71a918020" alt=""
Simplification 2: Spatial Discretization
Assume scene consisting of patches
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/cf36d/cf36d549738939cf2c2925587f13b5bf64f3e4ce" alt=""
Plug the Radiosity Equation into this:
data:image/s3,"s3://crabby-images/3b873/3b8732713ee5a6a78f392517f2b794caa5d24800" alt=""
data:image/s3,"s3://crabby-images/635ec/635ec7931b6c0bac0d17adda5ca4f5f0a7571684" alt=""
We know that
data:image/s3,"s3://crabby-images/5d892/5d892141cf95eace3a8a6c9ce9f2754e223bceb9" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/521e3/521e3e33687049387d8a80736ef7c598ca8f153b" alt=""
data:image/s3,"s3://crabby-images/9cfc6/9cfc6050d42374c0b5e48499e6371e0c0168df08" alt=""
data:image/s3,"s3://crabby-images/33d08/33d08273bd27cf1a9c2b361d41b3561cbc04686c" alt=""
data:image/s3,"s3://crabby-images/a4902/a4902e431c9c0f40b802d7896f51f24207c03c37" alt=""
with the Form Factors
data:image/s3,"s3://crabby-images/8337a/8337aa9ce84fe2e2f3e1e137233c5247b633fc3a" alt=""
Write the Radiosity Equation as a linear system and explain two ways to evaluate it! Which approach is better?
Linear Radiosity System
data:image/s3,"s3://crabby-images/e4bdc/e4bdc052cd7215472785b414bd9d49d4224d5928" alt=""
where
are radiosity values
is emitted radiosity
is a diagonal matrix of reflectance values
is the form factor matrix
Rearrange:
data:image/s3,"s3://crabby-images/e4bdc/e4bdc052cd7215472785b414bd9d49d4224d5928" alt=""
data:image/s3,"s3://crabby-images/c5370/c53707b2e76418d72730ca1cabce9d720004b975" alt=""
data:image/s3,"s3://crabby-images/e0795/e0795f96eb88d875e875e0e61fb0ac10d72007eb" alt=""
data:image/s3,"s3://crabby-images/ae256/ae256ad85808070da257e8ca8bc04034fe9a556a" alt=""
Expand using von-Neumann series
data:image/s3,"s3://crabby-images/dd905/dd90537cf0ed004d2627f9726835bee1453202c8" alt=""
data:image/s3,"s3://crabby-images/40636/40636f32f871a1c8e4a1366f05467758ae1e34b2" alt=""
Gathering
data:image/s3,"s3://crabby-images/921e2/921e2c36450c4c6a3bbf16d4e9f3f19dc528474d" alt=""
data:image/s3,"s3://crabby-images/767d9/767d96b5d8aa43eaf1710268ddeb90865b757dbb" alt=""
Product
requires row-wise evaluation of all form factors in
(
complexity)
Shooting
Idea: Only transport distribute energy from patches with high radiosity. Evaluate one colum of
at a time.
Store a tuple
for each patch:
: accumulated radiosity on patch data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
: unshot radiosity on patch data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
Repeat:
More efficient than Gathering but still
complexity.
data:image/s3,"s3://crabby-images/e4bdc/e4bdc052cd7215472785b414bd9d49d4224d5928" alt=""
where
data:image/s3,"s3://crabby-images/87cb6/87cb62d7a9ee44ec1913ed0abaed653e5d70289b" alt=""
data:image/s3,"s3://crabby-images/320b2/320b2516f9446cfd2e637b1ed258d58447c12536" alt=""
data:image/s3,"s3://crabby-images/2942f/2942f017f9d1a64ab97e0a36951cc509b0b6ef9e" alt=""
data:image/s3,"s3://crabby-images/898b4/898b4e975e71e875fd5e6121605a2888eed4e549" alt=""
Rearrange:
data:image/s3,"s3://crabby-images/e4bdc/e4bdc052cd7215472785b414bd9d49d4224d5928" alt=""
data:image/s3,"s3://crabby-images/c5370/c53707b2e76418d72730ca1cabce9d720004b975" alt=""
data:image/s3,"s3://crabby-images/e0795/e0795f96eb88d875e875e0e61fb0ac10d72007eb" alt=""
data:image/s3,"s3://crabby-images/ae256/ae256ad85808070da257e8ca8bc04034fe9a556a" alt=""
Expand using von-Neumann series
data:image/s3,"s3://crabby-images/dd905/dd90537cf0ed004d2627f9726835bee1453202c8" alt=""
data:image/s3,"s3://crabby-images/40636/40636f32f871a1c8e4a1366f05467758ae1e34b2" alt=""
Gathering
data:image/s3,"s3://crabby-images/921e2/921e2c36450c4c6a3bbf16d4e9f3f19dc528474d" alt=""
data:image/s3,"s3://crabby-images/767d9/767d96b5d8aa43eaf1710268ddeb90865b757dbb" alt=""
Product
data:image/s3,"s3://crabby-images/e2939/e29392317fb95ab198c9d3ddc97ee5649df2a98c" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/07029/07029320e3d47a124e4f65147ebfc864c592a972" alt=""
Shooting
Idea: Only transport distribute energy from patches with high radiosity. Evaluate one colum of
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Store a tuple
data:image/s3,"s3://crabby-images/32096/320967c9a59a62bacdf99703a782d43f02910e30" alt=""
data:image/s3,"s3://crabby-images/fee80/fee801556efc62e71e539cf587130e6ad8563e7d" alt=""
data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
data:image/s3,"s3://crabby-images/06ca8/06ca8ef06f2d620e6390736744b8b0aa8135e07c" alt=""
data:image/s3,"s3://crabby-images/a713b/a713b8d17119c8331826af9339461d0a9752ca75" alt=""
Repeat:
- Pick patch
with highest unshot radiosity
- Update all other patches
:
-
data:image/s3,"s3://crabby-images/76fd6/76fd64c0c8a313e4ea4d16badd6ecb189fd200d6" alt=""
data:image/s3,"s3://crabby-images/c3d3e/c3d3ed22fcc955970de2e13f898763979d609f36" alt=""
More efficient than Gathering but still
data:image/s3,"s3://crabby-images/07029/07029320e3d47a124e4f65147ebfc864c592a972" alt=""
Define the Form Factors for Radiosity! When are the form factors large / small? How are reciprocal form factors related? Give the Flux Equation!
data:image/s3,"s3://crabby-images/5503a/5503a14f41ff62ee3e3f7e5d4efd04d1471d21ac" alt=""
data:image/s3,"s3://crabby-images/1b9da/1b9dae9e6c6cbff179c9af59942e42e8fa076d5c" alt=""
First integral: Averaging over receiver
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/a2bc9/a2bc938510a226d33859c6c6ed6cfe50a6b45b07" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/a2bc9/a2bc938510a226d33859c6c6ed6cfe50a6b45b07" alt=""
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/a2bc9/a2bc938510a226d33859c6c6ed6cfe50a6b45b07" alt=""
Reciprocal Form Factors
data:image/s3,"s3://crabby-images/5503a/5503a14f41ff62ee3e3f7e5d4efd04d1471d21ac" alt=""
data:image/s3,"s3://crabby-images/789ab/789ab5f0c124d27d8b5d8a9470878dfd6976e2dc" alt=""
data:image/s3,"s3://crabby-images/d15df/d15df52140ac795056e3f4ef60f8cda216bb3225" alt=""
data:image/s3,"s3://crabby-images/b1f24/b1f24d52a293c10ecfc553571f4dbbf9d889e4b5" alt=""
Flux Equation
Flux is radiosity times area:
data:image/s3,"s3://crabby-images/048a1/048a1d3cf615dc5b2a1d607209c936cf68d948e2" alt=""
data:image/s3,"s3://crabby-images/7ca49/7ca4979153d06e19afb6ecb78f2e7eb10917ec84" alt=""
Radiosity is flux per area:
data:image/s3,"s3://crabby-images/da562/da5625f64d08be2747348e58e6081b48d077740a" alt=""
data:image/s3,"s3://crabby-images/a7865/a7865c6173e983aaab112336b11b72c5f336e49b" alt=""
data:image/s3,"s3://crabby-images/1da4a/1da4af9d5a1a09c15d18a7359b79a21a89e849bc" alt=""
Explain Hierarchical Radiosity!
Radiosity is very smooth across most patches. Use adaptive refinement to only subdivide where form factors change. Problem: Subdivision leads to
complexity since each patch can interact with each other one.
Solution: Allow interactions across subdivision levels.
Adaptive Refinement
Idea: where form factors are large, subdivide the larger patch
refine(
,
):
if (
&&
)
link(
,
)
else if (
)
if (subdivide(
) >
)
refine(
,
)
refine(
,
)
refine(
,
)
refine(
,
)
else
link(
,
)
else
if (subdivide(
) >
)
refine(
,
)
refine(
,
)
refine(
,
)
refine(
,
)
else
link(
,
)
Solution
Alternatingly, apply to all unsubdivided patches
Gather
gather(
):
.in data:image/s3,"s3://crabby-images/a3697/a369786c6c22c8a2f9256013da2d6f7b070eb6f1" alt=""
for (all links
)
.in
.in +
.out
gather(
)
gather(
)
gather(
)
gather(
)
Push-Pull
pushpull(
)
if (
has children)
push
in
in
.in
in
in
.in
in
in
.in
in
in
.in
recurse
pushpull(
)
pushpull(
)
pushpull(
)
pushpull(
)
pull
data:image/s3,"s3://crabby-images/f3300/f3300d98c8a67aa167cc174e28aa891419662b12" alt=""
else
convert incoming to outgoing radiance
in
data:image/s3,"s3://crabby-images/07029/07029320e3d47a124e4f65147ebfc864c592a972" alt=""
Solution: Allow interactions across subdivision levels.
Adaptive Refinement
Idea: where form factors are large, subdivide the larger patch
refine(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
if (
data:image/s3,"s3://crabby-images/6596e/6596e0fb98b5c23b511be4d5a36bc845bd1b8148" alt=""
data:image/s3,"s3://crabby-images/e9ae9/e9ae94d54ae97c57845846edc017a14ab2a109aa" alt=""
link(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
else if (
data:image/s3,"s3://crabby-images/0065c/0065c09598852cf1ed0e91364ca614d5de370608" alt=""
if (subdivide(
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/1607f/1607f26884edbd07852216f60b9963d4a23a114b" alt=""
refine(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/ec4ca/ec4ca4000e132ec47363b74271e2419b4dc97740" alt=""
refine(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/d5575/d55756e9812ae27f029591a71ef0420e9e939a10" alt=""
refine(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/c2128/c2128275ab1364135986b40044a6556c0573cd85" alt=""
refine(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/54b23/54b23269cd9439a8cf0098d3d1c6222e42d55876" alt=""
else
link(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
else
if (subdivide(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/1607f/1607f26884edbd07852216f60b9963d4a23a114b" alt=""
refine(
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/1aada/1aadaed5a39dd08c9c281c5d05fb703dfc708382" alt=""
refine(
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/835a8/835a873d2fa92f8bdfa61c6bdd79094b00a7277f" alt=""
refine(
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/5aa46/5aa46b997847889d8f6c5ef5a17bae95f54dfac5" alt=""
refine(
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
data:image/s3,"s3://crabby-images/3f1c8/3f1c8bf5ad5a6a6f5b241f10b3c1c9ea71eb0a06" alt=""
else
link(
data:image/s3,"s3://crabby-images/68f99/68f991da2116c7d3e50cc05573c9a850afc53166" alt=""
data:image/s3,"s3://crabby-images/09aed/09aedf8e086e1c26ce7152630cb8dcdbf1ead9f3" alt=""
Solution
Alternatingly, apply to all unsubdivided patches
- Gathering Step
- Push-Pull Step
Gather
gather(
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/a3697/a369786c6c22c8a2f9256013da2d6f7b070eb6f1" alt=""
for (all links
data:image/s3,"s3://crabby-images/6069c/6069c226f3c59cb9bb73f8f912a293cabd5eb7b5" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/6518f/6518fae3d7c6c210d335e6b86fdb0f39df5d7179" alt=""
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
data:image/s3,"s3://crabby-images/d120b/d120b835f1964ef4201a149bf52ff839215e53e3" alt=""
gather(
data:image/s3,"s3://crabby-images/44a1e/44a1e0cbb8e805c4b55aab33d79c652a95a53543" alt=""
gather(
data:image/s3,"s3://crabby-images/81f93/81f93a912ec0f0a32deb4e6bc1b46532c994780e" alt=""
gather(
data:image/s3,"s3://crabby-images/d9cb9/d9cb9784d3736f63bf33887565b62510e098ca15" alt=""
gather(
data:image/s3,"s3://crabby-images/eb28f/eb28f397cc1f19891254779e90db30e8a4c57832" alt=""
Push-Pull
pushpull(
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
if (
data:image/s3,"s3://crabby-images/334f1/334f185e6acfe565b7bc43d7a8712641e9a68c6c" alt=""
push
data:image/s3,"s3://crabby-images/c65e5/c65e5f5745819f72d2c1c331c977d84d88ffe4e3" alt=""
data:image/s3,"s3://crabby-images/6518f/6518fae3d7c6c210d335e6b86fdb0f39df5d7179" alt=""
data:image/s3,"s3://crabby-images/c65e5/c65e5f5745819f72d2c1c331c977d84d88ffe4e3" alt=""
data:image/s3,"s3://crabby-images/bdcb9/bdcb9f7505ebaf68e8dc049c7e184bf9b3d5c455" alt=""
data:image/s3,"s3://crabby-images/34bf4/34bf4eb517d570cd871ff80e6f43725909cfbff2" alt=""
data:image/s3,"s3://crabby-images/6518f/6518fae3d7c6c210d335e6b86fdb0f39df5d7179" alt=""
data:image/s3,"s3://crabby-images/34bf4/34bf4eb517d570cd871ff80e6f43725909cfbff2" alt=""
data:image/s3,"s3://crabby-images/bdcb9/bdcb9f7505ebaf68e8dc049c7e184bf9b3d5c455" alt=""
data:image/s3,"s3://crabby-images/af65e/af65eb6dc8dd309590b6ad541d62b303789d213f" alt=""
data:image/s3,"s3://crabby-images/6518f/6518fae3d7c6c210d335e6b86fdb0f39df5d7179" alt=""
data:image/s3,"s3://crabby-images/af65e/af65eb6dc8dd309590b6ad541d62b303789d213f" alt=""
data:image/s3,"s3://crabby-images/bdcb9/bdcb9f7505ebaf68e8dc049c7e184bf9b3d5c455" alt=""
data:image/s3,"s3://crabby-images/67156/671565d163f90946b9b2ccb7a8f18685775ceff1" alt=""
data:image/s3,"s3://crabby-images/6518f/6518fae3d7c6c210d335e6b86fdb0f39df5d7179" alt=""
data:image/s3,"s3://crabby-images/67156/671565d163f90946b9b2ccb7a8f18685775ceff1" alt=""
data:image/s3,"s3://crabby-images/bdcb9/bdcb9f7505ebaf68e8dc049c7e184bf9b3d5c455" alt=""
recurse
pushpull(
data:image/s3,"s3://crabby-images/44a1e/44a1e0cbb8e805c4b55aab33d79c652a95a53543" alt=""
pushpull(
data:image/s3,"s3://crabby-images/81f93/81f93a912ec0f0a32deb4e6bc1b46532c994780e" alt=""
pushpull(
data:image/s3,"s3://crabby-images/d9cb9/d9cb9784d3736f63bf33887565b62510e098ca15" alt=""
pushpull(
data:image/s3,"s3://crabby-images/eb28f/eb28f397cc1f19891254779e90db30e8a4c57832" alt=""
pull
data:image/s3,"s3://crabby-images/f3300/f3300d98c8a67aa167cc174e28aa891419662b12" alt=""
else
convert incoming to outgoing radiance
data:image/s3,"s3://crabby-images/a52cd/a52cd0c83bbe9fa3256f8939828011d2eb4c69aa" alt=""
Explain the de Casteljau algorithm!
de Casteljau algorithm gives a geometric procedure to construct points on Bézier curves.
Example: Given control points
(cubic spline), we compute
data:image/s3,"s3://crabby-images/59c29/59c299df9203e855f5ee657bd2675a411577fdd4" alt=""
data:image/s3,"s3://crabby-images/80109/8010962ea27e627de354820ae86762a6710c3bde" alt=""
data:image/s3,"s3://crabby-images/82264/822641f7652a1ec9b67bacbbbfab0639a23b3878" alt=""
data:image/s3,"s3://crabby-images/46c1d/46c1df604e6ce66ded5a83dbaf113bca0be0880c" alt=""
data:image/s3,"s3://crabby-images/bee6d/bee6d7b05ce1151ca8650210b8a922e732d4cd2b" alt=""
data:image/s3,"s3://crabby-images/df704/df704611f5545de20537ebd491e12d16617b1322" alt=""
Note how this schema iteratively evaluates the Bernstein polynomials for all coefficients:
data:image/s3,"s3://crabby-images/6c292/6c2929c5497ff0b8cbeb8b730cb1dfb7f8bdcf28" alt=""
data:image/s3,"s3://crabby-images/82bd0/82bd0a79960b583c5173f1d42d7b536c41d5aa0e" alt=""
Useful properties:
Example: Given control points
data:image/s3,"s3://crabby-images/c4a8c/c4a8cfb9739c5278b9dc81d44c912d187a6b966a" alt=""
data:image/s3,"s3://crabby-images/59c29/59c299df9203e855f5ee657bd2675a411577fdd4" alt=""
data:image/s3,"s3://crabby-images/80109/8010962ea27e627de354820ae86762a6710c3bde" alt=""
data:image/s3,"s3://crabby-images/82264/822641f7652a1ec9b67bacbbbfab0639a23b3878" alt=""
data:image/s3,"s3://crabby-images/46c1d/46c1df604e6ce66ded5a83dbaf113bca0be0880c" alt=""
data:image/s3,"s3://crabby-images/bee6d/bee6d7b05ce1151ca8650210b8a922e732d4cd2b" alt=""
data:image/s3,"s3://crabby-images/df704/df704611f5545de20537ebd491e12d16617b1322" alt=""
Note how this schema iteratively evaluates the Bernstein polynomials for all coefficients:
data:image/s3,"s3://crabby-images/6c292/6c2929c5497ff0b8cbeb8b730cb1dfb7f8bdcf28" alt=""
data:image/s3,"s3://crabby-images/82bd0/82bd0a79960b583c5173f1d42d7b536c41d5aa0e" alt=""
Useful properties:
- Numerically robust: Sequence of affine combinations (instead of sum of scaled polynomial coefficients)
- First derivative:
What are spline curves? How are spline curves constructed from Bézier curves?
Spline curves: Piecewise polynomial curves which are maximally smooth:
Polynomial degree
continuous
Constructing Spline curves
This allows to create a cubic spline curve by only specifying A-frame vertices:
Polynomial degree
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/6760f/6760f144661828dd1b6677beb48d89333bb9cfa3" alt=""
data:image/s3,"s3://crabby-images/e96c3/e96c39b0c3298275304cd3becaa54518eacc481c" alt=""
Constructing Spline curves
- Degree 1: Linear segments. Connect endpoints for
- Degree 2: Quadratic segments. Connect endpoints for
- Degree 3: Cubic segments. Connect endpoints for
data:image/s3,"s3://crabby-images/859c2/859c24391338327dc75b1677f4e8df03d325f04c" alt=""
data:image/s3,"s3://crabby-images/859c2/859c24391338327dc75b1677f4e8df03d325f04c" alt=""
data:image/s3,"s3://crabby-images/1efd5/1efd51a5702bf5114a6e45b5ebf5c3942160824b" alt=""
data:image/s3,"s3://crabby-images/859c2/859c24391338327dc75b1677f4e8df03d325f04c" alt=""
data:image/s3,"s3://crabby-images/1efd5/1efd51a5702bf5114a6e45b5ebf5c3942160824b" alt=""
data:image/s3,"s3://crabby-images/c79d8/c79d8c65dd088ceebcbc2b6f066a876d9e8faaf2" alt=""
This allows to create a cubic spline curve by only specifying A-frame vertices:
- Connect A-frame vertices by edges and split 1:1:1
- Add edges between each first and last vertex between neighboring edges and split 1:1
- Connect each 4 vertices with one cubic spline
How to create Freeform Surfaces from Bézier curves?
Tensor Product Patches
given a grid of coefficients
for
,
, compute a surface data:image/s3,"s3://crabby-images/b891c/b891ce1f4bcfbd26dab33b4ed20ddd43fb514231" alt=""
First, compute interpolated control points
for parameter
:
data:image/s3,"s3://crabby-images/7611e/7611e07c2f5f1ad85b005f04bfa0420604505c47" alt=""
Then, compute the interpolated point along the curve of the generated control points
for parameter
:
data:image/s3,"s3://crabby-images/2e2dd/2e2ddc177719130369b1752cc192340371d3a20a" alt=""
data:image/s3,"s3://crabby-images/d052a/d052a87cccf4ac1f476bbb7ce51fd91a9ee957a6" alt=""
data:image/s3,"s3://crabby-images/f18cf/f18cfce08f03c0ddf91c1b6ea6f2abeb511a9922" alt=""
data:image/s3,"s3://crabby-images/777e9/777e9f60770397e84e40f382a77bd976e768d6e8" alt=""
tensor
given a grid of coefficients
data:image/s3,"s3://crabby-images/2c07d/2c07d9113de279dfde4eb4d2f690db9e4ba56596" alt=""
data:image/s3,"s3://crabby-images/fcdbb/fcdbb174b5e80d68e0f1b4c8caa98df6909f5967" alt=""
data:image/s3,"s3://crabby-images/09370/093702716dc817c60976342cbcd3b0987f5518ef" alt=""
data:image/s3,"s3://crabby-images/b891c/b891ce1f4bcfbd26dab33b4ed20ddd43fb514231" alt=""
First, compute interpolated control points
data:image/s3,"s3://crabby-images/3c02c/3c02c2d71fa93ed3c7aff2a42d0968ac47d687e3" alt=""
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/7611e/7611e07c2f5f1ad85b005f04bfa0420604505c47" alt=""
Then, compute the interpolated point along the curve of the generated control points
data:image/s3,"s3://crabby-images/3c02c/3c02c2d71fa93ed3c7aff2a42d0968ac47d687e3" alt=""
data:image/s3,"s3://crabby-images/27110/271106d9bf9e93f1f430f13629d765e47cf88746" alt=""
data:image/s3,"s3://crabby-images/2e2dd/2e2ddc177719130369b1752cc192340371d3a20a" alt=""
data:image/s3,"s3://crabby-images/d052a/d052a87cccf4ac1f476bbb7ce51fd91a9ee957a6" alt=""
data:image/s3,"s3://crabby-images/f18cf/f18cfce08f03c0ddf91c1b6ea6f2abeb511a9922" alt=""
data:image/s3,"s3://crabby-images/777e9/777e9f60770397e84e40f382a77bd976e768d6e8" alt=""
tensor
How to compute an interpolating spline curve?
Exploit endpoint interpolation of spline segments. Compute positions for spline control points
such that the positions of spline endpoints match the desired interpolation positions
.
Example: Cubic splines
Given spline control points
, we can compute the position of the closest spline endpoint as
data:image/s3,"s3://crabby-images/e751f/e751f0a9c071938ee68eed3c9dacd8cbc3a6408b" alt=""
Set up a linear system
data:image/s3,"s3://crabby-images/11715/1171569e99329210466f722b8048ea75ea4cefff" alt=""
data:image/s3,"s3://crabby-images/21fb6/21fb659316c352faf32abe20d3c9dd3e7904ddf7" alt=""
and solve for
.
data:image/s3,"s3://crabby-images/fee80/fee801556efc62e71e539cf587130e6ad8563e7d" alt=""
data:image/s3,"s3://crabby-images/704f2/704f2dfcd44885620550b8959ef7876a43e08e7c" alt=""
Example: Cubic splines
Given spline control points
data:image/s3,"s3://crabby-images/19096/1909682ae3aea040f43894866bd63d6d9312d36a" alt=""
data:image/s3,"s3://crabby-images/e751f/e751f0a9c071938ee68eed3c9dacd8cbc3a6408b" alt=""
Set up a linear system
data:image/s3,"s3://crabby-images/11715/1171569e99329210466f722b8048ea75ea4cefff" alt=""
data:image/s3,"s3://crabby-images/21fb6/21fb659316c352faf32abe20d3c9dd3e7904ddf7" alt=""
and solve for
data:image/s3,"s3://crabby-images/fee80/fee801556efc62e71e539cf587130e6ad8563e7d" alt=""
What types of culling are there?
Back-face culling
Skipping polygons which face away from the viewer (on back sides of objects)
View frustum culling
Skipping objects which are outside the region covered by the camera view frustum
(often used in conjunction with appropriate hierarchical optimization structures)
Portal culling
Only rendering objects which are visible inside a restricted region of the current view frustum, generated by the shape of a portal
1. render current room
2. for all portals of the current room inside the current frustum: narrow down the frustum and repeat step 1 in the room behind the respective portal
Occlusion culling
Skipping objects which are in the viewing frustum but hidden by other objects in front of it
Skipping polygons which face away from the viewer (on back sides of objects)
View frustum culling
Skipping objects which are outside the region covered by the camera view frustum
(often used in conjunction with appropriate hierarchical optimization structures)
Portal culling
Only rendering objects which are visible inside a restricted region of the current view frustum, generated by the shape of a portal
1. render current room
2. for all portals of the current room inside the current frustum: narrow down the frustum and repeat step 1 in the room behind the respective portal
Occlusion culling
Skipping objects which are in the viewing frustum but hidden by other objects in front of it
Explain Shadow Mapping! What problem is solved by Perspective Shadow Mapping, and how?
Insight: Shadowing is a visibility problem like the one for rendering in general.
Problem: Discretization of off-screen depth buffer leads to aliasing artifacts. The size of one texel of the shadow map in the final camera image is given by the following approximation:
data:image/s3,"s3://crabby-images/d6b2c/d6b2c9881d3bcd2449c00b8c7ee5e4981ff95731" alt=""
: shadow map resolution
: distance from light source to shadow surface (affects Perspective Aliasing)
: angle between shadow surface and shadow map projection plane normal (affects Projective Aliasing)
: angle between shadow surface and image plane normal (affects Projective Aliasing)
: distance from shadow surface to camera (affects Perspective Aliasing)
can be decreased at the cost of memory / computation
can not be changed.
Goal: make
as large as possible.
Solution: Apply the frustum transform of the camera to the scene before shadow map rendering and lookup. This effectively moves the camera center to infinity and thus minimizes the Perspective Aliasing caused by the camera distance.
- Render scene from the position of the light source into an off-screen depth buffer
- Render scene from the camera view. For every pixel: Compute position w.r.t. view from light source. Look up depth value from off-screen depth buffer. If
, the pixel is in shadow.
Problem: Discretization of off-screen depth buffer leads to aliasing artifacts. The size of one texel of the shadow map in the final camera image is given by the following approximation:
data:image/s3,"s3://crabby-images/d6b2c/d6b2c9881d3bcd2449c00b8c7ee5e4981ff95731" alt=""
data:image/s3,"s3://crabby-images/029cb/029cb2536e0d333327ad81e774958fa11552cbd0" alt=""
data:image/s3,"s3://crabby-images/4174c/4174c8dcef43bd3e904fa84b9bf5a4df033a332b" alt=""
data:image/s3,"s3://crabby-images/c2483/c24837036941ddfe49a85713877f5e075ffca037" alt=""
data:image/s3,"s3://crabby-images/2ddba/2ddbaec639213ead3595e9760a0dd50e8acf64f4" alt=""
data:image/s3,"s3://crabby-images/a4ae6/a4ae6d3a1a33921e96bc679b19b8b113c1bcea47" alt=""
data:image/s3,"s3://crabby-images/029cb/029cb2536e0d333327ad81e774958fa11552cbd0" alt=""
data:image/s3,"s3://crabby-images/3e075/3e0750a1316d32209c516959505f2ec8e0932c84" alt=""
Goal: make
data:image/s3,"s3://crabby-images/a4ae6/a4ae6d3a1a33921e96bc679b19b8b113c1bcea47" alt=""
Solution: Apply the frustum transform of the camera to the scene before shadow map rendering and lookup. This effectively moves the camera center to infinity and thus minimizes the Perspective Aliasing caused by the camera distance.
What are advantages and disadvantages of Shadow Maps and Shadow Volumes?
Shadow Maps | Shadow Volumes |
any shadow geometry | shadow geometry must be manifold poly-mesh |
omni-directional lights require multiple shadow maps | omni-directional lights are no special case |
requires additional resources (off-screen depth textures) | requires additional computation (projecting shadow volumes) |
aliasing / depth bias artifacts | exact shadows |
What is a 2-manifold? How can you tell whether a triangle mesh is a 2-manifold?
Two-manifold: A surface where every local vicinity is homeomorphic to a disc.
Triangle mesh criteria for 2-manifoldness:
Triangle mesh criteria for 2-manifoldness:
- the interior of faces is flat and hence homeomorphic to a disc
- at every edge, there must be exactly 2 adjacent faces (except for boundary edges with 1 adjacent face)
- every vertex must have a uniquely defined 1-ring neighborhood
What is the genus of an object?
- The number of "handles" of the object
- The maximum number of times one can cut a closed loop through the surface until the object falls apart into two parts, minus one
- For a polygon mesh:
The genus is a tolopogical, not a geometrical property of an object
Give the Euler Formula and prove it!
data:image/s3,"s3://crabby-images/e9f87/e9f8721b482766092a4e196552e727494d29dd68" alt=""
Start with a closed mesh with genus 0: 1 vertex surrounded by 1 face:
data:image/s3,"s3://crabby-images/9d202/9d202a2049c9e5f836fa4e732a1983ef61423798" alt=""
Three fundamental operation for extending the mesh:
Add new vertex connected by one edge
data:image/s3,"s3://crabby-images/83c09/83c094795f2d9f3f15d487e3b42fa6a19182d966" alt=""
Connect two existing vertices by a new edge
data:image/s3,"s3://crabby-images/8b1d9/8b1d99f9af29311423ab97da946d95eb98490985" alt=""
Genus change: Connect two holes (i.e. faces) by one new edge, thus merging the two holes into one
data:image/s3,"s3://crabby-images/1329a/1329a7f928e01f39f3548f1e55da3ec9d5118646" alt=""
data:image/s3,"s3://crabby-images/6b988/6b988fff2bfdd22b388ee1373bc7e3f9fce038f0" alt=""
Give the Euler Formula and derive the three Magic Numbers!
data:image/s3,"s3://crabby-images/e9f87/e9f8721b482766092a4e196552e727494d29dd68" alt=""
Magic Number: 2 times as many faces as vertices
data:image/s3,"s3://crabby-images/71802/71802a8bcd43e3cfff745d4abad73c128e257576" alt=""
data:image/s3,"s3://crabby-images/6e1c8/6e1c8f15c9c854267367bfc45f773b429a8d127c" alt=""
data:image/s3,"s3://crabby-images/49f37/49f371b23bb7be177bff1625bfb8e143365c64c9" alt=""
data:image/s3,"s3://crabby-images/a105f/a105f417a14cb48a6f1be683e47523240c6c46c4" alt=""
data:image/s3,"s3://crabby-images/1c0ea/1c0ea4d97df5790408d444fd41ff9359eff3d219" alt=""
data:image/s3,"s3://crabby-images/26bd3/26bd30d56c8cca6cb11fec6a3261d161b16f4214" alt=""
data:image/s3,"s3://crabby-images/03d1a/03d1af9b6fd9ddac3a745463e0b45b8f4f6742a5" alt=""
data:image/s3,"s3://crabby-images/9006c/9006c2341c04a13b144739da6d3c1587edce6d3e" alt=""
Magic Number: Average vertex valence is 6
data:image/s3,"s3://crabby-images/71802/71802a8bcd43e3cfff745d4abad73c128e257576" alt=""
data:image/s3,"s3://crabby-images/eca71/eca71bb0ea54b58641280ab360ebe5d8c95dc9ca" alt=""
data:image/s3,"s3://crabby-images/49f37/49f371b23bb7be177bff1625bfb8e143365c64c9" alt=""
data:image/s3,"s3://crabby-images/72b0c/72b0cd743d6e772599f253d63a880ec91c7f0aad" alt=""
data:image/s3,"s3://crabby-images/24a95/24a952cee02d3460fefc2ff59267b5da0fbebcbf" alt=""
data:image/s3,"s3://crabby-images/4d800/4d8006b8e0b44690dca3a7f6ed6e9d59a104a0b7" alt=""
data:image/s3,"s3://crabby-images/d3ed3/d3ed36545dbc0887813b1982d22240fd5bb6aae3" alt=""
Magic Number: 5 platonic solids
A platonic solids with Schläfli symbol
data:image/s3,"s3://crabby-images/26274/26274a1c9c0d9a2a11a047f4925c5e501568dff1" alt=""
-
- All faces are
-gons:
(where
)
- All vertices have valence
:
(where
)
data:image/s3,"s3://crabby-images/e9f87/e9f8721b482766092a4e196552e727494d29dd68" alt=""
data:image/s3,"s3://crabby-images/5f6fa/5f6faeb441aa2ac7f897266a4f0a03dbb6823dd6" alt=""
data:image/s3,"s3://crabby-images/86d43/86d43900d949f9bdd517ec5c71fdfc50d05ad9ed" alt=""
data:image/s3,"s3://crabby-images/c1b6b/c1b6b08ac7c684b4e290c8bc20d844426ca0b5f0" alt=""
data:image/s3,"s3://crabby-images/006d2/006d21021290ab551e1a5d6430b72da63fb6dec8" alt=""
data:image/s3,"s3://crabby-images/b99ab/b99abc4d21d4fbcb1a79ac4fa4fd5f057ac999be" alt=""
Number of edges cannot be negative:
data:image/s3,"s3://crabby-images/5a3d8/5a3d844e21edec71c629a981db4d0224c369081b" alt=""
Since
data:image/s3,"s3://crabby-images/eba47/eba475a6adfe012ef60785631984b0ee00e71909" alt=""
data:image/s3,"s3://crabby-images/a808e/a808ed302454cfff32b5e243b06f7f042560e487" alt=""
data:image/s3,"s3://crabby-images/2391a/2391aee731655cb83468c748930a430f4586b545" alt=""
data:image/s3,"s3://crabby-images/d5fc6/d5fc6e9833c22ae6326c23ba0694edd749017379" alt=""
Gives only 5 solutions for
data:image/s3,"s3://crabby-images/6981d/6981dbe02e269950fe4eb132d25d72f545a2fff8" alt=""
-
: Tetrahedron (4 triangular faces, self-dual)
-
: Octahedron (8 triangular faces, dual to Cube)
-
: Cube (6 square faces, dual to Octahedron)
-
: Icosahedron (20 triangular faces, dual to Dodecahedron)
-
: Dodecahedron (12 pentagonal faces, dual to Icosahedron)
In what ways can we represent 3D models?
- Polygonal meshes
- Point clouds
- Volumetric representations
- Constructive Solid Geometry
- Freeform curves / surfaces
How are 3D volumes be represented using quadrics? Give the quadrics for spheres, cylinders, cones! How are quadrics transformed? How to compute ray / quadric intersections?
Scalar function
. Inside < 0, surface = 0, outside > 0. All quadratic trivariate functions are given by
data:image/s3,"s3://crabby-images/e185e/e185eb70fffa0ffb982ce00fa4e63597bd27ec77" alt=""
or
data:image/s3,"s3://crabby-images/9c828/9c8280a07eabd80713041d8eb3d4731b50c55f0b" alt=""
or
data:image/s3,"s3://crabby-images/267e9/267e9780ea3a23cb411ba4025435fb0931201527" alt=""
or
data:image/s3,"s3://crabby-images/6aaa2/6aaa230e2be7cd8e0e3dce8611f1763a3d138b16" alt=""
Sphere
at center
with radius
:
data:image/s3,"s3://crabby-images/63843/6384380df653fb730483214a5a806985335b2ee4" alt=""
data:image/s3,"s3://crabby-images/9314c/9314c74b92a64c42896c8d1a430483a984194da1" alt=""
data:image/s3,"s3://crabby-images/7a4f6/7a4f6052c2c7660f71cbe13c0eeb892c2c662c6a" alt=""
Cylinder
along the
axis around
with radius
:
data:image/s3,"s3://crabby-images/b7708/b77082be14b831d5b6c9fe6c3d0b97074b2c77f3" alt=""
data:image/s3,"s3://crabby-images/f2ba4/f2ba4682a7e6916abe34f441832c424ddc6f1f10" alt=""
data:image/s3,"s3://crabby-images/3e28e/3e28e704347135353567c53a6ab5054237dfdc61" alt=""
Cone
apex at
, opening along the
axis with an angle of data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/23cd5/23cd588adb571afcca33cc9247bcbd36a587a5c8" alt=""
data:image/s3,"s3://crabby-images/8dd3c/8dd3c46fb26722e12e8ec6e7c8499db61bf1cecb" alt=""
data:image/s3,"s3://crabby-images/c4308/c43087f4b25ecfe26e9b906bbbfa69516108194a" alt=""
Quadric Transformation
Given a point
on the surface of a quadric
:
data:image/s3,"s3://crabby-images/f9a2c/f9a2c1aac9fb5c12b7d59a55a6db7cfce5e7e2ba" alt=""
we apply a transformation to
:
data:image/s3,"s3://crabby-images/a7f10/a7f107488b20131f704ba2a18fc69558b5e37cac" alt=""
we obtain
data:image/s3,"s3://crabby-images/a8c16/a8c1606ed5b8c5547b262dd617d8ec478e58bf2f" alt=""
data:image/s3,"s3://crabby-images/9012b/9012b93be08c70424b86bd824a1452a912e35ea7" alt=""
data:image/s3,"s3://crabby-images/9982c/9982c3baf175fb4f0cfbefa538f5326da68d8122" alt=""
Thus, the quadric after application of the transformation is:
data:image/s3,"s3://crabby-images/c2e88/c2e8869163f99afb9e6af0080b68908be8f90f46" alt=""
Ray / Quadric Intersections
data:image/s3,"s3://crabby-images/f88ba/f88ba72cecfdd651e5f57a62f5d8dcbadd0b7597" alt=""
data:image/s3,"s3://crabby-images/235af/235afebde71d1fea845d4d0eb40c98c16da32dea" alt=""
data:image/s3,"s3://crabby-images/35967/35967ae964e28175860c512aca4bb92deebeccfe" alt=""
data:image/s3,"s3://crabby-images/b4dbd/b4dbde50228c19fe058b9f62efa4998bb6e4c8ef" alt=""
Has 0, 1, or 2 real solutions.
data:image/s3,"s3://crabby-images/e5a58/e5a5898ee01a5b06a68fb918ced46c058a857c7b" alt=""
data:image/s3,"s3://crabby-images/e185e/e185eb70fffa0ffb982ce00fa4e63597bd27ec77" alt=""
or
data:image/s3,"s3://crabby-images/9c828/9c8280a07eabd80713041d8eb3d4731b50c55f0b" alt=""
or
data:image/s3,"s3://crabby-images/267e9/267e9780ea3a23cb411ba4025435fb0931201527" alt=""
or
data:image/s3,"s3://crabby-images/6aaa2/6aaa230e2be7cd8e0e3dce8611f1763a3d138b16" alt=""
Sphere
at center
data:image/s3,"s3://crabby-images/ec295/ec295b5c2c38e1c0d3f497f072a812586eb8b631" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
data:image/s3,"s3://crabby-images/63843/6384380df653fb730483214a5a806985335b2ee4" alt=""
data:image/s3,"s3://crabby-images/9314c/9314c74b92a64c42896c8d1a430483a984194da1" alt=""
data:image/s3,"s3://crabby-images/7a4f6/7a4f6052c2c7660f71cbe13c0eeb892c2c662c6a" alt=""
Cylinder
along the
data:image/s3,"s3://crabby-images/e56c6/e56c6d687475c5442a7bf578c09cff67e2aa1283" alt=""
data:image/s3,"s3://crabby-images/22dfd/22dfd722f03fe17dc9dd72735e21678047eb40b7" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
data:image/s3,"s3://crabby-images/b7708/b77082be14b831d5b6c9fe6c3d0b97074b2c77f3" alt=""
data:image/s3,"s3://crabby-images/f2ba4/f2ba4682a7e6916abe34f441832c424ddc6f1f10" alt=""
data:image/s3,"s3://crabby-images/3e28e/3e28e704347135353567c53a6ab5054237dfdc61" alt=""
Cone
apex at
data:image/s3,"s3://crabby-images/ec295/ec295b5c2c38e1c0d3f497f072a812586eb8b631" alt=""
data:image/s3,"s3://crabby-images/e56c6/e56c6d687475c5442a7bf578c09cff67e2aa1283" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/23cd5/23cd588adb571afcca33cc9247bcbd36a587a5c8" alt=""
data:image/s3,"s3://crabby-images/8dd3c/8dd3c46fb26722e12e8ec6e7c8499db61bf1cecb" alt=""
data:image/s3,"s3://crabby-images/c4308/c43087f4b25ecfe26e9b906bbbfa69516108194a" alt=""
Quadric Transformation
Given a point
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/fd0da/fd0da2a1b90b1e240fee0d3fd2d01477a630313c" alt=""
data:image/s3,"s3://crabby-images/f9a2c/f9a2c1aac9fb5c12b7d59a55a6db7cfce5e7e2ba" alt=""
we apply a transformation to
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/a7f10/a7f107488b20131f704ba2a18fc69558b5e37cac" alt=""
we obtain
data:image/s3,"s3://crabby-images/a8c16/a8c1606ed5b8c5547b262dd617d8ec478e58bf2f" alt=""
data:image/s3,"s3://crabby-images/9012b/9012b93be08c70424b86bd824a1452a912e35ea7" alt=""
data:image/s3,"s3://crabby-images/9982c/9982c3baf175fb4f0cfbefa538f5326da68d8122" alt=""
Thus, the quadric after application of the transformation is:
data:image/s3,"s3://crabby-images/c2e88/c2e8869163f99afb9e6af0080b68908be8f90f46" alt=""
Ray / Quadric Intersections
data:image/s3,"s3://crabby-images/f88ba/f88ba72cecfdd651e5f57a62f5d8dcbadd0b7597" alt=""
data:image/s3,"s3://crabby-images/235af/235afebde71d1fea845d4d0eb40c98c16da32dea" alt=""
data:image/s3,"s3://crabby-images/35967/35967ae964e28175860c512aca4bb92deebeccfe" alt=""
data:image/s3,"s3://crabby-images/b4dbd/b4dbde50228c19fe058b9f62efa4998bb6e4c8ef" alt=""
Has 0, 1, or 2 real solutions.
Define the three basic CSG operations!
Given volumetric representations
where
if
outside
if
on the surface
if
inside
Uniondata:image/s3,"s3://crabby-images/6ca09/6ca09f4452953517bc2ada60b05f47de6bd5b68d" alt=""
data:image/s3,"s3://crabby-images/f683b/f683b54bf79496c6efeddc8eaab9f846baa1426f" alt=""
Intersectiondata:image/s3,"s3://crabby-images/29a5d/29a5d301a26421da57daed01551212fba629efcb" alt=""
data:image/s3,"s3://crabby-images/1f8a5/1f8a5792f6cc7e8bf69451b1956c84ebfe4dbcf5" alt=""
Differencedata:image/s3,"s3://crabby-images/07225/07225f6c69303181955898dd6c07083eb36c820c" alt=""
data:image/s3,"s3://crabby-images/a049a/a049a4c217280a5d2f5787cf71757bf84e1aa0e7" alt=""
data:image/s3,"s3://crabby-images/73960/73960b93989f2dfef977ad872300c59a9811e466" alt=""
data:image/s3,"s3://crabby-images/6fa4c/6fa4cc212bbcf54b87959824f63d0c5a0c16484f" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/46548/46548ac97081547103929e3a942c1fa43fbf5260" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/ff635/ff6355549f0039faad1551306c529d6f07fee728" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
Union
data:image/s3,"s3://crabby-images/6ca09/6ca09f4452953517bc2ada60b05f47de6bd5b68d" alt=""
data:image/s3,"s3://crabby-images/f683b/f683b54bf79496c6efeddc8eaab9f846baa1426f" alt=""
Intersection
data:image/s3,"s3://crabby-images/29a5d/29a5d301a26421da57daed01551212fba629efcb" alt=""
data:image/s3,"s3://crabby-images/1f8a5/1f8a5792f6cc7e8bf69451b1956c84ebfe4dbcf5" alt=""
Difference
data:image/s3,"s3://crabby-images/07225/07225f6c69303181955898dd6c07083eb36c820c" alt=""
data:image/s3,"s3://crabby-images/a049a/a049a4c217280a5d2f5787cf71757bf84e1aa0e7" alt=""
Name the main approaches for rendering volumetric representations!
Direct Rendering
Indirect Rendering
- Ray Casting (backward mapping)
- Slicing (forward mapping)
Indirect Rendering
- Isosurface Extraction (Marching Cubes)
Explain Volume Ray Casting!
Volume Rendering Integral
Given functions for color
and opacity
(where 0 = transparent and
= opaque), the color for a ray
is given by
data:image/s3,"s3://crabby-images/ca5c3/ca5c3d8d88773b63c75bbeaff6fe5af0b13fbea8" alt=""
data:image/s3,"s3://crabby-images/92e27/92e27e2fb6cadf29f6ade27df55a8d9900fc0cbc" alt=""
data:image/s3,"s3://crabby-images/acb96/acb96d3d50a757bc8be49d6c6106a36a53cb720f" alt=""
Discretization
data:image/s3,"s3://crabby-images/3f399/3f399e322d2db2de66372343c53b2a06b62d0196" alt=""
data:image/s3,"s3://crabby-images/32494/324941e7793c8424913bcc5924adfd3676bbd5f0" alt=""
: opacity (0 = transparent,
= opaque)
: normalized transparency (0 = opaque, 1 = transparent)
: normalized opacity (0 = transparent, 1 = opaque)
data:image/s3,"s3://crabby-images/39ab6/39ab636adcc3b9c048148738b9c9e64603f66814" alt=""
We only want opaque pixels to emit color:
data:image/s3,"s3://crabby-images/f3b72/f3b7215c3db20e5680a591823d84cefa912d8c5f" alt=""
Volume Rendering Integral
Given functions for color
and opacity
(where 0 = transparent and
= opaque), the color for a ray
is given by
data:image/s3,"s3://crabby-images/ca5c3/ca5c3d8d88773b63c75bbeaff6fe5af0b13fbea8" alt=""
data:image/s3,"s3://crabby-images/92e27/92e27e2fb6cadf29f6ade27df55a8d9900fc0cbc" alt=""
data:image/s3,"s3://crabby-images/acb96/acb96d3d50a757bc8be49d6c6106a36a53cb720f" alt=""
Discretization
data:image/s3,"s3://crabby-images/3f399/3f399e322d2db2de66372343c53b2a06b62d0196" alt=""
data:image/s3,"s3://crabby-images/32494/324941e7793c8424913bcc5924adfd3676bbd5f0" alt=""
: opacity (0 = transparent,
= opaque)
: normalized transparency (0 = opaque, 1 = transparent)
: normalized opacity (0 = transparent, 1 = opaque)
data:image/s3,"s3://crabby-images/39ab6/39ab636adcc3b9c048148738b9c9e64603f66814" alt=""
We only want opaque pixels to emit color:
data:image/s3,"s3://crabby-images/f3b72/f3b7215c3db20e5680a591823d84cefa912d8c5f" alt=""
Back-to-Front Evaluation
Start:
data:image/s3,"s3://crabby-images/4fafb/4fafbd25aed8cbcce73b636edcb230e00316221a" alt=""
Update:
data:image/s3,"s3://crabby-images/24520/245200908999d518cbae255abea1679bc0a7fbf7" alt=""
Front-to-Back Evaluation
Start:
data:image/s3,"s3://crabby-images/bfbf7/bfbf7650405031e69e56cddcc7d86dd8b448e8bc" alt=""
data:image/s3,"s3://crabby-images/f3e9b/f3e9b6c1b1d58f3f2814329cdf4b3fe35190daac" alt=""
Update:
data:image/s3,"s3://crabby-images/dca35/dca35a1e2a5eb826f7ad590a2b96543f1b2b861c" alt=""
data:image/s3,"s3://crabby-images/31805/31805b25f6541d1e085c383748024a261c98fac7" alt=""
Early abort ifdata:image/s3,"s3://crabby-images/ef889/ef88945abb0f70dab5dcc6df93e42cd77ed68ef7" alt=""
Given functions for color
data:image/s3,"s3://crabby-images/ece8c/ece8c220e6280f12c5e33477040958a8cd16f565" alt=""
data:image/s3,"s3://crabby-images/53bfb/53bfb4fcc7b8f9f16d231277d63b72eec338226b" alt=""
data:image/s3,"s3://crabby-images/56561/5656181d195c30da01783edbd7b71caab38cf39b" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
data:image/s3,"s3://crabby-images/ca5c3/ca5c3d8d88773b63c75bbeaff6fe5af0b13fbea8" alt=""
data:image/s3,"s3://crabby-images/92e27/92e27e2fb6cadf29f6ade27df55a8d9900fc0cbc" alt=""
data:image/s3,"s3://crabby-images/acb96/acb96d3d50a757bc8be49d6c6106a36a53cb720f" alt=""
Discretization
data:image/s3,"s3://crabby-images/3f399/3f399e322d2db2de66372343c53b2a06b62d0196" alt=""
data:image/s3,"s3://crabby-images/32494/324941e7793c8424913bcc5924adfd3676bbd5f0" alt=""
data:image/s3,"s3://crabby-images/0b557/0b55778d850015e35a6fe0bd0ce79916f9dc5f1a" alt=""
data:image/s3,"s3://crabby-images/56561/5656181d195c30da01783edbd7b71caab38cf39b" alt=""
data:image/s3,"s3://crabby-images/eee05/eee059ba5450fb806ec5b5bd00746373229d79d5" alt=""
data:image/s3,"s3://crabby-images/fc44d/fc44d6a10f665ae5442a490322639c416cabb2bb" alt=""
data:image/s3,"s3://crabby-images/39ab6/39ab636adcc3b9c048148738b9c9e64603f66814" alt=""
We only want opaque pixels to emit color:
data:image/s3,"s3://crabby-images/f3b72/f3b7215c3db20e5680a591823d84cefa912d8c5f" alt=""
Volume Rendering Integral
Given functions for color
data:image/s3,"s3://crabby-images/ece8c/ece8c220e6280f12c5e33477040958a8cd16f565" alt=""
data:image/s3,"s3://crabby-images/53bfb/53bfb4fcc7b8f9f16d231277d63b72eec338226b" alt=""
data:image/s3,"s3://crabby-images/56561/5656181d195c30da01783edbd7b71caab38cf39b" alt=""
data:image/s3,"s3://crabby-images/54369/54369b7f4efbfff4cde9eaab5e379c88554121c1" alt=""
data:image/s3,"s3://crabby-images/ca5c3/ca5c3d8d88773b63c75bbeaff6fe5af0b13fbea8" alt=""
data:image/s3,"s3://crabby-images/92e27/92e27e2fb6cadf29f6ade27df55a8d9900fc0cbc" alt=""
data:image/s3,"s3://crabby-images/acb96/acb96d3d50a757bc8be49d6c6106a36a53cb720f" alt=""
Discretization
data:image/s3,"s3://crabby-images/3f399/3f399e322d2db2de66372343c53b2a06b62d0196" alt=""
data:image/s3,"s3://crabby-images/32494/324941e7793c8424913bcc5924adfd3676bbd5f0" alt=""
data:image/s3,"s3://crabby-images/0b557/0b55778d850015e35a6fe0bd0ce79916f9dc5f1a" alt=""
data:image/s3,"s3://crabby-images/56561/5656181d195c30da01783edbd7b71caab38cf39b" alt=""
data:image/s3,"s3://crabby-images/eee05/eee059ba5450fb806ec5b5bd00746373229d79d5" alt=""
data:image/s3,"s3://crabby-images/fc44d/fc44d6a10f665ae5442a490322639c416cabb2bb" alt=""
data:image/s3,"s3://crabby-images/39ab6/39ab636adcc3b9c048148738b9c9e64603f66814" alt=""
We only want opaque pixels to emit color:
data:image/s3,"s3://crabby-images/f3b72/f3b7215c3db20e5680a591823d84cefa912d8c5f" alt=""
Back-to-Front Evaluation
Start:
data:image/s3,"s3://crabby-images/4fafb/4fafbd25aed8cbcce73b636edcb230e00316221a" alt=""
Update:
data:image/s3,"s3://crabby-images/24520/245200908999d518cbae255abea1679bc0a7fbf7" alt=""
Front-to-Back Evaluation
Start:
data:image/s3,"s3://crabby-images/bfbf7/bfbf7650405031e69e56cddcc7d86dd8b448e8bc" alt=""
data:image/s3,"s3://crabby-images/f3e9b/f3e9b6c1b1d58f3f2814329cdf4b3fe35190daac" alt=""
Update:
data:image/s3,"s3://crabby-images/dca35/dca35a1e2a5eb826f7ad590a2b96543f1b2b861c" alt=""
data:image/s3,"s3://crabby-images/31805/31805b25f6541d1e085c383748024a261c98fac7" alt=""
Early abort if
data:image/s3,"s3://crabby-images/ef889/ef88945abb0f70dab5dcc6df93e42cd77ed68ef7" alt=""
Explain the Slicing technique for Volume Rendering!
- generate set of planes parallel to the image plane within the viewing frustum
- render back-to-front with alpha blending
- texture each plane using the volume data as a 3D texture
Explain the Marching Cubes algorithm! What are its disadvantages?
Given: Volumetric representation data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Impose regular grid of cubes over the volume.
For every cube cell:
Disadvantages:
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
Impose regular grid of cubes over the volume.
For every cube cell:
- Sample the values of
at the eight cube vertices
- Based on a lookup table with
entries, decide which geometry to generate for this cell
- Compute intersection positions for vertices on the cube edges. For instance, the position of the vertex right of
is
data:image/s3,"s3://crabby-images/606ac/606ac43ce6ff5b1efbcae156d9f471d50e92ecb3" alt=""
Disadvantages:
- Creates mesh which can be highly over-sampled (requires Decimation) and contain bad triangle shapes (requires Mesh Optimization / Re-Meshing)
- Linear interpolation of distance values approximates smooth surfaces: Sharp features within cells are lost
- Aliasing artifacts due to alignment of the voxel grid. Increasing voxel resolution only reduces the size of the artifacts but they never go away
Give the Bernstein polynomials! What are their properties?
Partition of unity:
data:image/s3,"s3://crabby-images/eac34/eac341b4f2138bb67af3d4cd914731cdad96a17d" alt=""
data:image/s3,"s3://crabby-images/81b20/81b202ab53e24831d7d90887ab6c039350202604" alt=""
Define the Bernstein polynomial
data:image/s3,"s3://crabby-images/ff718/ff718e92c10b40bff1f9c09d4d8485334cf2cb6e" alt=""
Bezier curve
data:image/s3,"s3://crabby-images/bf1ef/bf1ef770b9defd2490d0526434c204452d3f3593" alt=""
Properties
data:image/s3,"s3://crabby-images/eac34/eac341b4f2138bb67af3d4cd914731cdad96a17d" alt=""
data:image/s3,"s3://crabby-images/81b20/81b202ab53e24831d7d90887ab6c039350202604" alt=""
Define the Bernstein polynomial
data:image/s3,"s3://crabby-images/ff718/ff718e92c10b40bff1f9c09d4d8485334cf2cb6e" alt=""
Bezier curve
data:image/s3,"s3://crabby-images/bf1ef/bf1ef770b9defd2490d0526434c204452d3f3593" alt=""
Properties
- Partition of unity
- Non-negativity
- Maximum
- Endpoint interpolation
- Symmetry
- Recursion
data:image/s3,"s3://crabby-images/d55fe/d55fec9012f8b844c3241b4e25b562430c44cb7a" alt=""
data:image/s3,"s3://crabby-images/918b5/918b5728b2454654d3d4cfa86dac118d88fda9d4" alt=""
data:image/s3,"s3://crabby-images/71ce1/71ce11ec81cc64e9125833f18f92c6a792d50e21" alt=""
data:image/s3,"s3://crabby-images/a30ef/a30efc278148239849af53b25a469909c99399c4" alt=""
data:image/s3,"s3://crabby-images/ef06f/ef06f2d0686f2710aaebe6a854302a0c70d1969d" alt=""
data:image/s3,"s3://crabby-images/62052/620529d133efdaa6f1e6957e584834555e3aaaab" alt=""
data:image/s3,"s3://crabby-images/9d7cc/9d7cc78da6f9cf2149e0fe5761ebdff5038f372a" alt=""
data:image/s3,"s3://crabby-images/c1968/c1968b12592373095828a05dc3f81aaae0256ee0" alt=""
data:image/s3,"s3://crabby-images/d6322/d632213a249c52026c0fa8bc7276f408023ccfa2" alt=""
data:image/s3,"s3://crabby-images/280ae/280aefb50f1d1b4938dcb84113a553b39b2b65d7" alt=""
data:image/s3,"s3://crabby-images/a7a04/a7a04f68c0ed650666606dd140bed56199b9a80b" alt=""
data:image/s3,"s3://crabby-images/8457d/8457d24d7b5139a3e08dae14e47da222ee18968e" alt=""
data:image/s3,"s3://crabby-images/69a44/69a448fec61873121f4b042a326cd7def57e82c4" alt=""
What problems are addressed by the Extended Marching Cubes algorithm? How does it solve them?
Problems of Marching Cubes
Solution: Directed Distances
instead of an iso-value, store three directed distances for every vertex: exact distance to the surface crossing along every cube edge
Solution: Feature Detection / Sampling / Reconstruction
Feature Detection
based on the gradient values at the edge intersections, compute normal vectors:
data:image/s3,"s3://crabby-images/773dc/773dc6224f7c40905338bda50ab52f2563e23fa4" alt=""
find the two normal vectors
which span the largest angle
data:image/s3,"s3://crabby-images/77092/77092fd2fe530dd3cc3665dd8fcd936a89fc6dce" alt=""
data:image/s3,"s3://crabby-images/0cee8/0cee831bfbc5eefe96e247097490e8529c09853a" alt=""
find the normal
which forms the smallest angle to the orthogonal direction data:image/s3,"s3://crabby-images/c87ea/c87ea73493764e2a530ab276e23f39e972dd9fc4" alt=""
data:image/s3,"s3://crabby-images/d1a12/d1a12474015df0094f92590b74b626fe34dbadda" alt=""
data:image/s3,"s3://crabby-images/0967e/0967ee10b6b6dd3b4c8cd9a06cfe3595bef8a2d0" alt=""
If
, we have detected a feature.
If additionally
, the current feature is a corner feature (two large opening angles). Otherwise, it is an edge feature (one large opening angle).
Feature Sampling
Find intersection point of tangent planes:
data:image/s3,"s3://crabby-images/2458e/2458e1ccc35f8315fd7a62fc91006b9f04ee9dbc" alt=""
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
This might not have a unique solution:
Over-determined: No common intersection point. Find least-squares solution (closest to all planes).
Under-determined: Infinitely many intersection points. Find least-norm solution (closest to voxel center).
Solve using SVD:
data:image/s3,"s3://crabby-images/43f0a/43f0acb296eb1cdece47fd014e41f5ce4e0731b0" alt=""
data:image/s3,"s3://crabby-images/141d3/141d3399756124d676235ebba129faee16309cb9" alt=""
data:image/s3,"s3://crabby-images/7affd/7affd90b1b5fdf852c30f6115e9a5dabf2811de9" alt=""
data:image/s3,"s3://crabby-images/5b2a0/5b2a0b397a2aa1137f99834abf672a9ac22503b7" alt=""
Feature Reconstruction
Look up cell configuration from Marching Cubes table. If in a feature cell, insert feature vertex at computed position and connect with a triangle fan. Flip edges so they align with feature edges.
- edge intersections are computed using linear interpolation (inaccurate)
- assumes smooth isosurface: sharp features within cells are lost (aliasing problem)
Solution: Directed Distances
instead of an iso-value, store three directed distances for every vertex: exact distance to the surface crossing along every cube edge
Solution: Feature Detection / Sampling / Reconstruction
Feature Detection
based on the gradient values at the edge intersections, compute normal vectors:
data:image/s3,"s3://crabby-images/773dc/773dc6224f7c40905338bda50ab52f2563e23fa4" alt=""
find the two normal vectors
data:image/s3,"s3://crabby-images/934be/934be146f37aeb365782b10cff33ee5efcb99971" alt=""
data:image/s3,"s3://crabby-images/77092/77092fd2fe530dd3cc3665dd8fcd936a89fc6dce" alt=""
data:image/s3,"s3://crabby-images/0cee8/0cee831bfbc5eefe96e247097490e8529c09853a" alt=""
find the normal
data:image/s3,"s3://crabby-images/724ba/724bad11c3e3fbbdbcedcddd683d7b23046be225" alt=""
data:image/s3,"s3://crabby-images/c87ea/c87ea73493764e2a530ab276e23f39e972dd9fc4" alt=""
data:image/s3,"s3://crabby-images/d1a12/d1a12474015df0094f92590b74b626fe34dbadda" alt=""
data:image/s3,"s3://crabby-images/0967e/0967ee10b6b6dd3b4c8cd9a06cfe3595bef8a2d0" alt=""
If
data:image/s3,"s3://crabby-images/df061/df0611e63ff38de67f87cb6c354159c0d7ec0c22" alt=""
If additionally
data:image/s3,"s3://crabby-images/53e16/53e165a98807a23a81c5fc814af79aa5feb4d29b" alt=""
Feature Sampling
Find intersection point of tangent planes:
data:image/s3,"s3://crabby-images/2458e/2458e1ccc35f8315fd7a62fc91006b9f04ee9dbc" alt=""
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
This might not have a unique solution:
Over-determined: No common intersection point. Find least-squares solution (closest to all planes).
Under-determined: Infinitely many intersection points. Find least-norm solution (closest to voxel center).
Solve using SVD:
data:image/s3,"s3://crabby-images/43f0a/43f0acb296eb1cdece47fd014e41f5ce4e0731b0" alt=""
data:image/s3,"s3://crabby-images/141d3/141d3399756124d676235ebba129faee16309cb9" alt=""
data:image/s3,"s3://crabby-images/7affd/7affd90b1b5fdf852c30f6115e9a5dabf2811de9" alt=""
data:image/s3,"s3://crabby-images/5b2a0/5b2a0b397a2aa1137f99834abf672a9ac22503b7" alt=""
Feature Reconstruction
Look up cell configuration from Marching Cubes table. If in a feature cell, insert feature vertex at computed position and connect with a triangle fan. Flip edges so they align with feature edges.
Explain the Singular Value Decomposition!
Given
, a system
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
might be over- or under-determined. We still want to compute an approximate solution.
For any such
, there exists the Singular Value Decomposition
where
is orthonormal: data:image/s3,"s3://crabby-images/11cae/11cae545f402733812fcd18e6d01c7ae77f64688" alt=""
data:image/s3,"s3://crabby-images/3dd47/3dd47124fd6039a9f2145f99df3eba9c78d59483" alt=""
is orthonormal: data:image/s3,"s3://crabby-images/11cae/11cae545f402733812fcd18e6d01c7ae77f64688" alt=""
From this, we can construct the pseudo-inverse
data:image/s3,"s3://crabby-images/145d8/145d843981b17e069d1afa157b4db708d4c7d7d2" alt=""
wheredata:image/s3,"s3://crabby-images/5c9b5/5c9b542f1378a69ed1e68ae508729b98a06d0c74" alt=""
where
data:image/s3,"s3://crabby-images/d512c/d512c5f3d38161a5848500859b223e1878b531c9" alt=""
Due to numerical imprecisions, we use
data:image/s3,"s3://crabby-images/4578c/4578cf88c186d131a65364ee1b912e4fddaffda8" alt=""
Now, we can compute a solution:
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
data:image/s3,"s3://crabby-images/1513f/1513f2bbc8092116d2e1f7b2348059516dfc4307" alt=""
data:image/s3,"s3://crabby-images/1c40d/1c40d3d9fd8714e6e71c441dd6b7e78820078dd4" alt=""
data:image/s3,"s3://crabby-images/f2463/f246312267fd7d5ed5369b3052f8c54735dbcb07" alt=""
This solution is
data:image/s3,"s3://crabby-images/96acc/96accafcf1292c0e9b873d35cd565382c5401361" alt=""
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
might be over- or under-determined. We still want to compute an approximate solution.
For any such
data:image/s3,"s3://crabby-images/d68d5/d68d5dc0332cf1eeb74fa37df2ca159a569aeba1" alt=""
data:image/s3,"s3://crabby-images/25632/2563260f990fbf415c46acae76daed3f0858f38c" alt=""
data:image/s3,"s3://crabby-images/347c2/347c27dfdac07a1c82a647515f314d25d68a463d" alt=""
data:image/s3,"s3://crabby-images/11cae/11cae545f402733812fcd18e6d01c7ae77f64688" alt=""
data:image/s3,"s3://crabby-images/3dd47/3dd47124fd6039a9f2145f99df3eba9c78d59483" alt=""
data:image/s3,"s3://crabby-images/d5e8a/d5e8a7f6adc7c87f66721c1f43e6325116b12132" alt=""
data:image/s3,"s3://crabby-images/11cae/11cae545f402733812fcd18e6d01c7ae77f64688" alt=""
From this, we can construct the pseudo-inverse
data:image/s3,"s3://crabby-images/145d8/145d843981b17e069d1afa157b4db708d4c7d7d2" alt=""
where
data:image/s3,"s3://crabby-images/5c9b5/5c9b542f1378a69ed1e68ae508729b98a06d0c74" alt=""
where
data:image/s3,"s3://crabby-images/d512c/d512c5f3d38161a5848500859b223e1878b531c9" alt=""
Due to numerical imprecisions, we use
data:image/s3,"s3://crabby-images/4578c/4578cf88c186d131a65364ee1b912e4fddaffda8" alt=""
Now, we can compute a solution:
data:image/s3,"s3://crabby-images/631b7/631b7aa702e644adfa332cf9b81f717e537e1904" alt=""
data:image/s3,"s3://crabby-images/1513f/1513f2bbc8092116d2e1f7b2348059516dfc4307" alt=""
data:image/s3,"s3://crabby-images/1c40d/1c40d3d9fd8714e6e71c441dd6b7e78820078dd4" alt=""
data:image/s3,"s3://crabby-images/f2463/f246312267fd7d5ed5369b3052f8c54735dbcb07" alt=""
This solution is
- a solution in the least-squares sense if M is overdetermined
- a solution in the last-norm sense if M in underdetermined
Explain different ways to store meshes on disk and give the average amount of memory per vertex!
Face Set
For each triangle, store the position of all vertices.
vertices
triangles
positions
floats
bytes
Shared Vertex
Store one list with positions of all vertices. For each triangle, store three indices into the vertex list.
For the vertex list:
vertices
positions
floats
bytes
For the triangles:
vertices
triangles
indices (i.e. ints)
bytes
Total
bytes
Triangle Strips
Store a list of vertex positions. Each triple of vertices in that list defines one triangle. (Note: triangles have alternating winding)
vertices
triangles
positions
floats
bytes
Representing general triangle meshes as triangle strips:
For each triangle, store the position of all vertices.
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/c73f3/c73f30791476193e3bc60b820e0b742f304a9800" alt=""
data:image/s3,"s3://crabby-images/d7a95/d7a953fe7259557ef8f923bcc905a5c10855fab0" alt=""
data:image/s3,"s3://crabby-images/1eeec/1eeecd4b94d45086374962e02e381807acd2c62a" alt=""
data:image/s3,"s3://crabby-images/0575a/0575ae7d93358a5abc5c15392ce7ee3720cf6213" alt=""
Shared Vertex
Store one list with positions of all vertices. For each triangle, store three indices into the vertex list.
For the vertex list:
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/64e3b/64e3b89d555f146c221b1f95480aa9446beaa88f" alt=""
data:image/s3,"s3://crabby-images/e635a/e635a13b030cf5a722a49fa29c36cbac0262f3cf" alt=""
For the triangles:
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/c73f3/c73f30791476193e3bc60b820e0b742f304a9800" alt=""
data:image/s3,"s3://crabby-images/d7a95/d7a953fe7259557ef8f923bcc905a5c10855fab0" alt=""
data:image/s3,"s3://crabby-images/8b09f/8b09f27f3fc314b341c45c68f7d5d7d24cd8d209" alt=""
Total
data:image/s3,"s3://crabby-images/9f85c/9f85c2a9f18661d67a91207332af57ea68464469" alt=""
Triangle Strips
Store a list of vertex positions. Each triple of vertices in that list defines one triangle. (Note: triangles have alternating winding)
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/c73f3/c73f30791476193e3bc60b820e0b742f304a9800" alt=""
data:image/s3,"s3://crabby-images/f9709/f97096b51eb29286fa494d9642474d9f9dc897f5" alt=""
data:image/s3,"s3://crabby-images/e7f20/e7f20085c594b22def87cc650cc52adc7ba963a4" alt=""
data:image/s3,"s3://crabby-images/ac824/ac824f6229665d4a110fbc0ba388ee37820f654b" alt=""
Representing general triangle meshes as triangle strips:
- Apply 1:3-splits to allow for flexibility in mesh traversal.
- Generalized Triangle Strips: Store 1 additional bit per vertex, telling whether to replace the oldest or second-oldest vertex from the current triangle.
- Use multiple triangle strips for one mesh
Name and explain three mesh data structures for geometry processing!
Face Based
Store, for every face:
Problem: For arbitrary meshes, entries can be of different size (because of varying face valence)
Edge Based
Store, for every edge:
Advantage: Constant storage per entry
Problem: Start and end point are chosen arbitrarily. Traversal in both directions requires case distinctions.
Halfedge Based
Store, for every halfedge:
Advantage: Constant storage per entry, no directional ambiguity, can only represent manifold meshes
Enumerating 1-Ring Neighborhood
1. pick one outgoing halfedge
from center vertex
2. do something with the current target vertex
3. go to the opposite halfedge
4. go to the next halfedge
5. if the current halfedge is not
, go to 2
Store, for every face:
- pointers to all face vertices
- pointers to all adjacent faces
Problem: For arbitrary meshes, entries can be of different size (because of varying face valence)
Edge Based
Store, for every edge:
- 2 pointers to the edge endpoint vertices
- 2 pointers to the incident faces
- 4 pointers to adjacent edges (on each side, one in cw / ccw direction)
Advantage: Constant storage per entry
Problem: Start and end point are chosen arbitrarily. Traversal in both directions requires case distinctions.
Halfedge Based
Store, for every halfedge:
- pointer to target vertex
- pointer to incident face (to the left)
- pointer to next halfedge (leftmost outgoing halfedge from target vertex)
- pointer to opposite halfedge (not explicitly stored: store list of halfedge pairs. obtain pointer to opposite halfedge by flipping last bit of index)
- (sometime: previous halfedge)
Advantage: Constant storage per entry, no directional ambiguity, can only represent manifold meshes
Enumerating 1-Ring Neighborhood
1. pick one outgoing halfedge
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
2. do something with the current target vertex
3. go to the opposite halfedge
4. go to the next halfedge
5. if the current halfedge is not
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
Explain point based rendering techniques! In what cases are they used? How does real-time rendering work? What are disadvantages?
For very hi-res models, where triangle rendering would lead to multiple triangles mapping to the same pixel, it is more efficient to drop the triangle rendering and just render points.
Gaps between points filled by rendering splats (litte discs).
Possible improvements:
Real-time rendering of blended splat clouds: 2-Pass Rendering
Major disadvantage: For (approximately) correct visibility, point cloud needs to be rendered twice
Gaps between points filled by rendering splats (litte discs).
Possible improvements:
- Oriented Splats: Better approximation of object's silhouette (using normal information, e.g. from least-square plane of local neighborhood)
- Gouraud Splatting: Render blended blobs instead of discs (low-pass filter)
- Phong Splatting: Smoothly blend normal information, then shade in deferred rendering pass based on depth buffer and interpolated normals
Real-time rendering of blended splat clouds: 2-Pass Rendering
- render splat cloud to z-buffer only
- render colored and blended splat cloud again with depth write off and some depth bias
Major disadvantage: For (approximately) correct visibility, point cloud needs to be rendered twice
Explain how to transform geometry according to camera position and projection to the screen!
Concatenation of three matrices:
data:image/s3,"s3://crabby-images/20160/20160b07d2f51999085b5b0b4b856250299bff87" alt=""
Look-at transformdata:image/s3,"s3://crabby-images/d68f5/d68f50c50b81df92c194a1935d9f674b7d539c55" alt=""
Given a camera position
, a desired viewing direction
and an up vector
, we compute a orthogonal coordinate system as follows:
data:image/s3,"s3://crabby-images/049a7/049a7eaf5cf53e87735a59e33ca23677afa9bba7" alt=""
data:image/s3,"s3://crabby-images/23afb/23afb100b11af4f2d2a0e4c4b7f0a724a5114a85" alt=""
Now, the matrix transforming points from camera space to world space is given by
data:image/s3,"s3://crabby-images/c1d03/c1d039608e346ded75bee1d24da6c4ee5067b43d" alt=""
The look-at transform is the inverse of this, transforming points from world space to local camera space:
data:image/s3,"s3://crabby-images/656cb/656cb0d31fa74e10df619dce0dc21dfceab2fc7c" alt=""
Frustum transformdata:image/s3,"s3://crabby-images/1393d/1393da24d4c3f7b1d99faf7fc58fe3d5bd50952a" alt=""
Transforms points from a frustum defined by the near / far plane distance of the camera
and the extents of the near plane rectangle
into the unit cube
.
maps points on the near plane to
and points on the far plane to
.
Viewport transformdata:image/s3,"s3://crabby-images/837ef/837ef4f550514c645f4fbcba3c880ac4470f98f2" alt=""
Transforms from the unit cube to pixel coordinates on a
screen:
data:image/s3,"s3://crabby-images/3d3a0/3d3a0417e88948aae1ca98c6497f018642fd98f9" alt=""
data:image/s3,"s3://crabby-images/20160/20160b07d2f51999085b5b0b4b856250299bff87" alt=""
Look-at transform
data:image/s3,"s3://crabby-images/d68f5/d68f50c50b81df92c194a1935d9f674b7d539c55" alt=""
Given a camera position
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/95c06/95c0682bf226940194bbcf20938992853aa4e877" alt=""
data:image/s3,"s3://crabby-images/049a7/049a7eaf5cf53e87735a59e33ca23677afa9bba7" alt=""
data:image/s3,"s3://crabby-images/23afb/23afb100b11af4f2d2a0e4c4b7f0a724a5114a85" alt=""
Now, the matrix transforming points from camera space to world space is given by
data:image/s3,"s3://crabby-images/c1d03/c1d039608e346ded75bee1d24da6c4ee5067b43d" alt=""
The look-at transform is the inverse of this, transforming points from world space to local camera space:
data:image/s3,"s3://crabby-images/656cb/656cb0d31fa74e10df619dce0dc21dfceab2fc7c" alt=""
Frustum transform
data:image/s3,"s3://crabby-images/1393d/1393da24d4c3f7b1d99faf7fc58fe3d5bd50952a" alt=""
Transforms points from a frustum defined by the near / far plane distance of the camera
data:image/s3,"s3://crabby-images/2b81c/2b81ce3ad1eeeb37102ad21ca720257c91169400" alt=""
data:image/s3,"s3://crabby-images/28acd/28acd3d5fd682ed6865b2582d57f4a55951e6a89" alt=""
data:image/s3,"s3://crabby-images/2b682/2b682ef70a009c7f6010db7550c8b49a7bdb9a19" alt=""
data:image/s3,"s3://crabby-images/61d82/61d82119e7214f126f67b727b5d35e690226881b" alt=""
data:image/s3,"s3://crabby-images/fff4f/fff4fbb37d5cb1925a303415df4451f4be335b97" alt=""
data:image/s3,"s3://crabby-images/53e8c/53e8c7cc30d25a44531979d6d8deb50ec0460ef0" alt=""
Viewport transform
data:image/s3,"s3://crabby-images/837ef/837ef4f550514c645f4fbcba3c880ac4470f98f2" alt=""
Transforms from the unit cube to pixel coordinates on a
data:image/s3,"s3://crabby-images/47679/476799c261f2d59e5d6b206fe43cd2a3f53430d9" alt=""
data:image/s3,"s3://crabby-images/3d3a0/3d3a0417e88948aae1ca98c6497f018642fd98f9" alt=""
What is trichromacity? What is metamerism?
Trichromacity
Cone cells in the eye only report one integral value, which is
data:image/s3,"s3://crabby-images/49d19/49d1921c6a8b0506f2bbb07ed0409e0048980ca0" alt=""
where
is the incoming color spectrum and
is the response function of the given cone type. Since there are only three types of cone cells, each color stimulus can be described by a three-tuple
, the tristimulus.
Metamerism
Due to trichromacity, different color spectra can map to the same tristimulus value and thus produce the same color impression.
Cone cells in the eye only report one integral value, which is
data:image/s3,"s3://crabby-images/49d19/49d1921c6a8b0506f2bbb07ed0409e0048980ca0" alt=""
where
data:image/s3,"s3://crabby-images/89cc6/89cc631b59b0bb8a3133f0bc44e7ef93d44f15f5" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/0099f/0099f4fe3b7477a615cfb2a8807f1ecee31bf21f" alt=""
Metamerism
Due to trichromacity, different color spectra can map to the same tristimulus value and thus produce the same color impression.
What kinds of receptor cells are on the retina of the human eye?
Rods ("Stäbchen") detect overall brightness intensities
Cones ("Zäpfchen") detect color intensities
Cones ("Zäpfchen") detect color intensities
What is the CIE color model and why is it used?
Color system with artificial basis colors which allows all human visible colors to be represented by a triple of positive values.
This is not possible when using the natural red, green and blue base colors: In order to recreate the color impression of wavelengths between 450 and 550 nm, negative red light contributions would be necessary.
This is not possible when using the natural red, green and blue base colors: In order to recreate the color impression of wavelengths between 450 and 550 nm, negative red light contributions would be necessary.
Give transformation matrices for translation, scaling, shearing and rotation.
Translation
data:image/s3,"s3://crabby-images/3dcb2/3dcb241f8336a99f14a9eef8207c30c3470ded8e" alt=""
Scaling
data:image/s3,"s3://crabby-images/e6524/e6524787ef2de7a5d068d8081f508453e008dd2a" alt=""
Shearing (here: x-axis is sheared into y direction)
data:image/s3,"s3://crabby-images/4dfc7/4dfc79304c67a661bc5c6d779be1d0105a83d3b9" alt=""
Rotation around x, y and z axis, respectively (counter-clockwise when rotation axis points towards observer, clockwise when looking into direction of the axis)
data:image/s3,"s3://crabby-images/b5b5b/b5b5beedb4f4fd639b7f02f58c17472a5154adcf" alt=""
data:image/s3,"s3://crabby-images/c490c/c490c28e57631a551e9d0c0b2b3bec024f86e132" alt=""
data:image/s3,"s3://crabby-images/8d833/8d833390b0ea36d367a7f7ab52d1277b575911ff" alt=""
data:image/s3,"s3://crabby-images/3dcb2/3dcb241f8336a99f14a9eef8207c30c3470ded8e" alt=""
Scaling
data:image/s3,"s3://crabby-images/e6524/e6524787ef2de7a5d068d8081f508453e008dd2a" alt=""
Shearing (here: x-axis is sheared into y direction)
data:image/s3,"s3://crabby-images/4dfc7/4dfc79304c67a661bc5c6d779be1d0105a83d3b9" alt=""
Rotation around x, y and z axis, respectively (counter-clockwise when rotation axis points towards observer, clockwise when looking into direction of the axis)
data:image/s3,"s3://crabby-images/b5b5b/b5b5beedb4f4fd639b7f02f58c17472a5154adcf" alt=""
data:image/s3,"s3://crabby-images/c490c/c490c28e57631a551e9d0c0b2b3bec024f86e132" alt=""
data:image/s3,"s3://crabby-images/8d833/8d833390b0ea36d367a7f7ab52d1277b575911ff" alt=""
Give three basic projective transforms
Standard Projection
projects towards the origin onto planedata:image/s3,"s3://crabby-images/621ea/621ea3d521c92a3b1bbecfc500c68e6350b67a68" alt=""
data:image/s3,"s3://crabby-images/e3892/e38925fbc536491d5cc774d49142e70629c7b005" alt=""
Central Point Projection
projects towards the origin onto a plane with normal
at distance data:image/s3,"s3://crabby-images/1607f/1607f26884edbd07852216f60b9963d4a23a114b" alt=""
data:image/s3,"s3://crabby-images/cb5d8/cb5d84311f7d1608c90feecfe225ca7de61a1636" alt=""
note: Standard Projection is a special case of this
Central Plane Projection
project onto plane through origin given by normal vector
towards point data:image/s3,"s3://crabby-images/455a6/455a66a1b774b8489058ac44bd0aa36b23f707c2" alt=""
data:image/s3,"s3://crabby-images/c5425/c542516cba7adfebf86c47bfc2b67ad2b856c442" alt=""
Degenerates to orthogonal projection fordata:image/s3,"s3://crabby-images/9d38b/9d38bc98267ecf4fd44eca592267649cf634f24b" alt=""
projects towards the origin onto plane
data:image/s3,"s3://crabby-images/621ea/621ea3d521c92a3b1bbecfc500c68e6350b67a68" alt=""
data:image/s3,"s3://crabby-images/e3892/e38925fbc536491d5cc774d49142e70629c7b005" alt=""
Central Point Projection
projects towards the origin onto a plane with normal
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/1607f/1607f26884edbd07852216f60b9963d4a23a114b" alt=""
data:image/s3,"s3://crabby-images/cb5d8/cb5d84311f7d1608c90feecfe225ca7de61a1636" alt=""
note: Standard Projection is a special case of this
Central Plane Projection
project onto plane through origin given by normal vector
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/455a6/455a66a1b774b8489058ac44bd0aa36b23f707c2" alt=""
data:image/s3,"s3://crabby-images/c5425/c542516cba7adfebf86c47bfc2b67ad2b856c442" alt=""
Degenerates to orthogonal projection for
data:image/s3,"s3://crabby-images/9d38b/9d38bc98267ecf4fd44eca592267649cf634f24b" alt=""
Characterize linear, affine and projective transforms!
Linear Maps
A map
which is
additive:data:image/s3,"s3://crabby-images/d1ea2/d1ea2d15268c89345ea3cec440be7279cfdae5c2" alt=""
homogenous:data:image/s3,"s3://crabby-images/2a23e/2a23ed156d96395f562f3686c923a5f7f60fc640" alt=""
Representable by a transformation matrix
:
data:image/s3,"s3://crabby-images/fdd1b/fdd1b03b6d7591b260e01455b8ae955814a0609c" alt=""
Linear map preserve the origin.
Affine Maps
A map
which is
composed of a linear map
and a translation:
data:image/s3,"s3://crabby-images/178f2/178f2f29323cbdafd6adee89d0e7f6f2b746cf92" alt=""
Affine transformations can be represented as a matrix-vector product by using extended coordinates:
data:image/s3,"s3://crabby-images/94811/948111e70a8d7353acf582e2228570db3823a980" alt=""
Affine maps preserve collinearity of points and distance ratios.
Projective Maps
Represented by a matrix-vector product using homogeneous coordinates.
Projective maps preserve cross ratios:
data:image/s3,"s3://crabby-images/9f43b/9f43b860d925651c02a18744103fff907fe7bb13" alt=""
A map
data:image/s3,"s3://crabby-images/46ef2/46ef2601f2cfda511609a4c09c0e19d654e7e237" alt=""
additive:
data:image/s3,"s3://crabby-images/d1ea2/d1ea2d15268c89345ea3cec440be7279cfdae5c2" alt=""
homogenous:
data:image/s3,"s3://crabby-images/2a23e/2a23ed156d96395f562f3686c923a5f7f60fc640" alt=""
Representable by a transformation matrix
data:image/s3,"s3://crabby-images/b590a/b590a7ef389d0f9a4abade9c6764da8c5b1895b7" alt=""
data:image/s3,"s3://crabby-images/fdd1b/fdd1b03b6d7591b260e01455b8ae955814a0609c" alt=""
Linear map preserve the origin.
Affine Maps
A map
data:image/s3,"s3://crabby-images/b6d90/b6d90e0790176573732aaaeacaeb4f2bd19d73db" alt=""
composed of a linear map
data:image/s3,"s3://crabby-images/d44ee/d44ee16594cd8b7dd72ea393fdb20e76b8b19c82" alt=""
data:image/s3,"s3://crabby-images/178f2/178f2f29323cbdafd6adee89d0e7f6f2b746cf92" alt=""
Affine transformations can be represented as a matrix-vector product by using extended coordinates:
data:image/s3,"s3://crabby-images/94811/948111e70a8d7353acf582e2228570db3823a980" alt=""
Affine maps preserve collinearity of points and distance ratios.
Projective Maps
Represented by a matrix-vector product using homogeneous coordinates.
Projective maps preserve cross ratios:
data:image/s3,"s3://crabby-images/9f43b/9f43b860d925651c02a18744103fff907fe7bb13" alt=""
How to construct the vanishing point of a line? (analytically and on paper)
A point and a direction
data:image/s3,"s3://crabby-images/838bd/838bd60b9a879fdb55a5a706f58eae9888b21854" alt=""
data:image/s3,"s3://crabby-images/0d33f/0d33f3b7d86c6a257d148e33b1b4987cb7652799" alt=""
define the line
data:image/s3,"s3://crabby-images/6379d/6379d90269541947f977cd36dd1ba17a31ee7686" alt=""
The standard projection of a pointdata:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/28794/28794cfccc31d211c93afc7447a3981dc6e996cc" alt=""
results, after de-homogenization, in the point
data:image/s3,"s3://crabby-images/f04fb/f04fb86ec5ad394d26b009ae2b6c70eb7f469c3a" alt=""
on the image plane.
Thus,
data:image/s3,"s3://crabby-images/60ce6/60ce6f1bdca504f319f7363c5bec5b43e5ca5cc9" alt=""
Let us only examine the x-coordinate of this and rearrange some terms:
data:image/s3,"s3://crabby-images/38d0a/38d0aceb9ee94057da003c2ecb1a4ae4c104fdac" alt=""
data:image/s3,"s3://crabby-images/43692/43692c8fd079a1fbd9931c1763a2d39d9ee49d0b" alt=""
data:image/s3,"s3://crabby-images/8fc4b/8fc4be44ac732e1338991b9f848611738b6d7130" alt=""
Now, if
and
,
data:image/s3,"s3://crabby-images/34b39/34b39f540f5a7cda0305515c4ad4f8b38a164a45" alt=""
data:image/s3,"s3://crabby-images/838bd/838bd60b9a879fdb55a5a706f58eae9888b21854" alt=""
data:image/s3,"s3://crabby-images/0d33f/0d33f3b7d86c6a257d148e33b1b4987cb7652799" alt=""
define the line
data:image/s3,"s3://crabby-images/6379d/6379d90269541947f977cd36dd1ba17a31ee7686" alt=""
The standard projection of a point
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/28794/28794cfccc31d211c93afc7447a3981dc6e996cc" alt=""
results, after de-homogenization, in the point
data:image/s3,"s3://crabby-images/f04fb/f04fb86ec5ad394d26b009ae2b6c70eb7f469c3a" alt=""
on the image plane.
Thus,
data:image/s3,"s3://crabby-images/60ce6/60ce6f1bdca504f319f7363c5bec5b43e5ca5cc9" alt=""
Let us only examine the x-coordinate of this and rearrange some terms:
data:image/s3,"s3://crabby-images/38d0a/38d0aceb9ee94057da003c2ecb1a4ae4c104fdac" alt=""
data:image/s3,"s3://crabby-images/43692/43692c8fd079a1fbd9931c1763a2d39d9ee49d0b" alt=""
data:image/s3,"s3://crabby-images/8fc4b/8fc4be44ac732e1338991b9f848611738b6d7130" alt=""
Now, if
data:image/s3,"s3://crabby-images/29007/2900764874332d4c4430259aa923d5a42405f6c9" alt=""
data:image/s3,"s3://crabby-images/c5806/c5806ad22600f9422cf009386ab197f49d0dd99b" alt=""
data:image/s3,"s3://crabby-images/34b39/34b39f540f5a7cda0305515c4ad4f8b38a164a45" alt=""
How can 2D / 3D geometric objects be represented?
parametric: Range of a (uni- / multivariate) function mapping parameters to points on the object. Easy to produce points belonging to an object.
implicit: Function telling for each point in space whether it belongs to the object or not. Easy to test points for membership.
implicit: Function telling for each point in space whether it belongs to the object or not. Easy to test points for membership.
How are lines represented in parametric / implicit form?
Parametric
With base point
, direction
:
data:image/s3,"s3://crabby-images/6379d/6379d90269541947f977cd36dd1ba17a31ee7686" alt=""
Implicit 2D
Find normal vector
to
. Then, the line is given by all points
for which
.
Implicit 3D
Find two vectors
orthogonal to
. Then, the line is given by the intersection of the two planes given by
, i.e. all points
for which
.
With base point
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/6379d/6379d90269541947f977cd36dd1ba17a31ee7686" alt=""
Implicit 2D
Find normal vector
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/29c53/29c534dce420d34586d383a221aee4a4a7f1d27d" alt=""
Implicit 3D
Find two vectors
data:image/s3,"s3://crabby-images/a18f2/a18f2b86c8bf68245f3dfac02ca52d0527f79d7f" alt=""
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
data:image/s3,"s3://crabby-images/8bb20/8bb20e7a84178b3dceb5bcc4f35df3b57aacea25" alt=""
data:image/s3,"s3://crabby-images/6cac3/6cac33753adf18fc85a1201e31ee1d4161cac5ab" alt=""
data:image/s3,"s3://crabby-images/a5d58/a5d58a9f52bd3eb35dcf47d592b4dfdce754beb5" alt=""
Give an explicit form for line segments and triangles!
Line Segment from
to data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/47bee/47bee13cbc4b545ac181e0dcb2603d0ce06e733c" alt=""
Triangle with cornersdata:image/s3,"s3://crabby-images/e27ba/e27ba951ca282a19549855f9da3297eeb308ff10" alt=""
data:image/s3,"s3://crabby-images/2e511/2e511ce5bb08cb4b40c30ade2eff573c6e03b3ec" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/a1bc8/a1bc803f5f11d8fc5088f001c80bc20baf1881d4" alt=""
data:image/s3,"s3://crabby-images/47bee/47bee13cbc4b545ac181e0dcb2603d0ce06e733c" alt=""
Triangle with corners
data:image/s3,"s3://crabby-images/e27ba/e27ba951ca282a19549855f9da3297eeb308ff10" alt=""
data:image/s3,"s3://crabby-images/2e511/2e511ce5bb08cb4b40c30ade2eff573c6e03b3ec" alt=""
Explain Barycentric Coordinates and give a geometric interpretation!
Three non-collinear points
span a plane. Any point
in this plane is given by an affine combination
, where data:image/s3,"s3://crabby-images/cb59b/cb59b168afa32719e54db40e74cf28b172461551" alt=""
or
data:image/s3,"s3://crabby-images/0ce8a/0ce8a45130cd08b010baf8c99375399cde7402e6" alt=""
The values
are called the barycentric coordinates of
.
lies on the intersection of
an
-iso-line which is parallel to
,
a
-iso-line which is parallel to
,
a
-iso-line which is parallel to
.
data:image/s3,"s3://crabby-images/e27ba/e27ba951ca282a19549855f9da3297eeb308ff10" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/e4cd2/e4cd2155070c76613fd315ee22772a096740bc18" alt=""
data:image/s3,"s3://crabby-images/cb59b/cb59b168afa32719e54db40e74cf28b172461551" alt=""
or
data:image/s3,"s3://crabby-images/0ce8a/0ce8a45130cd08b010baf8c99375399cde7402e6" alt=""
The values
data:image/s3,"s3://crabby-images/ca113/ca113e80fdf280097433a0b969d5880566ff3e05" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
an
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/6c350/6c3508a0edeb155884066db11844c1b16bc100ca" alt=""
a
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
data:image/s3,"s3://crabby-images/18765/187659d2f8da592d26b327ccc6612cec0ced0c0e" alt=""
a
data:image/s3,"s3://crabby-images/4e59d/4e59d95d41962d5bf177b954c1911765bbd3d590" alt=""
data:image/s3,"s3://crabby-images/039a5/039a5f90d68fad6b7937d00f722d5d24ebf7e6e9" alt=""
Give the steps of the Rendering Pipeline!
Input: 3D Geometry
Output: Image
In hardware: Transformation / Projection programmable in Vertex Shader. Lighting / Texturing programmable in Fragment Shader. Visibility Test may be done after / during Rasterization (Early-Z).
- Transformation / Projection
- Clipping
- Rasterization
- (Local) Lighting
- Texturing
- Visibility Test
Output: Image
In hardware: Transformation / Projection programmable in Vertex Shader. Lighting / Texturing programmable in Fragment Shader. Visibility Test may be done after / during Rasterization (Early-Z).
Explain the Bresenham / Midpoint algorithm for line drawing!
A line with integer-valued endpoints
should be rasterized. W.l.o.g., we assume
and
(we can rotate / flip our pixel grid to fulfill these conditions).
The line is rasterized by starting with a point
on the line at
, and successively shifting
to the right
,
or to the top right
.
This decision is made based on whether the line passes above or below the midpoint
data:image/s3,"s3://crabby-images/9b98c/9b98cf8c483bdf7b329a48db29b8dd60c53b1018" alt=""
between
and
.
This condition can be checked by deriving an implicit representation of the line
. By taking
, we can define a normal to
as
data:image/s3,"s3://crabby-images/c87f7/c87f719d2b4d93046faca184b1020f0445d1567e" alt=""
and thus derive the implicit representation
.
In order to decide whether to go East or Northeast, we introduce a decision variable, which is initially
.
If
, we go East:
Update
.
Update
.
If
, we go Northeast:
Update
.
Update
.
Values for
can be doubled, thus using only integer arithmetic.
data:image/s3,"s3://crabby-images/814a9/814a9d00dc9a3e7555f7367834e5daade921745f" alt=""
data:image/s3,"s3://crabby-images/1eeef/1eeef7aa80a614b96089dad058695ca5a654f860" alt=""
data:image/s3,"s3://crabby-images/461ed/461ed34066aabc39083422be2ee7c478c3745ccc" alt=""
The line is rasterized by starting with a point
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/27b55/27b55b4474008196f38ee0b4c0a8a7c45fe5d176" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/30db3/30db3dd5098b508c3284556f49fc96f39b5f3223" alt=""
or to the top right
data:image/s3,"s3://crabby-images/2d1fd/2d1fd725efef0698903947bf0800bb4f906a3f3d" alt=""
This decision is made based on whether the line passes above or below the midpoint
data:image/s3,"s3://crabby-images/9b98c/9b98cf8c483bdf7b329a48db29b8dd60c53b1018" alt=""
between
data:image/s3,"s3://crabby-images/d883d/d883dc0e8a916dddc4f337a041bf5fd06e81bb32" alt=""
data:image/s3,"s3://crabby-images/cb813/cb81341d081ce1bcd921b774870785547af1cd06" alt=""
This condition can be checked by deriving an implicit representation of the line
data:image/s3,"s3://crabby-images/039a5/039a5f90d68fad6b7937d00f722d5d24ebf7e6e9" alt=""
data:image/s3,"s3://crabby-images/e6a8d/e6a8d83c8b38c92efb2c493c70c104217aec3603" alt=""
data:image/s3,"s3://crabby-images/039a5/039a5f90d68fad6b7937d00f722d5d24ebf7e6e9" alt=""
data:image/s3,"s3://crabby-images/c87f7/c87f719d2b4d93046faca184b1020f0445d1567e" alt=""
and thus derive the implicit representation
data:image/s3,"s3://crabby-images/dfc73/dfc73c0fb1244b32111d9209500f0e8e0f51aa56" alt=""
In order to decide whether to go East or Northeast, we introduce a decision variable, which is initially
data:image/s3,"s3://crabby-images/069ad/069ad1342946e02e8dc629ec5d1712287423be59" alt=""
If
data:image/s3,"s3://crabby-images/fcf2a/fcf2a1a0291c4696aaa911147a68bbf0b0c9885d" alt=""
Update
data:image/s3,"s3://crabby-images/366fc/366fc345dd646f2e4334ea175e8574765e216f8c" alt=""
Update
data:image/s3,"s3://crabby-images/85888/858887bc15bf7117c10c8b705ba43a9606783c43" alt=""
If
data:image/s3,"s3://crabby-images/88253/88253f47a309ecdff966292e98f242b2798e5e98" alt=""
Update
data:image/s3,"s3://crabby-images/e0f13/e0f13b65441712743835c2c34d6e92a7d1642328" alt=""
Update
data:image/s3,"s3://crabby-images/2c91a/2c91ac20fb0266dcdd63bfd6a402fc7d02b62c44" alt=""
Values for
data:image/s3,"s3://crabby-images/9513c/9513c541804861f94bcb80ffff86f26d9c8bc962" alt=""
Draw a unit cube using 1-Point / 2-Point / 3-Point Perspective!
1-Point:
Vanishing point
is identical with the projection center
. Draw lines from cube edge
to
. The vanishing points of the cube diagonals
are found by adding lines with distance
to the projection center, parallel to the edges of the cube.
2-Point:
Vanishing points
,
lie on a line with the projection center
. Given a cube edge
, add connections from the end vertices to the vanishing points.
Now, consider shifting the upper corner
of the cube into the projection center. Then,
forms a right triangle with
and
, where
is the footpoint of
. Given the lengths
,
, we can construct the vanishing points of the diagonals of the cube.
and
can be found geometrically by constructing a half circle above
and intersecting it with the perpendicular above
.
3-Point:
Only the three vanishing points
are given. The projection center
is found by intersecting the three heights of the triangle
. Based on these heights, we again use Thales' theorem to find the right triangles above the edges of the vanishing point triangle. By intersecting the angle bisectors with the respective edges, the diagonal vanishing points
are found.
Vanishing point
data:image/s3,"s3://crabby-images/0ec83/0ec83b2e516be32f4ffcb96f6d0f2688f2e3064c" alt=""
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
data:image/s3,"s3://crabby-images/3b63d/3b63de2928b7f90aef521b2af6706d8bb7c63bf0" alt=""
data:image/s3,"s3://crabby-images/0ec83/0ec83b2e516be32f4ffcb96f6d0f2688f2e3064c" alt=""
data:image/s3,"s3://crabby-images/a71f0/a71f07e5c51b85c2867612675d2b9bd60a838d2c" alt=""
data:image/s3,"s3://crabby-images/1607f/1607f26884edbd07852216f60b9963d4a23a114b" alt=""
2-Point:
Vanishing points
data:image/s3,"s3://crabby-images/60720/6072065955a4b83fa71a08412eb6fb87bf67ac32" alt=""
data:image/s3,"s3://crabby-images/282ef/282eff7789d13d5f9bbdbb96011c5a54bcbf0f79" alt=""
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
data:image/s3,"s3://crabby-images/3b63d/3b63de2928b7f90aef521b2af6706d8bb7c63bf0" alt=""
Now, consider shifting the upper corner
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/60720/6072065955a4b83fa71a08412eb6fb87bf67ac32" alt=""
data:image/s3,"s3://crabby-images/282ef/282eff7789d13d5f9bbdbb96011c5a54bcbf0f79" alt=""
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
data:image/s3,"s3://crabby-images/d9acc/d9acc498191206c13d9651551850c751d4e0cc63" alt=""
data:image/s3,"s3://crabby-images/07d04/07d041910145598ebe008e051fcaabab8d0d5b8c" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
data:image/s3,"s3://crabby-images/9dea8/9dea8c7e3b55c7432621f0bf955cbeca9f623ae3" alt=""
data:image/s3,"s3://crabby-images/a888d/a888d87bbcbfbbac12f3c4f255d6cd1600c005ed" alt=""
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
3-Point:
Only the three vanishing points
data:image/s3,"s3://crabby-images/b67a6/b67a62d25f730fbc01e6027ae6f4cd2db31af018" alt=""
data:image/s3,"s3://crabby-images/de82e/de82e9f17670e7d85826d26382e2d3c0d493e051" alt=""
data:image/s3,"s3://crabby-images/4e5dc/4e5dc7ba611775e636e18228beddb3392991e127" alt=""
data:image/s3,"s3://crabby-images/9c014/9c0149dca2add0f964013f107020510d7f785832" alt=""
Derive a rotation matrix given by a rotation axis
and angle
(Rodrigues' Formula)
data:image/s3,"s3://crabby-images/9d8a6/9d8a6117b52b3630c0b0367975036fa7cf0ac732" alt=""
data:image/s3,"s3://crabby-images/20755/20755acaa30f720ad196fbb5796e73c7f21651f8" alt=""
We want to derive
. Write
w. r. t. new coordinate system given by
Applying a rotation around the 3rd coordinate gives
data:image/s3,"s3://crabby-images/2fa73/2fa7320ded7481e2c9f08e03a7804cec8f48483c" alt=""
data:image/s3,"s3://crabby-images/573db/573dbdba551d73111bf28a9a74c3426a161daa2f" alt=""
data:image/s3,"s3://crabby-images/c4bb2/c4bb2ba6f8a7265868d7f951db225de2e7a88c92" alt=""
data:image/s3,"s3://crabby-images/e812c/e812c8cd3157efb685d3944f9b10c0f98409e092" alt=""
data:image/s3,"s3://crabby-images/36f14/36f1409fc3fcd93c4d805629cd9fd48dec9c2975" alt=""
data:image/s3,"s3://crabby-images/e9c2f/e9c2fd3112559bdb350cabb94169cb2abe1a86f4" alt=""
data:image/s3,"s3://crabby-images/1f9ef/1f9efaba2e49842bb4d6d69a42a81d47de3bbe8e" alt=""
data:image/s3,"s3://crabby-images/18eca/18eca4c5a35cd0ab460601336a685fc223e45051" alt=""
data:image/s3,"s3://crabby-images/18eca/18eca4c5a35cd0ab460601336a685fc223e45051" alt=""
data:image/s3,"s3://crabby-images/7488f/7488f8023ffbe7777677b272eabde1a1daa4be8c" alt=""
- origin
- 1st coordinate
- 2nd coordinate
- 3rd coordinate
Applying a rotation around the 3rd coordinate gives
data:image/s3,"s3://crabby-images/2fa73/2fa7320ded7481e2c9f08e03a7804cec8f48483c" alt=""
data:image/s3,"s3://crabby-images/573db/573dbdba551d73111bf28a9a74c3426a161daa2f" alt=""
data:image/s3,"s3://crabby-images/c4bb2/c4bb2ba6f8a7265868d7f951db225de2e7a88c92" alt=""
data:image/s3,"s3://crabby-images/e812c/e812c8cd3157efb685d3944f9b10c0f98409e092" alt=""
data:image/s3,"s3://crabby-images/36f14/36f1409fc3fcd93c4d805629cd9fd48dec9c2975" alt=""
data:image/s3,"s3://crabby-images/e9c2f/e9c2fd3112559bdb350cabb94169cb2abe1a86f4" alt=""
data:image/s3,"s3://crabby-images/1f9ef/1f9efaba2e49842bb4d6d69a42a81d47de3bbe8e" alt=""
data:image/s3,"s3://crabby-images/18eca/18eca4c5a35cd0ab460601336a685fc223e45051" alt=""
What are advantages of parametric and implicit representations of geometric objects (lines, planes, etc.)?
Parametric: Easy to generate points, hard to verify points
Implicit: Easy to verify points, hard to generate points
Implicit: Easy to verify points, hard to generate points
data:image/s3,"s3://crabby-images/c64c7/c64c7f61abb9e2d96a6c69beff1bd79eb8bfc4e8" alt=""
Kartensatzinfo:
Autor: janisborn
Oberthema: Informatik
Thema: Computergrafik
Schule / Uni: RWTH Aachen
Ort: Aachen
Veröffentlicht: 18.05.2022
Schlagwörter Karten:
Alle Karten (116)
keine Schlagwörter