-
Notifications
You must be signed in to change notification settings - Fork 7
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
39 additions
and
68 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
# Dual Quaternions | ||
|
||
![test badge](https://github.com/Achllle/dual_quaternions/actions/workflows/run_tests.yml/badge.svg) | ||
![last tag version badge](https://img.shields.io/github/v/tag/achllle/dual_quaternions) | ||
|
||
Dual quaternions are a way of representing rigid body transformations, just like homogeneous transformations do. Instead of using a 4x4 matrix, the transformation is represented as two quaternions. This has several advantages, which are listed under [Why use dual quaternions?](#why-use-dual-quaternions). The term 'dual' refers to dual number theory, which allows representing numbers (or in this case quaternions) very similar to complex numbers, with the difference being that `i` or `j` becomes `e` (epsilon), and instead of `i^2 = -1`, we have `e^2 = 0`. This allows, for example, the multiplication of two dual quaternions to work in the same way as homogeneous matrix multiplication. | ||
|
||
For more information on dual quaternions, take a look at the [References](#references). | ||
For conversion from and to common ROS messages, see [dual_quaternions_ros](https://github.com/Achllle/dual_quaternions_ros>). | ||
|
||
[![viz.gif](viz.gif)](https://gist.github.com/Achllle/c06c7a9b6706d4942fdc2e198119f0a2) | ||
|
||
## Why use dual quaternions? | ||
|
||
* dual quaternions have all the advantages of quaternions including unambiguous representation, no gimbal lock, compact representation | ||
* direct and simple relation with screw theory. Simple and fast Screw Linear Interpolation (ScLERP) which is shortest path on the manifold | ||
* dual quaternions have an exact tangent / derivative due to dual number theory (higher order taylor series are exactly zero) | ||
* we want to use quaternions but they can only handle rotation. Dual quaternions are the correct extension to handle translations as well. | ||
* easy normalization. Homogeneous tranformation matrices are orthogonal and due to floating point errors operations on them often result in matrices that need to be renormalized. This can be done using the Gram-Schmidt method but that is a slow algorithm. Quaternion normalization is very fast. | ||
* mathematically pleasing | ||
|
||
## Installation | ||
|
||
```bash | ||
pip install dual_quaternions | ||
``` | ||
|
||
## Usage | ||
|
||
```python | ||
from dual_quaternions import DualQuaternion | ||
``` | ||
|
||
## References | ||
|
||
* \K. Daniilidis, E. Bayro-Corrochano, "The dual quaternion approach to hand-eye calibration", IEEE International Conference on Pattern Recognition, 1996 | ||
* Kavan, Ladislav & Collins, Steven & Zara, Jiri & O'Sullivan, Carol. (2007). Skinning with dual quaternions. I3D. 39-46. 10.1145/1230100.1230107. | ||
* Kenwright, B. (2012). A Beginners Guide to Dual-Quaternions What They Are, How They Work, and How to Use Them for 3D Character Hierarchies. | ||
* Furrer, Fadri & Fehr, Marius & Novkovic, Tonci & Sommer, Hannes & Gilitschenski, Igor & Siegwart, Roland. (2018). Evaluation of Combined Time-Offset Estimation and Hand-Eye Calibration on Robotic Datasets. 145-159. 10.1007/978-3-319-67361-5_10. |
This file was deleted.
Oops, something went wrong.