You are currently viewing a new version of our website. To view the old version click .
Sensors
  • Article
  • Open Access

29 October 2024

VNS-BA*: An Improved Bidirectional A* Path Planning Algorithm Based on Variable Neighborhood Search

,
and
1
School of Electronic and Information Engineering, Nanjing University of Information Science and Technology, Nanjing 210044, China
2
School of Automation, Wuxi University, Wuxi 214105, China
*
Author to whom correspondence should be addressed.
This article belongs to the Section Sensors and Robotics

Abstract

The A* algorithm is an effective method for path planning; however, it has certain drawbacks, such as a high number of turns, low planning efficiency, and redundant searches. To address these issues, this paper proposes an improved bidirectional A* global path planning algorithm based on a variable neighborhood search strategy, named VNS-BA*. The new algorithm first employs an 8-11-13 neighborhood search method for node expansion. Then, the bidirectional search strategy is optimized by using the current nodes of the opposite path and the global target point, enabling the two paths to meet in the middle of the map. Finally, redundant turns are removed from the path, and cubic spline interpolation is applied to achieve local smoothing at the turns. The effectiveness of the improved algorithm was validated on different maps and compared with A* and its three derived improved versions. The simulation results indicate that VNS-BA* shows significant improvements in terms of the number of path turns, turn angles, and planning efficiency.

1. Introduction

Path planning is a critical technology for mobile robots, essential for executing dynamic tasks efficiently and safely in specific scenarios. Path planning can be divided into two main categories based on prior environmental information: global path planning and local path planning. Global path planning constructs an optimized path from the starting point to the target point in a static environment, where information such as the position and distribution of obstacles is known in advance. In contrast, local path planning, while capable of refining the path online based on dynamic information about unknown obstacles, may still be prone to getting trapped in local minima due to the lack of global environmental information. As a result, global planning is a crucial preliminary step, with the quality of the global path directly impacting navigation performance.
To address global path planning, several graph-based search algorithms have been proposed, including Breadth-First Search (BFS) [], Depth-First Search (DFS) [], and Dijkstra’s algorithm []. These algorithms offer high path coverage but suffer from low efficiency due to redundant searches. Sampling-based algorithms, such as Rapidly-exploring Random Trees (RRT) [], RRT-connect [], Probabilistic Roadmaps (PRM) [], and lazy PRM [], provide unique advantages for real-time applications but often fail to fully capture environmental details, leading to suboptimal paths. In subsequent developments, bio-inspired algorithms like Ant Colony Optimization (ACO) [], Particle Swarm Optimization (PSO) [], and Whale Optimization [], as well as machine learning methods based on reinforcement learning [] and deep reinforcement learning [,,], have also been widely applied to global path planning. While these algorithms are capable of generating high-quality paths and have relative advantages in handling complex and continuous search spaces, they generally require substantial resources, which makes them challenging to deploy in resource-constrained systems.
The A* algorithm is a global path planning method based on graph search, which improves upon blind search algorithms by utilizing heuristic information from the map to selectively expand path nodes. This provides advantages such as high search efficiency and simplicity. Due to its low computational resource requirements and minimal memory usage, A* is widely employed in practical robotic systems, such as Automated Guided Vehicles (AGVs) [,] and Unmanned Ground Vehicles (UGVs) []. However, traditional A* has limitations, including excessive path turns and redundant searches. Numerous scholars have worked to address these issues. Zhang et al. proposed Rectangular Expansion A* (REA*), which replaces the traditional eight-neighbor expansion of A* with a rectangular expansion, significantly enhancing its performance. Xu et al. further improved REA* by introducing bidirectional rectangular expansion, effectively reducing the number of expansions and accelerating the algorithm []. However, rectangular expansion significantly increases computation time in environments with high obstacle density. Liao et al. enhanced the heuristic function by adding adaptive weight factors to improve path safety and searching speed []. Kim and Ha used methods based on Artificial Neural Networks (ANN) and reinforcement learning to train the heuristic function, thereby continuously improving algorithm performance during the learning process [,]. While these approaches improved the heuristic function, there remains room for optimization regarding path turns. Bai and Xu utilized the Floyd smoothing algorithm to eliminate unnecessary path nodes [,]. These improvements have enhanced A* in specific aspects but are not comprehensive.
To address the issues of excessive node expansions, large turning angles, and unsmooth paths in the traditional A* algorithm, this paper proposes an integrated improvement called the VNS-BA* algorithm. The proposed algorithm employs a simultaneous bidirectional search strategy from both the start and goal points, combined with a variable neighborhood search strategy, an improved heuristic function, and path smoothing operations, significantly enhancing search efficiency and path quality. The validation results indicate that the algorithm performs well across various maps of differing sizes and complexities, providing a new path planning solution for mobile robots in environments such as indoor settings, ports, and warehouses.
The specific improvements are as follows:
  • The traditional eight-neighbor search is expanded to an 8-11-13 neighbor search. Nodes are selectively expanded based on the positional relationship between the target point and the current node, reducing redundant searches.
  • An improved bidirectional search strategy is employed, where the search begins simultaneously from both the start and target points, using the current node from the opposite path as the target point.
  • The heuristic function is modified by introducing a new distance function that incorporates the current distance to the opposite path and a weighted distance to the goal. Additionally, the obstacle density between the current and target nodes is included as a weighting factor.
  • Pruning operations are performed to eliminate unnecessary turns in the path.
  • Cubic spline interpolation is applied to locally smooth the path at turn points.

