diff --git a/src/jaxsim/simulation/ode.py b/src/jaxsim/simulation/ode.py index 6c9b1bcb9..b9c06a96c 100644 --- a/src/jaxsim/simulation/ode.py +++ b/src/jaxsim/simulation/ode.py @@ -105,6 +105,19 @@ def dx_dt( terrain=terrain, ) + # ============== + # Joint friction + # ============== + + kp_friction = physics_model._joint_friction_static.values() + kd_friction = physics_model._joint_friction_static.values() + + # Compute the joint friction effects + tau_friction = -( + jnp.diag(kp_friction) @ jnp.sign(ode_state.physics_model.joint_positions) + + jnp.diag(kd_friction) @ ode_state.physics_model.joint_velocities + ) + # ======================== # Compute forward dynamics # ======================== @@ -112,15 +125,8 @@ def dx_dt( # Compute the total forces applied to the bodies total_forces = ode_input.physics_model.f_ext + contact_forces_links - # Compute the mechanical joint torques (real torque sent to the joint) by - # subtracting the optional joint friction - # TODO: add support of coulomb/viscous parameters in parsers and PhysicsModel - kp_friction = jnp.array([0.0] * physics_model.dofs()) - kd_friction = jnp.array([0.0] * physics_model.dofs()) - tau = ode_input.physics_model.tau - ( - jnp.diag(kp_friction) @ jnp.sign(ode_state.physics_model.joint_positions) - + jnp.diag(kd_friction) @ ode_state.physics_model.joint_velocities - ) + # Compute the joint torques to actuate + tau = ode_input.physics_model.tau + tau_friction W_a_WB, qdd = algos.aba.aba( model=physics_model,