jaxsim 0.4.3.dev359__tar.gz → 0.4.3.dev362__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (129) hide show
  1. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/PKG-INFO +1 -1
  2. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/_version.py +2 -2
  3. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/common.py +5 -5
  4. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/relaxed_rigid.py +74 -56
  5. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim.egg-info/PKG-INFO +1 -1
  6. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.devcontainer/Dockerfile +0 -0
  7. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.devcontainer/devcontainer.json +0 -0
  8. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.gitattributes +0 -0
  9. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.github/CODEOWNERS +0 -0
  10. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.github/dependabot.yml +0 -0
  11. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.github/workflows/ci_cd.yml +0 -0
  12. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.github/workflows/pixi.yml +0 -0
  13. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.github/workflows/read_the_docs.yml +0 -0
  14. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.gitignore +0 -0
  15. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.pre-commit-config.yaml +0 -0
  16. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/.readthedocs.yaml +0 -0
  17. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/CONTRIBUTING.md +0 -0
  18. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/LICENSE +0 -0
  19. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/README.md +0 -0
  20. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/Makefile +0 -0
  21. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/conf.py +0 -0
  22. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/examples.rst +0 -0
  23. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/guide/install.rst +0 -0
  24. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/index.rst +0 -0
  25. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/make.bat +0 -0
  26. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/api.rst +0 -0
  27. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/integrators.rst +0 -0
  28. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/math.rst +0 -0
  29. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/mujoco.rst +0 -0
  30. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/parsers.rst +0 -0
  31. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/rbda.rst +0 -0
  32. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/typing.rst +0 -0
  33. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/docs/modules/utils.rst +0 -0
  34. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/environment.yml +0 -0
  35. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/.gitattributes +0 -0
  36. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/.gitignore +0 -0
  37. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/README.md +0 -0
  38. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/assets/build_cartpole_urdf.py +0 -0
  39. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/assets/cartpole.urdf +0 -0
  40. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/jaxsim_as_multibody_dynamics_library.ipynb +0 -0
  41. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/jaxsim_as_physics_engine.ipynb +0 -0
  42. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/examples/jaxsim_for_robot_controllers.ipynb +0 -0
  43. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/pixi.lock +0 -0
  44. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/pyproject.toml +0 -0
  45. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/setup.cfg +0 -0
  46. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/setup.py +0 -0
  47. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/__init__.py +0 -0
  48. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/__init__.py +0 -0
  49. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/com.py +0 -0
  50. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/common.py +0 -0
  51. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/contact.py +0 -0
  52. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/data.py +0 -0
  53. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/frame.py +0 -0
  54. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/joint.py +0 -0
  55. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/kin_dyn_parameters.py +0 -0
  56. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/link.py +0 -0
  57. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/model.py +0 -0
  58. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/ode.py +0 -0
  59. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/ode_data.py +0 -0
  60. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/api/references.py +0 -0
  61. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/exceptions.py +0 -0
  62. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/integrators/__init__.py +0 -0
  63. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/integrators/common.py +0 -0
  64. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/integrators/fixed_step.py +0 -0
  65. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/integrators/variable_step.py +0 -0
  66. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/logging.py +0 -0
  67. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/__init__.py +0 -0
  68. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/adjoint.py +0 -0
  69. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/cross.py +0 -0
  70. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/inertia.py +0 -0
  71. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/joint_model.py +0 -0
  72. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/quaternion.py +0 -0
  73. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/rotation.py +0 -0
  74. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/skew.py +0 -0
  75. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/math/transform.py +0 -0
  76. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/__init__.py +0 -0
  77. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/__main__.py +0 -0
  78. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/loaders.py +0 -0
  79. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/model.py +0 -0
  80. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/utils.py +0 -0
  81. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/mujoco/visualizer.py +0 -0
  82. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/__init__.py +0 -0
  83. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/descriptions/__init__.py +0 -0
  84. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/descriptions/collision.py +0 -0
  85. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/descriptions/joint.py +0 -0
  86. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/descriptions/link.py +0 -0
  87. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/descriptions/model.py +0 -0
  88. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/kinematic_graph.py +0 -0
  89. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/rod/__init__.py +0 -0
  90. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/rod/parser.py +0 -0
  91. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/parsers/rod/utils.py +0 -0
  92. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/__init__.py +0 -0
  93. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/aba.py +0 -0
  94. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/collidable_points.py +0 -0
  95. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/__init__.py +0 -0
  96. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/rigid.py +0 -0
  97. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/soft.py +0 -0
  98. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/contacts/visco_elastic.py +0 -0
  99. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/crba.py +0 -0
  100. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/forward_kinematics.py +0 -0
  101. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/jacobian.py +0 -0
  102. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/rnea.py +0 -0
  103. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/rbda/utils.py +0 -0
  104. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/terrain/__init__.py +0 -0
  105. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/terrain/terrain.py +0 -0
  106. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/typing.py +0 -0
  107. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/utils/__init__.py +0 -0
  108. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/utils/jaxsim_dataclass.py +0 -0
  109. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/utils/tracing.py +0 -0
  110. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim/utils/wrappers.py +0 -0
  111. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim.egg-info/SOURCES.txt +0 -0
  112. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim.egg-info/dependency_links.txt +0 -0
  113. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim.egg-info/requires.txt +0 -0
  114. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/src/jaxsim.egg-info/top_level.txt +0 -0
  115. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/__init__.py +0 -0
  116. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/conftest.py +0 -0
  117. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_com.py +0 -0
  118. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_contact.py +0 -0
  119. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_data.py +0 -0
  120. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_frame.py +0 -0
  121. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_joint.py +0 -0
  122. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_link.py +0 -0
  123. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_api_model.py +0 -0
  124. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_automatic_differentiation.py +0 -0
  125. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_contact.py +0 -0
  126. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_exceptions.py +0 -0
  127. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_pytree.py +0 -0
  128. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/test_simulations.py +0 -0
  129. {jaxsim-0.4.3.dev359 → jaxsim-0.4.3.dev362}/tests/utils_idyntree.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: jaxsim