2. A* Path Planning Algorithm

The traditional A* algorithm relies on a pre-established environmental model to plan a collision-free and safe path from the starting point to the destination. Currently, grid maps are widely used. In this approach, the map is divided into several independent square grids, each assigned a value based on the presence of obstacles. In this paper, we apply a simple binary treatment to the grids: grids containing obstacles are assigned a value of 1 and displayed in black on the map, while passable areas are assigned a value of 0 and displayed in white. To ensure that the generated path does not collide with obstacles, the grid size is set to the sum of the robot’s maximum diameter and the designated safety distance. This ensures that even if the path diagonally touches the corner of an obstacle grid, there will be no collision. After acquiring the map information, the A* algorithm selects nodes (i.e., grid centers) with the lowest path cost based on the cost function, and expands them until the destination is reached. The optimized path is the one with the minimum total cost, as determined by the algorithm.
The path cost function f ( n ) is the sum of the actual cost from the start point S to the current node n , denoted as g ( n ) , and the estimated cost from the current node n to the goal G , denoted as h ( n ) , as shown in Equation (1). The traditional A* algorithm typically uses Euclidean distance (Equation (2)), Manhattan distance (Equation (3)), and Chebyshev distance (Equation (4)) to express the estimated cost. In obstacle-free environments, Euclidean distance provides the most direct estimation of cost. However, when obstacles exist between two points, the robot must navigate around them, causing the path to include turns. In such cases, Manhattan distance can more accurately represent the estimated cost. In this paper, we switch the distance estimation function used for h ( n ) based on whether obstacles exist along the line connecting the current node and the target point.
f ( n ) = g ( n ) + h ( n )
h ( n ) E u c l i d e a n = ( x n x G ) 2 + ( y n y G ) 2
h ( n ) M a n h a t tan = x n x G + y n y G
h ( n ) C h e b y s h e v = max ( x n x G , y n y G )
The specific implementation of the A* algorithm is as follows:
  • Initialize two node lists: open list and close list.
  • Begin the search from the start point and add it to the open list.
  • Check whether the target point is in the close list. If true, trace back from the target point through the parent nodes to generate a complete path, and the pathfinding process is finished. If false, proceed to the next step.
  • Move the node with the smallest f ( n ) value from the open list to the close list, and set it as the current node.
  • Search the neighboring nodes of the current node and add all reachable, non-obstacle nodes to the open list.
  • If the expanded node is not in the open list, set the current node as its parent. If the expanded node is already in the open list, recalculate its g ( n ) . If the updated g ( n ) is smaller, set the current node as its parent. If the updated g ( n ) is larger, retain its original parent node.
  • Repeat steps 3 to 6 until the loop terminates, indicating that the path search is complete.

3. Improved Bidirectional A* Algorithm

3.1. Adaptive 8-11-13 Variable Neighborhood Search

