Try   HackMD

Orthogonal & Non-Orthogonal Gimbal Kinematics Derivation

Nikolai Nekrutenko, Freefly Systems

Using the axis convention as shown below, we derive the equations from translating motion from the gimbal body frame to that of the camera frame.

Image Not Showing Possible Reasons
  • The image was uploaded to a note which you don't have access to
  • The note which the image was originally uploaded to has been deleted
Learn More →

Using the following variable convention:

[xyz]=[rolltiltpan]

We define the following variables:

θx = roll joint angle [rad]
θy
= tilt joint angle [rad]
θz
= pan joint angle [rad]

sx = roll joint rate [rad/s]
sy
= tilt joint rate [rad/s]
sz
= pan join rate [rad/s]

ωx = roll IMU rate [rad/s]
ωy
= tilt IMU rate [rad/s]
ωz
= pan IMU rate [rad/s]

Orthogonal Gimbal Kinematics Derivation

The jacobian is defined as:

J=Ry(θy)[100]+[010]+Ry(θy)Rx(θx)[001]

Derivation from pg. 49 of the ETH Zurich lecture notes, found in resources on rotation matricies.

However, the standard rotational matricies do not work with our coordinate axes as the z-axis is flipped in the Freefly convention. As a result the rotation matricies are modified to take this into account:

Rx(θx)=[1000cos(θx)sin(θx)0sin(θx)cos(θx)][1000cos(θx)sin(θx)0sin(θx)cos(θx)]

Ry(θy)=[cos(θy)0sin(θy)010sin(θy)0cos(θy)][cos(θy)0sin(θy)010sin(θy)0cos(θy)]

Rz(θz)=[cos(θz)sin(θz)0sin(θz)cos(θz)0001][cos(θz)sin(θz)0sin(θz)cos(θz)0001]

We multiply

Ry(θy) by
Rx(θx)
and get the following:

Ry(θy)Rx(θx)=[cos(θy)sin(θy)sin(θx)sin(θy)cos(θx)0cos(θx)sin(θx)sin(θy)cos(θy)sin(θx)cos(θy)cos(θx)]

Then, we evaluate our expression for the jacobian:

J=[cos(θy)0sin(θy)010sin(θy)0cos(θy)][100]+[010]+[cos(θy)sin(θy)sin(θx)sin(θy)cos(θx)0cos(θx)sin(θx)sin(θy)cos(θy)sin(θx)cos(θy)cos(θx)][001]

J=[cos(θy)0sin(θy)cos(θx)01sin(θx)sin(θy)0cos(θy)cos(θx)]

The following relationship can be established between the rate from the camera and world frames using the jacobian:

[wxwywz]=[cos(θy)0sin(θy)cos(θx)01sin(θx)sin(θy)0cos(θy)cos(θx)][sxsysz]

Evaluating the matrix expression results in the following system of equations:

ωx=sxcos(θy)szsin(θy)cos(θx)

ωy=sy+szsin(θx)

ωz=sxcos(θy)+sycos(θy)cos(θx)


Non-Orthogonal Kinematics Derivation

To account for the non-orthogonality of the gimbal, a rotation matrix is introduced, with the angle from normal defined as

ϕ.

This makes the sequence of going from the body frame to the camera frame look like this:

1. panϕrolltilt

Going from camera frame to body frame is accomplished with the following:

1. tiltrollϕpan

Thus, the non-orthogonal Jacobian would look like the following:

J1=Ry(θy)[100]+[010]+Ry(θy)Rx(θx)Rϕ(ϕ)[001]

Where

Rϕ(ϕ) is the transformation that accounts for the non-orthogonality of the x-axis is dervied from a rotation about the y axis in the -
ϕ
direction:

Rϕ(ϕ)=Ry(ϕ)=[cos(ϕ)0sin(ϕ)010sin(ϕ)0cos(ϕ)]=[cos(ϕ)0sin(ϕ)010sin(ϕ)0cos(ϕ)]

Now, we move onto computing the Jacobians:

Ry(θy)Rx(θx)Rϕ(ϕ)=[cos(θy)sin(θy)sin(θx)sin(θy)cos(θx)0cos(θx)sin(θx)sin(θy)cos(θy)sin(θx)cos(θy)cos(θx)][cos(ϕ)0sin(ϕ)010sin(ϕ)0cos(ϕ)]

=[cos(θy)cos(ϕ)+sin(θy)cos(θx)sin(ϕ)sin(θy)sin(θx)cos(θy)sin(ϕ)sin(θy)cos(θx)cos(ϕ)sin(θy)sin(ϕ)cos(θx)sin(θx)cos(ϕ)sin(θy)cos(ϕ)cos(θy)cos(θx)sin(ϕ)cos(θy)sin(θx)sin(θy)sin(ϕ)+cos(θy)cos(θx)cos(ϕ)]

Thus,

J1 can be expressed as:

J1=[cos(θy)0cos(θy)sin(ϕ)sin(θy)cos(θx)cos(ϕ)01sin(θx)cos(ϕ)sin(θy)0sin(θy)sin(ϕ)+cos(θy)cos(θx)cos(ϕ)]

The resulting equations of motion for J1 is as follows:

[wxwywz]=J1[sxsysz]

[wxwywz]=[cos(θy)0cos(θy)sin(ϕ)sin(θy)cos(θx)cos(ϕ)01sin(θx)cos(ϕ)sin(θy)0sin(θy)sin(ϕ)+cos(θy)cos(θx)cos(ϕ)][sxsysz]

The resulting equations are:

wx=sxcos(θy)+sz[cos(θy)sin(ϕ)sin(θy)cos(θx)cos(ϕ)]

wy=sy+szsin(θx)cos(ϕ)

wz=sxsin(θy)+sz[sin(θy)sin(ϕ)+cos(θy)cos(θx)cos(ϕ)]


Resources: