====== Foot and Ankle Angles ====== [[Visual3D:Documentation:Pipeline:Model_Based_Data_Commands:Joint_Angle|Joint Angles]] are conceptually challenging to present concisely and accurately. A joint angle is the relative orientation of one segment relative to another segment, and mathematically is often represented as a 3x3 rotation matrix. The most common way to present the joint angle, however, is to parse this 3x3 rotation matrix into 3 components using an Euler sequence. The conceptual challenge is that there are 16 different Euler sequences by which this 3x3 rotation matrix can be parsed, and each sequence produces 3 different component values for a given 3x3 rotation matrix. It seems intuitively clear that there must be a standard choice of the correct sequence for a given anatomical joint, but unfortunately, this is not the case. ===== Preparing for the Tutorial ===== 1) Ensure that version 3.0 or later of Visual3D has been downloaded and installed.\\ 2) Download the cmo file with the standing calibration file and model template from the website: [[https://www.has-motion.com/download/examples/Tutorial1.cmo|Tutorial1.cmo]]\\ 3) Launch the Visual3D program from the Start menu.\\ The program will open to the main workspace.\\ ===== Purpose ===== 1. Discuss the minimal marker placement for a single segment foot: **[[#Foot_Segment_-_Marker_Placement|Foot Segment - Marker Placement]]** 2. Discuss the right-hand rule and its application to defining joint angles: **[[#Ankle_Angle_Explained|Ankle Angle Explained]]** 3. Create a simple foot definition which can be used for kinetic calculations: **[[#Create_a_Kinetic_Right_Foot_Segment|Kinetic Right Foot Segment]]** 3. Use three different methods to define the foot for kinematic calculations: **[[#Virtual_Foot_Method_1_-_Heel_to_Toe|Method 1 - Heel to Toe]]** **[[#Virtual_Foot_Method_2_-_Normalize_to_Proximal_Segment|Method 2 - Normalized to proximal segment]]** **[[#Virtual_Foot_Method_3_-_Projected_landmarks|Method 3 - Projected landmarks]]** ===== Discussion ===== There are many ways to define the foot. With a simple single segment foot, two feet are often used: 1) The first foot is used for kinetic calculations, with the proximal joint is define at the ankle.\\ 2) The second foot (often referred to as Virtual Foot) is used for kinematic calculations. The segment coordinate system of the kinematic foot is defined in such a way that the joint angle has a more clinically relevant meaning.\\ There is no set definition of neutral ankle angle, but neutral is approximately when the foot is flat on the floor and the shank segment is vertical. Since the angle joint and toe target are not parallel to the floor, an initial offset is introduced in the ankle angle. The segment coordinate system of the kinematic foot is defined to remove this initial offset and create a more clinically relevant ankle joint angle. This tutorial will explain 3 ways to define a kinematic only foot. Keep in mind, there is no default Visual3D foot definition, and the correct definition is dependent on your laboratory's definition of neutral. Note that although segments are defined using different proximal and distal landmarks, all segments are tracked using the same targets (RFT1, RFT2, RFT3). Also, since these feet are kinematic only, the radius is irrelevant and can be set to 0.1. ===== Foot Segment - Marker Placement ===== |__**The minimal useful marker set is as follows:**__\\ CA(FCC),SMH(FM2),VMH(FM5)\\ {{:foot_markers3.png}}| The **placement of the calcaneous marker** is then very important. The height of the calcaneous marker relative to the height of the toe marker defines dorsi-plantar flexion in the standing posture. Medial lateral placement of the calcaneous marker is important because the sagittal plane of the foot is defined by the calcaneous marker, the toe marker, and the virtual ankle center. CA[[#cite_note-Leardini-1|[1]]](FCC) [[#cite_note-Serge-2|[2]]]:p. 160 = Posterior Surface of Calcaneus\\ ST[[#cite_note-Leardini-1|[1]]](FST)[[#cite_note-Serge-2|[2]]]:p. 160 = Sustentaculum Tali of Calcaneus\\ SMH[[#cite_note-Leardini-1|[1]]](FM2)[[#cite_note-Serge-2|[2]]]:p. 160 = Head of 2nd Metatarsus\\ VMH[[#cite_note-Leardini-1|[1]]](FM5)[[#cite_note-Serge-2|[2]]]:p. 160 = Head of 5th Metatarsus\\ VMB[[#cite_note-Leardini-1|[1]]](FMT)[[#cite_note-Serge-2|[2]]]:p. 160 = Tuberosity of 5th Metatarsal\\ PM[[#cite_note-Leardini-1|[1]]](PM6)[[#cite_note-Serge-2|[2]]]:p. 160 = Proximal Medial Phalanx\\ FMB[[#cite_note-Leardini-1|[1]]] = Base of First Metatarsal\\ SMB[[#cite_note-Leardini-1|[1]]] = Base of Second Metatarsal\\ * As previously mentioned, Visual3D does not have a default marker set or segment definition. It is therefore important to keep in mind that the marker set and segment definitions described in this tutorial as solely provided as an example. There are a number of alternatives for marker placement and segment definition. ==== Create a Kinetic Right Foot Segment ==== This is a simple representation of the foot that is adequate for many of the Kinematic and Kinetic calculations in Visual3D. It is not, however, adequate for the calculation of the ankle joint angle. If using the **Sample Data** provided in the beginning of this tutorial, the Right Foot is defined in this way: |**1. Create the Right Foot Segment:**|In the **Segments** tab, select //Right Foot// in the Segment Name box.\\ Click on the **Create Segment** button| |**2. In the Right Foot tab, Enter these values**|**Define Proximal Joint and Radius Lateral:**\\ **Lateral**: //RLA//\\ **Joint**: //None//\\ **Medial**: //RMA//\\ \\ **Define Distal Joint and Radius:**\\ **Lateral:** //RFT1//\\ **Joint:** //None//\\ **Medial:** //None//\\ **Radius**: //0.06//| |**3. Click on Build Model and Close Tab before proceeding**|A 3D image of a foot will appear distal to the shank.| |{{:tutorial1_16.jpg?600}}| ===== Virtual Foot Method 1 - Heel to Toe ===== This method will use the heel and toe targets to define the proximal and distal ends of the foot. ==== Creating the Ankle and Toe Joint Centers ==== In this tutorial we consider the Ankle Joint Center to be the distal end of the shank segment: |**Create Right Ankle Joint Center (RAJC):**| |Click the **Landmarks** Button and then select **Add New Landmark**|**Landmark Name:** RAJC\\ **Define Orientation Using:** **Existing Segment** - Right Shank\\ Offset using the following **AXIAL** Offset: -1\\ **Check:** Offset by Percent (1.0 = 100%)\\ **Do NOT Check:** Calibration Only Landmark| |{{:RAJC.jpg}}| |**Create Right Toe Joint Center (RTOE) at the same height as the heel marker:**| |Click **Landmarks** button and then select **Add New Landmark**|**Landmark Name:** RTOE\\ **Define Orientation Using:** **Existing Segment:** LAB\\ Offset Using the Following **AXIAL** Offset: -1\\ **Check:** Calibration Only Landmark| |{{:visual3d:tutorials:kinematics_and_kinetics:rtoe.png?400|}}| \\ Once the Ankle Joint Centers have been created, the Foot segments can now be defined. ==== Defining the Virtual Foot Segments ==== Note: This definition assumes that the heel, toe, and ankle center define the sagittal plane of the foot. Care must be taken to place the heel marker carefully. Any medial/lateral misplacement of the heel marker will result in an inappropriate inversion/eversion of the segment. |**3. Create Right Virtual Foot Segment:**\\ \\
**Define Proximal Joint and Radius**\\ **Lateral:** //None// **Joint:** //RHL// **Medial:** //None// \\ **Radius:** //0.01//\\
\\ \\**Define Distal Joint and Radius**\\ **Lateral:** //None// **Joint:** //RTOE// **Medial:** //None// \\ **Radius:** //0.01//\\
\\ \\**Extra Target to Define Orientation**\\ **Location:** //Anterior// //RAJC//\\
\\ \\**Select Tracking Targets:** RFT1, RFT2, RFT3 \\
||**Define Proximal Joint and Radius**\\ **Lateral:** //RLK// **Joint:** //None// **Medial:** //RMK// \\
\\ \\**Define Distal Joint and Radius**\\ **Lateral:** //RLA// **Joint:** //None// **Medial:** //RMA// \\
\\ \\**Select Tracking Targets:**\\ **RFT1, RFT2, RFT3**\\
||**Landmark Name:** //Lab_Origin//\\
\\ \\**Define Orientation Using:**\\ **Existing Segment:** //LAB//\\
||**Landmark Name:** //Lab_X//\\
\\ \\**Define Orientation Using:**\\ **Existing Segment:** //LAB//\\
||**Landmark Name:** //Lab_Y//\\
\\ \\**Define Orientation Using:**\\ **Existing Segment:** //LAB//\\
||**Landmark Name:** //RLA_Floor//\\
\\ \\**Define Orientation Using:**\\ **Starting Point:** //Lab_Origin//\\ **Ending Point:** //Lab_X//\\ **Lateral Object:** //Lab_Y//\\ **Project From:** //RLA//\\
||**Landmark Name:** //RMA_Floor//\\
\\ \\**Define Orientation Using:**\\ **Starting Point:** //Lab_Origin//\\ **Ending Point:** //Lab_X//\\ **Lateral Object:** //Lab_Y//\\ **Project From:** //RMA//\\
||**Landmark Name:** //RFT1_Floor//\\
\\ \\**Define Orientation Using:**\\ **Starting Point:** //Lab_Origin//\\ **Ending Point:** //Lab_X//\\ **Lateral Object:** //Lab_Y//\\ **Project From:** //RFT1//\\
||**Define Proximal Joint and Radius**\\ **Lateral:** //RLA_Floor// **Joint:** //None// **Medial:** //RMA_Floor// \\
\\ \\**Define Distal Joint and Radius**\\ **Lateral:** //RFT1_Floor// **Joint:** //None// **Medial:** //None// \\ **Radius:** //0.01//\\
\\ \\**Select Tracking Targets:**\\ //RFT1//, //RFT2//, //RFT3//\\
||
Event_Explicit
/EVENT_NAME=START
/FRAME=1
! /TIME=
;
Event_Explicit
/EVENT_NAME=END
/FRAME=EOF
! /TIME=
;
!
! Find Pelvis at start
!
Metric_Signal_Value_At_Event
/RESULT_METRIC_NAME=Pelvis_At_START
! /RESULT_METRIC_FOLDER=PROCESSED
/SIGNAL_TYPES=KINETIC_KINEMATIC
/SIGNAL_NAMES=CGPOS
/SIGNAL_FOLDER=RPV
/EVENT_NAME=START
/GENERATE_MEAN_AND_STDDEV=FALSE
! /APPEND_TO_EXISTING_VALUES=FALSE
! /GENERATE_VECTOR_LENGTH_METRIC=FALSE
! /RETAIN_NO_DATA_VALUES=FALSE
;
!
! Find Pelvis at start
!
Metric_Signal_Value_At_Event
/RESULT_METRIC_NAME=Pelvis_At_END
! /RESULT_METRIC_FOLDER=PROCESSED
/SIGNAL_TYPES=KINETIC_KINEMATIC
/SIGNAL_NAMES=CGPOS
/SIGNAL_FOLDER=RPV
/EVENT_NAME=END
/GENERATE_MEAN_AND_STDDEV=FALSE
! /APPEND_TO_EXISTING_VALUES=FALSE
! /GENERATE_VECTOR_LENGTH_METRIC=FALSE
! /RETAIN_NO_DATA_VALUES=FALSE
;
!
! Convert metric signal by grabbing an arbitrary signal multiplied by zero and add metric
!
Evaluate_Expression
/EXPRESSION=0.0*KINETIC_KINEMATIC::RPV::CGPOS+METRIC::PROCESSED::Pelvis_At_END
/RESULT_NAME=Signal_Pelvis_At_END
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
!
! Convert metric signal by grabbing an arbitrary signal multiplied by zero and add metric
!
Evaluate_Expression
/EXPRESSION=0.0*KINETIC_KINEMATIC::RPV::CGPOS+METRIC::PROCESSED::Pelvis_At_START
/RESULT_NAME=Signal_Pelvis_At_START
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Evaluate_Expression
/EXPRESSION=vector((DERIVED::PROCESSED::Signal_Pelvis_At_End::X-DERIVED::PROCESSED::Signal_Pelvis_At_START::X),
(DERIVED::PROCESSED::Signal_Pelvis_At_End::Y- DERIVED::PROCESSED::Signal_Pelvis_At_START::Y),
(0*(DERIVED::PROCESSED::Signal_Pelvis_At_End::Z-DERIVED::PROCESSED::Signal_Pelvis_At_START::Z)))
/RESULT_NAME=DirectionOfProgression
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Signal_Magnitude
/SIGNAL_TYPES=DERIVED
/SIGNAL_NAMES=DirectionOfProgression
/SIGNAL_FOLDER=PROCESSED
/RESULT_NAMES=DirectionOfProgression_Magnitude
/RESULT_TYPES=DERIVED
/RESULT_FOLDER=PROCESSED
! /RESULT_SUFFIX=
;
Evaluate_Expression
/EXPRESSION=DERIVED::PROCESSED::DirectionOfProgression/DERIVED::PROCESSED::DirectionOfProgression_Magnitude
/RESULT_NAME=DirectionOfProgression_Unit
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
!
! Compute right-side unit vector
!
Evaluate_Expression
/EXPRESSION=vector((TARGET::PROCESSED::RTOE::X-TARGET::PROCESSED::RFCC::X),
(TARGET::PROCESSED::RTOE::Y-TARGET::PROCESSED::RFCC::Y),
(0.0*(TARGET::PROCESSED::RTOE::Z-TARGET::PROCESSED::RFCC::Z)))
/RESULT_NAME=RFoot_Line
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Signal_Magnitude
/SIGNAL_TYPES=DERIVED
/SIGNAL_NAMES=RFoot_Line
/SIGNAL_FOLDER=PROCESSED
/RESULT_NAMES=RFoot_Line_Magnitude
/RESULT_TYPES=DERIVED
/RESULT_FOLDER=PROCESSED
! /RESULT_SUFFIX=
;
Evaluate_Expression
/EXPRESSION=DERIVED::PROCESSED::RFoot_Line/DERIVED::PROCESSED::RFoot_Line_Magnitude
/RESULT_NAME=RFoot_Line_Unit
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
!
! Compute left-side unit vector
!
Evaluate_Expression
/EXPRESSION=vector((TARGET::PROCESSED::LTOE::X-TARGET::PROCESSED::LFCC::X),
(TARGET::PROCESSED::LTOE::Y-TARGET::PROCESSED::LFCC::Y),
(0.0*(TARGET::PROCESSED::LTOE::Z-TARGET::PROCESSED::LFCC::Z)))
/RESULT_NAME=LFoot_Line
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Signal_Magnitude
/SIGNAL_TYPES=DERIVED
/SIGNAL_NAMES=LFoot_Line
/SIGNAL_FOLDER=PROCESSED
/RESULT_NAMES=LFoot_Line_Magnitude
/RESULT_TYPES=DERIVED
/RESULT_FOLDER=PROCESSED
! /RESULT_SUFFIX=
;
Evaluate_Expression
/EXPRESSION=DERIVED::PROCESSED::LFoot_Line/DERIVED::PROCESSED::LFoot_Line_Magnitude
/RESULT_NAME=LFoot_Line_Unit
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
!
! Steps left is to find unit vector of two landmarks on the right virtual foot Y
!
Evaluate_Expression
/EXPRESSION=cross(DERIVED::PROCESSED::RFoot_Line_Unit, DERIVED::PROCESSED::DirectionOfProgression_Unit)
/RESULT_NAME=RFoot_Line_Cross_Product
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Evaluate_Expression
/EXPRESSION=asin(DERIVED::PROCESSED::RFoot_Line_Cross_Product::Z)
/RESULT_NAME=RFoot_Angle
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Multiply_Signals_By_Constant
/SIGNAL_TYPES=DERIVED
/SIGNAL_NAMES=RFoot_Angle
/SIGNAL_FOLDER=PROCESSED
! /RESULT_NAMES=
! /RESULT_TYPES=
! /RESULT_FOLDER=PROCESSED
/RESULT_SUFFIX=_Degrees
! /SIGNAL_COMPONENTS=
/CONSTANT=57.3
;
!
! Steps left is to find unit vector of two landmarks on the left virtual foot Y
!
Evaluate_Expression
/EXPRESSION=cross(DERIVED::PROCESSED::LFoot_Line_Unit, DERIVED::PROCESSED::DirectionOfProgression_Unit)
/RESULT_NAME=LFoot_Line_Cross_Product
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Evaluate_Expression
/EXPRESSION=-1*asin(DERIVED::PROCESSED::LFoot_Line_Cross_Product::Z)
/RESULT_NAME=LFoot_Angle
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Multiply_Signals_By_Constant
/SIGNAL_TYPES=DERIVED
/SIGNAL_NAMES=LFoot_Angle
/SIGNAL_FOLDER=PROCESSED
! /RESULT_NAMES=
! /RESULT_TYPES=
! /RESULT_FOLDER=PROCESSED
/RESULT_SUFFIX=_Degrees
! /SIGNAL_COMPONENTS=
/CONSTANT=57.3
;
=== Graph the Foot Progression Angles ===
This method created a derived signal, make sure to select DERIVED in the Signal Type dropdown list, in the Y Axis Properties in the Add / Modify Graph window.
{{:FT_Prog_Angle_Graph2.png}}
===== References =====
- ↑ [[#cite_ref-Leardini_1-0|1.0]] [[#cite_ref-Leardini_1-1|1.1]] [[#cite_ref-Leardini_1-2|1.2]] [[#cite_ref-Leardini_1-3|1.3]] [[#cite_ref-Leardini_1-4|1.4]] [[#cite_ref-Leardini_1-5|1.5]] [[#cite_ref-Leardini_1-6|1.6]] [[#cite_ref-Leardini_1-7|1.7]] Leardini, A., M.G. Benedetti, L. Berti, D. Bettinelli, R. Nativo, and S. Giannini. "Rear-foot, Mid-foot and Fore-foot Motion during the Stance Phase of Gait." Gait & Posture 25 (2007): 453-55
- ↑ [[#cite_ref-Serge_2-0|2.0]] [[#cite_ref-Serge_2-1|2.1]] [[#cite_ref-Serge_2-2|2.2]] [[#cite_ref-Serge_2-3|2.3]] [[#cite_ref-Serge_2-4|2.4]] [[#cite_ref-Serge_2-5|2.5]] Cite error: Invalid ''%%%%'' tag; no text was provided for refs named ''%%Serge%%''