3
- Version: 0.4.3.dev359
3
+ Version: 0.4.3.dev362
4
4
  Summary: A differentiable physics engine and multibody dynamics library for control and robot learning.
5
5
  Author-email: Diego Ferigo <dgferigo@gmail.com>, Filippo Luca Ferretti <filippoluca.ferretti@outlook.com>
6
6
  Maintainer-email: Filippo Luca Ferretti <filippo.ferretti@iit.it>, Alessandro Croci <alessandro.croci@iit.it>
@@ -12,5 +12,5 @@ __version__: str
12
12
  __version_tuple__: VERSION_TUPLE
13
13
  version_tuple: VERSION_TUPLE
14
14
 
15
- __version__ = version = '0.4.3.dev359'
16
- __version_tuple__ = version_tuple = (0, 4, 3, 'dev359')
15
+ __version__ = version = '0.4.3.dev362'
16
+ __version_tuple__ = version_tuple = (0, 4, 3, 'dev362')
@@ -324,10 +324,10 @@ class ContactModel(JaxsimDataclass):
324
324
  The initialized model and data objects.
325
325
  """
326
326
 
327
- with model.editable(validate=validate) as model_out:
328
- model_out.contact_model = self
327
+ with self.editable(validate=validate) as contact_model:
328
+ contact_model.parameters = data.contacts_params
329
329
 
330
- with data.editable(validate=validate) as data_out:
331
- data_out.contacts_params = data.contacts_params
330
+ with model.editable(validate=validate) as model_out:
331
+ model_out.contact_model = contact_model
332
332
 
333
- return model_out, data_out
333
+ return model_out, data
@@ -10,6 +10,7 @@ import jax_dataclasses
10
10
  import optax
11
11
 
12
12
  import jaxsim.api as js
13
+ import jaxsim.rbda.contacts
13
14
  import jaxsim.typing as jtp
14
15
  from jaxsim import logging
15
16
  from jaxsim.api.common import ModelDataWithVelocityRepresentation, VelRepr
@@ -314,22 +315,20 @@ class RelaxedRigidContacts(common.ContactModel):
314
315
  joint_force_references=joint_force_references,
315
316
  )
316
317
 
317
- def detect_contact(x: jtp.Array, y: jtp.Array, z: jtp.Array) -> jtp.Array:
318
- x, y, z = jax.tree.map(jnp.squeeze, (x, y, z))
319
-
320
- n̂ = model.terrain.normal(x=x, y=y).squeeze()
321
- h = jnp.array([0, 0, z - model.terrain.height(x=x, y=y)])
322
-
323
- return jnp.dot(h, n̂)
324
-
325
318
  # Compute the position and linear velocities (mixed representation) of
326
319
  # all collidable points belonging to the robot.
327
320
  position, velocity = js.contact.collidable_point_kinematics(
328
321
  model=model, data=data
329
322
  )
330
323
 
331
- # Compute the activation state of the collidable points
332
- δ = jax.vmap(detect_contact)(*position.T)
324
+ # Compute the penetration depth and velocity of the collidable points.
325
+ # Note that this function considers the penetration in the normal direction.
326
+ δ, _, n̂ = jax.vmap(common.compute_penetration_data, in_axes=(0, 0, None))(
327
+ position, velocity, model.terrain
328
+ )
329
+
330
+ # Compute the position in the constraint frame.
331
+ position_constraint = jax.vmap(lambda δ, n̂: -δ * n̂)(δ, n̂)
333
332
 
334
333
  # Compute the transforms of the implicit frames corresponding to the
335
334
  # collidable points.
@@ -356,24 +355,22 @@ class RelaxedRigidContacts(common.ContactModel):
356
355
  M = js.model.free_floating_mass_matrix(model=model, data=data)
357
356
 
358
357
  Jl_WC = jnp.vstack(
359
- jax.vmap(lambda J, height: J * (height < 0))(
360
- js.contact.jacobian(model=model, data=data)[:, :3, :],
361
- δ,
358
+ jax.vmap(lambda J, δ: J * (δ > 0))(
359
+ js.contact.jacobian(model=model, data=data)[:, :3, :], δ
362
360
  )
363
361
  )
364
362
 
365
363
  J̇_WC = jnp.vstack(
366
- jax.vmap(lambda J̇, height: J̇ * (height < 0))(
367
- js.contact.jacobian_derivative(model=model, data=data)[:, :3],
368
- δ,
364
+ jax.vmap(lambda J̇, δ: J̇ * (δ > 0))(
365
+ js.contact.jacobian_derivative(model=model, data=data)[:, :3], δ
369
366
  ),
370
367
  )
371
368
 
372
369
  # Compute the regularization terms.
373
- a_ref, R, K, D = self._regularizers(
370
+ a_ref, R, *_ = self._regularizers(
374
371
  model=model,
375
- penetration=δ,
376
- velocity=velocity,
372
+ position_constraint=position_constraint,
373
+ velocity_constraint=velocity,
377
374
  parameters=data.contacts_params,
378
375
  )
379
376
 
@@ -435,6 +432,7 @@ class RelaxedRigidContacts(common.ContactModel):
435
432
 
436
433
  return params, state
437
434
 
435
+ # TODO: maybe fix the number of iterations and switch to scan?
438
436
  def continuing_criterion(carry: OptimizationCarry) -> jtp.Bool:
439
437
 
440
438
  _, state = carry
@@ -456,10 +454,20 @@ class RelaxedRigidContacts(common.ContactModel):
456
454
  # ======================================
457
455
 
458
456
  # Initialize the optimized forces with a linear Hunt/Crossley model.
459
- init_params = (
460
- K[:, jnp.newaxis] * jnp.zeros_like(position).at[:, 2].set(δ)
461
- + D[:, jnp.newaxis] * velocity
462
- ).flatten()
457
+ init_params = jax.vmap(
458
+ lambda p, v: jaxsim.rbda.contacts.SoftContacts.hunt_crossley_contact_model(
459
+ position=p,
460
+ velocity=v,
461
+ terrain=model.terrain,
462
+ K=1e6,
463
+ D=2e3,
464
+ p=0.0,
465
+ q=0.0,
466
+ # No tangential initial forces.
467
+ mu=0.0,
468
+ tangential_deformation=jnp.zeros(3),
469
+ )[0]
470
+ )(position, velocity).flatten()
463
471
 
464
472
  # Get the solver options.
465
473
  solver_options = self.solver_options
@@ -498,8 +506,8 @@ class RelaxedRigidContacts(common.ContactModel):
498
506
  @staticmethod
499
507
  def _regularizers(
500
508
  model: js.model.JaxSimModel,
501
- penetration: jtp.Array,
502
- velocity: jtp.Array,
509
+ position_constraint: jtp.Vector,
510
+ velocity_constraint: jtp.Vector,
503
511
  parameters: RelaxedRigidContactsParams,
504
512
  ) -> tuple:
505
513
  """
