Skip to content

Commit

Permalink
feat(intersection): distinguish 1st/2nd attention lanelet
Browse files Browse the repository at this point in the history
Signed-off-by: Mamoru Sobue <mamoru.sobue@tier4.jp>
  • Loading branch information
soblin committed Jan 10, 2024
1 parent 142bc49 commit 94f27ea
Show file tree
Hide file tree
Showing 3 changed files with 159 additions and 38 deletions.
16 changes: 16 additions & 0 deletions planning/behavior_velocity_intersection_module/src/debug.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -188,6 +188,22 @@ visualization_msgs::msg::MarkerArray IntersectionModule::createDebugMarkerArray(
&debug_marker_array);
}

if (debug_data_.first_attention_area) {
appendMarkerArray(
createLaneletPolygonsMarkerArray(
{debug_data_.first_attention_area.value()}, "first_attention_area", lane_id_, 1, 0.647,
0.0),
&debug_marker_array, now);
}

if (debug_data_.second_attention_area) {
appendMarkerArray(
createLaneletPolygonsMarkerArray(
{debug_data_.second_attention_area.value()}, "second_attention_area", lane_id_, 1, 0.647,
0.0),
&debug_marker_array, now);
}

Check warning on line 206 in planning/behavior_velocity_intersection_module/src/debug.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

❌ Getting worse: Complex Method

