jaxsim 0.4.2.dev47__py3-none-any.whl → 0.4.2.dev50__py3-none-any.whl
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.
- jaxsim/_version.py +2 -2
- jaxsim/rbda/crba.py +24 -12
- jaxsim/rbda/forward_kinematics.py +8 -4
- jaxsim/rbda/jacobian.py +24 -12
- {jaxsim-0.4.2.dev47.dist-info → jaxsim-0.4.2.dev50.dist-info}/METADATA +1 -1
- {jaxsim-0.4.2.dev47.dist-info → jaxsim-0.4.2.dev50.dist-info}/RECORD +9 -9
- {jaxsim-0.4.2.dev47.dist-info → jaxsim-0.4.2.dev50.dist-info}/LICENSE +0 -0
- {jaxsim-0.4.2.dev47.dist-info → jaxsim-0.4.2.dev50.dist-info}/WHEEL +0 -0
- {jaxsim-0.4.2.dev47.dist-info → jaxsim-0.4.2.dev50.dist-info}/top_level.txt +0 -0
jaxsim/_version.py
CHANGED
@@ -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.2.
|
16
|
-
__version_tuple__ = version_tuple = (0, 4, 2, '
|
15
|
+
__version__ = version = '0.4.2.dev50'
|
16
|
+
__version_tuple__ = version_tuple = (0, 4, 2, 'dev50')
|
jaxsim/rbda/crba.py
CHANGED
@@ -59,10 +59,14 @@ def crba(model: js.model.JaxSimModel, *, joint_positions: jtp.Vector) -> jtp.Mat
|
|
59
59
|
|
60
60
|
return (i_X_0,), None
|
61
61
|
|
62
|
-
(i_X_0,), _ =
|
63
|
-
|
64
|
-
|
65
|
-
|
62
|
+
(i_X_0,), _ = (
|
63
|
+
jax.lax.scan(
|
64
|
+
f=propagate_kinematics,
|
65
|
+
init=forward_pass_carry,
|
66
|
+
xs=jnp.arange(start=1, stop=model.number_of_links()),
|
67
|
+
)
|
68
|
+
if model.number_of_links() > 1
|
69
|
+
else [(i_X_0,), None]
|
66
70
|
)
|
67
71
|
|
68
72
|
# ===================
|
@@ -128,10 +132,14 @@ def crba(model: js.model.JaxSimModel, *, joint_positions: jtp.Vector) -> jtp.Mat
|
|
128
132
|
operand=carry,
|
129
133
|
)
|
130
134
|
|
131
|
-
(j, Fi, M), _ =
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
+
(j, Fi, M), _ = (
|
136
|
+
jax.lax.scan(
|
137
|
+
f=inner_fn,
|
138
|
+
init=carry_inner_fn,
|
139
|
+
xs=jnp.flip(jnp.arange(start=1, stop=model.number_of_links())),
|
140
|
+
)
|
141
|
+
if model.number_of_links() > 1
|
142
|
+
else [(j, Fi, M), None]
|
135
143
|
)
|
136
144
|
|
137
145
|
Fi = i_X_0[j].T @ Fi
|
@@ -143,10 +151,14 @@ def crba(model: js.model.JaxSimModel, *, joint_positions: jtp.Vector) -> jtp.Mat
|
|
143
151
|
|
144
152
|
# This scan performs the backward pass to compute Mbj, Mjb and Mjj, that
|
145
153
|
# also includes a fake while loop implemented with a scan and two cond.
|
146
|
-
(Mc, M), _ =
|
147
|
-
|
148
|
-
|
149
|
-
|
154
|
+
(Mc, M), _ = (
|
155
|
+
jax.lax.scan(
|
156
|
+
f=backward_pass,
|
157
|
+
init=backward_pass_carry,
|
158
|
+
xs=jnp.flip(jnp.arange(start=1, stop=model.number_of_links())),
|
159
|
+
)
|
160
|
+
if model.number_of_links() > 1
|
161
|
+
else [(Mc, M), None]
|
150
162
|
)
|
151
163
|
|
152
164
|
# Store the locked 6D rigid-body inertia matrix Mbb ∈ ℝ⁶ˣ⁶.
|
@@ -75,10 +75,14 @@ def forward_kinematics_model(
|
|
75
75
|
|
76
76
|
return (W_X_i,), None
|
77
77
|
|
78
|
-
(W_X_i,), _ =
|
79
|
-
|
80
|
-
|
81
|
-
|
78
|
+
(W_X_i,), _ = (
|
79
|
+
jax.lax.scan(
|
80
|
+
f=propagate_kinematics,
|
81
|
+
init=propagate_kinematics_carry,
|
82
|
+
xs=jnp.arange(start=1, stop=model.number_of_links()),
|
83
|
+
)
|
84
|
+
if model.number_of_links() > 1
|
85
|
+
else [(W_X_i,), None]
|
82
86
|
)
|
83
87
|
|
84
88
|
return jax.vmap(Adjoint.to_transform)(W_X_i)
|
jaxsim/rbda/jacobian.py
CHANGED
@@ -67,10 +67,14 @@ def jacobian(
|
|
67
67
|
|
68
68
|
return (i_X_0,), None
|
69
69
|
|
70
|
-
(i_X_0,), _ =
|
71
|
-
|
72
|
-
|
73
|
-
|
70
|
+
(i_X_0,), _ = (
|
71
|
+
jax.lax.scan(
|
72
|
+
f=propagate_kinematics,
|
73
|
+
init=propagate_kinematics_carry,
|
74
|
+
xs=np.arange(start=1, stop=model.number_of_links()),
|
75
|
+
)
|
76
|
+
if model.number_of_links() > 1
|
77
|
+
else [(i_X_0,), None]
|
74
78
|
)
|
75
79
|
|
76
80
|
# ============================
|
@@ -105,10 +109,14 @@ def jacobian(
|
|
105
109
|
|
106
110
|
return J, None
|
107
111
|
|
108
|
-
L_J_WL_B, _ =
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
+
L_J_WL_B, _ = (
|
113
|
+
jax.lax.scan(
|
114
|
+
f=compute_jacobian,
|
115
|
+
init=J,
|
116
|
+
xs=np.arange(start=1, stop=model.number_of_links()),
|
117
|
+
)
|
118
|
+
if model.number_of_links() > 1
|
119
|
+
else [J, None]
|
112
120
|
)
|
113
121
|
|
114
122
|
return L_J_WL_B
|
@@ -184,10 +192,14 @@ def jacobian_full_doubly_left(
|
|
184
192
|
|
185
193
|
return (B_X_i, J), None
|
186
194
|
|
187
|
-
(B_X_i, J), _ =
|
188
|
-
|
189
|
-
|
190
|
-
|
195
|
+
(B_X_i, J), _ = (
|
196
|
+
jax.lax.scan(
|
197
|
+
f=compute_full_jacobian,
|
198
|
+
init=compute_full_jacobian_carry,
|
199
|
+
xs=np.arange(start=1, stop=model.number_of_links()),
|
200
|
+
)
|
201
|
+
if model.number_of_links() > 1
|
202
|
+
else [(B_X_i, J), None]
|
191
203
|
)
|
192
204
|
|
193
205
|
# Convert adjoints to SE(3) transforms.
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: jaxsim
|
3
|
-
Version: 0.4.2.
|
3
|
+
Version: 0.4.2.dev50
|
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>
|
6
6
|
Maintainer-email: Diego Ferigo <dgferigo@gmail.com>, Filippo Luca Ferretti <filippo.ferretti@iit.it>
|
@@ -1,5 +1,5 @@
|
|
1
1
|
jaxsim/__init__.py,sha256=ixsS4dYMPex2wOUUp_rkPnwrPhYzkRh1xO_YuMj3Cr4,2626
|
2
|
-
jaxsim/_version.py,sha256=
|
2
|
+
jaxsim/_version.py,sha256=yzghig35pfSMhh0vIsIOBH-eqIGj9fpA6g-9yTfJMlQ,426
|
3
3
|
jaxsim/exceptions.py,sha256=8_h8iqL8DgNR754dR8SZiQ7361GR5V1sUk3ZuZCHw1Q,2069
|
4
4
|
jaxsim/logging.py,sha256=c4zhwBKf9eAYAHVp62kTEllqdsZgh0K-kPKVy8L3elU,1584
|
5
5
|
jaxsim/typing.py,sha256=IbFx3UkEXi-cm7UBqMPi58rJAFV_HbZ9E_K4JwfNvVM,753
|
@@ -47,9 +47,9 @@ jaxsim/parsers/rod/utils.py,sha256=5DsF3OeePZGidOJ5GiFSZx-51uIdnFvMW9EK6SgOW6Q,5
|
|
47
47
|
jaxsim/rbda/__init__.py,sha256=H7DhXpxkPOi9lpUvg31IMHFfRafke1UoJLc5GQIdyhA,387
|
48
48
|
jaxsim/rbda/aba.py,sha256=w7ciyxB0IsmueatT0C7PcBQEl9dyiH9oqJgIi3xeTUE,8983
|
49
49
|
jaxsim/rbda/collidable_points.py,sha256=Rmf1DhflhOTYh9mDalv0agS0CGSbmfoOybwP2KzKuJ0,4883
|
50
|
-
jaxsim/rbda/crba.py,sha256=
|
51
|
-
jaxsim/rbda/forward_kinematics.py,sha256=
|
52
|
-
jaxsim/rbda/jacobian.py,sha256=
|
50
|
+
jaxsim/rbda/crba.py,sha256=zJSiHKRvNU98z2tT9prrWR4VU9wIZQWFwEut7mua6as,5044
|
51
|
+
jaxsim/rbda/forward_kinematics.py,sha256=2GmEoWsrioVl_SAbKRKfhOLz57pY4aR81PKRdulqStA,3458
|
52
|
+
jaxsim/rbda/jacobian.py,sha256=p0EV_8cLzLVV-93VKznT7VPuRj8W7h7rQWkPlWJXfCA,11023
|
53
53
|
jaxsim/rbda/rnea.py,sha256=LGXD6s3NigaVy4-WxoROjnbKLZcUoyFmS9UNu_4ldjo,7568
|
54
54
|
jaxsim/rbda/utils.py,sha256=eeT21Y4DiiyhrdF0lUE_VvRuwru5-rR7yOlOlWzCCWE,5381
|
55
55
|
jaxsim/rbda/contacts/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -61,8 +61,8 @@ jaxsim/utils/__init__.py,sha256=Y5zyoRevl3EMVQadhZ4EtSwTEkDt2vcnFoRhPJjKTZ0,215
|
|
61
61
|
jaxsim/utils/jaxsim_dataclass.py,sha256=fLl1tY3DDb3lpIhG6BPqA5W34hM84oFzL-5cuz8k-68,11379
|
62
62
|
jaxsim/utils/tracing.py,sha256=KDMoyVPlu2NJvFkhtZwq5AkqMMgajt3munvJom-vEjQ,650
|
63
63
|
jaxsim/utils/wrappers.py,sha256=GOJQCJc5zwzoEGZB62wnWWGvUUQlXvDxz_A2Q-hFv7c,4027
|
64
|
-
jaxsim-0.4.2.
|
65
|
-
jaxsim-0.4.2.
|
66
|
-
jaxsim-0.4.2.
|
67
|
-
jaxsim-0.4.2.
|
68
|
-
jaxsim-0.4.2.
|
64
|
+
jaxsim-0.4.2.dev50.dist-info/LICENSE,sha256=eaYdFmdeMbiIoIiPzEK0MjP1S9wtFXjXNR5er49uLR0,1546
|
65
|
+
jaxsim-0.4.2.dev50.dist-info/METADATA,sha256=2Z9T8eA8kbRT6KsLPBUqmQLb6xvHBjLp_QI2yLMHWfk,17227
|
66
|
+
jaxsim-0.4.2.dev50.dist-info/WHEEL,sha256=nCVcAvsfA9TDtwGwhYaRrlPhTLV9m-Ga6mdyDtuwK18,91
|
67
|
+
jaxsim-0.4.2.dev50.dist-info/top_level.txt,sha256=LxGMA8FLtXjQ6oI7N5gd_R_oSUHxpXxUEOfT1xS_ni0,7
|
68
|
+
jaxsim-0.4.2.dev50.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|