@@ -507,12 +515,13 @@ class RelaxedRigidContacts(common.ContactModel):
507
515
 
508
516
  Args:
509
517
  model: The jaxsim model.
510
- penetration: The penetration of the collidable points.
511
- velocity: The velocity of the collidable points.
518
+ penetration: The point position in the constraint frame.
519
+ velocity: The point velocity in the constraint frame.
512
520
  parameters: The parameters of the relaxed rigid contacts model.
513
521
 
514
522
  Returns:
515
- A tuple containing the reference acceleration, the regularization matrix, the stiffness, and the damping.
523
+ A tuple containing the reference acceleration, the regularization matrix,
524
+ the stiffness, and the damping.
516
525
  """
517
526
 
518
527
  # Extract the parameters of the contact model.
@@ -545,70 +554,79 @@ class RelaxedRigidContacts(common.ContactModel):
545
554
  M_L = js.model.link_spatial_inertia_matrices(model=model)
546
555
 
547
556
  def imp_aref(
548
- penetration: jtp.Array, velocity: jtp.Array
549
- ) -> tuple[jtp.Array, jtp.Array]:
557
+ pos: jtp.Vector,
558
+ vel: jtp.Vector,
559
+ ) -> tuple[jtp.Vector, jtp.Vector, jtp.Vector, jtp.Vector]:
550
560
  """
