diff --git a/main.cpp b/main.cpp index 2e0bdfe..d67bff3 100644 --- a/main.cpp +++ b/main.cpp @@ -50,9 +50,14 @@ int main(int argc, char **argv) // Planner config auto planner_name = config["planner_name"].as(); PlannerType planner = GetPlanner(planner_name); + // Visualizer config + auto rescale_factor = config["visualizer"]["rescale"].as(); + auto delay = config["visualizer"]["delay"].as(); + auto tree_visualizer = std::make_shared( - map, tools::pair_double{2.0, 2.0}, 1u, "Tree Visualizer", planner_name); + map, tools::pair_double{rescale_factor, rescale_factor}, delay, + "Tree Visualizer", planner_name); // Path config auto s = config["path"]["start"]; diff --git a/planning/grid_base/dfs/dfs.cpp b/planning/grid_base/dfs/dfs.cpp index fa712f9..3a6cd3f 100644 --- a/planning/grid_base/dfs/dfs.cpp +++ b/planning/grid_base/dfs/dfs.cpp @@ -81,6 +81,7 @@ Path DFS::FindPath(const Node &start_node, const Node &goal_node, search_list.push(new_node_parent); } + std::this_thread::sleep_for(std::chrono::microseconds(100)); } if (search_list.empty()) diff --git a/planning/tree_base/src/common_tree_base.cpp b/planning/tree_base/src/common_tree_base.cpp index 86c77cc..9be73d7 100644 --- a/planning/tree_base/src/common_tree_base.cpp +++ b/planning/tree_base/src/common_tree_base.cpp @@ -32,19 +32,11 @@ std::pair RandomSampling() Node RandomNode(const std::shared_ptr map) { - bool is_valid{false}; Node random_node; - while (!is_valid) - { - auto random_point{RandomSampling()}; - random_node = - Node(static_cast(random_point.first * map->GetHeight()), - static_cast(random_point.second * map->GetWidth())); - if (map->GetNodeState(random_node) == NodeState::kFree) - { - is_valid = true; - } - } + auto random_point{RandomSampling()}; + random_node = Node(static_cast(random_point.first * map->GetHeight()), + static_cast(random_point.second * map->GetWidth())); + return random_node; } @@ -195,6 +187,10 @@ WireNewNode(const int max_branch_length, const int min_branch_length, { return std::make_shared(new_node, nearest_node, Cost{}); } + if (index == 0) + { + return std::nullptr_t(); + } auto isLengthValid{EuclideanDistance(ray[index - 1], nearest_node->node) > min_branch_length}; auto isNodeValid{map->GetNodeState(ray[index]) != NodeState::kOccupied &&