Parses model description input into a MultibodyPlant and (optionally) a SceneGraph.
A variety of input formats are supported, and are recognized by filename suffixes:
File format | Filename suffix |
---|---|
URDF | ".urdf" |
SDFormat | ".sdf" |
MJCF (Mujoco XML) | ".xml" |
Drake Model Directives | ".dmd.yaml" |
Wavefront OBJ | ".obj" |
The output of parsing is one or more model instances added to the MultibodyPlant provided to the parser at construction.
For an introductory tutorial about parsing, see the Authoring a Multibody Simulation page.
SDFormat files may contain multiple <model>
elements. New model instances will be added to plant
for each <model>
tag in the file.
<model>
s directly under <sdf>
, is deprecated. If you need multiple models in a single file, please use an SDFormat world tag.URDF files contain a single <robot>
element. Only a single model instance will be added to plant
.
MJCF (MuJoCo XML) files typically contain many bodies, they will all be added as a single model instance in the plant
.
Drake Model Directives are only available via AddModels or AddModelsFromString. The single-model methods (AddModelFromFile, AddModelFromString) cannot load model directives.
OBJ files will infer a model with a single body from the geometry. The OBJ file must contain a single object (in the OBJ-file sense). The body's mass properties are computed based on uniform distribution of material in the enclosed volume of the mesh (with the approximate density of water: 1000 kg/m³). If the mesh is not a closed manifold, this can produce unexpected results. The spatial inertia of the body is measured at the body frame's origin. The body's frame is coincident and fixed with the frame the mesh's vertices are measured and expressed in. The mesh's vertices are assumed to be measured in units of meters.
The name of the model and body are determined according to the following prioritized protocol:
model_name
, if given (e.g., in AddModelFromFile()).If the underlying plant is registered with a SceneGraph instance, the mesh will also be used for all three roles: illustration, perception, and proximity.
For more documentation of Drake-specific treatment of these input formats, see Parsing Models for Multibody Dynamics.
When parsing literal quantities, Parser assumes SI units and radians in the absence of units specified by the format itself. This includes the literals in the explicitly specified files as well as referenced files such as OBJ or other data file formats.
MultibodyPlant requires that model instances have unique names. To support loading multiple instances of the same model file(s) into a plant, Parser offers a few different strategies.
Parser has constructors that take a model name prefix, which gets applied to all models loaded with that Parser instance. The resulting workflow makes multiple parsers to build models for a single plant:
For situations where it is convenient to load a model many times, Parser offers optional auto-renaming. When auto-renaming is enabled, name collisions will be resolved by adding a subscript to the name.
(Advanced) In the rare case where the user is parsing into a MultibodyPlant and SceneGraph but has created them one at a time instead of using the more convenient AddMultibodyPlant() or AddMultibodyPlantSceneGraph() functions, the Parser constructors accept an optional SceneGraph pointer to specify which SceneGraph to parse into. If it is provided and non-null and the MultibodyPlant is not registered as a source, the Parser will perform the SceneGraph registration into the given plant. We describe this option only for completeness; we strongly discourage anyone from taking advantage of this feature.
#include <drake/multibody/parsing/parser.h>
Public Member Functions | |
Parser (MultibodyPlant< double > *plant, geometry::SceneGraph< double > *scene_graph=nullptr) | |
Creates a Parser that adds models to the given plant and (optionally) scene_graph. More... | |
Parser (MultibodyPlant< double > *plant, geometry::SceneGraph< double > *scene_graph, std::string_view model_name_prefix) | |
Creates a Parser that adds models to the given plant and scene_graph. More... | |
Parser (MultibodyPlant< double > *plant, std::string_view model_name_prefix) | |
Creates a Parser that adds models to the given plant and scene_graph. More... | |
~Parser () | |
MultibodyPlant< double > & | plant () |
Gets a mutable reference to the plant that will be modified by this parser. More... | |
geometry::SceneGraph< double > * | scene_graph () |
Gets a mutable pointer to the SceneGraph that will be modified by this parser, or nullptr if this parser does not have a SceneGraph. More... | |
PackageMap & | package_map () |
Gets a mutable reference to the PackageMap used by this parser. More... | |
void | SetStrictParsing () |
Cause all subsequent Add*Model*() operations to use strict parsing; warnings will be treated as errors. More... | |
void | SetAutoRenaming (bool value) |
Enable or disable auto-renaming. More... | |
bool | GetAutoRenaming () const |
Get the current state of auto-renaming. More... | |
CollisionFilterGroups | GetCollisionFilterGroups () const |
Gets the accumulated set of collision filter definitions seen by this parser. More... | |
std::vector< ModelInstanceIndex > | AddModels (const std::filesystem::path &file_name) |
Parses the input file named in file_name and adds all of its model(s) to plant . More... | |
std::vector< ModelInstanceIndex > | AddModelsFromUrl (const std::string &url) |
Parses the input file named in url and adds all of its model(s) to plant . More... | |
std::vector< ModelInstanceIndex > | AddModelsFromString (const std::string &file_contents, const std::string &file_type) |
Provides same functionality as AddModels, but instead parses the model description text data via file_contents with format dictated by file_type . More... | |
Does not allow copy, move, or assignment | |
Parser (const Parser &)=delete | |
Parser & | operator= (const Parser &)=delete |
Parser (Parser &&)=delete | |
Parser & | operator= (Parser &&)=delete |
Friends | |
class | internal::CompositeParse |
|
explicit |
Creates a Parser that adds models to the given plant and (optionally) scene_graph.
plant | A pointer to a mutable MultibodyPlant object to which parsed model(s) will be added; plant->is_finalized() must remain false for as long as the plant is in use by this . |
scene_graph | A pointer to a mutable SceneGraph object used for geometry registration (either to model visual or contact geometry). May be nullptr. |
Parser | ( | MultibodyPlant< double > * | plant, |
geometry::SceneGraph< double > * | scene_graph, | ||
std::string_view | model_name_prefix | ||
) |
Creates a Parser that adds models to the given plant and scene_graph.
The resulting parser will apply model_name_prefix
to the names of any models parsed.
plant | A pointer to a mutable MultibodyPlant object to which parsed model(s) will be added; plant->is_finalized() must remain false for as long as the plant is in use by this . |
scene_graph | A pointer to a mutable SceneGraph object used for geometry registration (either to model visual or contact geometry). May be nullptr. |
model_name_prefix | A string that will be added as a scoped name prefix to the names of any models loaded by this parser; when empty, no scoping will be added. |
Parser | ( | MultibodyPlant< double > * | plant, |
std::string_view | model_name_prefix | ||
) |
Creates a Parser that adds models to the given plant and scene_graph.
The resulting parser will apply model_name_prefix
to the names of any models parsed.
plant | A pointer to a mutable MultibodyPlant object to which parsed model(s) will be added; plant->is_finalized() must remain false for as long as the plant is in use by this . |
model_name_prefix | A string that will be added as a scoped name prefix to the names of any models loaded by this parser; when empty, no scoping will be added. |
~Parser | ( | ) |
std::vector<ModelInstanceIndex> AddModels | ( | const std::filesystem::path & | file_name | ) |
Parses the input file named in file_name
and adds all of its model(s) to plant
.
file_name | The name of the file to be parsed. The file type will be inferred from the extension. |
std::exception | in case of errors. |
std::vector<ModelInstanceIndex> AddModelsFromString | ( | const std::string & | file_contents, |
const std::string & | file_type | ||
) |
Provides same functionality as AddModels, but instead parses the model description text data via file_contents
with format dictated by file_type
.
file_contents | The model data to be parsed. |
file_type | The data format; must be one of the filename suffixes listed above, without the leading dot (.). |
std::exception | in case of errors. |
std::vector<ModelInstanceIndex> AddModelsFromUrl | ( | const std::string & | url | ) |
Parses the input file named in url
and adds all of its model(s) to plant
.
The allowed URL schemes are either file://
for local files or package://
(or model://
) to use this Parser's package_map()
.
url | The file to be parsed. The file type will be inferred from the extension. |
std::exception | in case of errors. |
bool GetAutoRenaming | ( | ) | const |
Get the current state of auto-renaming.
CollisionFilterGroups GetCollisionFilterGroups | ( | ) | const |
Gets the accumulated set of collision filter definitions seen by this parser.
There are two kinds of names in the returned data: group names and body names. Both may occur within scoped names indicating the model instance where they are defined. Note that the model instance names used in the returned data will reflect the current names in plant() at the time this accessor is called (see MultibodyPlant::RenameModelInstance()), but the local group and body names will be the names seen during parsing.
PackageMap& package_map | ( | ) |
Gets a mutable reference to the PackageMap used by this parser.
MultibodyPlant<double>& plant | ( | ) |
Gets a mutable reference to the plant that will be modified by this parser.
geometry::SceneGraph<double>* scene_graph | ( | ) |
Gets a mutable pointer to the SceneGraph that will be modified by this parser, or nullptr if this parser does not have a SceneGraph.
void SetAutoRenaming | ( | bool | value | ) |
Enable or disable auto-renaming.
It is disabled by default.
void SetStrictParsing | ( | ) |
Cause all subsequent Add*Model*() operations to use strict parsing; warnings will be treated as errors.
|
friend |