551
561
  Calculates impedance and offset acceleration in constraint frame.
552
562
 
553
563
  Args:
554
- penetration: penetration in constraint frame
555
- velocity: velocity in constraint frame
564
+ pos: position in constraint frame.
565
+ vel: velocity in constraint frame.
556
566
 
557
567
  Returns:
568
+ ξ: computed impedance
558
569
  a_ref: offset acceleration in constraint frame
559
- R: regularization matrix
560
570
  K: computed stiffness
561
571
  D: computed damping
562
572
  """
563
- position = jnp.zeros(shape=(3,)).at[2].set(penetration)
564
573
 
565
- imp_x = jnp.abs(position) / width
566
- imp_a = (1.0 / jnp.power(mid, p - 1)) * jnp.power(imp_x, p)
574
+ imp_x = jnp.abs(pos) / width
567
575
 
576
+ imp_a = (1.0 / jnp.power(mid, p - 1)) * jnp.power(imp_x, p)
568
577
  imp_b = 1 - (1.0 / jnp.power(1 - mid, p - 1)) * jnp.power(1 - imp_x, p)
569
-
570
578
  imp_y = jnp.where(imp_x < mid, imp_a, imp_b)
571
579
 
572
- imp = jnp.clip(ξ_min + imp_y * (ξ_max - ξ_min), ξ_min, ξ_max)
573
- imp = jnp.atleast_1d(jnp.where(imp_x > 1.0, ξ_max, imp))
580
+ # Compute the impedance.
581
+ ξ = ξ_min + imp_y * (ξ_max - ξ_min)
582
+ ξ = jnp.clip(ξ, ξ_min, ξ_max)
583
+ ξ = jnp.where(imp_x > 1.0, ξ_max, ξ)
584
+
585
+ # Compute the spring and damper parameters during runtime from the
586
+ # impedance and other contact parameters.
587
+ K = 1 / (ξ_max * Ω * ζ) ** 2
588
+ D = 2 / (ξ_max * Ω)
574
589
 
575
- # When passing negative values, K and D represent a spring and damper, respectively.
576
- K_f = jnp.where(K < 0, -K / ξ_max**2, 1 / (ξ_max * Ω * ζ) ** 2)
577
- D_f = jnp.where(D < 0, -D / ξ_max, 2 / (ξ_max * Ω))
590
+ # If the user specifies K and D and they are negative, the computed `a_ref`
591
+ # becomes something more similar to a classic Baumgarte regularization.
592
+ K = jnp.where(K < 0, -K / ξ_max**2, K)
593
+ D = jnp.where(D < 0, -D / ξ_max, D)
578
594
 
579
- a_ref = -jnp.atleast_1d(D_f * velocity + K_f * imp * position)
595
+ # Compute the reference acceleration.
596
+ a_ref = -(D * vel + K * ξ * pos)
580
597
 
581
- return imp, a_ref, jnp.atleast_1d(K_f), jnp.atleast_1d(D_f)
598
+ return ξ, a_ref, K, D
582
599
 
583
600
  def compute_row(
584
601
  *,
585
- link_idx: jtp.Float,
586
- penetration: jtp.Array,
587
- velocity: jtp.Array,
588
- ) -> tuple[jtp.Array, jtp.Array]:
602
+ link_idx: jtp.Int,
603
+ pos: jtp.Vector,
604
+ vel: jtp.Vector,
605
+ ) -> tuple[jtp.Vector, jtp.Matrix, jtp.Vector, jtp.Vector]:
589
606
 
590
607
  # Compute the reference acceleration.
591
- ξ, a_ref, K, D = imp_aref(
592
- penetration=penetration,
593
- velocity=velocity,
594
- )
608
+ ξ, a_ref, K, D = imp_aref(pos=pos, vel=vel)
595
609
 
596
- # Compute the regularization terms.
610
+ # Compute the regularization term.
597
611
  R = (
598
612
  (2 * μ**2 * (1 - ξ) / (ξ + 1e-12))
599
613
  * (1 + μ**2)
600
614
  @ jnp.linalg.inv(M_L[link_idx, :3, :3])
601
615
  )
602
616
 
603
- return jax.tree.map(lambda x: x * (penetration < 0), (a_ref, R, K, D))
617
+ # Return the computed values, setting them to zero in case of no contact.
618
+ is_active = (pos.dot(pos) > 0).astype(float)
619
+ return jax.tree.map(
620
+ lambda x: jnp.atleast_1d(x) * is_active, (a_ref, R, K, D)
621
+ )
604
622
 
605
623
  a_ref, R, K, D = jax.tree.map(
606
624
  f=jnp.concatenate,
607
625
  tree=(
608
626
  *jax.vmap(compute_row)(
609
627
  link_idx=parent_link_idx_of_enabled_collidable_points,
610
- penetration=penetration,
611
- velocity=velocity,
628
+ pos=position_constraint,
629
+ vel=velocity_constraint,
612
630
  ),
613
631
  ),
614
632
  )
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: jaxsim
3
- Version: 0.4.3.dev359
3
+ Version: 0.4.3.dev362
4
4
  Summary: A differentiable physics engine and multibody dynamics library for control and robot learning.
5
5
  Author-email: Diego Ferigo <dgferigo@gmail.com>, Filippo Luca Ferretti <filippoluca.ferretti@outlook.com>
6
6
  Maintainer-email: Filippo Luca Ferretti <filippo.ferretti@iit.it>, Alessandro Croci <alessandro.croci@iit.it>
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes