From 206018ddf8e01200dfbc7082a4b501fa832a0b10 Mon Sep 17 00:00:00 2001 From: Silvio Traversaro Date: Fri, 5 Jul 2024 11:03:08 +0000 Subject: [PATCH 1/3] Fix bug that caused iDynTree::ModelParserOptions to be ignored --- CMakeLists.txt | 2 +- .../codecs/include/private/URDFDocument.h | 2 +- src/model_io/codecs/src/ModelLoader.cpp | 17 ++++-- src/model_io/codecs/src/URDFDocument.cpp | 5 +- .../codecs/tests/URDFModelImportUnitTest.cpp | 55 +++++++++++++++++++ 5 files changed, 71 insertions(+), 10 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 1f8baf1fab..9cfcdfe6b8 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -3,7 +3,7 @@ cmake_minimum_required(VERSION 3.16) -project(iDynTree VERSION 12.3.2 +project(iDynTree VERSION 12.3.3 LANGUAGES C CXX) # Disable in source build, unless Eclipse is used diff --git a/src/model_io/codecs/include/private/URDFDocument.h b/src/model_io/codecs/include/private/URDFDocument.h index 5d3bb246e4..9ec9a19171 100644 --- a/src/model_io/codecs/include/private/URDFDocument.h +++ b/src/model_io/codecs/include/private/URDFDocument.h @@ -43,7 +43,7 @@ class iDynTree::URDFDocument: public iDynTree::XMLDocument { } m_buffers; public: - explicit URDFDocument(XMLParserState& parserState); + explicit URDFDocument(XMLParserState& parserState, const iDynTree::ModelParserOptions& parserOptions); virtual ~URDFDocument(); iDynTree::ModelParserOptions& options(); diff --git a/src/model_io/codecs/src/ModelLoader.cpp b/src/model_io/codecs/src/ModelLoader.cpp index ba9f20c619..2036ed005a 100644 --- a/src/model_io/codecs/src/ModelLoader.cpp +++ b/src/model_io/codecs/src/ModelLoader.cpp @@ -81,9 +81,11 @@ namespace iDynTree { // Allocate parser std::shared_ptr parser = std::make_shared(); - parser->setDocumentFactory([](XMLParserState& state){ - return std::shared_ptr(new URDFDocument(state)); - }); + auto parserOptions = this->m_pimpl->m_options; + auto documentFactoryWithOptions = [parserOptions](XMLParserState& state){ + return std::shared_ptr(new URDFDocument(state, parserOptions)); + }; + parser->setDocumentFactory(documentFactoryWithOptions); parser->setPackageDirs(packageDirs); if (!parser->parseXMLFile(filename)) { reportError("ModelLoader", "loadModelFromFile", "Error in parsing model from URDF."); @@ -106,9 +108,12 @@ namespace iDynTree { // Allocate parser std::shared_ptr parser = std::make_shared(); - parser->setDocumentFactory([](XMLParserState& state){ - return std::shared_ptr(new URDFDocument(state)); - }); + auto parserOptions = this->m_pimpl->m_options; + auto documentFactoryWithOptions = [parserOptions](XMLParserState& state){ + return std::shared_ptr(new URDFDocument(state, parserOptions)); + }; + + parser->setDocumentFactory(documentFactoryWithOptions); parser->setPackageDirs(packageDirs); if (!parser->parseXMLString(modelString)) { reportError("ModelLoader", "loadModelFromString", "Error in parsing model from URDF."); diff --git a/src/model_io/codecs/src/URDFDocument.cpp b/src/model_io/codecs/src/URDFDocument.cpp index a23333a1dc..d1cf4f473a 100644 --- a/src/model_io/codecs/src/URDFDocument.cpp +++ b/src/model_io/codecs/src/URDFDocument.cpp @@ -27,8 +27,8 @@ namespace iDynTree { const std::unordered_map& materialDatabase, ModelSolidShapes &modelGeometries); - URDFDocument::URDFDocument(XMLParserState& parserState) - : XMLDocument(parserState) {} + URDFDocument::URDFDocument(XMLParserState& parserState, const iDynTree::ModelParserOptions& options) + : XMLDocument(parserState), m_options(options) {} iDynTree::ModelParserOptions& URDFDocument::options() { return m_options; } @@ -133,6 +133,7 @@ namespace iDynTree { return false; } + std::cerr << "m_options.addSensorFramesAsAdditionalFrame:" << m_options.addSensorFramesAsAdditionalFrames << std::endl; if (m_options.addSensorFramesAsAdditionalFrames) { if (!addSensorFramesAsAdditionalFramesToModel(m_model)) { diff --git a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp index d5333d2188..b2636d0bbb 100644 --- a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp +++ b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp @@ -255,6 +255,60 @@ void checkDuplicateJointsReturnsError() { } +void checkaddSensorFramesAsAdditionalFramesOption() { + std::string urdf = R"( + + + + + + + + + + + + + + + + + + + + + + sensor + child_to_parent + + + + +)"; + + // Let's first load with the option disabled + { + iDynTree::ModelLoader mdlLoader; + iDynTree::ModelParserOptions parserOptions; + parserOptions.addSensorFramesAsAdditionalFrames = false; + mdlLoader.setParsingOptions(parserOptions); + ASSERT_IS_TRUE(mdlLoader.loadModelFromString(urdf)); + std::cerr << mdlLoader.model().toString() << std::endl; + ASSERT_IS_FALSE(mdlLoader.model().isFrameNameUsed("l_leg_ft")); + } + + // Then with the option enabled + { + iDynTree::ModelLoader mdlLoader; + iDynTree::ModelParserOptions parserOptions; + parserOptions.addSensorFramesAsAdditionalFrames = true; + mdlLoader.setParsingOptions(parserOptions); + ASSERT_IS_TRUE(mdlLoader.loadModelFromString(urdf)); + ASSERT_IS_TRUE(mdlLoader.model().isFrameNameUsed("l_leg_ft")); + } + +} + int main() { checkURDF(getAbsModelPath("/simple_model.urdf"),1,0,0,1, 1, 0, "link1"); @@ -270,6 +324,7 @@ int main() checkLimitsForJointsAreDefinedFromFileName(getAbsModelPath("iCubGenova02.urdf")); checkLoadReducedModelOrderIsKept(getAbsModelPath("iCubGenova02.urdf")); + checkaddSensorFramesAsAdditionalFramesOption(); return EXIT_SUCCESS; } From 2a1726e5a4a5e7ec72172e01dad1e2ec19935bb1 Mon Sep 17 00:00:00 2001 From: Silvio Traversaro Date: Fri, 5 Jul 2024 13:12:57 +0200 Subject: [PATCH 2/3] Update URDFModelImportUnitTest.cpp --- src/model_io/codecs/tests/URDFModelImportUnitTest.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp index b2636d0bbb..c2ab1794cd 100644 --- a/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp +++ b/src/model_io/codecs/tests/URDFModelImportUnitTest.cpp @@ -293,7 +293,6 @@ void checkaddSensorFramesAsAdditionalFramesOption() { parserOptions.addSensorFramesAsAdditionalFrames = false; mdlLoader.setParsingOptions(parserOptions); ASSERT_IS_TRUE(mdlLoader.loadModelFromString(urdf)); - std::cerr << mdlLoader.model().toString() << std::endl; ASSERT_IS_FALSE(mdlLoader.model().isFrameNameUsed("l_leg_ft")); } From 9bd5d7794e3214869edcec39102184c63b19a02c Mon Sep 17 00:00:00 2001 From: Silvio Traversaro Date: Fri, 5 Jul 2024 14:25:27 +0200 Subject: [PATCH 3/3] Update src/model_io/codecs/src/URDFDocument.cpp --- src/model_io/codecs/src/URDFDocument.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/src/model_io/codecs/src/URDFDocument.cpp b/src/model_io/codecs/src/URDFDocument.cpp index d1cf4f473a..8540d53d2d 100644 --- a/src/model_io/codecs/src/URDFDocument.cpp +++ b/src/model_io/codecs/src/URDFDocument.cpp @@ -133,7 +133,6 @@ namespace iDynTree { return false; } - std::cerr << "m_options.addSensorFramesAsAdditionalFrame:" << m_options.addSensorFramesAsAdditionalFrames << std::endl; if (m_options.addSensorFramesAsAdditionalFrames) { if (!addSensorFramesAsAdditionalFramesToModel(m_model)) {