Skip to main content

A world model that unifies kinematic information and semantic meaning for robotic world representations.

Project description

Welcome to the Semantic Digital Twin Package

Introducing Semantic Digital Twin: A unified interface for scene data and asserted meaning.

The Semantic Digital Twin Python package streamlines the integration and management of scene graphs with explicit semantic assertions. Agents and autonomous systems require more than just coordinates, they need contextual understanding. Semantic Digital Twin bridges geometry, kinematics, and meaning, allowing systems for planning, learning, and reasoning to process the environment through actionable, high-level concepts.

This enables the construction of environments that can be readily understood, queried, transformed, and shared across projects. Whether for research prototypes or robust data pipelines, Semantic Digital Twin translates raw environment data into structured knowledge.

Assimilated Technologies

Assimilation Icon Assimilation Icon

🌍 Model full kinematic worlds, not just meshes. Define bodies, regions, connections, and degrees of freedom as primary, first-class entities within a clean, composable Python API.

🤔 Enhance meaning with Views. Transform raw geometry into actionable concepts like drawers, handles, containers, and task-relevant regions. Express relationships and intent beyond simple shapes.

💡 Intelligent Querying. Use a high-level entity query language to precisely locate relevant elements—e.g., "the handle attached to the drawer that is currently accessible"—to enable targeted interaction.

🛢️️ Reproducible Persistence and Replay. Serialize annotated worlds into a SQL format, allowing for faithful reconstruction as consistent, interactive objects. This facilitates reproducible experiments and robust machine learning data pipelines.

🛠️ Effortless Composition. Leverage factories and dataclasses for simple authoring of complex scenes and extending semantics. Share domain knowledge efficiently without reliance on fragile glue code.

📈 Scale and Consistency. The integrated kinematic tree, DoF registry, and robust world validation ensure model consistency and integrity from initial prototype to large-scale production deployment.

🔮 Flexible Visualization. View worlds in lightweight RViz2, explore within notebooks, or integrate with richer simulation environments. Quickly understand both the structural and semantic layers of your models.

🔌 Pluggable Integration. Use a multitude of adapters for seamless import, no matter if its URDF, USD, MJCF, etc.

🦾 Reliable Kinematics. Compute forward transforms and inverse (backward) kinematics cleanly across the tree, providing a straightforward and robust foundation for pose queries, control, and reasoning.

👯‍ Real-Time World Synchronization. Maintain a consistent state across multiple processes and robotic agents using lightweight, real-time world synchronization. Structures can be created, merged, and updated at once, ensuring they are accurately reflected across all connected instances.

🚀 Get started with the user-guide!

📖 Read the full documentation!

🤝 Contribute with the developer-guide!

User Installation

You can install the package directly from PyPI:

pip install -U semantic_digital_twin

Contributing

If you are interested in contributing, you can check out the source code from GitHub:

git clone https://github.com/cram2/semantic_digital_twin.git

Development Dependencies

sudo apt install -y graphviz graphviz-dev
pip install -r requirements.txt

Tests

The tests can be run with pytest directly in PyCharm or from the terminal after installing Semantic Digital Twin as a python package.

pip install -e .
pytest test/

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

semantic_digital_twin-0.0.3.tar.gz (5.9 MB view details)

Uploaded Source

Built Distribution

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

semantic_digital_twin-0.0.3-py3-none-any.whl (178.2 kB view details)

Uploaded Python 3

File details

Details for the file semantic_digital_twin-0.0.3.tar.gz.

File metadata

  • Download URL: semantic_digital_twin-0.0.3.tar.gz
  • Upload date:
  • Size: 5.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for semantic_digital_twin-0.0.3.tar.gz
Algorithm Hash digest
SHA256 c72b146bb80c42a5e50fe5b9309de59bc8cd16c785a0c774ee29e73eb4aa071c
MD5 5477ae737098165e879bed69749899e3
BLAKE2b-256 13bd0fd7836a89410056519cf7f802058bc3c9bc8a05a7105d7c334bab93600f

See more details on using hashes here.

Provenance

The following attestation bundles were made for semantic_digital_twin-0.0.3.tar.gz:

Publisher: publish-to-pypi.yml on cram2/semantic_digital_twin

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

File details

Details for the file semantic_digital_twin-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for semantic_digital_twin-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 e01ed8971cedc5e90a68fc3920001af7e9772dc8f9141040dc9fbc7bfaaea645
MD5 342840a488f48dd924141093fc227fb7
BLAKE2b-256 a456c22b57b31cc9cf79f93474c99aa928e4d44bd808ba2ee51c5f5605219825

See more details on using hashes here.

Provenance

The following attestation bundles were made for semantic_digital_twin-0.0.3-py3-none-any.whl:

Publisher: publish-to-pypi.yml on cram2/semantic_digital_twin

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