From a18343a7f2baf361bc795cd9547743e14dc5ce82 Mon Sep 17 00:00:00 2001 From: Haidar Obeid <110574820+ufrhaidar@users.noreply.github.com> Date: Thu, 27 Jun 2024 14:15:11 +1000 Subject: [PATCH] ignore velocity limits for servo motor --- dart/constraint/JointConstraint.cpp | 69 +++++++++++++++-------------- 1 file changed, 36 insertions(+), 33 deletions(-) diff --git a/dart/constraint/JointConstraint.cpp b/dart/constraint/JointConstraint.cpp index 32ebec57fdfc1..c888b2d1fabea 100644 --- a/dart/constraint/JointConstraint.cpp +++ b/dart/constraint/JointConstraint.cpp @@ -289,42 +289,45 @@ void JointConstraint::update() continue; } - // Check lower velocity bound - const double vel_lb = std::max(velocityLowerLimits[i], vel_to_pos_lb); - const double vel_lb_error = velocities[i] - vel_lb; - if (vel_lb_error < 0.0) { - mDesiredVelocityChange[i] = -vel_lb_error; - mImpulseLowerBound[i] = 0.0; - mImpulseUpperBound[i] = static_cast(dInfinity); - - if (mActive[i]) { - ++(mLifeTime[i]); - } else { - mActive[i] = true; - mLifeTime[i] = 0; + // Ignore for Servo motor + if (mJoint->getActuatorType() != dynamics::Joint::SERVO) { + // Check lower velocity bound + const double vel_lb = std::max(velocityLowerLimits[i], vel_to_pos_lb); + const double vel_lb_error = velocities[i] - vel_lb; + if (vel_lb_error < 0.0) { + mDesiredVelocityChange[i] = -vel_lb_error; + mImpulseLowerBound[i] = 0.0; + mImpulseUpperBound[i] = static_cast(dInfinity); + + if (mActive[i]) { + ++(mLifeTime[i]); + } else { + mActive[i] = true; + mLifeTime[i] = 0; + } + + ++mDim; + continue; } - ++mDim; - continue; - } - - // Check upper velocity bound - const double vel_ub = std::min(velocityUpperLimits[i], vel_to_pos_ub); - const double vel_ub_error = velocities[i] - vel_ub; - if (vel_ub_error > 0.0) { - mDesiredVelocityChange[i] = -vel_ub_error; - mImpulseLowerBound[i] = -static_cast(dInfinity); - mImpulseUpperBound[i] = 0.0; - - if (mActive[i]) { - ++(mLifeTime[i]); - } else { - mActive[i] = true; - mLifeTime[i] = 0; + // Check upper velocity bound + const double vel_ub = std::min(velocityUpperLimits[i], vel_to_pos_ub); + const double vel_ub_error = velocities[i] - vel_ub; + if (vel_ub_error > 0.0) { + mDesiredVelocityChange[i] = -vel_ub_error; + mImpulseLowerBound[i] = -static_cast(dInfinity); + mImpulseUpperBound[i] = 0.0; + + if (mActive[i]) { + ++(mLifeTime[i]); + } else { + mActive[i] = true; + mLifeTime[i] = 0; + } + + ++mDim; + continue; } - - ++mDim; - continue; } }