pyCGM_Single.pyCGM.JointAngleCalc¶
- 
pyCGM_Single.pyCGM.JointAngleCalc(frame, vsk)¶
- Joint Angle Calculation function. - Calculates the Joint angles of plugingait and stores the data in array Stores: RPel_angle = [] LPel_angle = [] RHip_angle = [] LHip_angle = [] RKnee_angle = [] LKnee_angle = [] RAnkle_angle = [] LAnkle_angle = [] - Joint Axis store like below form - The axis is in the form [[origin], [axis]] Origin defines the position of axis and axis is the direction vector of x, y, z axis attached to the origin - If it is just single one (Pelvis, Hip, Head, Thorax) - Axis = [[origin_x, origin_y, origin_z],[[Xaxis_x,Xaxis_y,Xaxis_z],
- [Yaxis_x,Yaxis_y,Yaxis_z], [Zaxis_x,Zaxis_y,Zaxis_z]]] 
 - If it has both of Right and Left ( knee, angle, foot, clavicle, humerus, radius, hand) - Axis = [[[R_origin_x,R_origin_y,R_origin_z],
- [L_origin_x,L_origin_y,L_origin_z]],[[[R_Xaxis_x,R_Xaxis_y,R_Xaxis_z],
- [R_Yaxis_x,R_Yaxis_y,R_Yaxis_z], [R_Zaxis_x,R_Zaxis_y,R_Zaxis_z]], [[L_Xaxis_x,L_Xaxis_y,L_Xaxis_z], [L_Yaxis_x,L_Yaxis_y,L_Yaxis_z], [L_Zaxis_x,L_Zaxis_y,L_Zaxis_z]]]] 
 
 - Parameters
- framedict
- Dictionaries of marker lists. 
- vskdict
- A dictionary containing subject measurements. 
 
- Returns
- r, jctuple
- Returns a tuple containing an array that holds the result of all the joint calculations, followed by a dictionary for joint center marker positions. 
 
 - Examples - >>> import numpy as np >>> from .pyCGM import JointAngleCalc >>> from .pycgmIO import loadC3D, loadVSK >>> from .pycgmStatic import getStatic >>> from .pyCGM_Helpers import getfilenames >>> import os >>> fileNames=getfilenames(2) >>> c3dFile = fileNames[1] >>> vskFile = fileNames[2] >>> result = loadC3D(c3dFile) >>> data = result[0] >>> frame = result[0][0] >>> vskData = loadVSK(vskFile, False) >>> vsk = getStatic(data,vskData,flat_foot=False) >>> results = JointAngleCalc(frame, vsk)[1] >>> np.around(results['Pelvis'], 2) array([ 246.15, 353.26, 1031.71]) >>> np.around(results['Thorax'], 2) array([ 250.56, 303.23, 1461.17]) >>> np.around(results['Head'], 2) array([ 244.9 , 325.06, 1730.16]) >>> np.around(results['RHand'], 2) array([ 770.93, 591.05, 1079.05])