The traditional A* algorithm expands nodes around the current node, and common search strategies are typically divided into 4-neighborhood and 8-neighborhoo searches based on the expansion directions. The 4-neighborhood search only expands nodes in the four cardinal directions (up, down, left, and right) from the current node, restricting movement to horizontal and vertical directions. This leads to excessive path turns, and since the number of nodes explored per iteration is small, multiple iterations are required during the search process. The 8-neighborhood search adds four diagonal directions to the 4-neighborhood search, reducing the number of turns and shortening the overall path length compared to the right-angled paths of the 4-neighborhood search. The search process also requires fewer iterations, improving search efficiency. It performs well in most scenarios; however, because it expands uniformly in all directions, it results in redundant searches in directions that deviate from the target.
To address these issues, the proposed VNS-BA* algorithm employs an adaptive 8-11-13 variable neighborhood search strategy. This strategy expands the search neighborhood adaptively and switches between search strategies based on surrounding obstacles, selectively expanding nodes based on the target’s position.
When expanding nodes, the algorithm first visits the nodes surrounding the current node using the 8-neighborhood search method. If no obstacles are present in the eight neighboring areas, the search continues outward. A vector from the current node to the target node is calculated, with the current node as the origin. If the vector aligns with the axes centered on the current node, three additional nodes are expanded in the vector’s direction, forming an 11-neighborhood search. If the vector lies within one of the four quadrants of the coordinate system, five additional nodes are expanded in the direction of the corresponding quadrant. However, if obstacles are present in the initial 8-neighborhood search, the outward expansion is halted, and only the 8-neighborhood search is performed, preventing the path from crossing obstacles and ensuring safety. As illustrated in Figure 1.
Figure 1. (a) 8-neighborhood search, (b) 13-neighborhood search, (c) 11-neighborhood search. The green node represents the current node, light gray grids indicate the 8-neighborhood search area, dark gray grids represent obstacle grids, blue grids indicate the additional grids expanded by the 13-neighborhood search, yellow grids represent the additional grids expanded by the 11-neighborhood search, and the red arrow shows the vector direction from the target point to the current node.
Zhang et al. [] and Sun et al. [] also proposed search strategies that expand the 8-neighborhood to a 24-neighborhood or 48-neighborhood, uniformly expanding in all directions. While these approaches improve search efficiency, they lack directionality. The method proposed in this paper adapts the search towards the target direction, significantly reducing redundant searches that deviate from the goal. Additionally, by increasing the number of nodes expanded per iteration, the number of traversals is reduced, which also decreases the number of turns in the path.

3.2. Improved Bidirectional Search Strategy

The traditional A* algorithm uses a unidirectional search from the start to the goal, which is inefficient in large maps with numerous obstacles. To address this limitation, scholars have integrated the bidirectional search strategy with the traditional A* algorithm, resulting in the Bidirectional A* (BA*) algorithm. In BA*, searches are initiated simultaneously from both the start and goal points, with each treating the other as the target, until the paths meet in the middle. Then, the complete path is generated by backtracking from the meeting point to the start and goal. In theory, this approach can reduce search time by approximately 50% compared to unidirectional searches. However, it has a significant drawback: the directions of the two paths may diverge, failing to meet in the middle of the map, leading to redundant searches. As a result, the total number of expanded nodes may even exceed that of a unidirectional A* search, consuming additional computational resources, as shown in Figure 2a.
Figure 2. (a) General bidirectional search strategy, (b) the improved bidirectional search strategy proposed by Li et al. [], (c) the bidirectional search strategy proposed in this paper. In the figure, the red node represents the start point, the green node represents the goal point; yellow grids indicate the grids traversed by the forward path search, and blue grids represent the grids traversed by the backward path search. The yellow arrow points in the direction of the forward path search, and the blue arrow points in the direction of the backward path search.
Li et al. [] proposed an improved bidirectional alternating search strategy, where the forward and backward paths each use the current best node of the opposite path as the target. This ensures that the two paths intersect in the middle to form a complete path. However, this method still has limitations. First, because the target node’s position is continuously updated, disturbances can occur when expanding nodes forward, leading to excessive turns in the generated path, or even a zigzagging pattern, as illustrated in Figure 2b. Additionally, due to the lack of global guidance from both the start and goal points, “detours” may occur. Furthermore, the final backtracking to generate the complete path only begins when the current nodes of both paths coincide, leading to unnecessary searches.
To address the aforementioned issues, VNS-BA* employs an improved bidirectional search strategy, implemented by modifying the heuristic function. In a typical bidirectional A* algorithm, the heuristic function is defined as the distance from the current node to the start of the opposite path (usually using Euclidean or Manhattan distance). In the proposed strategy, the heuristic is defined as the distance from the current node n to the current node on the opposite path h ( n , o p p s i t e _ c u r r e n t ) and the distance from the current node to the start of the opposite path h ( n , o p p s i t e _ s t a r t ) , each assigned different weight coefficients, ω , η . The weighted sum of these distances is used as the distance function p ( n ) , while the rectangular obstacle density between the current node and the opposite path’s current node is used to construct an obstacle weight factor e ρ .
The product of the obstacle weight factor and the distance function is used as the heuristic function h ( n ) , as shown in Equations (5) and (6). It is important to note that the distance function switches between Euclidean and Manhattan distances based on the obstacle conditions between two points, as described in Section 2. The actual cost g ( n ) is defined as the Euclidean distance between the current node and the start node, as shown in Equation (7).
p ( n ) = ω × h ( n , o p p s i t e _ c u r r e n t ) + η × h ( n , o p p s i t e _ s t a r t )
h ( n ) = e ρ × p ( n )
g ( n ) = i = 1 n x i 1 x i 2 + y i y i 1 2
The function h ( n , o p p s i t e _ c u r r e n t ) allows the current path to move closer to the opposite path, ensuring that the two paths intersect in the middle of the map. The function h ( n , o p p s i t e _ s t a r t ) provides overall guidance, directing the current node towards the final target, which helps avoid repeated local searches and reduces the disturbances caused by frequent changes in the opposite path during dynamic planning. This approach enhances system robustness and minimizes turns along the path, as shown in Figure 2c.
The weight coefficients, ω and η , define the attraction of the current node n on the opposite path, o p p s i t e _ c u r r e n t , and the pull of the start node on the opposite path, o p p s i t e _ s t a r t , toward n . When ω is large, the current path aligns more with the opposite path, particularly when a significant obstacle exists between them. The current path may adjust to closer nodes around the obstacle rather than proceeding directly to the target node. This adjustment reduces search time but may increase the number of nodes explored and the overall path length. Conversely, when η is large, the current path focuses more on reaching the target, possibly encountering fewer obstacles, though with higher search costs and reduced efficiency. To determine appropriate values for the weight coefficients, ω and η were set between 0 and 1, with a step size of 0.1, as illustrated in Figure 3, which shows results from four test scenarios. As this study focuses on optimizing paths through offline experiments, the effects of turning angles and frequency were omitted, using instead the number of nodes explored and the search time as key metrics. The results in Table 1 show that ω ’s effect on overall path length is minimal. However, when ω and η are set to 0.5, both the number of nodes explored and the search time are minimized. Thus, for the subsequent experiments and simulations, both ω , η are set to 0.5.
Figure 3. (a) Simple map, (b) Map with obstacles placed in the middle, (c) Map with bar-shaped obstructions, (d) Random map with 20% obstacle density. In the figure, the red node represents the start point, the green node represents the goal point.
Table 1. Simulation results for different values of ω , η in the 4 test maps.
Generally, as the number of obstacles increases, the probability of detours increases, resulting in longer path lengths. The obstacle weight factor e ρ helps ensure that the heuristic function h ( n ) better reflects the actual cost when the path crosses areas with uneven obstacle distribution and guides the path toward regions with fewer obstacles. The algorithm flowchart is shown in Figure 4:
Figure 4. Flowchart of the improved bidirectional A* algorithm proposed in this paper.

