Skip to content

Commit dcb3c98

Browse files
committed
feat(pid_longitudinal_controller): improve FF gain constant calculation
Signed-off-by: Berkay Karaman <brkay54@gmail.com>
1 parent cc4a4f6 commit dcb3c98

File tree

1 file changed

+5
-1
lines changed

1 file changed

+5
-1
lines changed

control/pid_longitudinal_controller/src/pid_longitudinal_controller.cpp

+5-1
Original file line numberDiff line numberDiff line change
@@ -1038,6 +1038,8 @@ PidLongitudinalController::StateAfterDelay PidLongitudinalController::predictedS
10381038
double PidLongitudinalController::applyVelocityFeedback(const ControlData & control_data)
10391039
{
10401040
// NOTE: Acceleration command is always positive even if the ego drives backward.
1041+
const double nearest_target_vel =
1042+
control_data.interpolated_traj.points.at(control_data.nearest_idx).longitudinal_velocity_mps;
10411043
const double vel_sign = (control_data.shift == Shift::Forward)
10421044
? 1.0
10431045
: (control_data.shift == Shift::Reverse ? -1.0 : 0.0);
@@ -1072,7 +1074,9 @@ double PidLongitudinalController::applyVelocityFeedback(const ControlData & cont
10721074
constexpr double ff_scale_max = 2.0; // for safety
10731075
constexpr double ff_scale_min = 0.5; // for safety
10741076
const double ff_scale = std::clamp(
1075-
std::abs(current_vel) / std::max(std::abs(target_motion.vel), 0.1), ff_scale_min, ff_scale_max);
1077+
1.0 + (abs(nearest_target_vel - current_vel) / std::max(abs(current_vel), 0.1)), ff_scale_min,
1078+
ff_scale_max);
1079+
10761080
const double ff_acc =
10771081
control_data.interpolated_traj.points.at(control_data.target_idx).acceleration_mps2 * ff_scale;
10781082

0 commit comments

Comments
 (0)