Skip to content

Commit

Permalink
fix(accel_brake_map_calibrator): fix accel_brake_map_calibrator not t…
Browse files Browse the repository at this point in the history
…o output invalid maps (autowarefoundation#6992)

Signed-off-by: tomoya.kimura <[email protected]>
  • Loading branch information
tkimura4 authored and h-ohta committed May 14, 2024
1 parent a1762eb commit bd81d4c
Showing 1 changed file with 7 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -703,17 +703,19 @@ void AccelBrakeMapCalibrator::takeConsistencyOfAccelMap()
{
const double bit = std::pow(1e-01, precision_);
for (std::size_t ped_idx = 0; ped_idx < update_accel_map_value_.size() - 1; ped_idx++) {
for (std::size_t vel_idx = 0; vel_idx < update_accel_map_value_.at(0).size() - 1; vel_idx++) {
for (std::size_t vel_idx = update_accel_map_value_.at(0).size() - 1;; vel_idx--) {
if (vel_idx == 0) break;

const double current_acc = update_accel_map_value_.at(ped_idx).at(vel_idx);
const double next_ped_acc = update_accel_map_value_.at(ped_idx + 1).at(vel_idx);
const double next_vel_acc = update_accel_map_value_.at(ped_idx).at(vel_idx + 1);
const double prev_vel_acc = update_accel_map_value_.at(ped_idx).at(vel_idx - 1);

if (current_acc <= next_vel_acc) {
if (current_acc + bit >= prev_vel_acc) {
// the higher the velocity, the lower the acceleration
update_accel_map_value_.at(ped_idx).at(vel_idx + 1) = current_acc - bit;
update_accel_map_value_.at(ped_idx).at(vel_idx - 1) = current_acc + bit;
}

if (current_acc >= next_ped_acc) {
if (current_acc + bit >= next_ped_acc) {
// the higher the accel pedal, the higher the acceleration
update_accel_map_value_.at(ped_idx + 1).at(vel_idx) = current_acc + bit;
}
Expand Down

0 comments on commit bd81d4c

Please sign in to comment.