3.3. Path Polyline Optimization

The initially planned path may contain unnecessary turns. This paper proposes a method to perform a secondary optimization on the initially generated path to remove redundant turning points, making the path more in line with the kinematic model of mobile robots.
To optimize the initial path, Huang et al. [] first removed collinear redundant nodes from the path and then eliminated unnecessary turning points. While this approach can optimize the path to some extent, particularly in terms of length, it does not completely remove redundant turns. When dealing with longer paths with more turns, the optimization effect is less pronounced. We simulated the implementation of this algorithm in the map environment shown in Figure 5. The blue line represents the initial path, and the blue nodes indicate the initial nodes. After removing collinear redundant nodes, the path nodes become 1-3-7-11-12-14-15-16. Then, after removing additional unnecessary turns, the path nodes become 1-3-7-11-12-14-16. The optimized path is shown by the yellow line. Compared to the original path, this method only reduces one turning point, indicating that there is still room for further optimization.
Figure 5. Illustration of polyline optimization. The blue line represents the initial path, the yellow line represents the path optimized by Huang et al. [], and the black line represents the path optimized in this paper.
The specific idea of the algorithm proposed in this paper is as follows: First, the start point of the path is added to the optimized path list, and the start point is set as the front endpoint. Subsequently, the remaining nodes of the path are sequentially connected as the back endpoint to form a line segment. It is then determined whether the line segment crosses any obstacle grids, as indicated by the blue dashed line in the figure. The path nodes are traversed until a node forms a line segment with the start point that crosses an obstacle, as shown by the red dashed line in the figure. At this point, the previous node of the crossed node is added to the optimized path list, and this node is set as the new start point. The above steps are repeated, continuing to traverse the original path nodes until the end point is reached. The end point is then added to the optimized path list as well. The connections between all nodes in the list form the optimized path, as illustrated by the black solid line in the figure. As a result, the number of turning points in the path is reduced from 6 to 4, and unnecessary collinear nodes are eliminated. The method proposed in this paper retains only the necessary turning points in the path, achieving effective optimization.

