Skip to main content

OpenUSD schema definitions for the Newton physics engine

Project description

newton-usd-schemas

Overview

Newton USD schemas provide extensions to OpenUSD's UsdPhysics specification, allowing USD layers to configure the Newton runtime data model.

These schemas can be deployed into any python runtime with USD support, allowing content creators to author Newton compatible robots, props, and environments in any application of their choice, without requiring the Newton runtime itself.

This project is part of Newton, a Linux Foundation project which is community-built and maintained.

Get Started

These schemas are codeless, in that they contain no compiled code nor any public API of their own. Since codeless schemas do not provide any code, clients do not need to recompile USD to use or update these schemas. They are deployed as a python module via a wheel package for convenience, as all Newton projects use pyproject based dependencies and most USD authoring workflows include a python runtime.

To start using the schemas, install the python wheel into a virtual environment using your favorite package manager:

python -m venv .venv
source .venv/bin/activate
pip install newton-usd-schemas
pip install usd-core  # or any other USD runtime

At runtime, simply import the module to register the schemas with OpenUSD.

Important: Schemas must be registered before the Usd.SchemaRegistry is initialized. Make sure to import the module very early in the process.

import newton_usd_schemas  # this registers the schema
from pxr import Usd, UsdPhysics

stage: Usd.Stage = Usd.Stage.CreateInMemory()

# create a UsdPhysics.Scene and set gravity
scene: UsdPhysics.Scene = UsdPhysics.Scene.Define(stage, "/scene")
scene.GetGravityMagnitudeAttr().Set(9.81)

# apply a Newton schema and set some of its attributes
prim: Usd.Prim = scene.GetPrim()
prim.ApplyAPI("NewtonSceneAPI")
prim.GetAttribute("newton:timeStepsPerSecond").Set(500)  # 2ms

stage.Export("/tmp/my_robot.usda")  # or .usdc or .usd

Once a USD layer is authored to storage, it can be loaded into a Newton runtime using Newton's USD Parsing mechanism.

Experimental Status

The Newton USD Schemas are currently in a v0.x development phase. The schemas are considered experimental and could change in future releases.

If existing schemas need to change in subsequent releases, we will first attempt to provide easy migrations via non-breaking changes and deprecations. However, in some cases a breaking change may be required, and we will provide auto-upgrade scripts or agentic skills to aid content migration.

Please note automated upgrades may not always be possible and content could require manual updates to comply.

Design Principles

Newton schemas follow a minimalist approach to determine which attributes should be included, and are similar to the philosophy that UsdPhysics and the Newton API follow for capturing parameters that generalize across simulators. We view the Newton schemas as a proving and staging ground for physics parameters that should eventually be eligible for promotion into the UsdPhysics standard.

A USD attribute belongs in the Newton schema if it meets one of these criteria:

  1. Clear Physical Meaning: The attribute represents a physically meaningful quantity rather than a modeling or approximation parameter (e.g., simulation time step dt, or gravitational acceleration), and is supported by at least one Newton solver.

  2. Cross-Solver Support: The attribute has a direct (or transformable) correspondence to parameters supported by at least two Newton solvers. This mainly applies to physical modeling parameters (e.g., a viscous joint friction coefficient).

For solver-specific or workflow-specific parameters that are not in UsdPhysics or the Newton schema, Newton supports solver-specific schemas (e.g., mjcPhysics) or custom attributes.

Contribution Guidelines

Contributions from the community are welcome. See CONTRIBUTING.md to learn about contributing via GitHub issues, as well as building the project from source and our development workflow.

General contribution guidelines for Newton repositories are available here.

Community

For questions about these newton-usd-schemas, feel free to join or start a GitHub Discussions.

By participating in this community, you agree to abide by the Linux Foundation Code of Conduct.

References

License

newton-usd-schemas is provided under the Apache License, Version 2.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

newton_usd_schemas-0.3.1.tar.gz (66.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

newton_usd_schemas-0.3.1-py3-none-any.whl (18.2 kB view details)

Uploaded Python 3

File details

Details for the file newton_usd_schemas-0.3.1.tar.gz.

File metadata

  • Download URL: newton_usd_schemas-0.3.1.tar.gz
  • Upload date:
  • Size: 66.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for newton_usd_schemas-0.3.1.tar.gz
Algorithm Hash digest
SHA256 18f6c03f23ffff3a4d4f313b02c70d4f925d449da2b378f1f8309cd13eb1a250
MD5 ff9049bc3efd99de46250be4c0e4d0b4
BLAKE2b-256 555dd48294ea0f60cee4afa8d20757b9a7d2aa7b278da5b70e6070145666b460

See more details on using hashes here.

Provenance

The following attestation bundles were made for newton_usd_schemas-0.3.1.tar.gz:

Publisher: ci.yml on newton-physics/newton-usd-schemas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file newton_usd_schemas-0.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for newton_usd_schemas-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bc99d8bf8fe0b51fadaca520c5b481b4ceb9c0b14f47665fdf28070d511f9524
MD5 1d0f031953edb853fc6fe7d5988d5a10
BLAKE2b-256 2bb684647196a15dbb51a530a303085b2bb9ef54084a7111755f7a33450193c5

See more details on using hashes here.

Provenance

The following attestation bundles were made for newton_usd_schemas-0.3.1-py3-none-any.whl:

Publisher: ci.yml on newton-physics/newton-usd-schemas

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page