Catmull–Clark subdivision surface explained

The Catmull–Clark algorithm is a technique used in 3D computer graphics to create curved surfaces by using subdivision surface modeling. It was devised by Edwin Catmull and Jim Clark in 1978 as a generalization of bi-cubic uniform B-spline surfaces to arbitrary topology.

In 2005/06, Edwin Catmull, together with Tony DeRose and Jos Stam, received an Academy Award for Technical Achievement for their invention and application of subdivision surfaces. DeRose wrote about "efficient, fair interpolation" and character animation. Stam described a technique for a direct evaluation of the limit surface without recursion.

Recursive evaluation

Catmull–Clark surfaces are defined recursively, using the following refinement scheme.[1]

Start with a mesh of an arbitrary polyhedron. All the vertices in this mesh shall be called original points.

A+F+M+E
4
[2]
F+2R+(n-3)P
n
(This is the barycenter of P, R and F with respective weights (n − 3), 2 and 1)

Properties

The new mesh will consist only of quadrilaterals, which in general will not be planar. The new mesh will generally look "smoother" (i.e. less "jagged" or "pointy") than the old mesh. Repeated subdivision results in meshes that are more and more rounded.

The arbitrary-looking barycenter formula was chosen by Catmull and Clark based on the aesthetic appearance of the resulting surfaces rather than on a mathematical derivation, although they do go to great lengths to rigorously show that the method converges to bicubic B-spline surfaces.

It can be shown that the limit surface obtained by this refinement process is at least

l{C}1

at extraordinary vertices and

l{C}2

everywhere else (when n indicates how many derivatives are continuous, we speak of

l{C}n

continuity). After one iteration, the number of extraordinary points on the surface remains constant.

Exact evaluation

The limit surface of Catmull–Clark subdivision surfaces can also be evaluated directly, without any recursive refinement. This can be accomplished by means of the technique of Jos Stam (1998).[3] This method reformulates the recursive refinement process into a matrix exponential problem, which can be solved directly by means of matrix diagonalization.

Software using the algorithm

See also

Further reading

Notes and References

  1. Catmull . E. . Edwin Catmull. Clark . J. . James H. Clark. 10.1016/0010-4485(78)90110-0 . Recursively generated B-spline surfaces on arbitrary topological meshes . Computer-Aided Design . 10 . 6 . 350 . 1978 . 121149868 .
  2. Web site: Catmull–Clark subdivision surface - Rosetta Code. 2022-01-13. rosettacode.org.
  3. Book: Stam. J.. Jos Stam. Exact evaluation of Catmull-Clark subdivision surfaces at arbitrary parameter values. 10.1145/280814.280945. Proceedings of the 25th annual conference on Computer graphics and interactive techniques - SIGGRAPH '98. http://www.dgp.toronto.edu/people/stam/reality/Research/pdf/sig98.pdf. 395–404. 1998. 978-0-89791-999-9. 10.1.1.20.7798. 2771758.
  4. Web site: Subdivision Surface Modifier. 2020-01-15.
  5. Web site: Archived copy . 2016-12-04 . https://web.archive.org/web/20161123062105/http://www.ptc.com/File%20Library/Community/Academic%20Program/College_Student_Primer_Creo_2.pdf . 2016-11-23 . dead .
  6. Book: Martin Watt . Erwin Coumans . George ElKoura . Ronald Henderson . Manuel Kraemer . Jeff Lait . James Reinders . 3 . Multithreading for Visual Effects. 2014. CRC Press. 978-1-4822-4356-7. 163–199. Manuel Kraemer. OpenSubdiv: Interoperating GPU Compute and Drawing.
  7. live . https://ghostarchive.org/varchive/youtube/20211211/xFZazwvYc5o . 2021-12-11. Meet the Experts: Pixar Animation Studios, The OpenSubdiv Project . YouTube.
  8. Web site: Pixar's OpenSubdiv V2: A detailed look. 2013-09-18.
  9. http://on-demand.gputechconf.com/gtc/2014/video/S4856-subdivision-surfaces-industry-standard.mp4 AV Media
  10. live . https://ghostarchive.org/varchive/youtube/20211211/dzIl_S-qHIQ . 2021-12-11. OpenSubdiv Blender demo . YouTube.