3.4. Local Smoothing Using Cubic Spline Curves

At polyline turns, mobile robots may experience mechanical limitations, leading to stalling, and sharp changes in slope along the path may cause mechanical wear during turns. Therefore, the path needs to be smoothed to form a continuous and smooth path.
Many studies smooth the entire path using interpolation. However, in maps with densely distributed obstacles, the smoothed path may intersect with obstacles. This paper retains the straight sections of the path and only applies cubic spline interpolation at the turning points for optimization. As shown in Figure 6, the four nodes P 1 , P 2 , P 3 , P 4 before and after the turning point are selected as control points for cubic spline interpolation. The turning point itself is not used to avoid collisions between the smoothed path and obstacles. The second segment [ P 2 , P 3 ] of the interpolated path smooths the turn into an arc, while the first segment [ P 1 , P 2 ] and third segment [ P 3 , P 4 ] ensure that the interpolated curve connects smoothly with the original straight path at the junctions.
Figure 6. Illustration of Path Smoothing.
In the three intervals between the control points P 1 , P 2 , P 3 , P 4 , namely [ P 1 , P 2 ] , [ P 2 , P 3 ] , [ P 3 , P 4 ] , cubic functions S 1 ( x ) , S 2 ( x ) , S 3 ( x ) are used for interpolation, as shown in Equations (8)–(10).
S 1 ( x ) = a 1 + b 1 ( x x P 1 ) ) + c 1 ( x x P 1 ) 2 + d 1 ( x x P 1 ) 3
S 2 ( x ) = a 2 + b 2 ( x x P 2 ) ) + c 2 ( x x P 2 ) 2 + d 2 ( x x P 2 ) 3
S 3 ( x ) = a 3 + b 3 ( x x P 3 ) ) + c 3 ( x x P 3 ) 2 + d 3 ( x x P 3 ) 3
Since the curve passes through each control point and the first and second derivatives of the segmented curves are equal at the two intermediate points, the coefficients can be solved based on the conditions in Equation (11), and the final interpolated curve can be plotted. The result is shown in Figure 7.
S i ( x p i ) = y p i , i = 1 , 2 , 3 S i ( x p i + 1 ) = S i + 1 ( x p i + 1 ) , i = 1 , 2 S i ( x p i + 1 ) = S i + 1 ( x p i + 1 ) , i = 1 , 2 S i ( x p i + 1 ) = S i + 1 ( x p i + 1 ) , i = 1 , 2
Figure 7. The result of local path smoothing.

4. Simulation Experiments and Result Analysis

