Skip to content

Latest commit

 

History

History
10407 lines (8377 loc) · 505 KB

CHANGELOG.md

File metadata and controls

10407 lines (8377 loc) · 505 KB

Change Log

[25.02] - 2025-01-21

Build

  • Various fixes and changes to build_usd.py:

    • Added --no-zlib option to disable building zlib, for developers that need to supply their own version of the library. (PR: #2988, #3130)
    • Updated Boost dependency to 1.86.0 for Visual Studio 2022. (Issue: #1062, #2044, #2158, #3102)
    • Updated OpenEXR dependency to v3.1.13. (PR: #3077)
    • Updated OpenImageIO dependency to v2.5.6.0. (PR: #2940)
    • Updated to download boost from SourceForge or the official boost host.
    • Added --(no-)usdValidation option to enable/disable building the USD validation framework. USD validation is enabled by default.
  • Fixed various issues in pxr_boost::python when building against Python 3.11. (Issue: #3384)

  • Fixed issue with missing headers causing build failures with Visual Studio 2022. (Issue: #3433)

  • Fixed issues with precompiled headers when using Visual Studio and Ninja. (Issue: #3408, PR: #3204)

  • Various fixes for compilation issues and warnings.

    • Fixed compilation issues when building USD using the C++20 standard. (PR: #2605)
    • Made various fixes for compiler warnings emitted by GCC 11.
    • Made various fixes for stricter compiler parsing of templates by an upcoming clang/llvm release. (PR: #3434)
    • Correct re-declaration of structs as classes. (PR: #3316)
    • Static functions that should be static inline. (Issue: #3324, PR: #3356)
    • Overrides on member functions not marked override. (Issue: #3335, PR: #3355)
  • Fixed various link visibility issues.

    • Fixed methods from HdSingleInputFilteringSceneIndexBase. (PR: #3428)
    • Fixed HdDependenciesSchema::GetEntries. (PR: #3369)
    • Fixed HdxSelectionTracker.

USD

  • Increased the default version for newly-created binary files to 0.10.0. USD release 23.11 and newer support this file version. This can be overridden with the USD_WRITE_NEW_USDC_FILES_AS_VERSION env var.

  • Added UsdColorSpaceAPI for specifying the color space for a prim subtree.

  • Added UsdColorSpaceDefinitionAPI for defining custom color spaces.

  • Fixed issue where ArchDebuggerIsAttached would return false positives on some Linux distributions.
    (PR: #3014)

  • Fixed ArchGetFileName to return a full path on Windows. (PR: #3361)

  • Simplified and made the TfScriptModuleLoader thread-safe.

  • Added TfNotice::RevokeAndWait() to allow thread-safe revocation of notification.

  • Fixed issue where saving numeric data to text .usda layers could be formatted differently depending on the system locale. (Issue: #3214, PR: #3222)

  • Fixed an incorrect memory deallocation in TsRegressionPreventer.

  • Added WorkDispatcher::IsCancelled, which returns true if WorkDispatcher::Cancel has been called.

  • Removed flag PCP_DISABLE_TIME_SCALING_BY_LAYER_TCPS. Time sample scaling is always enabled.

  • Enabled change processing optimization for muting/unmuting and adding/removing sublayers. This can be disabled by setting the environment variable PCP_ENABLE_MINIMAL_CHANGES_FOR_LAYER_OPERATIONS to 0. See 24.11 release notes for more details.

  • Removed SdfPropertySpec::GetTimeSampleMap in favor of SdfAttributeSpec::GetTimeSampleMap.

  • Reverted deprecation of SdfLayer time sample methods.

  • Identifiers passed to SdfLayer::Find or FindOrOpen now have file format arguments removed before being resolved by ArResolver to keep resolver implementations from seeing unexpected values.

  • Made all SdfListOp setter methods enforce uniqueness by removing duplicates in explicit setter methods. Deprecated ModifyOperations(callback, removeDuplicates) as removeDuplicates is now assumed true.

  • Added SdfCreateAttributeInLayer and SdfCreateRelationshipInLayer.

  • Updated UsdNamespaceEditor to properly update the defaultPrim on affected layers when necessary.

  • Updated UsdUtilsModifyAssetPaths to preserve SdfAssetPath metadata. This was a fix to a regression introduced in 23.11.

  • Disabled UDIM resolution for ExtractExternalReferences, which addresses a behavior introduced in 23.11 where UDIM paths were not being resolved. (Issue: #3173)

  • The schema registry now throws a coding error if a schema is registered without a schemaIdentifier.

  • Updated usdGenSchema to only write out aliases to plugInfo if the prim type name does not match the class name.

  • Fixed updateSchemaWithSdrNote to add shaderId property appropriately for all shader nodes.

  • Fixed a bug in SdrShaderProperty where int arrays would always default to zero.

  • Added NdrRegistry.AddDiscoveryResult Python binding.

  • Various UsdValidation updates:

    • Moved the UsdValidation framework to its own library, pxr/usdValidation. Moved the USD schema domain validators to their respective schema libraries. This makes it possible for clients who do not want to use the validation framework to not have to have any dynamic library dependencies on the validation libraries.
    • Updated UsdValidationContext::Validate(stage) to validate all prims, including instance proxies, by default. Clients can also use the overload that takes a traversal predicate to be used for stage traversal when validating the stage.
    • Fixed a bug where schemaType validators were not processed by the UsdValidationContext.
    • Updated UsdValidationError::GetErrorAsString to include the error identifier information.
    • Added Python wrappings for UsdValidationContext.
    • Added UsdValidationTimeRange to allow prim and stage level validators to provide GfInterval or timeCodes, including default time to be evaluated for validation. Various UsdValidation core APIs are updated to use UsdValidationTimeRange. Added isTimeDependent metadata to UsdValidationValidatorMetadata to indicate if the validator is time dependent.
    • Added Validators to correspond to UsdUtilsComplianceChecker tests:
      • NormalMapTextureValidator (PR: #3443)
      • FileExtensionValidator (PR: #3444)
      • MissingReferenceValidator (PR: #3450)
      • RootPackageValidator and UsdzPackageValidator (PR: #3449)
  • Added support for scalar translate and scale xformOps. Added translateX, translateY, translateZ, scaleX, scaleY and scaleZ xformOps to correspond to translation along X, Y and Z and scale along X, Y and Z respectively. Also added APIs to UsdGeomXformable to allow to add the above mentioned xforms to UsdGeomXform.

Hydra

  • Removed deprecated OpenImageIO APIs from hioOiio to support OpenImageIO 3.0.0.x. (PR: #3418)

  • Improved diagnostics when rejecting primvars due to invalid interpolation values.

  • HdxAovInputTask no longer reads from an invalid memory address when converting a Float32Vec3 texture to a Float32Vec4 texture.

  • Fixed a regression that could result in assert failures in the aovInputTask when using some renderer plugins on macOS systems with discrete GPUs. (Issue: #3470)

  • Added the ability to only load Hydra Scene Index Plugins for a given set of apps, using the new "loadWithApps" HdSceneIndexPlugin type registration field. Plugin types can limit which apps will auto-load the plugin. When creating a scene index, an app name can be provided to load only specific plugins. Not specifying (or providing an empty) loadWithApps means all existing plugins will continue to be loaded normally.

  • Fixed a bug in HdMergingSceneIndex where it would not send out the proper notices when removing a prim. (Issue: #3261, #3471, PR: #3263)

  • Added scene index emulation support for tasks. Also added HdxFreeCameraPrimDataSource. The intention together with scene index emulation support for tasks is to make HdxTaskController a scene index.

  • Added an overload of HdEngine::Execute taking task paths, rather than task pointers.

  • Added API UsdviewqHydraObserver::GetNestedInputDisplayNames and TargetToNestedInputSceneIndex to see nested input scene indices.

  • Added HdsiSceneMaterialPruningSceneIndex which can implement material specific behaviors that the existing HdsiPrimTypePruningSceneIndex used for the same purpose cannot.

  • Fixed a case of over-invalidation in dirty bits emulation where repr and display style were invalidating each other.

  • Fixed dependency bugs in HdsiMaterialPrimvarTransferSceneIndex.

  • Fixed HdMapContainerDataSource producing output entries for keys with no input entry.

  • Fixed a bug in the dependency forwarding scene index to clear and recompute the dependency table entries for a prim when its dependencies are dirty.

  • Fixed propagation of light linking dirty bits for instancers in backend emulation.

  • Fixed unitTestHelper byteSize field. (PR: #3374)

  • Made correctness fix for HdRenderIndex::RemoveInputScene. (PR: #3304)

  • Implemented a vectorized version of HdxPrimOriginInfo::FromPickHit. (PR: #3413)

  • HdLegacyGeomSubsetSceneIndex will now properly clear its cache of descendants when an ancestor prim is removed.

  • HdSceneIndexAdapterSceneDelegate will now use the render delegate's material binding purpose when retrieving material bindings. (Issue: #3320, PR: #3352)

UsdImaging

  • Important: Deprecated UsdImagingGLRenderParams::enableIdRender setting in favor of using primId AOV. This setting will be removed in the following release.

  • UsdPreviewSurface's shader now computes a BRDF based on clearcoat roughness for the indirect lighting clearcoat component.

  • UsdPreviewSurface's shader now applies opacity to all components of the color, instead of only to the diffuse component.

  • Added a new opacityMode input to the Preview Surface spec to control whether or not fully transparent materials receive a specular response. HdPrman's implementation of PreviewSurface also updated to match the updated spec.

  • Improved type coverage of UsdImagingDataSourceAttribute. (Issue: #3298)

  • Made change to ensure HdSceneIndexAdapterSceneDelegate::GetMaterialResource considers all contexts. (Issue: #3286, PR: #3288)

  • Added a 2 * epsilon gap between opposing axis faces of drawMode cards cross geometry to avoid issues due to co-planarity. This significantly improves the stability of rendering, particularly with RenderMan.

Storm

  • Made various improvements to prim id rendering in Storm.

    • Deprecated HdxRenderTaskParams::enableIdRender setting in favor of using primId AOV.
    • Added support for int32 AOV format.
    • Introduced HdSt_RenderPassShaderKey to flexibility generate render pass shaders based on desired AOVs.
  • Fixed Vulkan crashes due to missing extensions and layers, and added reporting of missing layers and extensions. (PR: #3420)

  • Added a null GL context to use when X11 isn't available, so tests can still run when not using HgiGL. (PR: #3391)

  • Added OpenGL 3.1/GLSL 1.4 support to HgiInterop and use a VertexArray, as required by Apple OpenGL. (PR: #3391)

  • Added HGIVULKAN_VERIFY_VK_RESULT macro that verifies result of Vulkan call and prints result string if it fails. (PR: #3333)

  • Fixed a bug in HgiVulkanBlitCmds::CopyBufferCpuToGpu. (PR: #3382)

  • Fixed various HdSt and HgiVulkan build errors on Windows. (PR: #3411)

  • Updated HdSt test outputs and baselines so test outputs can be compared using FC.exe on Windows without any additional flags. (PR: #3409)

  • Various fixes to HdSt tests to enable their passing when using HgiVulkan with Lavapipe. (PR: #3170)

  • Dome light environment texture sampling now converts infinite or NaN values in any channel of a pixel to zero.

  • Added a dependency between rprim material binding and bound material.

  • Set GL_UNPACK_ALIGNMENT=1 to avoid texture distortion for single channel textures. (Issue: #3260, PR: #3262)

RenderMan Hydra Plugin

  • Improved diagnostics when issuing warnings about specific material networks.

  • HdPrman now avoids deleting and re-creating light instances in more cases when editing lights.

  • HdPrman now enables parallel sync for additional Hydra prim types, including materials and coordinate systems. This can be turned off with the environment setting HD_PRMAN_ENABLE_PARALLEL_PRIM_SYNC, which defaults to enabled.

  • Added scene index HdPrman_PreviewSurfacePrimvarsSceneIndex that adds primvar displacementbound:sphere to material primvars of materials using UsdPreviewSurface (to be transferred to the gprim later by the HdsiMaterialPrimvarTransferSceneIndex).

  • Updated args parser to support "sdrIgnore" and "sdrUsdDefault". "sdrIgnore" can be set to shader properties in the args file to suppress the property from getting added to its sdr representation. "sdrUsdDefault" can be used to set a specific default value for USD schema purposes.

  • Added support for more kinds of terminal nodes for material networks that use MaterialX patterns. Also, more than one node can make up the bxdf part of the network, e.g. if layering is involved.

  • Added code to force hider:incremental to be enabled for interactive renders.

  • Fixed a bug where the code that maps common USD names of AOVs, like 'normal', to RenderMan style names, like 'Nn', would inadvertently happen even when the AOV already had an associated 'lpe'. Now we only do the mapping if the sourceType wasn't already specified to be 'lpe' or 'primvar'.

  • Improved robustness if the scene provides a primvar schema without a value datasource.

  • Made change to register dependencies from a light on its targeted light filters to forward invalidations when the prims are backed by a non-emulated scene index.

  • Made optimizations to HdPrman_UpdateObjectSettingsSceneIndex to avoid unnecessary computation.

  • Removed Python bindings from rmanArgsParser.

  • Added the environment setting HD_PRMAN_ALL_LIGHTS_FIXED_SAMPLE_COUNT (int, default: -1). When set to a value > -1, hdPrman will set fixedSampleCount to the given value on all visible supported lights it encounters, overriding any value that might be authored on the light. This setting is intended to aid with testing, and should not be used in production.

  • Reduced pre-allocation of time sample arrays within instanced hierarchies to improve memory performance on scenes with heavy instancing.

  • Added experimental legacy mesh light support: PxrMesh and PxrVolume schemas now derive from their respective geometry classes rather than Light.

  • Lights will now properly depend on and update with their targeted light filters.

  • Role information for certain integrator, projection, and display and sample filter parameters is now retrieved by inspecting the relevant shader via SdrRegistry, rather than relying on lookup tables previously in projectionParams.h/cpp.

  • Added support for role lookup of integrator parameters set via RenderSettings & Integrator prims.

  • Fixed an issue when geometry prototype creation fails for an instanced gprim. Previously, this situation led to a fatal error about a missing light shader. Now we issue a non-fatal warning with an accurate message.

  • Fixed an issue that caused ri:hider:jitter to be ignored when authored in RenderSettings.

MaterialX

  • Allow for USD to be run with either MaterialX v1.38 or v1.39. (PR: #3159)

  • Added MaterialXConfigAPI and dataSourceAttributeTypeName to help support USD files that were written with v1.38 MaterialX nodes but run with MaterialX v1.39 (PR: #3157)

  • Fixed crash referencing image NodeDef. (PR: #3344)

usdview

  • Resolved labels are now displayed in a new "Resolved Labels" row in the attribute editor. Labels are resolved for prims and ancestors using the usdSemantics schema and APIs. (PR: #3300)

  • Removed unexposed "enableIdRender" setting from usdview.

usdchecker

  • Ported usdchecker to C++ and enabled it to use the new validation framework. Clients can use the --useNewValidationFramework flag to use the new validation framework. All the core USD validators available in the old UsdUtilsComplicanceChecker are ported to the new validation framework. This option will be made default in a subsequent OpenUSD Release.

  • Source for usdchecker has been migrated to pxr/usdValidation/bin/usdchecker.

  • New flags (--variantSets, variants, disableVariantValidationLimit) added to provide more control over variant validation. These flags are only valid when --newValidationFramework is used.

usdrecord

  • Added command line argument to enable performance tracing and allocation tracking. These match the same options provided by usdview.

usdmeasureperformance

  • Added optional trace file output via --tracedir arg.

Documentation

  • Added a basic overview with examples for the relocates composition arc to the Terms and Concepts page. Updated the Namespace Editor user guide to demonstrate how the namespace editor uses relocates when necessary.

  • Added example asset that demonstrates using the UsdSemantics schema, available in extras/usd/examples/usdSemanticsExamples/bookshelf.usda. (PR: #3390)

  • Updated documentation of HdSceneDelegate::SamplePrimvar(), SampleTransform(), and related methods to reflect new behavior with respect to interval bracketing samples introduced in 24.08.

  • Updated usdchecker documentation to include the new validation framework options.

  • Various documentation updates:

    • Added OpenExec and Animated Characters presentation slides to the Downloads and Videos page.
    • Updated VERSIONS.md to note that OpenUSD requires v3.0 or greater of the Jinja2 package. (PR: #3314)
    • Added documentation for the TF_DESCRIBE_SCOPE() macro.
    • Updated "Generating New Schema Classes" tutorial with note regarding DLL warning on Windows. (Issue: #3376, PR: #3394)
    • Updated UsdSemantics overview docs to disambiguate the UsdSemantics schema from model hierarchy concepts. (PR: #3385)
    • Fixed "unsupported type" typo. (PR: #3266)
Previous Releases

[24.11] - 2024-10-25

Build

  • Removed boost dependency from OpenUSD. Note that boost must still be supplied when OpenVDB support is enabled due to its use of boost in headers.

  • OpenUSD now uses its own internal pxr_boost::python library for generating Python bindings instead of boost::python.

    • Types from OpenUSD like Usd.Stage will no longer interoperate with other C++ code that have been wrapped with boost::python. Client code with Python bindings that interoperate with OpenUSD types must be updated to use the new pxr_boost::python library. In particular, schema libraries should be regenerated to pick up the new library.
    • Users can revert to the old behavior of using boost::python by specifying PXR_USE_BOOST_PYTHON=ON when running CMake. This option is for testing and transition purposes; it is deprecated and will be removed in a future release.
  • Added "--boost-python" option to build_usd.py for building OpenUSD's Python bindings with boost::python. This option is for testing and transition purposes; it is deprecated and will be removed in a future release. Note that the build script will continue to build boost if it's needed by optional dependencies. These include OpenImageIO and OpenVDB.

  • Enabled support for imaging and usdImaging on Apple embedded platforms. (PR: #3215)

  • OpenUSD's internal namespace now includes the patch version to help distinguish releases within the same year. (PR: #3167)

  • Removed support for usd-core PyPI package for Python 3.6 and deprecated support for Python 3.7.

USD

  • Updated Tf file utilities to ignore reparse points on network file systems on Windows. Reparse points on these systems are unlikely to be accessible from the remote machines. (PR: #2934)

  • Updated pxrTslRobinMap to latest release, 1.3.0, using erase_fast instead of erase when the returned iterator is not needed. (PR: #3253, #3255)

  • Added support for named color spaces from the Color Interchange Forum to GfColorSpace.

  • Added Gf.Color and Gf.ColorSpace Python bindings.

  • Removed overloads of GfMatrix4d::Transform, GfMatrix4d::TransformAffine, GfMatrix4d::TransformDir, and GfRotation::TransformDir that take and return GfVec3f, as they can potentially result in loss of precision. Matrix-vector multiplication operators for double precision matrix types and single precision vector types have also been removed. These were deprecated in 24.05.

  • Exposed Python bindings for ArAsset, enabling operations such as ArResolver.OpenAsset(resolvedPath) to allow reading ArAsset buffers from Python. (PR: #3318)

  • Various updates and fixes made for relocates.

    • Fixed a bug where ancestral relocates weren't properly elided, leading to verification failures and crashes.
    • Fixed a bug with Pcp dependencies where some prim indexes from nested relocates aren't invalidated when one of the ancestral relocates is updated.
  • Improved how Pcp generates changelists for muting/unmuting layers and adding/removing sublayers, improving performance especially in large stages. Change notifications to external clients remain unaffected, and legacy behavior is retained for layers that may contain relocates. This optimization is still in development and is disabled by default. It can be enabled by setting the environment variable PCP_ENABLE_MINIMAL_CHANGES_FOR_LAYER_OPERATIONS = 1.

  • Deprecated time sample related methods on SdfLayer, to be removed in the next release. SdfAttributeSpec now owns these time sample related methods.

  • Converted NdrSdfTypeIndicator from a std::pair to a full class.

  • Removed residual member function declaration for SdfPath. (PR: #3254)

  • Enhanced SdfCopySpec() to handle overlapping source/destination by copying the source to a temporary anonymous layer first, then copying that temporary to the destination. (Issue: #3095)

  • Initial work done on animation curves in USD.

  • Fixed performance issue writing .usdc files with high time sample counts. (Issue: #3249)

  • Reimplemented .usda text file parser using PEGTL. This removes a dependency on lex/yacc and also provides some performance improvements. (PR: #3005, #3293, #3294)

  • Fixed bugs in the namespace-editing code that caused unnecessary and incorrect edits to children defined by upstream composition dependencies.

  • Various updates for new Validation framework:

    • Updated UsdValidationError to include a name property, used along with the validator name to create an error identifier. This identifier can be used to categorize and filter errors, especially when a validator can generate multiple errors of different types. The error identifier is of the form "validatorName"."ErrorName" or "plugName":"validatorName"."ErrorName".
    • Added UsdValidationContext concept, which can be constructed by selecting validators using keywords, plugins, validator metadata, schema types, or pre-selected sets of validators. Validators for ancestor schema types are also considered when selecting validators for a validation context. Clients can use Validate() API to validate a layer, stage, or a set of prims with parallel execution and error collection. UsdValidationContext initialization may load plugins in order to load the validators. UsdValidationContext is a stateless context, which means that clients handle validation input and result tracking.
    • Updated UsdValidationRegistry to be immortal, which means that any registered validators and validator suites are also immortal.
    • Added schema validators using the new Validation framework:
      • Added StageMetadata Validator for usdGeom domain. (PR: #3134)
      • Added StageMetadata Validator for core USD. (PR: #3125)
      • Added SkelBindingApiAppliedValidator and SkelBindingApiValidator for usdSkel domain. (PR: #3166)
      • Added MaterialBindingApiAppliedValidator, EncapsulationRulesValidator for usdShade domain. (PR: #3154) (PR: #3227)
      • Added a Usdz Package Encapsulation Validator for usdUtils domain. (PR: #3206)
      • Added validators for UsdGeomSubsets (PR: #3123)
    • Updated UsdValidationErrorType to be registered as TfEnum. (PR: #3223)
    • Added Python bindings for UsdValidatorMetadata, UsdValidator, UsdValidatorSuite, UsdValidationError, UsdValidationErrorSite, UsdValidationErrorType and UsdValidationRegistry. (PR: #3232) (PR: #3236) (PR: #3242)
  • Added support for BlockCollection() and ResetCollection() to UsdCollectionAPI for expression-mode collections. Also added IsInExpressionMode() and IsInRelationshipsMode() convenience APIs.

  • usdGenSchema now adds a schemaIdentifier field to schema plugInfo metadata. When present, this field will be used as the schema's identifier in the schema registry. If not, the alias under UsdSchemaBase will be used.

  • Updated usdGenSchema to generate helper files used in the build so that when adding a new schema class to a schema library, users will just need to re-run usdGenSchema instead of having to name the generated files manually in
    CMakeLists.txt

  • Updated sdrOslParser to provide metadata (usdSchemaDef_* and sdrGlobalConfig_*) used for schema generation via usdgenschemafromsdr. This allows clients to generate USD schema from OSL shader definitions which are registered via sdr.

  • Added a new usdSemantics module which includes a SemanticsLabelsAPI schema for labeling prims with tokens. The implementation diverges slightly with the proposal with the taxonomy being after "labels" instead of before in the property name (e.g., semantics:labels:<taxonomy> instead of semantics:<taxonomy>:labels).
    In addition to the schema, UsdSemanticsLabelsQuery provides a reference for how ancestor labeling is expected to work and inherit. (PR: #3103)

  • Added support for elementType "segment" to UsdGeomSubset, where "segment" refers to a segment of a UsdGeomBasisCurves object.

  • Updated UsdLuxCylinderLight bounds computation to use X axis as major axis. (Issue: #3233, PR: #3246)

  • Removed RenderDenoisePass from usdRender schemas.

  • Fixed crash in UsdSkelAnimQuery::ComputeJointLocalTransformComponents when translate, rotate, or scale attributes are not present.

  • Updated UsdUtils.UpdateSchemaWithSdrNode to populate the shaderId attribute for all shaderNodes across sourceTypes for the same identifier.

  • Added Python performance module under extras directory in support of local performance testing and for tracking performance over OpenUSD releases. See usdmeasureperformance.py and documentation for more details.

Hydra

  • Storm and HdPrman lighting/shading have been updated to be more consistent when combining different material types and light types. Physically based lighting and physically based materials have not changed; nor have camera lights and fallback materials. However, camera lights and physically based materials will appear brighter, and physically based lights and fallback materials will appear darker, in order to produce correct lighting response.

  • Made change to allow the generative procedural resolving scene index to be more easily toggled (via a new switchingSceneIndex).

  • Added a new filtering scene index: HdsiPrimTypeAndPathPruningSceneIndex. One use case is to switch between camera and scene lights by changing the path predicate.

  • Fixed a problem with motion blur when using HdRenderIndex::InsertSceneIndex, where the shutter interval was not communicated from the render delegate to emulation. Hence, emulation called GetContributingSampleTimesForInterval on an HdSampledDataSource returned by the inserted scene index with a bad startTime/endTime.

  • Overhauled HdExtComputationSchema and related schemas. In particular, introduced HdExtComputationCpuCallback and changed the CPU callback data source to return the new type.

  • Added typed getters and setters to HdExtComputationContext.

  • Introduced HdsiExtComputationDependencySceneIndex which clients can use together with the HdsiExtComputationPrimvarPruningSceneIndex to evaluate and invalidate ext computation primvars.

  • Added the WithOrientation method to PxOsdMeshTopology which behaves similar to the WithScheme and WithHoleIndices methods. It returns a copy of the mesh topology object except with the orientation set to the given orientation.

  • Added GeomUtilDiskMeshGenerator for generating disk-shaped meshes.

  • Fixed the GeomUtilCapsuleMeshGenerator so that the height, bottom radius, and top radius of the cylindrical portion of the capsule is retained and the spheres are adjusted to maintain continuity with the cylinder sides, as defined in the documentation for UsdGeomCapsule.

  • Altered how the numCapAxial parameter works for GeomUtilCapsuleMeshGenerator when the radii are different. When the radii differ, the numCapAxial parameter is doubled and the number of cross-sections are divided between the top and bottom hemispheres relative to the angle that each portion uses. This makes the density of the mesh more even between the bottom and top when the radii difference is large.

  • Added normals generation to the various mesh generation utility classes. Similar to the point generation, the classes provide a method that returns the number of normals and a method for generating the normals into a provided container iterator. In addition, the interpolation mode of the normals can be requested.

  • Made improvements to the light linking scene index. Added support for non-nested native and point instancers and significantly improved invalidation performance.

  • Prefixed predicate expressions with "hd" for clarity and deprecated existing predicates.

  • Added render index API to allow batching of notices sent by the merging scene index.

  • Fixed a subtle bug in the generative procedural resolving scene index to not cook procedurals in response to scene queries.

  • Added RecipeMaterialOverride schema.

  • Added HdsiMaterialOverrideResolvingSceneIndex to resolve material overrides.

  • Fixed bug with loading monochrome .exr images. (PR: #3343)

UsdImaging

  • Added support for UsdGeomPlane in Scene Index mode.

  • Added UsdImagingModelSchema for any prim that has UsdModelAPI data in Scene Index mode, including models demoted to act as subcomponents within other models.

  • Fixed a bug causing spurious warnings about "implementationSource" for lights.

  • Fixed an invalidation bug so that when a material is edited, prims with that material bound will have their primvars correctly invalidated. (Issue: #2382)

  • Fixed DeprecationWarning in usdviewq/appController.py caused by a regex containing an invalid escape sequence. (PR: #2955)

  • Added AOV light adapter for transporting USD AOV lights to Hydra.

Storm

  • Fixed Vulkan buffer leaks in HdSt_PipelineDrawBatch. (PR: #3313)

  • Improved Lavapipe support, enabling the Vulkan driver as a software rasterizer on macOS. (PR: #3121)

  • Added support for configurable anisotropic filtering in Storm and Hgi. We now disable anisotropy for certain texture/sampler uses such as dome light textures and AOVs. (PR: #3216)

  • Fixed deadlock when Vulkan command buffers are consumed faster than they are executed. (PR: #3170)

  • Updated simpleLights to increase the brightness when used with physically based materials (for example, UsdPreviewSurface or MaterialX).

  • Updated fallback shading to decrease the brightness when used with physically based lights (like UsdLux), for consistency with physically based materials.

  • Fixed displacement shading when using vertex or varying displacement parameterization with Metal. (Issue: #3248)

  • Updated drawing of selected mesh edges to eliminate the need to apply a depth offset in the geometry shader.

  • Exposed an option in HdMeshReprDesc to enable generation of surface edge ids for surface and hull geom styles which do not otherwise draw edges. This option is disabled by default which avoids enabling geometry shader stages for more use cases. (PR: #3071)

  • Shaders for basis curves rprims that are rendered as ribbons are now provided with a texture coordinate that varies over the width of the curve, via the patchCoord argument to the shader terminal.

  • Fixed potential texture memory leak by explicitly calling garbage collection of the necessary subsystem from resource registry's garbage collection.

  • Storm draw target clients no longer need to call HdChangeTracker::MarkStateDirty when a draw target gets disabled and enabled. Storm automatically does the necessary invalidation by tracking the version number of the active draw target set in HdStRenderParam.

  • Fixed the deep selection resolve mode for the "pickPointsAndInstances" pick target.

  • Fixed missing include in glslProgram. (PR: #3283)

RenderMan Hydra Plugin

  • Important: Removed hdPrman for RenderMan 25. This was deprecated in USD 24.08

  • usdRiPxr schemas for rman26.3 are not bundled with OpenUSD and instead will be installed during a OpenUSD build from the specified RenderMan location.

  • Added support for the official RenderMan PxrPrimvarAPI schema in HdPrman.

  • Fixed a bug with missing invalidation of time-varying primvars in Scene Index mode. This would manifest as a stale primvar value after changing the input scene time during a render.

  • Added HD_PRMAN_INTERACTIVE_RENDER_WITH_RENDER_SETTINGS which adds the render settings' products to the task's AOV bindings in the render view.

  • Updated simpleLights (that is, lights set via HdxTaskController::SetLightingState) to increase the brightness when used with or without materials.

  • Added many preprocessor directives as needed to support compiling against USD versions back to 22.05.

  • hdPrman now respects an env var called RMAN_XPU_GPUGCONFIG that can be set with a comma delimited list of the indexes of the selected GPUs.

  • Updated the use of ri:checkpoint:exitat to work independently of ri:checkpoint:interval being set.

  • Updated to use "Shutter settings" on the camera and ignore ri:shutter render setting.

  • Updated PxrBakeTexture to correctly write to non tex files which exist on disk.

  • Fixed a bug where switching between VDB volumes that kept the same path name would not update in the interactive render.

  • Fixed a bug where interactively editing the Material Sync Mode of a PxrMeshLight would not trigger the expected update of the mesh light geometry's visibility. Note that mesh light support is still in active development and will be enabled in a future release.

  • Fixed a crash that could happen when switching between RenderMan Hydra delegates in Katana.

  • Added support for environment variable HD_PRMAN_TEX_EXTS that accepts a colon-separated list of extensions known to be tex compatible, e.g. "tex:txr".

  • Fixed a bug where UDIM textures used by the USDUvTexture node would be flipped incorrectly.

  • Updated Volume prims with primvar named "vel" or "velocity" to infer the type to be vector rather than float.

  • Support for the PRMAN_OSL_BEFORE_RIXPLUGINS environment variable to allow resolving OSL shaders before C++.

  • Support finding MaterialX search paths at runtime based on a DCC install location.

  • Support naming the hdPrman delegate something other than "Prman".

  • Support Ri:PixelFilterName and Ri:PixelFilterWidth options.

  • Various updates to SideFX Solaris support.

    • Enabled the use of interactive denoiser from within Solaris.
    • Fixed a bug where background renders in Solaris could lead to a crash if a RIS render was already running interactively or if the output type of the render was not set to "raster".
    • Fixed a bug where pixelAspectRatio wasn't having the expected effect.
    • Fixed some issues with MaterialX in Solaris.
    • Fixed problem where hdPrman would keep rendering in the background when the viewport switched to the GL renderer in Solaris.
    • Improved data/display window calculation and removed clamp on overscan.
    • Added support for aggregate volumes in Solaris.
    • Added HD_PRMAN_HIDE_DEFAULT_DOMELIGHT_TEXTURE environment variable, which, when set, forces any textured dome lights with a prefix of </_UsdImaging_> or </husk_headlight> to be camera-invisible, as a temporary measure to support Solaris.
  • Improved hdPrman compatibility with the Hush SideFX command line rendering utility.

  • More work on hdPrman Hydra 2.0 transition. The following assumes a recent USD version but does not require HD_PRMAN_EXPERIMENTAL_RILEY_SCENE_INDEX_OBSERVER. The HdPrman_RileyGlobalsSceneIndex filtering scene index now computes some of the Riley options to add a riley:globals prim. hdPrman's HdsiPrimManagingSceneIndexObserver picks up the options on the riley:globals prim and makes them contribute to the Riley::SetOptions call.

  • Fixed a bug where rendering a product without vars led to a crash in RenderMan.

  • Added support for PxrEnvDayLight.

  • Small performance cleanup for purpose-based visibility.

MaterialX

  • Made a change to how MaterialX node names are constructed from material network node paths to support Solaris. This change only affects hdPrman built as part of a DCC.

  • Fixed issue with Storm when rendering custom nodes that use the node in their defining nodegraph, and either re-use that node's output or are a multi-output node.

  • Fixed divide by zero issue in the calculation of a light's intensity value inside Storm's MaterialX glslfx shader.

  • Added support for custom texture nodes in hdPrman.

  • Switched the USD name of surface shader nodes to use the MaterialX node name instead of the NodeDef name. (Issue: #3100, PR: #3147)

  • Fixed shadow support for MaterialX materials in Metal. (Issue: #3176, PR: #3264)

  • Fixed testUsdMtlxFileFormat.py. (PR: #3147)

  • Added more function tracing in UsdMtlx. (PR: #2806)

Embree Hydra Plugin

  • Fixed a bug in HdEmbree random number generation. (PR: #3211)

  • Added HDEMBREE_RANDOM_NUMBER_SEED to facilitate stable image testing. (PR: #3183)

  • Typo fix and refactoring of ray hit code. (PR: #3185)

usdview

  • Made a fix to correctly handle device pixel ratio with multi-display setups.

  • Added applied API schema data to the usdview "Meta Data" tab. (Issue: #1431)

Documentation

  • Added new performance metrics page to docs, used to publish metrics for each release, and describe how metrics are measured.

  • Various documentation updates:

    • Improvements to Hydra prim schema documentation.
    • Updated docs to clarify schema strength ordering.
    • Additional doc fixes. (PR: #2695, #3287)
  • SIGGRAPH 2024 BoF slides PDF added to Downloads page.

  • Contributing to USD page updated with instructions to use when making major changes.

  • Added Security Policy with details on reporting security vulnerabilities with USD.

  • Switched .dox files in pxr/usd/usd to Markdown files (which addressed some formatting issues), and renamed enclosing directory to "docs". We recommend Markdown for new modules, as this makes the documentation more portable.

  • Updated URL to USD Assets Working Group "Primvar Interpolation" asset in the Rendering with USD user guide. (PR: #3110)

Security

[24.08] - 2024-07-25

OpenUSD is now licensed under the Tomorrow Open Source Technology license. This is a renaming of the license, but the terms and conditions are the same as before. See this forum post for details.

Build

  • boost is now an optional dependency that is only required for building Python bindings. (PR: #3028)

  • Added support for optionally building with oneTBB. (PR: #2457, #2458, #2459, #2462, #2463, #2464, #2465, #2466)

  • Various fixes and changes to build_usd.py:

    • Added "--onetbb" option to use oneTBB instead of TBB.
    • Added support for cross-compiling for iOS and visionOS. (PR: #2949, #2950, #3052)
    • Disabled argument abbreviations. For example, "--debug" will no longer match "--debug-python".
    • Updated to build with MaterialX v1.38.10.
  • Added support for Python 3.12 and deprecated support for 3.6 for usd-core PyPI package.

  • Added the build type to the absolute path used to store the PCH result, preventing Debug/Release PCH files from over-writing each other causing linker issues. (PR: #2698)

  • Fixed absolute paths to GL libraries and libm.so in pxrConfig.cmake. (PR: #2827, #2796)

  • Added support for MSVC's standards-conformant preprocessor. (PR: #2990)

  • Added the ability to set a string prefix for test run temp directory names.

USD

  • Continued progress on namespace editing:

    • Completed the work of adding relocates composition.
    • UsdNamespaceEditor can now handle moving and deleting prims with opinions across composition arcs by authoring relocates.
  • Various updates for UsdCollectionAPI and path expressions:

    • Allow leading & trailing whitespace in the SdfPathExpression constructor.
    • Added PathExpression complement-of-complement cancellation.
    • Allow path patterns that start with '//' to pass unchanged through both PcpMapFunction and UsdStage's prototype-to-instance path mapping.
    • Added missing Python bindings for UsdCollectionMembershipQuery::UsesPathExpansionRuleMap and UsdCollectionAPI::ResolveCompleteMembershipExpression().
    • Added UsdComputePathExpressionFromCollectionMembershipQueryRuleMap() which computes an SdfPathExpression that matches the same paths as the given UsdCollectionMembershipQuery::PathExpansionRuleMap.
    • Allow PathExpression atoms to be constructed from SdfPaths directly.
  • Completed the first phase of the UsdValidation framework. Users can now register UsdValidator validation functions with the UsdValidationRegistry. Validation functions can be invoked by UsdValidator::Validate() and will return any UsdValidationErrors. The following validators were also added:

    • CompositionErrorTest validator, which reports composition errors on a stage.
    • UsdShade ShaderPropertyTypeConformance validator, which reports various errors associated with UsdShadeShader and SdrShader compliance.
  • Added TraceReporter::LoadReport(), which can be used to read reports generated by TraceReporters.

  • Added TfMallocTag::CallTree::LoadReport(), which can be used to read malloc tag reports generated by calling TfMallocTag::CallTree::Report().

  • Changed TfNormPath's and TfRealPath's behavior to match Python os.normpath and os.realpath. In particular, the casing of drive letters on Windows will be retained instead of forced to lower-case. (Issue: #3020)

  • Deprecated functions on GfMatrix{2,3,4}d and GfRotation that take and return GfVec3f values as they can potentially result in loss of precision. These functions will be removed in a subsequent release.

  • Added GfColor and GfColorSpace to represent colors and provide color space transformations. This includes a set of built-in color spaces that are always known to USD. Note that as before, USD represents colors in scene description as float3, and properties and attributes may have an associated color space token.

  • URI schemes used by Ar URI resolvers must now conform to the character set requirements in RFC2396. Support for the environment variable PXR_AR_DISABLE_STRICT_SCHEME_VALIDATION has been removed. Support for non-compliant schemes was deprecated in 23.11. (PR: #2997)

  • Added support for sub-root default prims. (Issue: #2951)

  • Added a named sentinel value that is returned from SdfListProxy::Find when the value is not present in the list of operations.

  • Fixed an issue in PcpMapFunction where some functions wouldn't compose correctly.

  • Compose dynamic file format arguments through all non-dynamic arcs, which allows variant selections to impact dynamic payload arguments.

  • Added SdrShaderNode::CheckCompliance static method which checks if the same named properties of a given SdrShaderNode have matching types and default values.

  • usdGenSchema now correctly generates code when namespaces are used in a propertyNamespacePrefix. (PR: #3090)

  • We are deprecating the inclusion of API documentation in the "documentation" field of the schema prim and property definitions. This will be fully removed in 24.11.

  • Fixed issue with concurrent schema registry initialization and the Python GIL. (Issue: #3087)

  • Added UsdStage::GetAllCompositionErrors() for retrieving composition errors for all prims and layer stacks on the stage.

  • Added UsdGeomBasisCurves::ComputeSegmentCounts().

  • Fixed the code for calculating mesh points on Capsule_1 prims with different bottom and top radii. (PR: #3129)

  • UsdRenderPass schema refinements:

    • Removed lightsRenderVisibility and geomRenderVisibility to consolidate with the existing renderVisibility collection.
    • Specify that renderVisibility and cameraVisibility only apply to "renderable" prims, defined as geometry and lights but not render settings related types such as display or sample filters (which do otherwise obey the Hydra visibility schema). If a render pass intends to remove such types, a prune collection should be used instead.
    • renderVisibility and cameraVisibility can only make scene objects invisible; they cannot make invisible objects visible again. The intuitive basis for this is that render pass visibility is used to partition the upstream scene, not to pull hidden things back into view.
  • Added 'deepRaster' to the allowed tokens list for the UsdRenderProduct's productType attribute.

  • Added an option to UsdUtilsModifyAssetPaths which will preserve the length of asset array attributes/metadata when empty paths are present or the modify function returns an empty string. (Issue: #3060, PR: #3063)

Hydra

  • Important: HgiGL now defaults to using nearest sampling and not enabling anisotropic filtering for depth and stencil textures.

  • Important: Fixed a bug in the HdMergingSceneIndex that was not properly re-adding prims when removed in another input scene.

  • Added native support for .avif image files via the new hioAvif plugin. This plugin only supports reading these image files.

  • Optimized removal of rprims from HdRenderIndex. These changes improved many of the examples in the performance test by more than 100x.

  • HdxSelectionSceneIndexObserver::SetSceneIndex() now populates its initial selection in parallel, improving performance for consumers such as HdxColorizeSelectionTask::Prepare().

  • Certain Hdx task types now internally retain the GLSLFX form of their shaders to avoid re-parsing them each time a task is constructed. This improves render startup time.

  • Made change to ensure that HdsiPinnedCurveExpandingSceneIndex does not pull on the basisCurves schema when asked for unrelated scene index keys. This was causing a performance hit in the presence of generative procedurals producing curve data.

  • The Hydra Scene Browser can now display SdfPathVector values.

  • Added Hydra schema for render passes. Added activeRenderPassPrim to HdSceneGlobals schema. Added render pass support to UsdImaging (when in scene index mode).

  • HdxFullscreenShader now supports specifying samplers for any textures bound to it.

  • HdGetSamplerParameters has a new overload that operates on a std::map.

  • Added current frame to the scene globals scene index and render settings schemas, and updated Prman to use this ri:Frame attribute.

  • Fixed the transformation of camera lights when using a scene camera for renderers other than Storm.

  • Updated TetMesh to use surfaceFaceVertexIndices instead of the tetVertexIndices.

  • Removed down cast of world space hit point in HdxPickHit.

  • Added HdUtils::ConvertHdMaterialNetworkToHdMaterialSchema() and ConvertHdMaterialNetworkToHdMaterialNetworkSchema().

  • Added HdEncapsulatingSceneIndex. The mix-in class allows inspection tools to traverse the directed acyclic graph of scene indices at different levels of detail. Note that hdui is not (yet) aware of encapsulating scenes and thus their use is protected by an env var. The use of encapsulating scene indices will eventually make env vars such as USDIMAGING_SHOW_POINT_PROTOTYPE_SCENE_INDICES unnecessary.

  • In HdSceneDelegate added overloads of SampleFOO methods explicitly taking the sampling interval as startTime and endTime. HdSceneIndexAdapterSceneDelegate is passing these arguments to HdSampledDataSource::GetContributingSampleTimesForInterval. This will allow us to get rid of HdPrman_MotionBlurSceneIndexPlugin::SetShutterInterval and the associated global variables in the future.

  • Moved HdTextureType out of Hydra core into Storm.

  • Added support to provide finer grained invalidation for light filter prims in emulation.

  • Added HdsiLightLinkingSceneIndex to implement light linking semantics in a scene index.

  • Fixed a bug in the evaluation of path expressions for collections with pruning semantics.

  • Fixed backend emulation handling of PrimsAdded messages for already-populated prims, to properly resync them.

  • Fixed a theoretical bug in HdDirtyList that would leave stale render tag prim state if Sync() was called without any render tags activated.

  • Fixed a linking error some builds would hit related to HdRenderIndex::InsertTask. (PR: #3000)

  • Added missing include to several files. (PR: #3021)

  • Fixed a comment on the struct definition of HdDisplayStyle. (Issue: #3033)

  • Made HdRendererPluginRegistry more consistent about setting display name correctly, and added an HD_RENDERER_PLUGINS debug flag.

  • Added API tags to the pxr/imaging/hdui library. (PR: #2689)

  • Added a debug flag to provide detail when Hgi::IsBackendSupported() returns false.

  • Optimized HdSceneIndexAdapterSceneDelegate's usage of SdfPathTable to be more correct and cache-friendly.

  • Added deep picking support to HdxPickTask, via the "resolveDeep" resolve mode which is similar to "resolveUnique" but also includes results that are occluded in a typical id-render. (PR: #3044).

  • Updated stb_image to 2.29, and stb_image_resize to 2.07. (PR: #2880)

  • Added defensive coding in HioOIIOImage and switched int for size_t where appropriate (PR: #3119)

  • When calling HdSceneDelegate::SamplePrimvar() for a time-varying primvar when the time sampling interval's start or end time falls between authored sample times, the bracketing authored sample times are now included in the output. Previously, only authored sample times within the interval were included, along with interpolated values at the interval start and end, as needed. For example, if the primvar has authored values at T = [1, 2, 3], and the sampling interval is [1.5, 2.5], the new behavior provides the authored values at T = [1, 2, 3], whereas the old behavior would provide values at T = [1.5, 2, 2.5], with the values at 1.5 and 2.5 being linear interpolations between the adjacent authored values.

  • The behavior of HdSampledDataSource::GetContributingSampleTimesForInterval() for data sources coming out of UsdImaging has been corrected consistent with the change to HdSceneDelegate::SamplePrimvar() described above.

  • HdsiVelocityMotionResolvingSceneIndex, a reference implementation of USD velocity-based motion, has been added to the Hydra scene index library. It has been added to the Storm renderer, but is not a part of the UsdImaging default scene index stack.

  • HdGeomSubsetsSchema (plural 'Subsets') has been removed. In Hydra 2, geom subsets are no longer properties of the parent geometry. They now traverse the Hydra 2 scene indices as child prims of the parent geometry, so this schema is no longer required. This change should be transparent to consumers of the legacy HdSceneDelegate interface, but authors of Hydra 2 scene indices that need to be subset-aware will need to revise their implementations.

  • HdGeomSubsetSchema (singular 'Subset') now has a non-empty default locator, consistent with subsets' promotion from properties to prims. Data sources for geom subset fields will now be found under the "geomSubset" property of the geom subset prim, rather than at the top level of the prim. This change should be transparent to consumers of the legacy HdSceneDelegate interface.

UsdImaging

  • Fixed an issue when scene lights are enabled and disabled.

  • Made fix to assign ReplacePrefix() return value to newLocators when changing directMaterialBindings locators to materialBindings locators.

  • Made sure the results of UsdImagingStageSceneIndex's GetPrim and GetChildPrim are consistent by using the same prim predicate.

  • UsdImagingDataSourceCustomPrimvars no longer stores attribute queries in a map but creates it every time a particular primvar is queried. This fixes a bug where a client would not see a primvar that has an authored value now but had no authored value when the primvars container was retrieved by the client. More generally, it also fixes bugs where the resolution info in the previous attribute query is no longer valid.

  • Replaced UsdImagingDataSourceSchemaBased with the more flexible UsdImagingDataSourceMapped.

  • Transport USD collections as data sources when using the stage scene index.

  • Fixed performance issue where UsdImagingFieldAdapter would unnecessarily compute the total number of time samples for attributes, which could cause all value clip layers to be loaded.

  • Fixed sizing of result array when calling GetScenePrimPaths with some invalid instance indices. (PR: #2960)

  • Added imaging transport for uniform and constant primvars on UsdGeomPointInstancer, and fixed transport of "velocities", "accelerations", and "angularVelocities" on point instancers. (PR: #1731, #1734)

  • Added null-prim checks when computing Hydra materials. (PR: #2930)

  • Fixed incorrect API tags in UsdSkelImaging and UsdVolImaging. (PR: #2691)

  • Added StageSceneIndex support for UsdLuxCylinderLight, and fixed support for UsdGeomSubset.

  • Fixed UsdImagingGLEngine::TestIntersection instancing-related out-params when using StageSceneIndex.

  • Ratcheted usdImagingGL test thresholds. (PR: #2970)

  • Fixed a bug where UsdImagingDelegate would sometimes end up with duplicate primvar entries. (PR: #2096)

  • Added StageSceneIndex invalidation support for UsdVolField prims.

  • Fixed UsdImagingGLEngine::DecodeIntersection when using StageSceneIndex

  • Added a new version of UsdImagingGL::TestIntersection that takes resolve mode, and returns a result vector instead of a single result. (PR: #3044)

  • UsdImagingPrimAdapter::SamplePrimvar() now includes bracketing authored sample times in certain scenarios, similar to the updated behavior of HdSceneDelegate::SamplePrimvar() described above.

  • Point instancer prototype prims are now relocated as children of the point instancer, rather than properties of it. Previously, each drawable leaf prim within the prototype of a point instancer was relocated as a direct child of the point instancer, but with a property path of the form .proto0_<name>_id0. This property form of path precluded the relocated prototype prim from having child prims of its own. The promotion of geom subsets from properties to prims therefore required also promoting the relocated prototype prims from property paths to prim paths.

Storm

  • Updated the default compute shader local size to (64, 1, 1) for compute shaders executed for GPU ext computations and the frustum culling compute pipeline.

  • Improved shader interstage slot calculation for Hgi resource generation, reducing the total number of interstage locations needed, and accounting for resources that take up more than one slot. Fixed adaptive subdivision shader compilation when using HgiVulkan.

  • Added function Hgi::CreateNamedHgi, which can be used to create a specific Hgi instance given a valid Hgi token. (PR: #2850)

  • Use HgiHandle unique id in hashes rather than the pointer address, as the latter can be reused between different objects.

  • Added tests testHgiGL and testHgiVulkan.

  • Various HgiVulkan fixes and improvements:

    • Improved handling of Vulkan viewport. Rather than flipping the Vulkan viewport in the Y-direction, instead allow the geometry to render upside down by using the same projection matrix and viewport used for OpenGL, but flipping the winding order. This change greatly simplifies and circumvents coordinate system differences between Vulkan and other graphics backends in Storm.
    • Added MaterialX support for Vulkan, using MaterialX::VkShaderGenerator.
    • Added implementations for HgiVulkanBlitCmds::CopyTextureToBuffer and CopyBufferToTexture.
    • Fixed a bug in HgiVulkanBlitCmds::CopyBufferGpuToCpu.
    • Fixed bugs around HgiVulkan access masks for layout transition barriers.
    • Added correct read usage flags for depth and stencil buffers in Vulkan.
    • Fixed color correction shader and volume shader compilation bugs for Vulkan.
  • Fixed the behavior of HgiSubmitWaitTypeWaitUntilCompleted when submitting command buffers on Metal. (PR: #2794)

  • Fixed shading with Metal when geometry is flipped (e.g. scale -1,1,1). (Issue: #2536)

  • Fixed MaterialX shader gen for EDF type declarations. (Issue: #3049, #3105, PR: #3106)

  • Fixed Ptex GLSL layout sampler declaration and binding.

  • Fixed adaptive tessellation of subdivision surfaces to avoid under-tessellation artifacts. (Issue: #2981)

  • Fixed subdivision surface refinement of faceVarying primvar to avoid crashes when the faceVarying primvar topology is invalid.

  • Fixed an issue pulling fallback values from Sdr that was affecting material wrap modes, among others. (PR: #2519)

  • Fixed incorrect GPU skinning of meshes with blendshapes but no skeleton. (Issue: #2425, PR: #2696)

  • Added NAN guards to dome light convolution shader. (PR: #2383)

  • Fixed a bug where some BasisCurves pipelines were applying color overrides twice. (PR: #3124)

  • Storm now supports velocity-based motion of points-based geometry and point instances consistent with the USD velocity motion specification. Velocity-based motion will now be correctly applied to geometry points and to point instance positions and rotations at subframe sample times. Note that velocity-based motion is intended primarily for subframe sampling and should not be used as a physics engine or as a substitute for definitive, authored, per-frame position data. (Issue: #2571)

RenderMan Hydra Plugin

  • hdPrman for RenderMan 25 is deprecated. Support for hdPrman for RenderMan 25 will be removed in the 24.11 release.

  • Updated usdRiPxr to include schemas for Renderman 26.1. Also updated usdRiPxr CMakeLists to gather bundled schemas from yet to be released Renderman 26.2 and above.

  • Added code to take advantage of new display APIs for RenderMan 26 and also add #ifdefs so that building against RenderMan 25 still works.

  • Fixed an issue where gprim Sync() would cause extra rounds of edit requests to the Riley API, stopping & restarting the render even when there were no actual edits required.

  • RenderMan requires Ri:Frame to be an integer so force it to int(floor(time)).
    This ensures that it produces an independent sampling sequence per integer frame.

  • HdPrman now supports field-less RiVolume primitives. These are used for homogeneous fog volumes which do not require voxel data. Field-less volumes need the standard RenderMan parameters, Ri:type and Ri:Bounds.

  • HdPrman now applies the render pass specified byHdSceneGlobalsSchema using an internal RenderPassSceneIndex.

  • Fixed a bug where a crash could occur when AOV names are received as a string rather than a TfToken.

  • Added support for usdRiPxr's PxrCameraAPI schema. This required a corresponding adapter in usdRiPxrImaging as well as removing the default values for shutterOpen/shutterClose/shutterOpening in hdPrman. The old default values were hard-coded and different between the interactive and non-interactive modes.

  • Removed code to dirty all rprims in HdPrmanRenderDelegate::SetRenderSetting("renderCameraPath", value). This is a performance improvement when switching cameras. However, it also means that clients of hdPrman need to invalidate all animated primvars if the shutter interval between the old and new camera is different. Note that even before the change, clients need to invalidate all animated primvars if the shutter interval changes for reasons other than the camera path changing. This behavior of hdPrman might be revisited in the future.

  • Register scene index plugin to perform light linking when the light linking collections are transported. For legacy clients (e.g. UsdImagingDelegate) that don't transport collections, light linking is performed at the scene delegate end and this scene index should not affect that behavior.

  • Improved determination of the display driver to factor the product type.

  • Renamed rtx_glfImage to rtx_hioImage.

  • Added RMAN_DISPLAYPATH environment variable to populate 3rd-party RenderMan display driver search paths.

  • Added HDPRMAN_TESSELLATE_IMPLICIT_SURFACES environment variable to make hdPrman tessellated implicit surfaces into meshes rather than use builtin representations.

  • PxrPathTracer support for purpose-based visibility has been temporarily removed, as it could cause unexpected problems for lights. An improved approach to this feature is now available via PbsPathTracer and will be applied to PxrPathTracer in a future release of RenderMan.

MaterialX

  • Added support for MaterialX v1.38.10.

  • Added the ability to control Dome Light intensity with MaterialX materials.

  • Fixed MaterialX shader generation for simple surface shaders like ND_convert_color3_surfaceshader. (PR: #3045)

  • Added traces to hdMtlx. (PR: #2665)

  • Fixed MaterialX shader objects getting garbage collected too early. (PR: #3051)

  • Fixed MaterialX material tag detection for glTF PBR. (Issue: #1882, PR: #3069)

  • Optimized MaterialX shader generation and reuse; improved material tag detection; added support for triplanar texture nodes. (Issue: #2330, #3004, PR: #3073)

usdrecord

  • Updated to support specifying an active render pass, which is set in HdsiSceneGlobalSceneIndex for use within Hydra.

  • Updated to use the startTimeCode from the USD stage as the default time code.

  • Changed default dome light camera visibility to false, and added an "--enableDomeLightVisibility" flag. (PR: #2352)

usdview

  • Added the 'bboxStandin' command line argument to allow for unloaded prims to be displayed by their bounding boxes. (Issue: #2720)

  • Added workaround for issue in PySide that can cause the viewport to render incorrectly. (Issue: #2996, #3009)

  • Added a keyboard shortcut (Ctrl + Shift + R) to reload stage.

  • Refactored Usdviewq.Launcher to make it easier to extend, e.g. by testusdview.

  • Fixed a bug in layer stack view when the root layer stack contained both muted and unloaded sublayers.

  • Fixed an issue where the OCIO menus would occasionally select an invalid colorspace, for certain OCIO configurations. (PR: #3017)

Documentation

  • Added infrastructure and usdVol example content for a new schema user documentation process. User documentation can be added to schema definition files, using Markdown format. User documentation will be processed by usdGenSchema and added to the schema registry. User documentation can also be generated into HTML output using a script that generates Sphinx-compatible content files. See "Generating Schema User Docs" in docs/README.md for more details.

  • Added new testing guidelines and code guidelines to documentation.

  • Added new Collections and Patterns user guide to documentation.

  • Made clarifications to Hydra 2.0 Getting Started Guide.

  • Revised UsdCollectionAPI documentation to explain what makes an instance be in relationship-mode vs expression-mode, and how the built-in properties affect membership determination in each mode.

[24.05] - 2024-04-19

Build

  • Various fixes and changes to build_usd.py:

    • Added change to explicitly specify C++17 when building boost on macOS to avoid issues with newer Xcode toolchain versions. (PR: #2868)
    • Added change to download AnimX from a fixed location. (PR: #2938)
    • Fixed toolchain detection when using Microsoft Build Tools. (PR: #2220)
    • Updated OpenSubdiv build configuration to disable support for GL on Apple operating systems.
    • Updated builds on MacOS to now use boost 1.82.0 to support newer versions of Xcode.
    • Updated MaterialX to 1.38.8.
  • Improved Vulkan build support. (PR: #2735)

  • Fixed a build issue in sdrOsl plugin when building against an OSL build that uses Imath instead of IlmBase. (Issue: #2977, PR: #2604)

  • Cleaned up unnecessary uses of CREATE_FRAMEWORK in various libraries. (PR: #2953)

  • Added initial support for iOS and other Apple embedded operating systems. (PR: #2949)

  • Updated pxOsd to link only with CPU OSD libraries.

USD

  • Initial work on adding relocates to USD in support of non-destructive namespace editing of objects that are defined across composition arcs in remote layerStacks. This is a work-in-progress, future releases will provide more complete functionality and documentation.

  • Fixed issue that prevented processes from having different release versions of the USD libraries loaded at the same time. (PR: #2861)

  • We now default to measurement based computation of NanosecondsPerTick when CNTFRQ_EL0 is unreliable for arch platforms. (PR: #2929)

  • Reduced memory usage associated with specializes arcs in composition. In one production test case that makes heavy use of specializes, memory use decreased from 2.2 GB to 1.4 GB, a 36% improvement.

  • Added PythonGarbageCollectionCallback callback for tracing Python garbage collection, using Trace.Collection.

  • Support for URI schemes in Ar URI resolvers that do not conform to RFC2396 is deprecated. This support and the PXR_AR_DISABLE_STRICT_SCHEME_VALIDATION environment variable will be removed in a subsequent release.

  • Added ArGetRegisteredURISchemes() function for retrieving the list of URI schemes for which resolvers are registered.

  • Updated the implementation of ArDefaultResolver::SetDefaultSearchPath to trigger ArNotice::ResolverChanged notifications when the search path is updated. (Issue: #2925)

  • Various fixes and changes to support Boost dependency removal

    • Replaced boost::intrusive_ptr with TfDelegatedCountPtr. (PR: #2891, #2892, #2893, #2894, #2895, #2896, #2897, #2917)
    • Added gf/numericCast.h and replaced uses of boost::numeric_cast.
    • Removed unused boost preprocessorUtils. (Issue: #2225)
  • Fixed a bug calculating umask in certain cases when creating USD files. (PR: #2933)

  • Fixed a bug where an incorrect bounds calculation could lead to a possible buffer overflow when writing .usdc files. (PR: #2631)

  • Fixed an SdfPathExpression parser bug that incorrectly rejected namespaced property names.

  • Fixed an SdfPathExpression evaluator bug where patterns that end in // did not always correctly report constancy over descendants.

  • Removed the requirement to provide an object-to-path function in SdfPathExpression evaluator.

  • Added the ability for file format implementations to distinguish "Save" operations that update the layer's backing store from "Export" operations that write the layer's data to an independent asset, via a new optional virtual function SdfFileFormat::SaveToFile().

  • Changed .usdc file output to properly use Ar 2.0 API in conjunction with implementing SdfFileFormat::SaveToFile in UsdUsdFileFormat and UsdUsdcFileFormat so we can reliably detect "Export" operations. Enabled the testUsdFileFormats_asset test on Windows now that this is fixed. (Issue: #2773)

  • Added cast-to-bool null check for pxr.Pcp.NodeRef and graceful handling of calling methods on null pxr.Pcp.NodeRef. (PR: #2943)

  • Fixed a bug where attributes authored in variants were ignored when processing dynamic file formats.

  • Fixed a bug where ancestral payloads of internal subroot reference paths were not always being loaded.

  • Improved performance when adding or removing sublayers to a stage with many prims. (PR: #2937)

  • Restored behavior of dependency analysis functions to recursively analyze existing .usdz archives, allowing for discovery of assets in archives which are not self contained. (Issue: #2636, PR: #2637)

  • Updated UsdRenderComputeSpec() to treat attribute connections as stronger than local attribute values, consistent with UsdShade conventions. It also strips out the outputs: prefix where present so that callers no longer need to include it with requested namespaces.

  • Updated UsdRenderSpecComputeNamespacedSettings() to only collect attributes that exist in a namespace. If specific namespaces are provided, only those are used; if none are provided, any namespace is accepted.

  • Added GetSourceTypes function to UsdShadeNodeDefAPI and UsdShadeShader to retrieve all source types for both sourceCode and sourceAsset implementations.

  • Updated UsdShadeShaderDefParser to always add sdrUsdDefinitionType metadata for all sdrShaderProperties. This is important to maintain SdfValueTypeName round-tripping for shader specs represented by UsdShadeShaderDefs. For example, previously "token" property types in the USD shader spec were reported as "string" from sdrProperty::GetTypeAsSdfType.

  • Added UsdGeomTetMesh::FindInvertedElements to detect inverted tetrahedral elements with respect to its orientation attribute.

  • Updated UsdGeomBoundable::ComputeExtent API for const correctness.

Hydra

  • Important: Removed HD_USE_DEPRECATED_INSTANCER_PRIMVAR_NAMES. In 23.11, we introduced new names for the internal instancer primvars Hydra uses for instance transforms. The rename was important to avoid accidental collisions between custom authored primvars and the internal ones. At the same time, we introduced the HD_USE_DEPRECATED_INSTANCER_PRIMVAR_NAMES option to allow authors of Hydra render delegates time to update their implementations. We announced that the setting would be removed in 24.05. Render delegate authors who need more time to update their code should not adopt 24.05 until they have completed the transition.

  • Added HdGpGenerativeProceduralFilteringSceneIndex, which filters Hydra procedural prims against a list of allowed procedural types. Skipped procedurals have their primType changed to skippedHydraGenerativeProcedural, keeping them from being evaluated by a subsequent Resolving index but otherwise leaving them intact.

  • Adjusted the order of how scene index plugins concatenate, making phase the most significant ordinal component. Previously, all renderer-agnostic phases were first appended, followed by all renderer-specific phases. As a result there was no way for a renderer-specific plugin to run before a renderer-agnostic one, regardless of their relative phase.

  • HdImageShader now supports having an associated material network.

  • Added support for motion blur in pinned basis curves by updating functionality for respective scene index plugin.

  • Hydra schema generation tool hdGenSchema.py is now available.

  • Various Hydra schema clean-up changes: made getter's const, deprecated BuildRetained (unless schema has "GENERIC_MEMBER" in hdSchemaDefs.py), added consistent capitalization (in, e.g., UsdImagingGeomModelSchema token data source builders).

  • Fixed memory corruption on macOS when using HgiMetal in an external project whose automatic reference counting (ARC) setting differed from the setting used when building OpenUSD.

  • Added predicate library and path expression evaluator to evaluate SdfPathExpression-style queries on prims in a scene index.

  • Added schemata to represent collections. A collection has a name and path expression, allowing scene indices to implement membership-based behavior using the HdCollectionExpressionEvaluator.

  • Fixed a potential crash when updating skinned primitives. (PR: #2931)

  • Added Hydra2 support for geom subsets (also added to UsdImaging2).

UsdImaging

  • Important: Made changes to make adapter hijacking more transparent. Delegate queries for information about prims whose adapters are masked by the instancing and draw mode adapters will no longer fail when made during prim insertion. Note that the following methods of the UsdimagingPrimAdapter API are no longer const-qualified. Authors of custom prim adapters that override these methods will need to remove the const qualifier:

    • GetExtComputationInput
    • GetExtComputationInputs
    • GetExtComputationPrimvars
    • TrackVariability
  • Added support for light filters in scene index mode. Note that light filter linking is not yet implemented.

  • Added support for "orientationsf" attribute on UsdGeomPointInstancer. (Issue: #2529)

  • Added Hydra 2.0 imaging support for UsdGeomTetMesh.

  • Fixed a bug in UsdImagingCoordSysAdapter where transform variability was marking the wrong dirty bit.

  • Improved draw mode support in UsdImaging 2.0.

  • Updated "wrapS" and "wrapT" shader properties to be of token types for UsdUVTexture OSL shader spec, to conform to UsdShadeShaderDef specification.

Storm

  • Added bits to HdBufferArrayUsageHint to convey whether the associated buffer should be used as an SSBO, UBO, etc., allowing for more precise specification of the HgiBufferUsage during buffer array allocation.

  • Added support for interpolation/storage qualifiers on shader block members. (PR: #2493)

  • Disabled alpha to coverage for id renders, fixing id rendering for HgiVulkan.

  • Fixed HgiVulkanBlitCmds::CopyTextureGpuToCpu such that it copies the depth aspect when provided a depth-stencil texture. (PR: #2852)

  • HdStResourceRegistry now supports the notion of a sub-resource registry. A sub-resource registry is an additional HdResourceRegistry defined externally that can manage resources whose definitions and implementations are not known to HdStResourceRegistry, but whose lifetime is tied to an HdStResourceRegistry. HdStResourceRegistry will invoke Commit and GarbageCollect on any sub-resource registries it has ownership of whenever those functions are invoked on it.

  • Added support for primvars with the same name but different types in HdStInstancer. (Issue: #2529)

  • Fixed a Metal API validation error that could occur when using tessellation with MSAA. (PR: #2949)

  • Fixed shader code gen of primvar accessor methods to work correctly when a shader parameter has the same name as a primvar. (PR: #2789)

  • Improved draw batch aggregation to reduce draw times when using GL indirect draw batches for drawing scenes with a high ratio of textures to drawn geometry such as can occur when drawing geometry as texture card proxies.

  • Improved performance of HgiGL buffer allocation to skip unneeded mapping of buffers designated for use as storage buffers.

RenderMan Hydra Plugin

  • Important: Removed hdPrman for RenderMan 24. This was deprecated in USD 23.11

  • Updated usdRiPxr codeless schemas with updated concepts from RenderMan 25 (Feb 2024)

  • Updated the d_openexr display driver by providing a default value for the parameter asrgba of 1.0, matching the default specified in d_openexr.args in RenderMan. This ensures that exr's produced by RenderMan better conform to EXR conventions.

  • Updated interactive mode to avoid interactive renders from halting prematurely, by only filtering options that make sense for batch renders, such as exitat.

  • Updated rendering progress by emitting classic RenderMan-style percentage progress to the terminal during batch renders.

  • Updated HdPrman to add support for ad hoc EXR metadata coming from USD, in the form of ri:exrheader:namespace:name attributes. This is mapped to "namespace/name".

  • Fixed a bug where MaterialX shaders were not correctly generated when an upstream node was both part of a pattern network and also directly connected to the terminal node.

  • Updated the render delegate to include the default paths for the various search paths, even if the override environment variable path (e.g. RMAN_SHADERPATH) does not include it.

  • Added support for UsdGeomTetMesh.

  • Added support for camera parameters such as shutterOpenTime, shutteropening, and apertureNSides.

MaterialX

  • Important: The minimum supported version of MaterialX is now 1.38.8. Support for older versions of MaterialX has been removed.

Alembic plugin

  • We now use "DCCFPS" metadata to set the timeCodesPerSecond value in Alembic reader code. (PR: #2944)

usdchecker

  • Added ShaderPropertyTypeConformanceChecker to ComplianceChecker for validating attribute types on shaders. (Issue: #2729)

usdrecord

  • Added a --renderPassPrimPath argument.

  • Updated --disableCameraLight option to prevent the default camera light from being inserted into the scene.

  • Added support for motion blur (need to use a valid render settings prim, and indicate a frame number).

Documentation

[24.03] - 2024-02-23

Build

  • Added support for Python 3.11. (PR: #2742)

  • Various fixes and changes to build_usd.py:

    • Updated OpenSubdiv version to 3.6.0.
    • --ignore-paths and --ignore-homebrew options added to command line to help solve problems where CMake picks up unwanted sources for dependencies. (PR: #2873)
    • Fixed build issue with boost on macOS with Xcode 15.3+. (PR: #2919)
  • Builds on macOS now avoid hard-coding specific SDK versions for system library dependencies. (Issue: #2771, PR: #2772)

  • Updated CMakeLists for usdImaging tools (usdrecord and usdBakeMtlx) to skip building if GPU and/or OpenGL are unavailable. (PR: #2468)

  • CMake fixes to find OpenImageIO and OpenEXR when building for debug. (PR: #2079)

  • Made build of extras/imaging/examples conditional on PXR_BUILD_EXAMPLES. (PR: #2630)

  • Improved error message when uic is not found during the build. (Issue: #2582)

USD

  • Added support for Unicode identifiers. UTF-8 encoded characters may now be used in prim, property, and variant names, and dictionary keys. Support for serializing these identifiers has been added to the .usda and .usdc (crate) file formats. Note that files containing UTF-8 identifiers are not backwards-compatible with older versions of OpenUSD. See the proposals page for more details. (PR: #2378, #2673, #2751, #2788, #2830, #2848, #2855, #2856, #2857, #2858, #2867, #2883, #2888, #2889, #2890, #2906)

  • Added initial version of Ts library. This will be the open-source version of Presto's libAnim. It implements animation splines. For details, see the Spline Animation proposal. This version builds, but isn't used by anything yet. It's a first milestone that will allow us to begin co-developing with external partners and collecting public feedback. Much work remains, see ts/README.md for a rough list of tasks.

  • Add initial version of UsdNamespaceEditor. This object supports basic prim and property edits, with property target path fixing, in the local layer stack only. This is a work-in-progress, future releases will provide more complete functionality and documentation.

  • Fixed broken validation of allowed characters in Ar URI resolver schemes. (PR: #2859)

  • Refactored Arch_ComputeNanosecondsPerTick to empirically calculate nanoseconds per tick. (Issue: #2719)

  • Added thread-safety, size, and performance improvements to TfRefBase, TfRefPtr, and TfToken.

  • Updated DoubleConversion version to v3.3.0 in Tf. (Issue: #2218)

  • Fixed bugs not properly decrementing Python exception state reference counts, and not properly saving/restoring exception state in some corner cases.

  • Added workaround for "insufficient permissions" errors that occurred on Windows when saving files to a network drive. By default, filesystem permissions are no longer checked before saving files on Windows. This avoids cases where permissions are incorrectly reported by the system. On Linux and macOS permissions are still checked, maintaining previous behavior. This behavior can be overridden by setting the environment variable TF_REQUIRE_FILESYSTEM_WRITE_PERMISSION. This setting defaults to true on Linux and macOS, and false on Windows. (Issue: #849)

  • Fixed Python DLL loading order on Windows (PR: #2595)

  • Numerous changes to remove boost usage. (PR: #2353, #2681, #2682, #2684, #2701, #2707, #2709, #2711, #2714, #2715, #2718, #2748, #2750, #2752, #2754, #2761, #2763, #2764, #2765, #2778, #2781, #2785, #2786, #2802, #2810, #2811, #2823, #2831, #2833, #2834, #2835, #2842, #2843, #2864, #2874)

  • Various fixes and changes for SdfPathExpression:

    • Fixed a bug in the SdfPathExpression parser: only allow the pattern chars '-', '!', and ']' once an initial '[' has been seen. Previously a case like /foo//-/foo/bar// which should parse as a set-difference ('/foo// - /foo/bar//') would parse as a single path pattern with a '-' element.
    • Fixed a bug where SdfPathExpression was searching for wildcard matches anywhere in path components rather than matching components in full.
    • Fixed logic bugs in the incremental search implementation for SdfPathExpressionEval. Added debug output, and improved test coverage for incremental searches in testSdfPathExpression.
    • Fixed a bug where SdfPathExpression evaluation would incorrectly report a constant false when the query path was a prefix of a pattern prefix.
    • Added compile-time-enabled TF_DEBUG code for SdfPathExpressionEval.
  • SdfChangeList now provides a more precise list of layer edits.

    • Changes to composition-related fields like "references" and "inherits" are now listed as info changes so they can be handled generically.
    • Some changes are now split into multiple entries for the same prim or property when needed to provide clients an unambiguous order of operations.
    • The previous path for re-parented prims is now captured.
  • Added exception throwing and handling to avoid corrupted file reads during SdfLayer setup. (PR: #2552)

  • Ensured that SdfAbstractData::HasDictKey returns false if the provided value's type does not match the valueType.

  • Fixed bug in SdfBatchNamespaceEdit where certain sequences of operations would erroneously be flagged as invalid.

  • Initial work on reimplementing the .usda parser to remove dependencies on flex and bison. (PR: #2822, #2819)

  • Fixed an issue in SdfAssetPath::_ReadUTF8 where certain multibyte unicode characters would not be decoded correctly. (Issue: #2560)

  • Increased default version for newly created crate files to 0.9.0. (PR: #2838)

  • Updated SdrShaderProperty to support int2, int3, and int4, which conforms to SdfValueTypeNamess->int2, SdfValueTypeNames->int3, SdfValueTypeNames->int4. Users do not have to specify sdrUsdDefinitionType for int2, int3, and int4 SdrShaderProperties now.

  • Added the ability to pass a traversal predicate to UsdStage attribute connection/relationship target finders, and UsdStage::ExpandPopulationMask().

  • Made "kind" a disallowed field for metadata in schemas.

  • Changed UsdCollectionMembershipQuery behavior to use either the path expansion rule map form, or the membership expression form, preferring the rule map form if authored. Provided a way for callers to determine whether or not the expression form was used to match. Also fixed some API export tag names.

  • UsdFlattenLayerStack now handles add/reorder statements as described in the docs for the case where there's only one opinion.

  • Added guard to gracefully handle NULL stage pointers. (Issue: #2721)

  • Fixed unnecessary VtArray copy-on-writes during attribute creation. (PR: #2816)

  • Validate UsdCollectionAPI before accessing in UsdShadeMaterialBindingAPI::ComputeBoundMaterial. (PR: #2501)

  • Improved performance for computing variant selections during prim composition. For example, in a synthetic test case involving a prim with 1000 references, adding 500 variant sets to that prim previously took ~25.5 seconds; it now takes ~6.8 seconds. (Issue: #1957, #2010)

  • Fixed bug where variant selections authored at implied sites would be ignored when composing prims with composition arcs pointing to subroot prims.

  • Fixed bug where incorrect sites would be checked for opinions during dynamic payload argument composition.

  • Fixed bug where the wrong inclusion state for ancestral payloads would be computed when composing prims with composition arcs pointing to subroot prims.

  • Fixed bugs in UsdInherits::GetAllDirectInherits where the results would be incomplete or include paths in non-local layer stacks.

  • Added UsdGeomTetMesh schema.

  • Added support for elementTypes "point", "edge", and "tetrahedron" in UsdGeomSubset.

  • Added single precision orientationsf to UsdGeomPointInstancer, which, if authored, takes precedence over half-precision orientations. (Issue: #2529)

  • Deprecated UsdGeomSubset::ValidateSubsets in favor of ValidateFamily.

  • Added change to avoid de-referencing iterators of an empty set when validating UsdGeomSubset families with no indices. (PR: #2733)

  • Updated UsdGeomPrimvar::ComputeFlattened() to consider elementSize.

  • Added a null pointer check in UsdGeomBBoxCache::_Resolve. This brings behavior in line with other UsdGeomBBoxCache operations and prevents crashing in certain multi-threaded situations. (PR: #2905)

  • Improved the UsdObj handling of .obj files with 'g' statements. (PR: #2092)

  • Updated usdRiPxr codeless schemas with updated concepts from RenderMan 25.

  • Updated UsdShadeOutput::GetAttr to return const reference for consistency. (Issue: #2617)

  • Updated UsdShadeOutput::IsOutput to check attribute validity, to match UsdShadeInput::IsInput behavior. (Issue: #2876, PR: #2877)

  • Added a new method UsdUtilsLocalizeAsset which will localize an asset to a directory on disk. It also introduces the concept of a user processing function which allows users to provide a function which can modify asset paths and dependencies while leveraging built in asset discovery and traversal code.

  • Added an optional UsdUtilsProcessingFunc parameter to UsdUtilsComputeAllDependencies. This allows users to inject custom logic into asset discovery.

  • Updated NormalMapTextureChecker to use GetValueProducingAttributes. (PR: #2885)

  • Updated ARKit conformance checks to match spec from WWDC 2023. (https://developer.apple.com/documentation/realitykit/validating-usd-files) (PR: #2863, #2875)

UsdImaging

  • Replaced use of GetValueProducingAttribute() API, which had been deprecated and was emitting warnings.

  • Added imaging support for UsdGeomTetMesh in Hydra 1.0.

  • Added support for Material Nodegraph edits when using the stage SceneIndex.

  • Added DataSourceAttributeColorSpace to lazily populate the color space metadata in Hydra 2.0.

  • Added forceDirtyingTimeDeps flag to UsdImagingStageSceneIndex::SetTime(). This can be used to force render delegates into resampling all primvars in response to, e.g., the camera and thus the shutter interval changing.

  • Fixed a bug where time-sampled attributes on lights, light filters, and cameras were not detected as time-varying. (PR: #2734)

  • Added support for asynchronous Hydra processing in UsdImagingGLEngine and usdview, activated with the --allow-async flag in usdview.

  • Added support for asset[]-valued attribute data sources.

Storm

  • Removed include of dispatcher.h in public header to reduce transitive includes of TBB headers. (PR: #2616)

  • Published HdSt and Hdx tests, available on Linux.

  • Enabled Hgi resource generation for non-HgiGL Hgi backends by default.

  • Fixed a bug where creation of HgiSampler in various backends will always enable anisotropy. (PR: #2492)

  • Fixed a typo in hgiInterop CMakeLists.txt. (PR: #2641)

  • Added ability to support both HgiGL and HgiVulkan in single build. (PR: #2564)

  • Added new unit test for HgiGL and HgiVulkan. (PR: #2851)

  • Added memory barrier between CPU-GPU copy and GPU-GPU copies in HdStStagingBuffer::Flush.

  • Various correctness and stability improvements to HgiVulkan, including:

    • Added implementation for HgiVulkanBlitCmds::FillBuffer.
    • Improved clearing logic of HgiVulkanGraphicsCmds such that we only clear a VkRenderPass when it's used for the first draw batch in graphics cmds submission.
    • Fixed visualization of Embree normals AOV when using HgiVulkan.
    • HgiVulkan now uses validation layer VK_LAYER_KHRONOS_validation instead of deprecated VK_LAYER_LUNARG_standard_validation.
    • Removed incorrect use of indexBufferByteOffset when binding index buffer.
    • Added env var HGIVULKAN_ENABLE_MULTI_DRAW_INDIRECT, mirroring HgiGL version.
    • Added support for builtin barycentric coordinates.
    • Enabled alphaToOne, allowing its use in the VkPipelineMultisampleStateCreateInfo setup.
    • Added codepath for clearing attachments in HgiVulkanGraphicsCmds without beginning a render pass.
    • Added method Hgi::SubmitLayoutChange, allowing user to request texture layout changes. Used this method to fix color correction task when using HgiVulkan.
    • Many validation layer error fixes. (PR: #2852)
  • Enabled multi-threaded buffer source resolve to improve performance when executing buffer source computations during resource commit.

  • Updated to use improved OpenSubdiv shader source mixins to reduce shader source size and improve compatibility when compiling GLSL to SPIR-V for Vulkan.

  • Updated to include implementations of SPIRV-Reflect and VMA (Vulkan Memory Allocator) directly from the Vulkan SDK instead of maintaining copies of these within the hgiVulkan implementation. (PR: #2563)

  • Added a version guarded workaround to avoid a performance regression when rendering order independent transparency (OIT) on some recently released Metal devices.

  • Removed the use of CoreVideo texture caches from hgiMetal to simplify the implementation and fix a memory leak. (PR: #2828)

  • Added change to support float type matrix (GfMatrix4f) for instance transforms. (PR: #2724)

  • Added support to provide visual feedback for broken material shaders.

  • Fixed determination of screen space point size when using authored widths.

  • Improved the performance of shader generation when certain non-standard primvar names are present.

  • Refactored HdSt_CodeGen to take metaData as constructor arg. This allows us to delay the construction of the codeGen object since the hash can be computed from the constructor args. With this change there is approx 50% speedup in HdStExtCompGpuComputation::Execute.

Hydra

  • Fixed a bug that could lead to crashes in HdsiPrimTypePruningSceneIndex.

  • Hydra now supports inserting asset names into material networks.

  • Made HdImageShaderSchema constants return a schema instead of a container data source.

  • Made HdSceneIndexAdapterSceneDelegate handle image shaders correctly.

  • Made HdImageShaderSchema filePath a string, not an asset path.

  • Moved material node sampler parameter extraction into the standalone function HdGetSamplerParameters.

  • Added disableDepthOfField bool to RenderSettings.

  • Included to fix external build error. (PR: #2907)

  • Changed Metal's swizzle so single channel texture reads follow the UsdPreviewSurface spec of repeating the single channel on the r, g, and b channels with 1.0 in the alpha channel. (Issue: #2731)

  • Updated color correction task to support building against OpenColorIO 2.3.0. (PR: #2651)

  • Updated DataSourceMaterial and added HdMaterialNodeParameterSchema for colorspace handling in both Hydra 1.0 and 2.0.

  • Added UnderlyingDataSource to HdSchema and HdVectorSchema. This allows folding HdVectorSchemaBasedContainerSchema into HdSchemaBasedContainerSchema.

  • Deprecated hd/vectorSchemaTypeDefs.h in favor of the more generic hd/schemaTypeDefs.h

  • Deprecated BuildRetained Hydra schema in favor of Builder.

  • Added more typing to Hydra schemas by replacing container/vector data sources with appropriate schemas. This was done for HdMaterialBindingsSchema, HdMaterialSchema, HdMaterialNetwork, HdMaterialNode, HdRenderProductVectorSchema, and HdRenderVarVectorSchema.

  • Added GetFlattenedPrimvarValue for HdPrimvarSchema.

  • HdGeomSubsetsSchema::GetIds is now GetGeomSubsetNames.

  • Fixed implementation of GetContributingSampleTimesForInterval in HdDataSourceLegacyPrim to include the samples just before or just after the given shutter interval.

  • Added HdRenderDelegate::GetCapabilities, used to indicate motion blur support.

  • Introduced HdsiPrimTypeNoticeBatchingSceneIndex and HdsiPrimManagingSceneIndexObserver. Future render delegates can be implemented by observing the terminal scene index (HdRenderDelegate::SetTerminalSceneIndex) and providing an appropriate prim factory.

  • HdRenderPassState::SetOverrideWindowPolicy now takes std::optional instead of std::pair (similar for related classes).

  • Improved loading of multichannel OpenEXR files.

  • Enabled decompression of dwaa and dwab OpenEXR files.

  • OpenEXR code is now MinGW and Neon compatible.

  • Added support for monochrome OpenEXR images and swizzling for luminance channels. (Issue: #2800)

  • Added utility to write out scene index to file.

  • Removed 'bindingStrength' from HdMaterialBindingSchema.

  • Added support for asynchronous processing in Hydra generative procedurals, through the new SystemMessage scene index API. Procedural implementations need to implement the new asynchronous API to take advantage of this, and the host application will need to send periodic asyncPoll messages.

  • Added Hydra schema support for public interface mappings on material prims.

  • Prims with self-dependencies will no longer be signaled as dirty after they are removed.

  • Fixed a situation where both smooth and flat normals were being computed for HdMeshes for representations where only one of the two was needed. This is expected to remove about 10ms per unintended invocation.

  • Added multithreaded sync for HdExtComputations. Added a work parallel loop in Hd_PrimTypeIndex::SyncPrims enabled only for Prim types that opt-in. Opted "extComputation" into threaded prim sync by default. With this there is an order of magnitude performance improvement for use cases which have a significant number of HdExtComputations.

  • Added Hydra schemata to transport direct and collection-based material bindings, and a scene index to compute the resolved binding. Current support is limited to direct material bindings.

RenderMan Hydra Plugin

  • LPE AOV's now use the RenderVar name rather than the LPE expression as the channel name. This both gives expected output names in EXR channels, and fixes name collisions when the same LPE is used with multiple summary statistics, such as variance and mse.

  • Fixed crash when UsdRenderProduct's orderedVars points at a target prim that does not exist.

  • HdPrman now supports TfToken-typed parameters.

  • HdPrman now has a scene index filter, HdPrman_UpdateObjectSettingsSceneIndex, that will upgrade certain attributes used in older RenderMan versions to their modern representation.

  • Reduced overhead of portalLightResolvingSceneIndexPlugin.

  • Fixed handling of coordinate systems for light filters, which would give incorrect results in some circumstances.

  • Added support for single precision rotations for point instancers in HdPrman. Note that half precision rotations are still supported but are cast to floats. (Issue: #2529)

  • Added PxrMesh adapter to help mesh lights work on older versions of USD which do not have scene index support.

  • Added change to use the 'disableDepthOfField' RenderSettings option in HdPrman.

  • Added change to query and use shutter curve parameters if available.

  • Made various improvements to enable usage of a render settings prim to drive render pass execution. Current support is limited to generation of multiple render product artifacts in batched (i.e., non-interactive) mode.

  • Improved determination of the Riley shutter interval and its use for motion blur.

  • Improved instancing stability & performance.

  • All motion blur handling has been consolidated into a single scene index. Motion blur is now more consistently supported across the entire scene.

  • Motion blur will better respect the shutter settings of the active camera.

  • ExtComp is now compatible with motion blur.

usdview

  • Replaced deprecated QFontMetrics.width with horizontalAdvance. (PR: #2625)

  • Updated usdview selection processing to maintain correct selection highlighting after switching variants or prim activation and avoid some errors that could occur at startup when using PySide6 on Linux or Windows.

usdrecord

  • Updated camera transforms for usdrecord to make sure small objects are not unexpectedly culled by the clipping planes. (Issue: #2556)

  • Updated CMakeLists for usdrecord to skip building if GPU and/or OpenGL are unavailable. (PR: #2468)

usdcat

  • Fixed issues with usdcat --flattenLayerStack argument. (PR: #2832)

MaterialX

  • Fixed name collision with MaterialX inputs and built-in uniforms in Storm. (PR: #2807)

  • Fixed OIT issues for MaterialX when using Metal. (PR: #2614)

  • Added HdMtlxGetStdLibraries to cache the MaterialX::LoadLibraries step. (PR: #2666)

  • Added change to allow matrix33 default values in UsdMtlx. (PR: #2554)

  • Fixed testUsdImagingGLMaterialXCustomNodes_customColor failure. (PR: #2728)

  • Fixed Tangent vector calculation for MaterialX NormalMaps. (Issue: #1585)

  • Updated MaterialXMatfilt to handle normalMaps with PreviewSurface Materials. (Issue: #1585)

  • Fixed shader compile error when using MaterialX's :heighttonormal nodes. (Issue: #2281, PR: #2474)

  • Fixed a bug where the "fileprefix" attribute was not being applied to filenames. (Issue: #974, PR: #2660)

  • Updated CMakeLists for usdBakeMtlx to skip building if GPU and/or OpenGL are unavailable. (PR: #2468)

Documentation

  • Fixed various documentation issues. (PR: #2565, #2779)

  • Updated doc for UsdStage::Traverse() comments regarding PrimRange. (Issue: #222)

  • Updated UsdPreviewSurface Specification, added information about transparent black for texture wrap mode border color, clarified clearcoat inputs. (Issue: #2659, #2770)

  • Updated "Products Using USD" docs page with new Unity packages. (PR: #2884)

  • Updated UsdSkel documentation with fixed examples. (Issue: #2621, PR: #2697)

  • Updated Python docstring generation scripts:

    • Added fix to ignore previously generated __DOC.py files.
    • Fixed building docstrings on Windows.
    • Improved conversion of C++ types.
    • Added ability to build docstrings without having to first build HTML docs, using new CMake build options PXR_BUILD_PYTHON_DOCUMENTATION and PXR_BUILD_HTML_DOCUMENTATION. (PR: #2574, #2575, #2578, #2581)
  • Fixed UsdShadeMaterialBindingAPI example. (PR: #2726)

[23.11] - 2023-10-26

Build

USD

  • Fixed VtArray declarations of extern template instantiations. (PR: #2415)

  • Made change to use correct integer compression working space size when decompressing. (PR: #2435)

  • Fixed a bug where crash could occur on Python shutdown.

  • The initial deployment of pattern-based collections is now feature complete. This includes the following feature work on pattern-based collections: SdfPathExpression attribute values, composition support, a new membershipExpression attribute on UsdCollectionAPI, and UsdCollectionMembershipQuery support.

  • Added VtValue::(Unchecked)Mutate(), which lets callers mutate the held object.

  • Added GetNodeSubtreeRange function to PcpPrimIndex that returns an iterator range for traversing all nodes in prim index subtree starting at a particular node.

  • Added methods to UsdGeomXformable to retrieve individual UsdGeomXformOps.

  • Cleaned up wrapSchemaClass.cpp by specifying args and checking names for multipleApply classes. Regenerating schemas under this version will update Python wrappings for multiple-apply API schemas to add named arguments to
    constructors.

  • Removed the deprecated UsdSkelPackedJointAnimation class.

  • Added UsdLuxDomeLight_1 schema, a new version of the UsdLuxDomeLight schema that introduces a "poleAxis" property that affects the dome's final rendered orientation.

  • Fixed a dangling pointer bug in TfType that could lead to crashes on program exit.

  • URI schemes used for Ar URI resolvers are restricted to ASCII alphanumeric characters plus +, ., and - to conform to the URI/IRI specification in RFC2396. By default, URI resolvers associated with non-compliant schemes are ignored, but may be enabled by setting the environment variable PXR_AR_DISABLE_STRICT_SCHEME_VALIDATION to 1. (PR: #2453, #2467)

  • When flattening a stage, asset paths with unresolvable URI schemes will be treated as absolute paths. (Issue: #2480)

  • Allow loading plugins from file paths that contain Unicode characters. (PR: #1987)

  • Updated the UsdLuxPortalLight schema to add "width" and "height" and remove "extent".

  • Extended stage variable expression language:

    • Added support for integer, boolean and list types, and a 'None' sentinel value.
    • Added support for functions like "if" and "contains". See documentation for complete list.
  • Added "resolved asset path resyncs" to UsdNotice::ObjectsChanged. This new category of changes indicates that asset paths in a subtree have been invalidated and may now resolve to a different location, even though the authored asset paths have not changed. This may occur due to asset resolver changes, or expression variable changes.

    Client code that cares about changes to resolved asset paths must be updated to accommodate this new category of changes. The simplest way to do this is to treat all resolved asset path resyncs as full object resyncs. This is what UsdStage had done previously.

  • Fixed a bug where calls to ArResolver::RefreshContext that affected the resolution of sublayer asset paths would not cause affected prims to be resynced.

  • Fixed a bug where UsdNotice::ObjectsChanged::ChangedInfoOnly would incorrectly indicate that descendants of prims with info changes also had info changes.

  • Fixed a bug where UsdStage would not send notices for changes to instancing prototype in response to instances being loaded or unloaded.

  • Fixed a bug that caused crashes when calling UsdObject::GetDescription on expired UsdPrims.

  • Added GetKind and SetKind APIs to UsdPrim.

  • Added IsComponent and IsSubComponent APIs to UsdPrim. Note that subcomponent query is not cached because we only cache model-hierarchy-related information, and therefore this query will be considerably slower than other kind-based queries.

  • Added APIs to query model, group, assembly, component, and subcomponent to libKind.

  • Fixed TfPathUtils test by using TfNormPath instead of TfRealPath on Windows. (PR: #2476)

  • Versioned up and introduced UsdGeomCapsule_1 and UsdGeomCylinder_1 schemas to provide top and bottom radii. (PR: #2596)

  • Fixed SupportedFile error handling in complianceChecker. (PR: #2429)

UsdImaging

  • A previous release moved HdModelSchema out of UsdImagingModelSchema. This change has been reverted.

  • Fixed missing refresh when editing nodegraph attributes (PR: #2168)

  • Introduced UsdImagingCreateSceneIndices. Clients are encouraged to use this new API which abstracts creating the UsdImagingStageSceneIndex and the other scene indices necessary to resolve various USD behaviors such as instancing. Using the new API will hopefully isolate clients from future changes to the topology of filtering scene indices that are necessary to process a USD stage.

  • Made various fixes to the scene indices resolving USD native instancing and draw modes. In particular, draw modes authored on instances are now inherited and handled correctly and some subtle bugs with xforms authored on the prototype of a point instancer are fixed.

  • Moved code to handle UsdGeomModelAPI (when using scene indices) to its own API adapter.

  • Renamed usdRiImaging to usdRiPxrImaging since the corresponding schemata are in usdRiPxr (shipping with the Hydra RenderMan plugin).

  • Updated fallback purpose to "guide" so a bone mesh will not always show up when rendering skinned geometry.

  • Fixed UsdImaging 2.0 handling of requests to resync "/". The incorrect behavior was causing issues when changing the layer stack of a UsdStage, but behavior should now match UsdImagingDelegate.

  • Changed the UsdPreviewSurface spec's UDIM support to advertise handling of UDIM tiles from [1001,1100], instead of ending at 1099. This allows artists to use up to a 10x10 grid. Changed usdImaging/hdStorm UDIM handling to match.

  • Fixed an issue where the UsdImaging 2.0 configuration of UsdImagingGLEngine would lose root transform and visibility overrides on renderer change.

  • Bounding boxes representing prims with unloaded payloads are now instanced correctly. (PR: #2408)

  • Primvars with type 'asset' are now supported on native instances. (PR: #2521)

  • HdxSelectionTask and HdxColorizeSelectionTask no longer have the "enableSelection" parameter. This has been replaced with "enableSelectionHightlight" and "enableLocateHighlight" to allow separate control of selection and locate (rollover) highlighting with these tasks.

  • Added "includeSchemaFamily" option to the usdImaging pluginInfo.json, to allow one adapter to be used to render multiple different schema versions. (PR: #2596)

Storm

  • Added error handling for calls to OCIO in HdxColorCorrectionTask.

  • Removed unused SetLightingStateFromOpenGL and SetLightingState methods from HdStSimpleLightingShader.

  • Changed rebuilding of HdxSimpleLightTask buffer sources to happen only when needed.

  • Added scalar accessor for primvar redirects in HdSt_CodeGen even if primvar shares name with shader parameter.

  • Added argument to specify buffer usage when creating standalone buffer resources, allowing for correct specification of the drawIndirectResult buffer as a storage buffer.

  • Removed codegen of element primvar data for GPU frustum culling pipeline.

  • Fixed pipeline draw batch GPU frustum culling counting mechanism to wait for compute work rather than blit work.

  • Removed colorResolveAttachmentDescs and depthResolveAttachmentDesc fields from HgiGraphicsPipelineDesc and replaced them with boolean "resolveAttachments".

  • Added relevant geometric shader values to graphics pipeline hash computation.

  • Added OpenSubdiv shader source to geometry shader when using Hgi resource generation.

  • Added explicit default stencil value in HdStRenderDelegate::GetDefaultAovDescriptor, now used in Hgi backends.

  • Only fill color or depthStencil value of VkClearValue union in HgiVulkanGraphicsPipeline.

  • Various small cleanups to Hgi resource destruction.

  • HdSt_ResourceLayout has been moved and renamed to HioGlslfxResourceLayout.

  • HdStRenderPassState::ComputeImageToHorizontallyNormalizedFilmback is now accessible via the public API.

  • Improved shader program cache hit rate by reducing render pass shader variants stemming from different numbers of clip planes.

Hydra

  • Added modelPath, kind, and asset{Identifier,Name,Version} to the Hydra modelSchema, corresponding to UsdModelAPI.

  • Hydra's material network editor interface now provides GetModelAssetName().
    For the data source material implementation, this is backed by the Hydra modelSchema

  • Added a Tf scope description to inform the user while the app is waiting for a renderer to Stop()

  • Added HdxEffectsShader, a new base class for HdxFullscreenShader that provides functionality for image shaders creating and managing an HgiGraphicsPipeline instance.

  • HdxFullscreenShader's BindBuffers and BindTextures function signatures have changed, and the method used for determining binding points for buffers and textures has changed as well.

  • HdImageShader is a new prim type that has been added to represent image shaders in Hydra.

  • The RenderColorWithOccludedSelection render pass now takes non-opaque colors into account.

  • HdxAovInputTask now cleans up the intermediate depth texture it may have created when it is destroyed.

  • Fixed a bug that caused HdxColorCorrectionTask to not work correctly when using OpenColorIO 2.x with OpenGL on Linux.

  • Fixed race condition in HdGpGenerativeProceduralResolvingSceneIndex.

  • Introduced HdMakeStaticCopy used to make a copy of a data source.

  • Added built-in support for .exr (OpenEXR) image files in Hio. You no longer need to compile additional plugins to get OpenEXR support. See Working with Image File Formats: OpenEXR for more details.

  • Fixed scene transport of portal lights.

  • Added HdRenderDelegate API SetTerminalSceneIndex and Update to allow a render delegate to observe the terminal scene index and process change notices directly, aiding the transition to the Hydra 2.0 OM.

  • Added "shutterInterval" as a computed field on the render settings schema. Extended the render settings filtering scene index to compute and invalidate it based on the targeted camera and motion blur opinions of the render products.

  • Updated Hydra 2.0 stage scene index to sparsely invalidate in response to resolved asset path resyncs.

  • Added doxygen documentation about the HioImage plugin interface to help integrators writing their own HioImage plugins for texture loading.

  • Fixed Hydra 2.0 handling of transform flattening for non-zero shutter offsets.

  • The internal synthesized primvars used by Hydra instancers to communicate instance transforms to render backends have been renamed. Custom backend authors should update to the new tokens. An environment variable (HD_USE_DEPRECATED_INSTANCER_PRIMVAR_NAMES) is provided for the next 2 releases for those who need to continue using backends that have not yet been updated. Hydra backends for RenderMan, Storm, and Embree have been updated. See the post titled "Hydra synthesized instancer primvars renamed in release 23.11" in the Hydra channel in the AOUSD forums for more details.

  • HdMeshReprSpec adds the parameter 'forceOpaqueEdges' which, when true, signals that wireframe and hull opacity signals should be ignored.

  • Updated HdCyclinderSchema and HdCapsuleSchema in accordance with new Cylinder_1 and Capsule_1 schemas. Deprecated radius attribute and added radiusBottom and radiusTop attributes.

RenderMan Hydra Plugin

  • hdPrman for RenderMan 24 is deprecated. Support for hdPrman for RenderMan 24 will be removed in a future release.

  • Added support for array-valued inputs on shader nodes. (Issue: #1710)

  • Changed UsdPrimvarReader_float3 OSL shader "fallback" param to be float array instead of color. (Issue: #1683)

  • Added support during Riley shading node creation for shader parameters holding a GfVec3f with type SdrPropertyTypes->Float, treating them as a float array. (Issue: #1683)

  • Fixed a bug in MatfiltConvertPreviewMaterial where it could potentially iterate nodes multiple times, due to HdMaterialNetworkInterface::GetNodeNames not removing duplicates. Duplicates happen when there are multiple outputs being used on the material, like surface and displacement for UsdPreviewSurface.

  • We previously added sampleCount XPU rendering pixel information normalized in the renderer as opposed to normalized by display drivers. To enable backward compatibility, we've made a change that preserves the previous Rebind() API and just has a dead parameter, "weightsOffset". We rely on display drivers to ignore invalid offsets and only do sampleCount normalization when a valid sampleCount offset is provided.

  • Motion blur improvements for legacy motion blur support when scene index plug-ins aren't available:

    • Added a fallback code path for velocity motion blur used when the velocity blur scene index plug-in is not available.
    • Added a fallback code path for querying externally computed points for blur when the extComputationPrimvarPruningSceneIndexPlugin is not available.
  • Motion blur improvements for the velocity blur scene index plug-in:

    • Fixed issue where points were sampled on the frame (at time zero) for velocity computations, and other primvars were sampled at shutter open in hdPrman, so any time the shutter didn't open at time zero the blur could fail. Now, the velocity scene index plug-in deals with sampling all primvars at the sample time used for velocity blur, rather than just points.
    • For deforming blur, we now sample non-blurrable primvars at the center of the shutter interval, which more closely mimics how they would look if they were blurred.
  • The MtlxStandardSurface shader had an incorrect default for fuzzGain (it should be 0, not 1). Changed the default in the OSL StandardSurfaceParameters adapter pattern that gets wired up to PxrSurface when MtlxStandardSurface is being translated.

  • Added code pathway to allow HdPrman_RenderPass to use the Render Settings prim for non-interactive rendering with a valid Render Settings prim. Note that a Render Settings prim is considered valid if there is at least one Render Product and a camera relationship.

  • Added support for portal lights, including a resolver for managing their dome light relationship.

  • Removed "prmanParams" Sprim in favor of "renderSettings".

  • Added various improvements to improve determinism of test runs and reduce run times.

  • Reworked initialization of Riley scene options by composing opinions from various sources and allowing it to be deferred until render settings prim sync time to correctly handle immutable scene options.

  • The testHdPrman test shim will now produce noisier, but faster and more stable renders by default.

  • In response to a recent change to RenderMan, HdPrman will now enable rendering of volume aggregates by default when there is no authored integrator in the scene.

usdview

  • Edited the "Select Camera" menu in usdview to provide a popup dialog box that displays all cameras if there are more than 15 cameras in the scene.

  • Fixed a bug that prevented auto-complete from working correctly in the Python interpreter when using PySide6.

  • When authoring drawMode on a prim, apply UsdGeomModelAPI to the respective prim. Note that the scene index implementation of UsdImaging ignores the drawMode on a prim unless the prim has UsdGeomModelAPI.

usdchecker

  • usdchecker now allows .exr (OpenEXR) images in USDZ.

usdrecord

  • Updated usdrecord to use the Render Settings prim to generate image(s) based on the connected Render Products. To use this the HD_PRMAN_RENDER_PASS_USE_RENDER_SETTINGS_PRIM environment variable needs to be set to true.

MaterialX

  • Added change to process authored color spaces by HdMtlx and Storm, making the default color space 'raw' instead of 'auto' (Issue: #1523, #1878)

  • Updated MaterialX imaging tests.

  • Added error handling for MaterialX to avoid crashes when the shader is unable to be created.

Documentation

  • Updated USD Products entry for NVIDIA Omniverse. (PR: #2546)

  • Added Rendering with USD user guide. Use this guide to help build a robust USD pipeline and configure your assets for rendering.

  • Added details on OpenEXR support in USD to the USDZ specification and the Rendering with USD docs.

  • Added Variable Expression guide for using the new Variable Expressions feature.

  • Various documentation updates:

    • Added doxygen custom footer with copyright
    • Added VFX2022 details to VERSIONS.md
    • Added link to USD Working Group learning content wiki page
  • Various updates to python doc strings generation:

    • Added docstrings for many additional python objects (PR: #2526)
    • Fixed script to remove <USD module>_API type name prefixes (PR: #2580)
    • Fixed script to use "classmethod" instead of "static" (PR: #2579)
    • Fixed script to not word-wrap within code blocks (PR: #2576)
    • Fixed python docs build to raise CMake error if converting python docstrings fails (PR: #2573)
    • Fixed script to print stack trace on errors if debug mode on (PR: #2572)

[23.08] - 2023-07-21

We anticipate moving to the VFX Reference Platform CY2022 and C++17 in an upcoming release. Note that as part of the migration to C++17, some API signatures will change from using boost to using the std equivalent.

Build

USD

  • Sublayers are now loaded in parallel during UsdStage composition.

  • Fixed a bug in VtArray Python binding where setting values at index -1 would do nothing. (Issue: #2327)

  • UsdFlattenLayerStack now only adds a ".usda" extension if the tag provided is empty. This allows client code to flatten to their desired schema/format.

  • Deprecated spec-based functions on UsdPrimDefinition in favor of new property definition accessors.

  • Changed some behaviors of API schema composition in prim definitions.

    • Authored API schemas have been changed to be the weakest schemas instead of the strongest schemas when composing properties in a prim definition.
    • The "default" and "hidden" fields of properties can now be composed in from a weaker API if a stronger schema with the same property has no opinion for those fields.
    • The result of UsdPrim::GetAppliedSchemas now will never contain duplicate schema names. (Issue: #2336)
  • Added a function to PcpDynamicFileFormatContext that allows dynamic file formats to also compose and use attribute default values when determining the file format arguments for a dynamic payload.

  • Updated UsdUtilsComputeAllDependencies and UsdUtilsExtractExternalReferences to now work correctly with anonymous layer identifiers. (Issue: #2073

  • Fixed bug where UsdUtilsComputeAllDependencies would return layers with unexpected identifiers. (Issue: #2074

  • Fixed an issue in which nested usdz packages could result in additional dependencies being processed. (Issue: #2134

  • Fixed an issue to prevent asstInfo:identifier metadata from triggering an additional dependency when creating usdz archives. (Issue: #2135

  • Fixed a regression in UsdUtilsModifyAssetPaths to preserve explicit declaration of an empty SdfAssetPath.

  • Fixed a bug where UsdUtils.UsdzAssetIterator would change the process' current working directory.

  • Updated UsdSkel to remove warnings when UsdSkel attributes are authored on a prim but the UsdSkelBindingAPI schema is not applied. Please ensure that prims that have authored UsdSkel attributes have the UsdSkelBindingAPI schema applied.

  • Added stage variable expressions feature. The initial implementation supports string-valued variables and expressions with string substitutions (e.g., "asset_${NAME}".usd) in sublayer, reference, and payload asset paths, variant selections, and asset and asset[]-valued attributes and metadata. Additional work slated for an upcoming release include:

    • Support for integer and boolean value types as well as comparison and other functions.
    • Improved change processing to avoid resync notices for affected prims when variables are authored.
    • Detailed documentation
  • Fixed error messages for invalid specs in SdfCopySpec. (PR: #2440)

  • Removed the use of USD_SHADE_MATERIAL_BINDING_API_CHECK environment variable. Updated UsdShadeMaterialBindingAPI application check by adding a supportLegacyBindings argument to relevant APIs, which currently defaults to true. Note this default will be updated when Hydra 2.0 is enabled by default.

  • Fixed thread-safety issues that could lead to crashes in UsdSkel computations. (Issue: #1742, PR: #2369)

UsdImaging

  • Added UsdImagingPrimAdadpter::GetFullModelDrawMode and UsdImagingDelegate::GetModelDrawMode to support access of model draw mode from Hydra scene delegate.

  • Disabled shadows on the "simple" headlight. (PR: #2373)

  • Added various updates and fixes to UsdImagingStageSceneIndex. This class is being developed as a replacement for UsdImagingDelegate and is missing support for UsdSkel, UsdGeomSubset, and material binding collections. Code that wants to try the new implementation can add it to a render index by following the example of UsdImagingGLEngine, or enable it in UsdImagingGLEngine (and usdview) with the USDIMAGINGGL_ENGINE_ENABLE_SCENE_INDEX env var.

    • Added support for coordinate systems. Clients expecting prims of type coordSys (such as hdPrman) need to run HdsiCoordSysPrimSceneIndex to pick up the coordinate systems from the UsdImagingStageSceneIndex.
    • Added support for material binding strength (UsdShade's bindMaterialAs).
    • Improved support for selection and instancing.
    • Updated to force instance interpolation for non-constant and non-uniform primvars on point instancers.
    • Updated to prefer (prefixed) primvars over custom primvars (such as normals).
    • Applied multiple fixes to native and point instancing.
    • Updated to honor displayColor/Opacity authored on materials.
    • Added support for showing unloaded prims as bounding boxes.
    • Updated to communicate to schema adapters whether a USD property was updated or resynced.
    • Added UsdImagingRootOverridesSceneIndex and HdsiLegacyDisplayStyleOverrideSceneIndex and used these to implement some UsdImagingGLEngine behaviors when using scene indices.
    • Added support for UsdGeomNurbsCurves and UsdGeomNurbsPatches. Note that these are currently drawn as hulls by Storm, and not tessellated or evaluated.
    • Added both time-varying and property change invalidation for the "light" data source.
    • Made change when adding a new UsdImaging_DrawModeStandin draw mode standin prim that now deletes its child subtree of draw mode standin prims.
    • Made change that skips the draw mode processing of dirtied prims with an existing draw mode standin ancestor.
    • Made change that includes instancedBy data source in the draw mode standin data source.
  • Updated UsdImagingGLEngine to use the scene globals scene index to set the active render settings prim.

  • Fixed a performance regression in HdLight::Sync. (Issue: #2416)

  • Allow population of instanced USD materials as uninstanced Hydra materials. While Hydra doesn't directly support instanced materials yet, this allows scenes to make use of instancing at the USD level and still render correctly.
    If a UsdShadeMaterial is natively instanced on the UsdStage, it will share the potentially numerous UsdShadeShader nodes, and the material-level parameter interface (which can be connected to shader parameters) can be overridden on each instance.

  • Fixed issues where certain authored transforms were being lost in certain cases where point instancers were being instanced by native instancers, or where transforms were authored on a point instancer's non-imageable prototype root. (Issue: #1663, #2359)

  • UsdImaging now returns material networks by render context, and strips render context namespace from the terminal names. Consequently we no longer need HdsiTerminalsResolvingSceneIndex. Saved 30+ seconds of production shot Storm load time by keeping Storm from traversing RenderMan-specific USD material networks only to then immediately discard them.

  • Made change so UsdImagingDataSourceMaterial now strips the material path prefix from names of the nodes in the network. This both makes networks more concise to inspect and removes an unnecessary source of superficial variation in otherwise-matching materials recurring across models, enabling more effective de-duplication of matching material networks across assets.

  • Made UsdImaging_PiPrototypeSceneIndex performance improvements, reducing load time of a production shot from 67 sec to 13 sec.

  • Moved UsdImagingModelSchema to HdModelSchema.

Storm

  • Fixed value of aspectMask in HgiVulkanTexture::CopyBufferToTexture. (PR: #2442)

  • Fixed a bug with GPU instance frustum culling prims with geom subsets. (Issue: #1892)

  • Updated HdStRenderPassState::ComputeViewport to use _GetFramebufferHeight when computing the viewport.

  • Made various fixes for Metal backend:

    • Fixed null pointer checks during buffer binding. (PR: #2401)
    • Fixed 1x1 texture mipmap generation. (PR: #2264)
    • Fixed HgiInteropMetal to use FP16 textures to allow clients to make use of Extended Dynamic Range (EDR). (PR: #2482)
    • Fixed tessellation for Intel GPUs.
  • Cleaned up HdStRenderPassState setup of face cull mode. (PR: #2433)

  • Cleaned up codeGen mixins related to OpenSubdiv to reduce the size of compiled shader source.

  • Moved several Storm specific implementation aspects from lib/hd to lib/hdSt including: smoothNormals, flatNormals, vertexAdjacency, bufferArrayRegistry, strategyBase, resource, bufferResource, computation, extComp, drawItem BAR accessors.

  • Updated Basis curves shader to use difference rather than tangent vector when the latter is degenerate. This prevents artifacts where the last segment during tessellation is dropped when pinning curves (having the last points of a cubic curve all equal).

  • Fixed rendering of pinned catmullRom curves to include the first and last segments when drawn as lines. (Issue: #2445)

  • Optimized shader processing in Storm to provide stable shadertext to the GPU. This allows some GPU drivers to fully utilize shader compilation caches, significantly reducing the time spent compiling and linking GLSL shaders. In one production shot, this time went from 5+ seconds to 60 ms.

Hydra

  • HdsiPrimTypePruningSceneIndex now nulls out the primType and dataSource of pruned prims without also pruning the subtree beneath them. This allows application-supplied renderBuffers, drawTargets, etc. that are children of pruned prim types to survive.

  • HdFlatteningSceneIndex now lazily populates its cache of flattened data sources using a two phase scheme that more efficiently accommodates both scene updates and concurrent traversal.

  • Fixed HdRenderIndex::GetSceneDelegateAndInstancerIds for prims that don't contain a "delegate" data source.

  • Added API for accessing model draw mode data in HdSceneDelegate.

  • Fixed alpha channel blending in hgiInterop composite functions.

  • Added lens distortion, focus, and split diopter parameters to HdCamera.

  • Updated fullscreen shader to use the correct texture sampling function for the depth texture.

  • Updated HdxAovInputTask to create and manage a "depthIntermediate" texture to facilitate ping-pong behavior for image shaders.

  • Added legacy and Hydra 2.0 support for the render terminals in PxrRenderTerminalsAPI

  • Made HdFlatteningSceneIndex modular by allowing clients to give a container data source mapping names of data sources to instances of HdFlattenedDataSourceProvider which a client can implement to provide additional flattening policies. Some other fixes and potential performance improvements to HdFlatteningSceneIndex.

  • Updated HdFlatteningSceneIndex to additionally flatten coordinate system bindings and constant primvars.

  • Introduced HdsiPrimTypePruningSceneIndex which generalizes HdsiMaterialPruningSceneIndex and is also used to prune scene lights.

  • Renamed HdMaterialBindingSchema to HdMaterialBindingsSchema and made it contain a schema rather than just a path to the material to bind. This is to facilitate material binding strength in usdImaging.

  • Added GetSchemaToken to Hydra schemas where appropriate.

  • Made shading nodes with implementation source code work with scene indices. Updated HdRenderPassState to make the calls to set the camera, override window policy, and framing/viewport orthogonal.

  • Added scene index to manage global scene data such as the active render settings prim.

  • Added scene index that provides dependency registration and namespace filtering functionality in service of render settings prims.

  • Removed query of "material" data source for HdSceneIndexAdapterSceneDelegate::GetLightParamValue as it has significant overhead.

  • Updated to return light parameters within "light" data source from UsdImagingStageSceneIndex in order to satisfy render delegates which don't make use of GetMaterialResource for lights.

  • Added display names and tags for scene index instances (in service of user interfaces).

  • Added renderInstanceId on HdRenderIndex (used for application-specific tracking and in service of user interfaces).

  • Added scene index plug-in registry support for closure-based registration for application-specific configuration of downstream scene indices.

  • Updated HdSceneIndexPluginRegistry::InsertionPhase from unsigned int to int (in preparation for future "before vs after per-renderer branch distinction").

  • Added HdSceneIndexObserver::RenamePrims for future use (with fallback behavior to convert to removes and adds).

  • Updated back-end Hydra emulation to allow fallthrough to delegate->Get for an empty result even when a "primvars" data source is present.

  • Updated HioImage plugin precedence to space values out, for more flexibility. Note that the relative precedence of existing HioImage subclasses has not changed. Future plugin authors can add support for new image loading libraries by subclassing HioImage, specifying supported file extensions, and choosing a precedence relative to the basic USD plugins; the highest precedence plugin is used.

  • Added native instancing and point instancer support for lights to Hydra and HdPrman. Analytic and geometric (mesh) lights are now supported in instance prototypes all the way through Hydra, and Hydra render bridges may now expect to see instancing information on light prims. Note that mesh light support in HdPrman still requires that scene indices be enabled.

  • Made various performance improvements:

    • HdMergingSceneIndex now traverses the contents of added input scenes using task parallelism.
    • Improved performance of Hd_SortedItems when using Hydra scene indexes with nested point and native USD instancing, reducing load time of a production shot by 3 seconds.
    • Added a new approach to toggling use of scene materials, using a Hydra filtering scene index to prune material prims and bindings. Reduced time to load a production shot in Storm (with scene materials off) by 10 seconds, by avoiding unnecessary shader compiling and linking.
    • HdxColorCorrectionTask now does OCIO 3D LUT generation and shadertext generation in an async task, saving 750 msec of render startup time by moving work off the main thread.

RenderMan Hydra Plugin

  • Added support for RenderMan 25.

  • Fixed a bug where black artifacts often show up in RenderMan renders that use UsdPreviewSurface with a normal map. The fix handles bumpNormals that are facing away from the camera when the surface is facing forwards, based on what PxrNormalMap does in the RixAdjustNormal method.

  • Added support to use scene option settings on the active render settings prim.

  • Added functionality to configure and use the render settings filtering scene index for filtering and dependency functionality.

  • Improved performance of HdPrman significantly when rendering scenes with very high instance counts by making use of RenderMan nested group instancing.

  • Added support for instanced lights.

  • Updated RenderMan args parser to camelCase shader node context for displayFilters, to match how its done for sampleFilter, lightFilter and pixelFilter.

  • Updated usdRiPxr schemas to reflect updates to RenderMan args files for RenderMan 24.0.

usddiff

  • Enhanced usddiff to work with usdz packages. Files contained in usdz packages are now iterated and diffed individually. A specific diff program may be specified when image files are encountered in packages by setting the USD_IMAGE_DIFF environment variable. The USD_IMAGE_DIFF_FORMATS environment variable can optionally be set to indicate the file extensions that the image diffing tool supports. These are specified in a comma-separated list with the default being "'bmp', 'jpg', 'jpeg', 'png', 'tga', 'hdr'".

usdrecord

  • Disabled HdxPresentTask from running during recordings to avoid unneeded use of GL. (PR: #2391)

usdview

  • Fixed a bug in usdview's metadata tab where not all inherited paths would necessarily be listed for the inherits field.

  • Fixed PySide object initialization to avoid runtime exceptions when using PySide6 6.5.x. (PR: #2392)

  • Fixed a bug with display of prims having property paths for IDs in Python Hydra scene browser.

Alembic plugin

  • Updated UsdAbc plugin to re-enable USD_ABC_READ_ARCHIVE_USE_MMAP to be true by default and match the current behavior of Alembic 1.7.9+. (PR: (#2439)

MaterialX

  • Added MaterialX v1.38.7 support to allow for MaterialX support on Metal. (Issue: #2216, PR: #1965, #2324, #2402)

  • Fixed a bug where calling SdfLayer::ImportFromString with a .mtlx document would fail to resolve relative XML include paths.

  • Added Distant light support to MaterialX in Hydra.
    (Issue: #2411)

Documentation

  • Made various documentation updates:

    • Fixed various broken links and replaced references to graphics.pixar.com with openusd.org
    • Clarified propagation of UsdNotice::ObjectChanged() notification
    • Updated dynamic payload doc with new uniform attributes
    • Fixed usdRender RenderPass doc example
    • Added descriptions for opaque and group attribute types
    • Added more info on using session layer
  • Added the doxygen awesome theme to doc build. This theme adds responsive design so documentation can be viewed on mobile devices, and a dark/light theme to improve visibility. Note that doxygen awesome needs doxygen 1.9 or better to build properly. (PR: #2050)

  • Fixed typo in primvar documentation (Issue: #2386)

  • Fixed reported broken link (Issue: #2450)

  • Fixed pipeline plugInfo.json doc example (Issue: #2346)

  • Replaced references to ASCII with Text in USD binaries to account for UTF-8 support (PR: #2394, #2395)

  • Clarified sourceColorSpace = sRGB only applies to transfer curve and not gamut (Issue: #2303)

  • Added info on changing metadata via variants (Issue: #2326)

[23.05] - 2023-04-18

Support for Python 2 has been removed in this release.

Build

  • Changes and fixes for build_usd.py:

    • MaterialX support is now enabled by default.
    • Updated to use libpng version v1.6.38. (PR: #1946)
    • Fixed error when using Visual Studio 2019 or later with --generator Ninja. (PR: #2192)
    • Cleanup unused code. (PR: #2267)
    • NASM is no longer a required dependency when enabling OpenImageIO support on Windows.
    • Updated to use TurboJPEG 2.0.1 on all platforms for OpenImageIO.
  • Various CMake fixes (PR: #2275 #2030, #2179)

  • Bumped CMake minimum to 3.14 on linux to support vfx2020 dependencies. Other platforms require 3.20 or greater. (Issue: #1620)

  • Updated CMake to use PROJECT_SOURCE_DIR and PROJECT_BINARY_DIR instead of CMAKE_SOURCE_DIR and CMAKE_BINARY_DIR respectively, in order to allow building USD as a subdirectory. (PR: #1971)

  • Removed uic as alternative to pysideX-uic from FindPySide.cmake as uic will produce a py file containing C++ code.

  • Added ability to build docstrings for the USD Python modules. This can be enabled by specifying the PXR_BUILD_DOCUMENTATION, PXR_ENABLE_PYTHON_SUPPORT, and PXR_BUILD_PYTHON_DOCUMENTATION options when running CMake, or --docs, --python, and --python-docs when running build_usd.py. See BUILDING.md for more details. (Issue: #196)

  • Fixed issue when PXR_PY_UNDEFINED_DYNAMIC_LOOKUP is explicitly set when packaging wheels, or when cross compiling to a Python environment that is not the current interpreter environment. The value will now be set automatically during cmake configuration. (Issue: #1620)

  • Various fixes for build issues, including missing headers on different platforms and compilers. (PR: #2194, #2215)

  • Various fixes for compiler warnings from clang. This has reduced the warning count on MacOS builds from several hundred to roughly 60. (PR: #1684, #1997)

  • Removed PXR_USE_PYTHON_3 CMake option.

USD

  • Fixed a bug where undefined behavior could be invoked when reading a corrupted .usdz file.

  • Fixed a bug where UsdStage::LoadAndUnload() could over invalidate and recompose. (Issue: #2286)

  • Fixed deadlock when opening and closing layers from multiple threads in Python. (Issue: #2306)

  • Fixed deadlock in TfType::GetAllDerivedTypes(), which could appear when opening and closing layers from multiple threads. (Issue: #2282)

  • VtArray now uses operator new (including global replacements) to allocate memory.

  • Fixed a bug where VtArray could read from freed memory when inserting copies of elements from within the container.

  • Fixed various safety issues for reading from corrupted .usdc files.

  • The composition engine now supports internal references expressed by a variant. Internal references also now retain visibility to namespaces outside the referenced scope.

  • The composition engine now prohibits scene paths with embedded variant selection components (such as </A{x=y}B>) when used for composition arc targets. This is enforced both at the Sdf schema level and composition subsystem level. Schema enforcement means that invalid paths cannot be authored via runtime API, nor will they be accepted by the text parser. As a deployment aid, the environment setting SDF_SCHEMA_PROHIBIT_INVALID_VARIANT_SELECTIONS may be set to '0' to continue to allow these paths at the schema & parser level. Regardless of the setting, however, the composition system will always prohibit such paths where invalid for composition purposes.

  • UsdCollectionAPI now handles the combination of includeRoot=true and expansionRule=explicitOnly without throwing a coding error.
    (Issue: #2258

  • Updated RapidJSON used by pxr/base/js to the latest available version as of January 2023. (Issue: #2219)

  • Completed initial support for Schema Versioning

    • usdGenSchema now allows API schemas with version suffixes to be generated.
    • usdGenSchema does not allow a schema to inherit from another version of a schema in the same family.
    • usdGenSchema generates schema identifier and family tokens in the library tokens class.
    • UsdPrimDefinitons now enforce the rule that more than one version of the same API schema family cannot be applied at the same time.
    • If more than one version of the same API schema family is auto-applied to a schema only the latest version of the API schema is applied.
    • Added a templated static overload of FindSchemaInfo to UsdSchemaRegistry.
  • Improved UsdStage update performance when applying or removing an API schema on prim. (Issue: #2343)

  • Added "collection:" to the CollectionAPI schema as a real, opaque valued, attribute for allowing collections to be targeted by a relationship.

  • usdGenSchema now allows multiple-apply schemas to declare a property with no base name via the special property name "INSTANCE_NAME".

  • usdGenSchema generates literal token identifiers (instead of camel cased identifiers) by default. Some usdLux and usdVol token identifiers have been updated.

  • Added SdfFileFormat::FindAllDerivedFileFormatExtensions to determine all extensions supported by a subset of file formats without loading the plugins for those formats.

  • Updated usdRi schema to include RiRenderPassAPI, which provides cameraVisibility and matte collection attributes to provide collections of objects relevant to the renderer for respective concepts. Note by default cameraVisibility collection includes all objects, and matte collection excludes all objects.

  • Updated RenderPass schema to include a renderVisibility collection property, which provides a collection of objects relevant to the renderer. Note by default all objects are included in the collection.

  • Fixed race condition in ArFilesystemWritableAsset that could cause writing to the same directory from multiple threads to fail if that directory had not yet been created.

  • Added support for array vstruct sdrShaderPropery types.

  • Resolved UDIM tiles when calculating asset dependencies. (PR: #2133)

  • File format plugins can now specify read / write / edit capabilities in their plugInfo.json file. (Issue: #2147)

  • Added pointWeights attribute to NurbsCurves in usdGeom. (Issue: #1554)

  • Introduced GetAppliedItems for SdfListOp API. Deprecates GetAddedOrExplicitItems.

  • SdfSpec::ClearInfo now errors for unknown metadata fields.

  • UsdRenderComputeSpec() now skips schema properties when aggregating authored settings.

  • Replaced uses of boost::hash with TfHash throughout the base and usd packages of pxr. (PR: #2173, #2176, #2181, #2182, #2184, #2185, #2186, #2187, #2190, #2191, #2289, #2298, #2304, #2329)

  • Removed use of "register" keyword, which is no longer supported as of C++17. (PR: #2204)

  • Various changes to remove uses of boost. (Issue: #2203, #2211, #2217, #2221, #2247, #2290 PR: #2210, #2213, #2213, #2249, #2291)

  • Fixed a bug where UsdUtilsCreateNewUsdzPackage would not correctly handle relative filesystem paths pointing to a directory outside the directory containing the root layer.

  • Fixed a bug where using a Usd.PrimRange from an expired Usd.Stage in Python would crash or throw an unexpected exception. (Issue: #2160)

  • Updated USD compliance checker to error instead of warn when the following issues are found:

    • Shader prims are not encapsulated within a container type prim.
    • For 8bit normal maps, if sourceColorSpace is not "raw" and if bias and scale values are not provided.
  • Updated deprecation logic for USD_SHADE_COORD_SYS_IS_MULTI_APPLY, such that warnings are reported when the environment variable is set to Warn and usdPrim is using any old style coordSys property.

  • Updated testUsdBugs to explicitly use integer division, so as to avoid passing a float to truncate method. (Issue: #2170, PR: #2171)

  • Updated UsdProperty.GetPropertyStack and UsdProperty.GetPropertyStackWithLayerOffsets python APIs to take a UsdTimeCode as an optional argument, to match their respective C++ APIs. (PR: #2317)

  • Added compliance tests to make sure UsdSkelBindingAPI is applied on prims having properties provided by UsdSkelBindingAPI. Also added a compliance test to ensure that UsdSkelBindingAPI has only been applied on SkelRoot prims or descendants of SkelRoot prims.

  • Updated usdRiPxr codeless schemas with updated concepts from Renderman 24.5.

  • Fixed ZipFileWriter context manager to discard any archived files if the root USD file is non-compliant. This fixes usdzip and usdfixbrokenpixarschemas usage with non-compliant usdz archives.

  • Fixed various gf tests to resolve floating point precision issues on ARM (aarch64) platforms. (PR: #2115)

  • Updated UsdShadeShaderDefUtils::GetPrimvarNamesMetadataString to only append existing non-empty primvar strings into the list in order to avoid appending of empty strings on aarch64 platforms. (PR: #2131)

UsdImaging

  • Added UsdImaging::SetRootInstancerId as a method to set new member _rootInstancerId, which is now used as the fallback case for UsdImagingDelegate::GetInstancerId.

  • Fixed crash in UsdImagingAdapterRegistry by comparing with the end iterator of the same unordered_map. (PR: #2197)

  • Removed material prims under a point instancer when resyncing. (Issue: #1960)

  • Fixed shader compilation errors with usdImagingGL volume tests on macOS.

  • Fixed errors and inconsistencies with usdImagingGL instancing tests related to Ptex textures and handling of "--cullStyle" and "--shading" test command line arguments. (Issue: #2097)

  • Updated PreviewSurface.glslfx to mirror changes made to simpleLighting.glslfx to make sure the intensity and exposure on dome lights are properly affecting PreviewSurface materials.

  • Added GetRenderSettingsNamespaces to HdRenderDelegate to get namespaces for render settings attributes that are render-specific.

  • Updated HdRenderSettingsSchema and UsdImagingRenderSettingsAdapter.

  • Add Scene Index support functions to the UsdImagingRenderSettingsAdapter.

  • Added UsdImagingUsdSchema which combines data sources internal to UsdImaging.

  • Fixed a cyclic reference (in UsdImaging_NiInstanceAggregationSceneIndex_Impl) where a data source in a HdRetainedSceneIndex (_InstanceObserver::_retainedSceneIndex) held on to a ref ptr to a data structure (namely, _InstanceObserver) containing a ref ptr to the scene index. This was causing a memory leak and a crash in _InstanceObserver::PrimsRemoved.

  • Made various small fixes and clean-ups to the filtering scene indices required for USD native and point instancing support.

  • UsdImagingPiPrototypesPropagatingSceneIndex now lists the paths of the propagated prototypes for a USD prototype. This is intended for clients that need to translate a USD path to a Hydra scene path, e.g., to support selection highlighting.

  • UsdImagingNiPrototypesPropagatingSceneIndex populates the HdInstanceSchema for native instances.

  • Enabled selection highlighting of USD native instances when using scene indices. The UsdImagingSelectionSceneIndex processes the path to a native USD instance by reading its HdInstanceSchema and populating the HdSelectionSchema.

  • Fixed purpose handling in the UsdSkelImagingAdapter.

  • Added adapter support for transporting render settings scene description (which includes render products and render vars, but not render passes).

  • Fixed an issue where having multiple prim/API adapters could cause double population in UsdImagingStageSceneIndex.

  • Added support for "keyless" API schema adapters which have an opportunity to contribute to any prim.

  • GetInstanceCategories now works under nested instancing, returning categories for all instances in the flattened hierarchy. (Issue: #2002)

  • Fixed crash due to out of bounds access in UsdImagingInstanceAdapter::GetScenePrimPaths. (Issue: #2268, PR: #2278)

  • Updated UsdImagingCoordSysAPIAdapter to provide access to coordSys hydra prim (HdCoordSysSchema), which provides information about coordSys name and xform values. Also added dependency of this coordSys prim to the bound target xform.

  • Removed Populate() from the UsdImagingStageSceneIndex. "Population" is now done automatically when the stage is set.

Storm

  • Fixed use-after-free bug in basis-curves helper function in hdSt.

  • Implemented support for the remaining refined drawing modes for basisCurves and meshes using HW tessellation with HgiMetal.

  • Renamed HdBinding to HdStBinding and moved to hdSt since this is used only by Storm.

  • Improved performance when freeing argument buffers after command buffer submission with HgiMetal. (PR: #2046)

  • Fixed crash when loading non-filterable textures with HgiMetal. (PR: #2048)

  • Changed the name of an internal debug class to avoid problems with Cocoa View classes. (PR: #2256)

  • Added HorizontallyNormalizedFilmbackCoordinates to renderPass.glslfx for material shaders needing to draw in image space.

  • Fixed picking of semi-transparent fragments by using a small alpha threshold value when discarding fragments.

  • Fixed a bug to avoid an infinite loop and issue a coding error when passing relative paths to HdSystemSchema::Compose.

  • Improved the performance of cards stand-ins in Storm. Edges of cutouts may show slightly increased artifacts as a result.

Hydra

  • Fixed a bug in scene index emulation where removing an Rprim or Bprim from HdRenderIndex would remove all of that prim's children as well.

  • Moved UsdImaging_SceneIndexPrimView, an iterator to traverse all ancestors of a prim in a scene index, to HdSceneIndexPrimView.

  • HdInstanceSchema now includes the index of a native instance within the instancer instancing the prototype.

  • Added special case for sprim dirty bits translation for emulated mesh lights.

  • Added fix that ensures that HdSceneIndexAdapterSceneDelegate uses unique names with HdSceneIndexNameRegistry.

  • Added optional argument needsPrefixing to HdRenderIndex::InsertSceneIndex to indicate whether input scene index needs prefixing.

  • Added missing .tiff extension to hioOiio (PR: #2307)

  • Fixed double transforms in Hydra when using the new scene index API.

  • Added support for transporting render settings scene description in Hydra.

  • Added scene globals schema to encapsulate global state necessary to orchestrate a render.

  • Fixed computed view transform for the shadow matrix.

  • Made HdxTask::_hgi member private. Subclasses should use the protected _GetHgi() method instead.

  • Exported HdxTask::Sync to allow for custom render task creation and use. (PR: #2178)

  • Added HdCoordSysSchema which provides "name" member field and its builder interface.

  • Fixed a memory leak during framebuffer resize. (PR: #2342)

Renderman Hydra Plugin

  • The RenderMan Hydra delegate now transfers attributes from material to geometry that binds the material. This is useful in cases such as displacement bounds and subsurface trace groups.

  • Removed a deprecated staging flag, HD_PRMAN_ENABLE_LIGHT_MATERIAL_NETWORKS

  • Fixed hdPrman slowdown when rendering many AOVs.

  • Fixed an issue where normal maps going through the RtxHioImage plug-in were being linearized. HdPrman now provides a "sourceColorSpace=raw" argument when the rtxplugin is being invoked for a mtlx image node that has type "ND_image_vector[2,3,4]"; the type comes about based on the mtlx image node's "signature" param. This also affects the MaterialX Chess Set scene.

  • Fixed an issue with MaterialX texcoord nodes referring to texture coordinates as "uv" instead of "st". Now, as the MaterialX network is translated we swap out texcoord nodes for geompropvalue nodes that look up "st".

  • Fixed a crash in RtxHioImage plugin used by hdPrman, as a result of passing nullptr for RixContext. Explicit nullptr guards are now added for the same.

  • Added improvements for rendering with Solaris's husk, including support for RenderMan display drivers and command line arguments.

  • Reworked and reorganized the testHdPrman test harness to use the RenderSettings Prim by default, instead of the UsdRenderSpec.

  • Updated riley geometry instances for rprims owned by hydra instancers regardless of local dirty bit state to ensure that instance primvars are updated.

  • Made hdPrman invalidation more granular for improved performance

  • HdPrman now uses Renderman nested instancing for nested point instancer hierarchies, which can provide significant performance and memory footprint improvements in scenes with heavy nested instancing. This feature is enabled by default, and can be disabled by setting HD_PRMAN_DISABLE_NESTED_INSTANCING=1. Users should be aware that picking and selection of individual instances may not work as expected when this feature is enabled and HdPrman is in use. Users who need to use instance picking with HdPrman should disable this feature.

usdrecord

  • Fixed crash on startup when using PySide6.

usdview

  • Fixed python exceptions in usdview when selecting relationship targets whose path is either a property path or is a path to any object that doesn't exist on the stage.

  • Added a display menu item to toggle display of dome light background texture images when dome lights are enabled. (PR: #2123)

  • Fixed an error from the incorrect use of hasattr() when using openColorIO color management. (Issue: #2254)

  • Fixed usdview to hide viewport frame when --norender is set

  • Updated usdview Hydra Scene Browser to be compatible with more PySide versions and macOS

MaterialX

  • Fixed MaterialX materials with the name 'material' (Issue: #2076)

  • Fixed issue for MaterialX namespaces when adding MaterialX nodes to a node graph.

  • Fixed MaterialX split string array parsing to split only on "," delimiter and not "," and spaces.
    (Issue: #2268, PR: #2278)

  • Updated usdMtlx parser to parse various MaterialX metadata into sdr properties. (Issue: #1874, PR: #1895)

Documentation

  • Improved Python help() documentation for USD APIs when Python docstrings are built, as described in Build section above.

  • Various documentation updates, including:

    • Improved TfError documentation
    • Renamed image source filenames in tutorial docs
    • Added thread-safety guidance docs for ArResolver::RefreshContext()
    • Updated contributing guidelines
    • Updated docs on GeomPointInstancer xform resolution
    • Fixed incorrect description of SkelAnimation binding example, cleanups to UsdSkel documentation and examples
    • Updated UsdLuxShadowAPI properties docs
    • Added additional asset resources to "Downloads and Videos" page
    • Fixed the path to the basisCurves example asset in the documentation.
  • Updated Windows build instructions example in README.md to build into non-protected directory. (PR: #1994)

  • Updated "Environment Setup" section of Tutorials page to specify adding USD_INSTALL_ROOT/lib to the PATH environment variable on Windows when running the tutorials. (PR: #2198)

  • Added general guidance on FAQ page on where to install USD DLLs and plugins on Windows. (PR: #1788)

  • Updated UsdUVTexture and UsdPreview docs to clarify usages of scale, bias and sourceColorSpace when using an 8bit Normal Map, in order to satisfy tangent space requirement of the normals.

  • Updated USD toolset documentation to include usdfixbrokenpixarschemas.

[23.02] - 2023-01-24

Version 23.02 is the last release that supports Python 2. Support for Python 2 will be removed in the next release.

Build

  • The usd-core PyPI package now supports Apple Silicon. (Issue: #1718)

  • Added support for Python 3.10. (PR: #2007)

  • Added support for Visual Studio 2022, and removed 2015. The supported versions are now 2017, 2019, and 2022. (PR: #2007)

  • The minimum supported Boost version is now 1.70. (PR: #2007, #2150)

  • Updated CMake build system to use modern FindPython modules and import targets. This fixes an issue on macOS where the correct Python framework directory would not be added as an RPATH. Clients that were specifying CMake arguments like PYTHON_EXECUTABLE or PYTHON_LIBRARY or PYTHON_INCLUDE_DIR to control the behavior of the deprecated find modules will need to use the corresponding arguments for the new modules. (Issue: #2082, PR: #2091)

  • Fixed macOS code signing issue when using the Xcode CMake generator that would cause builds to be unusable on Apple Silicon.

  • Various CMake build system cleanup. (PR: #1958, #2152)

  • Fixed threading issue causing assertions in Windows debug builds. (PR: #2127)

  • Fixed compiler warning when using GfVec3f::GetLength with -Wconversion enabled. (PR: #2060)

  • Removed dependency on boost::program_options. (PR: #2114)

  • Fixed issue where C++ executables like sdfdump would fail to run on Linux and macOS in certain configurations due to a missing RPATH entry for the USD core libraries.

USD

  • Numerous performance and memory optimizations.

  • Updated UsdSkel plugin bounds computation to include nested skeletons in the case where there are no bindings.

  • UsdGeomModelAPI::ComputeExtentsHint now uses UsdGeomBoundable::ComputeExtentFromPlugins for boundable models.

  • Added malloc tag reporting to sdfdump when run with the TF_MALLOC_TAG environment variable set.

  • Fixed bug where handles to .usdc files were not being closed after the associated SdfLayer object was destroyed. (Issue: #1766)

  • SdfLayer is now case-insensitive for characters in 'A'-'Z' when looking up layer file format from file extension. (Issue: #1833)

  • Improved TfMallocTag performance for parallel applications. For example, time to open one test asset on a UsdStage with tagging enabled decreased from ~40 seconds to ~5 seconds.

  • Updated doc discouraging use of ArchGetFileName. (Issue: #1704)

  • UsdPrim::ComputeExpandedPrimIndex and UsdPrimCompositionQuery can be used with prototype prims.

  • Fixed a composition error involving specializes and subroot references.

  • Initial Schema Versioning support. Note that not all of the schema versioning work is complete. In particular, it is not yet possible to generate versioned API schemas through usdGenSchema even though the UsdPrim API for querying and authoring them has been added. Full schema versioning support is expected in a following release.

    • Added SchemaInfo structure to UsdSchemaRegistry for each schema type that can be retrieved via the FindSchemaInfo method.
    • Added functions to parse a schema's family and version from its identifier; the family and version are included in each schema's SchemaInfo
    • Added overloads the existing UsdPrim schema type query methods and API schema authoring methods that can take a schema identifier or a schema family and version.
    • Added schema family and version based queries, IsInFamily and HasAPIInFamily, to UsdPrim.
  • Added missing displayGroup and displayName hints for UsdLux properties that have display hints specified in the PRMan args files. Fixed documentation for CylinderLight's inputs:length property.

  • Added "opaque" and "group" attribute types. Opaque attributes have no value but can be connected to other attributes or targeted by relationships. Group attributes are opaque attributes that are intended to provide a connectable/targetable object that represents a property namespace.

  • Minor clean ups to the UsdCollectionMembershipQuery.

  • Support for URL-encoded characters in session layer name. (PR: #2022)

  • Fixed varying primvar size computation in UsdGeomBasisCurves for pinned cubic curves.

  • Made displayName metadata available on UsdPrim as well as UsdProperty, and updated usdview to optionally use displayName in the Prim Browser, when present. Display Names can use the entire UTF-8 glyph set. (PR: #2055)

  • Added UsdMediaAssetPreviewsAPI schema, an applied API for data in the assetInfo["previews"] dictionary on prims. Initially, this allows robust encoding of (asset) default and per-prim thumbnail previews, but may be expanded to other forms of preview in the future.

  • Modified sdffilter, sdfdump, and various tests to use CLI11 instead of boost::program_options. (PR: #2107, #2109, #2110, #2111, #2113)

  • Ported usdtree and usdcat utilities from Python to C++. (PR: #2108, #2090)

  • Fixed various intermittent unit test failures. (PR: #2068)

  • Fixed bug where adding an empty sublayer could cause errors and incorrect results with value clips. (Issue: #2014)

  • Added Python bindings for ArAssetInfo. (Issue: #2065)

  • Fixed crashes related to the dynamic library loader on macOS 12. (Issue: #2102)

  • Fixed issue where incorrect baseline image specifications for unit tests would be silently ignored. (PR: #1856)

  • Fixed UsdUtilsModifyAssetPaths to remove duplicate entries if the modification callback returns such entries, and to remove the original entry if the callback returns an empty asset path. (PR: #1282)

  • Fixed crash when creating VtArray from Python buffer with over 2^31 elements. (PR: #2064)

  • Updated usdchecker to accept references to textures with the ".jpeg" extension. (PR: #1919)

  • Changed UsdShadeCoordSysAPI from a non-applied API schema to multiple-apply API schema. The previous non-applied APIs have been deprecated and will issue a warning when called. Setting the environment variable USD_SHADE_COORD_SYS_IS_MULTI_APPLY to "False" will disable these warnings; setting it to "True" will disable the deprecated functions.

  • Fixed bug where using C++ keywords as token names in schema definitions would cause usdGenSchema to produce uncompilable C++ code. (PR: #2020)

  • Removed deprecated UsdRiTextureAPI schema.

Imaging

  • HdRendererPlugin::IsSupported and HdRendererPluginRegistry::GetDefaultPluginId now take an argument indicating if the GPU is enabled to assist in determining what to return to the caller.

  • Fixed bug where render settings were not being returned by HdSceneIndexAdapterSceneDelegate.

  • Added missing null pointer checks to HdxColorizeSelectionTask. (Issue: #1991)

  • Draw mode: cards will now use UsdPreviewSurface materials, expanding renderer compatibility. The draw mode adapter and scene index have accordingly been relocated from UsdImagingGL to UsdImaging.

  • Fixed a bug that prevented changes to ModelAPI properties from triggering invalidation.

  • Fixed a bug in Storm that prevented certain changes to array-valued primvars from being properly applied.

  • Added a warning when a plugin that duplicates built-in prim-handling functionality is detected. Note that overriding built-in prim-type handlers via plugin is not officially supported. The prior behavior remains unchanged (last-to-load wins).

  • Updated HdCoordSys::GetName() to return coodSys name in accordance with recently updated CoordSysAPI to be multi-applied API.

UsdImaging

  • Updated the precedence order of primvars:ri:attributes:*, which will now take precedence over ri:attributes:*.

  • Added support for OCIO 2.1.1 with native Metal support. (PR: #1936)

  • Updated UsdImagingGL tests to always render to AOVs and to remove most direct use of OpenGL. This improves consistency of test runs across different system configurations and renderer implementations. Also, fixed minor discrepancies in test command arguments and baseline compare metrics to more closely match internal test suite runs.

  • Enabled multisample for Storm AOV image outputs for improved consistency with usdview viewport display.

  • Populated the "system" container with asset resolution data.

  • Fixed UsdImagingBuildHdMaterialNetworkFromTerminal to support multiple input connections.

  • Improved point instancing support of usdImaging when using scene indices. This is implemented through a filtering scene index UsdImagingPiPrototypePropagatingSceneIndex.

  • Added native instancing support of usdImaging when using scene indices. This is implemented through a filtering scene index UsdImagingNiPrototypePropagatingSceneIndex (doing the instance aggregation) and some changes to the UsdImagingStageSceneIndex itself adding USD native instances and prototypes with identifying data sources.

  • Reworked usage of a flattened dependency cache to speed up dependency gathering.

  • Added methods for UsdImaging 2.0 prim adapters to represent descendants in terms of population and invalidation. Implemented property change invalidation for material prims via this mechanism. This change also manages time-varying invalidation by making sure that properties of USD shader prims know the hydra material path and locator.

  • Moved UsdImaging 2.0 primvar handling from gprim to prim and implemented primvar invalidation.

  • Added vector types to dataSourceAttribute.

  • Removed HdContainerDataSource::Has, as it is redundant with GetNames and Get, and doesn't in practice fulfill its original intent of being cheaper to query than Get.

  • Added initial UsdImaging 2 adapter support for GenerativeProcedural.

  • UsdImagingDataSourcePrimvars updated to lazily handle "primvars:" relationships as VtArray data sources.

  • Added UsdImagingStageSceneIndex-specific HdDataSourceLocator convention for triggering resync in response to property invalidation.

  • Added UsdPrim const& argument to UsdImaging 2.0 adapter methods to enable property-driven population and invalidation.

  • Added UsdSkel Dual Quaternion skinning as both a GPU and CPU computation.

  • Fixed a crash in UsdSkelBlendShapeQuery::ComputeFlattenedSubShapeWeights, and added asserts around array bounds violations.

  • Fixed bug where changing an attribute connection would not update primvars in Hydra. (Issue: #2013, PR: #2017)

  • Added CoordSysAPIAdapter to add coordsys support for multi-apply UsdShadeCoordSysAPI instances in UsdImagingStageSceneIndex.

  • Fixed UsdImagingStageSceneIndex functionality for subprims with non-empty names, which were previously tripping an assert in SdfPath.

Storm

  • Added missing instancer handling for volumes.

  • Renamed Hgi function MemoryBarrier to InsertMemoryBarrier to avoid potential build issues on Windows. (PR: #2124)

  • Fixed bug in which dome light prefilter textures were not created for 1x1 input textures.

  • Updated texture system to create samplers for udim and ptex layout textures.

  • Changed handling of invalid or missing textures. When there is no valid texture, bind a 1x1x1 black fallback texture. The value of TEXTURENAME_valid is now always checked before returning the texture value in the shader. Ptex and udim textures now also bind a boolean TEXTURENAME_valid value.

  • Converted mesh.glslfx geometry shader snippets to resource layouts, and introduced HgiShaderFunctionGeometryDesc.

  • Added bindIndex member to HgiShaderFunctionTextureDesc.

  • Introduced shader variables "hd_VertexID", "hd_InstanceID", and "hd_BaseInstance" to use instead of gl_VertexID, gl_InstanceID, and gl_BaseInstance, respectively, with appropriate values determine by the Hgi backend.

  • Various fixes and improvements to HgiVulkan backend, including:

    • Fixed first vertex binding in vkCmdBindVertexBuffers.
    • Added check to avoid destroying null Hgi resources in HgiVulkan::TrashObject.
    • Fixed texture view creation to correctly specify first mip and first layer.
    • Updated VkPhysicalDevicesFeatures to include additional needed features.
    • Enabled Vulkan extension VK_EXT_vertex_attribute_divisor and fixed input rate of per-draw command vertex attributes.
    • Improved shader generation, including proper tracking of location layout qualifiers of shader stage ins and outs and in and out blocks, and binding indices of buffers and textures.
    • Changed handling of binding indices in HgiVulkanResourceBindings to correspond to those used in shadergen.
    • Added handling for shader interpolation qualifiers.
  • Added fix to convert double mesh primvars to floats if doubles are not supported by the Hgi backend. (Issue: #2070)

  • ImageShaderRenderPass now sets a viewport prior to executing a draw.

  • Improved rendering of assets with multiple geom subsets by increasing the size of the drawingCoord topology offset and instancePrimvar offset from 8-bits to 16-bits. (Issue: #1749, PR: #2089)

  • Fixed some potential memory leaks related to HgiMetal resources. (PR: #2085)

  • Added StartFrame/EndFrame to HdxPickTask to improve Hgi resource cleanup. (PR: #2053)

  • Implemented GPU view frustum culling using compute shaders for HdSt_PipelineDrawBatch (Metal and Vulkan) including minor cleanups to HdStCommandBuffer and HdSt_RenderPass. As part of this, added a way to access drawingCoord values from compute shaders. Also, added support for concurrent dispatch of compute command encoders for Metal. (PR: #2053)

  • Updated render pass shader sources to include support for post tessellation control shader stages.

  • Updated basis curves and mesh tessellation shader source to use resource layouts for tessellation shaders. (PR: #2027)

  • Fixed some cases of undefined Osd symbols for Storm when using Osd shader source.

  • Added fix for Dome Light not changing. (PR: #2125)

  • Fixed basis curves index computation and validation. This changes the imaging behavior in that non-periodic curves with a vertex count of 2 or 3 are now rendered instead of being ignored.

  • Fixed cullstyle resolution for a corner case.

Hydra

  • Added a "system" schema. The "system" container is meant to be inherited by prims within a scene index. Scene indices that prefix and re-root have been updated to preserve the "system" container.

  • Fixed small bug for how visibility/purpose is handled.

  • HdInstancedBySchema: added prototype root which is populated by UsdImagingPiPrototypePropagatingSceneIndex and consumed by UsdImagingNiPrototypePropagatingSceneIndex to support interleaved point and native instancing.

  • Removed HdInstanceBySceneIndex in favor of new instancing implementation in UsdImagingPiPrototypePropagatingSceneIndex and UsdImagingNiPrototypePropagatingSceneIndex.

  • HdMergingSceneIndex and HdFlatteningSceneIndex: correct initialization when adding an already populated scene index or constructing from an already populated scene index.

  • Made data flattened by the HdFlatteningSceneIndex configurable.

  • Added initial support of picking for scene indices through HdPrimOriginSchema and HdxPrimOriginInfo.

  • Added initial selection support for scene indices through HdSelectionsSchema and HdSelectionSchema which are picked up by the HdxSelectionTracker.

  • Introduced HdTypedVectorSchema and HdSchemaBasedVectorSchema.

  • Added HdRenderSettings, a Hydra Bprim backing scene description render settings.

  • Added scene index that presents computed primvars as authored ones.

  • Fixed bug in HdExtComputationUtils::_GenerateDependencyMap() with multiple input computations. (PR: #2058)

  • Implemented optional scene index for transfer of primvars from material to bound prims.

  • Added protection against GIL deadlocks within generativeProceduralResolvingSceneIndex.

  • Added support for translation callbacks for custom sprim types within HdDirtyBitsTranslator.

  • For mesh lights, nack-end scene index emulation now checks GetLightParamValue(id, isLight) when considering whether a prim whose type is not a light should be treated as one.

  • Fixed compile and logic bugs in HdRetainedTypedMultisampledDataSource::GetTypedValue.

  • Added source example for a C++ Qt version of Hydra Scene Browser. This is the recommended reference and starting point for integration into applications (aside from usdview).

Renderman Hydra Plugin

  • Added fix to treat invisible faces in the mesh topology as holes.

  • Added scene index plugin to present computed primvars as authored ones.

  • Added hdPrman support for UsdLuxMeshLightAPI, via the meshLightResolvingSceneIndexPlugin.

  • Added support for Renderman Display Filters.

  • Removed deprecated MatfiltFilterChain, and associated envvar HD_PRMAN_USE_SCENE_INDEX_FOR_MATFILT.

usdview

  • Fixed usdview exception when right-clicking for a context menu in the Composition tab.

  • Included Hydra Scene Browser within usdview.

  • Added a function to usdviewApi to get the current renderer.

  • Changed the PluginMenu addItem() function to return the added action, so further customizations (such as making it checkable) can be applied to it.

usdAppUtils

  • UsdAppUtilsFrameRecorder now sleeps between render invocations if the frame has not converged to avoid potentially slowing down the render progress.

usdRecord

  • usdrecord can now be run without requiring a GPU by passing the "--disableGpu" option on the command line (Issue: #1926). Note the following:
    • The GPU is enabled by default.
    • If no renderer is specified, an appropriate default will be chosen depending on whether the GPU is enabled or not.
    • Disabling the GPU will prevent the HdxTaskController from creating any tasks that require it. In particular, this means that color correction is disabled when the GPU is disabled.

MaterialX Plugin

  • Fixed viewport calculation issue with full masking on both Mac and Vulkan MaterialX Plugin.

  • Updated MaterialX Imaging Tests, adding more comparisons between the Native and MaterialX implementations of UsdPreviewSurface materials. Note that these PreviewSurface test cases are commented out by default.

Alembic Plugin

  • HDF5 support for the Alembic plugin is now disabled by default.

Documentation

  • Various documentation fixes and cleanup. (PR: #1995)

  • Updated sphinx documentation pages to use system fonts. (PR: #2084)

  • Added new documentation page showing products using USD. (PR: #2095)

[22.11] - 2022-10-21

Build

  • Updated Azure Pipelines configurations used for CI and PyPI The active configurations are now:

    • Ubuntu 20.04, Python 3.8.10, PySide2 5.15.2.1
    • macOS 11.7, Python 3.10.6, PySide6 6.3.2
    • Windows 10, Visual Studio 2019, Python 3.7.9, PySide2 5.15.2.1
  • Updated PXR_USE_PYTHON_3 to ON to enable USD Python 3 binding by default. We still anticipate dropping support for Python 2 after the first release in 2023.

  • Fixed export of targets for usd monolithic builds (usd_ms). (PR: #2026)

  • Updated USD build to optionally use Imath library by using Imath's cmake config package. USD build falls back to using OpenEXR if Imath is not FOUND. Also updated USD's cmake config, pxrConfig.cmake.in to set Imath_DIR accordingly to set the import targets which were used for the USD build. (PR: #1829)

  • Disable Ptex support by default when using CMake directly.

  • Updated OpenSubdiv version to 3.5.0 to take advantage of build configuration improvements. The USD source remains compatible with OpenSubdiv 3.4.x.

  • Updated dependencies for JPEG, OpenImageIO, and Alembic for macOS to improve compatibility with cross architecture and universal builds.

  • Updated build_usd.py for macOS with additional options to support specifying a build architecture target and enabling code signing: -build-target {native,x86_64,arm64,universal} -codesign

  • Fixed issue where using pxrConfig.cmake from a USD build with MaterialX support enabled would cause linker errors. (Issue: #1955)

USD

  • Updated gathering of geom subset prims to not use UsdPrimDefaultPredicate and instead use a custom predicate that checks if the prim has a defining specifier, rather than is defined, allowing for correct gathering of geom subsets that are children of Prototype prims.

  • Updated ndr parser plugin instantiation to provide a stable ordering for plugin loading.

  • Added ability to UsdAttributeQuery to make queries about an attribute's value that only consider opinions "up to" or "stronger than" a certain edit target or composition arc (via the new UsdResolveTarget object). (Issue: #1483)

  • Fixed a bug with calling UsdAttribute::GetResolveInfo at default time where it could erroneously resolve to specs with time samples.

  • Updated UsdGeomImageable::GetPurposeVisibilityAttr and ComputeEffectiveVisibility to check that UsdGeomVisibilityAPI is applied before querying any purpose visibility attributes.

  • Updated TF_ERROR macros now return void instead of bool like the other diagnostic macros.

  • Updated some of the errors that are reported during prim index composition to be more informative.

  • Added GetTargetLayer and GetTargetPrimPath convenience functions to UsdPrimCompositionQueryArc.

  • Updated UsdPrimCompositionQueryArcs to be validly queried if even after the UsdPrimCompositionQuery that returned them is destroyed.

  • Added UsdGeomBBoxCache::ComputeWorldBoundWithOverrides.

  • Fixed a bug and updated docs for GfFrustum::ComputeNarrowedFrustum.

  • Updated UsdShadeMaterialBindingAPI::UnbindCollectionBinding documentation to explicitly state to use instance name of the targeted collection for unbinding if bindingName was not provided.

  • Documented the use of special use of "@@@" for asset paths containing "@". (Issue: #1832)

  • Created a usdzUtils python module, which provides methods like CreateUsdzPackage, ExtractUsdzPackage and UsdzAssetIterator.

  • Added a script "usdfixbrokenpixarschemas" to update any usda, usdc or usdz asset to respect updated pixar provides schemas. This utility currently fixes MaterialBindingAPI, SkelBindingAPI and authoring of upAxis metadata.

  • Updated UsdUtilsComplianceChecker to check if MaterialBindingAPI is applied on the prim which provides a material:binding. Also updated usdchecker unit tests for the same.

  • Fixed UsdShadeMaterialBindingAPI to return an empty Material if binding relationship is invalid. (PR: #2024)

  • Updated computing bound material core logic to check if MaterialBindingAPI is applied on a prim providing material:binding. Introduced USD_SHADE_MATERIAL_BINDING_API_CHECK environment variable for backward compatibility and default to "warnOnMissingAPI". In a later release the default will be updated to "strict", which will ignore prims which do not have MaterialBindingAPI applied for bound material computation.

  • Updated UsdShadeMaterialBinding::ComputeBoundMaterial logic such that bound material remains consistent irrespective of the load / active state of the target prim on the material:binding relationship.

  • Added UsdShadeMaterialBinding::GetResolvedTargetPathFromBindingRel to help clients get the path of the target of the winning binding from bound material computation.

  • Added support for merging of collision groups in UsdPhysics. (PR: #1947)

  • Updated UsdPhysics documentation to clarify mesh subdivision options which could affect physics colliders. (PR: #1948)

  • Added color4 type to Sdr to allow differentiating between color4 and vector4 input types at Sdr level. (PR: #1894)

  • Added "GetAll" method for multi-apply schemas in codegenTemplates. (PR: #1773, Issue: #1772)

  • Added "renderingColorSpace" to UsdRenderSetting schema. This describes a renderer's working (linear) colorSpace where all renderer/shader math is expected to happen. Renderer is expected to use its own default when renderingColorSpace is not provided.

  • Improved performance in clip manifest generation when no manifest is supplied.

  • Improved performance in pcp prim indexing by using a heap rather than a sorted array to handle tasks in priority order. This improves worst case runtime for task processing from O(n^2 log(n)) to O(n log(n)).

  • Changed pcp prim index graph representation, simultaneously expanding size limitations and reducing memory usage by 5-15% in production sets. Also improving composition time performance, saving 35% on one production example.

  • Improved pcp composition thread scaling by letting indexing and index publishing proceed concurrently.

  • Added node-based API to SdfPathTable so callers can pre-reserve memory locations and insert them into tables later.

  • Added VtVisitValue() utility for operating on held-types of VtValues.

  • Updated pyInterpreter and pyModule to Account for Python GIL explicit initialization deprecation from Python 3.7 to 3.9 (PR: #1909)

  • Updated usddiff logic in an attempt to handle files with bogus extensions by trying the usd file format, and copying the files to temporary extensioned files if necessary.

  • Updated crateFile core to sanity check spec requirements in prefer-safety-over-speed mode. (Issue: #1763)

  • Fixed a bug where TfType::_FindByTypeid() could call FindByName() while still holding the registry lock, resulting in an attempt to recursively require the lock, and a hang.

  • Updated USD changelog to indicate fixed but not-documented-as-such CVE-2020-13495. (Issue: #1966)

  • Fixed usdc files to use read-only mappings in mmap mode to avoid commit charge on most of the file content, only changing page protections to read/write when detaching outstanding zero-copy-array data.

  • Fixed Python 3.11 incompatibility. (PR: #1928)

  • Added "detached layer" feature to Sdf. This allows clients to specify layers to load "detached" from their serialized backing store, isolating them from external changes. In particular, loading .usdc layers as "detached" can help avoid crashes or other issues if another process attempts to overwrite those .usdc layers. (Issue: #1852)

  • Added SdfLayer::DetachedLayerRules and related API for specifying detached layers.

  • Added API to ArAsset, SdfFileFormat and SdfAbstractData to support detached layers.

  • Small optimizations to SdfLayer change processing to avoid unnecessary iteration and copies.

  • Fixed bug where SdfLayer would not strip file format arguments from identifiers before passing them to ArResolver::GetModificationTimestamp when calling SdfLayer::Save.

  • Fixed bug where calling SdfLayer::CreateNew with a file format target would not include the target in the new layer's identifier, causing subsequent lookups via SdfLayer::Find or FindOrOpen with the same arguments to fail.

  • Fixed bug causing errors when deleting a variant set containing only empty variants.

  • Fixed bug where reloading a text-based .usd layer that was overwritten with a crate-based layer would copy the contents of the crate layer into memory instead of streaming data on-demand.

  • Fixed crashes when reading .usda files containing certain strings with escaped quotes. .usda layers with incorrectly escaped/quoted strings (like "fo\"o") will no longer load. (Issue: #1630)

  • Fixed UsdUtilsComputeAllDependencies to remove incorrect coding error if a local reference or payload is encountered. (Issue: #1902)

  • Fixed variety of missing symbol exports and header includes. (Issue: #1942, #1969, PR: #1950)

Imaging

  • Fixed a speculative issue with light invalidation sometimes using dirty bits from the wrong enum. (Issue: #1719)

  • Fixes an issue where material binding paths on geometry subsets were not correctly prefixed, leading to missing materials in certain circumstances. (Issue: #1687)

  • Updated conversion of UsdImagingGLRenderParams to HdxRenderTaskParams to default to 0.1 for alphaThreshold no matter the transparency mode.

  • Added missing initialization of OpenVDB before creating a stream in Hio OpenVDB Utils, preventing crash due to uncaught OpenVDB exception.

  • Implemented GPU Indirect Command Buffer (ICB) encoding of draw commands for Storm on Metal. (PR: #1945)

  • Fixed GPU Skinning computations to not execute GL error checking for Storm on Metal. (PR: #1909)

  • Fixed CPU Frustum culling for Storm on Metal. (PR: #1978)

  • Minor optimization for CPU culling. (PR: #1860, #1956)

  • Fixed highlighting of selected mesh edges when mesh edges are not otherwise being displayed.

  • Extended Hgi interface for buffer and texture bindings to specify which bindings are writable. Non-writable bindings are declared const in shader gen for correctness and potentially improved performance. (PR: #2042)

  • Storm draw buffer entries are now aligned to 32 bytes on Metal for improved performance on newer drivers and correctness on older drivers (PR: #1980)

  • Implemented a workaround for fragment shader barycentrics and primitive id on older Intel GPU drivers for Storm on Metal. (PR: #1980)

  • Refactoring and small performance improvements for the Hydra Scene Index API.

  • Fixes an issue with redundant shader compilation requests as a result of rearranged HdBuffer elements.

  • Updated HdxTaskController to allow for DomeLight textures to use textures other than the shipped default dome light texture. (Issue: #1708)

  • Updated HdSceneIndexAdapterSceneDelegate::GetCameraParamValue to access data sources at nested data source locators. E.g. GetCameraParamValue(cameraId, TfToken("lensDistortion:k1")) accesses the data source at HdDataSourceLocator(TfToken("camera"), TfToken("lensDistortion"), TfToken("k1")).

  • Added geomUtil, a library housing mesh generators for common implicit primitives.

  • Fixed a bug in the computation of the number of vertex and varying primvars for indexed and periodic cubic basis curves.

  • Added support for "pinned" basis curves in Hydra, via a scene index plugin render delegates can use to convert "pinned" to "unpinned" curves.

  • Documented that Hydra only supports 100 tiles for UDIM (Issue: #1846)

  • Fixed performance issue in HdNoticeBatchingSceneIndex::_PrimsDirtied and _PrimsRemoved which was previously fixed only for _PrimsAdded.

  • UpdatedHdRenderIndex to track depth of calls to SceneIndexEmulationNoticeBatchBegin/End to allow for nested batching.

  • Unified behavior of procedural resolving scene index's GetChildPrimPaths to match PrimsAdded's forwarding of existing child prims.

  • Implemented first pass of materialBinding support within HdFlatteningSceneIndex.

  • Added support for prefixing of path array data sources in HdPrefixingSceneIndex.

  • Updated HdMergingSceneIndex to allow inputs to sparsely provide either type or data sources and confirms primType value in forwarded _PrimsAdded notices matches the GetPrim behavior.

  • Added support for delivering multiple renderContext nodeIdentifier values within HdMaterialNodeSchema.

  • Added fallback for HdSceneIndexAdapterSceneDelegate::GetLightParamValue to check against the light terminal node within the "material" data source for better compatibility with legacy render delegates.

  • Fixed a spurious dirty bit getting set on lights on visibility changes, which could theoretically lead to over-invalidation. (Issue: #1719)

  • Fixed rendering issue in colorize selection task in which original contents of render target (the rendered scene) were not properly loaded when rendering and blending the selection color on top.

UsdImaging

  • Deleted UsdImagingGLLegacyEngine, i.e. usdview's "HydraDisabled" renderer. This class was a simple GL3-based USD renderer that was kept as a fallback for hydra, as Hydra Storm GL requires GL 4.5. However, it was missing many foundational USD features (like instancing) and it's main use (on OSX) has been deprecated by the Storm Metal port. This change doesn't affect any of the existing usdview Hydra backends. If Hydra can't find any supported backends (e.g. a variant of Storm, Embree, Prman), usdview will now display an empty viewport.

  • Added an API for UsdImagingDelegate adapters to request a callback to UpdateForTime. Adapters now invoke this API on relevant invalidation, but UsdImagingDelegate doesn't automatically call UpdateForTime on every invalidation. This can be a major performance benefit in some scenes. Custom adapters need to be updated to work correctly; however, you can revert to the old behavior by setting the env var USDIMAGING_LEGACY_UPDATE_FOR_TIME=1.

  • Added a domeLightCameraVisibility render setting that allows turning off the dome light texture rendering while still using the dome light texture for lighting computations. This is respected by both Storm and Prman. (Issue: #1769)

  • Added partial support for point instancer to the scene index implementation.

  • Added UsdImagingDataSourceSchemaBased container data source to reduce boilerplate code when writing usd prim adapters that mostly just pass through Usd attribute values.

  • Fixed a case where UsdImaging would unnecessarily dirty prims from multiple threads. This was breaking the _PrimsDirtied threading contract.

  • Updated LightDataSource to exclude light/lightLink|shadowLink identifiers for trivial collections which include everything within UsdStageSceneIndex.

  • Added light/isLight bool and light/materialSyncMode data sources for identifying presence and behavior of LightAPI on non-light types (i.e. mesh light) within UsdStageSceneIndex.

  • Implemented Hydra 2.0 interfaces on UsdImagingLightAdapter to return UsdImagingDataSourcePrim so that boundable contributions are present.

  • Introduced UsdImagingLightAPIAdapter for UsdImagingStageSceneIndex.

  • Updated UsdImagingDataSourceMaterial to answer for unauthored light param attributes (like intensity) to match expectations of legacy hdStorm render delegate.

  • Updated disk, distant, dome, plugin, rect and sphere light adapters to implement Hydra 2.0 interfaces for defining prim type. This is combined with the LightAPI schema adapter's contributions.

  • Updated UsdImagingGLEngine::Render to release GIL at the top of to avoid deadlocks caused by imaging population code, potentially running plug-ins which indirectly interact with python from multiple threads.

  • Fixed an issue where material binding paths on geometry subsets were not correctly prefixed, leading to missing materials in certain circumstances. Consumers of UsdImagingDelegate::GetMeshTopology() can now expect any geometry subsets present on the topology to express full index paths for their id and materialId properties.

  • Fixed rendering of excluded geometries upon modification of stage in a session layer. (PR: #1949)

  • Improved performance for UsdImagingDelegate::SetTime by pre-caching path dependencies in parallel. (PR: #1815, Issue: #1813)

  • Improved performance of UsdImagingInstanceAdapter::_Populate by using SdfPathSet instead of SdfPathVector for instance paths. (PR: #1823)

  • Updated usdImaging tests to detect differences between visibly distinct reference images by tweaking idiff failure values. (PR: #1866)

Storm

  • Added new TF_DEBUG code HDX_DEBUG_DUMP_SHADOW_TEXTURES allowing users to save the shadow textures produced by HdxShadowTask to image files.

  • Improved handling of oversized buffers in HdStInterleavedMemoryManager and HdBufferArrayRegistry.

  • Added overload of HdInstanceRegistry::GarbageCollect that takes in a callback function to be called when the resource instance is removed, now used to properly destroy Hgi resources in HdStResourceRegistry.

  • Various fixes and improvements to HgiVulkan support.

  • Updated HdxSimpleLightTask to warn about the need to truncate the number of lights when changes are made to the light set, instead of every frame.

Renderman Hydra Plugin

  • Updated minimum RenderMan version required by hdPrman to 24.1 to avoid an issue where left-handed geometry may be shaded incorrectly.

  • Updated HdPrman plugin to respect "vector" role for instance primvars of type VtArray and pass an array of floats to rman.

  • Added support for terminal SdrPropertyType in hdPrman.

  • Updated MatFiltSceneIndexPlugin to allow scene index filters that interact with materials to have access to terminal names in a renderer agnostic way by executing HdSiTerminalsResolvingSceneIndex earlier in the scene index stack.

  • Added support for lens distortion. HdPrmanCamera::Sync reads the lens distortion parameters, setting up the projection shader with the correct fov and screen window. In order to render lens distortion, we aim to switch to the PxrCamera projection shader in a later release (requiring RenderMan 25).

  • Updated the default of HD_PRMAN_USE_SCENE_INDEX_FOR_MATFILT to true for better inspectability.

  • Added support to respect the doubleSided parameter on USD meshes with UsdPreviewSurface materials applied to them. Also added support for cullStyle, enabling, e.g., GL-like backface culling.

  • Updated UsdPreviewSurface OSL shader to improve appearance of transparency when opacityThreshold is zero.

  • Added gridGroup support to hdPrman for VDB grids. For now all grids provided in the VDB are included.

usdview

  • Updated usdview's Bounding box dashed lines drawing to use Hgi interface instead of glLineStipple.

  • Moved the "View" menu in usdview into the Viewer panel as a reorganized set of new menus.

  • Added the ability to save a screengrab from the Viewer of current frame in usdview.

  • Added the guides column in the usdview Prim View to choose which cameras to show oracles on.

  • Fixed (on posix platforms only) an issue where the usdview state file could be corrupted when closing multiple instances of usdview simultaneously.

  • Added ability to specify detached layers in usdview using the --detachLayers, --detachLayersInclude, and --detachLayersExclude arguments. (Issue: #1852)

  • Update usdview's layer stack view to be more informative of the effect of cumulative layer offsets on each sublayer, including the auto-scaling that occurs between layers with differing time codes per second. (Issue: #1782)

  • Fixed a bug in usdview where the property view would break when displaying an array valued attribute whose resolved value is an unsupported or non-array type.

MaterialX Plugin

  • Added support for locally defined custom nodes, and custom nodes that use textures/texture coordinates (Issue: #1636)

  • Added support for MaterialX materials that use nodes outside nodegraphs and nodegraph input/interface connections (Issue: #1636)

  • Added support for Custom Material Nodes that use textures. (Issue: #1786)

  • Added MaterialX tests to UsdImagingGL.

  • Added initial material caching for simple MaterialX Materials in Storm.

  • Updated HdStMaterialXShaderGen to use default geomprop/primvar value. (Issue: #1880)

Alembic Plugin

  • Fixed Alembic plugin to not collapse Alembic geometries into their transform parents if the parent has multiple children. (PR: #1940)

[22.08] - 2022-07-21

Support for Python 2 is sunsetted as of this release. We anticipate dropping support after the first release in 2023, tentatively scheduled for January.

Build

  • Updated dependencies to align with VFX Reference Platform CY2020, with some exceptions to work around various build issues on different platforms.

  • Added support for native builds on Apple Silicon. It is possible to cross compile for Intel systems by building within an x86_64 architecture environment, for example, by creating an x86_64 shell via "arch -x86_64 zsh" and then running the build within that shell. (PR: #1875)

  • Added support for PySide6. By default, the build will search first for PySide6 then PySide2 then PySide. Users may specify the following CMake variables to influence this search behavior:

    • PYSIDE_USE_PYSIDE2=TRUE to force the use of PySide2 or
    • PYSIDE_USE_PYSIDE=TRUE to force the use of PySide (PR: #1898)
  • Support for PySide is deprecated and will be removed in a future release.

  • Changes and fixes for build_usd.py:

    • Removed special handling when being run from Maya's Python.
    • Fixed detection of Python library and include directories when run with a virtualenv-based Python. (PR: #1692)
    • Fixed detection of Python libraries with ABI tags. (Issue: #1724)
  • Fixed build errors on Windows with OpenVDB v7.0.0+.

  • Monolithic builds no longer add the "usd_" prefix to library names by default.

  • Cleanup for miscellaneous build errors and compiler warnings. (Issue: #806, PR: #1696)

  • Unit tests will now extract files that fail baseline comparisons to ${CMAKE_BINARY_DIR}/Testing/Failed-Diffs/${TEST_NAME} (PR: #1839)

USD

  • Automatically disable glibc malloc hooks support on glibc versions >= 2.34.

  • Removed support for Ar 1.0, which was deprecated in v21.11.

  • Added ability to disable Ndr plugins via the PXR_NDR_DISABLE_PLUGINS env var.

  • Added NdrRegistry::AppendDiscoveryResult to allow clients to explicitly set additional discovery results that would not be found through the plugin system. (PR: #1810)

  • Reverted collaborative layer loading feature while investigating intermittent crashes.

  • Fixed bug where authoring opinions at certain sites for prims using inherits and/or specializes arcs would not trigger change processing and notifications.

  • Fixed bug with the composition of reference/payload list ops across sublayers with different time codes per second or layer offsets. (Issue: #1778)

  • Added the apiSchemaOverride feature to usdGenSchema that allows a schema definition to explicitly define sparse overrides to properties it expects to be included from a built-in API schema. See: https://graphics.pixar.com/usd/release/api/_usd__page__generating_schemas.html#Usd_APISchemaPropertyOverride

  • Updated usdgenschemafromsdr to read Sdr node paths with environment variables.

  • Fixed UsdUtilsUpdateSchemaFromSdrNode:

    • Non connectable nodes do not get any connectivity assigned.
    • Fixed pruning of properties when only typedSchemaForAttrPruning is set.
  • Fixed issue where UsdInherits::GetAllDirectInherits might not have returned all direct inherit paths and might have returned paths that were not actually inherits.

  • Fixed issue with removing references in sublayers with differing time codes per second. (Issue: #1778)

  • UsdAttribute::GetTimeSamplesInInterval will no longer open value clips outside the requested interval when interpolateMissingClipValues is disabled.

  • Improved memory allocation for value clips by using a shared pointer to the array of time mapping in Usd_Clips. (Issue: #1774, PR: #1777)

  • Improved performance of interpolating attribute time samples. (PR: #1883)

  • Improved UsdStage loading/repopulation performance and thread scalability.

  • Improved .usdc write performance for integer arrays.

  • Fixed UsdGeomImageable::ComputeProxyPrim to implement non-pruning semantics when computing the purpose value for the targeted prim.

  • Removed Primvar API on UsdGeomImageable which was deprecated in v19.03. All remaining uses of this API have been updated to use UsdGeomPrimvarsAPI.

  • Added UsdGeomPlane schema. (Issue: #772, PR: #1819)

  • Cleaned UsdShadeConnectableAPIBehavior code to not throw warnings when querying for incompatible prim type, which has no plugin registered.

  • Updated OSL and Args parsers to use Sdr's nested page delimiter of ":", instead of ".". Updated documentation for the same in UsdShadeInput and SdrShaderProperty.

  • Updated usdRiPxr schemas to reflect updates to RenderMan args files and to include other schema classes:

    • Added schemas for all RenderMan plugins/concepts, plus Options, Attributes, and Primvars.
    • Added RenderMan default plugins schema classes and display drivers schema classes.
    • Updated previously generated schemas to use ":" as the nested page delimiter in display groups.
    • A few vector3 attribute types were updated to use sdrUsdDefinitionType="float3", to provide appropriate SdfValueTypeName in the generated schema.
  • Added UsdRenderPass and UsdRenderDenoisePass schemas to UsdRender.

  • Added UsdProc schema domain for representing procedural data and an initial concrete UsdProcGenerativeProcedural schema.

  • Added UsdHydraGenerativeProceduralAPI to the now-repurposed usdHydra schema domain.

  • Miscellaneous small fixes. (PR: #1775, PR: #1842, PR: #1845, PR: #1850)

Imaging

  • Fixed crash in GlfSimpleShadowArray::GetShadowMapTexture, avoiding discrepancy between the lighting context/light data and the simple shadow array data.

  • Added HdChangeTracker::GetInstanceIndicesChangeCount to detect changes to instance indexing. (PR: #1754)

  • Fixed bug in HdRenderIndex::RemoveSceneIndex where a client removes a scene index that was added with a non-trivial scene path prefix.

  • Fixed double-creation of Bprims when using scene index emulation. (PR: #1737)

  • Various fixes to primvar sampling in scene index emulation and the usdImaging stage scene index.

  • Fixed inconsistencies for clipping planes to work with scene index emulation.

  • HdPrimvarSchema role tokens: changing capitalization for consistency with how these are used elsewhere in Hydra.

  • GLSLFX shaders can now consume int- and int-array valued primvars.

  • Fixed codegen of HdGetScalar_* for GLSL bindings to primvars. (Issue: #1862, PR: #1863)

  • Exposed secondary selection highlight color as a settable value on HdxTaskController. (PR: #1771)

  • Added HdGp library for Hydra procedurals which have read access to the input scene and can generate (or update) prims beneath a given prim. HdGpGenerativeProcedural subclasses may be provided by plugins and are resolved/evaluated/updated via an HdGpGenerativeProceduralResolvingSceneIndex.

    HdGp procedurals are disabled by default but may be enabled by setting the HDGP_INCLUDE_DEFAULT_RESOLVER environment variable to 1.

  • Added support for "includeDisconnectedNodes" within material network data source to trigger legacy behavior for renderers which rely on Hydra 1.0 behavior.

  • Fixed HdMergingSceneIndex::GetChildPrimPaths to incorporate ancestor paths of inputs with specified root paths.

UsdImaging

  • Added basic edit processing support for the USD scene index.

  • Added basic support for SampleFilters in RenderSettings in UsdImaging scene delegate and HdPrman render delegate.

  • Added hdSi library to support implicit shapes in UsdImagingStageSceneIndex.

  • Added usdProcImaging library for imaging UsdProcGenerativeProcedural prims.

  • Added initial support for API schema adapters in UsdImagingStageSceneIndex, along with an adapter for UsdShadeMaterialBindingAPI (direct bindings only).

  • Implemented Hydra 2.0 methods on UsdImagingMaterialAdapter.

  • Added API for accessing AOV render buffers to UsdImagingGLEngine.

  • Removed remaining direct uses of OpenGL from UsdImagingGLEngine.

  • Deprecated UsdImaging_GetUdimTiles.

  • Fixed "model:drawMode" evaluation to apply to components without "GeomModelAPI" applied.

  • Updated UsdImagingCameraAdapter::TrackVariability to consider all attributes on the camera prim. (PR: #1797)

  • Improved performance when handling large number of native instances. (Issue: #1740, PR: #1822, PR: #1932)

  • Fixed light collection change-tracking. (PR: #1653, PR: #1930)

  • Fixed bug where coordSys Sprims were not dirtied on transform changes on the target prim.

  • Updated UsdImagingPointInstancerAdapter to register velocity and acceleration primvars. (PR: #1849)

  • Fixed bug where changes to materials bound to geom subsets were not processed. (Issue: #1837, PR: #1838)

  • Fixed UsdImagingPrimAdapter computation of dirty bits for primvars. (PR: #1807)

  • Fixed thresholds for testUsdImagingGLPurpose to be more accurate. (PR: #1827)

Storm

  • Added a render setting for the maximum number of lights to support in Storm. This should be used with caution, as Storm hasn't been optimized for large numbers of lights.

  • Added API export tags to HdStTextureIdentifier. (Issue: #1758)

  • Improved HgiGraphicsCmds interface for binding vertex buffers. (PR: #1876)

  • Stopped adding fallback/unconnected material param names to the list of a HdSt_MaterialNetworkShader's primvars.

  • Changes and fixes for hgiVulkan backend:

    • Updated some missing HgiVulkanCapabilities and desired Vulkan extensions.
    • Fixed unsafe use of pointers to objects in temporary scopes. (Issue: #1911)
  • Fix crash when mesh prim has authored points and faceVertexCounts but not faceVertexIndices.

  • Transform two channel (grayscale + alpha) PNG images into RGBA format. (Issue: #1796)

  • Storm volumes: making material final to avoid the volume shader being replaced by the default material network that does not work for volumes.

  • Updated HdSt_DrawBatch::Prepare() to take a HgiGraphicsCmds instance to allow combined submission of GPU work.

  • Improved organization of internal methods in HdSt_PipelineDrawBatch and HgiMetalGraphicsCommands and HgiGraphicsPipeline. (PR: #1859)

  • Fixed inconsistent naming of HgiDeviceCapabilitiesBitsBasePrimitiveOffset. (PR: #1858)

  • Removed redundant shader resource layout declarations from Storm shader source.

RenderMan Hydra Plugin

  • Added various implicit shapes support by using native Riley prims and the implicit surface scene index.

  • Added support for SdfAssetPath-valued shader parameters.

  • Added support for RenderSettings and Murk Sample Filter prims, with the ability to have multiple Sample Filters. These prims are supported with and without scene index emulation.

  • Added support for MaterialX displacements and improved editing of displacements.

  • Various improvements to MaterialX support.

  • Improved diagnostic messages for materials with empty/wrongly typed material resources.

  • Updated to look for material properties in the "primvars:ri:attributes" namespace. "ri:attributes:" is still supported for backwards compatibility.

  • Fixed support for sharpness per crease edge with subdivs.

  • Fixed "depth" AOV to return [0,1] instead of [-1,1], for consistency with Storm and the expectations of Hdx compositing code.

usdview

  • Added --mute command line option for muting layers prior to initial stage load.

  • Improved muted layer support in the Layer Stack tab (previously muted layers were not listed) and added context menu support to interactively mute/unmute layers from the UI.

  • Fixed Interpreter window to respect OS hover-focus/click-focus settings.

  • Fixed Python 3 warning in usdview about not properly closing a file. (PR: #1861)

  • Fixed an error in usdview when framing with the root prim selected. (Issue: #1619, PR: #1843)

MaterialX Plugin

  • Added support for MaterialX v1.38.3+ and removed support for older versions. (PR: #1792)

  • Added support for usdBakeMaterialX baking script on Windows.

  • Updated default texture node wrap values for MaterialX texture nodes. (Issue: #1793)

  • Fixed MaterialX shading without a Dome Light. (Issue: #1877)

[22.05b] - 2022-06-14

Build

  • Fixed broken URL in build_usd.py for downloading libtiff. (Issue: #1901)

[22.05a] - 2022-05-11

USD

  • Fixed a race condition that could lead to crashes during scene changes.

[22.05] - 2022-04-22

This release enables Storm for macOS using Metal. Refer to notes under Storm for details. Many thanks to our collaborators at Apple for all of their work to make this happen!

Build

  • Fixed compilation issue on GCC11. (Issue: #1721, PR: #1776)

  • Deprecated support for Visual Studio 2015. Visual Studio 2017 will be the minimum supported version as of the next release.

  • Builds with Python enabled or disabled are now ABI-compatible. (PR: #1729)

  • Made 10.15.7 as the minimum macOS requirement (with compatible Xcode version being 12.4) we test against. Minimum CMake requirement for macOS has also been updated to 3.18.6.

  • On Apple Silicon systems, it is required to use an x86_64 architecture environment (e.g. "arch -x86_64 zsh") to build and execute binaries.

  • Updated build_usd.py to use OpenSubdiv 3.4.4.

USD

  • Added support for sdrUsdDefinitionType in UsdShadeShaderDef.

  • Removed SDR_DEFAULT_VALUE_AS_SDF_DEFAULT_VALUE environment variable, SdrShaderProperty::GetDefaultValue and SdrShaderProperty::GetDefaultValueAsSdfType will provide default values appropriately.

  • Added disableMotionBlur in favor of deprecated instantaneousShutter in UsdRender, to be more compliant of standard behavior of using only one sample at the current frame when motion blur is disabled.

  • Deprecated motion:velocityScale in UsdGeomMotionAPI in favor of more general motion:blurScale. Also deprecated usage of velocityScale in UsdGeomPointInstancer and UsdGeomPointBased. Refer to motion:blurScale documentation for more details.

  • Added GetMaterialPurposes() API to UsdShadeMaterialBindingAPI.

  • Improved performance and correctness of TfDictionaryLess.

  • Fixed performance regression due to thrashing of Sdf object identities.

  • Numerous performance improvements in UsdPrim's property names computation.

  • Changes for usdGenSchema:

    • Disabled inheritance for multiple apply API schemas, now that built-in API schemas are supported for multiple apply schemas.
    • Fixed issue where schema tokens with invalid C++ identifiers would be generated. These tokens will now be converted into a valid identifier. Tokens beginning with a numeral are now prefixed with '_'.
    • Added ability to generate C++ identifiers using property names and values exactly as authored in schema.usda instead of camel-casing them by specifying useLiteralIdentifier in the GLOBAL schema metadata. This is helpful in scenarios where schema.usda is generated using utilities like usdgenschemafromsdr instead of being hand authored.
    • Fixed Python 3 compatibility by explicitly included the None keyword in reserved list.
  • Added error handling for corrupt .usdc files where VtValues claimed to contain themselves.

  • Fixed inconsistent behavior of UsdShadeConnectableAPI::HasConnectableAPI between Python and C++.

  • Fixed UsdShadeConnectableAPIBehavior registry that caused it to miss builtin API schemas when querying for connectability. This caused incorrect result when querying for HasConnectableAPI on just the prim types.

  • Numerous fixes and improvements for Python 3 compatibility.

  • Instance proxies can now be used to author opinions to non-local edit targets.

  • Added NdrFsHelperDiscoverFiles function to NdrDiscoveryPlugin which returns a list of raw and resolved URIs to the files found by walking the directory. This is similar to NdrFsHelperDiscoverNodes which returns a list of full discovery results.

  • Updated UsdUtilsUpdateSchemaWithSdrNode to process nodes which do not exhibit UsdShade connectability. This is used to incorporate rman concepts like Options, etc, not connectable sdr nodes in the usdRiPxr schemas.

  • Updated NdrFsHelperDiscoverNodes API to include a parameter to optionally parse a shader identifier into its name, family and version.

  • Added an optional parameter to specify the tolerance for UsdSkelNormalizeWeights. (PR: #1667)

  • Deprecated UsdLuxListAPI in favor of new UsdLuxLightListAPI.

  • Added plugin mechanism for registering variantSets for UsdUtilsGetRegisteredVariantSets.

  • Fixed a critical bug with UsdPhysics Mass computation. (PR: #1799)

  • Restored fix for symlink reading on Windows. (PR: #1804)

  • Added UsdGeomBoundable::ComputeExtent API to sit alongside UsdGeomBoundable::ComputeExtentFromPlugins. This returns the extent on a boundable if one is explicitly authored, else it computes using the registered ComputeExtentFunction. Its recommended to use this API over extent getters, which might incorrectly return schema fallback extent.

  • Added nonlinearSampleCount attribute to UsdGeomMotionAPI.

MaterialX Plugin

  • Make UsdMtlx plugin a library, moved to /usd/usdMtlx

  • Added support for multi-output MaterialX nodes. (Issue: #1581

  • Added support for MaterialX namespaces declared in stdLibs (PR: #1631)

  • Fixed MaterialX boolean inputs. (Issue: #1784, PR: #1789)

  • Added support for using texcoord MaterialX node type for texture coordinates. (Issue: #1636

  • Updated documentation to mention current known limitation of the MaterialX plugin. (Issue: #1636

  • Added a UsdBakeMaterialX script to bake MaterialX materials, via MaterialX::TextureBaker. Note this does not work on windows yet, and skips volume materials.

  • Improved discovery of MaterialX vector3 inputs (PR: #1790)

Alembic Plugin

  • Pruned redundant "vals" namespace from the primvars namespace when reading array primvars from alembic. (PR: #1635)

Imaging

  • Added HdNoticeBatchingSceneIndex and methods to begin and end batching of notices for legacy scene delegates.

  • Adjusted HdRenderIndex::RemoveSprim() to not remove hierarchical descendents when scene index emulation is enabled.

  • Added HdSceneDelegate::GetScenePrimPaths(), a vectorized version of GetScenePrimPath(). Note that with this change, GetScenePrimPath() is deprecated; use GetScenePrimPaths() instead. (PR: #1744)

UsdImaging

  • Added tests for usdImagingGL and testusdview. These are enabled on Linux but are currently disabled on macOS and Windows, while we investigate these further. (PR: #1743)

  • Support shapes with blendshapes but no skinning when using CPU computations (PR: #1757)

  • Fixed UDIM path resolving when no "1001" file exists (PR: #1787)

  • Made usdImaging stricter about only reading "model:drawMode" attributes from prims with UsdGeomModelAPI applied.

  • Added early support to UsdImagingEngine (and consequently usdview) for loading USD stages into hydra with scene indices instead of scene delegates. This is gated on an environment variable and is disabled by default.

  • Added USD scene index support for cameras and volumes.

Storm

  • Enabled Storm for macOS using Metal. This is the first release with this feature enabled and there are currently the following limitations:

    • Disabled for macOS releases before 10.15 (Catalina) since Metal Shading Language 2.2 is required.
    • Disabled for systems using integrated Intel GPUs which do not yet support fragment shader barycentric coordinates.
    • Curves primitives are always drawn as linear segments and do not refine when complexity is changed.
    • Mesh primitives do support subdivision refinement but do not support adaptive tessellation.
    • Frustum culling is enabled but only executes on the CPU, GPU frustum culling is disabled.
    • MaterialX materials are not yet supported.
  • Introduced several aspects to take advantage of full performance on Metal:

    • Post Tessellation Vertex Shaders (PTVS) used when executing displacement shader terminals.
    • Vertex buffer step function used to support plumbing of drawing coordinate attributes.
    • Argument buffers used for buffer and texture binding.
    • Support parallel encoding of render command buffers.
  • Significant additions to the Hgi API and to the HgiMetal and HgiGL implementations. The Hgi API is still under development, recent additions include:

    • Extended shader parameter descriptor to include specification of interpolation qualifiers, arraySize, and binding location.
    • Improved the distinction between UBO and SSBO bindings as needed for GL.
    • Added support for GLSL style interstage interface blocks.
    • Added a way to enable early_fragment_tests.
    • Added support for conservative rasterization for HgiGL
    • Added support for additional clipping distances.
    • Added support for declaring and accessing arrays of textures (and texture arrays).
    • Added support to distinguish between [0,1] and [-1,1] depth ranges.
    • Added a BlitCmd to fill the contents of a GPU buffer.
    • Additional enumeration of GPU capabilities.
    • Improved consistency of naming for the input arguments to drawing commands.
  • Added support for building against OCIO v2.0 with backup compatibility for OCIO v1.x.

  • Fixed domeLight computations and skyDome viewport rendering for Metal including fixing the alpha value written by the skyDome (Issue: #1656)

  • Fixed management of framebuffer objects in HgiGL for applications with multiple GL contexts.

  • Added support for "widget" styled drawing in Storm.

  • Added a display style flag "materialIsFinal" to let geometry (such as widgets) opt out of material overrides.

  • Added ImageToWorldMatrix to renderPassState and GetPositionInWorldSpace() GLSL helper for fragment shaders.

  • Updated Storm runtime shader code generation significantly to support declaration of shader resources (textures, buffers, etc.) using Hgi.

  • Shader code generation continues to support native GLSL declaration of shader resources, the new method of using Hgi for this purpose is guarded by the env setting HDST_ENABLE_HGI_RESOURCE_GENERATION which is enabled by default only for Metal.

  • Enabled declaration of resources (textures, buffers, interstage interface blocks, etc.) as GLSLFX layouts for Storm's internal shader source files.

  • Use the appropriate GLSL (for OpenGL) or MSL (for Metal) shader mixins from OpenSubdiv.

  • Updated shader source files and generated shader code to use Hgi abstractions for accessing packed types, buffers, textures, atomic operators,

  • Updated previewSurface.glslfx and simpleLighting.glslfx to use newly added HdTextureLod_name() (consistent sampler access to specific mipmap levels) and HdGetScalar_name() (single component, scalar value access of a parameter without needing to guard against component swizzle of scalar data types) accessors where necessary for compatibility with GLSL and MSL. Also updated lighting shaders to use HdGet_name() for sampling shadow textures and arrays of shadow textures.

  • Shader programs compiled directly from Hgi (i.e. not going through Storm codegen) now access textures using HgiGet_name() accessors, HdGet_name() and similar accessors are provided by Storm codegen.

  • Generated shader source now has organizational comments to indicate which aspect of shader generation provided the following lines of shader source code.

  • Enabled HdSt_PipelineDrawBatch for Metal, and deleted HdSt_ImmediateDrawBatch. The existing env setting which enabled use of MDI drawing command buffers has been repurposed to just control whether the CPU or GPU iterates over the command buffer when executing drawing.

  • Fixed HdStTextureUtils::HgiTextureReadback() to support readback into aligned allocated buffers.

  • Added guards to allow volume primitive shaders to run when double precision values are not supported by the shader runtime.

  • Improved calculation of the size of OIT buffers in shaders for compatibility with Metal.

  • Added an error message when a scene is rendered with more than 16 lights. Changed the light selection to grab the first 16 lights, prioritizing dome and simple lights (which tend to be used as camera lights). Filtered out zero-intensity lights before light selection.

RenderMan Hydra Plugin

  • Removed use of __lightFilterParentShader as this is obsolete since R22, which was generating unknown or mismatched input parameter errors.

  • Changed light filter coordinate system name to be the full light filter path as opposed to the leaf name. Since light filters affecting a light are expressed via relationship, only the full path guarantees uniqueness.

  • Added support for light filter combineMode.

  • Updated the MaterialNetwork conversion function to return an HdMaterialNetwork2 for a given HdMaterialNetworkMap, instead of using an out param. Doing so avoids potential issues if the caller passes in an existing HdMaterialNetwork2, in which case we would get an inaccurate final material network.

  • Fixed a hang in StopRender() when blocking = true. Fixed HdPrmanRenderDelegate::IsStopped (and the Stop return value), which were previously erroneously always returning true for offline mode, and always returning false for interactive mode.

  • Disabled MaterialX scene index plugin when MaterialX support is not enabled.

  • Added scene index plugins for material filtering functionality.

  • Improved hdPrman's motion blur support by adding blur scale and velocity and acceleration motion blur implemented through a new scene index. The instantaneousShutter setting has been deprecated in favor of disableMotionBlur.

  • Fixed a bug where toggling visibility of individual instances would lead to a crash.

  • Fixed an issue that was not correctly updating riley visibility on changing rprim tags.

  • Updated hdPrman display driver to correctly normalize render outputs based on accumulation rule and type.

  • Updated usdRiPxr schemas to reflect updates to renderman args files.

usdview

  • Fixed crash bugs when running usdview on macOS systems where Storm is not enabled. (Issue: #1780)

  • Deprecated UsdImagingGLLegacyEngine, i.e. "HydraDisabled". This renderer doesn't support most USD features, and will be removed in the next release.

  • Deprecated UsdImagingGLEngine::_GetDelegate. This API will be removed in the next release.

[22.03] - 2022-02-18

Build

  • boost::program_options is now required only if PXR_BUILD_USD_TOOLS or PXR_BUILD_TESTS is enabled. (PR: #1649, #1703)

  • Workaround issues with UTF-8 filenames when extracting boost in build_usd.py. (PR: #1694)

  • The source .rst files for documentation on https://openusd.org are now part of the repository under the docs/ subdirectory.

  • Fixed warnings emitted when building with "-Wformat-security" and enabled this flag by default for gcc/clang builds. (Issue: #1675)

  • Fixed build failures with hioOpenVDB on Windows.

  • Fixed build failures with precompiled headers disabled on Windows. (PR: #1672)

  • Fixed error when importing modules from the usd-core PyPI package in Conda environments on Windows. (Issue: #1602, PR: #1642)

USD

  • Additions to simplify porting client code to Python 3:

    • Support for "future division" in Python 2 to Vt.Array and Sdf.TimeCode.
    • Support for Unicode strings in Tf.Type and Tf.Type.FindByName.
  • Fixed handling of file paths from mounted volumes on Windows. (Issue: #1520, PR: #1746)

  • Improved accuracy of timing performed by Trace and TfStopwatch.

  • Changes to Ndr and Sdr:

    • Improved performance of lookups by identifier and source type.
    • Removed aliasing functionality.
    • Switched environment variable SDR_DEFAULT_VALUE_AS_SDF_DEFAULT_VALUE off by default.
  • Fixed bug where certain combinations of specializes and inherit arcs on a prim could lead to errors or incorrect strength ordering.

  • Fixed regression where SdfSpec::IsInert would mark empty variant and variant set specs as not inert. (Issue: #1652)

  • Changes for applied API schemas:

    • Multiple-apply API schemas can now include other multiple-apply API schemas as built-ins.
    • "prepend apiSchemas" must be used in schema.usda to set built-in API schemas on another schema.
    • Applied API schemas authored on a prim can no longer change the type of a property defined by that prim's type or built-in API schemas.
  • Fixed uninitialized fields in UsdZipFile. (Issue: #1579, PR: #1578)

  • Cache .usdz archive traversal to improve performance for reading archives with many files and references. In one example, a .usdz file that previously took ~3 minutes to load improved to ~16 seconds with this change. (Issue: #1577, PR: #1578)

  • Numerous changes to improve performance of various operations, including reading .usda and .usdc files and initializing the schema registry.

  • Fixed bug where UsdUtilsComputeAllDependencies would inadvertently try to edit the given layer.

  • Fixed UsdUtilsUpdateSchemaWithSdrNode to emit "allowedTokens" for token-valued attributes based on the Sdr node's options.

  • Various documentation fixes. (Issue: #1370)

  • Fixed crash in UsdGeomCamera::SetFromCamera when the current edit target specifies a weaker layer than the layer defining xformOpList. (PR: #1661)

  • Added "guideRadius" attribute to UsdLuxDomeLight.

  • Removed UsdRenderSettingsAPI.

  • Changes to connectability in UsdShade:

    • Typeless prims can now be queried for connectability.
    • Multiple-apply schemas are now ignored when determining connectability. This previously would result in an error.
  • UsdShadeShaderDef now treats an attribute's "allowedTokens" as options if no other "options" metadata has been specified in "sdrMetadata".

  • Added support for skinning normals with faceVarying interpolation in UsdSkel. (PR: #1695)

  • Added UsdPhysicsRigidBodyAPI::ComputeMassProperties for computing the mass properties of the rigid body. (PR: #1677)

  • Changed UsdVolFieldBase to be an Xformable instead of a Boundable.

Draco Plugin

  • Fix compile error when building with Draco library that has disabled deduplication features. (Issue: #1671)

MaterialX Plugin

  • Fixed issue with NodeDef discovery. (Issue: #1629, PR: #1641)

  • Fixed issue with computing a shader name for Sdr from the NodeDef. (PR: #1641)

  • Allow runtime adjustment of MaterialX search paths. (Issue: #1586, PR: #1628)

Imaging

  • Added HdMaterialNetworkInterface to let material processing operators abstract away data representation.

  • Added API to merge application-provided scene indices with the Hydra emulation scene index.

  • Added API to HdRenderDelegate to query pause and stop state.

  • Augmented HdRenderDelegate::Stop to allow requests for blocking or non-blocking stop.

  • For HdxTaskController users with non-Storm renderers, replaced the fallback sphere light with a distant light.

  • Changed default dome light texture format from .exr to .hdr. (Issue: #1481)

  • Added HdSceneIndexPluginRegistry and HdSceneIndexPlugin, to allow for external registration of filtering scene indices to be added for specified renderers.

  • Improved HdMeshUtil Patch Param documentation. (Issue: #1720)

  • Cache "renderTag" attribute in Hydra instead of pulling it at every use.

UsdImaging

  • Fixed instancing-related edit processing bugs: when prims are added to or removed from USD prototype roots; or when invalidations propagate from non-instanced prims to instanced prims.

  • Fixed drawing of "unloaded-prim-as-bounds" when the unloaded prim is an instance.

  • Improved performance of UsdImagingDelegate::PopulateSelection. (Issue: #1689, PR: #1691)

  • Added UsdImagingStageSceneIndex, a scene-index native reader of Usd stages. Feature support is very limited as this is under development.

  • Fixed a bug where disabling scene materials would also disable lights when lights were using material network representation.

Storm

  • Filled out Hgi interface for Storm rendering needs

    • Added a capability bit for double-precision support in shaders.
    • Added fields to sampler parameter, graphics pipeline, and attachment state.
    • Added HgiVertexBufferStepFunction, to support Hgi multidraw calls.
    • Started adding Hgi API support for tessellation shaders and post-tessellation vertex shaders.
    • Added support for Hgi compute pipelines to specify workgroup size.
  • Refactored Storm to use Hgi for graphics API access

    • Augmented HdRenderPassState with further pipeline flags: conservative rasterization, depth clamp, depth range.
    • Added the Hgi-based PipelineDrawBatch, which is expected to deprecate the GL-specific Immediate- and IndirectDrawBatch classes. PipelineDrawBatch is currently disabled behind a config flag for main render and image shader use.
    • Extended HdSt_TextureBinder, HdSt_ResourceBinder, and HdSt_RenderPassState to let them use Hgi instead of direct GL calls.
    • Ported HdxShadowTask shadow rendering to use hydra-managed shadow textures, rather than GlfSimpleShadowArray.
    • Ported HdxSimpleLightTask to pass in lighting data through the HdSt buffer management system, instead of using out-of-band GL uniform blocks. Note that as part of this change, there's a new shader API for accessing lighting data.
    • Added the "triangulated quad" primitive type, which draws quad geometry as triangles. This is expected to deprecate the current quad rendering with adjacency lists, although the latter is supported in HgiGL at the moment.
    • Added support for built-in barycentric coordinates, based on NV_fragment_shader_barycentric in GL.
    • Removed geometry shader dependency from many rendering configurations: edge rendering & picking, patch coordinate evaluation, face-varying evaluation (only available in GL if barycentric coordinates are available).
    • Fixed codegen and shader snippet cross-compilation issues.
  • Improved support for MaterialX imaging in Storm:

    • Moved MaterialX parameters out of generated shadercode and into parameter buffers to support faster updates.
    • Added support for reading from non-bindless textures. (PR: #1634)
    • Added selection highlighting for MaterialX shaders. (PR: #1647)
    • Fixed duplicate name error when processing network nodes. (PR: #1659)
    • Added shadow support to MaterialX shaders. (PR: #1680)
  • Fixed typo in HgiVulkan backend. (Issue: #1702)

  • Extended GLSLFX file format to support resource layout configuration metadata.

  • Added shader support for binding arrays of UV textures (as distinct from TEXTURE_2D_ARRAY). Switched shadowmap binding to use arrays of textures, and removed bindless shadow texture code.

  • Added basis curve builtin primvars: screenSpaceWidths (boolean), for rendering UI elements, and minScreenSpaceWidth, for reducing aliasing of thin curves. Note that these haven't been formalized in USD.

  • Changed meshes with a present but invalid normals primvar to draw with shader-generated normals.

  • Added support for bool array primvar data.

  • Added support for widget rendering via the "widget" rendertag and surfaceShader implementation, which uses a draw/blend-on-top configuration.

  • Sped up execution of empty render passes.

  • Fixed leakage of vertex attrib binding state in HdxPickTask.

  • Added shadow support for "distantLight" prim type.

  • Fixed evaluation of dome lights and dome light parameters.

  • Added support for depthStencil AOV output.

RenderMan Hydra Plugin

  • Added API to request a non-blocking stop of Prman in interactive mode.

  • Removed fallback domelight when no lights are provided by the scene.

  • Enabled rendering of in-memory VDB volumes in hdPrman. Previously, hdPrman only supported VDB volumes from disk.

  • Added support (by scene index plugin) for velocity-based motion blur.

  • Added a render setting for the Prman backend to use.

  • Changed the shutter interval used for processing geometry deformation to come from the render camera, rather than render settings.

  • Changed light prims to pull parameters from light material networks by default, instead of using GetLightParamValue.

  • Improved support for offline rendering: e.g. writing results directly to file, configuring output via render settings, and rendering synchronously.

  • Fixed cookie light filters in hdPrman to provide the appropriate coordinate system object.

  • Updated hdPrman's fallback surface material to better match Storm, by respecting the "displayColor", "displayOpacity", "displayRoughness", and "displayMetallic" primvars.

  • Improved performance blitting Prman output when running interactively.

  • Reworked material filtering operations to use the material network interface.

usdview

  • Added usdviewApi functions to toggle viewer mode and set the renderer plugin.

  • usdview plugins can now extend built-in menus like File or Window.

  • Increased statistics timer resolution from millisecond to microsecond.

  • Added light material network support to usdview builtin lights.

  • Fixed uninitialized values when picking from Python.

  • Fixed a bug with usdview's composition view when examining prims with specializes arcs.

  • Added support to set the OCIO display, view, and colorspace. (PR: #1491)

[21.11] - 2021-11-01

Ar 2.0 is enabled by default as of this release. Ar 1.0 is deprecated and will be removed in a subsequent release. During this transition, Ar 1.0 may still be enabled by setting PXR_USE_AR_2=OFF when running CMake.

Build

  • Added support for building against debug versions of Python. Users must specify PXR_USE_DEBUG_PYTHON=ON when running CMake. (PR: #1478)

  • Libraries now use @loader_path instead of absolute paths for RPATHs on macOS. (PR: #1478)

  • Libraries are now prefixed with "libusd_" on Linux and macOS and "usd_" on Windows to avoid name conflicts with other packages. The previous behavior can be restored by setting PXR_LIB_PREFIX="lib" on Linux and macOS or PXR_LIB_PREFIX="" on Windows when running CMake. (Issue: #1615)

  • Changes and fixes to build_usd.py:

    • Added --debug-python and --build-python-info options to enable builds against debug versions of Python and to control Python to build against. (PR: #1478)
    • Added --use-cpp11-abi option on Linux to control defininition of _GLIBCXX_USE_CXX11_ABI when building USD and dependencies. (Issue: #1609)
    • Replaced --debug option with --build-variant.
    • Updated download locations for boost, libtiff, and libpng to avoid certificate expiration issues on systems with OpenSSL older than 1.1.0.
    • Updated Blosc to v1.20.1 for compatibility with macOS Catalina (10.15).
    • Fixed issue where the OpenEXR libraries would be installed in the root of the filesystem. (PR: #1575

USD

  • Fixed deadlock in NdrRegistry::GetNodesByFamily.

  • Changes for Ar 2.0:

    • ArResolver::CreateDefaultContextForAsset now gives all registered resolvers an opportunity to provide a default context for an asset.
    • ArResolver::GetModificationTimestamp now returns an ArTimestamp object instead of a VtValue. ArTimestamp requires the use of Unix time to facilitate asset comparisons across resolvers.
    • Added default implementations for ArResolver::GetExtension and GetModificationTimestamp to simplify resolver implementations.
    • Added UsdResolverExample, an example URI resolver implementation.
    • Added more documentation.
  • Deprecated SdfLayer::GetExternalReferences and UpdateExternalReference in favor of GetCompositionAssetDependencies and UpdateCompositionAssetDependency.

  • SdfLayer no longer treats the inability to retrieve a timestamp for a layer or its external asset dependencies as an error under Ar 2.0. Calls to SdfLayer::Reload will always reload layers with invalid timestamps.

  • Updated SdfCreateVariantInLayer and SdfCreatePrimInLayer to use "prepend" when creating new variant sets. (Issue: #1552)

  • Added support for Unicode asset paths on Windows. (Issue: #1443, PR: #1580)

  • Fixed bug that caused errors when reading large .usda files.

  • Code invoked from Python that accesses invalid UsdPrim objects in C++ will now emit a Python exception instead of crashing.

  • Fixed issue where ArResolver::OpenAsset would be called multiple times when opening an ASCII .usd file or a .usdz file. (Issue: #1613)

  • Fixed bugs in gfGenCode and usdGenSchema where file objects were not closed, leading to ResourceWarnings from Python. (PR: #1557)

  • Updated usdGenSchema to mark plugInfo as a resource instead of a library when codeless schemas are being generated via skipCodeGen option.

  • Fixed bugs where changes to a layer's resolved path would not trigger recomposition of prims when needed.

  • Fixed bug that caused crashes during composition. (PR: #1568)

  • Fixed bug where UsdNotice::ObjectsChanged notice emitted after call to UsdStage::Reload would contain pointers to destroyed objects. (Issue: #1605

  • Fixed bug where UsdUtilsComplianceChecker returned a false error due to not recognizing the UsdTransform2d shader. (PR: #1625)

  • Fixed issue where UsdUtilsExtractExternalReferences would mutate the input layer unnecessarily. (Issue: #1573

  • Added UsdGeomVisibilityAPI. This schema provides attributes to control prim visibility based on the "purpose" attribute from the UsdGeomImageable schema. It will eventually be the place where primary visibility and purpose are also housed and authored.

  • Added UsdGeomImageable::ComputeEffectiveVisibility for computing purpose visibility.

  • Removed unused UsdGeomImageable::ComputeVisibility overload that took a parentVisibility parameter.

  • Fixed broken Python bindings for UsdPhysics on Windows under Python 3.8+.

  • Fixed missing Python bindings and "kilogramsPerUnit" metadata in UsdPhysics. (PR: #1606)

  • Deleted many previously deprecated UsdRi schema classes, namely, UsdRiRisBxdf, UsdRiRisIntegrator, UsdRiRisObject, UsdRiRisOslPattern, UsdRiRisPattern, UsdRiRslShader and all UsdRiLight and UsdRiLightFilters which are now part of the usdRiPxr schema domain.

  • Updated connectedAPIBehavior so that APISchemas can now provide connectableAPIBehavior by explicitly registering a new behavior associated with the APISchemaType or by providing plug metadata to configure the connectability behavior. Note that the latter can be used for codeless schemas.

  • Fixed a couple of rare bugs associated with UsdShadeConnectableAPIBehavior and UsdGeomComputeExtentFunction, resulting in robust behavior when new plugins are registered.

  • Updated UsdUtilsUpdateSchemaWithSdrNodes to include new concepts like addition of shaderId attribute to the generated schema classes, provide apiSchemaCanOnlyApplyTo, and provide ability to control UsdShadeConnectableAPIBehavior using metadata on the sdrNodes. Refer to the updated documentation for more details.

  • Updated usdgenschemafromsdr to be able to provide sdr nodes via explicit asset paths and to parse and add renderContext related information from the json config.

  • Added support for different Sdr to Sdf type mappings. Introducimg a new "sdrUsdDefinitionType" metadata field for sdrShaderProperty, which is used to distinguish between sdrDefaultValue and equivalent sdfTypeDefaultValue. Note that for backward compatibility SdrShaderProperty::GetDefaultValue currently returns the same value as SdrShaderProperty::GetSdfTypeDefaultValue, this is guarded by an environment variable "SDR_DEFAULT_VALUE_AS_SDF_DEFAULT_VALUE".

  • Single apply API schemas can now include built-in API schemas and can auto apply to other single apply API schemas. API schemas are now only allowed to inherit directly from UsdAPISchemaBase.

  • Applied API schemas can no longer inherit from other other applied API schemas, which allows UsdPrim::HasAPI() to be a much faster query. Non-applied schemas may still inherit from other non-applied schemas.

  • Added UsdLuxLightAPI, which can be applied to geometry to create a light. UsdLuxLight has been deleted. Added the applied API schemas UsdLuxMeshLightAPI and UsdLuxVolumeLightAPI, which include UsdLuxLightAPI as a builtin.

    • The core lights UsdLuxCylinderLight, UsdLuxDiskLight, UsdLuxRectLight, UsdLuxSphereLight, and UsdLuxPortalLight all inherit from from UsdLuxBoundableLightBase, are now Boundable, and have extents/bbox computations.
    • The core lights UsdLuxDomeLight and UsdLuxDistantLight now inherit from UsdLuxNonboundableLightBase and are not Boundable.
    • Deprecated UsdLuxGeometryLight
    • Deleted deprecated UsdLuxLightPortal (use UsdLuxPortalLight instead).
    • Fixed issue where UsdLux would register default SdrShaderNodes with 'USD' source types for lights defined outside of UsdLux.
    • Default SdrShaderNodes registered for UsdLux lights now include shadow and shaping API properties.

Imaging

  • First iteration of the Scene Index and Data Source system is now on by default and compatible with existing scene and render delegates via emulation. No new functionality is yet exposed as this is thus far intended to validate correctness and performance. This can be disabled by setting an HD_ENABLE_SCENE_INDEX_EMULATION environmental variable to "0".

  • Changed the return type of UsdImagingDelegate::Get() for the point instancer "rotate" attribute from GfVec4f (quaternion layout of <real, i, j, k>) to GfQuath (quaternion layout of <i, j, k, real>). This aligns with the result of SamplePrimvar(). In hdStorm, the quaternion data is now transported to the GPU as half-float data, instead of float. All custom scene delegates supplying the instancer "rotate" primvar via the Get() API must be updated for the new quaternion layout.

  • Added half-float vec2 and vec4 primvar support to hdStorm.

  • Added support to UsdImaging for new LightAPI features.

  • Added sprim-sprim dependency map to HdChangeTracker so it can track the dependencies between lights and their light filters.

  • UsdImagingMeshAdapter only keeps track of geom subsets that are using the materialBind family.

  • UsdImaging internally manages which prims to call UpdateForTime on, instead of relying on hydra to maintain that list.

  • Extended HdxTaskController to support built-in lights for backends like HdPrman.

  • When filtering primvars by material in UsdImagingGprimAdapter, added filtering using materials bound to geom subsets.

  • Improved dirty list management and performance including moving to a single dirty list managed by the render index.

  • Deleted PrimvarDescCache::Extract and GarbageCollect, and UsdImagingDelegate::PostSyncCleanup.

  • Deleted HdRenderPass::Prepare.

  • Improved UsdImagingDelegate performance when editing many instances of the same prototype. (PR: #1608)

  • Updated stb_image code to latest versions, enable UTF-8 filename support for Windows. (PR: #1580)

  • Fixed sync valid repr tokens just once for Rprims.

  • Fixed memory leak in HioOpenVDB.

  • Fixed HioOpenVDB build on windows. (PR: #1574)

  • Fixed errors when trying to read udims from .usdz files. (Issue: #1558)

  • Fixed HdResampleRawTimeSamples() parameter bug and add test coverage. (Issue: #1549)

  • Fixed crash when processing multiple native instancer edits in the same frame. (Issue: #1551)

  • Fixed GprimAdapter::_AddRprim material resolution order to be consistent with other functions. (Issue: #1626)

  • Fixed to not normalize point instancer quaternions. (Issue: #1505)

Storm

  • Added support for rendering meshes with geom subsets.

  • Added support for rendering DomeLights as a skydome. (Issue: #1385)

  • Added support to rendering BasisCurves that don't completely cover the supplied points or other primvars.

  • Added support for "constant shading" of basis curves wherein they're unaffected by lighting.

  • Added support for screen-space flat normals.

  • Improved 1st order approximations of the basic area lights (SphereLight, DiskLight, RectLight, DistantLight, and CylinderLight).

  • Moved barycentric coord generation to codeGen.

  • Consolidated edge param calculations.

  • Implemented IsValid() for HdStUdimTextureObject.

  • Sync visibility once per-Rprim sync rather than per draw item.

  • Even if there are zero lights, prims should still use the lighting integrator, specifically the one specified by their shader key.

  • Moved bindless address fetch out of HdStBufferResource.

  • Changing the type storing the volume shader glslfx source code and material params in an HdStMaterial from HdStShaderCode to struct HdStMaterial::VolumeMaterialData.

  • When a scene delegate provides a network without volume output for a material used by a volume, use the volume fallback shader.

  • Removed IsFragmentOnPoint() and IsFragmentOnEdge() shader methods.

  • Renamed HdStSurfaceShader to HdSt_MaterialNetworkShader.

  • Fixed domelights to respond to visibility changes.

  • Fixed crash when UDIM textures are missing.

  • Fixed to support all sizes of domelight textures.

  • Fixed GS smooth fvar interp for displacement

  • Fixed GL version test to include minor version. (Issues: #957 and #1001

  • Various improvements to Hgi:

    • Moved bindless texture management to HgiGL.
    • Exposed general and device specific capabilities.
    • Improved staging buffer for unified memory devices.
    • Use shaderc to compile GLSL to SPIR-V in HgiVulkan.
    • Check buffer storage mode before blit sync in HgiMetal.

RenderMan Hydra Plugin

  • Added support for UsdPreviewSurface's displacement in HdPrman.

  • Added support for UsdUvTexture's "sourceColorSpace" input and fixed normal mapping.

  • Added support for additional clip planes.

  • Added flipped flag to RtxHioImage plugin.

  • Adjusted HdPrman's fallback volume shader to match Storm's.

  • Introduced codeless usdRiPxr schema domain for RenderMan lights and lightfilters. These are generated using usdgenschemfromsdr from rman light and lightfilter args files. Note that these schemas are compatible with RenderMan 24.2.

  • Removed use of "allowPresenceWithGlass" from UsdPreviewSurfaceParameters node.

  • RtxHioImage can convert various texture formats to type float, so they can be passed to Renderman. (Issue: #1313)

  • Fixed HdPrman's fallback maxSamples to match the RenderMan fallback (64).

MaterialX

  • Updating the arguments passed into mx::loadLibraries to better accommodate relocating the MaterialX libraries folder. (Issue: #1586)

[21.08] - 2021-07-15

Ar 2.0 is feature-complete as of this release. We anticipate addressing feedback and bug reports, deprecating Ar 1.0 and enabling Ar 2.0 by default for the next release, then removing Ar 1.0 entirely in the release after that. Developers should begin migrating to Ar 2.0 now.

RenderMan 24 is now required for the RenderMan plugin as of this release. Support for RenderMan 23 was deprecated in 21.05 and has now been removed.

Build

  • Updated dependencies to align with VFX Reference Platform CY2019. In particular, USD now requires TBB 2018 or greater.
  • Added support for Python 3.8+ on Windows. The usd-core PyPI package now supports Python 3.8 and 3.9 on all platforms. (PR: #1511, #1512, #1513)
  • Fixed build errors on ARM64 on Linux. (PR: #1453)
  • Fixed various build errors due to missing or bad includes on gcc 11, clang 11, clang 13, and for Android or emscripten. (PR: #1497, #1499, #1530, Issue: #1546)
  • Fixed issue in build_usd.py with some versions of PySide2 on Windows. (PR: #1454)

USD

  • Fixed bug with symbol demangling on Windows which broke some TfType alias registrations. (PR: #1510)

  • Replaced some uses of deprecated tbb::atomic with std::atomic. (PR: #1486)

  • Numerous changes to the Work library to adhere to TBB thread limits set by host applications. (Issue: #1368):

    • WorkGetConcurrencyLimit now returns tbb::this_task_arena::max_concurrency
    • Replaced WorkArenaDispatcher and other uses of task_arena in favor of new WorkWithScopedParallelism, which uses TBB's task isolation feature.
  • Many changes for Ar 2.0:

    • Removed the majority of deprecated APIs, including AnchorRelativePath, FetchToLocalResolvedPath, ConfigureResolverForAsset, and others.
    • UsdStage::Refresh now calls ArResolver::RefreshContext to let resolvers update any internal state. Resolvers can send a ArNotice::ResolverChanged notice in that function to inform UsdStage and other listeners of any changes.
    • Added default implementations for context management and scoped caching to make it easier to implement resolvers. Note that resolvers that provide their own implementations must indicate this in the plugInfo.json file. See ArResolver documentation for more details.
  • Added UTF-8 support for reading and writing asset paths. (Issue: #1443)

  • UTF-8 sequences are now written into .usda layers without hex encoding.

  • Embedded NUL bytes are disallowed in string values in .usda layers.

  • Dynamic file formats can now be set up to use anonymous layer identifiers to avoid the need for dummy resolvable assets. (Issue: #1356)

  • Made virtual SdfFileFormat functions protected instead of private. (PR: #1519)

  • Fixed bug where a layer would be dropped from the Sdf layer registry if its identifier were changed to an existing layer's via SdfLayer::SetIdentifier.

  • Fixed SdfLayer::SetIdentifier to use same restrictions as SdfLayer::CreateNew.

  • Fixed bug where entire layer would be parsed when reading layer metadata only from .usda layers via SdfLayer::OpenAsAnonymous if no such metadata existed.

  • Fixed bug with vector usage during calls to SdfLayer::TransferContent and other methods that caused debug asserts on Windows. (Issue: #1501)

  • Fixed output of PcpPrimIndex::PrintStatistics on Windows. (PR: #1480)

  • Added support for "codeless" USD schemas that do not have any C++ or Python code. Changes to these schemas' definitions do not require any code to be recompiled; instead, the generatedSchema.usda just needs to be regenerated via usdGenSchema and reinstalled.

  • Added usdgenschemafromsdr utility to generate schemas from Sdr nodes.

  • Added ability to specify allowed prim types for API schemas in the customData dictionary for the schema in schema.usda.

  • Added UsdPrim::CanApplyAPI and CanApply to all API schema classes to check if an API schema can be applied to a prim based on the restrictions above.

  • Removed deprecated instancing "master" API from UsdStage and UsdPrim.

  • Removed support for deprecated "UsdSchemaType" terminology in schemas.

  • Fixed UsdStage::ResolveIdentifierToEditTarget to be consistent with asset path computations during composition.

  • Fixed bug where UsdResolveInfo / UsdAttributeQuery would be invalidated by an insignificant layer stack change. (Issue: #1500)

  • Improved change processing performance in UsdStage. In an internal test that authored many attributes, runtime decreased by ~50% (from ~50s to ~25s).

  • A UsdConnectableAPIBehavior can now be set to ignore shader encapsulation rules by overriding UsdConnectableAPIBehavior::RequiresEncapsulation.

  • API schemas can now provide connectability behavior, which can override behavior based on prim type.

  • Deprecated UsdShadeMaterial::ComputeSurfaceSource, ComputeVolumeSource, and ComputeDisplacementSource overloads taking a single token for renderContext.

  • Renamed SdfTypeIndicator to NdrSdfTypeIndicator.

  • Added initial version of UsdPhysics domain and schemas. For more details, see the proposal. (PR: #1424)

  • Miscellaneous documentation fixes. (PR: #1485, #1553)

Imaging

  • Added basic support for Hydra Commands, a mechanism to invoke actions that renderers know how to perform.
  • Added support for loading OpenVDB grids via ArAsset, allowing OpenVDB files to be read from within .usdz files.
  • Added support for cameras in the testing Null render delegate.
  • Added new rendertask param to disable clipping.
  • Added UsdImagingGLEngine::SetPresentationOutput to explicitly set the framebuffer that AOVs are presented into.
  • Fixed buffer allocation in vboSimpleMemory Manager.
  • Fixed issue in UsdImaging that would occur when a CoordSys is bound to an Xform prim with a renderable descendants.
  • Fixed resync of shaders in UsdImaging to also resync geometry bound to the shader's material. (Issue: #1487)
  • Fixed handling of edits to "purpose" in the native instance adapter in UsdImaging. (Issue: #1515)
  • Fixed unwanted export of stbImage symbols from Hio. (PR: #1498)
  • Allow point instancer prototypes from overs in UsdImaging. (PR: #1436)
  • Removed HdxMaterialTagTokens in favor of HdStMaterialTagTokens.

usdview

  • usdview and usdrecord now share the argument parsing facility for renderers.
  • Fixed issue where usdview would sometimes open in the background on Windows. (PR: #1537)
  • Fixed to not error or warn in Rollover Prim Info if assetInfo has no identifier entry. (PR: #1476)
  • Fixed Qt window being displayed in usdrecord. (Issue: #1521)

Storm

  • Added support for correct refinement of varying and face-varying primvars.

  • Added support for compute program preprocessor defines.

  • Added size validation for uniform primvars of basis curves.

  • Improved performance of volume ray marching shader.

  • Improved wireframe on surface display for adaptive tessellation.

  • Improved wireframe on surface display for uniform refinement.

  • Improved edge picking performance.

  • Improved performance and appearance of patch edge drawing.

  • Improved GPU memory usage by using a non-aggregated allocation for GPU stencil table buffers.

  • Moved mesh edge handling out of the geometry shader.

  • Changed default material tag in HdxTaskController to enable alpha-to-coverage.

  • Changed behavior, when a dome light texture is invalid, issue a coding error and print the file path for debugging.

  • Changed behavior, updated selection on tracker during Prepare instead of Sync.

  • Use the new texture system to bind the texture in the render pass shader.

  • Removed redundant ptexId field from patchParam.

  • Removed HdStExtCompGpuComputationBufferSource.

  • Removed remaining GS edge id shader code.

  • Removed HdStMixinShader since its usage was very limited.

  • Fixed multiple issues related to OSD drawing.

  • Fixed Ptex layout texture sampler type.

  • Fixed TCS/TES processing of primvar and drawingCoord.

  • Fixed incorrect handling of left-handed meshes. (Issue: #1075)

  • Fixed resolution of symlinked UDIM textures. (Issue: #1329)

  • Fixed area light approximation when transforms are animated. (Issue: #1524)

  • Various improvements to Hgi:

    • Added 1D texture array upload support in HgiMetal.
    • Added 16-bit signed integer data formats.
    • Added buffer binding support for Hgi shader codegen.
    • Added codeGen for compute shader invocation ID.
    • Added HgiShaderFunctionDesc creation path to HdStGLSLProgram.
    • Moved Storm compute functions to Hgi shader generation.
    • Removed now unnecessary restoration of framebuffer in HgiGLScopedStateHolder and HgiInteropOpenGL.
    • Converted primvar refinement to Hgi compute shaders.

RenderMan Hydra Plugin

  • Updated RenderMan version required by HdPrman to 24.
  • Unified HdPrman & HdxPrman into HdPrman.
  • Added basic support to optionally use MaterialX networks. (see below)

Alembic Plugin

  • Changed default number of threads used for reading Ogawa-backed files from 4 to 1. This may be changed with the USD_ABC_NUM_OGAWA_STREAMS env var.

MaterialX Plugin

  • Added support for reading MaterialX documents within .usdz files when Ar 2.0 is enabled.
  • Imaging support:
    • Moved the code common to both Storm and HdPrman into imaging/hdMtlx.
    • Allow the output of a nodegraph to be used multiple times. (Issue: #1489)
    • Update _GetMxNodeType to use MaterialX functions to support arbitrary node types not just UsdPreviewSurface and StandardSurface. (Issue #1538)
    • Fixed issue with incorrect paths for finding nodes. (Issue: #1488)
    • (Storm support) Added support for different primvar texture coordinate names to be passed down through the mtlx file.
    • (Storm support) Added support for textures to be used anywhere within the connected nodegraph instead of just as inputs for the material properties.
    • (Storm support) Added basic support for transparent MaterialX materials making sure the proper material tag is set.
    • (HdPrman support) Added basic support to use MaterialX networks.
    • (HdPrman support) Updated StandardSurface adapter node to pass the normal to PxrSurface for the bumpNormal.

Security

[21.05] - 2021-04-12

Build

  • Removed unnecessary check for Python executable in build_usd.py. (Issue: #1414, PR: #1464)
  • Updated build_usd.py to use MaterialX v1.38.0 and unified the MaterialX plugin and imaging build options PXR_BUILD_MATERIALX_PLUGIN and PXR_ENABLE_MATERIALX_IMAGING_SUPPORT into PXR_ENABLE_MATERIALX_SUPPORT.
  • Exposed version numbers in pxrConfig.cmake for CMake client projects.
  • Updated CHANGELOG.md to include links to pull requests and issues. (Issue: #1362)
  • Fixed linking errors by removing extern C linkage from LZ4 symbols, to avoid collisions with other libraries embedding LZ4. (Issue: #1447)
  • Updated VERSIONS.md to include Linux, Windows and MacOS versions used for testing. Note that Windows and MacOS should still be considered experimental. (PR: #1393)

USD

  • Added UsdUtils.UpdateSchemaWithSdrNode functionality for creating or updating a schema.usda from specially curated sdrShaderNode and sdrShaderProperty metadata.
  • Updated usdGenSchema to not error when generating a dynamic schema and libraryPath is not specified.
  • The default 'USD' SdrShaderNodes generated from UsdLuxLightFilter types now have the context of "lightFilter" like other light filter shader nodes.
  • Fixed bug where the registered URI resolver would not be invoked for a URI asset path if it was shorter than the longest registered URI schema.
  • The template asset path field for value clips now supports Sdf file format arguments. (PR: #1450)
  • SdfLayer::ListFields now includes "required fields" for each spec type.
  • A collection of fixes and tests for Windows path handling, especially involving symlinks. (PR: #1441, #1465, #1468, Issues: #1440)
  • Fixed usdGenSchema to honor apiName metadata for auto generated tokens.h. This results in correct doxygen documentation for the correct API names.
  • UsdUtilsStitchClips now creates a separate manifest layer instead of using the topology layer as the manifest layer. This is because the topology layer can contain attributes that actually don't have any time samples in clips. (Issue: #1344)
  • Added documentation for built-in and auto-applied API schemas.
  • Added additional plugInfo mechanism (via AutoApplyAPISchemas metadata) to define auto apply API schemas, to allow context/site specific auto application of API schemas.
  • Added FlattenTo function to UsdPrimDefinition to copy the contents of a prim definition into a prim spec on a layer.
  • Updated UsdShadeConnectableAPI::Get{Inputs,Outputs} to only return authored inputs/outputs by default. Optional onlyAuthored=false argument can be passed to explicitly include Builtins. Results in performance improvement at code sites like UsdShadeShaderDefUtils.
  • UsdLux Shadow and Shaping APIs are now connectable. All attributes on these APIs have been given the "inputs:" prefix.
  • Adding support for identifier aliases in Ndr/Sdr. This allows NdrRegistry to use these aliases to find the node through the GetNodeByIdentifierAPIs when there are no appropriate nodes that exactly match the identifier being searched for.
  • Performance improvement in terminal resolution in UsdShade. Introduced a shaderOutputOnly flag on the GetValueProducingAttributes function, this allows us to get only the type of connections we want and avoid the cost of the extra checks.
  • Updated NdrRegistry::GetNodeFromAsset() to use asset name and extension as the node name instead of the identifier. Note that node name is not expected to be unique for a NdrNode.
  • Fixed a pcp change processing bug where we did not consider layers with replaced content significant wrt layer stacks that use the layer. (Issue: #1407)
  • Removed UsdShadeConnectableAPI implicit constructors from UsdShadeShader and UsdShadeNodeGraph to enforce independence of connectability concept from shader graphs. Callers are required to convert these explicitly now, which can be done via the ConnectableAPI() method on Shader and NodeGraph.
  • Updated connectability rules in UsdShadeConnectableAPIBehavior to improve encapsulation. Refer to the UsdShade documentation for details on connectability rules.
  • usdGenSchema now adds a type alias for abstract typed schemas, which means abstract typed schemas now have an official USD type name which is registered with the UsdSchemaRegistry.
  • Auto apply API schemas in USD can now specify abstract typed schemas to auto apply to, indicating that the API should be applied to all schemas that derive from the abstract schema type.
  • Removed deprecated UsdConnectableAPI::IsShader() and IsNodeGraph() APIs.
  • Fixed performance regression in UsdStage change processing when applying an API schema.
  • Make OSL parser for Sdr more robust to dynamic array type names.
  • Backwards compatibility for the deprecated "UsdSchemaType" terminology will be removed in the next release. Schemas that have not been updated since v21.02 must be regenerated to avoid breakage in the next release.

Imaging

  • Added SampleIndexedPrimvar() and GetIndexedPrimvar() scene delegate API to allow users to access unflattened primvars and their indices.
  • Added support for time-sampled computed primvars in the scene delegate API (including an UsdImaging implementation for Skel). (PR: #1455)
  • Added GetInstancerPrototypes() scene delegate API to return prim paths that are prototypes of an instancer.
  • Added support for GetMaterialResource() to the lightAdapter and lightFilterAdapter classes so the usdImaging scene delegate can provide HdMaterialNetworks for lights and filters.
  • Added imaging adapters for UsdLuxPluginLight and UsdLuxPluginLightFilter.
  • Added optimization when checking primvar existence, use Get() instead of ComputeFlattened().
  • Renamed render delegate API GetMaterialNetworkSelector() to GetMaterialRenderContexts() to allow for multiple material render contexts.
  • Moved version tracking of batches from HdChangeTracker to Storm's render delegate.
  • Moved garbage collection API to Storm's render delegate.
  • Refactored the free camera code in HdxTaskController::_Delegate into its own HdxFreeCameraSceneDelegate.
  • Removed obsolete HdTexture bprim.
  • Various improvements to Hio:
    • Refactored reading of HioImage and the conversion to an HgiFormat into common functionality.
    • Moved volume field texture loading out of Glf. Volume data is loaded via a plugin point (hioOpenVDB) in HioFieldTextureData.
    • Replaced GlfGetNumElements(HioFormat) and GlfGetElementSize(HioFormat) with equivalent functions in Hio.
    • The HioOIIO OpenImageIO plugin supports format conversion when loading image data, so we specify the target format in the destination image spec.
    • As the transition to Hio (and our new texture system) continues to move forward, we are now removing many entry points in Glf.
  • Fixed crash on Hydra update when a prototype primitive is removed (deleted or deactivated) in the same update cycle where an inheritable primvar is added or changed to an ancestor of the prototype that used to exist. (PR: #1418, Issue: #1417)
  • Fixed skip creating unsupported AOVs in the task controller. (Issue: #1215)
  • Fixed non-color AOV visualization. (Issue: #1437)
  • Fixed material binding improvements for point instancer prototypes. (Issue: #1449)
  • Fixed instance highlighting for native instances when the selected instance is invisible. (Issue: #1461)
  • Fixed PointInstancerAdapter Get() to properly call the fallback if it can't find the requested key. (Issue: #1439)

Storm

  • Added filtering of instancer primvar bindings.
  • Added shader configurations, mixins and a new material tag 'translucentToSelection' to enable occluded selection to show through.
  • Added HdRenderPassState API to enable/disable the depth test.
  • Added better support for a color mask to be specified per color attachment rather than use the same mask for all attachments.
  • Added SetPresentationOutput() API specifies the framebuffer the present task will write the AOVs into.
  • Added casts to avoid GLSL compile errors when enabling HD_ENABLE_DOUBLE_MATRIX and using the volume raymarcher.
  • Added GlfAnySharedGLContextScopeHolder that is a conditional GlfSharedGLContextScopeHolder only switching the shared context if there is no current valid context.
  • Added number of texture objects and handles to HdStResourceRegistry::GetResourceAllocation.
  • Changed Ptex layout texture format in order to improve compatibility on platforms which don't support 3-component textures.
  • Disabled bindless textures while we investigate unexpected performance regressions related to switching context and bindless.
  • Optimization to bail out early for Storm tasks that have no work.
  • Avoid invalidation in the renderpass shader when processing buffer binding requests.
  • Refactored basis curves points primvar processing such that it uses HdSt_BasisCurvesPrimvarInterpolaterComputation.
  • Fixed to trigger draw item gather when material tag changes
  • Fixed HgiBufferDesc byteSize calculations to avoid reading beyond initialized data when creating buffer objects.
  • Renamed renderPassShader.glslfx to renderPassColorShader.glslfx to clarify its intent.
  • Renamed rprimUtils to primUtils to reduce code duplication.
  • Removed unused mixin option to discard unselected fragments.
  • Removed Bind/Unbind HdRenderPassState API
  • Removed GlfHasLegacyGraphics - use GlfContextCaps instead.
  • Removed render pass state override shader.
  • Various improvements to Hgi:
    • Added support to pass an external framebuffer to HgiInterop.
    • Renamed HgiMipInfo::byteSize to HgiMipInfo::byteSizePerLayer for clarification.
    • Moved HgiShaderSection::WriteAttributeToIndex to HgiMetalShaderSection.
    • Unified how attributes are stored across GL, Metal and Vulkan.
    • Fixed resolve op to transfer data from/to all attachments.
    • Fixed a potential bug where the wrong size was computed for a compressed array texture.
    • Fixed code generation for unsigned and signed integer textures.
    • Fixed redundant depth buffer resolve and ensure that in the absence of color attachments, it still gets resolved.
    • Fixed Metal error related to resource lifetime.

RenderMan Hydra Plugin

  • Updated RenderMan version required by hdPrman to 23.5.
  • NOTE: The USD release following the RenderMan 24 release will increase the required version once more to 24.0. In other words, this will likely be the last USD release with hdPrman support for RenderMan 23.x.
  • Made the rman args parser map bxdf types inputs to the Sdr terminal type.
  • Finishing work to support fieldDataType and vectorDataRoleHint for UsdVol prims in hdPrman.

MaterialX Support

  • Minimum of MaterialX v1.38 is now required.
  • MaterialX support in Storm:
    • Added basic support for textures.
    • Added basic support for direct lights.
    • Added a Mtlx render context, which gets consumed by Storm's render delegate.
    • Register MaterialX nodes as having "mtlx" source type and allow Storm's material network to accept both glslfx and mtlx sourcetypes.
    • Changed the MaterialX option from FIS to Specular Environment Prefilter.
    • Fixed u_envMatrix calculation to account for y-up/z-up/domelight transform.
  • Various improvements to the usdMtlx plugin:
    • Record "geomprop" references from materialx into Sdr's "primvars" metadata. This lets clients query which primvars the material wants access to (for purposes such as primvar filtering).
    • No longer copying default values on shader inputs to each USD shader definition to improve performance and keep it more consistent with other UsdShade constructs.
    • Removed deprecated references to shaderref, Color2.
    • Fixed a crash in UsdMtlx when reading mtlx nodes that use a MaterialX standard shader nodedef.

usdview

  • Fixed a bug where we weren't updating for changes that affect the entire stage. (Issue: #1407)
  • Improved testusdview error reporting (PR: #1416)

[21.02] - 2021-01-18

Build

  • Added build and packaging scripts for PyPI packages. Thanks to Nvidia for their work on this project!

  • Updated documentation build to fix several issues and no longer require Python. (Issue: #718)

  • GLEW is no longer required for building imaging components.

  • Various fixes and changes to build_usd.py:

    • Fixed command-line args not being respected for OpenVDB. (PR: #1406)
    • Updated boost to 1.70 on macOS for both Python 2 and 3. (Issue: #1369)
    • Updated MaterialX to 1.37.3 with shared libraries on Linux.
  • Fixed various linking issues with OpenEXR. (PR: #1398)

USD

  • Allow setting malloc hook functions if they were previously set to malloc/etc.

  • Fixed handling of symbolic links and mount points on Windows. (PR: #1378)

  • Fixed incorrect handling of non-existent variables in TfEnvSetting in Python.

  • Updated GfRect2i API to use function and argument names that are agnostic to the direction of the Y axis.

  • Updated ilmbase half embedded in Gf to OpenEXR v2.5.3. (Issue: #1354)

  • Added VtArray::AsConst, cfront, and cback methods to help avoid inadvertent copy-on-writes and thread-safety issues.

  • Fixes for variety of issues with VtArray conversions in Python, including conversion from Python sequences if all elements are convertible and a bug with inadvertent copy-on-writes. (Issue: #1138)

  • Initial implementation of Ar 2.0. This includes new features like support for URI resolvers and many changes to the ArResolver interface. For more details see https://graphics.pixar.com/usd/docs/668045551.html.

    Work on Ar 2.0 is not yet complete and will continue through the next few releases. Ar 2.0 is disabled by default but can be enabled for preview and initial testing by specifying PXR_USE_AR_2=ON when running CMake.

  • Moved SdfFindOrOpenRelativeToLayer to SdfLayer::FindOrOpenRelativeToLayer.

  • Fixed SdfLayer::FindRelativeToLayer to use the same anchoring logic as SdfLayer::FindOrOpenRelativeToLayer.

  • Fixed string encoding issue in .usda file writer. (Issue: #1331)

  • Improved behavior when hitting hard-coded composition graph limits in Pcp.

  • Fixed incorrect native instancing behavior with sub-root references.

  • Added support for auto-apply API schemas. This allows single-apply API schemas to be automatically applied to prims using one of a list of associated concrete schema types instead of requiring the user to manually apply the API schema.

  • Renamed UsdSchemaType to UsdSchemaKind to disambiguate between the schema type (e.g. UsdGeomSphere) and kind (e.g. non-applied, single-apply, etc).

  • Deprecated functions using the "schema type" terminology in favor of "schema kind".

  • Added UsdVariantSet::BlockVariantSelection. (Issue: #1319, PR: #1340)

  • Removed deprecated UsdAttribute::BlockConnections.

  • Removed deprecated UsdRelationship::BlockTargets.

  • Removed deprecated UsdCollectionAPI::ApplyCollection.

  • Added "container" concept to UsdShadeConnectableAPI.

  • Added support for connecting multiple sources to UsdShadeConnectableAPI.

  • Deprecated API for connecting to single sources in favor of the more general multiple-source API on UsdShadeConnectableAPI.

  • Deprecated UsdConnectableAPI::IsShader and IsNodeGraph in favor of IsContainer API. Warnings are emitted on first use unless the environment setting USD_SHADE_EMIT_CONNECTABLE_API_DEPRECATION_WARNING is set to 0.

  • Updated various clients to apply the UsdShadeMaterialBindingAPI schema before binding materials.

  • Fixed Python binding for UsdShade.CoordSysAPI.HasLocalBindings. (PR: #1360)

  • Fixed Python binding for UsdSkel.SkinningQuery.ComputeExtentsPadding. (Issue: #1375)

  • Added UsdLuxPluginLight and UsdLuxPluginLightFilter schemas that allow for defining a light or light filter via an SdrShaderNode.

  • UsdLuxLight and UsdLuxLightFilter schemas now publish an associated SdrShaderNode based on their built-in properties.

  • Input attributes for UsdLuxLight and UsdLuxLightFilter schemas are now connectable and have been renamed to include the "inputs:" prefix.

  • Deprecated UsdLuxLightPortal schema in favor of new UsdLuxPortalLight schema.

Imaging

  • Added new GL Loading Library (GLApi) to replace GLEW. GLEW is no longer required.
  • Added HioImage, removed GlfImage.
  • Added new camera framing API. Introduces the display and data window and storage size to separate these concepts. Updated Storm, HdPrman, and HdEmbree.
  • Added support for normal buffers to HdxPickFromRenderBufferTask.
  • Added standard prim API to HdInstancer and HdSceneDelegate::GetInstancerId.
  • Added support for animated extents when using draw modes. (PR: #1365)
  • Improved Hydra camera to better support physically based attributes.
  • Extended HdDisplayStyle to house more advanced selection behaviors.
  • Changed renderParams timeCode default values from Default to EarliestValue.
  • Changed UsdImagingDelegate to map HdLightTokens to the new input attribute names in queries through GetLightParamValue.
  • Merged tokens textureResourceMemory into textureMemory for better performance tracking.
  • Renamed UsdImagingValueCache to UsdImagingPrimvarDescCache, it only stores primvar descriptors.
  • Removed implementations of deprecated HdSceneDelegate::GetTextureResource.
  • Removed HwFieldReader volume material node in favor of typed nodes.
  • Fixed bug in pick targets when resolving unique hits. (Issue: #1343)
  • Fixed UsdSkel instance drawing at origin bug. (Issue: #1347)
  • Fixed UsdImaging to discard coord sys bindings to non-existent xforms. (Issue: #1346)
  • Fixed UsdSkelImagingSkeletonAdapter to forward GetMaterialId and GetDoubleSided calls to skinned mesh primadapter. (Issue: #1384)
  • Fixed an issue where UsdSkelImagingSkeletonAdapter::_RemovePrim() failed to remove skeletons that did not have any bindings to skinned prims. (Issue: #1228, Issue: #1248)
  • Fixed some display crashes after resyncing skeletons. (PR: #1397)
  • Fixed dome light preview surface. (PR: #1392)
  • Fixed links to OpenEXR for Alembic and OpenImageIO plugins. (PR: #1398)

Storm

  • Added support for varying interpolation of any basis curves primvar. (Issue: #1308)
  • Added support for HdStResourceRegistry::ReloadResource to allow clients to explicitly force textures to be reloaded by file path. (Issue: #1352)
  • Added a new HdMaterialNetwork2 to combine (and then replace) HdStMaterialNetwork and MatFiltNetwork.
  • Added step to convert 3 channel textures to 4 channel to support Hgi backends with 4 channel requirements.
  • Added Resize() to barContainer.
  • Added fieldTextureMemory render setting to specify the target memory of volume textures.
  • Added experimental MaterialXFilter to process a material network and convert it into a MaterialX network. Also, added a first pass on a MaterialX shadergen.
  • Enabled bindless textures by default.
  • Several improvements to volume rendering including a step size relative to the sample distance so that the quality of the rendered volume does not depend on the scale.
  • Optimized HdStRenderBuffer performance by only allocating when the descriptor changes.
  • Optimized computations by avoiding copying the compute kernel for GPU computations.
  • Refactored face culling to remove fragment shader discards when possible.
  • Refactored geometric shaders such that only prims with the "masked" material tag can use alpha threshold based discards.
  • Switched Storm over to using the "translucent" material tag rather than "additive" as the default translucency state.
  • Fixed handling of valid to invalid BAR transitions due to Scene graph operations on primvars or primvar filtering. (Issue: #1182)
  • Fixed GPU memory leak of certain buffers never getting garbage collected.
  • Fixed fullscreen pass to preserve alpha.
  • Removed instance primvar filtering.
  • Various improvements to Hgi :
    • Added initial version of the Hgi codegen to be able to produce GLSL/MetalSL/others from glslfx.
    • Added the first push of our experimental, incomplete, HgiVulkan backend, which does not yet build by default.
    • Added memory barriers to Hgi.
    • Added CopyTextureToBuffer and CopyBufferToTexture to HgiBlitCmds.
    • Added 2D_ARRAY support to Hgi.
    • Moved Ptex and Udim loading from Glf to Hgi and Storm.
    • Added UINT16 format as prep work for Ptex support.
    • Fixed obj-c autorelease issue, and simplification of secondary command buffer in HgiMetal compute encoder.
    • Fixed HgiTexture::GetByteSizeOfResource to take the mip levels into account.
    • Fixed for missing include. (PR: #1359)

usdview

  • Fixed StageView.pickObject when doubles are small or out of image-bounds. (PR: #1296)

MaterialX Plugin

  • Removed deprecated support for MaterialX 1.36.

Embree Hydra Plugin

  • Added support for new camera framing API and HdCamera API.

RenderMan Hydra Plugin

  • Bumped version requirement to RenderMan 23.5 or greater.
  • Improved calculation of vertex, varying, and face-varying primvar counts in BasisCurves to better match RenderMan.
  • Added support for new camera framing API and HdCamera API.
  • Added support for material node int array inputs. (Issue: #1294)
  • Fixed issue that caused parameters from a shader to be incorrectly carried over to the next shader that was parsed. (Issue: #1396)

[20.11] - 2020-10-14

Build

  • Updated CMakeLists.txt to conform to recommended practice. (Issue: #1241)

  • The build system now sets Boost_NO_BOOST_CMAKE=ON by default to work around issues with boost's cmake files. (Issue: #1255)

  • Various fixes and changes to build_usd.py:

    • Added --toolset option for specifying CMake toolset. (PR: #1325)
    • Added --prefer-safety-over-speed and --prefer-speed-over-safety options. See below for more details.
    • Fixed issue with building libTIFF with Xcode 12. (PR: #1315)

USD

  • Fixed incorrect underlying container type for TfHashMultiMap. (PR: #1281)

  • Fixed invalid conversions of Gf containers like GfVec3f in Python. Note this issue is still present in Python 3. (Issue: #1290)

  • Fixed various tests to accommodate PXR_OVERRIDE_PLUGINPATH_NAME. (PR: #1275)

  • Added GetExternalAssetDependencies to SdfLayer and SdfFileFormat to allow file format plugins to declare additional dependencies that determine when a layer produced from that file format should be reloaded.

  • Reduced memory usage from SdfPath::GetString and added SdfPath::GetAsString and SdfPath::GetAsToken to avoid populating internal caches. (Issue: #1287)

  • Various fixes to composition behavior:

    • Fixed issues with sub-root references, payloads, and inherits, and ancestral variant selections.
    • Fixed issue with payloads on ancestors of sub-root references/payloads.
    • Fixed issue with combinations of root, sub-root, and ancestral inherits.
  • Fixed bug in .usda file writer that could cause data corruption. (Issue: #1331)

  • Fixed performance issue when writing many relationship targets or attribute connections to .usdc files. (Issue: #1345)

  • Improved performance for certain queries with .usdc files. In one example, this decreased draw times in usdview after transform changes by ~90%. (Issue: #1300)

  • New .usdc files now default to version 0.8.0. These files cannot be read in USD releases prior to v19.03. Users can revert to writing older versions by setting the environment variable USD_WRITE_NEW_USDC_FILES_AS_VERSION to an older version.

  • Added safety checks to guard against reading malformed .usdc files. These checks may negatively impact performance and may be disabled by specifying PXR_PREFER_SAFETY_OVER_SPEED=OFF when running CMake or --prefer-speed-over-safety with build_usd.py.

  • Native instancing "master" prims are now referred to as "prototype" prims. The generated paths of prototype prims has been changed from /_Master to /_Prototype. Clients can use new UsdPrim::IsPrototypePath and UsdPrim::IsPathInPrototype API to determine if a given path is related to a prototype.

    UsdStage and UsdPrim API using "master" terminology like UsdPrim::GetMaster and UsdStage::GetMasters have been deprecated and will be removed in a future release.

  • Added Get/Set/ClearChildrenReorder to UsdPrim for reordering prim children.

  • UsdProperty::FlattenTo now allows flattening properties across stages.

  • Deprecated UsdRelationship::BlockTargets and UsdAttribute::BlockConnections. Clients should use SetTargets({}) and SetConnections({}) instead.

  • Changed UsdRelationship::GetTargets and UsdAttribute::GetConnections to return false when HasAuthored would return false.

  • Fixed bug where UsdFlattenLayerStack was not applying the asset path resolution callback to asset paths in clips metadata. (PR: #1266)

  • Added UsdNotice::LayerMutingChanged notice. (Issue: #676)

  • Fixed resource leak with Usd.PrimCompositionQuery in Python. (PR: #1297)

  • Fixed crashes when printing expired Sdf.Layer and Usd.Stage objects in Python. (PR: #1012)

  • Removed isPrivateApply functionality from schema generation.

  • Fixed error in UsdUtilsComputeAllDependencies when an invalid templateAssetPath value is specified. (PR: #1289)

  • Improved UsdUtilsGetPrimaryUVSetName and UsdUtilsGetPrefName. (PR: #1283)

  • Fixed bug in UsdUtilsStitchClips that led to inconsistent stitched results.

  • Added CanContainPropertyName to UsdCollectionAPI, UsdGeomPrimvars, UsdShadeMaterialBindingAPI, and UsdShadeCoordSysAPI for checking if a property name is valid for these schemas.

  • Deprecated UsdCollectionAPI::ApplyCollection in favor of Apply.

  • Added fallback values for texture card attributes on UsdGeomModelAPI schema.

  • Added exposure control to UsdGeomCamera.

  • Added ease-of-use API to UsdGeom primitives for querying the size of primary geometric properties (e.g. UsdGeomMesh::GetFaceCount).

  • Fixed plugin extent computations for primitives in UsdGeom to respect given timecode parameter. (PR: #1284)

  • Fixed crash in UsdGeomSubset::GetUnassignedIndices when a given subset had negative indices. (Issue: #1227)

  • Added UsdShadeNodeDefAPI schema to represent connectable nodes in a graph. UsdShadeShader has been modified to build off of this schema.

  • Added UsdShadeConnectableAPIBehavior to allow plugins to customize connectability by prim type.

  • Added API to retrieve material outputs for standard terminals in all render contexts on UsdShadeMaterial.

  • Added more instancing support to UsdSkel. (PR: #1258)

  • Updated UsdVol FieldAsset schemas.

  • Various documentation fixes. (Issue: #1162, PR: #1335)

Imaging

  • Added new "sourceColorSpace" input to UsdUVTexture with values "raw", "sRGB", and "auto" for better control of with which color space a texture is read.

  • Added ability to use mip maps authored in a file in the new texture system in Storm.

  • Added UsdImagingPrimAdapter::ShouldIgnoreNativeInstanceSubtrees() to allow adapters to disable instancing of itself and its descendants.

  • Added pre-multiply alpha functionality for UDIM textures. Also added sRGB internal formats for UDIMs.

  • Added checks in HioGlslfxConfig to make sure the default value for an attribute and its type match.

  • Added HdEngine::ClearTaskContextData() to avoid the task context to hold on to resources that are about to become invalid as the render delegate is destroyed.

  • Added HDST_DUMP_FAILING_SHADER_SOURCEFILE debug flag to facilitate shader debugging.

  • Added texture filepath resolution for symlinks.

  • Added an "outHitNormal" parameter to UsdImagingGLEngine::TestIntersection().

  • Added ReloadResource in Storm which reloads shader files when they change.

  • Improvements to Hgi:

    • Added Draw, DrawIndirect and DrawIndexedIndirect to Hgi and backends.
    • Added tracking of HgiCmds submission to ensure they only get submitted once.
    • Added TextureCpuToGpu copy on BlitCmd, and CopyBufferGpuToCpu to read back the GPU frustum cull results.
    • Added guarantees that HgiGLInterop will restore GL state after interop.
    • Added guarantees that Hgi GPU-GPU sync between SubmitCmds calls.
    • Added TextureView to Hgi and convert domelight to use Hgi compute and texture views.
    • Added staging buffer in Hgi to reduce the amount of times small amounts of data are copied into the same GPU buffer.
    • Added HgiPrimitiveType, and added HgiSampleCount on HgiPipelineDesc.
    • Added support for BC texture compression.
    • Added component mapping to HgiTextureDesc and implementations for GL and Metal.
    • Added ability to share HgiCmds objects in Storm.
    • Added optional wait behavior for command submission in Hgi.
  • Changed GLenum usage in GlfBaseTextureData and others to use new HioFormat.

  • Changed Storm's frustum culling to be done via a vertex shader without a fragment shader.

  • Changed HdxShadowTask to specify that it should only render opaque and masked materials.

  • Changed cards UVs from face-varying to vertex interpolated.

  • Changed to GL_SAMPLE_ALPHA_TO_ONE when using alpha to coverage, the alpha computed after the framebuffer resolve is more meaningful.

  • Changed texture cards to require prims with UsdGeomModelAPI schema applied.

  • Changed type of UsdPrimvarReader.varname input from token to string.

  • Renamed various HdStGL classes to just HdSt, this is part of the transition of Storm to support multiple rendering APIs.

  • Enabled bindless shadow maps by default in Storm.

  • On first material sync in Storm, now we try to batch prims with identical textures together.

  • HdStDrawTarget's preferred mechanism are AOVs not GlfDrawTarget's. This change allows us to remove all GlfDrawTarget support from HdStDrawTarget.

  • Since HdStDrawTarget's no longer rely on the resolve task, removing code to communicate the draw target task render passes to the resolve task.

  • Deprecated HdSceneDelegate::GetTextureResource and will eventually be removed.

  • An application can now disable the PresentTask in hdx task controller.

  • When imaging basis curves, treat empty normals array the same as missing normals (i.e. draw as tube and not ribbon at higher complexities).

  • Store HgiResourceBindings and HgiPipeline objects on HdSt resource registry.

  • Switched (most of) the GPU frustum culling code from raw GL to Hgi.

  • With the addition of HgiMetal, all platforms we currently support (for Storm) support color correction and 16F targets.

  • Use BufferResource for GPU frustum cull result buffer so we can use the regular buffer binding APIs.

  • Load mipmap data in HgiMetal textures.

  • Changed signature of HgiDataSizeOfFormat so that it can return blockWidth and blockHeight. Returning block size in bytes for compressed formats.

  • Describe shader constants (push constants) in pipeline.

  • Using HgiCompute in smooth normals computation, switched flat normals and quadrangulate to HgiCompute, and converted HdStExtCompGpuComputation to Hgi.

  • Removed UsdImaging value cache API for all data except primvar descriptors and instance indices.

  • Removed unused hitMode field from HdxPickTaskContextParams.

  • Removed UsdImagingGLEngine::InvalidateBuffers().

  • Removed pre-multiply alpha behavior from volume.glslfx and changed renderPass.glslfx to allow fully transparent but still emissive volumes.

  • Removed pre-multiply alpha behavior from stb_image and make it optional via SubtextureIdentifier within the HdSt texture system.

  • Removed support of old-style draw targets using GlfDrawTarget instead of AOVs and render buffers.

  • Removed UsdUvTexture's rgba output, and updated the cards draw mode to now use "rgb" and "a" outputs rather than rgba.

  • Removed ReloadAllShaders from HdEngine.

  • Removed HD_DRAWITEM_DRAWN as it uses raw gl calls that map/unmap a buffer.

  • Removed HgiPipelineType. We split HgiPipeline into HgiComputePipeline and HgiGraphicsPipeline a little bit ago.

  • Removed resource bindings handle from pipeline.

  • Removed smooth normals CPU fallback path. Since previous releases required OpenGL 4.5 for Hgi to work, OpenGL compute must always be available.

  • Removed HdBinding::TBO.

  • Removed the implicit barriers from Hgi and let the external client manage synchronization via SubmitCmds.

  • Fixed potential dead-lock caused by parallel loading plugins.

  • Fixed lights to be turned off when invisible in UsdImaging.

  • Fixed issue with UsdImagingGLEngine::TestIntersection such that it now correctly populates. Callers of this function are reminded to provide the "frame" field in UsdImagingGLRenderParams for correct and performant results.

  • Fixed handling of computed primvar sources for meshes.

  • Fixed normals after complexity change.

  • Fixed HgiGL garbage collector leak when Hgi is recreated during process.

  • Fixed HgiGL to better protect against long labels when using glObjectLabel.

  • Fixed render settings behaviors so we test whether or not we're really changing anything before incrementing the settings version.

  • Fixed for cycle detection in material network processing.

  • Fixed Glf lighting resource binding.

  • Fixed USD edit dependency tracking for cards prims.

  • Updated UsdPreviewSurface clearcoat calculations to better match expected inputs for a specular lobe in Storm, and added clearcoat component to indirect lighting calculation in Storm. (Issue: #1307)

  • Added support for UsdPreviewSurface's opacityThreshold parameter in Storm. (Issue: #990)

  • Added support for normal mapping for UsdPreviewSurfaces in Storm. (Issue: #701)

  • Metallic materials should have an F0 equal to their base color in UsdPreviewSurface in Storm. (Issue: #1174)

  • Removed pre-multiplication behavior from OIT resolve shader. The preview surface (and other shaders) pre-multiply within the fragment shader (unless the "diffuseColor" and "opacity" params are connected to the same texture). (Issue: #1269)

  • Added support for UDIM texture scale and bias in Storm. (Issue: #1129)

  • Converted render index to usdImaging cachePath before calling the adapter InvokeComputation method. (Issue: #1333)

  • Fix draw mode adapter handling of transforms for instanced card prims. (Issue: #1251)

  • _IsVarying no longer clears dirty bit and now ProcessPropertyChange is filled out to provide more efficiency. (Issue: #1250)

usdview

  • Added 'Enable Scene Lights' option.
  • Changed UI to use bundled Roboto and Roboto Mono fonts.
  • Fixed build issues due to stricter checks in PySide2 5.15.1. (PR: #1320)

Alembic Plugin

  • Alembic uv's are now converted to texCoord2f[] primvars:st. This can be disabled by setting the USD_ABC_WRITE_UV_AS_ST_TEXCOORD2FARRAY environment variable to 0.

RenderMan Plugin

  • Fixed infinite loop in material processing.
  • Initial implementation of exposure.
  • Volumes can react to changes to a field prim.
  • Fixed UsdUVTexture wrap mode support.
  • Add support for UsdPreviewSurface's opacityThreshold param in HdPrman. (Issue: #990)
  • Updated UsdPreviewSurface clearcoat calculations to better match expected inputs for a specular lobe in HdPrman. (Issue: #1307)
  • Metallic materials should have an F0 equal to their base color in UsdPreviewSurface in HdPrman. (Issue: #1174)

Security

[20.08] - 2020-07-21

Build

  • The "master" branch on GitHub has been renamed "release".

  • Improved error handling when building the RenderMan plugin. (Issue: #1054)

  • Various fixes and changes to build_usd.py:

    • Added --tools and --no-tools options.
    • Updated OpenImageIO (2.1.16.0) and MaterialX (1.37.1) dependencies.
    • Specifying --embree will now build the Embree library. The --embree-location parameter has been removed.
    • CMake 3.14 is now required on Windows to support boost 1.70+.
    • Python 3.8 on Windows now causes an error, as USD does not support this version on Windows.
    • Improved handling of boost build failures.
    • Fixed locale decoding errors. (Issue: #1165)
    • Fixed incorrect detection of Draco library. (PR: #1239)

USD

  • Added support for "future division" in Python 2 to aid transition to Python 3.

  • Added ArResolver::CreatePathForLayer to allow users to customize behavior when writing a layer. SdfLayer now uses this method instead of creating a directory, which was not appropriate for non-filesystem uses. (Issue: #1148)

  • Added SdfReference::IsInternal. (PR: #1204)

  • Added fallback prim types feature, allowing clients to specify alternative schemas to use if a schema can't be found. See documentation for more details.

  • Added UsdPrim::ApplyAPI, RemoveAPI, AddAppliedSchemas, and RemoveAppliedSchemas. (Issue: #1218)

  • Added Python repr for generated schemas.

  • Added methods to UsdGeomPrimvar for processing property names.

  • Added methods to UsdGeomPrimvarsAPI for creating, removing, and blocking primvars. (Issue: #1100)

  • Improved documentation for UsdVol schema domain. (PR: #1203)

  • Improved documentation for UsdGeomMesh. (PR: #1254)

  • Improved diagnostic messages for plugin registration and loading.

  • Plugin search paths in PXR_PLUGINPATH_NAME can now be a symlink. Paths are now processed in order to ensure plugins in earlier entries take priority over those in later entries.

  • Replaced SdrShaderNode::GetSourceURI and GetResolvedSourceURI with GetResolvedDefinitionURI and GetResolvedImplementationURI to properly represent RenderMan C++ shaders.

  • Time sample times from layers whose timeCodesPerSecond value differ from the UsdStage are now automatically scaled to match. This can be disabled by setting the PCP_DISABLE_TIME_SCALING_BY_LAYER_TCPS environment variable, but we expect to remove this in a future release.

  • Significant changes and additions to value clips functionality. See documentation for more details:

    • Added support for jump discontinuities in clip times metadata to encode looping behaviors.
    • The clip manifest is now used to determine which attributes have values in clips. The manifest will be generated in-memory at runtime if one hasn't been specified.
    • Value resolution will no longer fall through to weaker layers if a clip does not have values for an attribute declared in the manifest. In these cases, the value may come from the default value authored in the manifest or (optionally) be interpolated from surrounding clips.
    • Removed support for legacy value clips metadata.
    • Fixed numerous bugs, including incorrect time samples when reversing clips. (Issue: #1116)
  • Changed the strength ordering of entries in the apiSchemas metadata to be strongest-to-weakest, matching the ordering of references and other fields.

  • Constructing a UsdGeom::XformOp with an invalid attribute is no longer a coding error for consistency with other schemas and objects.

  • Deprecated many schemas in UsdRi in preparation for modernization efforts in a future release.

  • Removed support for deprecated "hermite" and "power" basis from UsdGeomCurves.

  • Fixed crash when removing many entries from an SdfPathTable. (PR: #1172)

  • Fixed compile error due to missing virtual destructor for PcpDynamicFileFormatInterface. (PR: #1156)

  • Fixed type conversions when setting metadata values using dictionaries in Python. (Issue: #813)

  • Fixed handling of stage metadata and session layer muting in UsdStage.

  • Fixed UsdFlattenLayerStack to handle mismatched attribute types and time-sampled asset paths. (PR: #1169)

  • Fixed undefined behavior issue with iterator comparisons. (Issue: #1146)

  • Fixed regression in handling of inherited bindings in UsdSkelCache.

  • Fixed crash in UsdSkelBakeSkinning. (PR: #1213)

Imaging

  • Updated minimum required version of OpenGL to v4.5.

  • Added new texture system to Storm. This enables multi-threaded texture loading, uses Hgi, and frees the scene delegate from having to load textures. In a performance test using Nvidia's Attic scene, time to first image dropped by ~90%, from 115s to 10s.

  • Added first iteration of HgiMetal, a Metal-based Hgi implementation for Apple platforms. Currently, Hgi is used in several Hydra tasks to perform tasks like blitting, the goal is to slowly integrate Hgi in Storm.

  • Numerous updates to Hgi:

    • Added HgiInterop to exchange rendered results between GL-GL or Metal-GL.
    • Added HgiSampler to represent texture samplers.
    • Added HgiComputeCmds to issue compute commands.
    • Added HgiBlitCmds for mipmap generation and GPU-GPU copy.
    • Added SRGB format and removed unsupported 24-bit formats.
    • Added GetRawResource function to various resource objects to expose low-level resource handles.
  • Added garbage collection to HgiGL for proper handling of resource destruction.

  • Added HdRendererPluginHandle, an RAII object for managing plugin lifetimes.

  • Added HdxAovInputTask which takes HdRenderBuffer and (if needed) uploads it to the GPU as HgiTexture.

  • Added support for down-sampling volumes in Storm.

  • Improved performance of volumes in Storm by not re-creating the entire volume shader when fields are animated.

  • Added support for UsdTransform2d node in Storm. (Issue: #1207)

  • Added support for UsdUVTexture scale and bias in Storm. (Issue: #1129)

  • Added USDIMAGINGGL_ENGINE_DEBUG_SCENE_DELEGATE_ID environment variable to specify scene delegate ID for debugging. (Issue: #1093)

  • Changed default version of HdSceneDelegate::GetScenePrimPath to strip delegate ID.

  • Replaced obsolete GL_GENERATE_MIPMAP with glGenerateMipmap. (Issue: #1171)

  • Added support for uint16 type for GL textures and OpenImageIO. (PR: #1212)

  • Restructured OpenImageIO support as a plugin to Glf. (PR: #1214)

  • Converted common Hydra tasks (e.g. HdxColorCorrectionTask, HdxPresentTask, HdxColorizeSelectionTask) to use Hgi.

  • Renamed HdxProgressiveTask to HdxTask.

  • Storm now uses Hgi for buffers, shaders, and programs instead of OpenGL.

  • HdStResourceRegistry is instantiated once per Hgi instance in Storm.

  • Unshared computation BAR are reused when possible. (Issue: #1083)

  • Improved handling of invalid cases in several areas. (PR: #1232, PR: #1201)

  • Improved performance of UsdImagingDelegate::SetTime. (Issue: #1166)

  • Improved performance for displaying meshes with large numbers of geometry subsets. (PR: #1170)

  • Normals are ignored on skinned meshes so they are computed post-skinning.

  • Inherited UsdSkel bindings are now respected.

  • Allow HdStRenderBuffer::Resolve() to change the size of the image. (PR: #1236)

  • Removed "catmark" token in pxOsd in favor of "catmullClark".

  • Removed UsdImagingGLMaterialTextureAdapter, UsdImagingGLDomeLightAdapter, GlfVdbTexture[Container], and GlfTextureContainer, which are unneeded with the new texture system.

  • Removed unused HdxColorizeTask and HdxFullscreenShaderGL.

  • Removed HdWrapLegacyClamp, which corresponded to the deprecated GL_CLAMP.

  • Removed uses of HdStGLSLProgram as part of a new strategy to create these via HdStResourceRegistry (since it has access to Hgi).

  • Removed transform feedback from non-instanced GPU culling in Storm.

  • Fixed incorrect handling of buffer array resizing to 0 elements. (Issue: #1230)

  • Fixed memory regression when calling UsdImagingDelegate::SampleTransform and SamplePrimvar.

  • Fixed error in UsdImaging when changing from a time where a mesh provided points or normals to a time that does not.

  • Fixed potential deadlocks if plugins were loaded at various points in UsdImagingGLEngine.

  • Fixed error when processing skinned prim with no joint influences.

  • Fixed change processing issue with native instanced prims. (Issue: #1163)

  • Fixed handling of widths primvar with no value.

  • Fixed "IsFlipped" computation for native instanced prims. (Issue: #1190)

  • Fixed crash when updating a removed primvar. (PR: #1223)

  • Fixed crash when reparenting an instance root. (Issue: #1245)

  • Fixed various issues with cards prims, including a crash issue. (Issue: #1210)

  • Fixed selection encoding/decoding of invisible native instances.

  • Fixed invalidation when changing the "purpose" attribute. (Issue: #1243)

usdview

  • Added "Prototypes" pick mode that selects the prototype for a picked gprim in a PointInstancer and highlights the picked instance.
  • Reverted "Prims" and "Instances" pick modes to original behavior of selecting the root boundable of the picked object. (Issue: #1196)
  • Fixed "Reopen Stage" when usdview was launched with --norender. (PR: #1192)
  • Fixed camera guide and reticles rendering on high DPI displays.

Alembic Plugin

  • Fixed conversion of mesh subdivision interpolation options between UsdGeomMesh and AbcGeom's ISubD and OSubD schemas. (PR: #1246)

Embree Plugin

  • Removed support for Embree 2.0. The HdEmbree plugin now requires Embree 3.

MaterialX Plugin

  • Added support for MaterialX 1.37 and deprecated support for 1.36. We anticipate requiring 1.37 in a future release.
  • MaterialX "vectorN" datatypes are now translated to USD "floatN" datatypes.
  • Changed default output name from "result" to "out" to match conventions in MaterialX specification.
  • Fixed test issue found during Python 3 work. (PR: #1161)

RenderMan Plugin

  • Added support for arbitrary numbers of AOVs in HdPrman.

  • Removed deprecated RenderMan 22 Hydra plugin.

  • Material processing now uses SdrShaderNode::GetResolvedImplementationURI to locate shaders, which allows it consume shaders identified via UsdShadeShader's info:sourceAsset property.

  • Modified UsdVol support to allow easier extensions with custom volume plugin for RenderMan.

  • Fixed calculation of specularFaceColor in UsdPreviewSurfaceParameters.osl to better match the spec.

[20.05] - 2020-04-13

This release includes initial support for Python 3. Many thanks to our collaborators at Nvidia and SideFX for all of their work to make this happen!

The RenderMan 22 Hydra plugin is deprecated, and the deprecated Houdini and Katana plugins have been removed from the repository. See details below.

Build

  • Added support for Python 3. This may be enabled by specifying PXR_USE_PYTHON_3=TRUE when running cmake or by running build_usd.py with Python 3.

  • Updated C++ standard version to C++14 per VFX Reference Platform CY2018.

  • Updated CMake minimum version to 3.12. 2.x support was deprecated in 19.11.

  • Moved to Azure Pipelines for CI.

  • PySide2 is now preferred over PySide if both are installed. Users can specify PYSIDE_USE_PYSIDE=TRUE when running cmake to force the use of PySide.

  • Building examples and tutorials is now optional. (PR: #594)

  • Various fixes and changes to build_usd.py

    • Updated TBB (2017.6), Alembic (1.7.10), OpenImageIO (1.8.9), and OpenColorIO (1.0.9) dependencies for VFX Reference Platform CY2018 and/or to reflect versions used for testing internally.
    • Updated OpenSubdiv to 3.4.3. This removes the dependency on GLFW, which itself required X libraries on Linux. (Issue: #261)
    • Miscellaneous fixes. (Issue: #1110, Issue: #1126)
  • Made OpenEXR an optional dependency. It is only required for enabling OpenImageIO, OpenVDB, or OSL support. (PR: #1082)

  • Fixed strict builds on Linux when building with boost version 1.61 or earlier. (PR: #1081)

  • Fixed issue where warnings from 3rd-party headers would cause strict builds to fail.

  • Fixed bug where the boost_python library would not be found when building against boost 1.67+.

  • Fixed bug where specifying PXR_BUILD_DOCUMENTATION=TRUE but not having required programs would result in an incomplete build. (Issue: #1127)

  • Fixed incorrect instructions in README.md for running build_usd.py under Visual Studio 2017. (PR: #1120)

  • Fixed bug where build_usd.py would pick up external builds of boost 1.70 or later. (Issue: #1071)

  • Fixed bug in build_usd.py when building boost with Visual Studio 2019. (Issue: #1041)

  • Fixed issue where non-debug builds with Visual Studio 2019 would not work properly or crash immediately. (Issue: #1095)

  • Fixed several issues that caused errors when building a program against USD with clang on Windows. (Issue: #1030, PR: #1079)

  • Fixed issue where debug mode builds on Windows with Python bindings enabled would fail without a special debug build of Python. (PR: #785, Issue: #1006)

USD

  • Added typed value proxies to VtValue.

  • Added SdfPathAncestorsRange for iterating over an SdfPath's ancestors.

  • Added convenience scenegraph object accessor APIs to UsdPrim and UsdStage.

  • Added UsdPrim::GetInstances to get all instances of a master. (Issue: #962)

  • Added UsdPrimDefinition to represent the built-in properties of a given prim. Users can access a prim's definition via UsdPrim::GetPrimDefinition.

  • Added UsdUtilsConditionalAbortDiagnosticDelegate, a diagnostic delegate that aborts when an error or warning is encountered based on text-matching rules.

  • Added UsdUtilsSparseValueWriter::GetSparseAttrValueWriters to help with debugging. (PR: #1038)

  • Added UsdGeomHermiteCurves schema.

  • Deprecated 'hermite' and 'power' basis for UsdGeomBasisCurves.

  • Removed remnants of relationship-based shader encoding from UsdShade schemas.

  • Removed "shadow:include" and "shadow:exclude" from UsdLuxShadowAPI schema.

  • Removed raw spec access API from UsdSchemaRegistry in favor of the new UsdPrimDefinition objects.

  • For static USD builds, the Plug library now resolves plugin paths relative to the path of the executable that links to USD.

  • SdfLayer and UsdStage API for timeCodesPerSecond now fall back to using framesPerSecond if no timeCodePerSecond is specified.

  • Numerous optimizations for UsdStage load time and authoring speed.

  • UsdStage now sends notification when population mask, load rules, and interpolation type are changed. (Issue: #1139)

  • Applied API schemas now impart their properties and fallback values as builtins on the applied prim.

  • Concrete typed schemas can now provide fallback metadata values.

  • C++ typenames for schemas are no longer supported as prim typenames in scene description.

  • UsdGeomImageable now computes 'purpose' using non-pruning semantics. See documentation for UsdGeomImageable::ComputePurpose for a description of the new behavior.

  • Various fixes and changes for usdGenSchema

    • Added --headerTerminatorString option. (Issue: #1092, PR: #1097)
    • Output directory automatically created if it doesn't already exist.
    • Changed output in generatedSchema.usda for multiple-apply API schemas.
    • Changed output ordering for tokens in tokens.h.
  • Fixed race condition in UsdGeomBoundable::ComputeExtentFromPlugins that could cause incorrect results for bounds computations.

  • Fixed bug with value block handling in UsdFlattenLayerStack.

  • Fixed incorrect documentation on crate file structure. (Issue: #1072)

  • Fixed change processing bug for nested instancing that led to crashes.

  • Fixed bug reading .usdc files in .usdz files if USDC_USE_PREAD=1 was set.

  • Fixed usdedit failure on Windows due to file access conflicts. (PR: #1094)

  • Fixed line ending issue causing some tests to fail on Windows. (PR: #848)

Imaging

  • Added swizzle metadata to the output of UsdUVTexture. (Issue: #657)
  • Added ability to display unloaded prims as bounding boxes. (PR: #1145)
  • Added selection highlight outline capabilities (not exposed in usdview).
  • Added many more improvements to volume visualizations in Storm.
  • Added basic support for transporting pinned curves to UsdImaging.
  • Added support for computed vertex primvars for points prim in Storm.
  • Added support for element invising and point colors in basis curves.
  • Added hdTiny, a very simple example render delegate.
  • Added support for cascaded shadow maps (not exposed in usdview).
  • Added IsStopSupported/Stop/Restart APIs to render delegates.
  • Added transport of light filters through usdImaging.
  • Added HdResourceRegistry::ReloadResource API to allow for texture reloading.
  • Added USDVIEW_OCIO_LUT3D_EDGE_SIZE environment variable for setting 3D LUT size for OpenColorIO.
  • Removed IsFlipped() from certain Storm shaders for clean up.
  • Many changes to remove or replace uses of boost with C++ features.
  • Changed many APIs in Hgi as that subsystem continues to be built up.
  • Changed HdResourceRegistry APIs for several cleanups and fixes.
  • Replaced HdSceneDelegate::GetPrimPathForInstanceIndex with GetScenePrimPath.
  • Moved HdMaterialParam to HdSt and made it private.
  • Moved HdxSimpleLightingShader to HdSt.
  • Fixed issue with Storm shutdown on certain platforms.
  • Fixed several issues with selection highlighting (including issues relating to instancing) in usdImaging.
  • Fixed issue with Storm not drawing geometry when a PxrSurface is attached. (Issue: #1128)
  • Fixed issue where UsdUVTexture alpha output was driven by the wrong channel. (Issue: #657)
  • Fixed drawing of sphere implicit to be centered. (Issue: #1086)
  • Fixed handling of primvar addition and removal in Hydra. (Issue: #1078)
  • Fixed .glslfx processing to use Ar for resolving paths for includes.
  • Fixed parsing of texture default values for .glslfx files in Sdr.
  • Fixed issue with texture binding with certain configurations. (Issue: #1063)
  • Fixed several cleanup issues. (Issue: #1103, PR: #1104)
  • Fixed order of draw targets drawing in HdxDrawTargetTask.
  • Fixed default values for displayColor, displayOpacity and widths. (PR: #1098)
  • Fixed point instancer resync of prototypes. For example, we now resync prototypes properly if their material bindings change.
  • Fixed point instancer refresh in response to structural primvar and prototype updates. (PR: #1077)
  • Fixed HdRenderIndex::Clear to always call Finalize() for cleared rprims. (Issue: #1040)
  • Fixed color banding issue when using OpenColorIO.
  • Fixed reading stride with OpenImageIO. (Issue: #1080)
  • Fixed drawMode updates with native instancing. (Issue: #1069)
  • Fixed case sensitivity for image loading. (PR: #804)
  • Fixed issue with Storm shader generation when input and primvar names match.
  • Fixed debug flag not properly displaying source when shader fails to link. (PR: #1020)

usdview

  • Added ability to change font size.
  • Added 'Apply' button to renderer settings dialog.
  • Improved start up time by waiting until we've populated more of the UI.
  • Made free-cam's FOV part of saved user settings.
  • Fixed multi-line paste in the interpreter. (Issue: #1117)
  • Fixed errors when using PySide2 5.14.0 or later. (Issue: #1111)
  • Fixed errors when closing usdview with the native windowing system commands.

Alembic Plugin

  • Added file format arguments 'abcReRoot' for reparenting hierarchy beneath a new parent prim and 'abcLayers' for specifying a list of secondary files to load as layered Alembic. (PR: #1099)
  • Only deliver interesting timeSamples for constant properties. (PR: #1114)
  • Relaxed type-checking on position property and let any float[3] type through. (PR: #1115)
  • Removed need to link directly against Alembic backend libraries to open files.

Houdini Plugin

  • The Houdini plugin has been removed from the USD repository in favor of the native USD support in Houdini's Solaris suite.

Katana Plugin

MaterialX Plugin

  • Fixed bug where implementation file relative paths were assumed to be relative to the .mtlx file with the implementation node instead of to the MaterialX library itself.

RenderMan Plugin

  • Deprecated support for RenderMan 22. We anticipate removing the renderman-22 plugin in a future release.
  • Added support for HdAov clearValue.
  • Added support for Stop/Restart functionality.
  • Added early initial support for light filters and trace groups.
  • Fixed bug that caused empty renders when no scene camera was present. (Issue: #1113)
  • Fixed routing of ri:attributes properties when instancing is involved.
  • Fixed restarting of RenderMan when application is told that resources (e.g., textures) need to be reloaded.

[20.02] - 2020-01-24

We anticipate aligning with the version requirements from the VFX Reference Platform CY2018 (https://vfxplatform.com) in the next release. In particular, this includes requiring support for C++14.

This release adds a Hydra plugin for RenderMan 23 and removes the deprecated Maya plugin from the repository. This release also deprecates support for the Houdini and Katana plugins. See details below.

Build

  • The source tree has been restructured so that code no longer lives under a separate "lib" directory. This means that (with a few exceptions) include paths now match source tree paths.

  • Added support for Visual Studio 2019 to build_usd.py. (PR: #1042)

  • Added PXR_BUILD_USD_TOOLS option to disable building of command-line tools (e.g. usdcat, usdedit) (PR: #1048)

  • The PXR_LIB_PREFIX option now defaults to "" and is respected for .lib files on Windows. (Issue: #1027)

USD

  • Added "subIdentifier" and "sourceType" parameters to GetNodeFromAsset API in Ndr and Sdr and "subIdentifier" attribute to UsdShadeShader schema. This allows clients to identify and retrieve definitions for a particular shader in source assets that have multiple shaders defined in them. (Issue: #919)

  • Removed unused legacy SdfVariabilityConfig variability value.

  • Fixed bug where prims in masters would be populated incorrectly when a UsdStage's population mask contained paths descendant to masters.

  • Fixed bug where layer stack flattening would lose some variant selections. (Issue: #1060)

  • UsdStage::CreateClassPrim is no longer restricted to root prims. (Issue: #994)

  • UsdVariantSets::GetNames() now returns the union of all variant set names across layer stacks.

  • Improved performance of retrieving metadata with templated API in UsdObject.

  • Numerous changes to improve performance when making edits to many properties.

  • Removed support for inverse layer offsets which were deprecated in v0.8.2.

  • Removed support for legacy UsdShade encodings, yielding cleaner code and improved performance.

  • Improved diagnostics in usdGenSchema for non-identifier tokens in schema.usda.

  • Improved documentation generated by usdGenSchema for schema attributes.

  • usdGenSchema now treats all C++ and Python keywords as reserved and will prepend a "_" if they are encountered in any identifiers.

  • Modified UsdGeomXformCommonAPI to be generated and behave like other API schemas (as the name implies) for consistency.

  • Fixed bug in UsdGeomImageable::MakeVisible where the given prim would not be made visible if other "invis" opinions existed on ancestor prims. (PR: #1043)

  • Fixed bug in UsdGeomSubset::GetUnassignedIndices where passing in an invalid element count could lead to a crash. (Issue: #989)

  • Removed deprecated shader binding API on UsdShadeMaterial in favor of UsdShadeMaterialBindingAPI schema.

  • Improved fidelity of light-related UsdRi schemas.

  • Added UsdLuxDomeLight::OrientToStageUpAxis utility for creating dome lights with an appropriate default orientation. (Issue: #938)

  • Added UsdMedia schema library and UsdMediaSpatialAudio schema.

  • Fixed bugs in UsdSkelCache::ComputeSkelBinding where inherited skel:skeleton bindings were incorrectly evaluated and bindings would be returned for inactive prims.

  • Python binding for UsdSkelSkinningQuery is now UsdSkel.SkinningQuery.

Imaging

  • Added RenderMan 23 Hydra plugin.
  • Added support for specifying thread limits and convergence criteria in HdPrman via settings.
  • Added initial support for light filters.
  • Added an Sdr parser plugin for .glslfx files.
  • Added support for material networks in Storm.
  • Added initial support for volume rendering in Storm.
  • Added basic support for bindless shadow maps in Storm.
  • Added primvar/points editing support for points, basis curves, and meshes in UsdImaging. Previously everything was resync.
  • Added Hydra changetracker dependencies between parent and child instancers.
  • Added new task HdxColorChannelTask to output a specific display channel.
  • Added command line option (--traceToFile) to usdview to start tracing as soon as the application is started.
  • Changed HdPrman linking to be independent of RenderMan install.
  • Changed "depth" AOV range from [-1, 1] to [0, 1].
  • Changed name "linearDepth" AOV to "cameraDepth".
  • Changed HdxPickHit "ndcDepth" field with a range of [-1,1] to "normalizedDepth" with a range of [0,1]
  • Changed edge hashing to use triangular numbers in Hd. This is about 3x faster than the previous code.
  • Changed UsdImaging's DrawModeAdapter to use HdMaterialNetwork.
  • Changed default camera shutter in UsdImaging to match UsdGeomCamera [0,0].
  • Improved Storm's instance registry and moved resource registries from Hd core to Storm.
  • Improved aggregation of material shaders in Storm.
  • Improved material primvar filtering in Storm.
  • Improved property refresh support in UsdImaging for instance attributes.
  • Removed HydraMaterialAdapter in UsdImaging since it is no longer needed.
  • Removed old Hydra scene delegate API that was only used by the old material system in Storm. (GetSurfaceShaderSource, GetDisplacementShaderSource, GetMaterialParams and others..).
  • Fixed instance adapter selection highlighting performance issues.
  • Fixed bug where pick task was continuously running in usdview.
  • Fixed Storm to skip string primvars.
  • Fixed bug where rtx_glfImage was not honoring the channel offset and number of channels specified in the FillRequest parameter.
  • Fixed nullptr exception in HdPrman when rendering without a camera.
  • Fixed data ownership of instance indices. DirtyInstanceIndex is set on instancers and tells them they need to re-fetch their index buffer, relative to one of their prototypes.
  • Fixed UsdImaging native instancing so instead of compensating for prototype transforms by overwriting prototype transforms, it compensates in the per-instance transform primvar.
  • Fixed usdSkelImaging dirtyness propagation to the skinning aggregator computation.
  • Fixed double color correction on MacOS.
  • Implemented SamplePrimvar for native instancer adapter. (Issue: #996)
  • Fixed UsdPreviewSurface material displacement in Storm. (Issue: #922, Issue: #1026)
  • Fixed change processing when an inherited primvar is removed. (Issue: #1004)
  • Fixed incorrect points buffer computation for implicit geometry. (Issue: #1024)
  • Added GetHgiTextureHandle API on renderbuffer to avoid HdSt dynamic_casts and CPU -> GPU copies during post-process pipeline (Issue: #1008)
  • Fixed TBB library linkage in hdEmbree. (PR: #991)
  • Added support for 'jpeg' extension for Glf_StbImage. (PR: #998)
  • Fixed bug where time-invariant geometry subsets would mask time-varying topology from Hydra. (PR: #1045)
  • Fixed bug where UsdGeomSubset indices were always retrieved at the default time. (PR: #1059)
  • Fixed incomplete handling of UsdGeomMesh face-varying options. (PR: #1061)

Houdini Plugin

  • Deprecated Houdini plugins in favor of Houdini-native USD support. We anticipate removing the plugin from the USD repository in a future release.
  • Additional changes for Houdini 17.5 compatibility.

Katana Plugin

  • Deprecated Katana plugin in favor of the Foundry-supported Katana plugins available at https://github.com/TheFoundryVisionmongers/KatanaUsdPlugins. We anticipate removing the plugin from the USD repository in a future release.
  • Changed how UsdGeomBasisCurve Widths and Normal attributes are read into Katana. Author either a geometry.point.* entry (old behavior) or a geometry.arbitrary.* entry (new behavior) based on the attribute's interpolation.
  • Changes in preparation for reading UsdShadeMaterials which contain UsdShadeNodegraph subgraphs.
  • Removed custom Viewer Modifier Plugins. These were used by Katana's legacy Viewer tab, which has been replaced by the Hydra Viewer tab.
  • Removed support for /LooksDerivedStructure in USD shader libraries.
  • Fixed incorrect geometry.instanceSource attribute for nested instances. (PR: #1015)

MaterialX Plugin

  • Added support for versions 1.36.3 and later.

Maya Plugin

[19.11] - 2019-10-18

This release deprecates support for cmake 2.x and the Maya plugin. See details below.

Build

  • Deprecated support for cmake 2.x. We anticipate requiring cmake 3.x in the next release.
  • build_usd.py now fails if using 32-bit Python, which is a common gotcha on Windows. (Issue: #921)
  • Fixed issue where build_usd.py would fail to build TBB on MacOS if CUDA was installed due to an issue in the TBB build system. (Issue: #767)
  • Made PXR_VERSION a valid and comparable integer in C++. (PR: #886)
  • Fixed issue where pxrTargets.cmake would include plugins with no exported symbols. This caused errors when building against USD on Windows. (Issue: #530)
  • Fixed issue where downstream cmake projects using pxrTargets.cmake could not find the USD headers.

USD

  • Added warning when reading a .usda layer with size in MB greater than value of SDF_TEXTFILE_SIZE_WARNING_MB environment variable. (PR: #980)

  • Added UsdStageLoadRules to support more robust and declarative intent about how payloads should be included in a UsdStage.

  • Added UsdPrimCompositionQuery to facilitate discovery of composition arcs affecting a UsdPrim.

  • Added "timecode" scene description value type. This type is represented by the SdfTimeCode class and can be used for attribute and metadata values. Layer offsets are applied to all timecode values during UsdStage value resolution, enabling "timing curve"-like attributes.

  • Added support for Google's Draco compression library. This includes an SdfFileFormat plugin for reading .drc files and a standalone "usdcompress" tool that extracts and compress Mesh primitives from a USD file, creates .drc files for each one, and references them back into a result USD file. (PR: #912)

  • Added --quiet flag to usdGenSchema for suppressing output. (PR: #480)

  • Added --brief flag to usddiff so differing lines are not printed.

  • Added support for indexed uint primvars to UsdGeomPrimvar. (PR: #861)

  • Added "accelerations" attribute to UsdGeomPointInstancer schema and updated UsdGeomPointInstancer::ComputeInstanceTransformAtTime(s) to account for authored accelerations, if present.

  • Added "accelerations" attribute to UsdGeomPointBased schema and added UsdGeomPointBased::ComputePointsAtTime(s) to compute point positions using authored velocities and accelerations, if present.

  • Added initial version of UsdRender domain and schemas. See documentation and white paper on openusd.org for more details. (Issue: #910)

  • Added UsdShadeInput::GetValueProducingAttribute to facilitate more robust and correct processing of UsdShade shading networks.

  • Added initial support for skinning mesh normals in UsdSkel.

  • Removed SdfAbstractDataSpecId and updated the SdfAbstractData interface to use SdfPath in its place. Existing SdfAbstractData subclasses must be updated to match. See this usd-interest post for more details: https://groups.google.com/forum/#!topic/usd-interest/IVmd1t1GKBA

  • Numerous fixes for C++14 / gcc6 warnings. (PR: #869)

  • Various optimizations and cleanups in trace library.

  • Inherits and specializes arcs that target root prims ("global" arcs) are now combined with arcs that target sub-root prims ("local" arcs) for strength ordering in composition. Previously, local arcs would always be considered stronger than global arcs regardless of their authored order.

  • Calling UsdReferences::SetReferences (and equivalent API on UsdPayloads, UsdInherits, and UsdSpecializes) with an empty vector now authors an explicit empty list op instead of being a no-op. (Issue: #749)

  • Numerous fixes and changes to Sdr and associated parser plugins. This includes the addition of a "terminal" property type and "role" and "renderType" metadata to better describe shader properties and their representation in scene description.

  • Numerous optimizations for UsdStage load time and authoring speed.

  • Improved performance of adding empty sublayers to an existing UsdStage.

  • USD native instancing now includes both LoadRules and PopulationMasks in instancing keys, so different instances can have different load state. Instances that have equivalent load rules and population masks still share, but those that do not will use different masters.

  • Load/Unload operations on a UsdStage now must operate on the "expanded" stage namespace. That is, the namespace as it would be if instancing was disabled.

  • Updated UsdLuxDomeLight schema to clarify a dome light's orientation and its textures' orientation. (Issue: #938)

  • Changed 'pointIndices' attribute on UsdSkelBlendShape schema from uint[] to int[] for consistency with other core schemas. (Issue: #858)

  • Rewrote UsdSkelBakeSkinning to provide a more efficient baking solution.

  • Fixed bug where converting .usdc files from version 0.7 to 0.8 when saving an existing file would produce incorrect layer offsets in payloads.

  • Fixed crashes when calling methods on invalid Usd.SchemaBase objects in Python. (Issue: #872, PR: #876)

  • Fixed crash when muting and unmuting layers on a UsdStage. (Issue: #883)

Imaging

  • Renamed the real-time engine/rasterizer to "Storm"

  • Added support for dome lights in Storm.

  • Added support for screen-space adaptive tessellation and drawing for Loop scheme subdivision surface meshes when using OpenSubdiv 3.4 in Storm.

  • Added basic support for AOVs in Storm. In usdview, you can now switch between color and depth when using Hydra Storm.

  • Added Hgi (Hydra Graphics Interface) library. Hgi abstracts away graphics API calls in Storm.

  • Added HgiGL library, an OpenGL backend implementation for Hgi.

  • Added support for vstructs in Hydra RenderMan plugin.

  • Added support for light attributes in UsdImaging and Hydra RenderMan plugin.

  • Added an adapter in UsdImaging to read camera information, including custom camera parameters.

  • Added support for physical camera parameters in Hydra and Hydra RenderMan plugin.

  • Added support for camera motion blur in Hydra RenderMan plugin.

  • Added support to read any number of time samples authored in Usd. Improved Hydra API to allow render delegates to extract any number of samples from scene delegates.

  • Added API to HdRenderDelegate and the render thread to pause and resume renderers if supported. Updated Hydra RenderMan plugin to support it. (PR: #888)

  • Added API to HdRenderDelegate to return render stats to the client. Updated Hydra Embree to expose the number of samples completed this way. (PR: #888)

  • Added element/scope selection highlighting for raytraced backends.

  • Added basic support for NURBS curves to UsdImaging. For now, it will send them to the render delegate as basis curves.

  • Added support for UsdShadeNodeGraph to UsdImaging.

  • Added support for acceleration primvars in UsdImaging and Hydra.

  • Added support for inherited primvars to native instances.

  • Added instance-inheritance support for string-typed primvars.

  • Added convergence criteria to render settings in Hydra RenderMan.

  • Added support for basis curves instancing in Hydra RenderMan plugin.

  • Added support for OpenImageIO's IOProxy feature to allow supported image files (such as .exr) to be read from .usdz files.

  • Added "Set As Active Camera' on USD camera prims context menu in usdview.

  • Added a "Pause" menu item to usdview, and display the render status message.

  • Replaced the key/fill/back lights in usdview by a dome light, still only works in Storm for now.

  • Deprecated old material accessors on HdSceneDelegate in favor of using material networks in Storm.

  • Removed TrackVariabilityPrep/UpdateForTimePrep in UsdImaging.

  • Moved usdShaders from usdImaging/lib to usdImaging/plugin.

  • Moved rendererPlugin and rendererPluginRegistry from hdx to hd.

  • Moved UsdPreviewSurface conversion to the MatfiltFilterChain in Hydra RenderMan plugin.

  • Changed return type of HdRenderBuffer::Map from uint8_t to void*.

  • Improved handling of invalidations and edits of data such as instancers, primvars and others, in UsdImaging.

  • Improved 32 bit color support when using Hydra and the default task controller.

  • Improved draw item batching in Hydra Storm. (PR: #528)

  • Improved GLSL error reporting in Storm.

  • Improved usdrecord to allow more consistent results with usdview (e.g., default materials, purpose).

  • Prim browser in usdview now maintains its expansion-state and view when the stage recomposes.

  • Prim browser in usdview now behaves more like Maya's outliner with respect to viewport selections: the PrimView will no long expand/scroll to display the selected prim until you use the 'f' hotkey over it to frame the selection. Instead, all of the ancestors of selected prims will be highlighted in a secondary color.

  • Searches in the usdview prim browser begin at the currently selected prim rather than at the root of the scene.

  • Made usdview panes easier to resize by doubling size of splitter lanes.

  • Made usdview timeline playhead much larger to make it easier to grab.

  • Fixed inheriting primvars through instance boundaries when the primvar is an array.

  • Fixed the way UsdGeomPointInstancer calculates purpose and visibility across instance/master boundaries.

  • Fixed memory leak for draw items in Storm.

  • Fixed handling infinite bounds explicitly during GPU frustum culling in Storm.

  • Fixed UsdShadeShader material invalidations in UsdImaging.

  • Fixed handling of topology changes for basis curves in Storm.

  • Fixed ortho camera handling in Hydra RenderMan plugin.

Houdini Plugin

  • Added general methods for converting between USD values and GA_Attribute data.

  • Fixed missing usdSkel dependency. (PR: #827)

  • Detect skinning influences stored as detail attribs when converting to capture attributes. This allows rigid shapes to be coalesced into deforming agent shapes.

Katana Plugin

  • Point instancers with velocities now get motion blur on the first frame, even if their positions are not sampled at any previous frames.

  • Katana paths are now better aligned with USD paths when possible for point instancer prototypes.

  • Includes "prmanLightParams.iesProfileNormalize" when reading UsdLux lights in as RenderMan representations

  • Fixed bug where per-instance primvar values on point instancers could be inherited by the prototype geometry, causing warnings about mismatched sizes. (Issue: #893)

MaterialX Plugin

  • Fixed bug when reading a .mtlx file with more than 1 bindinput. (Issue: #950, PR: #956)

Maya Plugin

  • Deprecated Maya plugin in favor of the Autodesk maya-usd plugin available at https://github.com/Autodesk/maya-usd. We anticipate removing the plugin from the USD repository in the next release and recommend users begin transitioning to the Autodesk plugin -- it contains the same features as the Pixar plugin (in fact, it is the same code).

  • FindMaya.cmake module on MacOS (once again) supports paths that include the "Maya.app/Contents" subdirectory when specifying MAYA_LOCATION. (PR: #878)

  • Visibility for Maya point instancers is now exported to UsdGeomPointInstancer.

  • Maya "stroke" nodes are now exported as UsdGeomBasisCurves. (Issue: #867)

  • Various bug fixes and cleanup.

[19.07] - 2019-06-17

Build

  • Improved detection of GLEW and Ptex libraries during build. (PR: #808)
  • Fixed bug in build_usd.py that caused errors when specifying the "Xcode" CMake generator.

USD:

  • Various optimizations and cleanups in trace library.
  • Added iterator-based construction for VtArray. (PR: #644)
  • Added Python bindings for ArResolver::RefreshContext. (PR: #820)
  • Fixed incorrect results from NdrRegistry::GetAllNodeSourceTypes.
  • Removed unused spec types from Sdf.
  • Reimplemented SdfPath. The new implementation dramatically improves the performance of creating property paths, which is a key part of value resolution.
  • SdfFileFormat::IsStreamingLayer was moved to SdfAbstractData::StreamsData. SdfAbstractData implementations are now responsible for expressing whether they stream data from their back-end instead of SdfFileFormat.
  • Added file format arguments to SdfLayer::CreateAnonymous to match CreateNew.
  • Fixed bug where strings in scene description that look like format specifiers would be interpreted as such during .usda output.
  • Added dynamic payloads feature. Dynamic payloads allow file formats to procedurally generate a layer using metadata authored on the prim where the layer is introduced via a payload arc. See examples and "Advanced Features" documentation for more details.
  • Fixed erroneous composition cycle detection for subroot references to sibling prims across reference boundaries.
  • Added support for "schemaTokens" customData entry in schema.usda. This allows developers to associate tokens with a particular schema for clarity and organization. These tokens will continue to be emitted into the standard tokens.h and tokens.cpp files in each schema library.
  • Removed deprecated UsdListPositionTempDefault and USD_AUTHOR_OLD_STYLE_ADD environment variable.
  • Improved error detection for truncated .usdc files.
  • Improved error messages and debug output for USD schema generation. (PR: #427, PR: #478)
  • Fixed various issues that caused build errors on Windows. (Issue: #812)
  • Fixed bug that caused corrupt .usdc files to be created in certain rare cases. (Issue: #811)
  • Fixed bug where asset-valued stage metadata would not be resolved.
  • Calling Usd.Prim.IsDefined on a null prim in Python now raises a Python exception. (Issue: #753)
  • Fixed bug in UsdUtils dependency extraction and .usdz creation where asset dependencies in layer metadata were ignored.
  • Improved integer encoding and fixed a source of non-deterministic output in .usdc file format. (Issue: #830)
  • Added ability to usdcat to only show layer metadata via --layerMetadata command-line flag.
  • UsdGeomBasisCurves schema now accepts "pinned" as a valid value for wrapping to represent pinned curves.
  • UsdGeomPointInstancer will now use the "append" list op when authoring inactiveIds metadata instead of the deprecated "added" list op. This behavior can be reverted by setting the environment variable USDGEOM_POINTINSTANCER_NEW_APPLYOPS to 0, but this will be removed in a future release.
  • Added UsdShadeCoordSysAPI schema for representing coordinate systems.
  • Added shaping:ies:normalize attribute to UsdLuxShapingAPI.
  • Numerous fixes and improvements to UsdSkel schemas.

Imaging:

  • Added early version of RenderMan Hydra render delegate with support for geometry,material networks, lights, volumes, coordinate systems and more!
  • Added support for coordinate systems in Hydra and UsdImaging.
  • Added support for categories per instance in Hydra to support light linking to individual instances.
  • Added order independent transparency (OIT) to Hydra GL.
  • Added support for backend-independent picking and highlighting.
  • Improved Hydra support for scenegraph cameras.
  • Added support for instance-rate primvar queries in Hydra GL shading code.
  • Added support for generating normals for picking hits in Hydra GL.
  • Added "DontConform" camera window policy.
  • Added support for picking points in Hydra GL.
  • Added depth compositing to HdxColorizeTask.
  • Render delegates can now access "velocities" attribute on point-based schemas. (PR: #824)
  • Refactored and clarified use of "path" and "prim" terminology in UsdImaging.
  • Removed HdChangeTracker::MarkAllCollectionsDirty
  • Removed render tags API from HdRprimCollection. They have become a Hydra task concept.
  • Fixed instancing-related crashes in UsdImaging. (Issue: #838, Issue: #847)
  • Added usdAppUtils library containing common functionality and utilities for applications that view USD stages.
  • Added initial version of usdrecord command line tool for generating images from a USD file.
  • Added "debug flags" configuration dialog in usdview.
  • Added ability to specify first/last/current frame when launching usdview via "--ff", "--lf", and "--cf" command line parameters. (PR: #832)
  • Numerous correctness, interaction, and performance improvements to usdview's transport control (frame slider). (PR: #770)

Alembic Plugin:

  • Added support for Alembic 1.7.9. (PR: #825)

Houdini Plugin:

  • Support for Houdini 16.0 is deprecated. We anticipate bumping the minimum version requirement to 16.5 and dropping 16.0 support in the next release.
  • Fixed bug which could cause visibility to be incorrect.
  • Added support for export of additional primvar types.
  • Fixed bug which could cause incorrect attribute typeinfo when importing array attributes.
  • Added support for additional OSD subdiv interpolation tags.
  • Added support for targeting the default prim on import via a reserved "defaultPrim" prim path.
  • Miscellaneous improvements for converting between UsdSkel and Agent primitives.

Katana Plugin:

  • Added support for reading and resolving collection-based material bindings to PxrUsdIn. This is done as a two stage process in which bindings (for the purposes specified in "additionalBindingPurposeNames") are added within a "usd.materialBindings" group attribute. The PxrUsdInResolveMaterialBindings node (and its corresponding Op) transfers a purpose's binding to the system-level "materialAssign" attribute and optionally filters inherited redundancy.
  • The "info.usd" attributes which advertise which API schemas are applied can be created in either array or group attribute form. The latter is convenient to match against via CEL.

Maya Plugin:

  • Add support for exporting assembly edits on pxrUsdReferenceAssembly nodes.
  • Expose controls for tweaking selection parameters in pxrHdImagingShape.
  • Importing shaders and lights will use mel commands to property add shaders to hypershade and lights to the defaultLightSet.

[19.05] - 2019-04-10

Build

  • Added support for Ninja build system in build_usd.py. (PR: #590)
  • Added --build-debug option to build_usd.py. (PR: #502)
  • Better support for static builds in exported pxrConfig.cmake. (PR: #787)
  • .pdb files are now installed with the libraries on Windows. (PR: #502)
  • MacOS users can now run build_usd.py with Maya's Python interpreter (mayapy) to ensure that USD and the Maya plugin will be built against Maya's Python. This requires the --no-usdview option, as Maya does not provide the OpenGL module in Python. (Issue: #10)
  • Numerous fixes for FindMaya.cmake module. In particular, users on MacOS who specify MAYA_LOCATION should now use the root of the installation, without the "Maya.app/Contents" suffix.

USD:

  • Added usdtree utility for viewing the scenegraph at the command line. (PR: #619)
  • Added ability to configure default camera prim name via plugin and query the default name via UsdUtilsGetPrimaryCameraName.
  • Added UsdUtilsTimeCodeRange for representing an iterable range of time codes.
  • Added API to UsdGeom for setting and querying Stage-level linear units via the "metersPerUnit" metadata field.
  • Changed SdfFileFormat interface to operate in terms of SdfLayer instead of SdfLayerBase.
  • Improved performance of UsdGeomPointBased::ComputeExtent overload with an additional transform. (PR: #640)
  • Various cleanup changes to fix documentation, compiler warnings, and remove unused or legacy code.
  • Numerous changes to UsdSkel schemas for resolving and imaging blend shapes.
  • Removed UsdGeomFaceSetAPI schema.
  • Removed SdfLayerBase. Its functionality was folded into SdfLayer.
  • Fixed bug where parts of the codegen template for multiple-apply API schemas were specific to UsdCollectionAPI. (Issue: #799)
  • Fixed bug preventing the use of symlinks for generatedSchema.usda. (Issue: #763)
  • Fixed several bugs in .usdz creation related to nesting of .usdz files and file path syntax on Windows.

Imaging:

  • Added "MaterialTags" mechanism which allows the GL backend to render opaque primitives separated from translucent primitives.
  • Added early implementation of CPU/GPU UsdSkel skinning support, working in both GL and Embree backends.
  • Added early implementation of blend shapes support to UsdSkelImaging adapter.
  • Refactored renderer-independent input/output code into new "hio" library.
  • Added new phase for Hydra tasks called "Prepare", which runs after Sync phase and before Commit.
  • Added "instanceId" and "elementId" AOVs in HdEmbree.
  • Added new purpose cache in UsdImaging to improve performance.
  • Added support for animated textures in drawModeAdapter. (PR: #735)
  • TaskController::TestIntersections now allows selection by nearestToCamera. (PR: #760)
  • Split Hydra's color primvar into a float3 displayColor and a float displayOpacity.
  • Removed hidden GL dependencies in UsdImaging tests.
  • Removed unnecessary parameters from GetInstancerTransform and SampleInstancerTransforms in HdSceneDelegate API.
  • Fixed several issues with curve drawing in GL backend. (Issue: #690)
  • Fixed bug where UsdGeomSubset called Populate instead of Resync during resyncs.
  • Fixed leak of empty GlfSimpleShadowArray instance. (PR: #786)

Alembic plugin:

  • Fixed double time scaling when converting Alembic sample times from seconds to USD time codes. (Issue: #662)
  • USD's "timeCodesPerSecond" metadata is now used to scale when reading or writing an Alembic file.
  • Added support for facesets, which are represented using the UsdGeomSubset schema. (PR: #758)

Houdini plugin:

  • Added support for namespaced primvars in Houdini 17.5+. (PR: #747)
  • Added support for caching in-memory USD stages in GusdStageCache. (PR: #775)
  • Added support for import and export of holeIndices attribute on UsdGeomMesh.
  • Added support for all registered USD file extensions.
  • Changes in support of upcoming Houdini versions.
  • Fixed spurious warnings when evaluating transforms on pseudo-root prims.

Katana plugin:

  • The Katana plugin no longer supports Katana 2.x. Support for 2.x was deprecated in release 19.03.
  • Expanded support for and use of zero-copy construction of FnAttribute from VtArray.
  • Ensure that a NullAttribute is used to block an inherited shading connection when the USD equivalent is present.
  • PxrUsdIn will observe a "katana:useDefaultMotionSamples" USD attribute to hard-wire the equivalent behavior of a PxrUsdInDefaultMotionSamples node targeting that scope.
  • Fixed bug where calling UsdKatanaCache::FindSessionLayer with a cache key derived from an empty GroupAttribute would not return a layer whose key was generated for an invalid/nonexistent GroupAttribute.
  • Fixed crash in PxrUsdIn when an invalid regex value was given for "ignoreLayerRegex".

Maya plugin:

  • Added support for exporting units via new "metersPerUnit" metadata.
  • Imported shaders now appear in the Hypergraph UI.
  • Imported lights now appear in defaultLightSet.

[19.03] - 2019-02-13

Added

Build:

  • Ability to download and build OpenColorIO dependency via --opencolorio argument to support new color management functionality in Hydra.

USD:

  • Enabled usddumpcrate utility for viewing .usdc file information in the build. (PR: #470)

  • Internal payloads, list editing and layer offsets for payload arcs. Payloads now provide the same set of features as references.

    This may affect backwards compatibility of layers written with this version of USD:

    • Layers containing payloads using these new features will not be readable in previous USD versions. .usdc files containing these payloads will be marked as version 0.8.0.
    • Layers containing payloads that only use the previously-available features will continue to be readable in previous USD versions.
  • API for querying authored and inherited primvars in UsdGeomPrimvarsAPI schema.

  • Optional 'jointNames' attribute to UsdSkelSkeleton to help DCC import/export.

Imaging:

  • HdxColorCorrectionTask to do linear to sRGB conversions or color management via OpenColorIO.
  • HdxProgressiveTask type tag for tasks that support progressive rendering.
  • Initial support for computations in the UsdImaging scene delegate.
  • Support for points rendering for basis curves in Hydra GL.
  • Publish the normals attribute or primvar from points primitives through Hydra. (PR: #742)
  • usdview now responds to all scene edits from the interpreter. Plugins can connect to the usdviewApi.dataModel.signalPrimsChanged signal to be notified for these changes.

Houdini plugin:

  • Support for more primvar types.

Katana plugin:

  • Support for reading materials with multiple incoming shader connections.

Maya plugin:

  • Initial work for a UsdPreviewSurface shader node and USD export support.

Changed

Build:

  • build_usd.py now explicitly detects Python version to link against on macOS to avoid conflicts between multiple installations. (Issue: #19, Issue: #699)
  • build_usd.py only builds boost libraries like boost::filesystem when needed.

USD:

  • UsdStage::MuteAndUnmuteLayers and LoadAndUnload now send a UsdNotice::StageContentsChanged notification. (PR: #710)

Imaging:

  • UsdImaging scene delegate now stops population traversal at non-imageable prims.
  • Materials are no longer resynced on visibility changes.
  • Hydra will now only reset varying state for clean prims.
  • HdxCompositor can now copy depth without remapping its range and can also copy color and depth to a user-provided viewport size.
  • Interacting with the 'Vis' or 'Draw Mode' columns in usdview no longer changes selection.
  • When multiple prims are selected in usdview, changes in the 'Vis' column to one of those prims will affect all of them.

Katana plugin:

  • Optimizations for reading gprims and point instancers via a new library, vtKatana. This library requires Katana 3.0 or later.

Maya plugin:

  • Configuration of the default material scope name has been moved to usdUtils to facilitate sharing across plugins. See UsdUtilsGetMaterialsScopeName.

Deprecated

USD:

  • UsdAttribute::HasAuthoredValueOpinion in favor of HasAuthoredValue.
  • UsdPrim::ClearPayload, HasPayload, and SetPayload in favor of API on UsdPayloads object returned by GetPayloads.
  • Primvar API on UsdGeomImageable in favor of UsdGeomPrimvarsAPI schema.

Katana:

  • Support for Katana 2.x in favor of Katana 3.x. We anticipate removing support for Katana 2.x in the next release.

Removed

  • Dependency on boost::filesystem (Issue: #679)
  • Ability to read pre-xformOp transform attributes on UsdGeomXformable prims.
  • UsdShadeMaterial::CreateMaterialFaceSet, GetMaterialFaceSet, HasMaterialFaceSet functions.
  • UsdGeomCollectionAPI schema.

Fixed

Build:

  • Detection of Visual Studio on non-English platforms in build_usd.py. (Issue: #613, Issue: #697)

USD:

  • Error when composing prims with both direct and ancestral specializes arcs.
  • Incorrect strength ordering when composing specializes arcs declared across an internal reference arc.
  • UsdAttribute::GetConnections and UsdRelationship::GetTargets could return incorrect paths in cases involving nested instancing and instance proxies inside of masters.
  • Corrupted values when parsing OSL string arrays in Sdr via sdrOsl plugin.
  • Various fixes for UsdSkelSkinningQuery and UsdSkelAnimMapper.
  • Incorrect results from UsdGeomBBoxCache::ComputeRelativeBound.
  • UsdGeomPointInstancer enums in Python are now properly scoped under UsdGeom.PointInstancer instead of UsdGeom.

Imaging:

  • GlfDrawTarget::_BindAttachment could leave a different framebuffer bound than what was bound before calling the function.
  • Multiple GLSL shader fixes to allow Hydra GL to render correctly with Intel GPUs.
  • Errors when trying to use usdview on macOS due to incorrect handling of unsupported Hydra renderers. When no supported renderers are found, usdview will fall back to the legacy renderer.
  • Missing symbol exports in UsdVolImaging that could cause build errors on Windows. (PR: #742)
  • Regression in usdview that caused the "Redraw On Frame Scrub" option to always be in effect. (Issue: #734)

Alembic plugin:

  • Alembic curve basis, type, and wrap were being converted to varying attributes in USD instead of uniform.

Houdini plugin:

  • Incorrect display in Tree View panel when unimporting the top-most prim.
  • USD Reference ROP behavior when updating or removing an existing reference.
  • Various compilation errors with different Houdini versions.
  • Incorrect default value for horizontal aperture offset in USD camera node.
  • Vertex attributes on meshes with rightHanded winding order. (Issue: #631, PR: #632)

Maya plugin:

  • Incorrect name conflict error on export when stripping namespaces and merging transform and shape nodes. (PR: #683)

[19.01] - 2018-12-14

Added

USD:

  • usdresolve utility for checking the results of asset resolution at the command line. (PR: #609)
  • SdfFileFormat::FindAllFileFormats and FindAllFileFormatExtensions for querying available file formats. (PR: #532)
  • Option to UsdGeomBBoxCache to ignore visibility.

Imaging:

  • Render settings API to HdRenderDelegate. ("Enable Tiny Prim Culling" is the first example for Hydra GL)
  • Support for UDIM textures in Hydra GL. (PR: #597)
  • Blending controls to HdRenderPassState for initial transparency support in Hydra GL.
  • Ability to specify backend when starting usdview via "--renderer" parameter.
  • Optional "Draw Mode" column to prim browser in usdview that provides control of model draw modes. (texture cards, bbox, etc.)

Houdini plugin:

  • Optional layer scale, layer offset, and target prim parameters to the USD Reference ROP.
  • Option on USD Output ROP to use or ignore obj-level transforms.
  • Support for exporting ramp parameters in OSL shader networks.

Katana plugin:

  • "info.usd.outputSession" attribute authored by PxrUsdIn. This is a sibling to "info.usd.session" but is not affected by the translation of PxrUsdIn's old "variants" parameter into session data. It acts as a more stable session cache key for external apps to use.
  • "forceArrayForSingleValue" parameter that allows PxrUsdInAttributeSet to author 1-length arrays.

Maya plugin:

  • Support for instancing USD reference assemblies in instancers.

Changed

Build:

  • Symbols for wrapping functions are no longer exported from modules to avoid issues with using RTLD_GLOBAL in Python. (Issue: #641)
  • Updated minimum required version of GLEW to 2.0.0.

USD:

  • Numerous fixes and cleanup changes throughout to improve performance, remove dead code, convert code to more modern patterns, and remove unneeded uses of boost.
  • Replaced safe-bool idiom with explicit bool operator in several places.
  • Improved performance of setting and erasing time samples in .usda layers from linear complexity to logarithmic.
  • Improved error messages when attempting to read a .usdz files using compression or encryption.
  • Various improvements to UsdSkel documentation and API.
  • Changed scene description name for UsdSkelBindingAPI from "BindingAPI" to "SkelBindingAPI" to distinguish it from other binding API schemas.

Imaging:

  • Several improvements to the handling of AOVs in Hydra.
  • Simplified class hierarchy in usdImagingGL. The primary API entry point is now UsdImagingGLEngine.
  • Better performance for animated textures and large numbers of invisible prims in Hydra.
  • Optimized batch removal of prims in Hydra and UsdImaging.
  • Better handling of edits made in the interpreter in usdview.
  • Mesh normals are suppressed when the subdivision scheme is something other than "none".
  • The default stb-based image reader now extracts gamma information from .png images.
  • Functionality specific to the prim browser in usdview have been moved to a browser-specific menu bar with "Navigation" and "Show" menus.
  • Property browser in usdview now shows resolved material bindings and inherited primvars.

Maya plugin:

  • The name of the scope for exported material prims can now be customized in the UI or via the "materialsScopeName" parameter to usdExport. The default scope name is "Looks", matching the previous behavior.
  • Refactoring and cleanup in preparation for shading export support.

Removed

Build:

  • Build-time dependency on Python. (Issue: #605, PR: #615)

Imaging:

  • HdSceneTask in favor of HdTask.
  • UsdImagingGL and UsdImagingGLHdEngine.

Fixed

USD:

  • Incorrect composition error in cases involving internal sub-root references and variants. (Issue: #677)
  • Regression that caused prims to sometimes be composed incorrectly.
  • Missing symbol exports that could cause build errors on Windows. (PR: #623, Issue: #703, Issue: #704, Issue: #705)
  • Incorrect type validation and conversion when authoring metadata via Python that could lead to invalid scene description. (Issue: #529)
  • Various issues in usdzip and related usdUtils API when processing references for packaging into a .usdz file.

Imaging:

  • Batch aggregation for prims with face-varying primvars.
  • Drawing coord initialization of instance primvar slots.
  • Deep batch validation only happens when needed, improving performance.
  • Crash in cases where a prim is removed from a stage and a collection targeting that prim is updated in the same round of changes. (PR: #685)
  • Crash when reading half-float .exr images in the OpenImageIO plugin. (Issue: #581)
  • Incorrect handling of edits to material bindings.

Houdini plugin:

  • Issue where visibility and purpose attributes weren't properly inherited on import. (Issue: #649)
  • Crash when running ginfo on a USD file. (Issue: #673, PR: #674)
  • Issue where imported string attribute values could be incorrect. (Issue: #653)

Katana plugin:

  • Issues with reading UsdGeomPointInstancers
    • Regression in instance transform computation with masked instances.
    • Prototype transforms are cleared out on the Katana side since they are folded in when computing instance transforms.

Maya plugin:

  • Reference assemblies weren't being drawn in "playback" representation. (Issue: #675)
  • Issue where HdImagingShape prevented nodes from being reordered.

[18.11] - 2018-10-10

Added

USD:

  • [usdVol] UsdVol schema for representing volumes. (PR: #567)
  • [usdShade] Ability to define shaders in the shader definition registry using UsdShade.
  • [usdShaders] Shader definition registry plugin for core nodes defined in the UsdPreviewSurface specification.

Imaging:

  • [hd, usdImaging] Hydra support for UsdVol schema. (PR: #567)

  • [hd, hdSt] Topology visibility operations for meshes in Hydra.

  • [hd, hdSt] Support for inverting the depth test of a draw target.

  • [hd, hdSt] "Flat normals" computed buffer source for meshes.

  • [hdx] ResolveNearestToCenter pick hit resolution method for ray picking.

  • [usdview] Menu for switching AOVs for supported backends.

  • [usdview] Menu for backend-specific settings.

Alembic plugin:

  • [usdAbc] Behavior where an Xform with a single geometry or camera in an Alembic file would be collapsed into a single prim in USD can now be disabled by setting the environment variable USD_ABC_XFORM_PRIM_COLLAPSE to 0. (PR: #527)

Maya plugin:

  • [usdMaya] Display filter for USD proxy shapes.
  • [usdMaya, pxrUsdMayaGL] pxrHdImagingShape node that reduces overhead when imaging scenes with many Hydra-backed shapes.
  • [pxrUsdMayaGL] Support for Maya lights casting shadows between Hydra shapes, and Hydra shapes to Maya shapes, but not Maya shapes to Hydra shapes.

Houdini plugin:

  • [gusd] Experimental build support for Houdini plugin on Windows.
  • [OP_gusd] Multi-seg export to USD output ROP.

Changed

  • Numerous fixes and cleanup changes throughout to improve performance, convert code to more modern patterns, and remove unneeded uses of boost. (PR: #373, PR: #453, PR: #481, PR: #484, PR: #488)

USD:

  • [usd] UsdAPISchemaBase is now an abstract base class as originally intended.
  • [usdGeom] Improved performance of UsdGeomPointBased::ComputeExtent. In one example, this provided a ~30% improvement. (PR: #588)
  • [usdGeom] Improved performance of computing extents for UsdGeomPointInstancer. In one example with >5 million instances, extent computation time decreased from ~25 seconds to ~3 seconds.
  • [usdSkel] UsdSkelBakeSkinning bakes skinning at additional time samples based on stage's configured sampling rate.
  • [usdedit] Opening a .usdz file now forces read-only mode.
  • [usdzip] "-l" or "-d" arguments will now provide information about existing .usdz files.
  • [usdzip] ARKit compliance checks now require valid sources for shader inputs with connections and valid prims and/or collections for material bindings.

Imaging:

  • [hd] Improved Hydra AOV API.
  • [hd] Split reprs into the topology indices they affect.
  • [hd] Properly set up both the shadow projection and view matrices. (PR: #583)
  • [hd] Optimization to not run garbage collection if a texture hasn't change.
  • [hd, hdSt, usdImaging] Update wrap mode fallback behavior to useMetadata.
  • [hdx] Improved shadow support in HdxTaskController. (PR: #541)
  • [hdx] "Enable Hardware Shading" entry point is now "Enable Scene Materials".
  • [hdSt] Support to generate GLSL-compatible names for resources/primvars.
  • [usdImagingGL] Better support for animated textures. (PR: #488)
  • [usdview] Better error reporting if an unsupported backend is selected. (PR: #635)
  • [hdEmbree] Improved AO sampling (cosine-weighted sampling, stratified AO samples LHS).

Maya plugin:

  • [pxrUsdMayaGL] Many performance improvements in the Hydra batch renderer.
  • [usdMaya, pxrUsdMayaGL] Using USD in live surface uses the normal at the snap point.
  • [usdMaya, pxrUsdTranslators] Various code cleanup in USD exporter.

Katana plugin:

  • [usdKatana] Use bracketing sample closest to shutter open/close if no frames found in shutter interval.
  • [usdKatana] Honor UsdStage's authored timeCodesPerSecond and framesPerSecond. If they differ, Katana will operate in frames, with current time, motion samples, and shutter interval scaled appropriately.

Houdini plugin:

  • [gusd] Rebind materials when creating sub-root references.
  • [gusd] Optimizations in handling of stage mask operations.
  • [OP_gusd] USD output ROP now allows binding to shaders referenced from other models.

Removed

Imaging:

  • [hd] Removed Repr requirements from GetRenderTag API.

Fixed

Build:

  • [cmake] User-specified CMAKE_MODULE_PATH was being ignored during build. (PR: #614)
  • [cmake] Installed headers could take precedence over source headers, leading to build failures. (Issue: #83)

USD:

  • [tf] TfEnvSetting crash on MSVC 2017.
  • [ar] ArDefaultResolver::AnchorRelativePath did not call IsRelativePath on derived resolvers. (PR: #426)
  • [sdf] SdfCopySpec did not handle copying prim specs to variants and vice-versa.
  • [sdf] Incorrect notification was sent when removing subtrees of inert specs.
  • [usd] Prim payload was not automatically loaded when a deactivated ancestor prim with a payload was activated. (Issue: #604)
  • [usd] Incorrect lists of time samples would be returned in certain cases with value clips.
  • [usd, usdzip] .usdz files were not fully compliant with the zip file format specification.
  • [usdUtils, usdzip] Creating an ARKit .usdz file with a .usda asset would create an invalid file.
  • [usdMtlx] MaterialX plugin build failures on Windows and macOS. (Issue: #611)

Imaging:

  • [hdx] Picking with disabled scene materials generating shader errors.
  • [hdSt] Fix immediate draw batch invalidation on buffer migration.
  • [hdSt] Fix garbage collection on buffer migration.
  • [hdSt] Bindless texture loading not being deferred.
  • [usdImaging] Wrong transforms were being used when using usdLux light transforms (Issue: #612).
  • [usdImaging] Fix for usdImaging's TextureId not accounting for origin.

Houdini plugin:

  • [gusd] Several fixes for building with Houdini 17. (PR: #549)
  • [gusd] Several fixes for stale caches and crashes.
  • [gusd] Potential PackedUSD transform issues in Houdini 16.5.

[18.09] - 2018-08-07

This release includes several major new features and changes, including:

  • .usdz file format for packaging assets into a single file
  • Introduction of UsdPreviewSurface
  • Switch to calendar-based versioning scheme for USD libraries

Added

  • Build:

    • build_usd.py can be given custom arguments for building libraries via the --build-args option.
    • Option to disable building usdview by specifying PXR_BUILD_USDVIEW=OFF when running cmake or --no-usdview when running build_usd.py.
    • Allow specifying Boost_USE_STATIC_LIBS to cmake on Windows. Note that static boost libraries may lead to issues with Python bindings. (Issue: #407)
  • USD:

    • ArAsset and ArResolver::OpenAsset interfaces allowing resolvers to control how data for a given asset is accessed.
    • "Package" asset and layer concepts to Ar and Sdf, including "package-relative" asset path syntax for addressing assets within packages.
    • sdffilter utility for inspecting and summarizing the contents of a layer.
    • .usdz file format. This format allows multiple assets (including layers, textures, etc.) to be packaged into a single file that can be consumed by USD without being unpacked to disk. These files can be created via the "usdzip" command-line utility or via APIs like UsdZipFileWriter and UsdUtilsCreateNewUsdzPackage.
    • UsdStage::GetObjectAtPath for retrieving a generic UsdObject. (PR: #390)
    • UsdCollectionAPI can represent collections that include all paths or exclude some paths but include all others via the new "includeRoot" attribute.
    • Support for "sourceAsset" and "sourceCode" implementation sources in UsdShadeShader.
    • Ndr and Sdr libraries that provide a registry for shader definitions that can be extended via plugins.
    • sdrOsl plugin for populating shader definition registry from OSL 1.8.12. OSL support must be enabled by specifying PXR_ENABLE_OSL_SUPPORT=TRUE when running cmake.
    • usdMtlx plugin containing USD file format and shader definition registry plugins based on MaterialX 1.36.0. MaterialX support must be enabled by specifying PXR_BUILD_MATERIALX_PLUGIN=TRUE when running cmake.
    • Initial UsdSkel schema for blend shapes, which are not yet factored into computed deformation.
  • Imaging:

    • Per-prim adaptive refinement enabled via materials in hdSt.
    • Preliminary AOV support in Hydra with sample implementation in Embree plugin.
    • HdRenderThread utility class to enable render delegates to render in background threads. The Embree plugin uses this class as an example.
    • Support for scene-authored normals on meshes.
  • UsdImaging:

    • Light linking support.

    • Initial support for USD material preview nodes. For more details, see: http://graphics.pixar.com/usd/docs/UsdPreviewSurface-Proposal.html

      Currently unimplemented features include:

      • Support for automatically computed tangents when normal mapping. Primvars must be supplied.
      • Handling for ior (index or refraction).
  • Alembic plugin:

    • Support for TextureCoordinate role and value types.
  • Maya plugin:

    • Initial support for exporting .usdz files.
    • Support for importing and exporting volume and displacement in "pxrRis" shading mode.
    • pxrUsdPointBasedDeformerNode - an animation cache deformer that allows users to pose a Maya mesh based on a UsdGeomPointBased prim.
    • Option to apply Euler filtering to transforms during export. (PR: #299)
    • Option to filter out certain Maya node types during export. (PR: #475)
  • Katana plugin:

    • Support for TextureCoordinate role and value types.
    • Support for importing inherit paths metadata as a info.usd group attribute
    • "additionalLocations" parameter to PxrUsdInVariantSelect
    • "asArchive" option to PxrUsdIn. When enabled, a "usd archive" location will be created rather than loading the USD data directly. This is intended for passing along to renderers which support reading USD natively.
    • PxrUsdIn supports a "sharedLooksCacheKey" attribute to permit sharing cached USD shading information across multiple references/instances which are known to be identical from a pipeline standpoint.
  • Houdini plugin:

    • Support import of Scope prims.

Changed

  • Build:

    • USD resource files are now installed into /lib/usd instead of /share/usd/plugins to bring them closer to the installed libraries.
    • OpenGL dependency in imaging is now optional and may be disabled by specifying PXR_ENABLE_GL_SUPPORT=FALSE when running cmake. This will disable all GL-based functionality, including usdview.
    • OpenImageIO dependency imaging is now optional and is disabled by default. Support must be enabled by specifying PXR_BUILD_OPENIMAGEIO_PLUGIN=TRUE when running CMake or --openimageio when running build_usd.py.
    • build_usd.py on Windows will now use powershell to download dependencies if it's available to avoid TLS 1.2 issues. (Issue: #449)
    • build_usd.py now directs users to install PySide2 via pip on MacOS.
  • USD:

    • Numerous fixes and cleanup changes throughout to improve performance, convert code to more modern patterns, and remove unneeded uses of boost.
    • ArGetResolver no longer returns an instance of the ArResolver subclass used for asset resolution. Clients can use ArGetUnderlyingResolver in the special cases where access to the exact subclass is necessary.
    • ArResolver context and scoped cache functions are now public and have been renamed to match convention. Resolvers that override these functions will need to be updated.
    • ArDefaultResolver default context for an asset now includes the directory of the asset in its search path.
    • Optimizations to prim change processing in UsdStage. In one example, processing time for adding new prims decreased ~50%.
    • New .usdc files now default to version 0.7.0, which includes compression features introduced in earlier releases. These files cannot be read in USD releases prior to v0.8.4. Users can revert to writing older versions by setting the environment variable USD_WRITE_NEW_USDC_FILES_AS_VERSION to an older version.
    • Several changes to provide cleaner and more detailed runtime error messages.
    • Better support for generating code for properties of multiple-apply API schemas in usdGenSchema.
    • Schema types are now specified using the UsdSchemaType enum instead of individual flags.
    • "expansionRule" attribute for UsdCollectionAPI is now optional; collections are created simply by calling UsdCollectionAPI::ApplyCollection.
    • UsdGeomBBoxCache's bounds computation now includes all defined prims, including those with no type specified.
    • UsdRiMaterialAPI now writes standardized "ri:surface" output by default instead of deprecated "ri:bxdf".
    • UsdRiStatementsAPI now writes ri attributes as primvars by default.
    • Renamed UsdSkelPackedJointAnimation schema to UsdSkelAnimation
    • Renamed UsdSkelBakingSkinningLBS function to UsdSkelBakeSkinning
    • Numerous additional fixes and changes to UsdSkel schemas and APIs.
  • Imaging:

    • Several API cleanup changes in HdSprim/HdBprim/HdRprim.
    • HdRenderDelegate::CanComputeMaterialNetworks has been replaced by GetMaterialBindingPurpose, which has a default value of "preview".
    • Improved handling of fallback texturing behavior when texture inputs are missing from a material.
    • .png, .jpg, .bmp, .tga, and .hdr images are now handled by a built-in image reader based on stb_image.
    • Texture loading is deferred until needed.
    • Truncate mesh vertex primvar data to expected length if larger than expected.
    • Improved ptex rect packing performance. In one large test case, processing time decreased from ~600s to ~40s.
  • UsdImaging:

    • Avoid loading custom shaders and textures when the "Enable Hardware Shading" option is disabled in usdview.
    • Default values for wrapS/wrapT match the proposed value in the preview material spec. Also adds support for mirrored wrapS/wrapT.
    • Scene lights are now enabled by default. This can be disabled by setting the environment variable USDIMAGING_ENABLE_SCENE_LIGHTS to 0.
    • UsdShadeMaterialAPI is now used instead of UsdRi to look up material networks.
  • Alembic plugin:

    • Alembic writer now prefers writing to the "st" attribute instead of "uv". (PR: #463)
  • Maya plugin:

    • MAYA_SCRIPT_PATH and XBMLANGPATH environment variable settings have changed due to new resource file install location documented above. Refer to Maya plugin documentation for new values.
    • Large refactoring and cleanup of usdMaya. USD importers and exporters for built-in Maya nodes have been moved to pxrUsdTranslators plugin.
    • Proxy shape now redraws in response to changes on UsdStage.
    • Diagnostic messages are now batched together for better reporting behavior and to prevent log spewage.
    • Improved primvar export. (PR: #330)
    • Camera shake now applied to USD cameras on export. (PR: #366)

Deprecated

  • USD:
    • UsdSkelPackedJointAnimation schema in favor of UsdSkelAnimation
    • Specialized RIS and RSL shader schemas in UsdRi (e.g. UsdRisPattern and UsdRisBxdf) in favor of generic UsdShadeShader prims.

Removed

  • Build:

    • boost::regex dependency.
  • USD:

    • ArResolver::CreateDefaultContextForDirectory to better accommodate asset systems that are not file-system based.
    • SdfExtractExternalReferences. UsdUtilsExtractExternalReferences can be used as an alternative.
    • UsdLuxLinkingAPI, in favor of UsdCollectionAPI to represent light linking.

Fixed

  • Build:

    • Fixed issues with using Visual Studio 2017 in build_usd.py.
    • Issue preventing use of NMake generator on Windows. (PR: #519)
    • Several fixes for static library builds.
  • USD:

    • Bug where SdfLayer::GetDisplayName would return an empty string for anonymous layers if the tag contained a ":". (PR: #440)
    • Bug where SdfLayer::UpdateExternalReferences would not handle variants and payloads correctly.
    • Incorrect load state handling in UsdStage for payloads introduced across sub-root references, inherits, and specializes arcs.
    • Incorrect value clip time mapping during value resolution on UsdStage.
    • Change processing bug when adding a new inert prim spec.
    • Load/unload change processing bug with nested instances on UsdStage.
    • Crash when opening a UsdStage with a UsdStagePopulationMask containing instance prims. (Issue: #497)
    • Test failures when USD_EDITOR environment variable is set. (Issue: #505)
    • Bug where non-constant primvars were inherited down namespace in UsdGeomPrimvarsAPI.
  • Imaging:

    • Triangulation/quadrangulation of face varying for refined meshes.
    • Several selection and picking issues.
  • UsdImaging:

    • Material binding to instanced prims.
    • Change processing for UsdShadeShader prims beneath UsdShadeMaterial prims.
  • Alembic plugin:

    • Texture coordinate indices are now preserved. (PR: #520)
  • Katana plugin:

    • Several asset resolution fixes. (Issue: #535)
    • Bug preventing correct inheritance of motion sample times overrides as authored by PxrUsdInDefaultMotionSamples and PxrUsdInMotionOverrides in Katana plugin.
  • Houdini plugin:

    • Fixed several display and update issues with treeview panel.
    • Fixed bug in batched loading of masked prims.

[0.8.5a] - 2018-05-21

Fixed

  • Fixed broken URL in build_usd.py for downloading libtiff. (Issue: #498)

[0.8.5] - 2018-05-07

Added

  • New 'trace' library providing performance profiling functionality.
  • API to Ar for resolver implementations that wrap around other resolvers.
  • TextureCoordinate role and TexCoord{2,3}{h,f,d}{Array} value types to Sdf to indicate attributes that represent UV(W) texture coordinates.
  • UsdUtilsSparseValueWriter and UsdUtilsSparseAttrValueWriter utility classes for authoring attribute values sparsely.
  • UsdGeomPrimvar::GetIndicesAttr API for indexed primvars.
  • UsdGeomPrimvarsAPI schema for accessing primvars, including primvar values inherited down namespace. This is intended as an eventual replacement for the primvar API on UsdGeomImageable.
  • API to UsdShadeMaterial to support render context-specific terminal outputs and core support for three universal render context outputs: surface, displacement, and volume.
  • Time-sampling support for UsdGeomPointInstancer via new methods for computing extents and instance transforms at multiple times.
  • Finalize method for sprims and bprims in Hydra.
  • Time-sampling support in Hydra for geometry instancing.
  • Maya plugin users can specify if colors coming from Maya are linear via the PIXMAYA_LINEAR_COLORS environment variable.
  • Support for import/export with new TextureCoordinate role in Maya plugin.
  • Support for cards drawMode in USD reference assembly in Maya plugin.
  • Support for LiveSurface with proxy shapes in Maya plugin.
  • Support for importing UsdSkel schemas and exporting locators and particles in Maya plugin.
  • Option for placing exported data in parent scope in Maya plugin.
  • Initial support for session layer metadata in PxrUsdIn in Katana plugin.
  • Support for reading in UsdLuxCylinderLight schemas in Katana plugin.
  • Gusd Python bindings for Houdini plugin.

Changed

  • USD now requires TBB version 4.4 Update 6 or later.

  • Removed GLUT dependency for libtiff in build_usd.py. (Issue: #402)

  • build_usd.py will now use cURL to download dependencies if it's installed in the user's PATH. This can help avoid TLS v1.2 errors when downloading from certain sites. (Issue: #449)

  • Numerous documentation additions and fixes throughout the codebase.

  • Improved performance of SdfCopySpec and UsdUtils stitching API; one test case showed a 35% speed improvement, from 160s to 118s.

  • SdfLayer now uses the resolved path provided by Ar for a given identifier to determine the layer file format. (Issue: #144)

  • Simplified API for setting layer data in SdfFileFormat subclasses.

  • Adding or removing invalid sublayers now results in composition errors.

  • UsdStage::CreateNew and CreateInMemory now accept an InitialLoadSet argument. This controls whether new payloads are loaded automatically. (Issue: #267)

  • UsdStage::ExpandPopulationMask now considers attribute connections.

  • UsdStage::Flatten now authors anchored asset paths in flattened results.

  • UsdTraverseInstanceProxies() now includes instance proxy prims that pass the default predicate instead of all prims.

  • .usdc files now support zero-copy array access, which can significantly improve performance. This feature is supported by all .usdc file versions, but may not be activated for certain files depending on their data alignment. In these cases, users can simply re-export the file to activate zero-copy access.

    Users can set the environment variable USDC_ENABLE_ZERO_COPY_ARRAYS to 0 to disable this feature. Users can also track cases where array data is copied due to modifications by setting the environment variable VT_LOG_STACK_ON_ARRAY_DETACH_COPY to 1.

  • Other performance improvements in UsdStage composition.

  • API schemas are now classified as either "applied" or "non-applied". See "Generating New Schema Classes" tutorial for more information.

  • Behavior of UsdUtils stitching API can now be customized via callbacks.

  • UsdShadeMaterialBindingAPI now issues a warning when computing resolved material bindings if prims with old "look:binding" relationships are found. This can be disabled by setting the environment variable USD_SHADE_WARN_ON_LOOK_BINDING to 0.

  • UsdRiMaterialAPI now supports writing ri:surface outputs. ri:bxdf outputs are still written by default, but this can be disabled by setting the environment variable USD_RI_WRITE_BXDF_OUTPUT to 0.

  • UsdRiStatementsAPI now supports encoding ri attibutes as primvars. This is disabled by default but can be enabled by setting the environment variable USDRI_STATEMENTS_WRITE_NEW_ATTR_ENCODING to 1.

  • Additions and improvements to UsdLux and UsdSkel schemas.

  • Hydra backends that consume full network materials now receive all primvars for all rprims, not just those with bound materials.

  • Several improvements to primvar handling and picking infrastructure in Hydra.

  • Several performance improvements in Hydra, especially for material bindings and scenes with heavy nesting of instances.

  • Ongoing work on Hydra compute framework.

  • Conformed Hydra API to use "Primvar" instead of "PrimVar".

  • HdMaterialNetwork is now emitted in topological order.

  • Redundant animation data is no longer written during Maya export.

  • Katana plugin now allows parent scope names for materials other than "Looks". This can be enabled by setting the USD_KATANA_ALLOW_CUSTOM_MATERIAL_SCOPES environment variable to 1.

  • Refactor material loading in Katana plugin so that material locations aren't computed all at once and site ops can run on each location individually.

  • Improved construction of material terminal outputs in Katana plugin.

  • Caching improvements in Houdini plugin to share USD stages between loaded primitives when possible.

  • Improved error handling and reporting in Houdini plugin.

  • USD stage masking in Houdini plugin can now be disabled via GUSD_STAGEMASK_ENABLE environment variable.

  • Improved performance when opening USD stages which don't use "component" kind in their model hierarchy.

  • Object-level transforms are now written at a higher-level scope than leaf primitives if possible in Houdini plugin.

Deprecated

  • UsdGeomFaceSetAPI in favor of UsdGeomSubset.
  • UsdGeomCollectionAPI in favor of UsdCollectionAPI.

Removed

  • tracelite library, which has been replaced with the trace library.
  • Conversions for Python's datetime and dependency on boost::date_time.
  • Several unused classes and functions.
  • usdHydra schemas. This functionality is being replaced with by a registry of shaders in a future release.
  • API for ri:bxdf output on UsdRiMaterialAPI schema. ri:bxdf sources will still be returned by UsdRiMaterialAPI::GetSurface for backwards compatibility.

Fixed

  • Build errors when using ninja.
  • Error when extracting boost on Windows in build_usd.py. (Issue: #308)
  • The build now prefers Alembic library specified at cmake time over any Alembic library found in PATH. (Issue: #409)
  • Several compile-time warnings on clang and other compilers.
  • Bug where list-op valued metadata was not emitted by UsdStage::Flatten.
  • Missing notifications for master prims affected by metadata/property changes.
  • Crash in UsdCollectionAPI::ApplyCollection when given an invalid collection name. (Issue: #425)
  • Change processing for changes to drawMode property in imaging.
  • Numerous fixes to cards draw mode.
  • Change processing bug when removing nested point instancers.
  • Crashes in pxOsd due to incorrect authored crease data.
  • Bug where usdview would not redraw after switching renderer.
  • Crash in Alembic plugin when reading files with object names beginning with numerals.
  • Change processing bug when reloading an Alembic layer. (Issue: #429)
  • Several crash bugs in Maya plugin.
  • Material export bug in Maya plugin where the surface terminal was not being exported under the "ri" render context. This fix requires re-exporting any material networks exported from Maya using version 0.8.4.
  • Prevent overwriting instance sources that resolve to the same master name in Katana plugin.
  • Path resolution issue in Houdini plugin.
  • Miscellaneous bug fixes in Houdini plugin.

[0.8.4] - 2018-03-05

Added

  • The PXR_PLUGINPATH_NAME environment variable name may be changed by specifying PXR_OVERRIDE_PLUGINPATH_NAME=<name> when running cmake.
  • Example sendmail plugin for usdview, located at extras/usd/examples/usdviewPlugins/sendMail.py
  • ArDefaultResolverContext, a context object for the ArDefaultResolver asset resolution implementation that allows additional search paths to be used during asset resolution.
  • Users can now query the UsdNotice::ObjectsChanged notice for the changed scene description fields that affected the reported objects.
  • UsdAPISchemaBase base class for all API schemas.
  • All UsdGeomBoundable schemas in usdGeom now have functions for computing extents. These functions are also used when calling the general UsdGeomBoundable::ComputeExtentFromPlugins method.
  • UsdLuxCylinderLight schema.
  • Significant additions to edge and point selection and highlighting capabilities in Hydra.
  • Initial support for UsdSkel bones in usdImaging.
  • Initial support for exporting joints and skin clusters using the UsdSkel schema in the Maya plugin.
  • Documentation for third party plugin code is now included in the doxygen build.

Changed

  • build_usd.py no longer checks for pyside-uic or boost::python if Python support is disabled, and no longer builds OpenImageIO's Python bindings.
  • Updated moduleDeps.cpp files to only register direct library dependencies. This makes it easier for users to generate their own file for custom schemas.
  • ArDefaultResolver now allows search paths like "Dir/File.usd" to be anchored to other paths via AnchorRelativePath. During composition, these asset paths will be resolved relative to the layer where they were authored before falling back to the previous search path behavior.
  • Updates to VtArray and .usdc code in preparation for zero-copy functionality.
  • Inherit and specializes arcs to non-existent prims are no longer considered composition errors.
  • Apply method on API schemas have been moved to UsdAPISchemaBase and now require a UsdPrim. Also improved documentation.
  • Property queries on UsdPrim now accept a predicate for filtering results.
  • UsdPrim::HasAPI now accepts an instance name argument to query if a prim has a particular instance of a multiple-apply API schema has been applied.
  • Adding or removing an inert prim spec no longer causes affected prims to be resynced. These prims are now reported as "changed info only" in the corresponding UsdNotice::ObjectsChanged notice.
  • UsdNotice::ObjectsChanged::GetResyncedPaths and GetChangedInfoOnlyPaths now return a custom range object instead of a SdfPathVector.
  • Performance optimizations for querying properties on UsdPrim.
  • Replaced UsdCollectionAPI::AddPrim/RemovePrim with IncludePath/ExcludePath.
  • UsdGeomBoundable::ComputeExtentFromPlugins now accepts an optional transform matrix, which may be used to provide more accurate bounds.
  • UsdGeomBBoxCache now computes extents for all UsdGeomBoundable schemas.
  • Performance optimizations in UsdShadeMaterialBindingAPI.
  • Numerous changes and fixes to UsdSkel schemas.
  • Significantly improved curve rendering in Hydra.
  • Many improvements towards the goal of getting modern UsdShade materials through Hydra to various kinds of backends.
  • Performance improvements to hydra gather phase via multi-threading and other optimizations.
  • Changed complexity options in usdview to prevent users from inadvertently bumping the complexity value too high and hanging the application.
  • Several tweaks and improvements to usdview UI.
  • Refactored Maya/Hydra batch renderer to improve performance for imaging USD proxy shape nodes.

Removed

  • UsdShadeLook schema. This has been replaced by UsdShadeMaterial. Material bindings authored using the "look:binding" relationship are no longer respected.

Fixed

  • Various typo and compiler warning fixes throughout the codebase.
  • Fixed bug where build_usd.py would not use the CMake generator specified at the command line.
  • Fixed crash in Apply method on API schemas.
  • Fixed several bugs in UsdShadeMaterialBindingAPI::ComputeBoundMaterial.
  • Changing the population mask for a UsdStage now correctly releases resources used by objects that have been excluded from the stage.
  • Fixed quadrangulation bug in Hydra with handling topology with degenerate or hole faces.
  • Fixed patch param refinement for Loop meshes.
  • Several fixes to the nascent Hydra lights pipeline.
  • Fixed bug in the usdExport AlembicChaser in the Maya plugin where primvars that match the primvarprefix do not get exported. They are now exported with constant interpolation, and using _AbcGeomScope is no longer required.
  • Fixed bug in Katana plugin where infinite recursion would occur in pxrUsdIn when sources were outside the scope of the point instancer. (Issue: #286)

[0.8.3] - 2018-02-05

Added

  • Compression in .usdc files for integer arrays and scalar floating point arrays. The latter are compressed if the values are all integers or there are a small number of unique values. In the example Kitchen Set asset on the USD website, the total size of the geometry layers decreased by ~46%, from 25 MB to 14 MB.

    .usdc files with this new compression enabled are marked as version 0.6.0 and are not readable by earlier releases. These files are not written by default; this may be enabled by setting the environment variable USD_WRITE_NEW_USDC_FILES_AS_VERSION to "0.6.0".

  • Ability to record and query API schemas that have been applied to a prim via new Apply method on API schema classes, UsdPrim::GetAppliedSchemas and UsdPrim::HasAPI. Custom API schemas should be updated with these new methods by re-running usdGenSchema.

  • GetUnionedTimeSamples and GetUnionedTimeSamplesInInterval functions for UsdAttribute and UsdAttributeQuery.

  • Ability to offset time for active value clips when using template clip metadata via "templateActiveOffset" entry.

  • UsdUtilsGetDirtyLayers for retrieving dirty layers used by a UsdStage.

  • GetTimeSamplesInInterval functions for UsdGeomXformOp, UsdGeomXformable and UsdGeomXformable::XformQuery.

  • UsdShadeMaterialBindingAPI, which provides an interface for binding materials to prims or collections of prims and computing the final bound material for a prim via "material resolution".

  • Numerous features and documentation for UsdSkel schema.

  • "Save Flattened As" functionality in usdview.

  • Plugin mechanism in usdview that allows users to add custom commands and menus. See new tutorial for more details.

  • Partial support for RenderMan for Maya lights in the Maya plugin.

  • PxrUsdIn.BootstrapMaterialGroup op in Katana plugin for more robustly reading a Looks scope from a .usd file

Changed

  • Build now supports versioned OpenEXR and IlmBase shared libraries. (Issue: #71)
  • Layer identifiers may now include '?' characters. (Issue: #289)
  • UsdStage preserves payload load state when processing instancing changes.
  • UsdListPosition enum values now specify the "append" or "prepend" list as well as a position to provide users with finer-grained control.
  • The various Add... methods in Usd that take a UsdListPosition argument now author entries to the back of the "prepend" list by default if no "explicit" list exists. The old behavior of authoring to the (now deprecated) "added" list can be restored by setting the environment variable USD_AUTHOR_OLD_STYLE_ADD to 1.
  • Standard schema conventions are more strictly-enforced in usdGenSchema.
  • UsdCollectionAPI::AddCollection has been renamed ApplyCollection.
  • Enabled authoring of new UsdShade encoding by default. Authoring the old (now deprecated) encoding can be restored by setting the environment variable USD_SHADE_WRITE_NEW_ENCODING to 0.
  • The "joints" relationship on the UsdSkelSkeleton, UsdSkelPackedJointAnimation, and UsdSkelBinding API schemas is now a token array-valued attribute.
  • UsdRiStatements API schema has been renamed to UsdRiStatementsAPI.
  • sdfdump utility now shows all specs in a layer, even if they have no fields.
  • Various improvements to Hydra reprs and geometry processing.
  • More improvements to Hydra's handling of invalid data.
  • Ongoing work to prepare Hydra to fully consume UsdShade schemas.
  • Refactored GL dependency out of Hd library.
  • Built-in variables in usdview interpreter are now accessed through a separate usdviewApi object to avoid name collisions.
  • Performance improvements in Maya plugin when in Viewport 2.0.
  • Inclusion of info.usd.opArgs in Katana plugin is now parameterized; it will be authored to the location where a "setOpArgsToInfo" attribute exists and is set to 1.

Deprecated

  • The "added" list for list ops in scene description is deprecated in favor of the "prepend" and "append" lists.

Removed

  • GfCamera::ZUp and GfCamera::YUp.
  • UsdSkelJoint schema.

Fixed

  • build_usd.py ensures OpenImageIO build does not pick up OpenEXR from other locations, which could have led to runtime errors. (Issue: #315, Issue: #325)
  • Headers are now installed properly for monolithic builds. (Issue: #277)
  • Original install location will no longer be searched for plugins after relocating builds. (Issue: #363)
  • Fixed thread-safety issue where plugins with the same name but in different locations could be loaded twice. (Issue: #358)
  • Fixed bug where layers that were muted via SdfLayer::AddToMutedLayers before they were first opened could not be unmuted.
  • Fixed bug in usdGenSchema where changing an existing property's type in a schema would not be reflected in the generated code.
  • Fixed bug where a large (> 1460) number of variants in a .usda file would cause a "memory exhausted" error when parsing that file.
  • Fixed broken pread mode for .usdc files.
  • Fixed bug that caused UsdStage::CreateNew to crash on Windows. (Issue: #364)
  • Fixed bug when using a UsdStagePopulationMask with prims beneath instances. (Issue: #312)
  • Fixed bug where setting float-valued attributes to +inf in Python would fail.
  • UsdAttribute::GetTimeSamplesInInterval now properly accounts for layer offsets. (Issue: #352)
  • Internal references or empty asset paths no longer cause errors in UsdUtilsFlattenLayerStack.
  • Fixed bug where UsdGeomPrimvar::GetTimeSamples would miss time samples for indexed primvars.
  • Disabled tiny prim culling in Hydra by default. It can be re-enabled by setting the environment variable HD_ENABLE_TINY_PRIM_CULLING to 1. (Issue: #314)
  • Fixed issues with using non-file-backed asset paths in various utilities and Maya and Katana plugins.
  • Houdini plugin explicitly links against required libraries to avoid runtime errors with Houdini 16.5.
  • Fixed several bugs with point instancing support in Houdini plugin.

[0.8.2] - 2017-12-01

Release 0.8.2 increments the file format version for .usdc files. New .usdc files created in this release will not be readable by earlier releases. See below for more details.

Added

  • SdfCopySpec for copying scene description specs in layers.
  • Usd.GetVersion() for retrieving USD version in Python (Issue: #306)
  • UsdProperty::FlattenTo for copying a UsdProperty's resolved metadata/values.
  • IsTyped and IsConcrete schema queries on UsdSchemaRegistry and UsdSchemaBase.
  • UsdCollectionAPI schema for representing collections of objects. This schema is more expressive than UsdGeomCollectionAPI and can represent large numbers of objects compactly.
  • Utility functions in UsdUtils for determining compact representations of objects for UsdCollectionAPI.
  • UsdUtilsCoalescingDiagnosticDelegate, a Tf diagnostic delegate that provides condensed output for diagnostic messages.
  • UsdUtilsFlattenLayerStack for flattening a UsdStage's layer stack into a single layer, as well as a --flattenLayerStack option to usdcat.
  • Support for named clip sets for clip stitching API in UsdUtils.
  • Schema for cards rendering in UsdGeomModelAPI and imaging support. This provides a lightweight way to collapse model hierarchies into simple geometry for visualization of large scenes.
  • Ability to encode familyType on owners of families of UsdGeomSubsets.
  • Size properties for UsdLuxDiskLight, UsdLuxSphereLight, and UsdLuxRectLight. (Issue: #290)
  • Support for computing bounding boxes for UsdGeomPointInstancer instances using UsdGeomBBoxCache.
  • Support for residual GPU computations in Hydra.
  • Sheer display mode in Hydra, a 'see-through' display mode akin to the mesh being covered in a sheer mesh fabric instead of its regular surface. Implemented as a regular grid stipple pattern of the surface at 20% opacity.
  • Testing framework for usdview.
  • PxrUsdMayaXformStack for representing transform stacks in the Maya plugin.
  • Support for exporting Maya instancers to UsdGeomPointInstancers in the Maya plugin.
  • Support for exporting groups of objects with the same material binding as collections encoded with UsdCollectionAPI in the Maya plugin.
  • Support for vec4 primvars in the Katana plugin.
  • Support for point instancers with varying topology that don't have authored velocities in the Katana plugin.
  • Support for importing collections encoded with new UsdCollectionAPI schema in the Katana plugin.
  • Support for overriding data on a subset of point instancer instances in the Houdini plugin.

Changed

  • Build system now checks that the compiler being used supports 64-bit builds.

  • Tf diagnostic warnings and status messages issued in secondary threads are no longer printed to the terminal.

  • Multiple delegates may now be registered with the Tf diagnostic system.

  • SdfLayer::RemoveInertSceneDescription removes inert overs in variants.

  • When saving a new .usdc file over an existing file, data is first saved to a temporary file then renamed to the destination file. This provides some protection for other processes that were reading the old file.

  • Compression for structural sections in .usdc files is now enabled by default. New .usdc files will be marked as version 0.4.0 instead of 0.3.0 to accommodate a bug fix described below. This means that any new .usdc files created in this release will not be readable by previous USD releases.

    Users can disable the compression functionality by setting the environment variable USD_WRITE_NEW_USDC_FILES_AS_VERSION to "0.0.1". This will ensure new .usdc files will be readable in older releases.

  • UsdStage now uses the composed layer offset instead of its inverse when mapping times in layers to the stage. For example, to shift the time samples in a referenced layer stack forward by 10, users previously authored an offset of -10. Under the new behavior, users need to author an offset of 10 instead.

    Users can revert to the old behavior by setting the environment variable USD_USE_INVERSE_LAYER_OFFSET to 1. This will be deprecated in a future release.

  • UsdStage now allows a prim to be loaded without loading its descendants via a new UsdLoadPolicy argument supplied to UsdStage::Load and LoadAndUnload.

  • UsdInherits, UsdSpecializes, and UsdReferences now map non-root prim paths to the namespace of the edit target.

  • UsdAttribute::GetTimeSamplesInInterval now supports open/finite end points.

  • UsdClipsAPI now authors the dictionary-style clips metadata introduced in release 0.7.6 by default.

  • Schemas may now define fallback values for the majority of metadata fields, including custom metadata fields.

  • Schemas may now have more than 256 tokens defined.

  • usdedit now checks USD_EDITOR environment variable first when determining which editor to use.

  • Ongoing refactoring to move code from hd to hdSt in preparation for material support in Hydra and use of Hydra in other renderer backends.

  • Several performance optimizations in Hydra and UsdImaging.

  • usdview now uses a new JSON-based format for its settings file. Settings files from older releases will be ignored.

  • Several changes to provide better support for Viewport 2.0 in Maya plugin.

  • Enum attributes in Maya now have their integer values exported to USD instead of their descriptive names.

  • Improved attribute transfer on USD Unpack node in Houdini plugin.

  • usdvisible and usdactive attributes in Houdini plugin are now integers instead of strings.

  • Several changes to Houdini plugin for compatibility with Houdini 16.5 and improved HDK usage.

Deprecated

  • UsdGeomCollectionAPI, in favor of new UsdCollectionAPI.

Removed

  • TfDiagnosticNotice. The Tf diagnostic system no longer emits notices; consumers relying on these notices should use diagnostic delegates instead.
  • UsdGeomPointInstancer prototypeDrawMode attribute. Consumers should use the new drawMode attributes on UsdGeomModelAPI instead.

Fixed

  • Issue where users were forced to define certain preprocessor macros in order to build code against USD. In particular, an issue introduced in 0.8.1 caused users who did not #define PXR_ENABLE_PYTHON_SUPPORT to run into odd errors at runtime. (Issue: #304)
  • Bug that caused invalid .usdc files to be written. This affected all files with version 0.3.0; however, this file version was not enabled by default in release 0.8.1 and would only affect users who had explicitly enabled the new version via the USD_WRITE_NEW_USDC_FILES_AS_VERSION environment setting.
  • Precision loss when writing time sample times to .usda files.
  • Performance issue in UsdStage where memory would still be consumed by child prims after their parent prim had been deactivated.
  • Bug that caused UsdStage::ExpandPopulationMask to add invalid paths.
  • Bug that caused UsdObject::GetMetadata to not fill in resolved paths for asset-valued metadata.
  • Bug where layer offsets were incorrectly applied when authoring time samples.
  • Bug in UsdUtilsStageCache that led to crashes during static destruction.
  • Unpickable objects now act as occluders during picking in Hydra.
  • Bug that caused usdview to stop drawing after "Reopen Stage" or "Open Stage".
  • Bug that caused usdview to not play all frames if the step size was changed. (Issue: #321)
  • Several performance and UI issues in usdview.
  • Crash in Maya plugin with nested assemblies and variant set selections. (Issue: #288)
  • Bug in Maya plugin where exporting over a previously-imported layer failed.
  • Bug in Maya plugin that caused lights to flip between directional and non-directional in legacy viewport.
  • Various issues that prevented UsdKatana Python module from being imported. (Issue: #323)
  • Material bindings above point instancer prototypes are now preserved in the Katana plugin.
  • Reworked how USD masters/sources are built in the Katana plugin so that material bindings use the correct Katana paths.
  • Hang in Houdini plugin when importing from variant paths. (Issue: #309)

[0.8.1] - 2017-10-02

Added

  • "append" and "prepend" operations for SdfListOp-valued fields. Scene description layers that contain these new operations will not be readable by earlier USD releases.
  • --validate argument to sdfdump for checking file validity.
  • Support for sub-root references and payloads.
  • Ability to specify amount of data to prefetch when reading a .usdc file via the USDC_MMAP_PREFETCH_KB environment variable.
  • Debugging output that shows memory mapping information for .usdc files. This can be enabled via the USDC_DUMP_PAGE_MAPS environment variable.
  • UsdGeomMotionAPI schema.
  • UsdGeomSubset schema for representing a subset of a geometric prim.
  • Hydra GL support for displacement shaders
  • Initial experimental support for PySide2 in usdview. By default, the build will search for PySide, then PySide2. Alternatively, users may specify PYSIDE_USE_PYSIDE2=TRUE to CMake to force the use of PySide2.
  • Ability to view connections and relationship targets in usdview.
  • Support for camera clipping range in Alembic plugin.
  • Support for array attributes with "RfM Shaders" shading mode in Maya exporter.
  • Support for angularVelocities attribute on point instancers in Katana plugin.
  • Filtered view and improved selection to Tree View panel in Houdini plugin.
  • Support for prototype offsets in point instancer exports in Houdini plugin.

Changed

  • Made Python dependency optional. Python support is enabled by default but may be disabled by specifying PXR_ENABLE_PYTHON_SUPPORT=FALSE to CMake or --no-python to build_usd.py.

  • build_usd.py now requires that users install PyOpenGL manually. (Issue: #264)

  • Replaced addedOrExplicitItems attribute on Sdf.*ListOp in Python with GetAddedOrExplicitItems method.

  • Renamed Append... methods on composition arc APIs (e.g. UsdReferences, UsdInherits) to Add... and added a position argument to support new "append" and "prepend" operations.

    Calling these functions with the default UsdListPositionTempDefault argument will author "add" operations, maintaining the previous behavior. We anticipate removing UsdListPositionTempDefault and replacing it with UsdListPositionFront so that "prepend" operations will be authored by default in 0.8.2. Users may enable this behavior now by setting the USD_AUTHOR_OLD_STYLE_ADD environment variable to false.

  • UsdStage now issues warnings for invalid layers it encounters instead of errors, which cause exceptions in Python.

  • Code generation templates and schema.usda files used by usdGenSchema are now installed as part of the build. Schemas can now use asset paths like "usdGeom/schema.usda" or "usdShade/schema.usda" instead of absolute paths to add installed schemas as sublayers. (Issue: #158, Issue: #211)

  • Improved USD scenegraph instancing to allow more sharing of assets with inherits or specializes arcs. In one large example, this decreased stage load time by ~60%, stage memory usage by ~65%, and time to first image in usdview by ~20%.

  • Several optimizations to reduce I/O operations for .usda and .usdc files.

  • Add support for compressed structural sections in .usdc files. This can significantly decrease file sizes for files that are dominated by prim and property hierarchy; one production shading file decreased in size by ~94%, from 21 MB to 1.3 MB.

    Compressed files are marked as version 0.3.0 and are not readable by earlier USD releases. To help with transition, USD will not write these compressed files by default until a future release. Users may enable this feature now by setting the USD_WRITE_NEW_USDC_FILES_AS_VERSION environment variable to "0.3.0". We plan to add compression for geometry data and time samples in a future release.

  • UsdUtilsExtractExternalReferences now checks for references to external files in property values and metadata.

  • Increased precision for rotations attribute in UsdSkelPackedJointAnimation schema to 32-bit.

  • UsdGeomPrimvar now allows primvar names with arbitrarily-nested namespaces.

  • Sizeable refactor in Hydra to support sprims more like rprims in anticipation of future lights and material support.

  • Hydra no longer syncs rprims that are not visible.

  • Several performance and stability fixes to point instancer handling in Hydra.

  • "Reload All Layers" in usdview will try not to reset the camera or timeline.

  • Numerous other improvements to usdview.

  • The Alembic reader now converts single samples for properties in .abc files to single time samples in USD, instead of default values.

  • Updated required Katana version to Katana 2.5v1.

  • Improved bounds computations for point instancers in Katana plugin

  • Account for motion sample time overrides when computing bounding boxes in Katana plugin.

  • Improved stage cache in Houdini plugin, which can have significantly better performance in some circumstances.

  • Improved handling of instanced USD primitives in Houdini plugin.

Deprecated

  • UsdGeomFaceSetAPI and related API in usdShade and usdLux in favor of new UsdGeomSubset schema.

Removed

  • UsdStage::Close.
  • Camera zUp-related functionality
  • Support for faceVaryingInterpolateBoundary in UsdGeomMesh schema. See faceVaryingLinearInterpolation instead.

Fixed

  • Bug in build_usd.py where specifying --no-embree did the opposite. (Issue: #276)
  • Bug in build_usd.py where specifying --force-all or --force on a Python dependency would cause the script to error out early. (Issue: #263)
  • Race condition between TfType consumers and TfType registry initialization.
  • Composition bug where references with the same prim path and relative asset path would be considered duplicates even when anchoring location differed.
  • Composition bug where payloads on arcs requiring ancestral opinions could result in errors.
  • Change processing bug when removing sublayers specified by search path.
  • Stack overflow crash when reading .usdc files due to excessive recursion.
  • Possible crash in Hydra when using basis curves.
  • Memory leak in Hydra task controller.
  • Build issue for Alembic plugin with HDF5 support disabled when precompiled headers are enabled (which is the default on Windows).
  • Several other bugs in Alembic reader.
  • Performance issue in Katana plugin due to inefficiency in UsdShadeNodeGraph.

[0.8.0] - 2017-07-29

Added

  • Added option to build_usd.py for building monolithic shared library and for building new sample Embree plugin.
  • Added --mask option to usdcat, matching the --mask option in usdview.
  • Added CPU-side external computation support to Hydra.
  • Added Embree backend to serve as an example of how to add renderer plugins to Hydra.
  • Added camera gates to usdview.
  • Added ability to Houdini plugin to set active state via usdactive attribute and to write static data to default time via usdwritestatictopology, usdwritestaticprimvars, and usdwritestaticgeo attributes.
  • Added UsdExportAttributes hda to Houdini plugin for setting primitive and detail attributes which control various USD attributes or metadata.

Changed

  • Restored export of CMake targets from shared library builds.
  • Asset paths in .usda files may now contain any printable character. (Issue: #73)
  • Legacy special behavior for variant sets named "standin" has been disabled by default.
  • Interpolation is now applied to time samples from clips when no sample exists at a specified clip time.
  • Removed deprecated UsdShadePShader schema.
  • Enabled vertex primvar sharing in Hydra. Hydra can now use significantly less GPU memory.
  • Many internal performance improvements to Hydra.
  • usdview HUD now shows the backend renderer plugin used by Hydra
  • Wireframe drawing now ignores opacity.
  • Katana plugin properly interprets schema-supported triangle subdivision rule when meshes are read in and rendered.

Fixed

  • Fixed several issues in build_usd.py related to building dependencies. (Issue: #225, Issue: #230, Issue: #234)
  • Fixed bug where UsdGeomPrimvar::IsIndexed() would not work for attributes with only authored time samples. (Issue: #238)
  • Fixed small platform inconsistencies for Windows in Hydra.
  • Fixed crash in Katana plugin when using point instancers that did not have scales or orientations specified. (Issue: #239)
  • Fixed issue in Houdini plugin where the "w" attribute was not converted to the "angularVelocities" attribute for point instancer prims.

[0.7.6] - 2017-06-30

Added

  • Added build_scripts/build_usd.py for building USD and its dependencies.
  • Added support for building static libraries or a single monolithic shared library. See BUILDING.md for more details.
  • Added support for color spaces to Usd. Color configuration and management system can be specified on a UsdStage (via the stage's root layer), and colorSpace metadata is available on any UsdAttribute.
  • Added clip set functionality to Usd. This provides the ability to specify multiple sets of value clips on the same prim, which allows users to compose different sets of clips together. See UsdClipsAPI for more details.
  • Added initial UsdLux schemas for representing interchangeable lights and related concepts, and UsdRi schemas for Renderman-specific extensions. UsdImaging/Hydra support will be coming in a future release.
  • Added ability to specify smooth triangle subdivision scheme for catmullClark surfaces in UsdGeomMesh and imaging support in Hydra.
  • Added backdrops for node layout description in UsdUI.
  • Added support for sharing immutable primvar buffers to Hydra. This can greatly reduce the memory required on the GPU when displaying typical scenes. It is currently experimental and disabled by default. It can be enabled for testing with the environment variable HD_ENABLE_SHARED_VERTEX_PRIMVAR.
  • Added support for uniform primvars for basis curves in Hydra.
  • Added ability to Alembic plugin to control number of Ogawa streams used for each opened archive via the environment variable USD_ABC_NUM_OGAWA_STREAMS, which defaults to 4.
  • Added Katana plugin support for reading UsdLux lights.
  • Added --camera command line argument to usdview to specify the initial camera to use for viewing.
  • Added display of instance index and (if authored) instance ID to rollover prim info in usdview.
  • Added initial version of Houdini plugin.

Changed

  • Removed unnecessary dependency on OpenImageIO binaries.
  • Removed unnecessary dependency on boost::iostreams.
  • Made HDF5 backend for Alembic plugin optional. HDF5 support is enabled by default but may be disabled by specifying PXR_ENABLE_HDF5_SUPPORT=FALSE to CMake.
  • Metadata fields for value clips feature in UsdStage (e.g. clipAssetPaths, clipTimes, etc.) have been deprecated in favor of the new clips metadata dictionary. Authoring APIs on UsdClipsAPI still write out the deprecated metadata unless the environment variable USD_AUTHOR_LEGACY_CLIPS is set to 0. This will be disabled in a future release.
  • When using value clips, Usd will now report time samples at each time authored in the clip times metadata.
  • Completed support for encoding UsdShade data using UsdAttribute connections. Authoring APIs still write out the old encoding, unless the environment variable USD_SHADE_WRITE_NEW_ENCODING is set to 1. This will be enabled in a future release.
  • Removed support for deprecated UsdShade schemas UsdShadeParameter and UsdShadeInterfaceAttribute, which have been superseded by UsdShadeInput.
  • Removed deprecated UsdRiLookAPI, which has been replaced by UsdRiMaterialAPI.
  • Removed deprecated Hydra scene delegate APIs.
  • Significant refactoring and refinements to allow multiple backends to be plugged in to Hydra.
  • UsdImaging now pushes GL_DEPTH_BUFFER_BIT to avoid any potential state pollution issues when integrating it with other renderers.
  • Improved error handling in Hydra for:
    • Invalid point instancer input
    • Inconsistent displayColor and displayOpacity primvars
    • Direct instances of imageable prims
  • usdview more gracefully handles the situation where it doesn't get a valid GL context (e.g., due to limited resources on the GPU).
  • Improved how edits are handled on assembly nodes in the Maya plugin.
  • Improved UsdGeomPointInstancer support in the Katana plugin:
    • Overhauled methods for computing instance transforms and aggregate bounds.
    • Backward motion and multi-sampled point instancer positions, orientations, and scales are now supported.
    • Removed opArgs attributes that were used for configuring the reader's behavior.
    • More robust primvar transfer to point instancer's Katana locations.
    • Restructured prototype building logic to preserve material bindings when creating prototype prims.
  • Numerous changes and fixes for Mac and Windows ports.

Fixed

  • Fixed issue that caused IDEs and other tools to find headers in the build directories rather than the source directories.
  • Fixed race condition in TfType.
  • Fixed long-standing memory corruption bug in Pcp that surfaced when building on MacOS with XCode 8.3.2.
  • Fixed potential deadlocks in Usd and Pcp due to issues with TBB task group isolation.
  • Fixed bug where UsdStage::Flatten was not preserving attribute connections.
  • Fixed infinite loop on glGetError in the presence of an invalid GL context. (Issue: #198)
  • Fixed build issues that caused the Maya plugin to be unusable after building on MacOS.

[0.7.5] - 2017-05-01

C++ namespaces are now enabled by default. The PXR_ENABLE_NAMESPACES CMake option may be used to disable namespaces if needed.

This release adds initial experimental support for building the USD core libraries on Windows.

Added

  • Added ability to build doxygen documentation. See BUILDING.md for more details.
  • Added support for pre-compiled headers. By default, this is disabled for Linux and Mac builds and enabled for Windows builds. This may be configured with the PXR_ENABLE_PRECOMPILED_HEADERS CMake option.
  • Added many unit tests for core libraries
  • Added UsdStage::Save and UsdStage::SaveSessionLayers
  • Added attribute connection feature that allows consumers to describe connections between an attribute and other prims and properties.
  • Added instance proxy feature that allows consumers to interact with objects on a UsdStage as if scenegraph instancing were not in use while retaining the performance benefits of instancing.
  • Plugins providing Boundable schema types can now register functions for computing extents. This allows code in the USD core to compute extents for prims with types provided by external schemas.
  • Added support for specializes arcs to usdShade.
  • Added UsdUISceneGraphPrimAPI for representing prim display properties.
  • Added HD_DISABLE_TINY_PRIM_CULLING flag for TF_DEBUG to make it easier to turn off tiny prim culling for debugging.
  • Added support for generic metadata to GLSLFX, allowing hardware shaders to pass information to downstream rendering code.
  • Added ability to adjust basic material properties in usdview.
  • Plugins can now register MayaPrimWriter subclasses for exporting Maya nodes to USD prims.
  • Added ability to override default motion data (sample times, current time, shutter open/close) on a per-scope basis in Katana plugin. Users can author these overrides by modifying the global graph state, then decide to use the default motion values with or without these overrides applied.

Changed

  • Removed OpenEXR dependency from core libraries. Note that OpenEXR is still required for imaging.
  • Made Ptex dependency optional. It is only required if Ptex support for imaging is enabled. This is on by default, but can be disabled by specifying PXR_ENABLE_PTEX_SUPPORT=FALSE to CMake.
  • Cleaned up and expanded doxygen documentation:
    • Added documentation for value clips and scenegraph instancing USD features.
    • Enabled XML generation for external tools
    • Fixed invalid tags and formatting in several places
  • UsdTreeIterator has been replaced by UsdPrimRange, which provides container-like semantics in C++ (e.g., the ability to use them in range-based for loops).
  • Removed UsdPrim::GetPayload API
  • UsdRelationship and UsdAttribute will no longer forward target/connection paths that point to objects within instances to objects in master prims. Users can use the new instance proxy functionality to work with these paths instead.
  • Relationships belonging to prims in instances that point to the root of the instance no longer cause errors.
  • Value clip metadata can now be sparsely overridden across composition arcs.
  • Deprecated shading property schemas UsdShadeParameter and UsdShadeInterfaceAttribute. These are replaced by UsdShadeInput, which can represent both input parameters on shaders and interface inputs on node graphs.
  • The --compose command line parameter for usddiff is now --flatten
  • Numerous cleanup changes for Hydra API. In particular:
    • HdEngine::Draw has been retired in favor of HdEngine::Execute.
    • HdSceneDelegate::IsInCollection has been deprecated in favor of render-tag based API.
  • Meshes with subdivisionScheme = none will no longer be bilinearly subdivided.
  • usdview now displays prim hierarchies beneath instances inline in the browser. The "Jump to Master" command has been removed in favor of this new functionality.
  • The default specular response in usdview has been reduced by a factor of 5.
  • The Maya plugin now excludes attributes during import if they are tagged with customData specifying them as generated.
  • Numerous changes for ongoing Mac and Windows port efforts.
  • Changed scoping of built-out point instancer prototypes in Katana plugin so that their hierarchy more closely matches the original USD hierarchy.

Fixed

  • Added workaround to avoid redefined "_XOPEN_SOURCE" and "_POSIX_C_SOURCE" macro warnings due to Python includes on Linux. (Issue: #1)
  • Fixed issue where code would be generated directly into the install location when running cmake, interfering with the use of make's DESTDIR functionality. (Issue: #84)
  • Fixed memory leak when converting Python tuples to C++ GfVec objects.
  • Fixed thread-safety issue with PCP_PRIM_INDEX and PCP_PRIM_INDEX_GRAPHS TF_DEBUG flags. (Issue: #157)
  • Fixed invalid memory access bug in Pcp
  • Fixed memory leak when saving .usdc files.
  • Fixed bug with removing an attribute's last time sample in a .usdc file.
  • Fixed bug where instance prims with locally-defined variants would incorrectly share the same master prim.
  • Reader-writer locks are now used for various registry to improve performance.
  • Improved speed of adding an empty sublayer to an opened stage. In one large test case, time to add an empty sublayer went from ~30 seconds to ~5 seconds.
  • Fixed issues with opening .usda files and files larger than 4GB on Windows. (Issue: #189)
  • Fixed backwards compatibility issues with UsdShadeInput and UsdShadeConnectableAPI.
  • Memory footprint has been significantly reduced in Hydra's adjacency tables for subdivs that contain vertices of high valence.
  • Fixed crash in imaging due to invalid textures.
  • Fixed shadow banding artifacts when using vertex color with basis curves.
  • Fixed buffer overrun when using GPU smooth normals.
  • Fixed issue in Maya plugin where multiple assemblies that reference the same file might all be affected by the edits of one particular assembly when viewing them via a proxy.
  • Fixed issue in Maya plugin where path resolution was being done by the plugin itself rather than deferring to Usd and Sdf.

[0.7.4] - 2017-03-03

USD now supports C++ namespaces. They are disabled by default in this release to ease transition, but we anticipate enabling them by default in the next release.

Specify the PXR_ENABLE_NAMESPACES CMake option to enable namespaces. See documentation in BUILDING.md for more details.

Added

  • Added GfHalf type to represent half-precision numeric values. This type is currently an alias to the "half" type supplied by the ilmbase library USD is built against. This will be changed in an upcoming release to point to a version of "half" that is included in the USD codebase, which will allow us to remove the USD core's dependency on ilmbase.
  • Added UsdShadeInput class to represent shader or NodeGraph input. These are encoded as attributes in the "inputs:" namespace. By default, this encoding will not be written out via UsdShadeConnectableAPI unless the 'USD_SHADE_WRITE_NEW_ENCODING' environment variable is set.
  • Added "Composition" tab to usdview that allows users to inspect the composition structure of a selected prim.
  • Added tests for Hdx. These tests are currently not run as part of the unit test suite, but are being included for users to try on their platforms and to serve as example code.
  • Added icons for the USD assemblies in Maya.
  • Added initial implementation of Katana plugin for reading UsdGeomPointInstancer locations.

Changed

  • CMake module now additionally looks for the pyside-uic binary under the name pyside-uic-2.7 to accommodate package managers on OSX.
  • Removed GLUT dependency.
  • Removed double-conversion dependency.
  • Modified all uses of "half" type from ilmbase to use new GfHalf type.
  • Renamed UsdShadeSubgraph to UsdShadeNodeGraph to conform with final MaterialX terminology.
  • Numerous changes for in-progress work on refactoring Hydra to support render delegates.
  • Updated UI in usdview to display legends for text coloring in collapsible panes and to include more information.
  • The import UI in the Maya plugin now enables reading of anim data by default.
  • Updated API in Maya plugin that referred to "look" to "material".
  • Numerous changes for ongoing Mac and Windows porting efforts.

Fixed

  • Fixed several issues when building with C++ namespaces enabled.
  • Fixed bug with selection highlighting for instanced prims in usdview.
  • Fixed crash that occurred when an invalid color primvar was encountered while using usdview's "simple" renderer.
  • Fixed issue with TF_REGISTRY_DEFINE* macros that caused build failures for the Maya plugin on OSX. (Issue: #162)

[0.7.3] - 2017-02-05

Added

  • Added support for RelWithDebInfo and MinSizeRel release types.
  • Added initial support for C++ namespaces. This feature is currently experimental but can be enabled by specifying the PXR_ENABLE_NAMESPACES option to CMake. See documentation in BUILDING.md for more details.
  • Added population masking to UsdStage.
    • Consumers can specify what parts of a stage to populate and use to reduce resources used by the stage.
    • usdview now has a --mask option allowing users to view just the specified portion of a stage.
  • Added UsdPrim API for collecting relationship targets authored in a given prim subtree.
  • Added UsdShade API to allow creating and connecting outputs on subgraphs and shaders instead of terminals.
  • Added support for bool shader parameters in Hydra. (Issue: #104)
  • Added ability to independently toggle display of geometry with purpose=proxy in usdview.
  • Added initial set of unit tests for pxrUsd library in the Maya plugin.
  • The Maya plugin now supports multi-sampling of frames during export.
  • Attributes in Maya may now be tagged to be converted from double to single precision during export.
  • Alembic tagging for attributes in Maya are now respected during export. This includes support for primvars and custom prefixes.
  • Added support for playing back animation in assemblies via Hydra when the Playback representation is activated in Maya.
  • Added support for reading material references in Katana plugin.

Changed

  • CMake will no longer look for X11 on OSX. (Issue: #72)
  • The build system now uses relative paths for baking in plugin search paths, allowing for relocatable builds as long as all build products are moved together as one unit.
  • Removed hard-coded /usr/local/share directory from plugin search path.
  • Optimized creation of prim specs in Sdf. Creating 100k prim specs previously took 190s, it now takes 0.9s.
  • SdfPath::GetVariantSelection now returns a variant selection only for variant selection paths.
  • UsdStage no longer issues an error if requested to unload a path that does not identify an unloadable object.
  • Changed API on UsdInherits, UsdReferences, UsdRelationship, UsdSpecializes, UsdVariantSet, and UsdVariantSets for clarity.
  • Hydra GPU compute settings have been consolidated under a single HD_ENABLE_GPU_COMPUTE environment setting which is enabled by default if the OpenSubdiv being used supports the GLSL compute kernel.
  • Numerous changes for in-progress work on refactoring Hydra to support render delegates.
  • Changed 'Display' menu in usdview to 'Display Purposes...' and menu items to match USD terminology.
  • Updated required Maya version to Maya 2016 EXT2 SP2.
  • Normals are now emitted by default when exporting polygonal meshes in Maya.
  • Katana plugin now supports deactivating prims directly on UsdStage for improved efficiency.
  • Continued work on deprecating UsdShadeLook in favor of UsdShadeMaterial.
  • Numerous changes for ongoing Mac and Windows porting efforts.
  • Changed coding style to use symbol-like logical operators instead of the keyword-like form (e.g., '&&' instead of 'and').
  • Various cleanup changes to fix comments, compiler warnings, and to remove unused/old code.

Fixed

  • Fixed composition bug where nested variants with the same name were composed incorrectly.
  • Fixed composition bug where variant selections from classes were not being applied in certain cases. (Issue: #156)
  • Fixed .usda file output to write out floating point values using the correct precision and to use exponential representation for values greater than 1e15 (instead of 1e21) to avoid parsing issues.
  • Fixed bug where negative double values that could be represented as floats were not stored optimally in .usdc files.
  • Fixed bug where UsdPrim::Has/GetProperty would return incorrect results.
  • Fixed bug where UsdObject::GetMetadata would return incorrect results for dictionary-valued metadata in certain cases.
  • Fixed bug where reading certain .usdc files while forcing single-threaded processing via PXR_WORK_THREAD_LIMIT would lead to a stack overflow.
  • Fixed missing garbage collection for shader and texture resource registries in Hydra.
  • Several fixes for nested instancing support in Hydra (native USD instances containing other instances or point instancers, etc.)
  • Fixed "Jump to Bound Material" in "Pick Models" selection mode in usdview.
  • Fixed bug where USD assemblies would not be drawn in Maya under VP2.0.
  • Workaround for performance issue when drawing proxies in Katana plugin.
  • Fixed issue causing USD Alembic plugin to fail to build with Alembic 1.7. (Issue: #106)
  • Various other bug fixes and performance improvements.

[0.7.2] - 2016-12-02

Added

  • Added ability to apply a custom prefix to shared library names by specifying the PXR_LIB_PREFIX option to CMake.
  • Added ability to disable tests by using the PXR_BUILD_TESTS option with CMake.
  • usddiff can now diff two directories containing USD files.
  • Value clips on a prim may now be specified using 'template' clip metadata. This is a more compact representation for simple cases where each value clip corresponds to a single time code.
  • Better support for non-file-backed asset resolution
    • Made ArDefaultResolver public, so that subclasses can layer behavior on top of it.
    • Added ArResolver API for retrieving files from data store when needed.
  • Initial version of UsdGeomPointInstancer schema and preliminary support in usdImaging.
  • pxrUsdReferenceAssemblies in Maya can now import animation from a USD scene. See http://openusd.org/docs/Maya-USD-Plugins.html#MayaUSDPlugins-ImportingasAssemblies for details.
  • Core USD metadata (e.g. hidden, instanceable, kind) now roundtrips through Maya, stored as "USD_XXX" attributes on corresponding Maya nodes.

Changed

  • Removed dependency on Qt. Note that PySide is still a dependency for usdview.
    • Removed imaging/glfq library as part of this work.
  • Modified variant behavior in composition:
    • Variants may now be nested within other variants in scene description. Nested variants may be authored by using nested UsdEditContext objects returned by UsdVariantSet::GetVariantEditContext.
    • Weaker variants may now introduce variant selections that affect stronger variants. Previously, these selections would be ignored and the variant fallbacks would be used instead.
  • Optimized .usdc file format performance in certain cases:
    • Output is buffered in memory to improve write times for layers containing many nested dictionaries. In one such example, wall-clock time improved by ~64% and system time improved by 89%.
    • Time samples are now written out grouped by time to improve read performance for frame-by-frame access patterns.
  • Several optimizations to improve USD scenegraph authoring and composition speed and reduce memory consumption. In some use cases, we observed:
    • ~5-7x less memory consumed by Pcp dependency tracking structures
    • ~40% less time spent to author large stages
  • Exporting USD from the Maya Export window now produces binary .usd files by default instead of .usda files.

Fixed

  • Fixed bug where edits to a layer opened in Maya would persist when reopening that layer in a new scene.
  • Fixed issue where exporting USD from the Maya Export window would produce files ending with ".usda", even if a different format was specified. The exporter should now respect any extension that is entered, so long as the "Default file extensions" option is turned off.
  • Fixed several issues with example plugins being improperly built, making them unusuable, and missing functionality.
  • Various other bug fixes and performance improvements.

[0.7.1] - 2016-09-21

Added

  • UsdMaterial schema for shading, intended to replace UsdLook. Also added support for this new schema to Hydra.
  • Initial version of UsdUI schema library, intended for encoding GUI information on USD prims.
  • Parallel teardown of some data members in UsdStage, speeding up overall teardown by ~2x.
  • Support for packed vertex normals to Hydra, reducing GPU memory consumption by 20-30% in some cases.
  • Ability to compare two composed stages to usddiff by specifying the "--compose" or "-c" options.
  • Support for soft-selection for collapsed USD assemblies in Maya.
  • Support for exporting color sets and UV sets as indexed primvars from Maya.

Changed

  • Refactored Hydra libraries to move higher-level concepts out of the core hd library and into hdx.
  • Removed use of opensubdiv3/ include path from imaging code in favor of standard opensubdiv/ include.
  • Modified UsdStage to automatically load newly-discovered payloads if their nearest ancestor's payload was also loaded. For example, consumers will no longer have to explicitly call UsdStage::Load to ensure payloads are loaded when switching variants on a prim, so long as their nearest ancestor is also loaded.
  • Refactoring and other changes to help with Mac and Windows ports.
  • Updated doxygen and other documentation.

Fixed

  • Fixed issue that caused Alembic plugin (usdAbc) to be misconfigured at build time, which required users to manually update its plugInfo.json and set an environment variable at runtime to make it work. This plugin is now installed to $PREFIX/plugin/usd/ and requires no additional steps to use once it has been built.

  • Fixed issue with .usdc files that resulted in corrupted files on Windows. The file structure was changed, so the .usdc version has been bumped from 0.0.1 to 0.1.0. USD will continue to write 0.0.1 files by default, but will begin writing 0.1.0 files in the near future.

    Users may choose to write files with the new version immediately by setting the environment variable USD_WRITE_NEW_USDC_FILES_AS_VERSION to "0.1.0".

    Note that 0.0.1 files are still readable using this release, except for those that have been generated on Windows using 0.7.0. Early testers on Windows will need to regenerate those files with this release.

  • Fixed issue that caused usdGenSchema to generate files that could not be compiled.

  • Added a workaround for TBB-related issue in Maya that caused hangs when using the USD Maya plugin. This can be enabled at build time by specifying the PXR_MAYA_TBB_BUG_WORKAROUND option to CMake.

  • Various other bug fixes and performance improvements.

[0.7.0] - 2016-08-01

Initial release