doc/changelog.rst
General ^^^^^^^
multi-cell support<body-flexcomp-cellnum> for trilinear and quadratic flexes. Note that the implicit
integrator uses a dense solver for the flex degrees of freedom, which can be slow for multi-cell flexes.strain flex :ref:equality constraints<flexcomp-edge-equality> to be instantiated per cell instead of
per flex object, reducing the number of degrees of freedom per constraint row. The equality can be associated with a
specific cell with the new attribute :ref:cell <equality-flexstrain-cell>mj_maxContact<mj_maxContact> function to get the maximum number of possible contacts returned by
colliding two geoms.mj_containsBufferVFS and mj_containsFileVFS to check for existence of buffers and files in VFS... admonition:: Breaking API changes :class: attention
The :ref:multiccd<coMultiCCD> option (multiple contacts returned from the convex collision detection pipeline)
is now enabled by default. The new implementation (as opposed to the legacy pipeline) has little performance
overhead and improves stability.
Migration: Disable :ref:multiccd<option-flag-multiccd> to recover the previous behavior.
Documentation ^^^^^^^^^^^^^
documentation<exDecoder> for :ref:mjpDecoder plugins.Bug fixes ^^^^^^^^^
General ^^^^^^^
dcmotor<actuator-dcmotor> actuator for modeling DC motors. Supports optional
electrical dynamics (inductance), cogging torque, thermal resistance variation, and LuGre friction. See the
technical note <_static/dcmotor.pdf>__ for more details.damping<actuator-general-damping> and :ref:armature<actuator-general-armature> to their transmission target.
These are applied during the passive force and inertia computations, respectively, and are scaled by gear\ :sup:2
("reflected" damping/inertia)... youtube:: aKa3ZlEF9_Y :align: right :width: 35%
Stiffness in :ref:joints<body-joint-stiffness> and :ref:tendons<tendon-spatial-stiffness> and damping in
:ref:joints<body-joint-damping> and :ref:tendons<tendon-spatial-damping> now support nonlinear polynomial
:ref:force profiles<gePolynomial>. New mjModel arrays (jnt_stiffnesspoly, tendon_stiffnesspoly,
dof_dampingpoly, tendon_dampingpoly) hold higher-order coefficients. The existing scalar arrays
(jnt_stiffness, dof_damping, etc.) continue to hold the linear coefficient and are unchanged.
The polynomial order is defined by the new constant :ref:mjNPOLY<glNumericSizes>. A future breaking C-API change
may unify the linear and higher-order coefficients into a single array.
Added :ref:midpoint integration<geMidpoint> for standalone free bodies in implicit and implicitfast
:ref:integrators<geIntegrators>. This applies the implicit midpoint rule to the rotational dynamics of free bodies
with no children, conserving kinetic energy to machine precision in the absence of external torques. The
:ref:invdiscrete<option-flag-invdiscrete> flag now also disables midpoint integration, providing an opt-out
mechanism.
Added the centripetal/Coriolis acceleration term :math:\dot{J}v to the constraint solver bias for
:ref:connect<equality-connect> and :ref:weld<equality-weld> equality constaints. This significantly improves the
stability of constrained mechanisms like four-bar linkages. See :ref:Dual problem<soDual> for details.
Introduced :ref:mjpEncoder, the counterpart to :ref:mjpDecoder for encoding of :ref:mjSpec and :ref:mjModel
into :ref:mjResource.
Added :ref:mj_encode, :ref:mjp_registerEncoder, :ref:mjp_defaultEncoder, and :ref:mjp_findEncoder.
.. admonition:: Breaking API changes :class: attention
The mjs layer fields stiffness and damping in :ref:mjsJoint and :ref:mjsTendon have
been widened from mjtNum scalars to mjtNum[mjNPOLY+1] arrays. The first element is the linear coefficient
(previously the scalar), and subsequent elements are the higher-order :ref:polynomial<gePolynomial> coefficients.
Migration: Replace assignments like joint.stiffness = val with joint.stiffness[0] = val.
.obj and .stl decoders are now included as source when building MuJoCo with CMake. This fixes the
behaviour from the previous release where it required downstream code to load these plugins explicitly.
The vertcollide field in :ref:mjsFlex has been removed. It is no longer required since
:doc:MuJoCo Warp <mjwarp/index> supports native flex collisions.
:ref:mjPLUGIN_LIB_INIT macro now requires a name argument to avoid initialization function name collisions.
When building with MSVC, we now use the C runtime initialization section to initialize plugins instead of
DllMain. See :ref:plugin registration<exRegistration> for more details.
The :ref:mjtWarning enum value mjWARN_VGEOMFULL is removed. Exhaustion of visual geoms is now handled
internally by the :ref:mjvScene.
URDF parsing no longer hardcodes :ref:strippath<compiler-strippath> to "true". The setting is now respected and
the default is "false". Setting this is attribute is now the responsibility of the user.
Migration: Set :ref:strippath<compiler-strippath> to "true" in MJCF or programmatically using
.. code-block:: python
spec = mujoco.MjSpec.from_file("path/to/model.urdf") spec.compiler.strippath = True
Bug fixes ^^^^^^^^^
General ^^^^^^^
.. admonition:: Breaking API changes :class: attention
The tendon Jacobian ten_J is now always sparse. The fields ten_J_rownnz, ten_J_rowadr, and
ten_J_colind have been moved from :ref:mjData to :ref:mjModel and are no longer computed at run time by
mj_tendon but at compile time.
Added :ref:mjs_getCompiler C API function and a compiler read-only property to all Python spec element types.
This allows querying the compiler settings (e.g., meshdir) from any element, with the correct originating spec's
compiler preserved after attachment.
Added a new strain :ref:equality constraint<flexcomp-edge-equality> type for trilinear and quadratic
:ref:dofs<body-flexcomp-dof>.
Flexes now support collisions with SDF geoms.
Improved memory requirements for ten_J and ten_J_colind by reducing the upper bound for the number of
non-zeros nJten.
Improved memory requirements for actuator_moment and moment_colind by reducing the upper bound for the number
of non-zeros nJmom.
MJX ^^^
MJX-Warp batch rendering<MjxWarpBatchRendering> section for
details.Bug fixes ^^^^^^^^^
mjs_attach silently dropped spatial tendons with wrapping geometries that had no
sidesite attribute (:issue:3119, reported by :github:user:tomstewart89).Significant new features ^^^^^^^^^^^^^^^^^^^^^^^^
MuJoCo Warp <mjwarp/index> is now officially released.README <https://github.com/google-deepmind/mujoco/blob/main/python/mujoco/sysid/README.md>__ for details.
|br| A Colab notebook demonstrating the toolbox is available here: |sysid_colab|
|br| Contribution by :github:user:kevinzakka, :github:user:aftersomemath, :github:user:jonathanembleyriches,
:github:user:qiayuanl, :github:user:spjardim and :github:user:gizemozd... |sysid_colab| image:: https://colab.research.google.com/assets/colab-badge.png :target: https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/python/mujoco/sysid/sysid.ipynb
mjData.history variable
to the :ref:Physics state<siPhysicsState>. See :ref:Delays<CDelay> for details... image:: images/changelog/poncho.png :width: 45% :align: right :target: https://github.com/google-deepmind/mujoco/blob/main/model/flex/poncho.xml
flexvert<equality-flexvert> equality constraints that enable cloth simulations with coarser meshes.
This adds a new attribute value vert to flexcomp edge :ref:equality<flexcomp-edge-equality> and the new
equality type :ref:flexvert<equality-flexvert>. Uses the method described in
Chen, Kry and Vouga, 2019 <https://arxiv.org/abs/1911.05204>__.implicit and implicitfast
:ref:integrators<geIntegration>. This method extracts the flex degrees of freedom and solves them as a dense block,
enabling increased stability for stiff flex objects without reducing the timestep. It is compatible with the
trilinear and quadratic :ref:dof<body-flexcomp-dof> types... image:: images/XMLreference/rfcamera.png :width: 45% :align: right :target: https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/sensor/rfcamera.xml
rangefinder/camera<sensor-rangefinder-camera>
attribute. In this case, the sensor respects the :ref:camera/resolution<body-camera-resolution> attribute and casts
multiple rays, one for each pixel.Rangefinders<sensor-rangefinder> can now report various kinds of information besides ray distances,
including surface normals and intersection points... container:: custom-clear
.. raw:: html
<div style="clear: both;"></div>
General ^^^^^^^
.. admonition:: Breaking API changes :class: attention
Ray-cast functions now optionally compute the surface normal at the ray intersection. This is a breaking change
due to the addition of the mjtNum normal[3] argument. The modified functions are :ref:mj_ray,
:ref:mj_multiRay, :ref:mju_rayGeom, :ref:mj_rayFlex, :ref:mj_rayHfield and :ref:mj_rayMesh.
Migration: In C/C++, pass NULL to the normal argument. In Python, in all functions except
:ref:mj_multiRay, it defaults to None, so no action is required.
mju_rayFlex has been renamed to :ref:mj_rayFlex for consistency with other functions that take
mjModel* and mjData* arguments.
The mjModel.cam_orthographic field has been renamed to cam_projection, with the semantic of a new enum
type :ref:mjtProjection. This will allow for more projection types in the future like fisheye cameras.
Relatedly, the camera/orthographic MJCF attribute for cameras has been renamed to
:ref:camera/projection<body-camera-projection> and now accepts the values orthographic and perspective.
Migration: Replace orthographic = "false/true" with projection="perspective/orthographic",
respectively.
Removed getdir from the mjpResourceProvider struct. All Resource Providers now use the same shared
implementation.
When combining the margin or gap :ref:parameters<CContact> of two geoms to obtain the parameters
of a contact, the respective values are now summed rather than taking the maximum. This allows geom
margins to be a proper "inflation" of the geom.
Camera frustum visualization is now triggered by setting :ref:resolution<body-camera-resolution> to values larger
than 1. Relatedly, frustum visualization also works for :ref:orthographic<body-camera-projection> cameras.
See :ref:rangefinder<sensor-rangefinder> for details.
Cameras now have an :ref:output<body-camera-output> attribute, parsed into the mjModel.cam_output bitfield.
Unused by the renderer, it serves as a convenient location to store a camera's supported output types.
Added :ref:mj_mountVFS and :ref:mj_unmountVFS functions for mounting a custom VFS provider. Mounting allows
providers to be used to open/read/close resources dynamically at arbitrary paths.
The optimization whereby sequential :ref:collision sensors<collision-sensors> with identical attributes shared
computation has been removed. This results in a (likely minor) performance regression for models which exploited
this optimization. To recover the performance, use the :ref:fromto<sensor-fromto> and compute the other values
manually. If from = fromto[0:3] and to = fromto[3:6] then distance = norm(to-from) and
normal = normalize(to-from).
:doc:OpenUSD <OpenUSD/index>:
third_party_deps/openusd <https://github.com/google-deepmind/mujoco/tree/main/cmake/third_party_deps/openusd>__
CMake utility project.USD_DIR is no longer used by the MuJoCo CMake project, instead use pxr_DIR if you have a pre-built USD
library.PXR_PLUGINPATH_NAME environment variable, MuJoCo should load USD plugins
automatically.Non-breaking ABI changes:
sig (signature) argument of :ref:mj_stateSize and related functions has been changed from
unsigned int to int. Before this change, invalid negative arguments passed to this function would result
in a silent implicit cast; now, negativity will trigger an error.depth<mjtRndFlag> rendering flag.mjModel now use 64-bit rather than 32-bit integers to accommodate larger scenes.MJX
^^^
19. Added actuator_length, cdof and cdof_dof fields to mjx.Data.
20. Add graph_mode argument to put_model to support multiple Warp graph capture modes.
Documentation
^^^^^^^^^^^^^
21. General improvements to the :ref:Programming/Simulation<Simulation> chapter. Notably, the main discussion of
:ref:state<siStateControl> has been moved there, and the section on :ref:mjModel changes<siChange> has been
expanded.
22. The usability of the :ref:MJCF schema<CSchema> is improved with a collapsible dropdown menu with links to elements
and attributes.
23. MuJoCo version numbering is now based on Semantic Versioning, see
VERSIONING.md <https://github.com/google-deepmind/mujoco/blob/main/VERSIONING.md>__.
Bug fixes
^^^^^^^^^
24. Fixed a bug in :ref:implicit integrator<geIntegrators> derivatives where actuator velocity derivatives were
incorrectly computed when the force was clamped by :ref:forcerange<actuator-general-forcerange>.
25. Fixed a bug in :ref:implicit integrator<geIntegrators> derivatives where actuator velocity derivatives did not
account for the :ref:actearly<actuator-general-actearly> flag.
26. Multi-threaded mesh processing, enabled by the :ref:usethread<compiler-usethread> compiler flag (on by default),
was in fact disabled by the flag. Fixing this bug speeds up compilation of mesh-heavy models by (up to) the number
of available cores.
27. The vertid argument of :ref:mj_rayFlex and :ref:mju_raySkin was marked as nullable but was not; it is now
nullable.
28. Fixed :ref:gravcomp<body-gravcomp> being ignored for bodies with no joints nested inside jointed parent bodies
(:issue:3066, reported by :github:user:Alex108306).
General ^^^^^^^
.. youtube:: aKa3ZlEF9_Y :aspect: 2:1 :align: right :width: 35%
Introduced a major new feature: :ref:sleeping islands<Sleeping>. Preliminary release for early testing, see
documentation for details.
Added "quadratic" option to :ref:flexcomp/dof<body-flexcomp-dof>. This type of fast :ref:deformable<CDeformable>
flex object is similar to the "trilinear" option, but it includes curved deformations.
Raise an error if there are name collisions also during parsing.
Increase Windows stack size to 16MB to enable models with deep nested body hierarchies.
Added a new pipeline component function :ref:mj_fwdKinematics that combines all kinematics-like sub-components.
Relatedly, added a clarifying table at the top of the :ref:Simulation Pipeline<Pipeline> chapter.
Added a new :ref:mj_extractState function that allows a subset of a state that was previously returned by
:ref:mj_getState to be extracted without having to be written back into mjData first.
Added a new :ref:mj_copyState function that copies state components from one mjData to another.
Tendon paths can now be queried from Python via MjsTendon.path, the returned object
is iterable and indexing it will give the MjsWrap at the given index in the path.
MjsWrap now exposes:
type -> mujoco.mjtWraptarget -> MjsSite|MjsJoint|MjsGeom|Nonesidesite -> MjsSite|Nonecoef -> realdivisor -> realNon-breaking ABI changes:
mjtSize is now defined as int64_t rather than uint64_t to avoid future type-promotion bugs.mj_sizeModel now returns an :ref:mjtSize rather than an int.MJX ^^^
warp-lang optional dependency is updated to 1.10.0. pmap now works with MuJoCo Warp from MJX... admonition:: Breaking ABI changes :class: attention
mjx.Model.tex_data is now a numpy ndarray instead of a jax.Array, to avoid vmapping over this potentially
large array. This may break certain use-cases with Madrona MJX, but we are no longer supporting this codepath.
We will be migrating users to a Warp-based batch renderer.Bug fixes ^^^^^^^^^
nvtw.General ^^^^^^^
.. admonition:: Breaking API changes :class: attention
The mjSpec C API fields :ref:meshdir<compiler-meshdir> and :ref:texturedir<compiler-texturedir> have been
moved to compiler.meshdir <https://github.com/google-deepmind/mujoco/blob/0baac589993220095cf09e153f194f35ca0f0738/include/mujoco/mjspec.h#L154>__
and compiler.texturedir <https://github.com/google-deepmind/mujoco/blob/0baac589993220095cf09e153f194f35ca0f0738/include/mujoco/mjspec.h#L155>__
respectively. For backwards compatibility, the old fields are still available in the Python API but will be
removed in a future release.
Migration: Replace meshdir and texturedir with compiler.meshdir and compiler.texturedir.
Remove _full_compat from mjx.put_data and mjx.put_model.
nconmax and njmax fields in mjx.make_data now default to None instead of -1. nconmax will be deprecated
in favor of naconmax in a future release.
Joint decorators and spatial tendons which have limits defined and whose current value (angle or length) exceeds the
limit, are recolored by using the :ref:constraint impedance<soParameters> :math:d to mix the existing color with
:ref:visual/rgba/constraint<visual-rgba-constraint>. For spatial tendons, this visualization aid is active only if
no :ref:material<tendon-spatial-material> is set and :ref:rgba<tendon-spatial-rgba> is default.
Added :ref:mju_getXMLDependencies for computing a list of unique asset dependencies from an MJCF file.
Added the code sample dependencies which provides command line utility for printing the result of :ref:mju_getXMLDependencies.
The minimum C++ standard required to compile MuJoCo is now C++20, this has been the case within Google since 2023 but the CMake update was forgotten.
.. admonition:: Breaking ABI changes :class: attention
mjOption.apirate was unused and has been removed.nconmax and njmax fields in mjx.make_data now default to None instead of -1.MJX
^^^
9. Fix :issue:2508, qLD shapes mismatched mjModel during get_data_into.
10. Pull in MuJoCo Warp update to io.py, and use naconmax instead of nconmax to set the maximum number
of contacts over all environments.
Bug fixes
^^^^^^^^^
11. Fix :issue:2881, :at:fitaabb was adding an offset to the mesh and applying an incorrect frame
transformation. Also, unify the meaning of fitting a geom to a mesh AABB: it now means to find the smallest geom
such that its AABB contains the mesh AABB.
General ^^^^^^^
documented<soIsland>
and promoted to default; disable it with :ref:option/flag/island <option-flag-island>. We expect islanding to be
a strict improvement over the monolithic constraint solver, please let us know if you experience any issues.Contact sensor<sensor-contact> :at-val:subtree1/subtree2 specification is now available for any body, not
just direct children of the world... admonition:: Breaking API changes :class: attention
The update of mjData.qacc_warmstart was moved from the end of the solver call (:ref:mj_fwdConstraint) to
the end of :ref:mj_step, and is now updated with all other state variables. This change makes :ref:mj_forward
fully idempotent.
Before this change, calling :ref:mj_forward repeatedly would make the constraint solver converge,
since each subsequent call would start from the previously updated qacc_warmstart value.
Indeed, this is precisely what happened in the viewer, which calls :ref:mj_forward repeatedly in PAUSE mode.
Migration: If your code depended on this behavior, you can recover it by updating manually after each
:ref:mj_forward: qacc_warmstart ← qacc. The behavior is available in :ref:simulate<saSimulate> by
clicking the "Pause update" toggle (off by default).
Furthermore, this change has a numerical impact on the output of the :ref:RK4 <geIntegrators> integrator.
Before this change, due to the qacc_warmstart update occurring after each of the four Runge-Kutta substeps,
the solver convergence of RK4 was faster, at the cost of unprincipled integration. This change makes the RK4
integration principled and well-defined. Since this change to RK4 is effectively a bug fix, migration to the
previous behavior is not provided.
The mjDSBL_PASSIVE flag for disabling passive forces was removed and replaced by
:ref:mjDSBL_SPRING<mjtDisableBit> and :ref:mjDSBL_DAMPER<mjtDisableBit> with corresponding
:ref:mjcf<option-flag-spring> :ref:attributes<option-flag-damper>. Each flag disables only joint and tendon
springs or dampers, respectively. When both flags are set, all passive forces are disabled, including gravity
compensation, fluid forces, forces computed by the :ref:mjcb_passive callback, and forces computed by
:ref:plugins <exPlugin> when passed the :ref:mjPLUGIN_PASSIVE<mjtPluginCapabilityBit> capability flag.
Migration: Set both flags to recover the behavior of the previous flag.
.. admonition:: Breaking ABI changes :class: attention
Removed mjMOUSE_SELECT flag for :ref:mjtMouse as it is no longer in use.
The promotion of islanding to default involved removing the enable flag mjENBL_ISLAND and
converting it to a disable flag :ref:mjDSBL_ISLAND <mjtDisableBit>.
Added support for shells with a curved reference configuration. See this example <https://github.com/google-deepmind/mujoco/blob/main/model/flex/basket.xml>__.
Added experimental option for :ref:passive<flex-contact-passive> contacts involving flexes.
Added support for assigning a default material to a mesh asset using the :ref:mesh/material <asset-mesh-material>
attribute.
MJX
^^^
10. Promote ten_length to the public MJX API. Add Warp support for mjx.tendon.
.. admonition:: Breaking API changes :class: attention
ten_length was moved from mjx.Data._impl.ten_length to a public field mjx.Data.ten_length.Bug fixes ^^^^^^^^^ 12. Fixed a latent bug where MjData objects were not serialized correctly by the Python bindings when islanding was enabled.
General ^^^^^^^
insidesite<sensor-insidesite> sensor, for checking if an object is inside the volume of a site.
It is useful for triggering events in surrounding environment logic.contact<sensor-contact> sensor, for reporting contact information according to user-defined
criteria.
The purpose of the :el:contact sensor is to report contact-related information in a fixed-size array. This is
useful as input to learning-based agents and in environment logic.tactile<sensor-tactile> sensor, for measuring the penetration depth between two objects at given
points and the sliding velocities in the tangent frame. The sensor reports tactile data only when colliding with
SDFs.SdfLib <https://github.com/UPC-ViRVIG/SdfLib>__. SDFs are now
supported natively in mjModel.oct_depth from :ref:mjvOption (unused).mesh/builtin<asset-mesh-builtin>.pipeline<piStages> function :ref:mj_makeM, which
combines the Composite Rigid Body algorithm in :ref:mj_crb and additional terms related to
:ref:tendon armature<tendon-spatial-armature>. Code that uses :ref:mj_crb to compute the inertia should now use
:ref:mj_makeM instead... admonition:: Breaking API changes :class: attention
mjVIS_FLEXBVH enum value, its functionality is now provided by :ref:mjVIS_MESHBVH<mjtVisFlag>.Bug fixes
^^^^^^^^^
9. Fixed a bug that caused object lists in the child to have missing elements after attaching an mjSpec. This was
caused by adding to the lists only the objects that belong to the tree of the requested body, but this causes to
skip objects that were attached, since they belong to the tree of the parent.
10. Fixed a bug where the convex hull of a collision mesh was not being computed if the mesh could only collide via a
:ref:contact pair<contact-pair>.
Python
^^^^^^
11. On Linux, built distribution packages (wheels) now target the manylinux_2_28 platform tag. Previously MuJoCo
wheels targeted manylinux2014 based on CentOS 7, which reached end-of-life in June 2024.
MJX
^^^
12. Add Warp as a backend implementation for MJX. The implementation can be specified via
mjx.put_model(m, impl='warp') and mjx.make_data(m, impl='warp'). The warp implementation requires
a CUDA device and warp-lang to be installed (pip install mujoco-mjx[warp]). This feature is available in
"beta" and some bugs are expected.
.. admonition:: Breaking API changes :class: attention
mjs_detachBody and mjs_detachDefault have been replaced by :ref:mjs_delete.element.delete have been replaced by spec.delete(element).mjs_setString has been replaced with a new
function :ref:mjs_setName which allows checking for naming collisions at set-time rather than compile-time, for
earlier catching of errors. Relatedly, the name attribute has been removed from all mjs elements. Known issue:
the error is not raised during parsing.mjx.Option dataclass now has private and public fields similar to mjx.Model and
mjx.Data. Some fields are no longer publicly available due to differences in the
underlying implementations of this data structure.General
^^^^^^^
4. Added support for setting the initial camera in the viewer using
:ref:visual/global/cameraid<visual-global-cameraid>.
5. Added support to only sync the state in the Python :ref:passive viewer<PyViewerPassive>'s Sync method, this is
useful to improve performance. The default behavior is unchanged and copies the entire model and data.
Bug fixes
^^^^^^^^^
6. Inverse dynamics were not being computed correctly when :ref:tendon armature<tendon-spatial-armature> was present,
now fixed.
7. Fix bug in mjx.put_data where actuator_moment was not being copied correctly for the C implementation.
Documentation ^^^^^^^^^^^^^ 8. Added missing item documentation and clarified the nature of breaking changes in the 3.3.3 changelog. See items 3 and 4 below.
General ^^^^^^^
shell plugin. This is now supported by :ref:flexcomp<body-flexcomp> and is active depending on
the :ref:elastic2d<flexcomp-elasticity-elastic2d> attribute (off by default)... admonition:: Breaking API changes :class: attention
Replaced the :ref:directional<body-light-directional> (boolean) field for lights with a
:ref:type<body-light-type> field (of type :ref:mjtLightType<mjtLightType>) to allow for additional lighting
types.
Migration: Replace light/directional="false/true" with light/type="spot/directional", respectively.
Added :ref:mjtColorSpace enum and associated :ref:colorspace<asset-texture-colorspace> attribute that allows
to specify the color space of textures (either linear or sRGB <https://en.wikipedia.org/wiki/SRGB>__). Since
this property is now read correctly from PNG files, textures files which use sRGB will now be rendered
differently.
Migration: Set :ref:colorspace<asset-texture-colorspace> to "linear" for all textures that should look like
they did before this change.
Added new sub-component :ref:mj_makeM which combines the :ref:mj_crb call with additional logic to support the
introduction in 3.3.1 of :ref:tendon armature<tendon-spatial-armature>. In addition to the traditional
mjData.qM, :ref:mj_makeM also computes mjData.M, a CSR representation of the same matrix.
Added a new function :ref:mj_copyBack to copy real-valued arrays in an mjModel to a compatible mjSpec.
Removed the limitation of :ref:fusestatic<compiler-fusestatic> to models which contain no references. The
fusestatic flag will now fuse all bodies which are not referenced and ignore bodies which are referenced.
Simulate
^^^^^^^^
8. The struct mjv_sceneState has been removed. This struct was used for partial synchronization of mjModel and
mjData when the Python viewer is used in passive mode. This functionality is now provided by
:ref:mjv_copyModel and :ref:mjv_copyData, which don't copy arrays which are not required for visualization.
.. image:: images/changelog/procedural_terrain_generation.png :width: 33% :align: right
Python bindings ^^^^^^^^^^^^^^^
MJX ^^^ 10. Added tendon armature.
MJX ^^^
2606 such that make_data copies over mocap_pos and mocap_quat
from body_pos and body_quat... admonition:: Breaking API changes :class: attention
internal flex contacts<flex-contact-internal> was changed from
"true" to "false". This feature has proven to be counterintuitive for users.mjs_attachBody, mjs_attachFrame, mjs_attachToSite,
mjs_attachFrameToSite) have been removed and replaced by a single function :ref:mjs_attach.General
^^^^^^^
3. Added :ref:tendon armature<tendon-spatial-armature>: inertia associated with changes in tendon length.
4. Added the :ref:compiler/saveinertial<compiler-saveinertial> flag, writing explicit inertial clauses for all
bodies when saving to XML.
5. Added :ref:orientation<body-composite-quat> attribute to :ref:composite<body-composite>. Moreover, allow the
composite to be the direct child of a frame.
6. Added :ref:tendon actuator force limits<tendon-spatial-actuatorfrclimited> and
:ref:tendon actuator force sensor<sensor-tendonactuatorfrc>.
MJX ^^^ 7. Added tendon actuator force limits.
Bug fixes
^^^^^^^^^
8. :ref:mj_jacDot was missing a term that accounts for the motion of the point with respect to
which the Jacobian is computed, now fixed.
9. Fixed a bug that caused the parent frame of elements in the child worldbody to be incorrectly set when attaching an
mjSpec to a frame or a site.
10. Fixed a bug that caused shadow rendering to flicker on platforms (e.g., MacOS) that do not support
ARB_clip_control. Fixed in collaboration with :github:user:aftersomemath.
Python bindings ^^^^^^^^^^^^^^^
.. youtube:: LbANnKMDOHg :aspect: 16:7 :align: right :width: 240px
mjSpec objects in the bind method, see the corresponding
:ref:section<PyMJCF> in the documentation... |mjspec_colab| image:: https://colab.research.google.com/assets/colab-badge.png :target: https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/python/mjspec.ipynb
Feature promotion ^^^^^^^^^^^^^^^^^ .. youtube:: qJFbx-FR7Bc :aspect: 16:7 :align: right :width: 240px
flexcomp/dof<body-flexcomp-dof> to
"trilinear". This type of :ref:deformable<CDeformable> flex object has the same collision geometry as a regular
flex, but has far fewer degrees of freedom. Instead of 3 dofs per vertex, only the corners of the bounding box are
free to move, with the positions of the interior vertices computed with trilinear interpolation of the 8 corners, for
a total of 24 dofs for the entire flex object (or less, if some of the corners are pinned). This limits the types of
deformation achievable by the flex, but allows for much faster simulation. For example, see the video on the right
comparing full <https://github.com/google-deepmind/mujoco/blob/main/model/flex/gripper.xml>__ and trilinear <https://github.com/google-deepmind/mujoco/blob/main/model/flex/gripper_trilinear.xml>__ flexes for modeling
deformable gripper pads... image:: images/computation/ccd_light.gif :width: 20% :align: right :class: only-light
.. image:: images/computation/ccd_dark.gif :width: 20% :align: right :class: only-dark
The native convex collision detection pipeline introduced in 3.2.3 and enabled by the
:ref:nativeccd<option-flag-nativeccd> flag, is now the default. See the section on
:ref:Convex Collision Detection<coCCD> for more details.
Migration: If the new pipeline breaks your workflow, set :ref:nativeccd<option-flag-nativeccd> to "disable".
General
^^^^^^^
3. Add support for custom plots in the MuJoCo viewer by exposing a viewport property, a set_figures method,
and a clear_figures method.
4. Separate collision and deformation meshes for :ref:flex<deformable-flex>. This enables a fixed cost for the soft
body computations, while preserving the fidelity of high-resolution collisions.
5. Added :ref:potential<sensor-e_potential> and :ref:kinetic<sensor-e_kinetic> energy sensors.
6. Improved shadow rendering in the native renderer.
7. Moved introspect to python/introspect.
.. admonition:: Breaking API changes :class: attention
As mentioned above, the native convex collision detection pipeline is now the default, which may break some
workflows. In this case, set :ref:nativeccd<option-flag-nativeccd> to "disable" to restore the old behavior.
Added :ref:mjs_setDeepCopy API function. When the deep copy flag is 0, attaching a model will not copy it to the
parent, so the original references to the child can be used to modify the parent after attachment. The default
behavior is to perform such a shallow copy. The old behavior of creating a deep copy of the child model while
attaching can be restored by setting the deep copy flag to 1.
Changes to inertia inference from meshes:
Previously, in order to specify that the mass lies on the surface, :ref:geom/shellinertia<body-geom-shellinertia>
could be used for any geom type. Now this attribute is ignored if the geom is a mesh; instead, inertia inference
for meshes is specified in the asset, using the :ref:asset/mesh/inertia<asset-mesh-inertia> attribute.
Previously, if the volumetric inertia computation failed (for example due to a very flat mesh), the compiler would silently fall back to surface inertia computation. Now, the compiler will throw an informative error.
Removed the composite type grid. Users should instead use :ref:flexcomp<body-flexcomp>.
Removed the particle composite type. It is recommended to use the more generic :ref:replicate<replicate>
instead, see for example this model <https://github.com/google-deepmind/mujoco/blob/main/model/replicate/particle.xml>__.
MJX
^^^
13. Added support for spatial tendons with internal sphere and cylinder wrapping.
14. Fix a bug with box-box collisions :issue:2356.
Python bindings ^^^^^^^^^^^^^^^
mujoco.rollout, a Python module for multithreaded simulation rollouts.
It is available here |rollout_colab|.
|br| Contribution by :github:user:aftersomemath... |rollout_colab| image:: https://colab.research.google.com/assets/colab-badge.png :target: https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/python/rollout.ipynb
Python bindings ^^^^^^^^^^^^^^^
rollout<PyRollout> now features native multi-threading. If a sequence of MjData instances
of length nthread is passed in, rollout will automatically create a thread pool and parallelize
the computation. The thread pool can be reused across calls, but then the function cannot be called simultaneously
from multiple threads. To run multiple threaded rollouts simultaneously, use the new class Rollout which
encapsulates the thread pool. Contribution by :github:user:aftersomemath.mjpython (:issue:2265).General ^^^^^^^
.. admonition:: Breaking API changes (minor) :class: attention
The field mjData.qLDiagSqrtInv has been removed. This field is only required for the dual solvers. It is now
computed as-needed rather than unconditionally. Relatedly, added the corresponding argument to :ref:mj_solveM2.
Reduced the memory footprint of the PGS solver's :ref:A matrix<soDual>. This was the last remaining dense-memory
allocation in MuJoCo, allowing for a significant reduction of the :ref:dynamic memory allocation heuristic<CSize>.
Bug fixes
^^^^^^^^^
5. Fixed a bug in the box-sphere collider, depth was incorrect for deep penetrations (:issue:2206).
6. Fixed a bug in :ref:mj_mulM2 and added a test.
General ^^^^^^^
composite<body-composite>. The user is encouraged to instead use the :at:cable
plugin or :ref:flexcomp<body-flexcomp>, respectively.MJX ^^^ 2. Added muscle actuators.
Python bindings
^^^^^^^^^^^^^^^
3. Provide prebuilt wheels for Python 3.13.
4. Added bind method and removed id attribute from :ref:mjSpec objects. Using ids is error prone in scenarios of
repeated attachment and detachment. Python users are encouraged to use names for unique identification of model
elements.
5. :ref:rollout<PyRollout> can now accept sequences of MjModel of length nroll. Also removed the nroll
argument because its value can always be inferred.
Bug fixes
^^^^^^^^^
6. Fixed :issue:2212, type error in mjx.get_data.
7. Fixed bug introduced in 3.2.0 in handling of :ref:texrepeat<asset-material-texrepeat> attribute, was mistakenly
cast from float to int, (fixed :issue:2223).
Feature promotion ^^^^^^^^^^^^^^^^^
Model Editing<programming/modeledit> framework afforded by :ref:mjSpec, introduced in 3.2.0 as an
in-development feature, is now stable and recommended for general use.nativeccd<option-flag-nativeccd> flag, is not yet the default but is already recommended for general use.
Please try it when encountering collision-related problems and report any issues you encounter.General ^^^^^^^
exactmeshinertia has been removed and replaced with the mesh-specific
:ref:inertia<asset-mesh-inertia> attribute.convexhull compiler option (to disable computation of mesh convex hulls) has been removed.mju_rotVecMat, mju_rotVecMatT and mjv_makeConnector functions.1638).layer<material-layer> sub-element.flexcomp<body-flexcomp>.MJX
^^^
9. Added apply_ft, jac, and xfrc_accumulate as public functions.
10. Added TOUCH sensor.
11. Added support for eq_active. Fixes :issue:2173.
12. Added ray intersection with ellipsoid.
Bug fixes
^^^^^^^^^
13. Fixed several bugs related to connect and weld constraints with site semantics (fixes :issue:2179, reported
by :github:user:yinfanyi). The introduction of site specification to connects and welds in 3.2.3 conditionally
changed the semantics of mjData.eq_obj1id and mjData.eq_obj2id, but these changes were not properly propagated
in several places leading to incorrect computations of constraint inertia, readings of affected force/torque sensors
and runtime enabling/disabling of such constraints.
14. Fixed a bug in slider-crank :ref:transmission<geTransmission>. The bug was introduced in 3.0.0.
15. Fixed a bug in flex texture coordinates that prevented the correct allocation of textures in mjModel.
Documentation
^^^^^^^^^^^^^
16. Function headers in the :doc:API reference <../APIreference/APIfunctions> now link to their source definitions
in GitHub.
General ^^^^^^^
.. youtube:: e8lUuykQPGs :aspect: 16:7 :align: right :width: 240px
nv*nv memory allocation, allowing for much larger models. See e.g.,
100_humanoids.xml <https://github.com/google-deepmind/mujoco/blob/main/model/humanoid/100_humanoids.xml>__.
Two quadratic-memory allocations still remain to be fully sparsified: mjData.actuator_moment and the matrices
used by the PGS solver.solid and :at:membrane plugins and moved the associated computations into the engine. See 3D example model <https://github.com/google-deepmind/mujoco/blob/main/model/flex/floppy.xml>__ and 2D example model <https://github.com/google-deepmind/mujoco/blob/main/model/flex/trampoline.xml>__ for examples of flex objects
that previously required these plugins.mjs_setActivePlugins with :ref:mjs_activatePlugin.MJX
^^^
4. Added mocap_pos and mocap_quat in kinematics.
5. Added support for :ref:spatial tendons <tendon-spatial> with pulleys and external sphere and cylinder wrapping.
6. Added sphere-cylinder and sphere-ellipsoid collision functions (:issue:2126).
7. Fixed a bug with frictionloss constraints.
8. Added TENDONPOS and TENDONVEL sensors.
9. Fixed a bug with the computation of tangential contact forces in _decode_pyramid.
10. Added JOINTINPARENT actuator transmission type.
Python bindings
^^^^^^^^^^^^^^^
11. Removed support for Python 3.8, now that it's deprecated upstream <https://devguide.python.org/versions>__.
Bug fixes
^^^^^^^^^
12. Fixed a bug where actuator_force was not set in MJX (:issue:2068).
13. Fixed bug where MJX data tendon fields were incorrect after calling mjx.put_data.
14. The compiler now returns an error if height fields are used with :ref:collision sensors<collision-sensors> as they
are not yet supported.
General ^^^^^^^
.. admonition:: Breaking API changes :class: attention
The runtime options mpr_tolerance and mpr_iterations were renamed to
:ref:ccd_tolerance<option-ccd_tolerance> and :ref:ccd_iterations<option-ccd_iterations>, both in XML and in
the :ref:mjOption struct. This is because the new convex collision detection pipeline (see below) does not use
the MPR algorithm. The semantics of these options remain identical.
The functions mjs_findMesh and mjs_findKeyframe were replaced by mjs_findElement, which allows to look
for any object type.
The experimental use of 2D/3D elasticity plugins with :ref:composite<body-composite> has been removed. Users
should instead use :ref:flexcomp<body-flexcomp>, which provides the correct collision behavior.
Added the :ref:nativeccd<option-flag-nativeccd> flag. When this flag is enabled, general convex collision
detection is handled with a new native code path, rather than libccd <https://github.com/danfis/libccd>__.
This feature is in early stages of testing, but users who've experienced issues related to collision detection are
welcome to experiment with it and report any issues.
.. youtube:: kcM_oauk3ZA :aspect: 16:7 :align: right :width: 240px
Added a new way of defining :ref:connect<equality-connect> and :ref:weld<equality-weld> equality constraints,
using two sites. The new semantic is useful when the assumption that the constraint is satisfied
in the base configuration does not hold. In this case the sites will "snap together" at the beginning of the
simulation. Additionally, changing the site positions (mjModel.site_pos) and orientations
( mjModel.site_quat) at runtime will correctly modify the constraint definition. This
example model <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/equality_site.xml>__ using
the new semantic is shown in the video on the right.
Introduced free joint alignment, an optimization that applies to bodies with a free joint and no child bodies
(simple free-floating bodies): automatically aligning the body frame with the inertial frame. This feature can be
toggled individually using the :ref:freejoint/align<body-freejoint-align> attribute or globally using the compiler
:ref:alignfree<compiler-alignfree> attribute. The alignment diagonalizes the related 6x6 inertia sub-matrix,
leading to both faster and more stable simulation of free bodies.
While this optimization is a strict improvement, it changes the semantics of the joint's degrees-of-freedom.
Therefore, qpos and qvel values saved in older versions (for example, in :ref:keyframes<keyframe>) will
become invalid. The global compiler attribute currently defaults to "false" due to this potential breakage, but could
be changed to "true" in a future release. Aligned free joints are recommended for all new models.
Added an :ref:mjSpec option for creating a texture directly from a buffer.
:ref:shell (surface) inertia <body-geom-shellinertia> is now supported by all geom types.
When :ref:attaching<meAttachment> sub-models, :ref:keyframes<keyframe> will now be correctly merged into the
parent model, but only on the first attachment.
Added the :ref:mjtSameFrame enum which contains the possible frame alignments of bodies and their children. These
alignments are used for computation shortcuts in :ref:mj_kinematics.
Added :ref:mj_jacDot for computing time-derivatives of kinematic Jacobians. Fixes :issue:411.
MJX
^^^
12. Added efc_pos to mjx.Data (:issue:1388).
13. Added position-dependent sensors: MAGNETOMETER, CAMPROJECTION, RANGEFINDER, JOINTPOS,
ACTUATORPOS, BALLQUAT, FRAMEPOS, FRAMEXAXIS, FRAMEYAXIS, FRAMEZAXIS, FRAMEQUAT,
SUBTREECOM, CLOCK.
14. Added velocity-dependent sensors: VELOCIMETER, GYRO, JOINTVEL, ACTUATORVEL, BALLANGVEL,
FRAMELINVEL, FRAMEANGVEL, SUBTREELINVEL, SUBTREEANGMOM.
15. Added acceleration/force-dependent sensors: ACCELEROMETER, FORCE, TORQUE, ACTUATORFRC,
JOINTACTFRC, FRAMELINACC, FRAMEANGACC.
16. Changed default policy to avoid placing unused (MuJoCo-only) arrays on device.
17. Added device parameter to mjx.make_data to bring it to parity with mjx.put_model and mjx.put_data.
18. Added support for :ref:implicitfast integration<geIntegration> for all cases except
:doc:fluid drag <computation/fluid>.
19. Fixed a bug where qLDiagInv had the wrong size for sparse mass matrices.
20. Added support for joint and tendon :ref:frictionloss <coFriction>.
21. Added support for :ref:connect<equality-connect> equality constraints using two sites.
22. Added support for :ref:spatial tendons <tendon-spatial> with site wrapping.
Bug fixes
^^^^^^^^^
23. Fixed a performance regression introduced in 3.1.7 in mesh Bounding Volume Hierarchies (:issue:1875,
contribution by :github:user:michael-ahn).
24. Fixed a bug wherein, for models that have both muscles and stateless actuators and used one of the implicit
integrators, wrong derivatives would be computed.
25. Fixed a bug in tendon wrapping around spheres. Before this fix, tendons that wrapped around spheres with an
externally-placed :ref:sidesite<spatial-geom-sidesite> could jump inside the sphere instead of wrapping around it.
26. Fixed a bug that caused :at:meshdir and :at:texturedir to be overwritten during model
:ref:attachment<meAttachment>, preventing model attachment for models with assets in different directories.
Python bindings
^^^^^^^^^^^^^^^
27. Added support for engine plugins in :ref:mjSpec (:issue:1903).
28. Better error reporting for issues with the assets dictionary, when loading models.
General ^^^^^^^
1877).General ^^^^^^^
mjModel.tex_rgb to mjModel.tex_data.autoreset<option-flag-autoreset> flag to disable automatic reset when NaNs or infinities are
detected.material<asset-material> element, to allow specification of multiple textures
for rendering (e.g., occlusion, roughness, metallic). Note that the MuJoCo renderer doesn't
support these new features, and they are made available for use with external renderers.mjQUICKSORT) now calls std::sort when building with C++ (:issue:1638).MJX
^^^
5. Added more fields to mjx.Model and mjx.Data for further compatibility with the corresponding MuJoCo structs.
6. Added support for :ref:fixed tendons <tendon-fixed>.
7. Added support for tendon length limits (mjCNSTR_LIMIT_TENDON in :ref:mjtConstraint).
8. Added support for tendon equality constraints (mjEQ_TENDON in :ref:mjtEq).
9. Added support for tendon actuator transmission (mjTRN_TENDON in :ref:mjtTrn).
Python bindings
^^^^^^^^^^^^^^^
10. Added support for asset dictionary argument in mujoco.spec.from_file, mujoco.spec.from_string and
mujoco.spec.compile.
Bug fixes
^^^^^^^^^
11. Fixed a bug where implicit integrators did not take into account disabled actuators (:issue:1838).
New features ^^^^^^^^^^^^
mjSpec. See the :doc:Model Editing<programming/modeledit> chapter for details.
Note that as of this release this feature is still in testing and subject to future breaking changes.
Fixes :issue:364.General ^^^^^^^
.. admonition:: Breaking API changes :class: attention
Removed deprecated mj_makeEmptyFileVFS and mj_findFileVFS functions. The constants mjMAXVFS and
mjMAXVFSNAME are also removed as they are no longer needed.
Migration: Use :ref:mj_addBufferVFS to copy a buffer into a VFS file directly.
Calls to :ref:mj_defaultVFS may allocate memory inside VFS, and the corresponding
:ref:mj_deleteVFS must be called to deallocate any internal allocated memory.
Deprecated mju_rotVecMat and mju_rotVecMatT in favor of :ref:mju_mulMatVec3 and
:ref:mju_mulMatTVec3. These function names and argument order are more consistent with the rest of the API.
The older functions have been removed from the Python bindings and will be removed from the C API in the next
release.
Removed the actuator_actdim callback from actuator plugins. They now have the actdim attribute, which
must be used with actuators that write state to the act array. This fixed a crash which happened when
keyframes were used in a model with stateful actuator plugins. The PID plugin will give an error when the wrong
value of actdim is provided.
Added :ref:attach<body-attach> meta-element to MJCF, which allows :ref:attaching<meAttachment> a subtree from a
different model to a body in the current model.
The :ref:VFS<Virtualfilesystem> implementation has been rewritten in C++ and is now considerably more efficient in
speed and memory footprint.
.. youtube:: ZXBTEIDWHhs :aspect: 16:7 :align: right :width: 240px
Added support for orthographic cameras. This is available for both fixed cameras and the free camera, using the
camera/orthographic and :ref:global/orthographic<visual-global-orthographic>
attributes, respectively.
Added :ref:maxhullvert<asset-mesh-maxhullvert>, the maximum number of vertices in a mesh's convex hull.
Added :ref:mj_setKeyframe for saving the current state into a model keyframe.
Added support for ball joints in the URDF parser ("spherical" in URDF).
Replaced mjUSEDOUBLE which was previously hard-coded in
mjtnum.h <https://github.com/google-deepmind/mujoco/blob/main/include/mujoco/mjtnum.h>__
with the build-time flag mjUSESINGLE. If this symbol is not defined, MuJoCo will use double-precision floating
point, as usual. If mjUSESINGLE is defined, MuJoCo will use single-precision floating point. See :ref:mjtNum.
Relatedly, fixed various type errors that prevented building with single-precision.
Quaternions in mjData.qpos and mjData.mocap_quat are no longer normalized in-place by
:ref:mj_kinematics. Instead they are normalized when they are used. After the first step, quaternions in
mjData.qpos will be normalized.
Mesh loading in the compiler, which is usually the slowest part of the loading process, is now multi-threaded.
MJX
15. Added support for :ref:`elliptic friction cones<option-cone>`.
16. Fixed a bug that resulted in less-optimal linesearch solutions for some difficult constraint settings.
17. Fixed a bug in the Newton solver that sometimes resulted in less-optimal gradients.
.. youtube:: P83tKA1iz2Y
:align: right
:width: 360px
Simulate
^^^^^^^^
18. Added improved tutorial video.
19. Improved the Brownian noise generator.
20. Now displaying model load times if they are longer than 0.25 seconds.
Python bindings
^^^^^^^^^^^^^^^
21. Fixed a memory leak when using ``copy.deepcopy()`` on a ``mujoco.MjData`` instance (:issue:`1572`).
Bug fixes
^^^^^^^^^
22. Fix an issue where ``mj_copyData`` (or ``copy.copy()`` in the Python bindings) was not copying contact information
correctly (:issue:`1710`).
23. Fix an issue with saving to XML that caused frames to be written multiple times (:issue:`1802`).
Version 3.1.6 (Jun 3, 2024)
---------------------------
General
^^^^^^^
1. Added :ref:`mj_geomDistance` for computing the shortest signed distance between two geoms and optionally a segment
connecting them. Relatedly, added the 3 sensors: :ref:`distance<sensor-distance>`, :ref:`normal<sensor-normal>`,
:ref:`fromto<sensor-fromto>`. See the function and sensor documentation for details. Fixes :issue:`51`.
2. Improvements to position actuators:
- Added :ref:`timeconst<actuator-position-timeconst>` attribute to the :ref:`position actuator<actuator-position>`.
When set to a positive value, the actuator is made stateful with :at:`filterexact` dynamics.
- Added :ref:`dampratio<actuator-position-dampratio>` to both :el:`position` and :el:`intvelocity` actuators. An
alternative to the :at:`kv` attribute, it provides a convenient way to set actuator damping using natural units.
See attribute documentation for details.
MJX
^^^
3. Add height-field collision support. Fixes :issue:`1491`.
4. Add a pre-compiled field ``mesh_convex`` to ``mjx.Model`` so that mesh properties can be vmapped over.
Fixes :issue:`1655`.
5. Fix a bug in convex mesh collisions, where erroneous edge contacts were being created even though face
separating axes were found. Fixes :issue:`1695`.
Bug fixes
^^^^^^^^^
6. Fixed a bug the could cause collisions to be missed when :ref:`fusestatic<compiler-fusestatic>` is enabled, as is
often the case for URDF imports. Fixes :issue:`1069`, :issue:`1577`.
7. Fixed a bug that was causing the visualization of SDF iterations to write outside the size of the vector storing
them. Fixes :issue:`1539`.
Version 3.1.5 (May 7, 2024)
---------------------------
General
^^^^^^^
.. youtube:: 5k0_wsIRAFc
:aspect: 16:7
:align: right
:width: 240px
1. Added the :ref:`replicate<replicate>` to MJCF, a :ref:`meta-element<meta-element>` which permits to repeat a subtree
with incremental translational and rotational offsets.
2. Enabled an internal cache in the MuJoCo compiler resulting in recompilation speedup. Currently, processed
textures, hfields, and OBJ meshes are cached. Support for Unity environments is not yet available.
3. Added ``mjModel.mesh_scale``: the scaling applied to asset vertices, as specified in the
:ref:`scale<asset-mesh-scale>` attribute.
4. Added visual properties which are ignored by the native renderer, but can be used by external renderers:
- :ref:`light/bulbradius<body-light-bulbradius>` attribute and corresponding ``mjModel.light_bulbradius`` field.
- :ref:`material/metallic<asset-material-metallic>` attribute and corresponding ``mjModel.material_metallic`` field.
- :ref:`material/roughness<asset-material-roughness>` attribute and corresponding ``mjModel.material_roughness``
field.
5. The type of the ``size`` argument of :ref:`mj_stackAllocNum` and :ref:`mj_stackAllocInt` was changed from ``int``
to ``size_t``.
6. Added support for gmsh format version 2.2 surface meshes in :ref:`flexcomp<body-flexcomp-file>`.
MJX
^^^
.. admonition:: Breaking API changes
:class: attention
7. Removed deprecated ``mjx.device_get_into`` and ``mjx.device_put`` functions as they lack critical new
functionality.
**Migration:** Use ``mjx.get_data_into`` instead of ``mjx.device_get_into``, and ``mjx.put_data`` instead of
``mjx.device_put``.
8. Added cylinder plane collisions.
9. Added ``efc_type`` to ``mjx.Data`` and ``dim``, ``efc_address`` to ``mjx.Contact``.
10. Added ``geom`` to ``mjx.Contact`` and marked ``geom1``, ``geom2`` deprecated.
11. Added ``ne``, ``nf``, ``nl``, ``nefc``, and ``ncon`` to ``mjx.Data`` to match ``mujoco.MjData``.
12. Given the above added fields, removed ``mjx.get_params``, ``mjx.ncon``, and ``mjx.count_constraints``.
13. Changed the way meshes are organized on device to speed up collision detection when a mesh is replicated for many
geoms.
14. Fixed a bug where capsules might be ignored in broadphase colliision checking.
15. Added cylinder collisions using SDFs.
16. Added support for all :ref:`condim <coContact>`: 1, 3, 4, 6.
17. Add support functions for ``id2name`` and ``name2id``, MJX versions of :ref:`mj_id2name` and :ref:`mj_name2id`.
18. Added support for :ref:`gravcomp<body-gravcomp>` and :ref:`actuatorgravcomp<body-joint-actuatorgravcomp>`.
19. Fixed a bug in ``mjx.ray`` for sometimes allowed negative distances for ray-mesh tests.
20. Added a new `differentiable physics tutorial <https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/mjx/training_apg.ipynb>`__ that demonstrates training locomotion policies with analytical gradients
automatically derived from the MJX physics step. Contribution by :github:user:`Andrew-Luo1`.
Bug fixes
^^^^^^^^^
21. Defaults of lights were not being saved, now fixed.
22. Prevent overwriting of frame names by body names when saving an XML. Bug introduced in 3.1.4.
23. Fixed bug in Python binding of :ref:`mj_saveModel`: ``buffer`` argument was documented as optional but was actually
not optional.
24. Fixed bug that prevented memory allocations larger than 2.15 GB. Fixes :issue:`1606`.
Version 3.1.4 (April 10th, 2024)
--------------------------------
General
^^^^^^^
.. admonition:: Breaking API changes
:class: attention
1. Removed the ability to natively add noise to sensors. Note that the ``mjModel.sensor_noise`` field and
:ref:`corresponding attribute<CSensor>` are kept and now function as a convenient location for the user to save
standard-deviation information for their own use. This feature was removed because:
- There was no mechanism to seed the random noise generator.
- It was not thread-safe, even if seeding would have been provided, sampling on multiple threads would lead to
non-reproducible results.
- This feature was seen as overreach by the engine. Adding noise should be the user's responsibility.
- We are not aware of anyone who was actually using the feature.
**Migration:** Add noise to sensor values yourself.
2. Added the :ref:`actuatorgravcomp<body-joint-actuatorgravcomp>` joint attribute. When enabled, gravity compensation
forces on the joint are treated as applied by actuators. See attribute documentation for more details. The example
model
`refsite.xml <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/actuation/refsite.xml>`__,
which demonstrates Cartesian actuation of an arm, has been updated to use this attribute.
3. Added support for gmsh format 2.2 , tetrahedral mesh, as generated by e.g. `fTetwild <https://github.com/wildmeshing/fTetWild>`__.
4. Added :ref:`mju_euler2Quat` for converting an Euler-angle sequence to quaternion.
MJX
^^^
5. Improved performance of SAT for convex collisions.
6. Fixed bug for sphere/capsule-convex deep penetration.
7. Fixed bug where ``mjx.Data`` produced by ``mjx.put_data`` had different treedef than ``mjx.make_data``.
8. Throw an error for margin/gap for convex mesh collisions, since they are not supported.
9. Added ellipsoid plane collisions.
10. Added support for userdata.
11. Added ellipsoid-ellipsoid and ellipsoid-capsule collisions using signed distance functions (SDFs).
Simulate
^^^^^^^^
12. Fixed bug in order of enable flag strings. Before this change, using the simulate UI to toggle the
:ref:`invdiscrete<option-flag-invdiscrete>` or the (now removed) ``sensornoise`` flags would actually toggle the
other flag.
Python bindings
^^^^^^^^^^^^^^^
.. youtube:: xHDS0n5DpqM
:aspect: 16:7
:align: right
:width: 240px
13. Added the ``mujoco.minimize`` Python module for nonlinear least-squares, designed for System Identification (sysID).
The sysID tutorial is work in progress, but a pedagogical colab notebook with examples, including Inverse
Kinematics, is available here: |ls_colab|
|br| The video on the right shows example clips from the tutorial.
.. |ls_colab| image:: https://colab.research.google.com/assets/colab-badge.png
:target: https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/python/least_squares.ipynb
Version 3.1.3 (March 5th, 2024)
-------------------------------
General
^^^^^^^
1. Added the :at:`inheritrange` attribute to :ref:`position<actuator-position>` and
:ref:`intvelocity<actuator-intvelocity>` actuators, allowing convenient setting of the actuator's
:at:`ctrlrange` or :at:`actrange` (respectively), according to the range of the transmission
target (joint or tendon). See :ref:`position/inheritrange<actuator-position-inheritrange>` for
details.
2. Deprecated ``mj_makeEmptyFileVFS`` in favor of :ref:`mj_addBufferVFS`. :ref:`mjVFS` now computes checksums of
its internal file buffers. :ref:`mj_addBufferVFS` allocates an empty buffer with a given name in an mjVFS and
copies the data buffer into it, combining and replacing the deprecated two-step process of calling
``mj_makeEmptyFileVFS`` followed by a direct copy into the given mjVFS internal file buffer.
3. Added :ref:`mj_angmomMat` which computes the ``3 x nv`` angular momentum matrix :math:`H(q)`, providing the linear
mapping from generalized velocities to subtree angular momentum :math:`h = H \dot q`. Contribution by
:github:user:`v-r-a`.
MJX
^^^
4. Improved performance of getting and putting device data.
- Use ``tobytes()`` for numpy array serialization, which is orders of magnitude faster than converting to tuples.
- Avoid reallocating host ``mjData`` arrays when array shapes are unchanged.
- Speed up calculation of ``mjx.ncon`` for models with many geoms.
- Avoid calling ``mjx.ncon`` in ``mjx.get_data_into`` when ``nc`` can be derived from ``mjx.Data``.
5. Fixed a bug in ``mjx-viewer`` that prevented it from running. Updated ``mjx-viewer`` to use newer
``mjx.get_data_into`` function call.
6. Fixed a bug in ``mjx.euler`` that applied incorrect damping when using dense mass matrices.
7. Fixed a bug in ``mjx.solve`` that was causing slow convergence when using ``mjSOL_NEWTON`` in :ref:`mjtSolver`.
8. Added support for :ref:`mjOption.impratio<mjOption>` to ``mjx.Model``.
9. Added support for cameras in ``mjx.Model`` and ``mjx.Data``. Fixes :issue:`1422`.
10. Added an implementation of broadphase using `top_k` and bounding spheres.
Python bindings
^^^^^^^^^^^^^^^
11. Fixed incorrect data types in the bindings for the ``geom``, ``vert``, ``elem``, and ``flex`` array members
of the ``mjContact`` struct, and all array members of the ``mjrContext`` struct.
Version 3.1.2 (February 05, 2024)
---------------------------------
General
^^^^^^^
1. Improved the :ref:`discardvisual<compiler-discardvisual>` compiler flag, which now discards all visual-only assets.
See :ref:`discardvisual<compiler-discardvisual>` for details.
2. Removed the :ref:`timer<mjtTimer>` for midphase colllision detection, it is now folded in with the narrowphase
timer. This is because timing the two phases separately required fine-grained timers inside the collision
functions; these functions are so small and fast that the timer itself was incurring a measurable cost.
3. Added the flag :ref:`bvactive<visual-global-bvactive>` to ``visual/global``, allowing users to turn off
visualisation of active bounding volumes (the red/green boxes in this :ref:`this changelog item<midphase>`). For
models with very high-resolution meshes, the computation required for this visualization can slow down simulation
speed. Fixes :issue:`1279`.
- Added color of :ref:`bounding volumes<visual-rgba-bv>` and :ref:`active bounding volumes<visual-rgba-bvactive>`
to :ref:`visual/rgba<visual-rgba>`.
4. Height-field elevation data can now be specified directly in XML with the :ref:`elevation<asset-hfield-elevation>`
attribute (and not only with PNG files).
See `example model <https://github.com/google-deepmind/mujoco/blob/main/test/user/testdata/hfield_xml.xml>`__.
MJX
^^^
5. Added :ref:`dyntype<actuator-general-dyntype>` ``filterexact``.
6. Added :at:`site` transmission.
7. Updated MJX colab tutorial with more stable quadruped environment.
8. Added ``mjx.ray`` which mirrors :ref:`mj_ray` for planes, spheres, capsules, boxes, and meshes.
9. Added ``mjx.is_sparse`` which mirrors :ref:`mj_isSparse` and ``mjx.full_m`` which mirrors :ref:`mj_fullM`.
10. Added support for specifying sparse or dense mass matrices via :ref:`option-jacobian`.
11. Raise a not implemented error when nonzero frictionloss is present. Fixes :issue:`1344`.
Python bindings
^^^^^^^^^^^^^^^
12. Improved the implementation of the :ref:`rollout<PyRollout>` module. Note the changes below are breaking, dependent
code will require modification.
- Uses :ref:`mjSTATE_FULLPHYSICS<siFullPhysics>` as state spec, enabling divergence detection by inspecting time.
- Allows user-defined control spec for any combination of :ref:`user input<siInput>` fields as controls.
- Outputs are no longer squeezed and always have dim=3.
13. The ``sync`` function for the :ref:`passive viewer<PyViewerPassive>` can now pick up changes to rendering flags in
``user_scn``, as requested in :issue:`1190`.
Bug fixes
^^^^^^^^^
14. Fixed a bug that prevented the use of pins with plugins if flexes are not in the worldbody. Fixes
:issue:`1270`.
15. Fixed a bug in the :ref:`muscle model<CMuscle>` that led to non-zero values outside the lower
bound of the length range. Fixes :issue:`1342`.
Version 3.1.1 (December 18, 2023)
-----------------------------------
Bug fixes
^^^^^^^^^
1. Fixed a bug (introduced in 3.1.0) where box-box collisions produced no contacts if one box was deeply embedded in the
other.
2. Fixed a bug in :ref:`simulate<saSimulate>` where the "LOADING..." message was not showing correctly.
3. Fixed a crash in the Python :ref:`passive viewer<PyViewerPassive>`, when used with models containing Flex objects.
4. Fixed a bug in MJX where ``site_xmat`` was ignored in ``get_data`` and ``put_data``
5. Fixed a bug in MJX where ``efc_address`` was sometimes incorrectly calculated in ``get_data``.
Version 3.1.0 (December 12, 2023)
---------------------------------
General
^^^^^^^
1. Improved convergence of Signed Distance Function (SDF) collisions by using line search and a new objective function
for the optimization. This allows to decrease the number of initial points needed for finding the contacts and is
more robust for very small or large geom sizes.
2. Added :ref:`frame<frame>` to MJCF, a :ref:`meta-element<meta-element>` which defines a pure coordinate transformation
on its direct children, without requiring a :ref:`body<body>`.
3. Added the :at:`kv` attribute to the :ref:`position<actuator-position>` and :ref:`intvelocity<actuator-intvelocity>`
actuators, for specifying actuator-applied damping. This can be used to implement a PD controller with 0 reference
velocity. When using this attribute, it is recommended to use the implicitfast or implicit
:ref:`integrators<geIntegration>`.
Plugins
^^^^^^^
4. Allow actuator plugins to use activation variables in ``mjData.act`` as their internal state, rather than
``mjData.plugin_state``. Actuator plugins can now specify :ref:`callbacks<mjpPlugin>` that compute activation
variables, and they can be used with built-in :ref:`dyntype<actuator-plugin-dyntype>` actuator dynamics.
5. Added the `pid <https://github.com/deepmind/mujoco/blob/main/plugin/actuator/README.md>`__ actuator plugin, a
configurable PID controller that implements the Integral term, which is not available with native MuJoCo actuators.
MJX
^^^
6. Added ``site_xpos`` and ``site_xmat`` to MJX.
7. Added ``put_data``, ``put_model``, ``get_data`` to replace ``device_put`` and ``device_get_into``, which will be
deprecated. These new functions correctly translate fields that are the result of intermediate calculations such as
``efc_J``.
Bug fixes
^^^^^^^^^
8. Fix bug in Cartesian actuation with movable refsite, as when using body-centric Cartesian actuators on a quadruped.
Before this fix such actuators could lead to non-conservation of momentum.
9. Fix bug that prevented using flex with :ref:`simulate<saSimulate>`.
10. Fix bug that prevented the use of elasticity plugins in combination with pinned flex vertices.
11. Release Python wheels targeting macOS 10.16 to support x86_64 systems where ``SYSTEM_VERSION_COMPAT`` is set.
The minimum supported version is still 11.0, but we release these wheels to fix compatibility for those users. See
:issue:`1213`.
12. Fixed mass computation of meshes: Use the correct mesh volume instead of approximating it using the inertia box.
Version 3.0.1 (November 15, 2023)
---------------------------------
General
^^^^^^^
1. Added sub-terms of total passive forces in ``mjData.qfrc_passive`` to :ref:`mjData`:
``qfrc_{spring, damper, gravcomp, fluid}``. The sum of these vectors equals ``qfrc_passive``.
.. youtube:: H9qG9Zf2W44
:aspect: 16:7
:align: right
:width: 240px
2. Added :ref:`actuatorgroupdisable<option-actuatorgroupdisable>` attribute and associated
:ref:`mjOption.disableactuator<mjOption>` integer bitfield, which can be used to disable sets of actuators at runtime
according to their :ref:`group<actuator-general-group>`. Fixes :issue:`1092`. See :ref:`CActDisable`.
- The first 6 actuator groups are toggleable in the :ref:`simulate<saSimulate>` viewer. See `example model
<https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/actuation/actuator_group_disable.xml>`__
and associated screen-capture on the right.
3. Increased ``mjMAXUIITEM`` (maximum number of UI elements per section in Simulate) to 200.
MJX
^^^
4. Added support for Newton solver (``mjSOL_NEWTON`` in :ref:`mjtSolver`). The Newton solver significantly speeds up
simulation on GPU:
.. list-table:: Steps-per-second, Conjugate Gradient vs. Newton on A100
:header-rows: 1
:align: left
* - Model
- CG
- Newton
- Speedup
* - `Humanoid <https://github.com/google-deepmind/mujoco/tree/56006355b29424658b56aedb48a4269bd4361c68/mjx/mujoco/mjx/benchmark/model/humanoid>`__
- 640,000
- 1,020,000
- **1.6 x**
* - `Barkour v0 <https://github.com/google-deepmind/mujoco/tree/56006355b29424658b56aedb48a4269bd4361c68/mjx/mujoco/mjx/benchmark/model/barkour_v0>`__
- 1,290,000
- 1,750,000
- **1.35 x**
* - `Shadow Hand <https://github.com/google-deepmind/mujoco/tree/56006355b29424658b56aedb48a4269bd4361c68/mjx/mujoco/mjx/benchmark/model/shadow_hand>`__
- 215,000
- 270,000
- **1.25 x**
Humanoid is the standard MuJoCo humanoid,
`Google Barkour <https://blog.research.google/2023/05/barkour-benchmarking-animal-level.html>`__ and the Shadow Hand
are both available in the :ref:`MuJoCo Menagerie<Menagerie>`.
5. Added support for joint equality constraints (``mjEQ_JOINT`` in :ref:`mjtEq`).
6. Fixed bug where mixed ``jnt_limited`` joints were not being constrained correctly.
7. Made ``device_put`` type validation more verbose (fixes :issue:`1113`).
8. Removed empty EFC rows from ``MJX``, for joints with no limits (fixes :issue:`1117`).
9. Fixed bug in ``scan.body_tree`` that led to incorrect smooth dynamics for some kinematic tree layouts.
Python bindings
^^^^^^^^^^^^^^^
10. Fix the macOS ``mjpython`` launcher to work with the Python interpreter from Apple Command Line Tools.
11. Fixed a crash when copying instances of ``mujoco.MjData`` for models that use plugins. Introduced a ``model``
attribute to ``MjData`` which is reference to the model that was used to create that ``MjData`` instance.
Simulate
^^^^^^^^
12. :ref:`simulate<saSimulate>`: correct handling of "Pause update", "Fullscreen" and "VSync" buttons.
Documentation
^^^^^^^^^^^^^
.. youtube:: cE3s_IfO4g4
:aspect: 16:7
:align: right
:width: 240px
13. Added cell to the `tutorial colab <https://github.com/google-deepmind/mujoco#getting-started>`__ providing an
example of procedural camera control:
14. Added documentation for the :ref:`UI` framework.
15. Fixed typos and supported fields in docs (fixes :issue:`1105` and :issue:`1106`).
Bug fixes
^^^^^^^^^
16. Fixed bug relating to welds modified with :ref:`torquescale<equality-weld-torquescale>`.
Version 3.0.0 (October 18, 2023)
--------------------------------
New features
^^^^^^^^^^^^
1. Added simulation on GPU and TPU via the new :doc:`mjx` (MJX) Python module. Python users can now
natively run MuJoCo simulations at millions of steps per second on Google TPU or their own accelerator hardware.
- MJX is designed to work with on-device reinforcement learning algorithms. This Colab notebook demonstrates using
MJX along with reinforcement learning to train humanoid and quadruped robots to locomote: |colab|
- The MJX API is compatible with MuJoCo but is missing some features in this release. See the outline of
:ref:`MJX feature parity <MjxFeatureParity>` for more details.
.. |colab| image:: https://colab.research.google.com/assets/colab-badge.png
:target: https://colab.research.google.com/github/google-deepmind/mujoco/blob/main/mjx/tutorial.ipynb
.. youtube:: QewlEqIZi1o
:aspect: 16:7
:align: right
:width: 240px
2. Added new signed distance field (SDF) collision primitive. SDFs can take any shape and are not constrained to be
convex. Collision points are found by minimizing the maximum of the two colliding SDFs via gradient descent.
- Added new SDF plugin for defining implicit geometries. The plugin must define methods computing an SDF and its
gradient at query points. See the :ref:`documentation<exWriting>` for more details.
.. youtube:: ra2bTiZHGlw
:aspect: 16:7
:align: right
:width: 240px
3. Added new low-level model element called ``flex``, used to define deformable objects. These
`simplicial complexes <https://en.wikipedia.org/wiki/Simplicial_complex>`__ can be of dimension 1, 2
or 3, corresponding to stretchable lines, triangles or tetrahedra. Two new MJCF elements are used
to define flexes. The top-level :ref:`deformable<deformable>` section contains the low-level flex definition.
The :ref:`flexcomp<body-flexcomp>` element, similar to :ref:`composite<body-composite>` is a convenience macro for
creating deformables, and supports the GMSH tetrahedral file format.
- Added `shell <https://github.com/deepmind/mujoco/blob/main/plugin/elasticity/shell.cc>`__ passive force plugin,
computing bending forces using a constant precomputed Hessian (cotangent operator).
**Note**: This feature is still under development and subject to change. In particular, deformable object
functionality is currently available both via :ref:`deformable<CDeformable>` and :ref:`composite<CComposite>`,
and both are modifiable by the first-party
`elasticity plugins <https://github.com/google-deepmind/mujoco/tree/main/plugin/elasticity>`__. We expect some of
this functionality to be unified in the future.
.. youtube:: Vc1tq0fFvQA
:aspect: 16:7
:align: right
:width: 240px
4. Added constraint island discovery with :ref:`mj_island`. Constraint islands are disjoint sets of constraints
and degrees-of-freedom that do not interact. The only solver which currently supports islands is
:ref:`CG<option-solver>`. Island discovery can be activated using a new :ref:`enable flag<option-flag-island>`.
If island discovery is enabled, geoms, contacts and tendons will be colored according to the corresponding island,
see video. Island discovery is currently disabled for models that have deformable objects (see previous item).
5. Added :ref:`mjThreadPool` and :ref:`mjTask` which allow for multi-threaded operations within the MuJoCo engine
pipeline. If engine-internal threading is enabled, the following operations will be multi-threaded:
- Island constraint resolution, if island discovery is :ref:`enabled<option-flag-island>` and the
:ref:`CG solver<option-solver>` is selected. The
`22 humanoids <https://github.com/deepmind/mujoco/blob/main/model/humanoid/22_humanoids.xml>`__ model shows a 3x
speedup compared to the single threaded simulation.
- Inertia-related computations and collision detection will happen in parallel.
Engine-internal threading is a work in progress and currently only available in first-party code via the
:ref:`testspeed<saTestspeed>` utility, exposed with the ``npoolthread`` flag.
6. Added capability to initialize :ref:`composite<body-composite>` particles from OBJ files. Fixes :issue:`642`
and :issue:`674`.
General
^^^^^^^
.. admonition:: Breaking API changes
:class: attention
7. Removed the macros ``mjMARKSTACK`` and ``mjFREESTACK``.
**Migration:** These macros have been replaced by new functions :ref:`mj_markStack` and
:ref:`mj_freeStack`. These functions manage the :ref:`mjData stack<siStack>` in a fully encapsulated way (i.e.,
without introducing a local variable at the call site).
8. Renamed ``mj_stackAlloc`` to :ref:`mj_stackAllocNum`. The new function :ref:`mj_stackAllocByte` allocates an
arbitrary number of bytes and has an additional argument for specifying the alignment of the returned pointer.
**Migration:** The functionality for allocating ``mjtNum`` arrays is now available via :ref:`mj_stackAllocNum`.
9. Renamed the ``nstack`` field in :ref:`mjModel` and :ref:`mjData` to ``narena``. Changed ``narena``, ``pstack``,
and ``maxuse_stack`` to count number of bytes rather than number of :ref:`mjtNum` |-| s.
10. Changed :ref:`mjData.solver<mjData>`, the array used to collect solver diagnostic information.
This array of :ref:`mjSolverStat` structs is now of length ``mjNISLAND * mjNSOLVER``, interpreted as as a matrix.
Each row of length ``mjNSOLVER`` contains separate solver statistics for each constraint island.
If the solver does not use islands, only row 0 is filled.
- The new constant :ref:`mjNISLAND<glNumericSizes>` was set to 20.
- :ref:`mjNSOLVER<glNumericSizes>` was reduced from 1000 to 200.
- Added :ref:`mjData.solver_nisland<mjData>`: the number of islands for which the solver ran.
- Renamed ``mjData.solver_iter`` to ``solver_niter``. Both this member and ``mjData.solver_nnz`` are now integer
vectors of length ``mjNISLAND``.
11. Removed ``mjOption.collision`` and the associated ``option/collision`` attribute.
**Migration:**
- For models which have ``<option collision="all"/>``, delete the attribute.
- For models which have ``<option collision="dynamic"/>``, delete all :ref:`pair<contact-pair>` elements.
- For models which have ``<option collision="predefined"/>``, disable all dynamic collisions (determined
via contype/conaffinity) by first deleting all :ref:`contype<body-geom-contype>` and
:ref:`conaffinity<body-geom-conaffinity>` attributes in the model and then setting them globally to ``0`` using
|br| ``<default> <geom contype="0" conaffinity="0"/> </default>``.
12. Removed the :at:`rope` and :at:`cloth` composite objects.
**Migration:** Users should use the :at:`cable` and :at:`shell` elasticity plugins.
13. Added :ref:`mjData.eq_active<mjData>` user input variable, for enabling/disabling the state of equality
constraints. Renamed ``mjModel.eq_active`` to :ref:`mjModel.eq_active0<mjModel>`, which now has the semantic of
"initial value of ``mjData.eq_active``". Fixes :issue:`876`.
**Migration:** Replace uses of ``mjModel.eq_active`` with ``mjData.eq_active``.
14. Changed the default of :ref:`autolimits<compiler-autolimits>` from "false" to "true". This is a minor breaking
change. The potential breakage applies to models which have elements with "range" defined and "limited" not set.
Such models cannot be loaded since version 2.2.2 (July 2022).
15. Added a new :ref:`dyntype<actuator-general-dyntype>`, ``filterexact``, which updates first-order filter states with
the exact formula rather than with Euler integration.
16. Added an actuator attribute, :ref:`actearly<actuator-general-actearly>`, which uses semi-implicit integration for
actuator forces: using the next step's actuator state to compute the current actuator forces.
17. Renamed ``actuatorforcerange`` and ``actuatorforcelimited``, introduced in the previous version to
:ref:`actuatorfrcrange<body-joint-actuatorfrcrange>` and
:ref:`actuatorfrclimited<body-joint-actuatorfrclimited>`, respectively.
18. Added the flag :ref:`eulerdamp<option-flag-eulerdamp>`, which disables implicit integration of joint damping in the
Euler integrator. See the :ref:`Numerical Integration<geIntegration>` section for more details.
19. Added the flag :ref:`invdiscrete<option-flag-invdiscrete>`, which enables discrete-time inverse dynamics for all
:ref:`integrators<option-integrator>` other than ``RK4``. See the flag documentation for more details.
20. Added :ref:`ls_iterations<option-ls_iterations>` and :ref:`ls_tolerance<option-ls_tolerance>` options for adjusting
linesearch stopping criteria in CG and Newton solvers. These can be useful for performance tuning.
21. Added ``mesh_pos`` and ``mesh_quat`` fields to :ref:`mjModel` to store the normalizing transformation applied to
mesh assets. Fixes :issue:`409`.
22. Added camera :ref:`resolution<body-camera-resolution>` attribute and :ref:`camprojection<sensor-camprojection>`
sensor. If camera resolution is set to positive values, the camera projection sensor will report the location of a
target site, projected onto the camera image, in pixel coordinates.
23. Added :ref:`camera<body-camera>` calibration attributes:
- The new attributes are :ref:`resolution<body-camera-resolution>`, :ref:`focal<body-camera-focal>`,
:ref:`focalpixel<body-camera-focalpixel>`, :ref:`principal<body-camera-principal>`,
:ref:`principalpixel<body-camera-principalpixel>` and :ref:`sensorsize<body-camera-sensorsize>`.
- Visualize the calibrated frustum using the :ref:`mjVIS_CAMERA<mjtVisFlag>` visualization flag when these
attributes are specified. See the following
`example model <https://github.com/deepmind/mujoco/blob/main/test/engine/testdata/vis_visualize/frustum.xml>`__.
- Note that these attributes only take effect for offline rendering and do not affect interactive visualisation.
24. Implemented reversed Z rendering for better depth precision. An enum :ref:`mjtDepthMap` was added with values
``mjDEPTH_ZERONEAR`` and ``mjDEPTH_ZEROFAR``, which can be used to set the new ``readDepthMap`` attribute in
:ref:`mjrContext` to control how the depth returned by :ref:`mjr_readPixels` is mapped from ``znear`` to ``zfar``.
Contribution :pr:`978` by `Levi Burner <https://github.com/aftersomemath>`__.
25. Deleted the code sample ``testxml``. The functionality provided by this utility is implemented in the
`WriteReadCompare <https://github.com/google-deepmind/mujoco/blob/main/test/xml/xml_native_writer_test.cc>`__ test.
26. Deleted the code sample ``derivative``. Functionality provided by :ref:`mjd_transitionFD`.
Python bindings
^^^^^^^^^^^^^^^
27. Fixed :issue:`870` where calling ``update_scene`` with an invalid camera name used the default camera.
28. Added ``user_scn`` to the :ref:`passive viewer<PyViewerPassive>` handle, which allows users to add custom
visualization geoms (:issue:`1023`).
29. Added optional boolean keyword arguments ``show_left_ui`` and ``show_right_ui`` to the functions ``viewer.launch``
and ``viewer.launch_passive``, which allow users to launch a viewer with UI panels hidden.
Simulate
^^^^^^^^
.. youtube:: YSvWn_poqWs
:aspect: 16:7
:align: right
:width: 240px
30. Added **state history** mechanism to :ref:`simulate<saSimulate>` and the managed
:ref:`Python viewer<PyViewerManaged>`. State history can be viewed by scrubbing the History slider and (more
precisely) with the left and right arrow keys. See screen capture:
31. The ``LOADING...`` label is now shown correctly. Contribution :pr:`1070` by
`Levi Burner <https://github.com/aftersomemath>`__.
Documentation
^^^^^^^^^^^^^
.. youtube:: nljr0X79vI0
:aspect: 16:7
:align: right
:width: 240px
32. Added :doc:`detailed documentation <computation/fluid>` of fluid force modeling, and an illustrative example model
showing `tumbling cards <https://github.com/google-deepmind/mujoco/blob/main/model/cards/cards.xml>`__ using the
ellipsoid-based fluid model.
Bug fixes
^^^^^^^^^
33. Fixed a bug that was causing :ref:`geom margin<body-geom-margin>` to be ignored during the construction of
midphase collision trees.
34. Fixed a bug that was generating incorrect values in ``efc_diagApprox`` for weld equality constraints.
Version 2.3.7 (July 20, 2023)
-----------------------------
General
^^^^^^^
1. Added primitive collider for sphere-cylinder contacts, previously this pair used the generic convex-convex collider.
#. Added :ref:`joint-actuatorforcerange<body-joint-actuatorfrcrange>` for clamping total actuator force at joints and
:ref:`sensor-jointactuatorfrc<sensor-jointactuatorfrc>` for measuring total actuation force applied at a joint. The
most important use case for joint-level actuator force clamping is to ensure that
:ref:`Cartesian actuator<actuator-general-refsite>` forces are realizable by individual motors at the joints.
See :ref:`CForceRange` for details.
#. Added an optional ``content_type`` attribute to hfield, texture, and mesh assets. This attribute supports a formatted
`Media Type <https://www.iana.org/assignments/media-types/media-types.xhtml>`_ (previously known as MIME type) string
used to determine the type of the asset file without resorting to pulling the type from the file extension.
#. Added analytic derivatives for quaternion :ref:`subtraction<mjd_subQuat>` and :ref:`integration<mjd_quatIntegrate>`
(rotation with an angular velocity). Derivatives are in the 3D tangent space.
#. Added :ref:`mjv_connector` which has identical functionality to ``mjv_makeConnector``, but with more convenient
"from-to" argument parametrization. ``mjv_makeConnector`` is now deprecated.
#. Bumped oldest supported MacOS from version 10.12 to 11. MacOS 11 is the oldest version still maintained by Apple.
Python bindings
^^^^^^^^^^^^^^^
7. The :ref:`passive viewer<PyViewerPassive>` handle now exposes ``update_hfield``, ``update_mesh``, and
``update_texture`` methods to allow users to update renderable assets.
(Issues :issue:`812`, :issue:`958`, :issue:`965`).
#. Allow a custom keyboard event callback to be specified in the :ref:`passive viewer<PyViewerPassive>`
(:issue:`766`).
#. Fix GLFW crash when Python exits while the passive viewer is running (:issue:`790`).
Models
^^^^^^
10. Added simple `car <https://github.com/google-deepmind/mujoco/blob/main/model/car/car.xml>`__ example model.
Version 2.3.6 (June 20, 2023)
-----------------------------
.. note::
MuJoCo 2.3.6 is the last version to officially support Python 3.7.
.. youtube:: ZppeDArq6AU
:align: right
:width: 240px
Models
^^^^^^
1. Added `3x3x3 cube <https://github.com/google-deepmind/mujoco/blob/main/model/cube/cube_3x3x3.xml>`__ example model.
See `README <https://github.com/google-deepmind/mujoco/blob/main/model/cube/README.md>`__ for details.
Bug fixes
^^^^^^^^^
2. Fixed a bug that was causing an incorrect computation of the mesh bounding box and coordinate frame if the volume was
invalid. In such case, now MuJoCo only accepts a non-watertight geometry if
:ref:`shellinertia<body-geom-shellinertia>` is equal to ``true``.
#. Fixed the sparse Jacobian multiplication logic that is used to compute derivatives for tendon damping and fluid
force, which affects the behaviour of the :ref:`implicit and implicitfast integrators<geIntegration>`.
#. Fixes to :ref:`mj_ray`, in line with geom visualisation conventions:
- Planes and height-fields respect the ``geom_group`` and ``flg_static`` arguments. Before this change, rays would
intersect planes and height-fields unconditionally.
- ``flg_static`` now applies to all static geoms, not just those which are direct children of the world body.
.. youtube:: hqIMTNGaLF4
:align: right
:width: 240px
Plugins
^^^^^^^
5. Added touch-grid sensor plugin. See `documentation <https://github.com/google-deepmind/mujoco/blob/main/plugin/sensor/README.md>`__
for details, and associated `touch_grid.xml <https://github.com/google-deepmind/mujoco/blob/main/model/plugin/sensor/touch_grid.xml>`__
example model. The plugin includes `in-scene visualisation <https://youtu.be/0LOJ3WMnqeA>`__.
Simulate
^^^^^^^^
.. youtube:: mXVPbppGk5I
:aspect: 16:7
:align: right
:width: 240px
6. Added Visualization tab to simulate UI, corresponding to elements of the :ref:`visual<visual>` MJCF element. After
modifying values in the GUI, a saved XML will contain the new values. The modifiable members of
:ref:`mjStatistic` (:ref:`extent<statistic-extent>`, :ref:`meansize<statistic-meansize>` and
:ref:`center<statistic-center>`) are computed by the compiler and therefore do not have defaults. In order for these
attributes to appear in the saved XML, a value must be specified in the loaded XML.
.. image:: images/changelog/simulate_text_width.png
:align: right
:width: 380px
:alt: Before / After
7. Increased text width for UI elements in the default spacing. [before / after]:
General
^^^^^^^
8. Added :ref:`mj_getState` and :ref:`mj_setState` for getting and setting the simulation state as a concatenated vector
of floating point numbers. See the :ref:`State<geState>` section for details.
#. Added :ref:`mjContact.solreffriction<mjContact>`, allowing different :ref:`solref<CSolver>` parameters for the normal
and frictional axes of contacts when using :ref:`elliptic friction cones<option-cone>`. This attribute is required
for elastic frictional collisions, see associated
`example model <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/spin_recoil.xml>`__
mimicking the spin-bounce recoil behaviour of `elastic rubber balls <https://www.youtube.com/watch?v=uFLJcRegIVQ&t=3s>`__.
This is an advanced option currently only supported by explicit :ref:`contact pairs<contact-pair>`, using the
:ref:`solreffriction<contact-pair-solreffriction>` attribute.
#. Added :ref:`mjd_inverseFD` for finite-differenced inverse-dynamics derivatives.
#. Added functions for operations on banded-then-dense "arrowhead" matrices. Such matrices are common when doing direct
trajectory optimization. See :ref:`mju_cholFactorBand` documentation for details.
#. Added :ref:`mj_multiRay` function for intersecting multiple rays emanating from a single point.
This is significantly faster than calling :ref:`mj_ray` multiple times.
#. Ray-mesh collisions are now up to 10x faster, using a bounding volume hierarchy of mesh faces.
#. Increased ``mjMAXUIITEM`` (maximum number of UI elements per section in Simulate) to 100.
#. Added :ref:`documentation<exProvider>` for resource providers.
#. Changed the formula for :ref:`mju_sigmoid`, a finite-support sigmoid :math:`s \colon \mathbf R \rightarrow [0, 1]`.
Previously, the smooth part consisted of two stitched quadratics, once continuously differentiable.
It is now a single quintic, twice continuously differentiable:
.. math::
s(x) =
\begin{cases}
0, & & x \le 0 \\
6x^5 - 15x^4 + 10x^3, & 0 \lt & x \lt 1 \\
1, & 1 \le & x \qquad
\end{cases}
17. Added optional :ref:`tausmooth<actuator-muscle-tausmooth>` attribute to muscle actuators. When positive, the
time-constant :math:`\tau` of muscle activation/deactivation uses :ref:`mju_sigmoid` to transition smoothly
between the two extremal values given by the `Millard et al. (2013) <https://doi.org/10.1115/1.4023390>`__ muscle
model, within a range of width tausmooth. See :ref:`Muscle actuators<CMuscle>` for more details.
Relatedly, :ref:`mju_muscleDynamics` now takes 3 parameters instead of 2, adding the new smoothing-width parameter.
#. Moved public C macro definitions out of mujoco.h into a new public header file called
`mjmacro.h <https://github.com/google-deepmind/mujoco/blob/main/include/mujoco/mjmacro.h>`__. The new file
is included by mujoco.h so this change does not break existing user code.
#. Added instrumentation for the `Address Sanitizer (ASAN) <https://clang.llvm.org/docs/AddressSanitizer.html>`__ and
`Memory Sanitizer (MSAN) <https://clang.llvm.org/docs/MemorySanitizer.html>`__ to detect memory bugs when allocating
from the ``mjData`` stack and arena.
#. Removed ``pstack`` and ``parena`` from the output of ``mj_printData``, since these are implementation details of the
``mjData`` allocators that are affected by diagnostic paddings in instrumented builds.
#. Removed the ``mj_activate`` and ``mj_deactivate`` functions. These had been kept around for compatibility with old
user code from when MuJoCo was closed source, but have been no-op functions since open sourcing.
Version 2.3.5 (April 25, 2023)
------------------------------
Bug fixes
^^^^^^^^^
1. Fix asset loading bug that prevented OBJ and PNG files from being read from disk when :ref:`mjVFS` is used.
#. Fix occasional segmentation faults on macOS when mouse perturbations are applied in the Python passive viewer.
Plugins
^^^^^^^
3. The ``visualize`` callback in :ref:`mjpPlugin` now receives an :ref:`mjvOption` as an input argument.
Version 2.3.4 (April 20, 2023)
------------------------------
.. note::
This version is affected by an asset loading bug that prevents OBJ and PNG files from being read from disk when
``mjVFS`` is used. Users are advised to skip to version 2.3.5 instead.
General
^^^^^^^
1. Removed the "global" setting of the :ref:`compiler/coordinate<compiler-coordinate>` attribute. This rarely-used
setting complicates the compiler logic and is blocking future improvements. In order to convert older models which
used this option, load and save them in MuJoCo 2.3.3 or older.
.. image:: images/changelog/ellipsoidinertia.gif
:align: right
:width: 240px
2. Added :ref:`visual-global<visual-global>` flag :ref:`ellipsoidinertia<visual-global-ellipsoidinertia>` to visualize
equivalent body inertias with ellipsoids instead of the default boxes.
#. Added midphase and broadphase collision statistics to :ref:`mjData`.
#. Added documentation for :ref:`engine plugins<exPlugin>`.
#. Added struct information to the ``introspect`` module.
#. Added a new extension mechanism called :ref:`resource providers<exProvider>`. This extensible mechanism allows MuJoCo
to read assets from data sources other than the local OS filesystem or
the :ref:`Virtual file system<Virtualfilesystem>`.
Python bindings
^^^^^^^^^^^^^^^
7. Offscreen rendering on macOS is no longer restricted to the main thread. This is achieved by using the low-level
Core OpenGL (CGL) API to create the OpenGL context, rather than going via GLFW which relies on Cocoa's NSOpenGL.
The resulting context is not tied to a Cocoa window, and is therefore not tied to the main thread.
#. Fixed a race condition in ``viewer.launch_passive`` and ``viewer.launch_repl``. These functions could previously
return before an internal call to ``mj_forward``. This allows user code to continue and potentially modify physics
state concurrently with the internal ``mj_forward``, resulting in e.g.
`MuJoCo stack overflow error <https://github.com/google-deepmind/mujoco/issues/783>`__
or `segmentation fault <https://github.com/google-deepmind/mujoco/issues/790>`__.
#. The ``viewer.launch_passive`` function now returns a handle which can be used to interact with the viewer. The
passive viewer now also requires an explicit call to ``sync`` on its handle to pick up any update to the physics
state. This is to avoid race conditions that can result in visual artifacts. See
:ref:`documentation<PyViewerPassive>` for details.
#. The ``viewer.launch_repl`` function has been removed since its functionality is superseded by ``launch_passive``.
#. Added a small number of missing struct fields discovered through the new ``introspect`` metadata.
Bug fixes
^^^^^^^^^
12. Fixed bug in the handling of ellipsoid-based fluid model forces in the new implicitfast integrator.
#. Removed spurious whole-arena copying in `mj_copyData`, which can considerably
`slow down <https://github.com/google-deepmind/mujoco/issues/568>`__ the copying operation.
#. Make :ref:`shellinertia<body-geom-shellinertia>` ignore ``exactmeshinertia``, which is
only used for legacy volume computations (`#759 <https://github.com/google-deepmind/mujoco/issues/759>`__).
Version 2.3.3 (March 20, 2023)
------------------------------
General
^^^^^^^
1. Improvements to implicit integration:
- The derivatives of the RNE algorithm are now computed using sparse math, leading to significant speed
improvements for large models when using the :ref:`implicit integrator<geIntegration>`.
- A new integrator called ``implicitfast`` was added. It is similar to the existing implicit integrator, but skips the
derivatives of Coriolis and centripetal forces. See the :ref:`numerical integration<geIntegration>` section for a
detailed motivation and discussion. The implicitfast integrator is recommended for all new models and will
become the default integrator in a future version.
The table below shows the compute cost of the 627-DoF `humanoid100
<https://github.com/google-deepmind/mujoco/blob/main/model/humanoid/humanoid100.xml>`__ model using different
integrators. "implicit (old)" uses dense RNE derivatives, "implicit (new)" is after the sparsification mentioned
above. Timings were measured on a single core of an AMD 3995WX CPU.
.. csv-table::
:header: "timing", "Euler", "implicitfast", "implicit (new)", "implicit (old)"
:widths: auto
:align: left
one step (ms), 0.5, 0.53, 0.77, 5.0
steps/second, 2000, 1900, 1300, 200
.. image:: images/computation/midphase.gif
:align: right
:width: 350px
.. _midphase:
2. Added a collision mid-phase for pruning geoms in body pairs, see :ref:`documentation<coSelection>` for more details.
This is based on static AABB bounding volume hierarchy (a BVH binary tree) in the body inertial frame. The GIF on
the right is cut from `this longer video <https://youtu.be/e0babIM8hBo>`__.
#. The ``mjd_transitionFD`` function no longer triggers sensor calculation unless explicitly requested.
#. Corrected the spelling of the ``inteval`` attribute to ``interval`` in the :ref:`mjLROpt` struct.
#. Mesh texture and normal mappings are now 3-per-triangle rather than 1-per-vertex. Mesh vertices are no longer
duplicated in order to circumvent this limitation as they previously were.
#. The non-zeros for the sparse constraint Jacobian matrix are now precounted and used for matrix memory allocation.
For instance, the constraint Jacobian matrix from the `humanoid100
<https://github.com/google-deepmind/mujoco/blob/main/model/humanoid/humanoid100.xml>`__ model, which previously
required ~500,000 ``mjtNum``'s, now only requires ~6000. Very large models can now load and run with the CG solver.
#. Modified :ref:`mju_error` and :ref:`mju_warning` to be variadic functions (support for printf-like arguments). The
functions :ref:`mju_error_i`, :ref:`mju_error_s`, :ref:`mju_warning_i`, and :ref:`mju_warning_s` are now deprecated.
#. Implemented a performant ``mju_sqrMatTDSparse`` function that doesn't require dense memory allocation.
#. Added ``mj_stackAllocInt`` to get correct size for allocating ints on mjData stack. Reducing stack memory usage
by 10% - 15%.
Python bindings
^^^^^^^^^^^^^^^
10. Fixed IPython history corruption when using ``viewer.launch_repl``. The ``launch_repl`` function now provides
seamless continuation of an IPython interactive shell session, and is no longer considered experimental feature.
#. Added ``viewer.launch_passive`` which launches the interactive viewer in a passive, non-blocking mode. Calls to
``launch_passive`` return immediately, allowing user code to continue execution, with the viewer automatically
reflecting any changes to the physics state. (Note that this functionality is currently in experimental/beta stage,
and is not yet described in our :ref:`viewer documentation<PyViewer>`.)
#. Added the ``mjpython`` launcher for macOS, which is required for ``viewer.launch_passive`` to function there.
#. Removed ``efc_`` fields from joint indexers. Since the introduction of arena memory, these fields now have dynamic
sizes that change between time steps depending on the number of active constraints, breaking strict correspondence
between joints and ``efc_`` rows.
#. Added a number of missing fields to the bindings of ``mjVisual`` and ``mjvPerturb`` structs.
Simulate
^^^^^^^^
15. Implemented a workaround for `broken VSync <https://github.com/glfw/glfw/issues/2249>`__ on macOS so that the frame
rate is correctly capped when the Vertical Sync toggle is enabled.
.. image:: images/changelog/contactlabel.png
:align: right
:width: 400px
16. Added optional labels to contact visualization, indicating which two geoms are contacting (names if defined, ids
otherwise). This can be useful in cluttered scenes.
|br|
Version 2.3.2 (February 7, 2023)
--------------------------------
General
^^^^^^^
1. A more performant mju_transposeSparse has been implemented that doesn't require dense memory allocation.
For a constraint Jacobian matrix from the
`humanoid100.xml <https://github.com/google-deepmind/mujoco/blob/main/model/humanoid/humanoid100.xml>`__ model,
this function is 35% faster.
#. The function :ref:`mj_name2id` is now implemented using a hash function instead of a linear search for better
performance.
#. Geom names are now parsed from URDF. Any duplicate names are ignored.
``mj_printData`` output now contains contacting geom names.
Bug fixes
^^^^^^^^^
4. Fixed a bug that for :at:`shellinertia` equal to ``true`` caused the mesh orientation to be overwritten by the
principal components of the shell inertia, while the vertex coordinates are rotated using the volumetric inertia.
Now the volumetric inertia orientation is used also in the shell case.
#. Fixed misalignment bug in mesh-to-primitive fitting when using the bounding box fitting option :at:`fitaabb`.
.. image:: images/changelog/meshfit.png
:align: right
:width: 300px
6. The ``launch_repl`` functionality in the Python viewer has been fixed.
#. Set ``time`` correctly in ``mjd_transitionFD``, to support time-dependent user code.
#. Fixed sensor data dimension validation when ``user`` type sensors are present.
#. Fixed incorrect plugin error message when a null ``nsensordata`` callback is encountered during model compilation.
#. Correctly end the timer (``TM_END``) ``mj_fwdConstraint`` returns early.
#. Fixed an infinite loop in ``mj_deleteFileVFS``.
Simulate
^^^^^^^^
12. Increased precision of simulate sensor plot y-axis by 1 digit
(`#719 <https://github.com/google-deepmind/mujoco/issues/719>`_).
#. Body labels are now drawn at the body frame rather than inertial frame, unless inertia is being visualised.
Plugins
^^^^^^^
14. The ``reset`` callback now receives instance-specific ``plugin_state`` and ``plugin_data`` as arguments, rather than
the entire ``mjData``. Since ``reset`` is called inside ``mj_resetData`` before any physics forwarding call has been
made, it is an error to read anything from ``mjData`` at this stage.
#. The ``capabilities`` field in ``mjpPlugin`` is renamed ``capabilityflags`` to more clearly indicate that this is a
bit field.
Version 2.3.1 (December 6, 2022)
--------------------------------
Python bindings
^^^^^^^^^^^^^^^
1. The ``simulate`` GUI is now available through the ``mujoco`` Python package as ``mujoco.viewer``.
See :ref:`documentation<PyViewer>` for details. (Contribution by `Levi Burner <https://github.com/aftersomemath>`__.)
#. The ``Renderer`` class from the MuJoCo tutorial Colab is now available directly in the native Python bindings.
General
^^^^^^^
3. The tendon :at:`springlength` attribute can now take two values. Given two non-decreasing values, `springlength`
specifies a `deadband <https://en.wikipedia.org/wiki/Deadband>`__ range for spring stiffness. If the tendon length is
between the two values, the force is 0. If length is outside this range, the force behaves like a regular spring, with
the spring resting length corresponding to the nearest :at:`springlength` value. This can be used to create tendons
whose limits are enforced by springs rather than constraints, which are cheaper and easier to analyse. See
`tendon_springlength.xml <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/tendon_springlength.xml>`__
example model.
.. attention::
This is a minor breaking API change. ``mjModel.tendon_lengthspring`` now has size ``ntendon x 2`` rather than
``ntendon x 1``.
.. youtube:: -PJ6afdETUg
:align: right
:height: 150px
#. Removed the requirement that stateless actuators come before stateful actuators.
#. Added :ref:`mju_fill`, :ref:`mju_symmetrize` and :ref:`mju_eye` utility functions.
#. Added :at:`gravcomp` attribute to :ref:`body<body>`, implementing gravity compensation and buoyancy.
See `balloons.xml <https://github.com/google-deepmind/mujoco/blob/main/model/balloons/balloons.xml>`__ example model.
#. Renamed the ``cable`` plugin library to ``elasticity``.
#. Added :at:`actdim` attribute to :ref:`general actuators<actuator-general>`. Values greater than 1 are only allowed
for dyntype :at-val:`user`, as native activation dynamics are all scalar. Added example test implementing 2nd-order
activation dynamics to
`engine_forward_test.cc <https://github.com/google-deepmind/mujoco/blob/main/test/engine/engine_forward_test.cc>`__.
#. Improved particle :ref:`composite<body-composite>` type, which now permits a user-specified geometry and multiple
joints. See the two new examples:
`particle_free.xml <https://github.com/google-deepmind/mujoco/blob/main/model/composite/particle_free.xml>`__ and
`particle_free2d.xml <https://github.com/google-deepmind/mujoco/blob/main/model/composite/particle_free2d.xml>`__.
#. Performance improvements for non-AVX configurations:
- 14% faster ``mj_solveLD`` using `restrict <https://en.wikipedia.org/wiki/Restrict>`__. See `engine_core_smooth_benchmark_test
<https://github.com/google-deepmind/mujoco/blob/main/test/benchmark/engine_core_smooth_benchmark_test.cc>`__.
- 50% faster ``mju_dotSparse`` using manual loop unroll. See `engine_util_sparse_benchmark_test
<https://github.com/google-deepmind/mujoco/blob/main/test/benchmark/engine_util_sparse_benchmark_test.cc>`__.
#. Added new :at:`solid` passive force plugin:
.. youtube:: AGcTGHbbze4
:align: right
:height: 150px
- This is new force field compatible with the :ref:`composite<body-composite>` particles.
- Generates a tetrahedral mesh having particles with mass concentrated at vertices.
- Uses a piecewise-constant strain model equivalent to finite elements but expressed in a coordinate-free
formulation. This implies that all quantities can be precomputed except edge elongation, as in a mass-spring model.
- Only suitable for small strains (large displacements but small deformations). Tetrahedra may invert if subject to
large loads.
#. Added API functions ``mj_loadPluginLibrary`` and ``mj_loadAllPluginLibraries``. The first function is identical to
``dlopen`` on a POSIX system, and to ``LoadLibraryA`` on Windows. The second function scans a specified directory for
all dynamic libraries file and loads each library found. Dynamic libraries opened by these functions are assumed to
register one or more MuJoCo plugins on load.
#. Added an optional ``visualize`` callback to plugins, which is called during ``mjv_updateScene``. This callback allows
custom plugin visualizations. Enable stress visualization for the Cable plugin as an example.
#. Sensors of type :ref:`user<sensor-user>` no longer require :at:`objtype`, :at:`objname` and :at:`needstage`. If
unspecified, the objtype is now :ref:`mjOBJ_UNKNOWN<mjtObj>`. ``user`` sensors :at:`datatype` default is now
:at-val:`"real"`, :at:`needstage` default is now :at-val:`"acc"`.
#. Added support for capsules in URDF import.
#. On macOS, issue an informative error message when run under `Rosetta 2 <https://support.apple.com/en-gb/HT211861>`__
translation on an Apple Silicon machine. Pre-built MuJoCo binaries make use of
`AVX <https://en.wikipedia.org/wiki/Advanced_Vector_Extensions>`__ instructions on x86-64 machines, which is not
supported by Rosetta 2. (Before this version, users only get a cryptic "Illegal instruction" message.)
Bug fixes
^^^^^^^^^
17. Fixed bug in ``mj_addFileVFS`` that was causing the file path to be ignored (introduced in 2.1.4).
Simulate
^^^^^^^^
18. Renamed the directory in which the ``simulate`` application searches for plugins from ``plugin`` to ``mujoco_plugin``.
#. Mouse force perturbations are now applied at the selection point rather than the body center of mass.
Version 2.3.0 (October 18, 2022)
--------------------------------
General
^^^^^^^
1. The ``contact`` array and arrays prefixed with ``efc_`` in ``mjData`` were moved out of the ``buffer`` into a new
``arena`` memory space. These arrays are no longer allocated with fixed sizes when ``mjData`` is created.
Instead, the exact memory requirement is determined during each call to :ref:`mj_forward` (specifically,
in :ref:`mj_collision` and :ref:`mj_makeConstraint`) and the arrays are allocated from the ``arena`` space. The
``stack`` now also shares its available memory with ``arena``. This change reduces the memory footprint of ``mjData``
in models that do not use the PGS solver, and will allow for significant memory reductions in the future.
See the :ref:`Memory allocation <CSize>` section for details.
.. youtube:: RHnXD6uO3Mg
:aspect: 16:7
:align: right
:height: 150px
#. Added colab notebook tutorial showing how to balance the humanoid on one leg with a Linear Quadratic Regulator. The
notebook uses MuJoCo's native Python bindings, and includes a draft ``Renderer`` class, for easy rendering in Python.
|br| Try it yourself: |LQRopenincolab|
.. |LQRopenincolab| image:: https://colab.research.google.com/assets/colab-badge.png
:target: https://colab.research.google.com/github/deepmind/mujoco/blob/main/python/LQR.ipynb
#. Updates to humanoid model:
- Added two keyframes (stand-on-one-leg and squat).
- Increased maximum hip flexion angle.
- Added hamstring tendons which couple the hip and knee at high hip flexion angles.
- General cosmetic improvements, including improved use of defaults and better naming scheme.
#. Added :ref:`mju_boxQP` and allocation function :ref:`mju_boxQPmalloc` for solving the box-constrained
Quadratic Program:
.. math::
x^* = \text{argmin} \; \tfrac{1}{2} x^T H x + x^T g \quad \text{s.t.} \quad l \le x \le u
The algorithm, introduced in `Tassa et al. 2014 <https://doi.org/10.1109/ICRA.2014.6907001>`__,
converges after 2-5 Cholesky factorisations, independent of problem size.
#. Added :ref:`mju_mulVecMatVec` to multiply a square matrix :math:`M` with vectors :math:`x` and :math:`y` on both
sides. The function returns :math:`x^TMy`.
#. Added new plugin API. Plugins allow developers to extend MuJoCo's capability without modifying core engine code.
The plugin mechanism is intended to replace the existing callbacks, though these will remain for the time being as an
option for simple use cases and backward compatibility. The new mechanism manages stateful plugins and supports
multiple plugins from different sources, allowing MuJoCo extensions to be introduced in a modular fashion, rather
than as global overrides. Note the new mechanism is currently undocumented except in code, as we test it internally.
If you are interested in using the plugin mechanism, please get in touch first.
#. Added :at:`assetdir` compiler option, which sets the values of both :at:`meshdir` and :at:`texturedir`. Values in
the latter attributes take precedence over :at:`assetdir`.
#. Added :at:`realtime` option to :ref:`visual<visual>` for starting a simulation at a slower speed.
#. Added new :at:`cable` composite type:
- Cable elements are connected with ball joints.
- The `initial` parameter specifies the joint at the starting boundary: :at:`free`, :at:`ball`, or :at:`none`.
- The boundary bodies are exposed with the names :at:`B_last` and :at:`B_first`.
- The vertex initial positions can be specified directly in the XML with the parameter :at:`vertex`.
- The orientation of the body frame **is** the orientation of the material frame of the curve.
#. Added new :at:`cable` passive force plugin:
- Twist and bending stiffness can be set separately with the parameters :at:`twist` and :at:`bend`.
- The stress-free configuration can be set to be the initial one or flat with the flag :at:`flat`.
- New `cable.xml <https://github.com/google-deepmind/mujoco/blob/main/model/plugin/elasticity/cable.xml>`__ example
showing the formation of plectoneme.
- New `coil.xml <https://github.com/google-deepmind/mujoco/blob/main/model/plugin/elasticity/coil.xml>`__ example
showing a curved equilibrium configuration.
- New `belt.xml <https://github.com/google-deepmind/mujoco/blob/main/model/plugin/elasticity/belt.xml>`__ example
showing interaction between twist and anisotropy.
- Added test using cantilever exact solution.
+--------------------------+--------------------------+--------------------------+
| .. youtube:: 25kQP671fJE | .. youtube:: 4DvGe-BodFU | .. youtube:: QcGdpUd5H0c |
| :align: center | :align: center | :align: center |
| :height: 140px | :height: 140px | :height: 140px |
+--------------------------+--------------------------+--------------------------+
Python bindings
^^^^^^^^^^^^^^^
11. Added ``id`` and ``name`` properties to
`named accessor <https://mujoco.readthedocs.io/en/latest/python.html#named-access>`__ objects.
These provide more Pythonic API access to ``mj_name2id`` and ``mj_id2name`` respectively.
#. The length of ``MjData.contact`` is now ``ncon`` rather than ``nconmax``, allowing it to be straightforwardly used as
an iterator without needing to check ``ncon``.
#. Fix a memory leak when a Python callable is installed as callback
(`#527 <https://github.com/google-deepmind/mujoco/issues/527>`__).
Version 2.2.2 (September 7, 2022)
---------------------------------
General
^^^^^^^
.. youtube:: BcHZ5BFeTmU
:aspect: 16:7
:align: right
:height: 150px
1. Added :ref:`adhesion actuators<actuator-adhesion>` mimicking vacuum grippers and adhesive biomechanical appendages.
#. Added related `example model <https://github.com/google-deepmind/mujoco/tree/main/model/adhesion>`__ and video:
#. Added :ref:`mj_jacSubtreeCom` for computing the translational Jacobian of the center-of-mass of a subtree.
#. Added :at:`torquescale` and :at:`anchor` attributes to :el:`weld` constraints. :at:`torquescale` sets the
torque-to-force ratio exerted by the constraint, :at:`anchor` sets the point at which the weld wrench is
applied. See :ref:`weld <equality-weld>` for more details.
#. Increased ``mjNEQDATA``, the row length of equality constraint parameters in ``mjModel.eq_data``, from 7 to 11.
#. Added visualisation of anchor points for both :el:`connect` and :el:`weld` constraints (activated by the 'N' key in
``simulate``).
#. Added `weld.xml <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/weld.xml>`__ showing
different uses of new weld attributes.
.. youtube:: s-0JHanqV1A
:aspect: 16:7
:align: right
:height: 150px
#. Cartesian 6D end-effector control is now possible by adding a reference site to actuators with :at:`site`
transmission. See description of new :at:`refsite` attribute in the :ref:`actuator<actuator-general>` documentation
and `refsite.xml <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/actuation/refsite.xml>`__
example model.
#. Added :at:`autolimits` compiler option. If ``true``, joint and tendon :at:`limited` attributes and actuator
:at:`ctrllimited`, :at:`forcelimited` and :at:`actlimited` attributes will automatically be set to ``true`` if the
corresponding range *is defined* and ``false`` otherwise.
If ``autolimits="false"`` (the default) models where a :at:`range` attribute is specified without the :at:`limited`
attribute will fail to compile. A future release will change the default of :at:`autolimits` to ``true``, and this
compilation error allows users to catch this future change of behavior.
.. attention::
This is a breaking change. In models where a range was defined but :at:`limited` was unspecified, explicitly set
limited to ``false`` or remove the range to maintain the current behavior of your model.
#. Added moment of inertia computation for all well-formed meshes. This option is activated by setting the compiler
flag :at:`exactmeshinertia` to ``true`` (defaults to ``false``). This default may change in the future.
#. Added parameter :at:`shellinertia` to :at:`geom`, for locating the inferred inertia on the boundary (shell).
Currently only meshes are supported.
#. For meshes from which volumetric inertia is inferred, raise error if the orientation of mesh faces is not consistent.
If this occurs, fix the mesh in e.g., MeshLab or Blender.
.. youtube:: I2q7D0Vda-A
:align: right
:height: 150px
#. Added catenary visualisation for hanging tendons. The model seen in the video can be found
`here <https://github.com/google-deepmind/mujoco/blob/main/test/engine/testdata/catenary.xml>`__.
#. Added ``azimuth`` and ``elevation`` attributes to :ref:`visual/global<visual-global>`, defining the initial
orientation of the free camera at model load time.
#. Added ``mjv_defaultFreeCamera`` which sets the default free camera, respecting the above attributes.
#. ``simulate`` now supports taking a screenshot via a button in the File section or via ``Ctrl-P``.
#. Improvements to time synchronisation in `simulate`, in particular report actual real-time factor if different from
requested factor (if e.g., the timestep is so small that simulation cannot keep up with real-time).
#. Added a disable flag for sensors.
#. :ref:`mju_mulQuat` and :ref:`mju_mulQuatAxis` support in place computation. For example
|br| ``mju_mulQuat(a, a, b);`` sets the quaternion ``a`` equal to the product of ``a`` and ``b``.
#. Added sensor matrices to ``mjd_transitionFD`` (note this is an API change).
Deleted/deprecated features
^^^^^^^^^^^^^^^^^^^^^^^^^^^
21. Removed ``distance`` constraints.
Bug fixes
^^^^^^^^^
22. Fixed rendering of some transparent geoms in reflection.
#. Fixed ``intvelocity`` defaults parsing.
Version 2.2.1 (July 18, 2022)
-----------------------------
General
^^^^^^^
1. Added ``mjd_transitionFD`` to compute efficient finite difference approximations of the state-transition and
control-transition matrices, :ref:`see here<derivatives>` for more details.
#. Added derivatives for the ellipsoid fluid model.
#. Added ``ctrl`` attribute to :ref:`keyframes<keyframe>`.
#. Added ``clock`` sensor which :ref:`measures time<sensor-clock>`.
#. Added visualisation groups to skins.
#. Added actuator visualisation for ``free`` and ``ball`` joints and for actuators with ``site`` transmission.
#. Added visualisation for actuator activations.
#. Added ``<actuator-intvelocity>`` actuator shortcut for "integrated velocity" actuators, documented
:ref:`here <actuator-intvelocity>`.
#. Added ``<actuator-damper>`` actuator shortcut for active-damping actuators, documented :ref:`here <actuator-damper>`.
#. ``mju_rotVecMat`` and ``mju_rotVecMatT`` now support in-place multiplication.
#. ``mjData.ctrl`` values are no longer clamped in-place, remain untouched by the engine.
#. Arrays in mjData's buffer now align to 64-byte boundaries rather than 8-byte.
#. Added memory poisoning when building with `Address Sanitizer (ASAN) <https://clang.llvm.org/docs/AddressSanitizer.html>`__
and `Memory Sanitizer (MSAN) <https://clang.llvm.org/docs/MemorySanitizer.html>`__. This allows ASAN to
detect reads and writes to regions in ``mjModel.buffer`` and ``mjData.buffer`` that do not lie within an array, and
for MSAN to detect reads from uninitialised fields in ``mjData`` following ``mj_resetData``.
#. Added a `slider-crank example model <https://github.com/google-deepmind/mujoco/tree/main/model/slider_crank>`__.
Bug fixes
^^^^^^^^^
15. :ref:`Activation clamping <CActRange>` was not being applied in the :ref:`implicit integrator<geIntegration>`.
#. Stricter parsing of orientation specifiers. Before this change, a specification that included both ``quat`` and an
:ref:`alternative specifier<COrientation>` e.g., ``<geom ... quat=".1 .2 .3 .4" euler="10 20 30">``, would lead to
the ``quat`` being ignored and only ``euler`` being used. After this change a parse error will be thrown.
#. Stricter parsing of XML attributes. Before this change an erroneous XML snippet like ``<geom size="1/2 3 4">`` would
have been parsed as ``size="1 0 0"`` and no error would have been thrown. Now throws an error.
#. Trying to load a ``NaN`` via XML like ``<geom size="1 NaN 4">``, while allowed for debugging purposes, will now print
a warning.
#. Fixed null pointer dereference in ``mj_loadModel``.
#. Fixed memory leaks when loading an invalid model from MJB.
#. Integer overflows are now avoided when computing ``mjModel`` buffer sizes.
#. Added missing warning string for ``mjWARN_BADCTRL``.
Packaging
^^^^^^^^^
23. Changed MacOS packaging so that the copy of ``mujoco.framework`` embedded in ``MuJoCo.app`` can be used to build
applications externally.
Version 2.2.0 (May 23, 2022)
----------------------------
Open Sourcing
^^^^^^^^^^^^^
1. MuJoCo is now fully open-source software. Newly available top level directories are:
a. ``src/``: All source files. Subdirectories correspond to the modules described in the Programming chapter
:ref:`introduction<inIntro>`:
- ``src/engine/``: Core engine.
- ``src/xml/``: XML parser.
- ``src/user/``: Model compiler.
- ``src/visualize/``: Abstract visualizer.
- ``src/ui/``: UI framework.
b. ``test/``: Tests and corresponding asset files.
c. ``dist/``: Files related to packaging and binary distribution.
#. Added `contributor's guide <https://github.com/google-deepmind/mujoco/blob/main/CONTRIBUTING.md>`__ and
`style guide <https://github.com/google-deepmind/mujoco/blob/main/STYLEGUIDE.md>`__.
General
^^^^^^^
3. Added analytic derivatives of smooth (unconstrained) dynamics forces, with respect to velocities:
- Centripetal and Coriolis forces computed by the Recursive Newton-Euler algorithm.
- Damping and fluid-drag passive forces.
- Actuation forces.
#. Added ``implicit`` integrator. Using the analytic derivatives above, a new implicit-in-velocity integrator was added.
This integrator lies between the Euler and Runge Kutta integrators in terms of both stability and computational
cost. It is most useful for models which use fluid drag (e.g. for flying or swimming) and for models which use
:ref:`velocity actuators<actuator-velocity>`. For more details, see the :ref:`Numerical Integration<geIntegration>`
section.
#. Added :at:`actlimited` and :at:`actrange` attributes to :ref:`general actuators<actuator-general>`, for clamping
actuator internal states (activations). This clamping is useful for integrated-velocity actuators, see the
:ref:`Activation clamping <CActRange>` section for details.
#. ``mjData`` fields ``qfrc_unc`` (unconstrained forces) and ``qacc_unc`` (unconstrained accelerations) were renamed
``qfrc_smooth`` and ``qacc_smooth``, respectively. While "unconstrained" is precise, "smooth" is more intelligible
than "unc".
#. Public headers have been moved from ``/include`` to ``/include/mujoco/``, in line with the directory layout common in
other open source projects. Developers are encouraged to include MuJoCo public headers in their own codebase via
``#include <mujoco/filename.h>``.
#. The default shadow resolution specified by the :ref:`shadowsize<visual-quality>` attribute was increased from 1024 to
4096.
#. Saved XMLs now use 2-space indents.
Bug fixes
^^^^^^^^^
10. Antialiasing was disabled for segmentation rendering. Before this change, if the :ref:`offsamples<visual-quality>`
attribute was greater than 0 (the default value is 4), pixels that overlapped with multiple geoms would receive
averaged segmentation IDs, leading to incorrect or non-existent IDs. After this change :at:`offsamples` is ignored
during segmentation rendering.
#. The value of the enable flag for the experimental multiCCD feature was made sequential with other enable flags.
Sequentiality is assumed in the ``simulate`` UI and elsewhere.
#. Fix issue of duplicated meshes when saving models with OBJ meshes using mj_saveLastXML.
Version 2.1.5 (Apr. 13, 2022)
-----------------------------
General
^^^^^^^
1. Added an experimental feature: multi-contact convex collision detection, activated by an enable flag. See full
description :ref:`here <option-flag>`.
Bug fixes
^^^^^^^^^
2. GLAD initialization logic on Linux now calls ``dlopen`` to load a GL platform dynamic library if a
``*GetProcAddress`` function is not already present in the process' global symbol table. In particular, processes
that use GLFW to set up a rendering context that are not explicitly linked against ``libGLX.so`` (this applies to the
Python interpreter, for example) will now work correctly rather than fail with a ``gladLoadGL`` error when
``mjr_makeContext`` is called.
#. In the Python bindings, named indexers for scalar fields (e.g. the ``ctrl`` field for actuators) now return a NumPy
array of shape ``(1,)`` rather than ``()``. This allows values to be assigned to these fields more straightforwardly.
Version 2.1.4 (Apr. 4, 2022)
----------------------------
General
^^^^^^^
1. MuJoCo now uses GLAD to manage OpenGL API access instead of GLEW. On Linux, there is no longer a need to link against
different GL wrangling libraries depending on whether GLX, EGL, or OSMesa is being used. Instead, users can simply
use GLX, EGL, or OSMesa to create a GL context and ``mjr_makeContext`` will detect which one is being used.
#. Added visualisation for contact frames. This is useful when writing or modifying collision functions, when the actual
direction of the x and y axes of a contact can be important.
Binary build
^^^^^^^^^^^^
3. The ``_nogl`` dynamic library is no longer provided on Linux and Windows. The switch to GLAD allows us to resolve
OpenGL symbols when ``mjr_makeContext`` is called rather than when the library is loaded. As a result, the MuJoCo
library no longer has an explicit dynamic dependency on OpenGL, and can be used on system where OpenGL is not
present.
Simulate
^^^^^^^^
4. Fixed a bug in simulate where pressing '[' or ']' when a model is not loaded causes a crash.
#. Contact frame visualisation was added to the Simulate GUI.
#. Renamed "set key", "reset to key" to "save key" and "load key", respectively.
#. Changed bindings of F6 and F7 from the not very useful "vertical sync" and "busy wait" to the more useful cycling of
frames and labels.
Bug fixes
^^^^^^^^^
8. ``mj_resetData`` zeroes out the ``solver_nnz`` field.
#. Removed a special branch in ``mju_quat2mat`` for unit quaternions. Previously, ``mju_quat2mat`` skipped all
computation if the real part of the quaternion equals 1.0. For very small angles (e.g. when finite differencing), the
cosine can evaluate to exactly 1.0 at double precision while the sine is still nonzero.
Version 2.1.3 (Mar. 23, 2022)
-----------------------------
General
^^^^^^^
1. ``simulate`` now supports cycling through cameras (with the ``[`` and ``]`` keys).
#. ``mjVIS_STATIC`` toggles all static bodies, not just direct children of the world.
Python bindings
^^^^^^^^^^^^^^^
3. Added a ``free()`` method to ``MjrContext``.
#. Enums now support arithmetic and bitwise operations with numbers.
Bug fixes
^^^^^^^^^
5. Fixed rendering bug for planes, introduced in 2.1.2. This broke maze environments in
`dm_control <https://github.com/google-deepmind/dm_control>`__.
Version 2.1.2 (Mar. 15, 2022)
-----------------------------
New modules
^^^^^^^^^^^
1. Added new :doc:`Python bindings<python>`, which can be installed via ``pip install mujoco``,
and imported as ``import mujoco``.
#. Added new :doc:`Unity plug-in<unity>`.
#. Added a new ``introspect`` module, which provides reflection-like capability for MuJoCo's public API, currently
describing functions and enums. While implemented in Python, this module is expected to be generally useful for
automatic code generation targeting multiple languages. (This is not shipped as part of the ``mujoco`` Python
bindings package.)
API changes
^^^^^^^^^^^
4. Moved definition of ``mjtNum`` floating point type into a new header
`mjtnum.h <https://github.com/google-deepmind/mujoco/blob/3577e2cf8bf841475b489aefff52276a39f24d51/include/mjtnum.h>`__.
#. Renamed header `mujoco_export.h` to :ref:`mjexport.h<inHeader>`.
#. Added ``mj_printFormattedData``, which accepts a format string for floating point numbers, for example to increase
precision.
General
^^^^^^^
7. MuJoCo can load `OBJ <https://en.wikipedia.org/wiki/Wavefront_.obj_file>`__ mesh files.
a. Meshes containing polygons with more than 4 vertices are not supported.
#. In OBJ files containing multiple object groups, any groups after the first one will be ignored.
#. Added (post-release, not included in the 2.1.2 archive) textured
`mug <https://github.com/google-deepmind/mujoco/blob/main/model/mug/mug.xml>`__ example model:
.. image:: images/changelog/mug.png
:width: 300px
#. Added optional frame-of-reference specification to :ref:`framepos<sensor-framepos>`,
:ref:`framequat<sensor-framequat>`, :ref:`framexaxis<sensor-framexaxis>`, :ref:`frameyaxis<sensor-frameyaxis>`,
:ref:`framezaxis<sensor-framezaxis>`, :ref:`framelinvel<sensor-framelinvel>`, and
:ref:`frameangvel<sensor-frameangvel>` sensors. The frame-of-reference is specified by new :at:`reftype` and
:at:`refname` attributes.
#. Sizes of :ref:`user parameters <CUser>` are now automatically inferred.
a. Declarations of user parameters in the top-level :ref:`size <size>` clause (e.g. :at:`nuser_body`,
:at:`nuser_jnt`, etc.) now accept a value of -1, which is the default. This will automatically set the value to
the length of the maximum associated :at:`user` attribute defined in the model.
#. Setting a value smaller than -1 will lead to a compiler error (previously a segfault).
#. Setting a value to a length smaller than some :at:`user` attribute defined in the model will lead to an error
(previously additional values were ignored).
#. Increased the maximum number of lights in an :ref:`mjvScene` from 8 to 100.
#. Saved XML files only contain explicit :ref:`inertial <body-inertial>` elements if the original XML included them.
Inertias that were automatically inferred by the compiler's :ref:`inertiafromgeom <compiler>` mechanism remain
unspecified.
#. User-selected geoms are always rendered as opaque. This is useful in interactive visualizers.
#. Static geoms now respect their :ref:`geom group<body-geom>` for visualisation. Until this change rendering of static
geoms could only be toggled using the :ref:`mjVIS_STATIC<mjtVisFlag>` visualisation flag . After this change, both
the geom group and the visualisation flag need to be enabled for the geom to be rendered.
#. Pointer parameters in function declarations in :ref:`mujoco.h<inHeader>` that are supposed to represent fixed-length
arrays are now spelled as arrays with extents, e.g. ``mjtNum quat[4]`` rather than ``mjtNum* quat``. From the
perspective of C and C++, this is a non-change since array types in function signatures decay to pointer types.
However, it allows autogenerated code to be aware of expected input shapes.
#. Experimental stateless fluid interaction model. As described :ref:`here <gePassive>`, fluid forces use sizes computed
from body inertia. While sometimes convenient, this is very rarely a good approximation. In the new model forces act
on geoms, rather than bodies, and have a several user-settable parameters. The model is activated by setting a new
attribute: ``<geom fluidshape="ellipsoid"/>``. The parameters are described succinctly :ref:`here<body-geom>`, but we
leave a full description or the model and its parameters to when this feature leaves experimental status.
Bug fixes
^^^^^^^^^
16. ``mj_loadXML`` and ``mj_saveLastXML`` are now locale-independent. The Unity plugin should now work correctly for
users whose system locales use commas as decimal separators.
#. XML assets in VFS no longer need to end in a null character. Instead, the file size is determined by the size
parameter of the corresponding VFS entry.
#. Fix a vertex buffer object memory leak in ``mjrContext`` when skins are used.
#. Camera quaternions are now normalized during XML compilation.
Binary build
^^^^^^^^^^^^
20. Windows binaries are now built with Clang.
Version 2.1.1 (Dec. 16, 2021)
-----------------------------
API changes
^^^^^^^^^^^
1. Added ``mj_printFormattedModel``, which accepts a format string for floating point numbers, for example to increase
precision.
#. Added ``mj_versionString``, which returns human-readable string that represents the version of the MuJoCo binary.
#. Converted leading underscores to trailing underscores in private instances of API struct definitions, to conform to
reserved identifier directive, see
`C standard: Section 7.1.3 <https://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf>`__.
.. attention::
This is a minor breaking change. Code which references private instances will break. To fix, replace leading
underscores with trailing underscores, e.g. ``_mjModel`` |rarr| ``mjModel_``.
General
^^^^^^^
4. Safer string handling: replaced ``strcat``, ``strcpy``, and ``sprintf`` with ``strncat``, ``strncpy``, and
``snprintf`` respectively.
#. Changed indentation from 4 spaces to 2 spaces, K&R bracing style, added braces to one-line conditionals.
Bug Fixes
^^^^^^^^^
6. Fixed reading from uninitialized memory in PGS solver.
#. Computed capsule inertias are now exact. Until this change, capsule masses and inertias computed by the
:ref:`compiler <compiler>`'s :at:`inertiafromgeom` mechanism were approximated by a cylinder, formed by the
capsule's cylindrical middle section, extended on both ends by half the capsule radius. Capsule inertias are now
computed with the `Parallel Axis theorem <https://en.wikipedia.org/wiki/Parallel_axis_theorem>`__, applied to the two
hemispherical end-caps.
.. attention::
This is a minor breaking change. Simulation of a model with automatically-computed capsule inertias will be
numerically different, leading to, for example, breakage of golden-value tests.
#. Fixed bug related to :ref:`force <sensor-force>` and :ref:`torque <sensor-torque>` sensors. Until this change, forces
and torques reported by F/T sensors ignored out-of-tree constraint wrenches except those produced by contacts. Force
and torque sensors now correctly take into account the effects of :ref:`connect <equality-connect>` and
:ref:`weld <equality-weld>` constraints.
.. note::
Forces generated by :ref:`spatial tendons <tendon-spatial>` which are outside the kinematic tree (i.e., between
bodies which have no ancestral relationship) are still not taken into account by force and torque sensors. This
remains a future work item.
Code samples
^^^^^^^^^^^^
9. ``testspeed``: Added injection of pseudo-random control noise, turned on by default. This is to avoid settling into
some fixed contact configuration and providing an unrealistic timing measure.
#. ``simulate``:
a. Added slower-than-real-time functionality, which is controlled via the '+' and '-' keys.
#. Added sliders for injecting Brownian noise into the controls.
#. Added "Print Camera" button to print an MJCF clause with the pose of the current camera.
#. The camera pose is not reset when reloading the same model file.
Updated dependencies
^^^^^^^^^^^^^^^^^^^^
11. ``TinyXML`` was replaced with ``TinyXML2`` 6.2.0.
#. ``qhull`` was upgraded to version 8.0.2.
#. ``libCCD`` was upgraded to version 1.4.
#. On Linux, ``libstdc++`` was replaced with ``libc++``.
Binary build
^^^^^^^^^^^^
15. MacOS packaging. We now ship Universal binaries that natively support both Apple Silicon and Intel CPUs.
a. MuJoCo library is now packaged as a `Framework Bundle
<https://developer.apple.com/library/archive/documentation/MacOSX/Conceptual/BPFrameworks/Concepts/FrameworkAnato
my.html>`__, allowing it to be incorporated more easily into Xcode projects (including Swift projects). Developers
are encouraged to compile and link against MuJoCo using the ``-framework mujoco`` flag, however all header files
and the ``libmujoco.2.1.1.dylib`` library can still be directly accessed inside the framework.
#. Sample applications are now packaged into an Application Bundle called ``MuJoCo.app``. When launched via GUI,
the bundle launches the ``simulate`` executable. Other precompiled sample programs are shipped inside that bundle
(in ``MuJoCo.app/Contents/MacOS``) and can be launched via command line.
#. Binaries are now signed and the disk image is notarized.
#. Windows binaries and libraries are now signed.
#. Link-time optimization is enabled on Linux and macOS, leading to an average of \~20% speedup when benchmarked on
three test models (``cloth.xml``, ``humanoid.xml``, and ``humanoid100.xml``).
#. Linux binaries are now built with LLVM/Clang instead of GCC.
#. An AArch64 (aka ARM64) Linux build is also provided.
#. Private symbols are no longer stripped from shared libraries on Linux and MacOS.
Sample models
^^^^^^^^^^^^^
21. Clean-up of the ``model/`` directory.
a. Rearranged into subdirectories which include all dependencies.
#. Added descriptions in XML comments, cleaned up XMLs.
#. Deleted some composite models: ``grid1``, ``grid1pin``, ``grid2``, ``softcylinder``, ``softellipsoid``.
#. Added descriptive animations in ``docs/images/models/`` :
|humanoid| |particle|
Version 2.1.0 (Oct. 18, 2021)
-----------------------------
New features
^^^^^^^^^^^^
1. Keyframes now have ``mocap_pos`` and ``mocap_quat`` fields (mpos and quat attributes in the XML) allowing mocap
poses to be stored in keyframes.
2. New utility functions: ``mju_insertionSortInt`` (integer insertion sort) and ``mju_sigmoid`` (constructing a
sigmoid from two half-quadratics).
General
^^^^^^^
3. The preallocated sizes in the virtual file system (VFS) increased to 2000 and 1000, to allow for larger projects.
#. The C structs in the ``mjuiItem`` union are now named, for compatibility.
#. Fixed: ``mjcb_contactfilter`` type is ``mjfConFilt`` (was ``mjfGeneric``).
#. Fixed: The array of sensors in ``mjCModel`` was not cleared.
#. Cleaned up cross-platform code (internal changes, not visible via the API).
#. Fixed a bug in parsing of XML ``texcoord`` data (related to number of vertices).
#. Fixed a bug in `simulate.cc <https://github.com/google-deepmind/mujoco/blob/main/simulate/simulate.cc>`__ related to
``nkey`` (the number of keyframes).
#. Accelerated collision detection in the presence of large numbers of non-colliding geoms (with ``contype==0 and
conaffinity==0``).
UI
^^
11. Figure selection type changed from ``int`` to ``float``.
#. Figures now show data coordinates, when selection and highlight are enabled.
#. Changed ``mjMAXUIMULTI`` to 35, ``mjMAXUITEXT`` to 300, ``mjMAXUIRECT`` to 25.
#. Added collapsible sub-sections, implemented as separators with state: ``mjSEPCLOSED`` collapsed, ``mjSEPCLOSED+1``
expanded.
#. Added ``mjITEM_RADIOLINE`` item type.
#. Added function ``mjui_addToSection`` to simplify UI section construction.
#. Added subplot titles to ``mjvFigure``.
Rendering
^^^^^^^^^
18. ``render_gl2`` guards against non-finite floating point data in the axis range computation.
#. ``render_gl2`` draws lines from back to front for better visibility.
#. Added function ``mjr_label`` (for text labels).
#. ``mjr_render`` exits immediately if ``ngeom==0``, to avoid errors from uninitialized scenes (e.g. ``frustrum==0``).
#. Added scissor box in ``mjr_render``, so we don't clear the entire window at every frame.
License manager
^^^^^^^^^^^^^^^
23. Removed the entire license manager. The functions ``mj_activate`` and ``mj_deactivate`` are still there for
backward compatibility, but now they do nothing and it is no longer necessary to call them.
#. Removed the remote license certificate functions ``mj_certXXX``.
Earlier versions
----------------
For changelogs of earlier versions please see `roboti.us <https://www.roboti.us/download.html>`__.
.. |humanoid| image:: images/models/humanoid.gif
:width: 270px
.. |particle| image:: images/models/particle.gif
:width: 270px