Package jme3utilities.math
Class MyQuaternion
java.lang.Object
jme3utilities.math.MyQuaternion
Mathematical utility methods.
-
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionstatic voidaccumulateScaled(Quaternion total, Quaternion input, float scale) Accumulate a linear combination of quaternions.static voidcardinalizeLocal(Quaternion input) Find the cardinal rotation most similar to the specified Quaternion.static Quaternionconjugate(Quaternion q, Quaternion storeResult) Return the conjugate of a Quaternion.static StringGenerate a textual description of a Quaternion value.static doubledot(Quaternion q1, Quaternion q2) Return the dot (scalar) product of 2 quaternions.static Quaternionexp(Quaternion q, Quaternion storeResult) Return the exponential of a pure Quaternion.static booleanisPure(Quaternion q) Test for a pure Quaternion.static booleanTest whether the specified Quaternion represents an identity rotation.static booleanisZero(Quaternion q) Test for a zero Quaternion.static doubleReturn the squared length of the argument.static Quaternionlog(Quaternion q, Quaternion storeResult) Return the natural logarithm of a normalized quaternion.static booleanne(Quaternion a, Quaternion b) Test whether 2 quaternions are distinct, without distinguishing 0 from -0.static voidnormalizeLocal(Quaternion input) Normalize the specified Quaternion in place.static Quaternionpow(Quaternion base, float exponent, Quaternion storeResult) Raise a normalized quaternion to the specified real power.static Vector3frotate(Quaternion rotation, Vector3f input, Vector3f storeResult) Rotate the input vector using the specified quaternion.static Vector3frotateInverse(Quaternion rotation, Vector3f input, Vector3f storeResult) Rotate the input vector using the inverse of the specified quaternion.static Quaternionslerp(float t, Quaternion q0, Quaternion q1, Quaternion storeResult) Interpolate between 2 normalized quaternions using spherical linear (Slerp) interpolation.static Quaternionsquad(float t, Quaternion p, Quaternion a, Quaternion b, Quaternion q, Quaternion storeResult) Interpolate between 4 normalized quaternions using the Squad function.static QuaternionsquadA(Quaternion q0, Quaternion q1, Quaternion q2, Quaternion storeResult) Return Squad parameter "a" for a continuous first derivative at the middle point of 3 specified control points.static Quaternionstandardize(Quaternion input, Quaternion storeResult) Standardize a Quaternion in preparation for hashing.static booleanvalidateUnit(Quaternion q, String description, float tolerance) Validate a normalized quaternion as a method argument.
-
Field Details
-
logger
message logger for this class
-
-
Method Details
-
accumulateScaled
Accumulate a linear combination of quaternions.- Parameters:
total- sum of the scaled inputs so far (not null, modified, may beinput)input- the Quaternion to scale and add (not null, unaffected unless it'stotal)scale- scale factor to apply to the input
-
cardinalizeLocal
Find the cardinal rotation most similar to the specified Quaternion. A cardinal rotation is one for which the rotation angles on all 3 axes are integer multiples of Pi/2 radians.- Parameters:
input- the input value (not null, modified)
-
conjugate
Return the conjugate of a Quaternion.For normalized quaternions, the conjugate is a fast way to calculate the inverse.
- Parameters:
q- the input value (not null, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beq)- Returns:
- a conjugate quaternion (either
storeResultor a new instance)
-
describe
Generate a textual description of a Quaternion value.- Parameters:
q- the value to describe (may be null, unaffected)- Returns:
- a description (not null, not empty)
-
dot
Return the dot (scalar) product of 2 quaternions.This method returns a double-precision value for precise comparison of angles.
- Parameters:
q1- the first input value (not null, unaffected)q2- the 2nd input value (not null, unaffected)- Returns:
- the dot product
-
exp
Return the exponential of a pure Quaternion.- Parameters:
q- the input value (not null, w=0, unaffected)storeResult- storage for the result (modified if not null)- Returns:
- the exponential value (either
storeResultor a new instance)
-
isPure
Test for a pure Quaternion.- Parameters:
q- the value to test (not null, unaffected)- Returns:
- true if w=0, false otherwise
-
isRotationIdentity
Test whether the specified Quaternion represents an identity rotation.Accepts any finite, non-zero value for w.
- Parameters:
q- the value to test (not null, unaffected)- Returns:
- true for a rotation identity, otherwise false
-
isZero
Test for a zero Quaternion.- Parameters:
q- the value to test (not null, unaffected)- Returns:
- true if the argument equals (0,0,0,0), false otherwise
-
lengthSquared
Return the squared length of the argument.Unlike
Quaternion.norm(), this method returns a double-precision value for precise comparison of lengths.- Parameters:
q- the input value (not null, unaffected)- Returns:
- the squared length (≥0)
-
log
Return the natural logarithm of a normalized quaternion.In general, the result isn't itself normalized.
- Parameters:
q- the input value (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beq)- Returns:
- a pure quaternion (either
storeResultor a new instance)
-
ne
Test whether 2 quaternions are distinct, without distinguishing 0 from -0.- Parameters:
a- the first input value (not null, unaffected)b- the 2nd input value (not null, unaffected)- Returns:
- true if distinct, otherwise false
-
normalizeLocal
Normalize the specified Quaternion in place.- Parameters:
input- the instance to normalize (not null, modified)
-
pow
Raise a normalized quaternion to the specified real power.- Parameters:
base- the input value (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)exponent- the exponentstoreResult- storage for the result (modified if not null, may bebase)- Returns:
- the power (either
storeResultor a new instance)
-
rotate
Rotate the input vector using the specified quaternion.This method doesn't assume the quaternion is normalized. Instead, rotation is performed using a normalized version of the quaternion.
- Parameters:
rotation- the desired rotation (not null, not zero, unaffected)input- the vector to rotate (not null, finite, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beinput)- Returns:
- the rotated vector (either
storeResultor a new instance)
-
rotateInverse
Rotate the input vector using the inverse of the specified quaternion.- Parameters:
rotation- the rotation (not null, not zero, unaffected)input- the vector to rotate (not null, finite, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beinput)- Returns:
- the rotated vector (either
storeResultor a new instance)
-
slerp
Interpolate between 2 normalized quaternions using spherical linear (Slerp) interpolation.The caller is responsible for flipping the sign of
q0orq1when it's appropriate to do so.- Parameters:
t- the weight given toq1(≥0, ≤1)q0- the function value at t=0 (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)q1- the function value at t=1 (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beq0orq1)- Returns:
- an interpolated value (either
storeResultor a new instance)
-
squad
public static Quaternion squad(float t, Quaternion p, Quaternion a, Quaternion b, Quaternion q, Quaternion storeResult) Interpolate between 4 normalized quaternions using the Squad function. The caller is responsible for flipping signs when it's appropriate to do so.- Parameters:
t- the weight given toq(≥0, ≤1)p- function value at t=0 (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)a- the first control point (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)b- the 2nd control point (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)q- function value at t=1 (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null)- Returns:
- the interpolated value (either
storeResultor a new instance)
-
squadA
public static Quaternion squadA(Quaternion q0, Quaternion q1, Quaternion q2, Quaternion storeResult) Return Squad parameter "a" for a continuous first derivative at the middle point of 3 specified control points.- Parameters:
q0- the previous control point (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)q1- the current control point (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)q2- the following control point (not null, norm approximately equal to 1, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null)- Returns:
- the Squad parameter (either
storeResultor a new instance)
-
standardize
Standardize a Quaternion in preparation for hashing.- Parameters:
input- the input value (not null, unaffected unless it'sstoreResult)storeResult- storage for the result (modified if not null, may beinput)- Returns:
- an equivalent Quaternion without negative zeros (either storeResult or a new instance)
-
validateUnit
Validate a normalized quaternion as a method argument.- Parameters:
q- the Quaternion to validate (not null, unaffected)description- description of the Quaterniontolerance- for the norm (≥0)- Returns:
- true
- Throws:
IllegalArgumentException- if the norm is out of toleranceNullPointerException- if the Quaternion is null
-