A quaternion class. More...
#include <math/gzmath.hh>
Public Member Functions | |
Quaternion () | |
Default Constructor. More... | |
Quaternion (const double &_w, const double &_x, const double &_y, const double &_z) | |
Constructor. More... | |
Quaternion (const double &_roll, const double &_pitch, const double &_yaw) | |
Constructor from Euler angles in radians. More... | |
Quaternion (const Vector3 &_axis, const double &_angle) | |
Constructor from axis angle. More... | |
Quaternion (const Vector3 &_rpy) | |
Constructor. More... | |
Quaternion (const Quaternion &_qt) | |
Copy constructor. More... | |
Quaternion (const ignition::math::Quaterniond &_qt) | |
Copy constructor for ignition::math::Quaterniond. More... | |
~Quaternion () | |
Destructor. More... | |
void | Correct () |
Correct any nan values in this quaternion. More... | |
double | Dot (const Quaternion &_q) const |
Dot product. More... | |
void | GetAsAxis (Vector3 &_axis, double &_angle) const |
Return rotation as axis and angle. More... | |
Vector3 | GetAsEuler () const |
Return the rotation in Euler angles. More... | |
Matrix3 | GetAsMatrix3 () const |
Get the quaternion as a 3x3 matrix. More... | |
Matrix4 | GetAsMatrix4 () const |
Get the quaternion as a 4x4 matrix. More... | |
Quaternion | GetExp () const |
Return the exponent. More... | |
Quaternion | GetInverse () const |
Get the inverse of this quaternion. More... | |
Quaternion | GetLog () const |
Return the logarithm. More... | |
double | GetPitch () |
Get the Euler pitch angle in radians. More... | |
double | GetRoll () |
Get the Euler roll angle in radians. More... | |
Vector3 | GetXAxis () const |
Return the X axis. More... | |
double | GetYaw () |
Get the Euler yaw angle in radians. More... | |
Vector3 | GetYAxis () const |
Return the Y axis. More... | |
Vector3 | GetZAxis () const |
Return the Z axis. More... | |
ignition::math::Quaterniond | Ign () const |
Convert this quaternion to an ignition::math::Quaterniond. More... | |
Quaternion | Integrate (const Vector3 &_angularVelocity, const double _deltaT) const |
Integrate quaternion for constant angular velocity vector along specified interval _deltaT . More... | |
void | Invert () |
Invert the quaternion. More... | |
bool | IsFinite () const |
See if a quaternion is finite (e.g., not nan) More... | |
void | Normalize () |
Normalize the quaternion. More... | |
bool | operator!= (const Quaternion &_qt) const |
Not equal to operator. More... | |
Quaternion | operator* (const Quaternion &_q) const |
Multiplication operator. More... | |
Quaternion | operator* (const double &_f) const |
Multiplication operator by a scalar. More... | |
Vector3 | operator* (const Vector3 &_v) const |
Vector3 multiplication operator. More... | |
Quaternion | operator*= (const Quaternion &qt) |
Multiplication operator. More... | |
Quaternion | operator+ (const Quaternion &_qt) const |
Addition operator. More... | |
Quaternion | operator+= (const Quaternion &_qt) |
Addition operator. More... | |
Quaternion | operator- (const Quaternion &_qt) const |
Subtraction operator. More... | |
Quaternion | operator- () const |
Unary minus operator. More... | |
Quaternion | operator-= (const Quaternion &_qt) |
Subtraction operator. More... | |
Quaternion & | operator= (const Quaternion &_qt) |
Equal operator. More... | |
Quaternion & | operator= (const ignition::math::Quaterniond &_v) |
Assignment operator for ignition math. More... | |
bool | operator== (const Quaternion &_qt) const |
Equal to operator. More... | |
Vector3 | RotateVector (const Vector3 &_vec) const |
Rotate a vector using the quaternion. More... | |
Vector3 | RotateVectorReverse (Vector3 _vec) const |
Do the reverse rotation of a vector by this quaternion. More... | |
void | Round (int _precision) |
Round all values to _precision decimal places. More... | |
void | Scale (double _scale) |
Scale a Quaternionion. More... | |
void | Set (double _u, double _x, double _y, double _z) |
Set this quaternion from 4 floating numbers. More... | |
void | SetFromAxis (double _x, double _y, double _z, double _a) |
Set the quaternion from an axis and angle. More... | |
void | SetFromAxis (const Vector3 &_axis, double _a) |
Set the quaternion from an axis and angle. More... | |
void | SetFromEuler (const Vector3 &_vec) |
Set the quaternion from Euler angles. More... | |
void | SetFromEuler (double _roll, double _pitch, double _yaw) |
Set the quaternion from Euler angles. More... | |
void | SetToIdentity () |
Set the quaternion to the identity. More... | |
Static Public Member Functions | |
static Quaternion | EulerToQuaternion (const Vector3 &_vec) |
Convert euler angles to a quaternion. More... | |
static Quaternion | EulerToQuaternion (double _x, double _y, double _z) |
Convert euler angles to quatern. More... | |
static Quaternion | Slerp (double _fT, const Quaternion &_rkP, const Quaternion &_rkQ, bool _shortestPath=false) |
Spherical linear interpolation between 2 quaternions, given the ends and an interpolation parameter between 0 and 1. More... | |
static Quaternion | Squad (double _fT, const Quaternion &_rkP, const Quaternion &_rkA, const Quaternion &_rkB, const Quaternion &_rkQ, bool _shortestPath=false) |
Spherical quadratic interpolation given the ends and an interpolation parameter between 0 and 1. More... | |
Public Attributes | |
double | w |
w value of the quaternion More... | |
double | x |
x value of the quaternion More... | |
double | y |
y value of the quaternion More... | |
double | z |
z value of the quaternion More... | |
Friends | |
std::ostream & | operator<< (std::ostream &_out, const gazebo::math::Quaternion &_q) |
Stream insertion operator. More... | |
std::istream & | operator>> (std::istream &_in, gazebo::math::Quaternion &_q) |
Stream extraction operator. More... | |
A quaternion class.
gazebo::math::Quaternion::Quaternion | ( | ) |
Default Constructor.
gazebo::math::Quaternion::Quaternion | ( | const double & | _w, |
const double & | _x, | ||
const double & | _y, | ||
const double & | _z | ||
) |
Constructor.
[in] | _w | W param |
[in] | _x | X param |
[in] | _y | Y param |
[in] | _z | Z param |
gazebo::math::Quaternion::Quaternion | ( | const double & | _roll, |
const double & | _pitch, | ||
const double & | _yaw | ||
) |
Constructor from Euler angles in radians.
[in] | _roll | roll |
[in] | _pitch | pitch |
[in] | _yaw | yaw |
gazebo::math::Quaternion::Quaternion | ( | const Vector3 & | _axis, |
const double & | _angle | ||
) |
Constructor from axis angle.
[in] | _axis | the rotation axis |
[in] | _angle | the rotation angle in radians |
gazebo::math::Quaternion::Quaternion | ( | const Vector3 & | _rpy | ) |
Constructor.
[in] | _rpy | euler angles |
gazebo::math::Quaternion::Quaternion | ( | const Quaternion & | _qt | ) |
Copy constructor.
[in] | _qt | Quaternion to copy |
gazebo::math::Quaternion::Quaternion | ( | const ignition::math::Quaterniond & | _qt | ) |
Copy constructor for ignition::math::Quaterniond.
[in] | _qt | Ignition math quaterniond to copy |
gazebo::math::Quaternion::~Quaternion | ( | ) |
Destructor.
|
inline |
Correct any nan values in this quaternion.
References gazebo::math::equal().
double gazebo::math::Quaternion::Dot | ( | const Quaternion & | _q | ) | const |
Dot product.
[in] | _q | the other quaternion |
|
static |
Convert euler angles to a quaternion.
[in] | _vec | The vector of angles to convert. |
|
static |
Convert euler angles to quatern.
[in] | _x | rotation along x |
[in] | _y | rotation along y |
[in] | _z | rotation along z |
void gazebo::math::Quaternion::GetAsAxis | ( | Vector3 & | _axis, |
double & | _angle | ||
) | const |
Return rotation as axis and angle.
[in] | _axis | rotation axis |
[in] | _angle | ccw angle in radians |
Vector3 gazebo::math::Quaternion::GetAsEuler | ( | ) | const |
Return the rotation in Euler angles.
Matrix3 gazebo::math::Quaternion::GetAsMatrix3 | ( | ) | const |
Get the quaternion as a 3x3 matrix.
Matrix4 gazebo::math::Quaternion::GetAsMatrix4 | ( | ) | const |
Get the quaternion as a 4x4 matrix.
Quaternion gazebo::math::Quaternion::GetExp | ( | ) | const |
Return the exponent.
|
inline |
Get the inverse of this quaternion.
References gazebo::math::equal(), w, x, y, and z.
Referenced by gazebo::math::Pose::CoordPositionSub(), and gazebo::math::Pose::CoordRotationSub().
Quaternion gazebo::math::Quaternion::GetLog | ( | ) | const |
Return the logarithm.
double gazebo::math::Quaternion::GetPitch | ( | ) |
Get the Euler pitch angle in radians.
double gazebo::math::Quaternion::GetRoll | ( | ) |
Get the Euler roll angle in radians.
Vector3 gazebo::math::Quaternion::GetXAxis | ( | ) | const |
Return the X axis.
double gazebo::math::Quaternion::GetYaw | ( | ) |
Get the Euler yaw angle in radians.
Vector3 gazebo::math::Quaternion::GetYAxis | ( | ) | const |
Return the Y axis.
Vector3 gazebo::math::Quaternion::GetZAxis | ( | ) | const |
Return the Z axis.
ignition::math::Quaterniond gazebo::math::Quaternion::Ign | ( | ) | const |
Convert this quaternion to an ignition::math::Quaterniond.
Quaternion gazebo::math::Quaternion::Integrate | ( | const Vector3 & | _angularVelocity, |
const double | _deltaT | ||
) | const |
Integrate quaternion for constant angular velocity vector along specified interval _deltaT
.
[in] | _angularVelocity | Angular velocity vector, specified in same reference frame as base of this quaternion. |
[in] | _deltaT | Time interval in seconds to integrate over. |
void gazebo::math::Quaternion::Invert | ( | ) |
Invert the quaternion.
bool gazebo::math::Quaternion::IsFinite | ( | ) | const |
See if a quaternion is finite (e.g., not nan)
void gazebo::math::Quaternion::Normalize | ( | ) |
Normalize the quaternion.
Referenced by gazebo::math::Pose::CoordRotationSub().
bool gazebo::math::Quaternion::operator!= | ( | const Quaternion & | _qt | ) | const |
|
inline |
Multiplication operator.
[in] | _q | Quaternion for multiplication |
Quaternion gazebo::math::Quaternion::operator* | ( | const double & | _f | ) | const |
Multiplication operator by a scalar.
[in] | _f | factor |
Vector3 multiplication operator.
[in] | _v | vector to multiply |
Quaternion gazebo::math::Quaternion::operator*= | ( | const Quaternion & | qt | ) |
Multiplication operator.
[in] | _qt | Quaternion for multiplication |
Quaternion gazebo::math::Quaternion::operator+ | ( | const Quaternion & | _qt | ) | const |
Addition operator.
[in] | _qt | quaternion for addition |
Quaternion gazebo::math::Quaternion::operator+= | ( | const Quaternion & | _qt | ) |
Addition operator.
[in] | _qt | quaternion for addition |
Quaternion gazebo::math::Quaternion::operator- | ( | const Quaternion & | _qt | ) | const |
Subtraction operator.
[in] | _qt | quaternion to subtract |
Quaternion gazebo::math::Quaternion::operator- | ( | ) | const |
Unary minus operator.
Quaternion gazebo::math::Quaternion::operator-= | ( | const Quaternion & | _qt | ) |
Quaternion& gazebo::math::Quaternion::operator= | ( | const Quaternion & | _qt | ) |
Equal operator.
[in] | _qt | Quaternion to copy |
Quaternion& gazebo::math::Quaternion::operator= | ( | const ignition::math::Quaterniond & | _v | ) |
Assignment operator for ignition math.
[in] | _v | a new value |
bool gazebo::math::Quaternion::operator== | ( | const Quaternion & | _qt | ) | const |
Rotate a vector using the quaternion.
[in] | _vec | vector to rotate |
References gazebo::math::Vector3::x, x, gazebo::math::Vector3::y, y, gazebo::math::Vector3::z, and z.
Do the reverse rotation of a vector by this quaternion.
[in] | _vec | the vector |
void gazebo::math::Quaternion::Round | ( | int | _precision | ) |
Round all values to _precision decimal places.
[in] | _precision | the precision |
void gazebo::math::Quaternion::Scale | ( | double | _scale | ) |
Scale a Quaternionion.
[in] | _scale | Amount to scale this rotation |
void gazebo::math::Quaternion::Set | ( | double | _u, |
double | _x, | ||
double | _y, | ||
double | _z | ||
) |
Set this quaternion from 4 floating numbers.
[in] | _u | u |
[in] | _x | x |
[in] | _y | y |
[in] | _z | z |
void gazebo::math::Quaternion::SetFromAxis | ( | double | _x, |
double | _y, | ||
double | _z, | ||
double | _a | ||
) |
Set the quaternion from an axis and angle.
[in] | _x | X axis |
[in] | _y | Y axis |
[in] | _z | Z axis |
[in] | _a | Angle in radians |
void gazebo::math::Quaternion::SetFromAxis | ( | const Vector3 & | _axis, |
double | _a | ||
) |
Set the quaternion from an axis and angle.
[in] | _axis | Axis |
[in] | _a | Angle in radians |
void gazebo::math::Quaternion::SetFromEuler | ( | const Vector3 & | _vec | ) |
Set the quaternion from Euler angles.
The order of operations is roll, pitch, yaw around a fixed body frame axis (the original frame of the object before rotation is applied). Roll is a rotation about x, pitch is about y, yaw is about z.
[in] | _vec | Euler angle |
void gazebo::math::Quaternion::SetFromEuler | ( | double | _roll, |
double | _pitch, | ||
double | _yaw | ||
) |
Set the quaternion from Euler angles.
[in] | _roll | Roll angle (radians). |
[in] | _pitch | Pitch angle (radians). |
[in] | _yaw | Yaw angle (radians). |
void gazebo::math::Quaternion::SetToIdentity | ( | ) |
Set the quaternion to the identity.
|
static |
Spherical linear interpolation between 2 quaternions, given the ends and an interpolation parameter between 0 and 1.
[in] | _ft | the interpolation parameter |
[in] | _rkP | the beginning quaternion |
[in] | _rkQ | the end quaternion |
[in] | _shortestPath | when true, the rotation may be inverted to get to minimize rotation |
Referenced by gazebo::math::OnePoleQuaternion::Process().
|
static |
Spherical quadratic interpolation given the ends and an interpolation parameter between 0 and 1.
[in] | _ft | the interpolation parameter |
[in] | _rkP | the beginning quaternion |
[in] | _rkA | first intermediate quaternion |
[in] | _rkB | second intermediate quaternion |
[in] | _rkQ | the end quaternion |
[in] | _shortestPath | when true, the rotation may be inverted to get to minimize rotation |
|
friend |
Stream insertion operator.
[in] | _out | output stream |
[in] | _q | quaternion to output |
|
friend |
Stream extraction operator.
[in] | _in | input stream |
[in] | _q | Quaternion to read values into |
double gazebo::math::Quaternion::w |
w value of the quaternion
Referenced by gazebo::physics::BulletTypes::ConvertPose(), gazebo::physics::DARTTypes::ConvQuat(), GetInverse(), and operator*().
double gazebo::math::Quaternion::x |
x value of the quaternion
Referenced by gazebo::physics::BulletTypes::ConvertPose(), gazebo::physics::DARTTypes::ConvQuat(), gazebo::math::Pose::CoordPositionSub(), GetInverse(), operator*(), and RotateVector().
double gazebo::math::Quaternion::y |
y value of the quaternion
Referenced by gazebo::physics::BulletTypes::ConvertPose(), gazebo::physics::DARTTypes::ConvQuat(), gazebo::math::Pose::CoordPositionSub(), GetInverse(), operator*(), and RotateVector().
double gazebo::math::Quaternion::z |
z value of the quaternion
Referenced by gazebo::physics::BulletTypes::ConvertPose(), gazebo::physics::DARTTypes::ConvQuat(), gazebo::math::Pose::CoordPositionSub(), GetInverse(), operator*(), and RotateVector().