diff options
author | Campbell Barton <ideasman42@gmail.com> | 2012-04-28 15:45:28 +0400 |
---|---|---|
committer | Campbell Barton <ideasman42@gmail.com> | 2012-04-28 15:45:28 +0400 |
commit | 4dd552fef9bc009dcad052121f827be84b8e8f86 (patch) | |
tree | e48404874d259b88c4979fcb480ab8e8139150bf /source/blender | |
parent | 9caab2e26501f709109024ade3063e3762a19929 (diff) |
patch [#31104] Correct comment for mul_qt_v3
from Bill Currie (taniwha)
Diffstat (limited to 'source/blender')
-rw-r--r-- | source/blender/blenlib/intern/math_rotation.c | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/source/blender/blenlib/intern/math_rotation.c b/source/blender/blenlib/intern/math_rotation.c index bb3265bdf33..37402f9391c 100644 --- a/source/blender/blenlib/intern/math_rotation.c +++ b/source/blender/blenlib/intern/math_rotation.c @@ -78,7 +78,23 @@ void mul_qt_qtqt(float q[4], const float q1[4], const float q2[4]) q[2] = t2; } -/* Assumes a unit quaternion */ +/** + * \note: + * Assumes a unit quaternion? + * + * infact not, but you may wan't to use a unit quat, read on... + * + * Shortcut for 'q v q*' when \a v is actually a quaternion. + * This removes the need for converting a vector to a quaternion, + * calculating q's conjugate and converting back to a vector. + * It also happens to be faster (17+,24* vs * 24+,32*). + * If \a q is not a unit quaternion, then \a v will be both rotated by + * the same amount as if q was a unit quaternion, and scaled by the square of + * the length of q. + * + * For people used to python mathutils, its like: + * def mul_qt_v3(q, v): (q * Quaternion((0.0, v[0], v[1], v[2])) * q.conjugated())[1:] + */ void mul_qt_v3(const float q[4], float v[3]) { float t0, t1, t2; |