--- a +++ b/osim/models/gait9dof18musc.osim @@ -0,0 +1,2942 @@ +<?xml version="1.0" encoding="UTF-8" ?> +<OpenSimDocument Version="30000"> + <Model name="gait9dof18musc_Thelen_BigSpheres.osim"> + <credits>A planar reduced gait model with 9 degrees of freedom and 18 muscles by Ajay Seth. Adjusted by Carmichael Ong to follow muscle strengths of Handsfield/Rajagopal and changed hamstrings to follow semimembranosus. Ankle passive mechanics based on Weiss, Kearney, and Hunter 1986. Closely based on Delp S.L., Loan J.P., Hoy M.G., Zajac F.E., Topp E.L., Rosen J.M., Thelen D.G., Anderson F.C., Seth A. Notes: 3D, 23 DOF gait model created by D.G. Thelen, Univ. of Wisconsin-Madison, and Ajay Seth, Frank C. Anderson, and Scott L. Delp, Stanford University. Lower extremity joint defintions based on Delp et al. (1990). Low back joint and anthropometry based on Anderson and Pandy (1999, 2001). Planar knee model of Yamaguchi and Zajac (1989). Seth replaced tibia translation constraints with a CustomJoint for the knee and removed the patella to eliminate all kinematic constraints; insertions of the quadrucepts are handled with moving points in the tibia frame as defined by Delp 1990. Number of muscles was reduced by Anderson to improve simulation speed for demonstrations and is not intended to be used in research. License: Creative Commons (CCBY 3.0). You are free to distribute, remix, tweak, and build upon this work, even commercially, as long as you credit us for the original creation. http://creativecommons.org/licenses/by/3.0/ More Information: http://simtk-confluence.stanford.edu:8080/display/OpenSim/Gait+2392+and+2354+Models</credits> + <publications>Delp, S.L., Loan, J.P., Hoy, M.G., Zajac, F.E., Topp E.L., Rosen, J.M.: An interactive graphics-based model of the lower extremity to study orthopaedic surgical procedures, IEEE Transactions on Biomedical Engineering, vol. 37, pp. 757-767, 1990. Yamaguchi G.T., Zajac F.E.: A planar model of the knee joint to characterize the knee extensor mechanism." J . Biomech. vol. 22. pp. 1-10. 1989. Anderson F.C., Pandy M.G.: A dynamic optimization solution for vertical jumping in three dimensions. Computer Methods in Biomechanics and Biomedical Engineering 2:201-231, 1999. Anderson F.C., Pandy M.G.: Dynamic optimization of human walking. Journal of Biomechanical Engineering 123:381-390, 2001.</publications> + <length_units>meters</length_units> + <force_units>N</force_units> + <!--Acceleration due to gravity.--> + <gravity> 0 -9.80665 0</gravity> + <!--Bodies in the model.--> + <BodySet> + <objects> + <Body name="ground"> + <mass>0</mass> + <mass_center> 0 0 0</mass_center> + <inertia_xx>0</inertia_xx> + <inertia_yy>0</inertia_yy> + <inertia_zz>0</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint /> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="pelvis"> + <mass>11.777</mass> + <mass_center> -0.0707 0 0</mass_center> + <inertia_xx>0.1028</inertia_xx> + <inertia_yy>0.0871</inertia_yy> + <inertia_zz>0.0579</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PlanarJoint name="ground_pelvis"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>ground</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 0 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="pelvis_tilt"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>-0.05</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-1.57079633 1.57079633</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + <Coordinate name="pelvis_tx"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>translational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-5 5</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + <Coordinate name="pelvis_ty"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>translational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0.91</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-1 2</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PlanarJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>sacrum.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>pelvis.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_pelvis.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="femur_r"> + <mass>9.3014</mass> + <mass_center> 0 -0.17 0</mass_center> + <inertia_xx>0.1339</inertia_xx> + <inertia_yy>0.0351</inertia_yy> + <inertia_zz>0.1412</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PinJoint name="hip_r"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>pelvis</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>-0.0707 -0.0661 0.0835</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="hip_flexion_r"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-2.0943951 2.0943951</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PinJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>femur.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="tibia_r"> + <mass>3.7075</mass> + <mass_center> 0 -0.1867 0</mass_center> + <inertia_xx>0.0504</inertia_xx> + <inertia_yy>0.0051</inertia_yy> + <inertia_zz>0.0511</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <CustomJoint name="knee_r"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>femur_r</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 0 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="knee_angle_r"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-2.0943951 0.17453293</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + <!--Defines how the child body moves with respect to the parent as a function of the generalized coordinates.--> + <SpatialTransform> + <!--3 Axes for rotations are listed first.--> + <TransformAxis name="rotation1"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_r</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 0 1</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <LinearFunction> + <coefficients> 1 0</coefficients> + </LinearFunction> + </function> + </TransformAxis> + <TransformAxis name="rotation2"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 1 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + <TransformAxis name="rotation3"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>1 0 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + <!--3 Axes for translations are listed next.--> + <TransformAxis name="translation1"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_r</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>1 0 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <SimmSpline> + <x> -2.0944 -1.74533 -1.39626 -1.0472 -0.698132 -0.349066 -0.174533 0.197344 0.337395 0.490178 1.52146 2.0944</x> + <y> -0.0032 0.00179 0.00411 0.0041 0.00212 -0.001 -0.0031 -0.005227 -0.005435 -0.005574 -0.005435 -0.00525</y> + </SimmSpline> + </function> + </TransformAxis> + <TransformAxis name="translation2"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_r</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 1 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <SimmSpline> + <x> -2.0944 -1.22173 -0.523599 -0.349066 -0.174533 0.159149 2.0944</x> + <y> -0.4226 -0.4082 -0.399 -0.3976 -0.3966 -0.395264 -0.396</y> + </SimmSpline> + </function> + </TransformAxis> + <TransformAxis name="translation3"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 0 1</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + </SpatialTransform> + </CustomJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>tibia.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>fibula.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="talus_r"> + <mass>0.1</mass> + <mass_center> 0 0 0</mass_center> + <inertia_xx>0.001</inertia_xx> + <inertia_yy>0.001</inertia_yy> + <inertia_zz>0.001</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PinJoint name="ankle_r"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>tibia_r</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 -0.43 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="ankle_angle_r"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-1.57079633 1.57079633</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PinJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>talus.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="calcn_r"> + <mass>1.25</mass> + <mass_center> 0.1 0.03 0</mass_center> + <inertia_xx>0.0014</inertia_xx> + <inertia_yy>0.0039</inertia_yy> + <inertia_zz>0.0041</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <WeldJoint name="subtalar_r"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>talus_r</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>-0.04877 -0.04195 0.00792</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects /> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </WeldJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>foot.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="toes_r"> + <mass>0.2166</mass> + <mass_center> 0.0346 0.006 -0.0175</mass_center> + <inertia_xx>0.0001</inertia_xx> + <inertia_yy>0.0002</inertia_yy> + <inertia_zz>0.0001</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <WeldJoint name="mtp_r"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>calcn_r</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0.1788 -0.002 0.00108</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects /> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </WeldJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>bofoot.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="femur_l"> + <mass>9.3014</mass> + <mass_center> 0 -0.17 0</mass_center> + <inertia_xx>0.1339</inertia_xx> + <inertia_yy>0.0351</inertia_yy> + <inertia_zz>0.1412</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PinJoint name="hip_l"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>pelvis</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>-0.0707 -0.0661 -0.0835</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="hip_flexion_l"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-2.0943951 2.0943951</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PinJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_femur.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="tibia_l"> + <mass>3.7075</mass> + <mass_center> 0 -0.1867 0</mass_center> + <inertia_xx>0.0504</inertia_xx> + <inertia_yy>0.0051</inertia_yy> + <inertia_zz>0.0511</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <CustomJoint name="knee_l"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>femur_l</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 0 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="knee_angle_l"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-2.0943951 0.17453293</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + <!--Defines how the child body moves with respect to the parent as a function of the generalized coordinates.--> + <SpatialTransform> + <!--3 Axes for rotations are listed first.--> + <TransformAxis name="rotation1"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_l</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 0 1</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <LinearFunction> + <coefficients> 1 0</coefficients> + </LinearFunction> + </function> + </TransformAxis> + <TransformAxis name="rotation2"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 1 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + <TransformAxis name="rotation3"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>1 0 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + <!--3 Axes for translations are listed next.--> + <TransformAxis name="translation1"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_l</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>1 0 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <SimmSpline> + <x> -2.0944 -1.74533 -1.39626 -1.0472 -0.698132 -0.349066 -0.174533 0.197344 0.337395 0.490178 1.52146 2.0944</x> + <y> -0.0032 0.00179 0.00411 0.0041 0.00212 -0.001 -0.0031 -0.005227 -0.005435 -0.005574 -0.005435 -0.00525</y> + </SimmSpline> + </function> + </TransformAxis> + <TransformAxis name="translation2"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates>knee_angle_l</coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 1 0</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <SimmSpline> + <x> -2.0944 -1.22173 -0.523599 -0.349066 -0.174533 0.159149 2.0944</x> + <y> -0.4226 -0.4082 -0.399 -0.3976 -0.3966 -0.395264 -0.396</y> + </SimmSpline> + </function> + </TransformAxis> + <TransformAxis name="translation3"> + <!--Names of the coordinates that serve as the independent variables of the transform function.--> + <coordinates></coordinates> + <!--Rotation or translation axis for the transform.--> + <axis>0 0 1</axis> + <!--Transform function of the generalized coordinates used to represent the amount of transformation along a specified axis.--> + <function> + <Constant> + <value>0</value> + </Constant> + </function> + </TransformAxis> + </SpatialTransform> + </CustomJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_tibia.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_fibula.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="talus_l"> + <mass>0.1</mass> + <mass_center> 0 0 0</mass_center> + <inertia_xx>0.001</inertia_xx> + <inertia_yy>0.001</inertia_yy> + <inertia_zz>0.001</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PinJoint name="ankle_l"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>tibia_l</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 -0.43 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="ankle_angle_l"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>0</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-1.04719755 1.04719755</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>false</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PinJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_talus.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="calcn_l"> + <mass>1.25</mass> + <mass_center> 0.1 0.03 0</mass_center> + <inertia_xx>0.0014</inertia_xx> + <inertia_yy>0.0039</inertia_yy> + <inertia_zz>0.0041</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <WeldJoint name="subtalar_l"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>talus_l</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>-0.04877 -0.04195 -0.00792</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects /> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </WeldJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_foot.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="toes_l"> + <mass>0.2166</mass> + <mass_center> 0.0346 0.006 0.0175</mass_center> + <inertia_xx>0.0001</inertia_xx> + <inertia_yy>0.0002</inertia_yy> + <inertia_zz>0.0001</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <WeldJoint name="mtp_l"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>calcn_l</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0.1788 -0.002 -0.00108</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects /> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </WeldJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>l_bofoot.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="torso"> + <mass>34.2366</mass> + <mass_center> -0.03 0.32 0</mass_center> + <inertia_xx>1.4745</inertia_xx> + <inertia_yy>0.7555</inertia_yy> + <inertia_zz>1.4314</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <!--Joint that connects this body with the parent body.--> + <Joint> + <PinJoint name="back"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>pelvis</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>-0.1007 0.0815 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + <CoordinateSet> + <objects> + <Coordinate name="lumbar_extension"> + <!--Coordinate can describe rotational, translational, or coupled motion. Defaults to rotational.--> + <motion_type>rotational</motion_type> + <!--The value of this coordinate before any value has been set. Rotational coordinate value is in radians and Translational in meters.--> + <default_value>-0.139626</default_value> + <!--The speed value of this coordinate before any value has been set. Rotational coordinate value is in rad/s and Translational in m/s.--> + <default_speed_value>0</default_speed_value> + <!--The minimum and maximum values that the coordinate can range between. Rotational coordinate range in radians and Translational in meters.--> + <range>-1.57079633 1.57079633</range> + <!--Flag indicating whether or not the values of the coordinates should be limited to the range, above.--> + <clamped>false</clamped> + <!--Flag indicating whether or not the values of the coordinates should be constrained to the current (e.g. default) value, above.--> + <locked>true</locked> + <!--If specified, the coordinate can be prescribed by a function of time. It can be any OpenSim Function with valid second order derivatives.--> + <prescribed_function /> + <!--Flag indicating whether or not the values of the coordinates should be prescribed according to the function above. It is ignored if the no prescribed function is specified.--> + <prescribed>false</prescribed> + </Coordinate> + </objects> + <groups /> + </CoordinateSet> + <!--Whether the joint transform defines parent->child or child->parent.--> + <reverse>false</reverse> + </PinJoint> + </Joint> + <VisibleObject> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>hat_spine.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>hat_jaw.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>hat_skull.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + <DisplayGeometry> + <!--Name of geometry file .vtp, .stl, .obj--> + <geometry_file>hat_ribs.vtp</geometry_file> + <!--Color used to display the geometry when visible--> + <color> 1 1 1</color> + <!--Name of texture file .jpg, .bmp--> + <texture_file /> + <!--in body transform specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded--> + <display_preference>4</display_preference> + <!--Display opacity between 0.0 and 1.0--> + <opacity>1</opacity> + </DisplayGeometry> + </objects> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + <WrapObjectSet> + <objects /> + <groups /> + </WrapObjectSet> + </Body> + <Body name="head"> + <mass>4.5</mass> + <mass_center>0 0 0</mass_center> + <inertia_xx>0</inertia_xx> + <inertia_yy>0</inertia_yy> + <inertia_zz>0</inertia_zz> + <inertia_xy>0</inertia_xy> + <inertia_xz>0</inertia_xz> + <inertia_yz>0</inertia_yz> + <Joint> + <WeldJoint name="back1"> + <!--Name of the parent body to which this joint connects its owner body.--> + <parent_body>torso</parent_body> + <!--Location of the joint in the parent body specified in the parent reference frame. Default is (0,0,0).--> + <location_in_parent>0 0.55 0</location_in_parent> + <!--Orientation of the joint in the parent body specified in the parent reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. Default is (0,0,0).--> + <orientation_in_parent>0 0 0</orientation_in_parent> + <!--Location of the joint in the child body specified in the child reference frame. For SIMM models, this vector is always the zero vector (i.e., the body reference frame coincides with the joint). --> + <location>0 0 0</location> + <!--Orientation of the joint in the owing body specified in the owning body reference frame. Euler XYZ body-fixed rotation angles are used to express the orientation. --> + <orientation>0 0 0</orientation> + <!--Set holding the generalized coordinates (q's) that parmeterize this joint.--> + </WeldJoint> + </Joint> + </Body> + </objects> + <groups /> + </BodySet> + <!--Constraints in the model.--> + <ConstraintSet> + <objects /> + <groups /> + </ConstraintSet> + <!--Forces in the model.--> + <ForceSet> + <objects> + <Thelen2003Muscle name="hamstrings_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="semimem_r-P1"> + <location> -0.1192 -0.09747 0.07151</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="semimem_r-P2"> + <location> -0.0348 -0.03519 -0.01891</location> + <body>tibia_r</body> + <range> -0.558505 0.174533</range> + <coordinate>knee_angle_r</coordinate> + </ConditionalPathPoint> + <PathPoint name="semimem_r-P3"> + <location> -0.027 -0.04771 -0.01957</location> + <body>tibia_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>4105.465574</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.069</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.349</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.26179939</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="bifemsh_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="bifemsh_r-P1"> + <location> 0.005 -0.2111 0.0234</location> + <body>femur_r</body> + </PathPoint> + <PathPoint name="bifemsh_r-P2"> + <location> -0.0301 -0.036 0.02943</location> + <body>tibia_r</body> + </PathPoint> + <PathPoint name="bifemsh_r-P3"> + <location> -0.0234 -0.0563 0.0343</location> + <body>tibia_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>557.11475409836</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.11</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.117</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.40142573</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="glut_max_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="glut_max2_r-P1"> + <location> -0.1349 0.0176 0.0563</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="glut_max2_r-P2"> + <location> -0.1376 -0.052 0.0914</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="glut_max2_r-P3"> + <location> -0.0426 -0.053 0.0293</location> + <body>femur_r</body> + </PathPoint> + <PathPoint name="glut_max2_r-P4"> + <location> -0.0156 -0.1016 0.0419</location> + <body>femur_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>3337.583607</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.157</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.048</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="iliopsoas_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="psoas_r-P1"> + <location> -0.0647 0.0887 0.0289</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="psoas_r-P2"> + <location> -0.0238 -0.057 0.0759</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="psoas_r-P3"> + <location> -0.0288 -0.0805 0.0816</location> + <body>pelvis</body> + <range> -1.5708 0.785398</range> + <coordinate>hip_flexion_r</coordinate> + </ConditionalPathPoint> + <PathPoint name="psoas_r-P4"> + <location> 0.0016 -0.0507 0.0038</location> + <body>femur_r</body> + </PathPoint> + <PathPoint name="psoas_r-P5"> + <location> -0.0188 -0.0597 0.0104</location> + <body>femur_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2697.344262</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.117</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.130</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.13962634</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="rect_fem_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="rect_fem_r-P1"> + <location> -0.0295 -0.0311 0.0968</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="rect_fem_r-P2"> + <location> 0.0334 -0.403 0.0019</location> + <body>femur_r</body> + <range> -2.61799 -1.45997</range> + <coordinate>knee_angle_r</coordinate> + </ConditionalPathPoint> + <MovingPathPoint name="rect_fem_r-P3"> + <location> 0.0617576 0.020984 0.0014</location> + <body>tibia_r</body> + <x_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0155805 0.0179938 0.0275081 0.0296564 0.0307615 0.0365695 0.0422074 0.0450902 0.048391 0.0534299 0.0617576 0.0617669 0.0617762 0.0633083 0.066994 0.0733035 0.0573481</y> + </SimmSpline> + </x_location> + <x_coordinate>knee_angle_r</x_coordinate> + <y_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0234116 0.0237613 0.0251141 0.0252795 0.0253146 0.0249184 0.0242373 0.0238447 0.0234197 0.0227644 0.020984 0.0209814 0.0209788 0.0205225 0.0191754 0.0159554 -0.0673774</y> + </SimmSpline> + </y_location> + <y_coordinate>knee_angle_r</y_coordinate> + <z_location> + <SimmSpline> + <x> -2.0944 0.1745</x> + <y> 0.0014 0.0014</y> + </SimmSpline> + </z_location> + <z_coordinate>knee_angle_r</z_coordinate> + </MovingPathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2191.74098360656</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.076</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.346</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.08726646</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + <!--passive muscle strain at maximum isometric muscle force--> + <FmaxMuscleStrain>1.0</FmaxMuscleStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="vasti_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="vas_int_r-P1"> + <location> 0.029 -0.1924 0.031</location> + <body>femur_r</body> + </PathPoint> + <PathPoint name="vas_int_r-P2"> + <location> 0.0335 -0.2084 0.0285</location> + <body>femur_r</body> + </PathPoint> + <ConditionalPathPoint name="vas_int_r-P3"> + <location> 0.0343 -0.403 0.0055</location> + <body>femur_r</body> + <range> -2.61799 -1.42</range> + <coordinate>knee_angle_r</coordinate> + </ConditionalPathPoint> + <MovingPathPoint name="vas_int_r-P4"> + <location> 0.0554632 0.0252923 0.0018</location> + <body>tibia_r</body> + <x_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0082733 0.0106866 0.0202042 0.022353 0.0234583 0.0292715 0.0349465 0.037871 0.0412569 0.0465287 0.0554632 0.0554735 0.0554837 0.0571717 0.061272 0.0684368 0.0648818</y> + </SimmSpline> + </x_location> + <x_coordinate>knee_angle_r</x_coordinate> + <y_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.025599 0.0259487 0.0273124 0.0274796 0.0275151 0.0271363 0.0265737 0.0263073 0.0261187 0.0260129 0.0252923 0.0252911 0.0252898 0.0250526 0.0242191 0.0218288 -0.0685706</y> + </SimmSpline> + </y_location> + <y_coordinate>knee_angle_r</y_coordinate> + <z_location> + <SimmSpline> + <x> -2.0944 2.0944</x> + <y> 0.0018 0.0018</y> + </SimmSpline> + </z_location> + <z_coordinate>knee_angle_r</z_coordinate> + </MovingPathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>9593.95082</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.099</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.102</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.05235988</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + <!--passive muscle strain at maximum isometric muscle force--> + <FmaxMuscleStrain>1.0</FmaxMuscleStrain> + <!--exponential shape factor for passive force-length relationship--> + <KshapePassive>9</KshapePassive> + </Thelen2003Muscle> + <Thelen2003Muscle name="gastroc_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="med_gas_r-P1"> + <location> -0.019 -0.3929 -0.0235</location> + <body>femur_r</body> + </PathPoint> + <ConditionalPathPoint name="med_gas_r-P2"> + <location> -0.03 -0.4022 -0.0258</location> + <body>femur_r</body> + <range> -0.785398 0.174533</range> + <coordinate>knee_angle_r</coordinate> + </ConditionalPathPoint> + <PathPoint name="med_gas_r-P3"> + <location> 0 0.031 -0.0053</location> + <body>calcn_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>4690.57377</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.051</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.384</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.29670597</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.1</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="soleus_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="soleus_r-P1"> + <location> -0.0024 -0.1533 0.0071</location> + <body>tibia_r</body> + </PathPoint> + <PathPoint name="soleus_r-P2"> + <location> 0 0.031 -0.0053</location> + <body>calcn_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>7924.996721</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.044</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.244</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.43633231</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.1</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="tib_ant_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="tib_ant_r-P1"> + <location> 0.0179 -0.1624 0.0115</location> + <body>tibia_r</body> + </PathPoint> + <PathPoint name="tib_ant_r-P2"> + <location> 0.0329 -0.3951 -0.0177</location> + <body>tibia_r</body> + </PathPoint> + <PathPoint name="tib_ant_r-P3"> + <location> 0.1166 0.0178 -0.0305</location> + <body>calcn_r</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2116.818162</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.068</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.238</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.08726646</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="hamstrings_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="semimem_l-P1"> + <location> -0.1192 -0.09747 -0.07151</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="semimem_l-P2"> + <location> -0.0348 -0.03519 0.01891</location> + <body>tibia_l</body> + <range> -0.558505 0.174533</range> + <coordinate>knee_angle_l</coordinate> + </ConditionalPathPoint> + <PathPoint name="semimem_l-P3"> + <location> -0.027 -0.04771 0.01957</location> + <body>tibia_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>4105.465574</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.069</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.349</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.26179939</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="bifemsh_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="bifemsh_l-P1"> + <location> 0.005 -0.2111 -0.0234</location> + <body>femur_l</body> + </PathPoint> + <PathPoint name="bifemsh_l-P2"> + <location> -0.0301 -0.036 -0.02943</location> + <body>tibia_l</body> + </PathPoint> + <PathPoint name="bifemsh_l-P3"> + <location> -0.0234 -0.0563 -0.0343</location> + <body>tibia_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>557.11475409836</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.11</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.117</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.40142573</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="glut_max_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="glut_max2_l-P1"> + <location> -0.1349 0.0176 -0.0563</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="glut_max2_l-P2"> + <location> -0.1376 -0.052 -0.0914</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="glut_max2_l-P3"> + <location> -0.0426 -0.053 -0.0293</location> + <body>femur_l</body> + </PathPoint> + <PathPoint name="glut_max2_l-P4"> + <location> -0.0156 -0.1016 -0.0419</location> + <body>femur_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>3337.583607</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.157</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.048</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="iliopsoas_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="psoas_l-P1"> + <location> -0.0647 0.0887 -0.0289</location> + <body>pelvis</body> + </PathPoint> + <PathPoint name="psoas_l-P2"> + <location> -0.0238 -0.057 -0.0759</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="psoas_l-P3"> + <location> -0.0288 -0.0805 -0.0816</location> + <body>pelvis</body> + <range> -1.5708 0.785398</range> + <coordinate>hip_flexion_l</coordinate> + </ConditionalPathPoint> + <PathPoint name="psoas_l-P4"> + <location> 0.0016 -0.0507 -0.0038</location> + <body>femur_l</body> + </PathPoint> + <PathPoint name="psoas_l-P5"> + <location> -0.0188 -0.0597 -0.0104</location> + <body>femur_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2697.344262</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.117</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.130</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.13962634</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="rect_fem_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="rect_fem_l-P1"> + <location> -0.0295 -0.0311 -0.0968</location> + <body>pelvis</body> + </PathPoint> + <ConditionalPathPoint name="rect_fem_l-P2"> + <location> 0.0334 -0.403 -0.0019</location> + <body>femur_l</body> + <range> -2.61799 -1.45997</range> + <coordinate>knee_angle_l</coordinate> + </ConditionalPathPoint> + <MovingPathPoint name="rect_fem_l-P3"> + <location> 0.0617576 0.020984 -0.0014</location> + <body>tibia_l</body> + <x_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0155805 0.0179938 0.0275081 0.0296564 0.0307615 0.0365695 0.0422074 0.0450902 0.048391 0.0534299 0.0617576 0.0617669 0.0617762 0.0633083 0.066994 0.0733035 0.0573481</y> + </SimmSpline> + </x_location> + <x_coordinate>knee_angle_l</x_coordinate> + <y_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0234116 0.0237613 0.0251141 0.0252795 0.0253146 0.0249184 0.0242373 0.0238447 0.0234197 0.0227644 0.020984 0.0209814 0.0209788 0.0205225 0.0191754 0.0159554 -0.0673774</y> + </SimmSpline> + </y_location> + <y_coordinate>knee_angle_l</y_coordinate> + <z_location> + <SimmSpline> + <x> -2.0944 0.1745</x> + <y> -0.0014 -0.0014</y> + </SimmSpline> + </z_location> + <z_coordinate>knee_angle_l</z_coordinate> + </MovingPathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2191.74098360656</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.076</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.346</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.08726646</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + <!--passive muscle strain at maximum isometric muscle force--> + <FmaxMuscleStrain>1.0</FmaxMuscleStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="vasti_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="vas_int_l-P1"> + <location> 0.029 -0.1924 -0.031</location> + <body>femur_l</body> + </PathPoint> + <PathPoint name="vas_int_l-P2"> + <location> 0.0335 -0.2084 -0.0285</location> + <body>femur_l</body> + </PathPoint> + <ConditionalPathPoint name="vas_int_l-P3"> + <location> 0.0343 -0.403 -0.0055</location> + <body>femur_l</body> + <range> -2.61799 -1.42</range> + <coordinate>knee_angle_l</coordinate> + </ConditionalPathPoint> + <MovingPathPoint name="vas_int_l-P4"> + <location> 0.0554632 0.0252923 -0.0018</location> + <body>tibia_l</body> + <x_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.0082733 0.0106866 0.0202042 0.022353 0.0234583 0.0292715 0.0349465 0.037871 0.0412569 0.0465287 0.0554632 0.0554735 0.0554837 0.0571717 0.061272 0.0684368 0.0648818</y> + </SimmSpline> + </x_location> + <x_coordinate>knee_angle_l</x_coordinate> + <y_location> + <SimmSpline> + <x> -2.0944 -1.99997 -1.5708 -1.45752 -1.39626 -1.0472 -0.698132 -0.526391 -0.349066 -0.174533 0 0.00017453 0.00034907 0.0279253 0.0872665 0.174533 2.0944</x> + <y> 0.025599 0.0259487 0.0273124 0.0274796 0.0275151 0.0271363 0.0265737 0.0263073 0.0261187 0.0260129 0.0252923 0.0252911 0.0252898 0.0250526 0.0242191 0.0218288 -0.0685706</y> + </SimmSpline> + </y_location> + <y_coordinate>knee_angle_l</y_coordinate> + <z_location> + <SimmSpline> + <x> -2.0944 2.0944</x> + <y> -0.0018 -0.0018</y> + </SimmSpline> + </z_location> + <z_coordinate>knee_angle_l</z_coordinate> + </MovingPathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>9593.95082</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.099</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.102</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.05235988</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + <!--passive muscle strain at maximum isometric muscle force--> + <FmaxMuscleStrain>1.0</FmaxMuscleStrain> + <!--exponential shape factor for passive force-length relationship--> + <KshapePassive>9</KshapePassive> + </Thelen2003Muscle> + <Thelen2003Muscle name="gastroc_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="med_gas_l-P1"> + <location> -0.019 -0.3929 0.0235</location> + <body>femur_l</body> + </PathPoint> + <ConditionalPathPoint name="med_gas_l-P2"> + <location> -0.03 -0.4022 0.0258</location> + <body>femur_l</body> + <range> -0.785398 0.174533</range> + <coordinate>knee_angle_l</coordinate> + </ConditionalPathPoint> + <PathPoint name="med_gas_l-P3"> + <location> 0 0.031 0.0053</location> + <body>calcn_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>4690.57377</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.051</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.384</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.29670597</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.1</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="soleus_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="soleus_l-P1"> + <location> -0.0024 -0.1533 -0.0071</location> + <body>tibia_l</body> + </PathPoint> + <PathPoint name="soleus_l-P2"> + <location> 0 0.031 0.0053</location> + <body>calcn_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>7924.996721</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.044</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.244</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.43633231</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.1</FmaxTendonStrain> + </Thelen2003Muscle> + <Thelen2003Muscle name="tib_ant_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Minimum allowed value for control signal. Used primarily when solving for control values.--> + <min_control>0</min_control> + <!--Maximum allowed value for control signal. Used primarily when solving for control values.--> + <max_control>1</max_control> + <!--The set of points defining the path of the muscle.--> + <GeometryPath> + <!--The set of points defining the path--> + <PathPointSet> + <objects> + <PathPoint name="tib_ant_l-P1"> + <location> 0.0179 -0.1624 -0.0115</location> + <body>tibia_l</body> + </PathPoint> + <PathPoint name="tib_ant_l-P2"> + <location> 0.0329 -0.3951 0.0177</location> + <body>tibia_l</body> + </PathPoint> + <PathPoint name="tib_ant_l-P3"> + <location> 0.1166 0.0178 0.0305</location> + <body>calcn_l</body> + </PathPoint> + </objects> + <groups /> + </PathPointSet> + <!--The wrap objecs that are associated with this path--> + <PathWrapSet> + <objects /> + <groups /> + </PathWrapSet> + <!--Used to display the path in the 3D window--> + <VisibleObject name="display"> + <!--Set of geometry files and associated attributes, allow .vtp, .stl, .obj--> + <GeometrySet> + <objects /> + <groups /> + </GeometrySet> + <!--Three scale factors for display purposes: scaleX scaleY scaleZ--> + <scale_factors> 1 1 1</scale_factors> + <!--transform relative to owner specified as 3 rotations (rad) followed by 3 translations rX rY rZ tx ty tz--> + <transform> 0 0 0 0 0 0</transform> + <!--Whether to show a coordinate frame--> + <show_axes>false</show_axes> + <!--Display Pref. 0:Hide 1:Wire 3:Flat 4:Shaded Can be overriden for individual geometries--> + <display_preference>4</display_preference> + </VisibleObject> + </GeometryPath> + <!--The maximum force this actuator can produce.--> + <optimal_force>1</optimal_force> + <!--Maximum isometric force that the fibers can generate--> + <max_isometric_force>2116.818162</max_isometric_force> + <!--Optimal length of the muscle fibers--> + <optimal_fiber_length>0.068</optimal_fiber_length> + <!--Resting length of the tendon--> + <tendon_slack_length>0.238</tendon_slack_length> + <!--Angle between tendon and fibers at optimal fiber length expressed in radians--> + <pennation_angle_at_optimal>0.08726646</pennation_angle_at_optimal> + <!--Maximum contraction velocity of the fibers, in optimal fiberlengths/second--> + <max_contraction_velocity>15</max_contraction_velocity> + <!--time constant for ramping up muscle activation--> + <activation_time_constant>0.01</activation_time_constant> + <!--time constant for ramping down of muscle activation--> + <deactivation_time_constant>0.04</deactivation_time_constant> + <!--tendon strain at maximum isometric muscle force--> + <FmaxTendonStrain>0.049</FmaxTendonStrain> + </Thelen2003Muscle> + <HuntCrossleyForce name="foot_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Material properties.--> + <HuntCrossleyForce::ContactParametersSet name="contact_parameters"> + <objects> + <HuntCrossleyForce::ContactParameters> + <!--Names of geometry objects affected by these parameters.--> + <geometry>platform r_heel r_toe</geometry> + <stiffness>600000</stiffness> + <dissipation>1.5</dissipation> + <static_friction>0.8</static_friction> + <dynamic_friction>0.8</dynamic_friction> + <viscous_friction>0</viscous_friction> + </HuntCrossleyForce::ContactParameters> + </objects> + <groups /> + </HuntCrossleyForce::ContactParametersSet> + <!--Slip velocity (creep) at which peak static friction occurs.--> + <transition_velocity>0.1</transition_velocity> + </HuntCrossleyForce> + <HuntCrossleyForce name="foot_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Material properties.--> + <HuntCrossleyForce::ContactParametersSet name="contact_parameters"> + <objects> + <HuntCrossleyForce::ContactParameters> + <!--Names of geometry objects affected by these parameters.--> + <geometry>platform l_heel l_toe</geometry> + <stiffness>600000</stiffness> + <dissipation>1.5</dissipation> + <static_friction>0.8</static_friction> + <dynamic_friction>0.8</dynamic_friction> + <viscous_friction>0</viscous_friction> + </HuntCrossleyForce::ContactParameters> + </objects> + <groups /> + </HuntCrossleyForce::ContactParametersSet> + <!--Slip velocity (creep) at which peak static friction occurs.--> + <transition_velocity>0.1</transition_velocity> + </HuntCrossleyForce> + <CoordinateLimitForce name="HipLimit_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>hip_flexion_r</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>120</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-30</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + <CoordinateLimitForce name="HipLimit_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>hip_flexion_l</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>120</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-30</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + <CoordinateLimitForce name="KneeLimit_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>knee_angle_r</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>10</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-140</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + <CoordinateLimitForce name="KneeLimit_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>knee_angle_l</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>10</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-140</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + <CoordinateLimitForce name="AnkleLimit_r"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>ankle_angle_r</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>20</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-40</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + <CoordinateLimitForce name="AnkleLimit_l"> + <!--Flag indicating whether the force is disabled or not. Disabled means that the force is not active in subsequent dynamics realizations.--> + <isDisabled>false</isDisabled> + <!--Coordinate (name) to be limited.--> + <coordinate>ankle_angle_l</coordinate> + <!--Stiffness of the passive limit force when coordinate exceeds upper limit. Note, rotational stiffness expected in N*m/degree.--> + <upper_stiffness>20</upper_stiffness> + <!--The upper limit of the coordinate range of motion (rotations in degrees).--> + <upper_limit>20</upper_limit> + <!--Stiffness of the passive limit force when coordinate exceeds lower limit. Note, rotational stiffness expected in N*m/degree.--> + <lower_stiffness>20</lower_stiffness> + <!--The lower limit of the coordinate range of motion (rotations in degrees).--> + <lower_limit>-40</lower_limit> + <!--Damping factor on the coordinate's speed applied only when limit is exceeded. For translational has units N/(m/s) and rotational has Nm/(degree/s)--> + <damping>0.25</damping> + <!--Transition region width in the units of the coordinate (rotations in degrees). Dictates the transition from zero to constant stiffness as coordinate exceeds its limit.--> + <transition>10</transition> + </CoordinateLimitForce> + </objects> + <groups /> + </ForceSet> + <!--Markers in the model.--> + <MarkerSet> + <objects /> + <groups /> + </MarkerSet> + <!--ContactGeometries in the model.--> + <ContactGeometrySet> + <objects> + <ContactHalfSpace name="platform"> + <!--Body name to connect the contact geometry to--> + <body_name>ground</body_name> + <!--Location of geometry center in the body frame--> + <location>0 0 0</location> + <!--Orientation of geometry in the body frame--> + <orientation>0 0 -1.5707963267949</orientation> + </ContactHalfSpace> + <ContactSphere name="r_heel"> + <!--Body name to connect the contact geometry to--> + <body_name>calcn_r</body_name> + <!--Location of geometry center in the body frame--> + <location>0.03 0.04 0</location> + <!--Orientation of geometry in the body frame--> + <orientation>0 0 0</orientation> + <radius>0.05</radius> + </ContactSphere> + <ContactSphere name="r_toe"> + <!--Body name to connect the contact geometry to--> + <body_name>toes_r</body_name> + <!--Location of geometry center in the body frame--> + <location>0.03 0.04 0</location> + <!--Orientation of geometry in the body frame--> + <orientation>0 0 0</orientation> + <radius>0.05</radius> + </ContactSphere> + <ContactSphere name="l_heel"> + <!--Body name to connect the contact geometry to--> + <body_name>calcn_l</body_name> + <!--Location of geometry center in the body frame--> + <location>0.03 0.04 0</location> + <!--Orientation of geometry in the body frame--> + <orientation>0 0 0</orientation> + <radius>0.05</radius> + </ContactSphere> + <ContactSphere name="l_toe"> + <!--Body name to connect the contact geometry to--> + <body_name>toes_l</body_name> + <!--Location of geometry center in the body frame--> + <location>0.03 0.04 0</location> + <!--Orientation of geometry in the body frame--> + <orientation>0 0 0</orientation> + <radius>0.05</radius> + </ContactSphere> + </objects> + <groups /> + </ContactGeometrySet> + <!--Controllers in the model.--> + <ControllerSet name="Controllers"> + <objects /> + <groups /> + </ControllerSet> + <!--Additional components in the model.--> + <ComponentSet name="MiscComponents"> + <objects /> + <groups /> + </ComponentSet> + <!--Probes in the model.--> + <ProbeSet> + <objects /> + <groups /> + </ProbeSet> + </Model> +</OpenSimDocument>