6D vs Euler rotation regression

Shows the continuous 6D rotation representation is far easier for a network to regress than Euler angles.

Trained from scratch in Ropedia Academy β€” an interactive, bilingual course on embodied & spatial AI. Educational model: small and quick to train; the value is the method and a reproducible pipeline, not a leaderboard score. Try it live in the Ropedia demos Space.

At a glance

Base model Trained from scratch (random initialization) β€” no pretrained base model.
Task 3D rotation regression
Training objective Regress 3D rotations under a geodesic loss, comparing the continuous 6D parameterization against Euler angles.
Track A Β· Human modeling
Notebook Open In Colab

Dataset

  • Name: Random SO(3) rotations
  • Type: synthetic β€” procedural
  • Size / stats: uniform rotations via random quaternions; input = rotation applied to 8 fixed 3D points (24-D); 256/batch
  • Split: generative (infinite)
  • Source: procedural

Training config

Adam (lr 1e-3), 3000 steps; geodesic rotation loss; two heads (6D vs Euler) compared.

Evaluation results

metric value meaning
geo_6d (final) 0.0126
geo_euler (final) 0.1313

figure

Inference example

import torch
state = torch.load("rot6d.pt", map_location="cpu")   # this repo's checkpoint
# Rebuild the exact module from the lab notebook (see "Reproduce"), then:
# model.load_state_dict(state); model.eval()

Limitations

Educational scale. Trained quickly on CPU on small or synthetic data, so absolute numbers are not competitive with production systems β€” the value is the method and a reproducible pipeline. No large-scale data, no hyperparameter sweep, and no multi-seed variance is reported. Not for production use.

Failure cases

The Euler baseline fails near gimbal lock / the Β±180Β° wrap (a representation discontinuity) β€” exactly what 6D fixes.

Reproduce / train your own

One click: open the notebook in Colab β†’ Runtime β†’ GPU β†’ Run all, then run its Publish to the Hugging Face Hub cell.

Open In Colab

From a shell:

git clone https://github.com/ChaoYue0307/ropedia-academy.git && cd ropedia-academy
pip install torch numpy matplotlib scikit-learn scikit-image gymnasium
jupyter nbconvert --to notebook --execute notebooks/training/A_rotation_6d.ipynb --output run.ipynb
# optional: override training length, e.g.  STEPS=2000  (or EPISODES=600)  before running

Files

  • figure.png
  • metrics.json
  • rot6d.pt

License

Code & weights: MIT (this repository) β€” educational use encouraged.
Data: generated procedurally in the notebook β€” no external dataset.

Citation

If you use this model or the course materials, please cite:

@misc{ropedia_academy,
  title  = {Ropedia Academy: an interactive course on embodied & spatial AI},
  author = {Ropedia Academy},
  year   = {2026},
  howpublished = {\url{https://chaoyue0307.github.io/ropedia-academy/}}
}

Method / original work: Zhou et al., On the Continuity of Rotation Representations in Neural Networks, CVPR 2019.

Related assets


Part of the Ropedia Academy trained-model collection. Contributions & issues welcome on GitHub.

Downloads last month

-

Downloads are not tracked for this model. How to track
Inference Providers NEW
This model isn't deployed by any Inference Provider. πŸ™‹ Ask for provider support

Collection including cy0307/a-rotation-6d