mirror of
https://github.com/PixarAnimationStudios/OpenSubdiv
synced 2025-01-10 16:40:11 +00:00
Updated Far and Osd user guide docs for 3.4
Updated the Far Overview and Osd Overview and shader interface pages for 3.4 to include a discussion of trianglular patch types and other minor updates.
This commit is contained in:
parent
b28290439c
commit
95138e680f
@ -294,42 +294,21 @@ to refine primvar data.
|
|||||||
Far::PatchTable
|
Far::PatchTable
|
||||||
================
|
================
|
||||||
|
|
||||||
The patch table is a serialized topology representation. This container is
|
PatchTable is the collection of patches derived from the refined faces of a particular mesh topology.
|
||||||
generated using *Far::PatchTableFactory* from an instance
|
|
||||||
*Far::TopologyRefiner* after a refinement has been applied. The
|
|
||||||
FarPatchTableFactory traverses the data-structures of the TopologyRefiner and
|
|
||||||
serializes the sub-faces into collections of bi-linear and bi-cubic patches as
|
|
||||||
dictated by the refinement mode (uniform or adaptive). The patches are then
|
|
||||||
sorted into arrays based on their types.
|
|
||||||
|
|
||||||
.. container:: notebox
|
This collection is created using *Far::PatchTableFactory* from an instance
|
||||||
|
of *Far::TopologyRefiner* after refinement has been applied.
|
||||||
**Release Notes (3.0.0)**
|
|
||||||
|
|
||||||
The organization and API of Far::PatchTable is likely to change
|
|
||||||
in the 3.1 release to accommodate additional functionality including:
|
|
||||||
smooth face-varying interpolation on patches, and dynamic feature
|
|
||||||
adaptive isolation (DFAS), and patch evaluation of Loop subdivision
|
|
||||||
surfaces.
|
|
||||||
|
|
||||||
Patch Arrays
|
Patch Arrays
|
||||||
************
|
************
|
||||||
|
|
||||||
The patch table is a collection of control vertex indices. Meshes are decomposed
|
The PatchTable is organized into patch arrays. All patches in each array have
|
||||||
into a collection of patches, which can be of different types. Each type
|
the same type except for face-varying patch arrays which may have a mix of regular and irregular patch types.
|
||||||
has different requirements for the internal organization of its
|
|
||||||
control-vertices. A PatchArray contains a sequence of multiple patches that
|
|
||||||
share a common set of attributes.
|
|
||||||
|
|
||||||
While all patches in a PatchArray will have the same type, each patch in the
|
The *PatchDescriptor* provides the fundamental description of a patch, including the number of control points per patch as well as the basis for patch evaluation.
|
||||||
array is associated with a distinct *PatchParam* which specifies additional
|
|
||||||
information about the individual patch.
|
|
||||||
|
|
||||||
Each PatchArray contains a patch *Descriptor* that provides the fundamental
|
Each patch in the array is associated with a *PatchParam* which
|
||||||
description of the patches in the array.
|
specifies additional information about the individual patch.
|
||||||
|
|
||||||
The PatchArray *ArrayRange* provides the indices necessary to track the records
|
|
||||||
of individual patches in the table.
|
|
||||||
|
|
||||||
.. image:: images/far_patchtables.png
|
.. image:: images/far_patchtables.png
|
||||||
:align: center
|
:align: center
|
||||||
@ -350,19 +329,21 @@ PatchTable:
|
|||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| LINES | 2 | Lines : useful for cage drawing |
|
| LINES | 2 | Lines : useful for cage drawing |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| QUADS | 4 | Bi-linear quads-only patches |
|
| QUADS | 4 | Bi-linear quadrilaterals |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| TRIANGLES | 3 | Bi-linear triangles-only mesh |
|
| TRIANGLES | 3 | Linear triangles |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| LOOP | n/a | Loop patch (currently unsupported) |
|
| LOOP | 12 | Quartic triangular Box-spline patches |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| REGULAR | 16 | B-spline Basis patches |
|
| REGULAR | 16 | Bi-cubic B-spline patches |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| GREGORY | 4 | Legacy Gregory patches |
|
| GREGORY | 4 | Legacy Gregory patches |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| GREGORY_BOUNDARY | 4 | Legacy Gregory Boundary patches |
|
| GREGORY_BOUNDARY | 4 | Legacy Gregory Boundary patches |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
| GREGORY_BASIS | 20 | Gregory Basis patches |
|
| GREGORY_BASIS | 20 | Bi-cubic quadrilateral Gregory patches |
|
||||||
|
+---------------------+------+---------------------------------------------+
|
||||||
|
| GREGORY_TRIANGLE | 18 | Quartic triangular Gregory patches |
|
||||||
+---------------------+------+---------------------------------------------+
|
+---------------------+------+---------------------------------------------+
|
||||||
|
|
||||||
|
|
||||||
@ -372,6 +353,10 @@ table as well as the method used to evaluate values.
|
|||||||
Patch Parameterization
|
Patch Parameterization
|
||||||
**********************
|
**********************
|
||||||
|
|
||||||
|
Here we describe the encoding of the patch parameterization for
|
||||||
|
quadrilateral patches. The encoding for triangular patches is similar,
|
||||||
|
please see the API documentation of Far::PatchParam for details.
|
||||||
|
|
||||||
Each patch represents a specific portion of the parametric space of the
|
Each patch represents a specific portion of the parametric space of the
|
||||||
coarse topological face identified by the PatchParam FaceId. As topological
|
coarse topological face identified by the PatchParam FaceId. As topological
|
||||||
refinement progresses through successive levels, each resulting patch
|
refinement progresses through successive levels, each resulting patch
|
||||||
@ -435,11 +420,9 @@ sharpness parameter.
|
|||||||
|
|
||||||
.. container:: notebox
|
.. container:: notebox
|
||||||
|
|
||||||
**Release Notes (3.0.0)**
|
**Release Notes (3.x)**
|
||||||
|
|
||||||
Currently, the crease sharpness parameter is encoded as a separate
|
Evaluation
|
||||||
PatchArray within the PatchTable. This parameter may be combined
|
|
||||||
with the other PatchParam values in future releases. Also, evaluation
|
|
||||||
of single-crease patches is currently only implemented for OSD patch
|
of single-crease patches is currently only implemented for OSD patch
|
||||||
drawing, but we expect to implement support in all of the evaluation
|
drawing, but we expect to implement support in all of the evaluation
|
||||||
code paths for future releases.
|
code paths for future releases.
|
||||||
@ -453,15 +436,6 @@ adaptively to the points of the coarse mesh. However, the final patches
|
|||||||
generated from irregular faces, e.g. patches incident on an extraordinary
|
generated from irregular faces, e.g. patches incident on an extraordinary
|
||||||
vertex might have a representation which requires additional local points.
|
vertex might have a representation which requires additional local points.
|
||||||
|
|
||||||
.. container:: notebox
|
|
||||||
|
|
||||||
**Release Notes (3.0.0)**
|
|
||||||
|
|
||||||
Currently, representations which require local points also require
|
|
||||||
the use of a StencilTable to compute the values of local points.
|
|
||||||
This requirement, as well as the rest of the API related to local
|
|
||||||
points may change in future releases.
|
|
||||||
|
|
||||||
Legacy Gregory Patches
|
Legacy Gregory Patches
|
||||||
**********************
|
**********************
|
||||||
|
|
||||||
@ -472,15 +446,6 @@ Legacy Gregory patches are used, the PatchTable must also have an alternative
|
|||||||
representation of the mesh topology encoded as a vertex valence table
|
representation of the mesh topology encoded as a vertex valence table
|
||||||
and a quad offsets table.
|
and a quad offsets table.
|
||||||
|
|
||||||
.. container:: notebox
|
|
||||||
|
|
||||||
**Release Notes (3.0.0)**
|
|
||||||
|
|
||||||
The encoding and support for Legacy Gregory patches may change
|
|
||||||
in future releases. The current encoding of the vertex valence
|
|
||||||
and quad offsets tables may be prohibitively expensive for some
|
|
||||||
use cases.
|
|
||||||
|
|
||||||
Far::StencilTable
|
Far::StencilTable
|
||||||
==================
|
==================
|
||||||
|
|
||||||
|
@ -42,8 +42,8 @@ The main roles of **Osd** are:
|
|||||||
Compute limit surfaces by limit stencils on CPU/GPU backends
|
Compute limit surfaces by limit stencils on CPU/GPU backends
|
||||||
- **Limit Evaluation with PatchTable**
|
- **Limit Evaluation with PatchTable**
|
||||||
Compute limit surfaces by patch evaluation on CPU/GPU backends
|
Compute limit surfaces by patch evaluation on CPU/GPU backends
|
||||||
- **OpenGL/DX11 Drawing with hardware tessellation**
|
- **OpenGL/DX11/Metal Drawing with hardware tessellation**
|
||||||
Provide GLSL/HLSL tessellation functions for patch table
|
Provide GLSL/HLSL/Metal tessellation functions for patch table
|
||||||
- **Interleaved/Batched buffer configuration**
|
- **Interleaved/Batched buffer configuration**
|
||||||
Provide consistent buffer descriptor to deal with arbitrary buffer layout.
|
Provide consistent buffer descriptor to deal with arbitrary buffer layout.
|
||||||
- **Cross-Platform Implementation**
|
- **Cross-Platform Implementation**
|
||||||
@ -98,7 +98,8 @@ as a stencil tables as long as Evaluator::EvalStencils() can access the necessar
|
|||||||
+-----------------------------+-----------------------+-------------------------+
|
+-----------------------------+-----------------------+-------------------------+
|
||||||
| DX11 ComputeShader (GPU) | D3D11ComputeEvaluator | D3D11StencilTable |
|
| DX11 ComputeShader (GPU) | D3D11ComputeEvaluator | D3D11StencilTable |
|
||||||
+-----------------------------+-----------------------+-------------------------+
|
+-----------------------------+-----------------------+-------------------------+
|
||||||
|
| Metal (GPU) | MTLComputeEvaluator | MTLStencilTable |
|
||||||
|
+-----------------------------+-----------------------+-------------------------+
|
||||||
|
|
||||||
Limit Stencil Evaluation
|
Limit Stencil Evaluation
|
||||||
========================
|
========================
|
||||||
@ -141,17 +142,18 @@ Once all control vertices and local points are resolved by the stencil evaluatio
|
|||||||
| DX11 ComputeShader (GPU) | | D3D11ComputeEvaluator | D3D11PatchTable |
|
| DX11 ComputeShader (GPU) | | D3D11ComputeEvaluator | D3D11PatchTable |
|
||||||
| | | (*)not yet supported | |
|
| | | (*)not yet supported | |
|
||||||
+-----------------------------+-------------------------+-------------------------+
|
+-----------------------------+-------------------------+-------------------------+
|
||||||
|
| Metal ComputeShader (GPU) | | MTLComputeEvaluator | MTLPatchTable |
|
||||||
|
+-----------------------------+-------------------------+-------------------------+
|
||||||
|
|
||||||
.. container:: notebox
|
.. container:: notebox
|
||||||
|
|
||||||
**Release Notes (3.0.0)**
|
**Release Notes (3.x)**
|
||||||
|
|
||||||
* GPU limit evaluation backends (Evaluator::EvalPatches()) only support
|
* Osd evaluation backends (Evaluator::EvalPatches()) do not support
|
||||||
BSpline patches. Clients need to specify BSpline approximation for endcap
|
evaluation of single-crease or Legacy Gregory patch types.
|
||||||
when creating a patch table. See `end capping <far_overview.html#endcap>`__.
|
|
||||||
|
|
||||||
OpenGL/DX11 Drawing with Hardware Tessellation
|
OpenGL/DX11/Metal Drawing with Hardware Tessellation
|
||||||
==============================================
|
====================================================
|
||||||
|
|
||||||
One of the most interesting use cases of the **Osd** layer is realtime drawing
|
One of the most interesting use cases of the **Osd** layer is realtime drawing
|
||||||
of subdivision surfaces using hardware tessellation. This is somewhat similar to
|
of subdivision surfaces using hardware tessellation. This is somewhat similar to
|
||||||
@ -265,6 +267,8 @@ The methods that need to be implemented for the Evaluators are:
|
|||||||
+-----------------------+------------------------+------------------+
|
+-----------------------+------------------------+------------------+
|
||||||
| D3D11ComputeEvaluator | D3D11 UAV | BindD3D11UAV() |
|
| D3D11ComputeEvaluator | D3D11 UAV | BindD3D11UAV() |
|
||||||
+-----------------------+------------------------+------------------+
|
+-----------------------+------------------------+------------------+
|
||||||
|
| MTLComputeEvaluator | MTLBuffer | BindMTLBuffer() |
|
||||||
|
+-----------------------+------------------------+------------------+
|
||||||
|
|
||||||
The buffers can use these methods as a trigger of interop. **Osd** provides a default
|
The buffers can use these methods as a trigger of interop. **Osd** provides a default
|
||||||
implementation of interop buffer for most of the backend combinations.
|
implementation of interop buffer for most of the backend combinations.
|
||||||
|
@ -50,8 +50,8 @@ The following is a minimal example of GLSL code explaining how client shader cod
|
|||||||
uses OpenSubdiv shader functions to tessellate patches of a patch table.
|
uses OpenSubdiv shader functions to tessellate patches of a patch table.
|
||||||
|
|
||||||
|
|
||||||
Tessellation Control Shader Example (for BSpline patches)
|
Tessellation Control Shader Example (for B-Spline patches)
|
||||||
*********************************************************
|
**********************************************************
|
||||||
|
|
||||||
.. code:: glsl
|
.. code:: glsl
|
||||||
|
|
||||||
@ -88,8 +88,8 @@ Tessellation Control Shader Example (for BSpline patches)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
Tessellation Evaluation Shader Example (for BSpline patches)
|
Tessellation Evaluation Shader Example (for B-Spline patches)
|
||||||
************************************************************
|
*************************************************************
|
||||||
|
|
||||||
.. code:: glsl
|
.. code:: glsl
|
||||||
|
|
||||||
@ -160,7 +160,8 @@ are stored in a OsdPerPatchVertexGreogryBasis struct.
|
|||||||
|
|
||||||
.. code:: glsl
|
.. code:: glsl
|
||||||
|
|
||||||
void OsdComputePerPatchVertexGregoryBasis(
|
void
|
||||||
|
OsdComputePerPatchVertexGregoryBasis(
|
||||||
ivec3 patchParam, int ID, vec3 cv, out OsdPerPatchVertexGregoryBasis result)
|
ivec3 patchParam, int ID, vec3 cv, out OsdPerPatchVertexGregoryBasis result)
|
||||||
|
|
||||||
The tessellation evaluation shader takes an array of OsdPerPatchVertexGregoryBasis struct,
|
The tessellation evaluation shader takes an array of OsdPerPatchVertexGregoryBasis struct,
|
||||||
@ -174,6 +175,54 @@ and then evaluates the patch using the OsdEvalPatchGregory() function.
|
|||||||
out vec3 N, out vec3 dNu, out vec3 dNv)
|
out vec3 N, out vec3 dNu, out vec3 dNv)
|
||||||
|
|
||||||
|
|
||||||
|
Box-spline Triangle Patch
|
||||||
|
*************************
|
||||||
|
|
||||||
|
While regular triangle patches are expressed as triangular box-spline patches in Far::PatchTable,
|
||||||
|
the **Osd** shader converts them into triangular Bezier patches for consistency.
|
||||||
|
This conversion is performed in the tessellation control stage. The boundary edge evaluation is resolved during this conversion.
|
||||||
|
OsdComputePerPatchVertexBoxSplineTriangle() can be used for this process.
|
||||||
|
The resulting Bezier control vertices are stored in OsdPerPatchVertexBezier struct.
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void
|
||||||
|
OsdComputePerPatchVertexBoxSplineTriangle(
|
||||||
|
ivec3 patchParam, int ID, vec3 cv[12], out OsdPerPatchVertexBezier result);
|
||||||
|
|
||||||
|
The tessellation evaluation shader takes an array of OsdPerPatchVertexBezier struct,
|
||||||
|
and then evaluates the patch using the OsdEvalPatchBezierTriangle() function.
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void OsdEvalPatchBezierTriangle(ivec3 patchParam, vec2 UV,
|
||||||
|
OsdPerPatchVertexBezier cv[15],
|
||||||
|
out vec3 P, out vec3 dPu, out vec3 dPv,
|
||||||
|
out vec3 N, out vec3 dNu, out vec3 dNv)
|
||||||
|
|
||||||
|
|
||||||
|
Gregory Triangle Patch
|
||||||
|
**********************
|
||||||
|
|
||||||
|
OsdComputePerPatchVertexGregoryBasis() can be used for the quartic triangular Gregory patches (although no basis conversion involved for the Gregory triangle patches) and the resulting vertices are stored in a OsdPerPatchVertexGreogryBasis struct.
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void
|
||||||
|
OsdComputePerPatchVertexGregoryBasis(
|
||||||
|
ivec3 patchParam, int ID, vec3 cv, out OsdPerPatchVertexGregoryBasis result)
|
||||||
|
|
||||||
|
The tessellation evaluation shader takes an array of OsdPerPatchVertexGregoryBasis struct,
|
||||||
|
and then evaluates the patch using the OsdEvalPatchGregoryTriangle() function.
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void
|
||||||
|
OsdEvalPatchGregoryTriangle(ivec3 patchParam, vec2 UV, vec3 cv[18],
|
||||||
|
out vec3 P, out vec3 dPu, out vec3 dPv,
|
||||||
|
out vec3 N, out vec3 dNu, out vec3 dNv)
|
||||||
|
|
||||||
|
|
||||||
Legacy Gregory Patch (2.x compatibility)
|
Legacy Gregory Patch (2.x compatibility)
|
||||||
****************************************
|
****************************************
|
||||||
|
|
||||||
@ -190,12 +239,6 @@ Tessellation levels
|
|||||||
|
|
||||||
**Osd** provides both uniform and screen-space adaptive tessellation level computation.
|
**Osd** provides both uniform and screen-space adaptive tessellation level computation.
|
||||||
|
|
||||||
Uniform tessellation
|
|
||||||
OsdGetTessLevelsUniform()
|
|
||||||
|
|
||||||
Screen-space adaptive tessellation
|
|
||||||
OsdGetTessLevelsAdaptiveLimitPoints()
|
|
||||||
|
|
||||||
Because of the nature of `feature adaptive subdivision <far_overview.html>`__,
|
Because of the nature of `feature adaptive subdivision <far_overview.html>`__,
|
||||||
we need to pay extra attention for a patch's outer tessellation level for the screen-space
|
we need to pay extra attention for a patch's outer tessellation level for the screen-space
|
||||||
adaptive case so that cracks don't appear.
|
adaptive case so that cracks don't appear.
|
||||||
@ -212,31 +255,63 @@ as separate levels for the two segments of the edge split at the middle.
|
|||||||
|
|
||||||
.. image:: images/osd_shader_transition.png
|
.. image:: images/osd_shader_transition.png
|
||||||
|
|
||||||
Then the tessellation evaluation shader takes gl_TessCoord and those two values, and remaps
|
Tessellation levels at each tessellated vertex
|
||||||
gl_TessCoord using OsdGetTessParameterization() to ensure the parameters are consistent
|
**********************************************
|
||||||
|
|
||||||
|
The tessellation evaluation shader takes gl_TessCoord and those two values, and remaps
|
||||||
|
gl_TessCoord using OsdGetTessParameterization() or OsdGetTessLevelParameterizationTriangle() to ensure the parameters are consistent
|
||||||
across adjacent patches.
|
across adjacent patches.
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
vec2 OsdGetTessParameterization(vec2 uv, vec4 tessOuterLo, vec4 tessOuterHi);
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
vec2 OsdGetTessParameterizationTriangle(vec3 uvw, vec4 tessOuterLo, vec4 tessOuterHi);
|
||||||
|
|
||||||
.. image:: images/osd_shader_param_remap.png
|
.. image:: images/osd_shader_param_remap.png
|
||||||
|
|
||||||
.. code:: glsl
|
Tessellation levels computed at each patch
|
||||||
|
******************************************
|
||||||
|
|
||||||
vec2 OsdGetTessParameterization(vec2 uv, vec4 tessOuterLo, vec4 tessOuterHi)
|
These tessellation levels can be computed the corresponding method in the tesselation control shader. Note that these functions potentially requires all bezier control
|
||||||
|
|
||||||
These tessellation levels can be computed by OsdGetTessLevelsAdaptiveLimitPoints()
|
|
||||||
in the tessellation control shader. Note that this function requires all 16 bezier control
|
|
||||||
points, you need to call barrier() to ensure the conversion is done for all invocations.
|
points, you need to call barrier() to ensure the conversion is done for all invocations.
|
||||||
See osd/glslPatchBSpline.glsl for more details.
|
See osd/glslPatchBSpline.glsl for more details.
|
||||||
|
|
||||||
|
Uniform
|
||||||
|
~~~~~~~
|
||||||
|
|
||||||
.. code:: glsl
|
.. code:: glsl
|
||||||
|
|
||||||
void OsdGetTessLevelsAdaptiveLimitPoints(OsdPerPatchVertexBezier cpBezier[16],
|
void
|
||||||
ivec3 patchParam,
|
OsdGetTessLevelsUniform(ivec3 patchParam,
|
||||||
out vec4 tessLevelOuter, out vec2 tessLevelInner,
|
out vec4 tessLevelOuter, out vec2 tessLevelInner,
|
||||||
out vec4 tessOuterLo, out vec4 tessOuterHi)
|
out vec4 tessOuterLo, out vec4 tessOuterHi)
|
||||||
|
|
||||||
.. container:: notebox
|
.. code:: glsl
|
||||||
|
|
||||||
**Release Notes (3.0.0)**
|
void
|
||||||
|
OsdGetTessLevelsUniformTriangle(ivec3 patchParam,
|
||||||
|
out vec4 tessLevelOuter, out vec2 tessLevelInner,
|
||||||
|
out vec4 tessOuterLo, out vec4 tessOuterHi)
|
||||||
|
|
||||||
* Currently OsdGetTessParameterization doesn't support fraction spacing.
|
|
||||||
It will be fixed in a future release.
|
Screenspace
|
||||||
|
~~~~~~~~~~~
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void OsdEvalPatchBezierTessLevels(
|
||||||
|
OsdPerPatchVertexBezier cpBezier[16],
|
||||||
|
ivec3 patchParam,
|
||||||
|
out vec4 tessLevelOuter, out vec2 tessLevelInner,
|
||||||
|
out vec4 tessOuterLo, out vec4 tessOuterHi);
|
||||||
|
|
||||||
|
.. code:: glsl
|
||||||
|
|
||||||
|
void OsdEvalPatchBezierTriangleTessLevels(
|
||||||
|
vec3 cv[15],
|
||||||
|
ivec3 patchParam,
|
||||||
|
out vec4 tessLevelOuter, out vec2 tessLevelInner,
|
||||||
|
out vec4 tessOuterLo, out vec4 tessOuterHi);
|
||||||
|
Loading…
Reference in New Issue
Block a user