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.5.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.5-py3-none-any.whl (179.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: semantic_digital_twin-0.0.5.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.5.tar.gz
Algorithm Hash digest
SHA256 1ba8202dc8cee31dbfd5956af53ae6609fff6be63dd4d81cf14912df55016a1a
MD5 eec22d43c41dbe8d1d65907d2b856c65
BLAKE2b-256 2ea1d3631d5dd9dce0c6a16fbd73c5fd49696233c733f6b1e7f17bdff76e748f

See more details on using hashes here.

Provenance

The following attestation bundles were made for semantic_digital_twin-0.0.5.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.5-py3-none-any.whl.

File metadata

File hashes

Hashes for semantic_digital_twin-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 cf9579c7f5a50d6e1207fe4f822719890985f7d96e29d959d5dcac288351190c
MD5 28ad822b79db7a5d3f3c47f1eab8eda3
BLAKE2b-256 4ba05a59b0e45cad0c27f702167be01854e8743f53ffff45f2aff7c75abcbb8b

See more details on using hashes here.

Provenance

The following attestation bundles were made for semantic_digital_twin-0.0.5-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