2.2.2. Calculate Joint Angles

RF Robin Fonk
SS Sean Schneeweiss
US Ulrich Simon
LE Lucas Engelhardt
request Request a Protocol
ask Ask a question
Favorite

To transfer the motion into the AMS, the corresponding angles must be calculated for each recorded frame/time step and for each joint. Accordingly, three joint angles (Cardan angles) were exported per joint, each describing a relative angle between two bone segments, i.e., metacarpal to proximal phalanx, along a selected axis [23]. In this work, the joint coordinate system followed the standards of the International Society of Biomechanics as described by Disselhorst-Klug et al. [24]. The three angles (ϕ,θ,ψ) and the corresponding axes in Figure 4 are

rotation about the flexion and extension axis (X-axis, ϕ),

rotation about the resultant abduction and adduction axis (Y-axis, θ), and

rotation about the resultant rotation axis (Z-axis, ψ).

Definition of the joint angles. (a) The skeletal structure of a hand. (b) The stretched position of the index finger (wrist, metacarpals (MC), proximal phalanges (PP), intermediate phalanges (IP), and distal phalanges (DP)) represents the reference position. (c) Angles are calculated in a followed bending position of the index finger. The angles ϕMC,PP, ϕPP,IP and ϕIP,DP represent the angles around the X-axis (flexion/extension).

An initial position (neutral-zero position) of the hand is set in the AMS. The joint angle calculation is based on the reference position and bone bases of the flat outstretched hand exported from the AMS. The angles for the following motion are calculated depending on this reference position. ROSE Motion saves the basis for each bone—per frame/time step—from the LMC recording. From this basis, the required joint angles (ϕ,θ,ψ) are calculated by matrix multiplications and angle functions. As an example, the index finger is shown in Figure 4. The index finger is shown in its initial position and below, in the following position, the index finger is flexed. To reproduce this motion, in each frame the angles ϕMC,PP, ϕPP,IP and ϕIP,DP are calculated (θ and ψ accordingly).

The basis of a bone represents a rotation matrix, which defines the rotation from the global coordinate system into the current orientation of the bones local coordinate system. Using the basis of an arbitrary bone, for example, bone A, at time ti and at time ti+1, another rotation matrix can be calculated, which reflects the rotation between time ti and ti+1. The matrix RA,0(ti) represents the rotation from the origin 0 to the bone A at the time frame i. R0,A(ti) represents the rotation from the bone A to the origin 0 and is equal to RA,0(ti)T. With matrix multiplication [23,25], it is possible to calculate the rotation matrix RA(ti,ti+1) from bone A between the time frame ti and ti+1. From the rotation matrix RA(ti,ti+1) the Cardan angles ϕ, θ, and ψ can be calculated [23,26] and implemented as in the Blender mathutils library [27].

To simplify the transfer of the angles to the AMS, the angles of the joints are always calculated in relation to the initial position t0 of the hand. The calculation of the Cardan angles is shown by an example in Figure 5. The angle between the proximal phalanges (PP) and intermediate phalanges (IP) of the index finger is calculated. The calculation is divided into two steps. In the first step, the rotation matrix R(t0,ti) of the IP and PP is calculated at the time t0 to the bones IP and PP at the time ti. The calculation is made by the basis R(t0) and R(ti) of the bones and is the same as in Equation (1). To calculate the Cardan angle between the PP and IP, the difference of both rotation matrices RPP(t0,ti) and RIP(t0,ti) must be determined in the same way as in Equation (2).

To obtain the angle ϕPP,IP between the proximal phalanges (PP) and intermediate phalanges (IP) the angles ϕIP and ϕPP are needed. Consequently, first the angle ϕIP will be calculated with the rotation matrix from RIP(t0) at the initial condition (t0) and RIP(ti) at the time step ti. Second, the angle ϕPP will be calculated with the rotation matrix from RPP(t0) at the initial condition (t0) and RPP(ti) at the time step ti. The difference between ϕPP and ϕIP defines the required angle ϕPP,IP.

The calculation of the example as graphically illustrated in Figure 5 is applied to all finger joints.

Do you have any questions about this protocol?

Post your question to gather feedback from the community. We will also invite the authors of this article to respond.

post Post a Question
0 Q&A