collection="name"
reference is allowed.
+
+
+
+## Geometry Prefixes
+
+As a shorthand convenience, MaterialX allows the specification of a `geomprefix` attribute that will be prepended to data values of type "geomname" or "geomnamearray" (e.g. `geom` attributes in `+ +--- + + +**MaterialX v1.39** provides the following enhancements over v1.38: + + +**MaterialX Geometry Extensions** + +The parts of the main MaterialX Specification document dealing with various Geometry-related features has now been split into a separate [**MaterialX Geometry Extensions**](./MaterialX.GeomExts.md) document, describing Collections, Geometry Name Expressions, geometry-related data types, Geometry Info elements and the GeomProp and Token elements used within them, and Look, Property, Visibility and assignment elements. + +With this split, applications can claim to be MaterialX Compatible if they support all the things described in the main Specification, e.g. the elements for nodegraph shading networks and materials as well as the standard set of nodes, while using an application's native mechanisms or something like USD to describe the assignment of these materials to geometry. Applications may additionally support the MaterialX Geometry Extensions and thus use a single unified representation for complete CG objecct looks. + + +**New Support for Shader AOVs** + +Previously, MaterialX used custom types with a structure of output variables to define shader AOVs. But this approach was not very flexible and in fact had not been implemented. In v1.39, nodegraph-based shader implementations can include new [<aovoutput> elements](./MaterialX.Specification.md#aov-output-elements) to define AOVs which renderers can use to output additional channels of information in addition to the final shading result, while file-based <implementation>s can similarly define AOVs using [<aov> elements](./MaterialX.Specification.md#implementation-aov-elements). + + +**Array Types Now Uniform and Static Length** + +Many shading languages do not support dynamic array types with a variable length, so MaterialX now only supports arrays with a fixed maximum length, and all array-type node inputs must be uniform; nodes are no longer permitted to output an array type. Array-type inputs may be accompanied by a uniform integer input declaring the number of array elements actually used in the array. Because of this change, the unimplemented <arrayappend> node has been removed. + + +**Connectable Uniform Inputs and New Tokenvalue Node** + +A uniform node input is now explicitly allowed to be connected to the output of a <constant> node. This makes it possible to define a uniform value and use it in multiple places in a nodegraph. + +Similarly, <token>s in materials and other node instances may now be connected to the output of a new <tokenvalue> node: this is essentially a <constant> node but which connects to <token>s rather than <input>s. + + +**Standardized Color Space Names** + +The [standard colorspace names](./MaterialX.Specification.md#color-spaces-and-color-management-systems) in MaterialX have now been defined explicitly in the Specification, and are aligned to their definitions in the ACES 1.2 OCIO config file. With this change, there is no need for a definition of "cms" or "cmsconfig" in MaterialX documents, so those two attributes have been deprecated. + + +**Disambiguated Nodedef and Nodegraph References** + +Normally, the set of provided inputs to a node and their types in conjunction with the output type of the node itself is sufficient to disambiguate exactly which nodedef signature should be applied. In the rare situations where this is not sufficient, it is now permissible for any node instantiation to specify the name of a nodedef to completely disambiguate the intended node signature. + +Additionally, a <nodegraph> could previously declare itself to be an implementation of a particular <nodedef> by providing a "nodedef" attribute, which is still the preferred method for making this association. Now, it is also permissible for an [<implementation> element](39/MaterialX.Specification.md#custom-node-definition-using-implementation-elements) to provide a "nodegraph" attribute to declare that nodegraph to be the implementation for the nodedef specified in the <implementation>. This allows a single nodegraph to be the implementation of multiple nodedefs, e.g. two different node names with the same underlying implementation, or if the only difference between two versions of a nodedef is the default values. + + +**Generalized Swizzle Operator Removed** + +The standard <swizzle> node using a string of channel names and allowing arbitrary channel reordering is very inefficient (and in some shading languages virtually impossible) to implement as previously specified, and as such has been removed. Nodegraphs should instead use combinations of <extract> (which is now a standard node), <separateN> and <combineN> nodes to perform arbitrary channel reordering. Additionally, the previous "channels" attribute for inputs which allowed arbitrary channel reordering and used string "swizzle" channel naming has been replaced with an integer "channel" attribute, allowing a float input to be connected to a specified channel number of a colorN or vectorN output. This is both far more efficient to implement and more closely matches the conventions for connecting different input and output types available in modern DCCs. + + +**New Unlit Surface Shader and Standard Materials** + +A new standard <surface> constructor node for unlit surfaces has been added to the standard library. + +Additionally, the standard <surfacematerial> material now supports both single- or double-sided surfaces with the addition of a separate `backsurface` input. + + +**Inheritance and Hints for Typedefs** + +Typedefs may now inherit from other types, including built-in types, and may provide hints about their values such as floating-point precision. These new "inherit" and "hint" attributes are themselves merely metadata hints about the types; applications and code generators are still expected to provide their own precise definitions for all custom types. + + +**New Nodes** + +The following new standard operator nodes have been added: + +* [Procedural nodes](./MaterialX.Specification.md#procedural-nodes): **tokenvalue**, **fractal2d**, **cellnoise1d** +* [Geometric nodes](./MaterialX.Specification.md#geometric-nodes): **bump**, **geompropvalueuniform** +* [Math nodes](./MaterialX.Specification.md#math-nodes): boolean **and**, **or**, **not**; **transformcolor**, **creatematrix** +* [Adjustment nodes](./MaterialX.Specification.md#adjustment-nodes): **curveinversecubic**, **curveuniformlinear** and **curveuniformcubic** +* [Conditional nodes](./MaterialX.Specification.md#conditional-nodes): boolean-output variants of **ifgreater**, **ifgreatereq** and **ifequal**; new **ifelse** node +* [Channel nodes](./MaterialX.Specification.md#channel-nodes): **extractrowvector** + +Additionally, the following new supplemental nodes have been added: + +* [Procedural nodes](./MaterialX.Supplement.md#supplemental-procedural-nodes): **unifiednoise2d**, **unifiednoise3d** +* [Math nodes](./MaterialX.Supplement.md#supplemental-math-nodes): **triplanarblend** +* [Adjustment nodes](./MaterialX.Supplement.md#supplemental-adjustment-nodes): **colorcorrect** +* [Channel nodes](./MaterialX.Supplement.md#supplemental-channel-nodes): **separatecolor4** + + +**New Physically Based Shading Nodes** + +The following new standard physically based shading nodes have been added: + +* [EDF nodes](./MaterialX.PBRSpec.md#edf-nodes): **generalized_schlick_edf** +* [Shader nodes](./MaterialX.PBRSpec.md#shader-nodes): **environment** (latlong environment light source) + + +**Other Changes** + +* The <member> element for <typedef>s and the "member" attribute for inputs have been removed from the Specification, as they had never been implemented and it was not clear how they could be implemented generally. +* The "valuerange" and "valuecurve" attributes describing expressions and function curves have been removed, in favor of using the new <curveinversecubic> / <curveuniformcubic> / etc. nodes. +* The <cellnoise2d> and <cellnoise3d> nodes now support vectorN output types in addition to float output. +* The <worleynoise2d> and <worleynoise3d> nodes now support a number of different distance metrics. +* The <time> node no longer has a "frames per second" input: the application is now always expected to generate the "current time in seconds" using an appropriate method. "Fps" was removed because varible-rate real-time applications have no static "fps", and it's generally not good to bake a situation-dependent value like fps into a shading network. +* A standard "tangent" space is now defined in addition to "model", "object" and "world" spaces, and the <heighttonormal> node now accepts a uniform "space" input to define the space of the output normal vector. +* The <surface> and <displacement> nodes are now part of the main Specification rather than being Physically Based Shading nodes. +* <Token> elements are now explicitly allowed to be children of compound nodegraphs, and token values may now have defined enum/enumvalues. +* Inputs in <nodedef>s may now supply "hints" to code generators as to their intended interpretation, e.g. "transparency" or "opacity". +* <Attributedef> elements may now define enum/enumvalues to list acceptable values or labels/mapped values for an attribute. +* If a string input specifies an "enum" list, the list is now considered a "strict" list of allowable values; no values are allowed outside that list. To make the input non-strict, one must omit the "enum" atribute from the input. + + +Suggestions for v1.39: + +* Add a boolean “bound” output to the various geometry property nodes, so materials can be flexible if a given attribute doesn’t exist. Especially ones like <texcoord> that don’t let users specify names. + diff --git a/documents/Specification/inprog_v1.39/media/MaterialX_1.39_Overview_v5.png b/documents/Specification/inprog_v1.39/media/MaterialX_1.39_Overview_v5.png new file mode 100644 index 0000000000..fd2cf1630f Binary files /dev/null and b/documents/Specification/inprog_v1.39/media/MaterialX_1.39_Overview_v5.png differ diff --git a/documents/Specification/inprog_v1.39/media/PBSdiagram.png b/documents/Specification/inprog_v1.39/media/PBSdiagram.png new file mode 100644 index 0000000000..f802e36615 Binary files /dev/null and b/documents/Specification/inprog_v1.39/media/PBSdiagram.png differ diff --git a/documents/Specification/inprog_v1.39/media/nodegraph1.png b/documents/Specification/inprog_v1.39/media/nodegraph1.png new file mode 100644 index 0000000000..56322249f4 Binary files /dev/null and b/documents/Specification/inprog_v1.39/media/nodegraph1.png differ diff --git a/documents/Specification/inprog_v1.39/media/nodegraph2.png b/documents/Specification/inprog_v1.39/media/nodegraph2.png new file mode 100644 index 0000000000..3611e93d3e Binary files /dev/null and b/documents/Specification/inprog_v1.39/media/nodegraph2.png differ