====== ANGULAR MOMENTUM PT ======
\\
===== Angular Momentum =====
It is important to note that the total body angular momentum is not calculated by summing the [[Visual3D:Documentation:Pipeline:Model_Based_Data_Commands:ANGULAR_MOMENTUM|ANGULAR_MOMENTUM]] for each calculated by the Compute Model Based command. The [[Visual3D:Documentation:Pipeline:Model_Based_Data_Commands:ANGULAR_MOMENTUM|ANGULAR_MOMENTUM]] command calculates the angular momentum about each segment's center of mass, to calculate the total body angular momentum you must calculate the angular momentum for each segment about the same axis, such as the total body center of mass. The equations in the [[#Angular_Momentum:_About_Total_Body_Center_of_Mass|About Total Body Center of Mass]] section describe how to do this.
==== Angular Momentum: About Segment Center of Mass ====
Visual3D's built in [[Visual3D:Documentation:Pipeline:Model_Based_Data_Commands:ANGULAR_MOMENTUM|ANGULAR_MOMENTUM]] command calculates the angular momentum of a segment about the segment's center of mass, but angular momentum can also be calculated about a different point in space.
**Angular momentum about a segment's center of mass is:**\\
| {{:SegmentAngularMomentumExpression.jpg}} |
==== Angular Momentum: About Total Body Center of Mass ====
**Angular momentum about the total body center of mass is:**\\
**NOTE:** Angular momentum for the whole body about the total body center of mass is just the summation of the angular momentum of **each** segment about the total body center of mass.
|{{:SegmentAngularMomentum_AboutaPoint_Eq.png}}\\ \\ //Iw// = angular momentum of the segment\\ \\ \\ //I// = Moment of Inertia\\ \\ //w// = Angular velocity\\ \\ //r// = distance from the total body center of mass to the segment's center of mass\\ //m// = mass of the segment\\ //v// = translational velocity\\ |{{:SegmentAngularMomentum_AboutaPoint.png}} |
===== Example Script =====
==== Inroduction ====
**To calculate the angular momentum about a point (such as the model center of mass):**
- Compute r
- Compute mv
- Compute r x mv
- Compute the angular momentum of the segment using the [[Visual3D:Documentation:Pipeline:Model_Based_Data_Commands:ANGULAR_MOMENTUM|Angular Momentum]] command
- Compute Iw * (r x mv)
==== Script ====
This script and sample CMO files can be downloaded [[https://www.has-motion.com/download/examples/AngularMomentum/AngularMomentum_AboutAPoint.zip|here]]. The download also contains a PDF file with the Angular Momentum equations.
The following script computes the angular momentum about the total body center of mass, if the user would like to calculate angular momentum about a different point, specify the desired signal in place of "KINETIC_KINEMATIC::MODEL::CenterOfMass".
This script calculates the angular momentum **for each of the listed segments** (RFT+RSK+RTH+LFT+LSK+LTH+RPV).\\
\\
If the user would like to calculate the **total body angular momentum about the model center of mass**, the resulting signals from the last Evaluate Expression command for all segments should be summed together. If you would like to calculate the total body angular momentum, you can use the [[Visual3D:Documentation:Pipeline:Signal_Commands:Add_Signals|Add_Signals]] command after the End_For_Each.
First_Derivative
/SIGNAL_TYPES=KINETIC_KINEMATIC
/SIGNAL_FOLDER=Model
/SIGNAL_NAMES=CenterOfMass
/RESULT_TYPES=DERIVED
/RESULT_FOLDER=COM
! /RESULT_NAMES=
/RESULT_SUFFIX=_VEL
;
For_Each
/ITERATION_PARAMETER_NAME=SEG_NAME
/ITEMS=RFT+RSK+RTH+LFT+LSK+LTH+RPV
;
! compute the R for (r x mv)
Evaluate_Expression
/EXPRESSION=vector((Kinetic_Kinematic::&::SEG_NAME& ::CGPos::X - KINETIC_KINEMATIC::MODEL::CenterOfMass::X ),
(Kinetic_Kinematic::&::SEG_NAME& ::CGPos::Y - KINETIC_KINEMATIC::MODEL::CenterOfMass::Y),
(Kinetic_Kinematic::&::SEG_NAME& ::CGPos::Z - KINETIC_KINEMATIC::MODEL::CenterOfMass::Z))
/RESULT_NAME=::SEG_NAME&_R
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
! compute mv
Evaluate_Expression
/EXPRESSION=(MODEL::SEGMENT::&::SEG_NAME&:&:MASS)*(Kinetic_Kinematic::&::SEG_NAME& ::CGVel - DERIVED::COM::CENTEROFMASS_VEL )
/RESULT_NAME=::SEG_NAME&_mv
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
! compute rxmv
Evaluate_Expression
/EXPRESSION=cross(DERIVED::PROCESSED::&::SEG_NAME&_R, DERIVED::PROCESSED::&::SEG_NAME&_mv)
/RESULT_NAME=::SEG_NAME&_rxmv
! /RESULT_TYPE=DERIVED
! /RESULT_FOLDER=PROCESSED
;
Compute_Model_Based_Data
/RESULT_NAME=::SEG_NAME&_IW
/FUNCTION=ANGULAR_MOMENTUM
/SEGMENT=::SEG_NAME
/REFERENCE_SEGMENT=LAB
! /RESOLUTION_COORDINATE_SYSTEM=LAB
! /USE_CARDAN_SEQUENCE=FALSE
! /NORMALIZATION=FALSE
! /NORMALIZATION_METHOD=
! /NORMALIZATION_METRIC=
! /NEGATEX=FALSE
! /NEGATEY=FALSE
! /NEGATEZ=FALSE
! /AXIS1=X
! /AXIS2=Y
! /AXIS3=Z
;
! compute rxmv
Evaluate_Expression
/EXPRESSION=LINK_MODEL_BASED::ORIGINAL::&::SEG_NAME&_IW + DERIVED::PROCESSED::&::SEG_NAME&_rxmv
/RESULT_NAME=::SEG_NAME&_IW
/RESULT_TYPE=DERIVED
/RESULT_FOLDER=Momentum_Contribution
;
End_For_Each
/ITERATION_PARAMETER_NAME=SEG_NAME
;