The effectiveness and reliability of the VNS-BA* algorithm were verified through simulations conducted in the MATLAB 2018b environment. For comparison, this study reproduced an improved A* algorithm from [] and an improved bidirectional A* algorithm from []. Since [] did not explicitly specify the value of the weighting factor, the obstacle density factor proposed earlier was used as the weighting factor. Four maps of varying sizes and increasing complexity were designed, and the proposed algorithm was compared with the traditional A*, the improved A* algorithm [], the bidirectional A* algorithm (BA*), and the improved bidirectional A* algorithm (improved BA*) []. In the maps, gray areas represent obstacle grids, red circles indicate the start points, green circles represent the goal points, yellow grids denote the forward path search from the start, blue grids denote the backward path search from the goal, black lines indicate the planned path, and red lines at path turns represent locally smoothed sections of the path planned by the proposed algorithm.
As shown in Figure 8, the paths generated by the five algorithms on a simple 20 × 20 map are presented. The specific data is shown in Table 2.
Figure 8. Performance of the five algorithms on Map A.
Table 2. Comparison of Simulation Results of Different Algorithms in a 20 × 20 Map A.
Due to the simplicity of the map structure, there were no significant differences in path length or the number of expanded nodes among the five methods. However, in terms of time efficiency, the three methods using the bidirectional search strategy performed significantly better than the two unidirectional algorithms. Furthermore, due to the use of the polyline optimization strategy, the proposed VNS-BA* algorithm produced paths with noticeably fewer turns and greater smoothness compared to the other four algorithms.
As the map complexity increases, zigzag-shaped obstacles are added in Map B, as shown in the Figure 9. The specific data is shown in Table 3.
Figure 9. Performance of the five algorithms on Map B.
Table 3. Comparison of Simulation Results of Different Algorithms in a 40 × 40 Map B.
Due to the presence of branching paths in the middle of the map, the traditional unidirectional A* algorithm and the improved A* [] entered the wrong branch at the center of the map, leading to redundant searches and significantly longer planning times compared to the other three bidirectional algorithms. The BA* algorithm encountered an issue where the forward and backward paths did not converge in the middle of the map, resulting in numerous redundant search nodes. In the Improved BA* [], the forward path also deviated from the backward search path, and the generated path contained many turns. The proposed VNS-BA* algorithm employs an improved bidirectional search strategy, adding a distance weight between the current node and the opposite path’s current node to the heuristic function. This modification allows the forward and backward paths to attract each other and meet in the middle, avoiding unnecessary searches and achieving optimized results across all five evaluated path quality metrics.
The 60 × 60 environment shown in Figure 10 simulates indoor scenarios such as home and office environments. The specific data is presented in Table 4.
Figure 10. Performance of the five algorithms on Map C.
Table 4. Comparison of Simulation Results of Different Algorithms in a 60 × 60 Map C.
The traditional A*, improved A* [], and BA* algorithms experienced extended planning times due to many unnecessary searches. The improved A* generated paths that exhibited detours, failing to achieve global optimality. The Improved BA* [], using the traditional 8-neighborhood search, produced paths with excessive turns, which were not favorable for robot navigation. In contrast, the proposed algorithm employs the 8-11-13 neighborhood search strategy, where, in the central part of the map, the line between the forward and backward paths is parallel to the x-axis with fewer obstacles, allowing nodes to expand using the 11-neighborhood. This reduces the number of node iterations and turns, thereby improving planning speed. Data analysis indicates that although the number of nodes explored by the proposed algorithm is not the lowest, the generated paths are optimized in terms of length, planning time, and smoothness.
The 80 × 80 map shown in Figure 11 simulates environments such as ports and warehouses, where obstacles represent goods placed in the scene. The specific data is presented in Table 5.
Figure 11. Performance of the five algorithms on Map D.
Table 5. Comparison of Simulation Results of Different Algorithms in a 80 × 80 Map D.
As map complexity increased, all algorithms exhibited a significant rise in the number of turns and turn angles in their paths. However, VNS-BA* still demonstrated superior performance in terms of path smoothness and planning time, validating its effectiveness in large, complex environments.
Based on the results above, the optimization rate of VNS-BA* compared to the other four algorithms in the four scenarios was calculated, as shown in Table 6.
Table 6. The improving ratio of VNS-BA* compared to other algorithms across different maps.
From the analysis of the data in Table 6, it can be concluded that VNS-BA* shows significant improvement compared to traditional A*, improved A* [], BA*, and improved BA* []. Specifically, in terms of path smoothness and planning time, VNS-BA* achieved a turn-point optimization rate above 40% for all scenarios, with a maximum of 80.96%. The turn-angle optimization rate ranged from a minimum of 28.44% to a maximum of 83.53%. The planning time of VNS-BA* was notably better than that of the unidirectional algorithms, with some improvement over the bidirectional algorithms as well. In simple environments, all algorithms had a low number of node iterations, and due to the larger number of nodes expanded per iteration by the proposed algorithm, negative optimization was observed in node reduction. However, as the size of the map increased, the optimization effect also progressively improved.
To comprehensively evaluate the optimization effect of the algorithm, the arithmetic mean method is used to calculate the overall optimization rate of the algorithm, and the results are displayed using a bar chart, as shown in Figure 12.
Figure 12. A grouped bar chart showing the overall optimization rate of VNS-BA* compared to the other four algorithms across different maps.
From the analysis of the combined bar charts, it can be concluded that the proposed VNS-BA* algorithm maintains a leading position even in simple environments, though the advantage is not pronounced. However, in relatively complex environments, such as map B, map C, and map D, the overall optimization rate of the paths generated by the proposed algorithm exceeded 30%, demonstrating a significant advantage. This confirms that VNS-BA* is effective across various scenarios.

5. Conclusions

To meet the demand for high-quality global path planning in different scenarios, this paper proposes the VNS-BA* algorithm, which efficiently generates smooth paths with low path costs. The algorithm introduces an improved node expansion method to selectively and efficiently expand nodes for pathfinding. Additionally, it enhances the search strategy by using the current node of the opposite path as the target in the bidirectional search, guiding the paths to converge at the midpoint of the map, and further improves the heuristic function to increase search speed. Finally, unnecessary turns are removed, and local smoothing is applied to remaining turns, resulting in a stable path suitable for robot navigation.
Simulation results in various scenarios demonstrate that, compared to traditional A*, BA*, and two other optimized algorithms, VNS-BA* effectively reduces the number of path turns and achieves favorable optimization in terms of planning time and the number of expanded nodes. However, the paths generated by the proposed algorithm are only applicable in static environments with known map information. When obstacle states change within the map, dynamic obstacle avoidance algorithms are still needed to mitigate collision risks, which will be the focus of future research.

