From 8ad7ed84f83aa9503f15705617fab71cead615a4 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Fri, 13 Sep 2024 14:41:09 +0200 Subject: [PATCH 1/7] optionally use initial base pose and foot pose for the first trajectory --- .../Planners/UnicycleTrajectoryGenerator.h | 26 ++++++ .../Planners/UnicycleTrajectoryPlanner.h | 34 ++++++- .../src/UnicycleTrajectoryGenerator.cpp | 27 +++++- .../src/UnicycleTrajectoryPlanner.cpp | 90 +++++++++++++++++-- 4 files changed, 166 insertions(+), 11 deletions(-) diff --git a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h index 55f012cab5..fea8449e8a 100644 --- a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h +++ b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h @@ -116,6 +116,32 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final */ bool initialize(std::weak_ptr handler) override; + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param initialBasePosition Initial position of the base. + * @param leftToRightTransform Transformation Matrix between the left and right foot. + */ + bool initialize(std::weak_ptr handler, + const Eigen::Ref& initialBasePosition, + const manif::SE3d& leftToRightTransform); + + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param leftToRightTransform Transformation Matrix between the left and right foot. + */ + bool initialize(std::weak_ptr handler, + const manif::SE3d& leftToRightTransform); + + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param initialBasePosition Initial position of the base. + */ + bool initialize(std::weak_ptr handler, + const Eigen::Ref& initialBasePosition); + /** * @brief Get the output of the planner. * @return Output of the planner. diff --git a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h index 2d2f64d7fe..65cf63ebbd 100644 --- a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h +++ b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h @@ -143,6 +143,8 @@ struct BipedalLocomotion::Planners::UnicycleTrajectoryPlannerParameters int rightContactFrameIndex; /**< Index of the right foot contact frame */ std::string rightContactFrameName; /**< Name of the right foot contact frame */ + + bool swingLeft; /**< Perform the first step with the left foot */ }; /** @@ -238,6 +240,32 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryPlanner final bool initialize(std::weak_ptr handler) override; // clang-format on + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param initialBasePosition Initial position of the base. + * @param leftToRightTransform Transformation Matrix between the left and right foot. + */ + bool initialize(std::weak_ptr handler, + const Eigen::Ref& initialBasePosition, + const manif::SE3d& leftToRightTransform); + + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param leftToRightTransform Transformation Matrix between the left and right foot. + */ + bool initialize(std::weak_ptr handler, + const manif::SE3d& leftToRightTransform); + + /** + * @brief Initialize the planner. + * @param handler Pointer to the parameter handler. + * @param initialBasePosition Initial position of the base. + */ + bool initialize(std::weak_ptr handler, + const Eigen::Ref& initialBasePosition); + /** * Get the output of the planner. * @return The output of the planner. @@ -291,8 +319,12 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryPlanner final /** * Generate the first trajectory. + * @param initialBasePosition Initial position of the base. + * @param leftToRightTransform Transformation Matrix between the left and right foot. */ - bool generateFirstTrajectory(); + bool generateFirstTrajectory(const Eigen::Ref& initialBasePosition + = Eigen::Vector3d::Zero(), + const manif::SE3d& leftToRightTransform = manif::SE3d::Identity()); }; #endif // BIPEDAL_LOCOMOTION_PLANNERS_UNICYCLE_PLANNER_H diff --git a/src/Planners/src/UnicycleTrajectoryGenerator.cpp b/src/Planners/src/UnicycleTrajectoryGenerator.cpp index 30e76a78e4..3b2beaf8ea 100644 --- a/src/Planners/src/UnicycleTrajectoryGenerator.cpp +++ b/src/Planners/src/UnicycleTrajectoryGenerator.cpp @@ -182,8 +182,30 @@ bool Planners::UnicycleTrajectoryGenerator::setRobotContactFrames(const iDynTree return true; } +bool Planners::UnicycleTrajectoryGenerator::initialize( + std::weak_ptr handler, + const manif::SE3d& leftToRightTransform) +{ + return initialize(handler, Eigen::Vector3d::Zero(), leftToRightTransform); +} + +bool Planners::UnicycleTrajectoryGenerator::initialize( + std::weak_ptr handler, + const Eigen::Ref& initialBasePosition) +{ + return initialize(handler, initialBasePosition, manif::SE3d::Identity()); +} + bool Planners::UnicycleTrajectoryGenerator::initialize( std::weak_ptr handler) +{ + return initialize(handler, Eigen::Vector3d::Zero(), manif::SE3d::Identity()); +} + +bool Planners::UnicycleTrajectoryGenerator::initialize( + std::weak_ptr handler, + const Eigen::Ref& initialBasePosition, + const manif::SE3d& leftToRightTransform) { constexpr auto logPrefix = "[UnicycleTrajectoryGenerator::initialize]"; @@ -250,7 +272,10 @@ bool Planners::UnicycleTrajectoryGenerator::initialize( m_pImpl->newTrajectoryRequired = false; // Initialize the blf unicycle planner - ok = ok && m_pImpl->unicycleTrajectoryPlanner.initialize(ptr); + ok = ok + && m_pImpl->unicycleTrajectoryPlanner.initialize(ptr, + initialBasePosition, + leftToRightTransform); // Initialize contact frames std::string leftContactFrameName, rightContactFrameName; diff --git a/src/Planners/src/UnicycleTrajectoryPlanner.cpp b/src/Planners/src/UnicycleTrajectoryPlanner.cpp index c583dce347..077fcaf2fe 100644 --- a/src/Planners/src/UnicycleTrajectoryPlanner.cpp +++ b/src/Planners/src/UnicycleTrajectoryPlanner.cpp @@ -206,8 +206,30 @@ int Planners::UnicycleTrajectoryPlanner::getRightContactFrameIndex() const return m_pImpl->parameters.rightContactFrameIndex; } +bool Planners::UnicycleTrajectoryPlanner::initialize( + std::weak_ptr handler, + const manif::SE3d& leftToRightTransform) +{ + return initialize(handler, Eigen::Vector3d::Zero(), leftToRightTransform); +} + +bool Planners::UnicycleTrajectoryPlanner::initialize( + std::weak_ptr handler, + const Eigen::Ref& initialBasePosition) +{ + return initialize(handler, initialBasePosition, manif::SE3d::Identity()); +} + bool Planners::UnicycleTrajectoryPlanner::initialize( std::weak_ptr handler) +{ + return initialize(handler, Eigen::Vector3d::Zero(), manif::SE3d::Identity()); +} + +bool Planners::UnicycleTrajectoryPlanner::initialize( + std::weak_ptr handler, + const Eigen::Ref& initialBasePosition, + const manif::SE3d& leftToRightTransform) { constexpr auto logPrefix = "[UnicycleTrajectoryPlanner::initialize]"; @@ -270,7 +292,6 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( Eigen::Vector2d saturationFactors; - bool startWithLeft{true}; bool startWithSameFoot{true}; bool terminalStep{true}; @@ -325,7 +346,7 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( = iDynTree::deg2rad(m_pImpl->parameters.leftYawDeltaInRad); m_pImpl->parameters.rightYawDeltaInRad = iDynTree::deg2rad(m_pImpl->parameters.rightYawDeltaInRad); - ok = ok && loadParamWithFallback("swingLeft", startWithLeft, false); + ok = ok && loadParamWithFallback("swingLeft", m_pImpl->parameters.swingLeft, false); ok = ok && loadParamWithFallback("startAlwaysSameFoot", startWithSameFoot, true); ok = ok && loadParamWithFallback("terminalStep", terminalStep, true); ok = ok && loadParam("mergePointRatios", mergePointRatios); @@ -365,7 +386,7 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( unicyclePlanner->setLeftFootYawOffsetInRadians(m_pImpl->parameters.leftYawDeltaInRad); unicyclePlanner->setRightFootYawOffsetInRadians(m_pImpl->parameters.rightYawDeltaInRad); unicyclePlanner->addTerminalStep(terminalStep); - unicyclePlanner->startWithLeft(startWithLeft); + unicyclePlanner->startWithLeft(m_pImpl->parameters.swingLeft); unicyclePlanner->resetStartingFootIfStill(startWithSameFoot); UnicycleController unicycleController; @@ -426,7 +447,16 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( feetCubicSplineGenerator->setStepHeight(stepHeight); // generateFirstTrajectory; - ok = ok && generateFirstTrajectory(); + if (leftToRightTransform == manif::SE3d::Identity()) + { + // if the transform is the identity, the nominal width is used as distance between the feet + manif::SE3d tmpTransform = manif::SE3d::Identity(); + tmpTransform.translation(Eigen::Vector3d(0.0, -m_pImpl->parameters.nominalWidth, 0.0)); + ok = ok && generateFirstTrajectory(initialBasePosition, tmpTransform); + } else + { + ok = ok && generateFirstTrajectory(initialBasePosition, leftToRightTransform); + } // debug information auto leftSteps = m_pImpl->generator.getLeftFootPrint()->getSteps(); @@ -767,7 +797,9 @@ bool Planners::UnicycleTrajectoryPlanner::advance() return true; } -bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajectory() +bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajectory( + const Eigen::Ref& initialBasePosition, + const manif::SE3d& leftToRightTransform) { constexpr auto logPrefix = "[UnicycleTrajectoryPlanner::generateFirstTrajectory]"; @@ -788,8 +820,10 @@ bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajec // at the beginning ergoCub has to stop Eigen::Vector2d m_personFollowingDesiredPoint; - m_personFollowingDesiredPoint(0) = m_pImpl->parameters.referencePointDistance(0); - m_personFollowingDesiredPoint(1) = m_pImpl->parameters.referencePointDistance(1); + m_personFollowingDesiredPoint(0) + = m_pImpl->parameters.referencePointDistance(0) + initialBasePosition(0); + m_personFollowingDesiredPoint(1) + = m_pImpl->parameters.referencePointDistance(1) + initialBasePosition(1); // add the initial point if (!unicyclePlanner @@ -811,12 +845,50 @@ bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajec return false; } + // add real position of the feet + std::shared_ptr left, right; + + left = m_pImpl->generator.getLeftFootPrint(); + left->clearSteps(); + right = m_pImpl->generator.getRightFootPrint(); + right->clearSteps(); + + Eigen::Vector2d leftPosition, rightPosition; + double leftAngle, rightAngle; + + // if the standing foot is the right -> the unicycle starts parallel to the right foot + if (m_pImpl->parameters.swingLeft) + { + rightPosition(0) = initialBasePosition(0); + rightPosition(1) + = initialBasePosition(1) - leftToRightTransform.inverse().translation()(1) / 2; + rightAngle = 0; + right->addStep(iDynTree::Vector2(rightPosition), rightAngle, 0.0); + + leftPosition(0) = initialBasePosition(0) + leftToRightTransform.inverse().translation()(0); + leftPosition(1) + = initialBasePosition(1) + leftToRightTransform.inverse().translation()(1) / 2; + // z-y'-x" (intrinsic rotations) -> yaw, pitch, roll + leftAngle = leftToRightTransform.inverse().rotation().eulerAngles(2, 1, 0)(0); + left->addStep(iDynTree::Vector2(leftPosition), leftAngle, 0.0); + } else + { + leftPosition(0) = initialBasePosition(0); + leftPosition(1) = initialBasePosition(1) - leftToRightTransform.translation()(1) / 2; + leftAngle = 0; + left->addStep(iDynTree::Vector2(leftPosition), leftAngle, 0.0); + + rightPosition(0) = initialBasePosition(0) + leftToRightTransform.translation()(0); + rightPosition(1) = initialBasePosition(1) + leftToRightTransform.translation()(1) / 2; + // z-y'-x" (intrinsic rotations) -> yaw, pitch, roll + rightAngle = leftToRightTransform.rotation().eulerAngles(2, 1, 0)(0); + right->addStep(iDynTree::Vector2(rightPosition), rightAngle, 0.0); + } + // generate the first trajectories if (!m_pImpl->generator.generate(initTime, dt, endTime)) { - log()->error("{} Error while computing the first trajectories.", logPrefix); - return false; } From ae70a7b5b7e9cc519038cf45830dfd07db4a7474 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Fri, 13 Sep 2024 18:50:32 +0200 Subject: [PATCH 2/7] remove trailing white spaces --- .../Planners/UnicycleTrajectoryGenerator.h | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h index fea8449e8a..5f414cf4cb 100644 --- a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h +++ b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h @@ -122,8 +122,8 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final * @param initialBasePosition Initial position of the base. * @param leftToRightTransform Transformation Matrix between the left and right foot. */ - bool initialize(std::weak_ptr handler, - const Eigen::Ref& initialBasePosition, + bool initialize(std::weak_ptr handler, + const Eigen::Ref& initialBasePosition, const manif::SE3d& leftToRightTransform); /** @@ -131,7 +131,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final * @param handler Pointer to the parameter handler. * @param leftToRightTransform Transformation Matrix between the left and right foot. */ - bool initialize(std::weak_ptr handler, + bool initialize(std::weak_ptr handler, const manif::SE3d& leftToRightTransform); /** @@ -139,7 +139,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final * @param handler Pointer to the parameter handler. * @param initialBasePosition Initial position of the base. */ - bool initialize(std::weak_ptr handler, + bool initialize(std::weak_ptr handler, const Eigen::Ref& initialBasePosition); /** From 38fceca5bf343333bca23bbc30b4355666d0e22e Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Fri, 13 Sep 2024 19:20:16 +0200 Subject: [PATCH 3/7] update changelog --- CHANGELOG.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index bed9742c52..f6f93c54b6 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,14 @@ # Changelog All notable changes to this project are documented in this file. +## [unreleased] +### Added +- Add the possibility to initialize the base position and the feet pose in the `unicycleTrajectoryGenerator` (https://github.com/ami-iit/bipedal-locomotion-framework/pull/887) + +### Changed +### Fixed +### Removed + ## [0.19.0] - 2024-09-06 ### Added - Added Vector Collection Server for publishing information for real-time users in the YARPRobotLoggerDevice (https://github.com/ami-iit/bipedal-locomotion-framework/pull/796) From 33aaaf1692290d3a6c667b8fb62bb66798abab03 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Mon, 16 Sep 2024 12:04:36 +0200 Subject: [PATCH 4/7] improve resetting of contact list --- .../BipedalLocomotion/Contacts/ContactList.h | 11 ++++++++++ src/Contacts/src/ContactList.cpp | 21 +++++++++++++++++++ .../src/UnicycleTrajectoryGenerator.cpp | 6 +----- 3 files changed, 33 insertions(+), 5 deletions(-) diff --git a/src/Contacts/include/BipedalLocomotion/Contacts/ContactList.h b/src/Contacts/include/BipedalLocomotion/Contacts/ContactList.h index 359efe0dd5..002db1b757 100644 --- a/src/Contacts/include/BipedalLocomotion/Contacts/ContactList.h +++ b/src/Contacts/include/BipedalLocomotion/Contacts/ContactList.h @@ -243,6 +243,17 @@ class ContactList */ const_iterator getPresentContact(const std::chrono::nanoseconds& time) const; + /** + * @brief Get the contact given the time. + * + * It returns the contact with the highest deactivation time lower than time. + * If no contacts have a deactivation time lower than time, it returns an iterator to the end. + * @param time The present time. + * @return an iterator to the last contact having an activation time lower than time. + * If no contact satisfies this condition, it returns a pointer to the end. + */ + const_iterator getPreviousContact(const std::chrono::nanoseconds& time) const; + /** * @brief Clear all the steps, except the one returned by getPresentContact * @param time The present time. diff --git a/src/Contacts/src/ContactList.cpp b/src/Contacts/src/ContactList.cpp index 99d26f8289..9125e8ff16 100644 --- a/src/Contacts/src/ContactList.cpp +++ b/src/Contacts/src/ContactList.cpp @@ -264,6 +264,27 @@ ContactList::const_iterator ContactList::getNextContact(const std::chrono::nanos return nextContact; } +ContactList::const_iterator +ContactList::getPreviousContact(const std::chrono::nanoseconds& time) const +{ + // With the reverse iterator we find the last step such that the deactivation time is smaller + // than time + ContactList::const_reverse_iterator presentReverse + = std::find_if(rbegin(), rend(), [time](const PlannedContact& a) -> bool { + return a.deactivationTime < time; + }); + + if (presentReverse == rend()) + { + // No contact has activation time lower than the specified time. + return end(); + } + + return --(presentReverse.base()); // This is to convert a reverse iterator to a forward + // iterator. The -- is because base() returns a forward + // iterator to the next element. +} + bool ContactList::keepOnlyPresentContact(const std::chrono::nanoseconds& time) { ContactList::const_iterator dropPoint = getPresentContact(time); diff --git a/src/Planners/src/UnicycleTrajectoryGenerator.cpp b/src/Planners/src/UnicycleTrajectoryGenerator.cpp index 3b2beaf8ea..da64d6e935 100644 --- a/src/Planners/src/UnicycleTrajectoryGenerator.cpp +++ b/src/Planners/src/UnicycleTrajectoryGenerator.cpp @@ -118,7 +118,6 @@ class Planners::UnicycleTrajectoryGenerator::Impl * @param currentContactList The current contact list, being generated. */ static void resetContactList(const std::chrono::nanoseconds& time, - const std::chrono::nanoseconds& minStepDuration, const Contacts::ContactList& previousContactList, Contacts::ContactList& currentContactList); }; @@ -348,11 +347,9 @@ Planners::UnicycleTrajectoryGenerator::getOutput() const if (!m_pImpl->output.contactPhaseList.lists().empty()) { m_pImpl->resetContactList(m_pImpl->time - m_pImpl->parameters.dt, - m_pImpl->unicycleTrajectoryPlanner.getMinStepDuration(), m_pImpl->output.contactPhaseList.lists().at("left_foot"), leftContactList); m_pImpl->resetContactList(m_pImpl->time - m_pImpl->parameters.dt, - m_pImpl->unicycleTrajectoryPlanner.getMinStepDuration(), m_pImpl->output.contactPhaseList.lists().at("right_foot"), rightContactList); } @@ -833,7 +830,6 @@ bool BipedalLocomotion::Planners::UnicycleTrajectoryGenerator::generateFirstTraj void Planners::UnicycleTrajectoryGenerator::Impl::resetContactList( const std::chrono::nanoseconds& time, - const std::chrono::nanoseconds& minStepDuration, const Contacts::ContactList& previousContactList, Contacts::ContactList& currentContactList) { @@ -850,7 +846,7 @@ void Planners::UnicycleTrajectoryGenerator::Impl::resetContactList( // If not, try to get the last active if (activeContact == previousContactList.end()) { - activeContact = previousContactList.getActiveContact(time - minStepDuration / 2); + activeContact = previousContactList.getPreviousContact(time); } // if any active contact found, add it to the current contact list From f45e436e603ecf8f7b2d123d1a9a7eda75495f68 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Mon, 16 Sep 2024 16:30:24 +0200 Subject: [PATCH 5/7] use iDyntree to compute yaw from rotation matrix --- src/Planners/src/UnicycleTrajectoryPlanner.cpp | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/src/Planners/src/UnicycleTrajectoryPlanner.cpp b/src/Planners/src/UnicycleTrajectoryPlanner.cpp index 077fcaf2fe..c34026390b 100644 --- a/src/Planners/src/UnicycleTrajectoryPlanner.cpp +++ b/src/Planners/src/UnicycleTrajectoryPlanner.cpp @@ -17,8 +17,10 @@ #include #include + #include #include +#include #include #include @@ -868,8 +870,9 @@ bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajec leftPosition(0) = initialBasePosition(0) + leftToRightTransform.inverse().translation()(0); leftPosition(1) = initialBasePosition(1) + leftToRightTransform.inverse().translation()(1) / 2; - // z-y'-x" (intrinsic rotations) -> yaw, pitch, roll - leftAngle = leftToRightTransform.inverse().rotation().eulerAngles(2, 1, 0)(0); + iDynTree::Rotation leftToRightRotation + = iDynTree::Rotation(leftToRightTransform.rotation()); + leftAngle = leftToRightRotation.asRPY()(2); left->addStep(iDynTree::Vector2(leftPosition), leftAngle, 0.0); } else { @@ -880,8 +883,9 @@ bool BipedalLocomotion::Planners::UnicycleTrajectoryPlanner::generateFirstTrajec rightPosition(0) = initialBasePosition(0) + leftToRightTransform.translation()(0); rightPosition(1) = initialBasePosition(1) + leftToRightTransform.translation()(1) / 2; - // z-y'-x" (intrinsic rotations) -> yaw, pitch, roll - rightAngle = leftToRightTransform.rotation().eulerAngles(2, 1, 0)(0); + iDynTree::Rotation leftToRightRotation + = iDynTree::Rotation(leftToRightTransform.rotation()); + rightAngle = leftToRightRotation.asRPY()(2); right->addStep(iDynTree::Vector2(rightPosition), rightAngle, 0.0); } From 94f32efac92b5ae49940ac8d59d423ae1ad95846 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Wed, 18 Sep 2024 11:29:53 +0200 Subject: [PATCH 6/7] fix ambiguity of function signatures --- .../BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h | 4 ++-- .../BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h | 4 ++-- src/Planners/src/UnicycleTrajectoryGenerator.cpp | 4 ++-- src/Planners/src/UnicycleTrajectoryPlanner.cpp | 4 ++-- 4 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h index 5f414cf4cb..91bf82596b 100644 --- a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h +++ b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryGenerator.h @@ -123,7 +123,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final * @param leftToRightTransform Transformation Matrix between the left and right foot. */ bool initialize(std::weak_ptr handler, - const Eigen::Ref& initialBasePosition, + const Eigen::Vector3d& initialBasePosition, const manif::SE3d& leftToRightTransform); /** @@ -140,7 +140,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryGenerator final * @param initialBasePosition Initial position of the base. */ bool initialize(std::weak_ptr handler, - const Eigen::Ref& initialBasePosition); + const Eigen::Vector3d& initialBasePosition); /** * @brief Get the output of the planner. diff --git a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h index 65cf63ebbd..d64c4e3f4d 100644 --- a/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h +++ b/src/Planners/include/BipedalLocomotion/Planners/UnicycleTrajectoryPlanner.h @@ -247,7 +247,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryPlanner final * @param leftToRightTransform Transformation Matrix between the left and right foot. */ bool initialize(std::weak_ptr handler, - const Eigen::Ref& initialBasePosition, + const Eigen::Vector3d& initialBasePosition, const manif::SE3d& leftToRightTransform); /** @@ -264,7 +264,7 @@ class BipedalLocomotion::Planners::UnicycleTrajectoryPlanner final * @param initialBasePosition Initial position of the base. */ bool initialize(std::weak_ptr handler, - const Eigen::Ref& initialBasePosition); + const Eigen::Vector3d& initialBasePosition); /** * Get the output of the planner. diff --git a/src/Planners/src/UnicycleTrajectoryGenerator.cpp b/src/Planners/src/UnicycleTrajectoryGenerator.cpp index da64d6e935..aaa0b30c45 100644 --- a/src/Planners/src/UnicycleTrajectoryGenerator.cpp +++ b/src/Planners/src/UnicycleTrajectoryGenerator.cpp @@ -190,7 +190,7 @@ bool Planners::UnicycleTrajectoryGenerator::initialize( bool Planners::UnicycleTrajectoryGenerator::initialize( std::weak_ptr handler, - const Eigen::Ref& initialBasePosition) + const Eigen::Vector3d& initialBasePosition) { return initialize(handler, initialBasePosition, manif::SE3d::Identity()); } @@ -203,7 +203,7 @@ bool Planners::UnicycleTrajectoryGenerator::initialize( bool Planners::UnicycleTrajectoryGenerator::initialize( std::weak_ptr handler, - const Eigen::Ref& initialBasePosition, + const Eigen::Vector3d& initialBasePosition, const manif::SE3d& leftToRightTransform) { constexpr auto logPrefix = "[UnicycleTrajectoryGenerator::initialize]"; diff --git a/src/Planners/src/UnicycleTrajectoryPlanner.cpp b/src/Planners/src/UnicycleTrajectoryPlanner.cpp index c34026390b..66bea056e8 100644 --- a/src/Planners/src/UnicycleTrajectoryPlanner.cpp +++ b/src/Planners/src/UnicycleTrajectoryPlanner.cpp @@ -217,7 +217,7 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( bool Planners::UnicycleTrajectoryPlanner::initialize( std::weak_ptr handler, - const Eigen::Ref& initialBasePosition) + const Eigen::Vector3d& initialBasePosition) { return initialize(handler, initialBasePosition, manif::SE3d::Identity()); } @@ -230,7 +230,7 @@ bool Planners::UnicycleTrajectoryPlanner::initialize( bool Planners::UnicycleTrajectoryPlanner::initialize( std::weak_ptr handler, - const Eigen::Ref& initialBasePosition, + const Eigen::Vector3d& initialBasePosition, const manif::SE3d& leftToRightTransform) { constexpr auto logPrefix = "[UnicycleTrajectoryPlanner::initialize]"; From f1ed05b04e6e121a6553ed407de14f10ca540610 Mon Sep 17 00:00:00 2001 From: Lorenzo Date: Wed, 18 Sep 2024 11:43:51 +0200 Subject: [PATCH 7/7] add unit tests --- .../tests/UnicycleTrajectoryGeneratorTest.cpp | 137 +++++++++++++++++- 1 file changed, 136 insertions(+), 1 deletion(-) diff --git a/src/Planners/tests/UnicycleTrajectoryGeneratorTest.cpp b/src/Planners/tests/UnicycleTrajectoryGeneratorTest.cpp index ef92bed209..ae3c1beb06 100644 --- a/src/Planners/tests/UnicycleTrajectoryGeneratorTest.cpp +++ b/src/Planners/tests/UnicycleTrajectoryGeneratorTest.cpp @@ -32,10 +32,13 @@ std::shared_ptr params() handler->setParameter("leftContactFrameName", "l_sole"); handler->setParameter("rightContactFrameName", "r_sole"); + // Override some default parameters + handler->setParameter("nominalWidth", 0.2); + return handler; } -TEST_CASE("UnicycleTrajectoryGeneratorTest") +TEST_CASE("Simple run", "[UnicycleTrajectoryGenerator]") { auto jointsList @@ -73,3 +76,135 @@ TEST_CASE("UnicycleTrajectoryGeneratorTest") REQUIRE(output.contactPhaseList.size() == 1); } + +TEST_CASE("Initialization with Feet Realitve Pose", "[UnicycleTrajectoryGenerator]") +{ + + auto jointsList + = std::vector{"l_hip_pitch", "l_hip_roll", "l_hip_yaw", + "l_knee", "l_ankle_pitch", "l_ankle_roll", + "r_hip_pitch", "r_hip_roll", "r_hip_yaw", + "r_knee", "r_ankle_pitch", "r_ankle_roll", + "torso_pitch", "torso_roll", "torso_yaw", + "neck_pitch", "neck_roll", "neck_yaw", + "l_shoulder_pitch", "l_shoulder_roll", "l_shoulder_yaw", + "l_elbow", "r_shoulder_pitch", "r_shoulder_roll", + "r_shoulder_yaw", "r_elbow"}; + + iDynTree::ModelLoader ml; + REQUIRE(ml.loadReducedModelFromFile(getRobotModelPath(), jointsList)); + + const auto handler = params(); + + BipedalLocomotion::Planners::UnicycleTrajectoryGenerator unicycleTrajectoryGenerator; + + auto leftToRightTransform = manif::SE3d::Identity(); + double nominalWidth{}; + handler->getParameter("nominalWidth", nominalWidth); + leftToRightTransform.translation(Eigen::Vector3d(0.0, -nominalWidth, 0.0)); + + REQUIRE(unicycleTrajectoryGenerator.initialize(handler, leftToRightTransform)); + + REQUIRE(unicycleTrajectoryGenerator.setRobotContactFrames(ml.model())); + + UnicycleTrajectoryGeneratorInput input + = UnicycleTrajectoryGeneratorInput::generateDummyUnicycleTrajectoryGeneratorInput(); + + UnicycleTrajectoryGeneratorOutput output; + + REQUIRE(unicycleTrajectoryGenerator.setInput(input)); + REQUIRE(unicycleTrajectoryGenerator.advance()); + REQUIRE(unicycleTrajectoryGenerator.isOutputValid()); + + output = unicycleTrajectoryGenerator.getOutput(); + + REQUIRE(output.contactPhaseList.size() == 1); +} + +TEST_CASE("Initialization with Base Position", "[UnicycleTrajectoryGenerator]") +{ + + auto jointsList + = std::vector{"l_hip_pitch", "l_hip_roll", "l_hip_yaw", + "l_knee", "l_ankle_pitch", "l_ankle_roll", + "r_hip_pitch", "r_hip_roll", "r_hip_yaw", + "r_knee", "r_ankle_pitch", "r_ankle_roll", + "torso_pitch", "torso_roll", "torso_yaw", + "neck_pitch", "neck_roll", "neck_yaw", + "l_shoulder_pitch", "l_shoulder_roll", "l_shoulder_yaw", + "l_elbow", "r_shoulder_pitch", "r_shoulder_roll", + "r_shoulder_yaw", "r_elbow"}; + + iDynTree::ModelLoader ml; + REQUIRE(ml.loadReducedModelFromFile(getRobotModelPath(), jointsList)); + + const auto handler = params(); + + BipedalLocomotion::Planners::UnicycleTrajectoryGenerator unicycleTrajectoryGenerator; + + Eigen::Vector3d basePosition = Eigen::Vector3d(0.0, 0.0, 0.7); + + REQUIRE(unicycleTrajectoryGenerator.initialize(handler, basePosition)); + + REQUIRE(unicycleTrajectoryGenerator.setRobotContactFrames(ml.model())); + + UnicycleTrajectoryGeneratorInput input + = UnicycleTrajectoryGeneratorInput::generateDummyUnicycleTrajectoryGeneratorInput(); + + UnicycleTrajectoryGeneratorOutput output; + + REQUIRE(unicycleTrajectoryGenerator.setInput(input)); + REQUIRE(unicycleTrajectoryGenerator.advance()); + REQUIRE(unicycleTrajectoryGenerator.isOutputValid()); + + output = unicycleTrajectoryGenerator.getOutput(); + + REQUIRE(output.contactPhaseList.size() == 1); +} + +TEST_CASE("Initialization with Base Position and Feet Relative Pose", + "[UnicycleTrajectoryGenerator]") +{ + + auto jointsList + = std::vector{"l_hip_pitch", "l_hip_roll", "l_hip_yaw", + "l_knee", "l_ankle_pitch", "l_ankle_roll", + "r_hip_pitch", "r_hip_roll", "r_hip_yaw", + "r_knee", "r_ankle_pitch", "r_ankle_roll", + "torso_pitch", "torso_roll", "torso_yaw", + "neck_pitch", "neck_roll", "neck_yaw", + "l_shoulder_pitch", "l_shoulder_roll", "l_shoulder_yaw", + "l_elbow", "r_shoulder_pitch", "r_shoulder_roll", + "r_shoulder_yaw", "r_elbow"}; + + iDynTree::ModelLoader ml; + REQUIRE(ml.loadReducedModelFromFile(getRobotModelPath(), jointsList)); + + const auto handler = params(); + + BipedalLocomotion::Planners::UnicycleTrajectoryGenerator unicycleTrajectoryGenerator; + + auto leftToRightTransform = manif::SE3d::Identity(); + double nominalWidth{}; + handler->getParameter("nominalWidth", nominalWidth); + leftToRightTransform.translation(Eigen::Vector3d(0.0, -nominalWidth, 0.0)); + + Eigen::Vector3d basePosition = Eigen::Vector3d(0.0, 0.0, 0.7); + + REQUIRE(unicycleTrajectoryGenerator.initialize(handler, basePosition, leftToRightTransform)); + + REQUIRE(unicycleTrajectoryGenerator.setRobotContactFrames(ml.model())); + + UnicycleTrajectoryGeneratorInput input + = UnicycleTrajectoryGeneratorInput::generateDummyUnicycleTrajectoryGeneratorInput(); + + UnicycleTrajectoryGeneratorOutput output; + + REQUIRE(unicycleTrajectoryGenerator.setInput(input)); + REQUIRE(unicycleTrajectoryGenerator.advance()); + REQUIRE(unicycleTrajectoryGenerator.isOutputValid()); + + output = unicycleTrajectoryGenerator.getOutput(); + + REQUIRE(output.contactPhaseList.size() == 1); +}