Difference between revisions of "Slerp"

From Second Life Wiki
Jump to navigation Jump to search
m
m (forumlink)
Line 11: Line 11:
<lsl>rotation slerp( rotation a, rotation b, float t ) {
<lsl>rotation slerp( rotation a, rotation b, float t ) {
   return llAxisAngle2Rot( llRot2Axis(b /= a), t * llRot2Angle(b)) * a;
   return llAxisAngle2Rot( llRot2Axis(b /= a), t * llRot2Angle(b)) * a;
}//Written collectively, Taken from http://forums.secondlife.com/showthread.php?p=536622</lsl>
}//Written collectively, Taken from http://forums-archive.secondlife.com/54/3b/50692/1.html</lsl>
Source: http://forums.secondlife.com/showthread.php?p=536622
Source: http://forums-archive.secondlife.com/54/3b/50692/1.html

Revision as of 16:23, 24 May 2010

"Wikipedia logo"Slerp

Slerp is shorthand for spherical linear interpolation, introduced by Ken Shoemake in the context of quaternion interpolation for the purpose of animating 3D rotation. It refers to constant speed motion along a unit radius great circle arc, given the ends and an interpolation parameter between 0 and 1.

The following slerp algorithm uses a and b for ends and t for the interpolation parameter.
To continue the rotation past the ends use a value for t outside the range [0, 1].

<lsl>rotation slerp( rotation a, rotation b, float t ) {

  return llAxisAngle2Rot( llRot2Axis(b /= a), t * llRot2Angle(b)) * a;

}//Written collectively, Taken from http://forums-archive.secondlife.com/54/3b/50692/1.html</lsl> Source: http://forums-archive.secondlife.com/54/3b/50692/1.html