Author Contributions

Methodology, P.L. and Y.L.; writing—original draft preparation, Y.L.; writing—review and editing, P.L. and X.D. All authors have read and agreed to the published version of the manuscript.

Funding

This research was funded by the Natural Science Foundation of the Higher Education Institutions of Jiangsu Province (Grant No. 23KJB460030).

Data Availability Statement

No new data were created or analyzed in this study. Data sharing is not applicable to this article.

Acknowledgments

The authors express their gratitude to the scholars who have contributed to the field of path planning.

Conflicts of Interest

The authors declare no conflicts of interest.

References

  1. Bundy, A.; Wallen, L. Breadth-First Search. In Catalogue of Artificial Intelligence Tools; Bundy, A., Wallen, L., Eds.; Springer: Berlin/Heidelberg, Germany, 1984; p. 13. ISBN 978-3-540-13938-6. [Google Scholar]
  2. Tarjan, R. Depth-First Search and Linear Graph Algorithms. SIAM J. Comput. 1972, 1, 146–160. [Google Scholar] [CrossRef]
  3. Noto, M.; Sato, H. A Method for the Shortest Path Search by Extended Dijkstra Algorithm. In Proceedings of the 2000 IEEE International Conference on Systems, Man and Cybernetics—“Cybernetics Evolving to Systems, Humans, Organizations, and Their Complex Interactions”, Nashville, TN, USA, 8–11 October 2000; Volume 3, pp. 2316–2320. [Google Scholar]
  4. Karaman, S.; Walter, M.R.; Perez, A.; Frazzoli, E.; Teller, S. Anytime Motion Planning Using the RRT. In Proceedings of the 2011 IEEE International Conference on Robotics and Automation, Shanghai, China, 9–13 May 2011; pp. 1478–1483. [Google Scholar]
  5. Kuffner, J.J.; LaValle, S.M. RRT-Connect: An Efficient Approach to Single-Query Path Planning. In Proceedings of the 2000 ICRA. Millennium Conference. IEEE International Conference on Robotics and Automation. Symposia Proceedings, San Francisco, CA, USA, 24–28 April 2000; Volume 2, pp. 995–1001. [Google Scholar]
  6. Jaillet, L.; Siméon, T. A PRM-Based Motion Planner for Dynamically Changing Environments. In Proceedings of the 2004 IEEE/RSJ International Conference on Intelligent Robots and Systems (IROS), Sendai, Japan, 28 September–2 October 2004; Volume 2, pp. 1606–1611. [Google Scholar]
  7. Bohlin, R.; Kavraki, L.E. Path Planning Using Lazy PRM. In Proceedings of the 2000 ICRA. Millennium Conference. IEEE International Conference on Robotics and Automation. Symposia Proceedings, San Francisco, CA, USA, 24–28 April 2000; Volume 1, pp. 521–528. [Google Scholar]
  8. Miao, C.; Chen, G.; Yan, C.; Wu, Y. Path Planning Optimization of Indoor Mobile Robot Based on Adaptive Ant Colony Algorithm. Comput. Ind. Eng. 2021, 156, 107230. [Google Scholar] [CrossRef]
  9. Das, P.K.; Jena, P.K. Multi-Robot Path Planning Using Improved Particle Swarm Optimization Algorithm through Novel Evolutionary Operators. Appl. Soft Comput. 2020, 92, 106312. [Google Scholar] [CrossRef]
  10. Dai, Y.; Yu, J.; Zhang, C.; Zhan, B.; Zheng, X. A Novel Whale Optimization Algorithm of Path Planning Strategy for Mobile Robots. Appl. Intell. 2023, 53, 10843–10857. [Google Scholar] [CrossRef]
  11. Wang, B.; Liu, Z.; Li, Q.; Prorok, A. Mobile Robot Path Planning in Dynamic Environments through Globally Guided Reinforcement Learning. IEEE Robot. Autom. Lett. 2020, 5, 6932–6939. [Google Scholar] [CrossRef]
  12. Liu, H.; Ying, F.; Jiang, R.; Shan, Y.; Shen, B. Obstacle-Avoidable Robotic Motion Planning Framework Based on Deep Reinforcement Learning. IEEE/ASME Trans. Mechatron. 2024; in press. [Google Scholar]
  13. Gao, J.; Ye, W.; Guo, J.; Li, Z. Deep Reinforcement Learning for Indoor Mobile Robot Path Planning. Sensors 2020, 20, 5493. [Google Scholar] [CrossRef] [PubMed]
  14. Li, B.; Wu, Y. Path Planning for UAV Ground Target Tracking via Deep Reinforcement Learning. IEEE Access 2020, 8, 29064–29074. [Google Scholar] [CrossRef]
  15. AGV Path Planning Based on Improved A-Star Algorithm|IEEE Conference Publication|IEEE Xplore. Available online: https://ieeexplore.ieee.org/abstract/document/10503919/ (accessed on 2 October 2024).
  16. Han, Z.; Wang, D.; Liu, F.; Zhao, Z. Multi-AGV Path Planning with Double-Path Constraints by Using an Improved Genetic Algorithm. PLoS ONE 2017, 12, e0181747. [Google Scholar] [CrossRef] [PubMed]
  17. Thoresen, M.; Nielsen, N.H.; Mathiassen, K.; Pettersen, K.Y. Path Planning for UGVs Based on Traversability Hybrid A*. IEEE Robot. Autom. Lett. 2021, 6, 1216–1223. [Google Scholar] [CrossRef]
  18. Xu, X.; Zeng, J.; Zhao, Y.; Lü, X. Research on Global Path Planning Algorithm for Mobile Robots Based on Improved A*. Expert Syst. Appl. 2024, 243, 122922. [Google Scholar] [CrossRef]
  19. Liao, T.; Chen, F.; Wu, Y.; Zeng, H.; Ouyang, S.; Guan, J. Research on Path Planning with the Integration of Adaptive A-Star Algorithm and Improved Dynamic Window Approach. Electronics 2024, 13, 455. [Google Scholar] [CrossRef]
  20. Kim, S.; An, B. Learning Heuristic A: Efficient Graph Search Using Neural Network. In Proceedings of the 2020 IEEE International Conference on Robotics and Automation (ICRA), Paris, France, 31 May–31 August 2020; pp. 9542–9547. [Google Scholar]
  21. Ha, J.; An, B.; Kim, S. Reinforcement Learning Heuristic A*. IEEE Trans. Ind. Inf. 2023, 19, 2307–2316. [Google Scholar] [CrossRef]
  22. Bai, X.; Jiang, H.; Cui, J.; Lu, K.; Chen, P.; Zhang, M. UAV Path Planning Based on Improved A∗ and DWA Algorithms. Int. J. Aerosp. Eng. 2021, 2021, 4511252. [Google Scholar] [CrossRef]
  23. Xu, H.; Yu, G.; Wang, Y.; Zhao, X.; Chen, Y.; Liu, J. Path Planning of Mecanum Wheel Chassis Based on Improved A* Algorithm. Electronics 2023, 12, 1754. [Google Scholar] [CrossRef]
  24. Zhang, J.; Liu, Z.; Wang, Y.; Zhang, F.; Li, Y. Research on Effective Path Planning Algorithm Based on Improved A* Algorithm. J. Phys. Conf. Ser. 2022, 2188, 012014. [Google Scholar] [CrossRef]
  25. Robot Path Planning by Using Improved A* Algorithm and Dynamic Window Method. Available online: https://ieeexplore.ieee.org/abstract/document/9862697 (accessed on 2 August 2024).
  26. Li, C.; Huang, X.; Ding, J.; Song, K.; Lu, S. Global Path Planning Based on a Bidirectional Alternating Search A* Algorithm for Mobile Robots. Comput. Ind. Eng. 2022, 168, 108123. [Google Scholar] [CrossRef]
  27. Huang, C.; Zhao, Y.; Zhang, M.; Yang, H. APSO: An A*-PSO Hybrid Algorithm for Mobile Robot Path Planning. IEEE Access 2023, 11, 43238–43256. [Google Scholar] [CrossRef]
  28. Liu, Y.; Wang, C.; Wu, H.; Wei, Y. Mobile Robot Path Planning Based on Kinematically Constrained A-Star Algorithm and DWA Fusion Algorithm. Mathematics 2023, 11, 4552. [Google Scholar] [CrossRef]
  29. Zhang, H.; Tao, Y.; Zhu, W. Global Path Planning of Unmanned Surface Vehicle Based on Improved A-Star Algorithm. Sensors 2023, 23, 6647. [Google Scholar] [CrossRef] [PubMed]
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Article Metrics

Citations

Article Access Statistics

Multiple requests from the same IP address are counted as one view.