IntersectionModule::createDebugMarkerArray increases in cyclomatic complexity from 12 to 14, threshold = 9. This function has many conditional statements (e.g. if, for, while), leading to lower code health. Avoid adding more conditionals and code to it without refactoring.
if (debug_data_.stuck_vehicle_detect_area) {
appendMarkerArray(
debug::createPolygonMarkerArray(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1008,7 +1008,8 @@ IntersectionModule::DecisionResult IntersectionModule::modifyPathVelocityDetail(
getTrafficPrioritizedLevel(assigned_lanelet, planner_data_->traffic_light_id_map);
const bool is_prioritized =
traffic_prioritized_level == TrafficPrioritizedLevel::FULLY_PRIORITIZED;
intersection_lanelets.update(is_prioritized, interpolated_path_info, footprint, baselink2front);
intersection_lanelets.update(
is_prioritized, interpolated_path_info, footprint, baselink2front, routing_graph_ptr);

// this is abnormal
const auto & conflicting_lanelets = intersection_lanelets.conflicting();
Expand All @@ -1019,6 +1020,7 @@ IntersectionModule::DecisionResult IntersectionModule::modifyPathVelocityDetail(
}
const auto & first_conflicting_lane = first_conflicting_lane_opt.value();
const auto & first_conflicting_area = first_conflicting_area_opt.value();
const auto & second_attention_area_opt = intersection_lanelets.second_attention_area();

// generate all stop line candidates
// see the doc for struct IntersectionStopLines
Expand All @@ -1029,16 +1031,20 @@ IntersectionModule::DecisionResult IntersectionModule::modifyPathVelocityDetail(
: first_conflicting_lane;

const auto intersection_stoplines_opt = generateIntersectionStopLines(
assigned_lanelet, first_conflicting_area, dummy_first_attention_lane, interpolated_path_info,
path);
assigned_lanelet, first_conflicting_area, dummy_first_attention_lane, second_attention_area_opt,
interpolated_path_info, path);
if (!intersection_stoplines_opt) {
return IntersectionModule::Indecisive{"failed to generate intersection_stoplines"};
}
const auto & intersection_stoplines = intersection_stoplines_opt.value();
const auto
[closest_idx, stuck_stopline_idx_opt, default_stopline_idx_opt,
first_attention_stopline_idx_opt, occlusion_peeking_stopline_idx_opt,
default_pass_judge_line_idx, occlusion_wo_tl_pass_judge_line_idx] = intersection_stoplines;
const auto closest_idx = intersection_stoplines.closest_idx;
const auto stuck_stopline_idx_opt = intersection_stoplines.stuck_stopline;
const auto default_stopline_idx_opt = intersection_stoplines.default_stopline;
const auto first_attention_stopline_idx_opt = intersection_stoplines.first_attention_stopline;
const auto occlusion_peeking_stopline_idx_opt = intersection_stoplines.occlusion_peeking_stopline;
const auto default_pass_judge_line_idx = intersection_stoplines.first_pass_judge_line;

Check warning on line 1045 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1040-L1045

Added lines #L1040 - L1045 were not covered by tests
const auto occlusion_wo_tl_pass_judge_line_idx =
intersection_stoplines.occlusion_wo_tl_pass_judge_line;

// see the doc for struct PathLanelets
const auto & first_attention_area_opt = intersection_lanelets.first_attention_area();
Expand Down Expand Up @@ -1147,6 +1153,8 @@ IntersectionModule::DecisionResult IntersectionModule::modifyPathVelocityDetail(
debug_data_.attention_area = intersection_lanelets.attention_area();
debug_data_.occlusion_attention_area = occlusion_attention_area;
debug_data_.adjacent_area = intersection_lanelets.adjacent_area();
debug_data_.first_attention_area = intersection_lanelets.first_attention_area();
debug_data_.second_attention_area = intersection_lanelets.second_attention_area();

Check notice on line 1157 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ Getting worse: Complex Method

IntersectionModule::modifyPathVelocityDetail already has high cyclomatic complexity, and now it increases in Lines of Code from 372 to 380. This function has many conditional statements (e.g. if, for, while), leading to lower code health. Avoid adding more conditionals and code to it without refactoring.

// check occlusion on detection lane
if (!occlusion_attention_divisions_) {
Expand Down Expand Up @@ -1662,6 +1670,7 @@ IntersectionLanelets IntersectionModule::getObjectiveLanelets(
std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionStopLines(
lanelet::ConstLanelet assigned_lanelet, const lanelet::CompoundPolygon3d & first_conflicting_area,
const lanelet::ConstLanelet & first_attention_lane,
const std::optional<lanelet::CompoundPolygon3d> & second_attention_area_opt,
const util::InterpolatedPathInfo & interpolated_path_info,
autoware_auto_planning_msgs::msg::PathWithLaneId * original_path)
{
Expand All @@ -1683,15 +1692,16 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
const int base2front_idx_dist =
std::ceil(planner_data_->vehicle_info_.max_longitudinal_offset_m / ds);

// find the index of the first point whose vehicle footprint on it intersects with detection_area
// find the index of the first point whose vehicle footprint on it intersects with attention_area
const auto local_footprint = planner_data_->vehicle_info_.createFootprint(0.0, 0.0);
std::optional<size_t> first_footprint_inside_detection_ip_opt =
const std::optional<size_t> first_footprint_inside_1st_attention_ip_opt =
getFirstPointInsidePolygonByFootprint(
first_attention_area, interpolated_path_info, local_footprint, baselink2front);
if (!first_footprint_inside_detection_ip_opt) {
if (!first_footprint_inside_1st_attention_ip_opt) {
return std::nullopt;
}
const auto first_footprint_inside_detection_ip = first_footprint_inside_detection_ip_opt.value();
const auto first_footprint_inside_1st_attention_ip =
first_footprint_inside_1st_attention_ip_opt.value();

Check warning on line 1704 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1704

Added line #L1704 was not covered by tests

std::optional<size_t> first_footprint_attention_centerline_ip_opt = std::nullopt;
for (auto i = std::get<0>(lane_interval_ip); i < std::get<1>(lane_interval_ip); ++i) {
Expand Down Expand Up @@ -1719,7 +1729,7 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
stop_idx_ip_int = static_cast<int>(map_stop_idx_ip.value()) - base2front_idx_dist;
}
if (stop_idx_ip_int < 0) {
stop_idx_ip_int = first_footprint_inside_detection_ip - stopline_margin_idx_dist;
stop_idx_ip_int = first_footprint_inside_1st_attention_ip - stopline_margin_idx_dist;

Check warning on line 1732 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1732

Added line #L1732 was not covered by tests
}
if (stop_idx_ip_int < 0) {
default_stopline_valid = false;
Expand All @@ -1735,7 +1745,7 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
// (3) occlusion peeking stop line position on interpolated path
int occlusion_peeking_line_ip_int = static_cast<int>(default_stopline_ip);
bool occlusion_peeking_line_valid = true;
// NOTE: if footprints[0] is already inside the detection area, invalid
// NOTE: if footprints[0] is already inside the attention area, invalid
{
const auto & base_pose0 = path_ip.points.at(default_stopline_ip).point.pose;
const auto path_footprint0 = tier4_autoware_utils::transformVector(
Expand All @@ -1747,32 +1757,32 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
}
if (occlusion_peeking_line_valid) {
occlusion_peeking_line_ip_int =
first_footprint_inside_detection_ip + std::ceil(peeking_offset / ds);
first_footprint_inside_1st_attention_ip + std::ceil(peeking_offset / ds);

Check warning on line 1760 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1760

Added line #L1760 was not covered by tests
}

const auto occlusion_peeking_line_ip = static_cast<size_t>(
std::clamp<int>(occlusion_peeking_line_ip_int, 0, static_cast<int>(path_ip.points.size()) - 1));
const auto first_attention_stopline_ip = first_footprint_inside_detection_ip;

// (4) first attention stopline position on interpolated path
const auto first_attention_stopline_ip = first_footprint_inside_1st_attention_ip;
const bool first_attention_stopline_valid = true;

// (4) pass judge line position on interpolated path
// (5) 1st pass judge line position on interpolated path
const double velocity = planner_data_->current_velocity->twist.linear.x;
const double acceleration = planner_data_->current_acceleration->accel.accel.linear.x;
const double braking_dist = planning_utils::calcJudgeLineDistWithJerkLimit(
velocity, acceleration, max_accel, max_jerk, delay_response_time);
int pass_judge_ip_int =
static_cast<int>(first_footprint_inside_detection_ip) - std::ceil(braking_dist / ds);
const auto pass_judge_line_ip = static_cast<size_t>(
std::clamp<int>(pass_judge_ip_int, 0, static_cast<int>(path_ip.points.size()) - 1));
// TODO(Mamoru Sobue): maybe braking dist should be considered
const auto occlusion_wo_tl_pass_judge_line_ip =
static_cast<size_t>(first_footprint_attention_centerline_ip);

// (5) stuck vehicle stop line
int first_pass_judge_ip_int =

Check warning on line 1774 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1774

Added line #L1774 was not covered by tests
static_cast<int>(first_footprint_inside_1st_attention_ip) - std::ceil(braking_dist / ds);
const auto first_pass_judge_line_ip = static_cast<size_t>(

Check warning on line 1776 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1776

Added line #L1776 was not covered by tests
std::clamp<int>(first_pass_judge_ip_int, 0, static_cast<int>(path_ip.points.size()) - 1));
const auto occlusion_wo_tl_pass_judge_line_ip = static_cast<size_t>(std::max<int>(

Check warning on line 1778 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1778

Added line #L1778 was not covered by tests
0, static_cast<int>(first_footprint_attention_centerline_ip) - std::ceil(braking_dist / ds)));

// (6) stuck vehicle stopline position on interpolated path
int stuck_stopline_ip_int = 0;
bool stuck_stopline_valid = true;
if (use_stuck_stopline) {
// NOTE: when ego vehicle is approaching detection area and already passed
// NOTE: when ego vehicle is approaching attention area and already passed
// first_conflicting_area, this could be null.
const auto stuck_stopline_idx_ip_opt = getFirstPointInsidePolygonByFootprint(
first_conflicting_area, interpolated_path_info, local_footprint, baselink2front);
Expand All @@ -1791,14 +1801,37 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
}
const auto stuck_stopline_ip = static_cast<size_t>(std::max(0, stuck_stopline_ip_int));

// (7) second attention stopline position on interpolated path
int second_attention_stopline_ip_int = -1;
bool second_attention_stopline_valid = false;
if (second_attention_area_opt) {
const auto & second_attention_area = second_attention_area_opt.value();
std::optional<size_t> first_footprint_inside_2nd_attention_ip_opt =
getFirstPointInsidePolygonByFootprint(
second_attention_area, interpolated_path_info, local_footprint, baselink2front);
if (first_footprint_inside_2nd_attention_ip_opt) {
second_attention_stopline_ip_int = first_footprint_inside_2nd_attention_ip_opt.value();

Check warning on line 1813 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1813

Added line #L1813 was not covered by tests
}
}
const auto second_attention_stopline_ip =
second_attention_stopline_ip_int >= 0 ? static_cast<size_t>(second_attention_stopline_ip_int)

Check warning on line 1817 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1816-L1817

Added lines #L1816 - L1817 were not covered by tests
: 0;

// (8) second pass judge lie position on interpolated path
int second_pass_judge_ip_int = second_attention_stopline_ip_int - std::ceil(braking_dist / ds);

Check warning on line 1821 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1821

Added line #L1821 was not covered by tests
const auto second_pass_judge_line_ip =
static_cast<size_t>(std::max<int>(second_pass_judge_ip_int, 0));

struct IntersectionStopLinesTemp
{
size_t closest_idx{0};
size_t stuck_stopline{0};
size_t default_stopline{0};
size_t first_attention_stopline{0};
size_t second_attention_stopline{0};
size_t occlusion_peeking_stopline{0};
size_t pass_judge_line{0};
size_t first_pass_judge_line{0};
size_t second_pass_judge_line{0};
size_t occlusion_wo_tl_pass_judge_line{0};
};

Expand All @@ -1808,8 +1841,10 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
{&stuck_stopline_ip, &intersection_stoplines_temp.stuck_stopline},
{&default_stopline_ip, &intersection_stoplines_temp.default_stopline},
{&first_attention_stopline_ip, &intersection_stoplines_temp.first_attention_stopline},
{&second_attention_stopline_ip, &intersection_stoplines_temp.second_attention_stopline},
{&occlusion_peeking_line_ip, &intersection_stoplines_temp.occlusion_peeking_stopline},
{&pass_judge_line_ip, &intersection_stoplines_temp.pass_judge_line},
{&first_pass_judge_line_ip, &intersection_stoplines_temp.first_pass_judge_line},
{&second_pass_judge_line_ip, &intersection_stoplines_temp.second_pass_judge_line},
{&occlusion_wo_tl_pass_judge_line_ip,
&intersection_stoplines_temp.occlusion_wo_tl_pass_judge_line}};
stoplines.sort(
Expand Down Expand Up @@ -1843,11 +1878,17 @@ std::optional<IntersectionStopLines> IntersectionModule::generateIntersectionSto
intersection_stoplines.first_attention_stopline =
intersection_stoplines_temp.first_attention_stopline;
}
if (second_attention_stopline_valid) {
intersection_stoplines.second_attention_stopline =
intersection_stoplines_temp.second_attention_stopline;
}
if (occlusion_peeking_line_valid) {
intersection_stoplines.occlusion_peeking_stopline =
intersection_stoplines_temp.occlusion_peeking_stopline;
}
intersection_stoplines.pass_judge_line = intersection_stoplines_temp.pass_judge_line;
intersection_stoplines.first_pass_judge_line = intersection_stoplines_temp.first_pass_judge_line;

Check warning on line 1889 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1889

Added line #L1889 was not covered by tests
intersection_stoplines.second_pass_judge_line =
intersection_stoplines_temp.second_pass_judge_line;

Check notice on line 1891 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ Getting worse: Excess Number of Function Arguments

IntersectionModule::generateIntersectionStopLines increases from 5 to 6 arguments, threshold = 4. This function has too many arguments, indicating a lack of encapsulation. Avoid adding more arguments.

Check notice on line 1891 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ Getting worse: Bumpy Road Ahead

IntersectionModule::generateIntersectionStopLines increases from 3 to 4 logical blocks with deeply nested code, threshold is one single block per function. The Bumpy Road code smell is a function that contains multiple chunks of nested conditional logic. The deeper the nesting and the more bumps, the lower the code health.

Check notice on line 1891 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ Getting worse: Complex Method

IntersectionModule::generateIntersectionStopLines increases in cyclomatic complexity from 21 to 25, threshold = 9. This function has many conditional statements (e.g. if, for, while), leading to lower code health. Avoid adding more conditionals and code to it without refactoring.

Check warning on line 1891 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L1891

Added line #L1891 was not covered by tests
intersection_stoplines.occlusion_wo_tl_pass_judge_line =
intersection_stoplines_temp.occlusion_wo_tl_pass_judge_line;
return intersection_stoplines;
Expand Down Expand Up @@ -3252,7 +3293,8 @@ getFirstPointInsidePolygonsByFootprint(

void IntersectionLanelets::update(
const bool is_prioritized, const util::InterpolatedPathInfo & interpolated_path_info,
const tier4_autoware_utils::LinearRing2d & footprint, const double vehicle_length)
const tier4_autoware_utils::LinearRing2d & footprint, const double vehicle_length,
lanelet::routing::RoutingGraphPtr routing_graph_ptr)
{
is_prioritized_ = is_prioritized;
// find the first conflicting/detection area polygon intersecting the path
Expand All @@ -3265,13 +3307,44 @@ void IntersectionLanelets::update(
}
}
if (!first_attention_area_) {
auto first = getFirstPointInsidePolygonsByFootprint(
const auto first = getFirstPointInsidePolygonsByFootprint(
attention_non_preceding_area_, interpolated_path_info, footprint, vehicle_length);
if (first) {
first_attention_lane_ = attention_non_preceding_.at(first.value().second);
first_attention_area_ = attention_non_preceding_area_.at(first.value().second);
}
}
if (first_attention_lane_ && !second_attention_lane_ && !second_attention_lane_empty_) {

Check warning on line 3317 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

❌ New issue: Complex Conditional

IntersectionLanelets::update has 1 complex conditionals with 2 branches, threshold = 2. A complex conditional is an expression inside a branch (e.g. if, for, while) which consists of multiple, logical operators such as AND/OR. The more logical operators in an expression, the more severe the code smell.
const auto first_attention_lane = first_attention_lane_.value();
// remove first_attention_area_ and non-straight lanelets from attention_non_preceding
lanelet::ConstLanelets attention_non_preceding_ex_first;
lanelet::ConstLanelets sibling_first_attention_lanelets;
for (const auto & previous : routing_graph_ptr->previous(first_attention_lane)) {
for (const auto & following : routing_graph_ptr->following(previous)) {
sibling_first_attention_lanelets.push_back(following);
}
}

Check warning on line 3326 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L3325-L3326

Added lines #L3325 - L3326 were not covered by tests
for (const auto & ll : attention_non_preceding_) {
// the sibling lanelets of first_attention_lanelet are ruled out
if (lanelet::utils::contains(sibling_first_attention_lanelets, ll)) {
continue;

Check warning on line 3330 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L3330

Added line #L3330 was not covered by tests
}
if (std::string(ll.attributeOr("turn_direction", "else")).compare("straight") == 0) {
attention_non_preceding_ex_first.push_back(ll);
}
}
if (attention_non_preceding_ex_first.empty()) {
second_attention_lane_empty_ = true;

Check warning on line 3337 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L3337

Added line #L3337 was not covered by tests
}
const auto attention_non_preceding_ex_first_area =
getPolygon3dFromLanelets(attention_non_preceding_ex_first);
const auto second = getFirstPointInsidePolygonsByFootprint(
attention_non_preceding_ex_first_area, interpolated_path_info, footprint, vehicle_length);
if (second) {
second_attention_lane_ = attention_non_preceding_ex_first.at(second.value().second);
second_attention_area_ = second_attention_lane_.value().polygon3d();
}
}

Check notice on line 3347 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ New issue: Excess Number of Function Arguments

IntersectionLanelets::update has 5 arguments, threshold = 4. This function has too many arguments, indicating a lack of encapsulation. Avoid adding more arguments.

Check notice on line 3347 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ Getting worse: Bumpy Road Ahead

IntersectionLanelets::update increases from 2 to 4 logical blocks with deeply nested code, threshold is one single block per function. The Bumpy Road code smell is a function that contains multiple chunks of nested conditional logic. The deeper the nesting and the more bumps, the lower the code health.

Check notice on line 3347 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

CodeScene Delta Analysis / CodeScene Cloud Delta Analysis (main)

ℹ New issue: Complex Method

IntersectionLanelets::update has a cyclomatic complexity of 16, threshold = 9. This function has many conditional statements (e.g. if, for, while), leading to lower code health. Avoid adding more conditionals and code to it without refactoring.

Check warning on line 3347 in planning/behavior_velocity_intersection_module/src/scene_intersection.cpp

View check run for this annotation

Codecov / codecov/patch

planning/behavior_velocity_intersection_module/src/scene_intersection.cpp#L3347

Added line #L3347 was not covered by tests
}

void TargetObject::calc_dist_to_stopline()
Expand Down
Loading

0 comments on commit 94f27ea

Please sign in to comment.