The present invention belongs to the field of path planning, and more particularly, relates to a coverage-path planning method (IBA*) for a single unmanned surface mapping vessel.
Marine surveying is the basic work for building marine informationization, which has important economic significance for the development of national marine resources. Surveyors are faced with the problems of high labor intensity and high safety risks. All kinds of dangerous scenes make it difficult to implement traditional measurement methods.
The Unmanned Surface Vessel (USV) is a kind of marine intelligent platform which can navigate autonomously and safely in various marine environments and perform various tasks. The Unmanned Surface Mapping Vessel (USMV) used in ocean surveying can improve the efficiency of surveying and mapping operations, reduce the cost of mapping underwater topography and operational safety risks, and is very suitable for replacing or assisting traditional ocean surveying, thus having broad application prospects. At present, a single USMV is vulnerable to the limitations of endurance and operation efficiency in measuring coverage operation, while multi-USMV collaborative scanning can improve the efficiency of area coverage operation and shorten the time to complete tasks, so it has better task execution ability. As the basis and premise of collaborative surveying on water, it is of great significance to carry out research on multi-USV coverage path planning.
At present, the research on coverage path planning mostly focuses on the field of ground mobile robots. Compared with the ground mobile robot, the working range of the USMV is wider and the water environment is more complex, which requires higher efficiency and robustness of the coverage path planning algorithm.
Against the above deficiencies or improved needs of the prior art, the present invention proposes a coverage-path planning method for a single unmanned surface mapping vessel to improve the coverage rate and coverage effect in a complex operating environment of the unmanned surface mapping vessel and improve the operational efficiency of the unmanned surface mapping vessel.
To achieve the above objectives, in accordance with one aspect of the present invention, there is provided a coverage-path planning method for a single unmanned surface mapping vessel, including:
(1) rasterizing an environmental map, initializing GT values of all grids as ue, assigning a value BVa0 to a grid a0 in a BL0-level map, then importing an initialized environmental map, inputting coordinates, and continuing to update the environmental map, wherein the ue represents the free space where the bathymetry mission is not completed;
(2) outputting, by a USMV, position information ω and obstacle information η thereof according to the updated environmental map, starting to update an environmental map, outputting a grid status list GT_list according to the updated environmental map, and receiving, by the BL0-level map, input map information and USMV information according to the GT_list, starting path planning, and outputting a target point tp to the USMV, wherein the tp represents an index value of the grid where a next target point of the USMV is located;
(3) if the solution is trapped in a local optimum at the BL0-level map, updating each map level BL0 in ascending order, and searching the corresponding level for the tp, if a tp list is acquired, calculating a final tp according to a cost value, transmitting the final tp to the USMV, and causing the USMV to switch to a tr state, and when the tr state is entered, entering the BL0-level map and continuing to perform planning, wherein the tr state represents a non-normal task state after the USMV is in a Travel state and reaches local optimum; and
(4) if still no target point tp is found at the map corresponding to the highest level BLL, ending the task, checking the status of the highest level BLL map, and outputting an E state, wherein the E state represents an end state.
In some alternative embodiments, the step (1) includes:
updating the GT_list first, since the USMV has not yet started to traverse and the number of exps is 0, defining the vast majority of grids as a ue state, calculating a preset assigned value BVa0 of the grid a0 in the BL0-level map and updating level by level till the highest BLL-level, eventually importing environmental map information, updating obstacles, exclusion zones, and navigable waters, respectively, at the same time, starting, by the USMV, recording and transferring position information ω and obstacle information η thereof, thus starting circular traversal officially, wherein the exp represents the free space where the bathymetry mission has been completed.
In some alternative embodiments, the step (2) includes:
recording a detection field of the USMV in the updated environmental map as D0(ω), ω∈D0(ω), wherein the D0(ω) contains all the grid information perceptible to the USMV at the current position;
for each grid a0 in the D0(ω), if a connection line with the ω does not pass through a grid in a fz or obs state and a potential energy value of the grid a0 is positive, defining a grid set satisfying the above requirements as a priority field F0⊆D0(μ), wherein the D0(μ) represents the priority field determined from the D0(ω);
for coverage of the BL0-level map, since a priority path of the USMV is to complete the coverage task in the direction of a single scanning line, preferentially selecting the grid on the same scanning line in the D0(ω) as the target point, defining the grids in the D0(ω) in both north and south directions as ωN and ωs, if BVω>0 and {ωN,ωS}⊂F0, wherein, the BV is the grid potential value, in order to circumvent the case of massive backtracking, preferentially selecting the grid adjacent to the obstacle from the two grids, denoting the grid as tpobs, in the case where both the ωN and ωs meet the condition, introducing both into a cost calculation formula to calculate the potential cost values J(tp) produced by both paths, and selecting a relatively optimum path from local and global points of view;
if there is an adjacent obstacle on only one side of ωN and ωs, then then giving priority to a ωN or ωs orientation where the adjacent obstacle is located to start traversal, wherein in the case of BVω>0, the ω grid where the USMV is located has not yet been explored, in the two upper and lower orientations, one side is the mission completion or obstacle area and the other side is the free space that has not yet been explored, at the moment, the ω is the tp point, and the USMV switches to a tc instruction which guides the USMV to start the actual bathymetry mission;
if BVω=0, F0≠Ø, determining that the USMV has completed the task on the single scanning line, starting to turn to the next phase of traversal, at the moment, taking the grid α0 with the largest BVF
if none of the above cases are met, determining that the USMV is in the locally optimum state at the moment, wherein the most likely case is driving into a concave obstacle field or being surrounded by an area with BV≤0, at the moment, starting the high-level map phase for path finding, and outputting a tr instruction.
In some alternative embodiments, the priority field is determined by:
F
0={α0∈D0(ω):BVα
In some alternative embodiments, the potential cost value is determined by:
J(tp)=kθ·θ(ω,tp)+kd·d(ω,tp)+kul·Nexp,
wherein,
d(ω,tp)=∥(ωx,ωy)−(tpx,tpy)∥2,
kθ represents a turn cost coefficient and is considered as a unit turn angle cost; θ represents an absolute value of an angular change; kd represents a distance cost coefficient, and is considered as a unit distance movement cost; d represents a Euclidean distance; kul represents a global trend coefficient and is considered as as the cost of changing the situation; Nexp represents the number of ue-state grids in the input direction, (ωx,ωy) represents the horizontal and vertical coordinates of the ω point, and (tpx,tpy) represents the horizontal and vertical coordinates of the tp point.
In some alternative embodiments, the step (3) includes:
switching to a BLl-level phase with l=1, finding a level-1 map grid α1 with the largest BVF
since the local optimum case occurs in the vast majority of cases at the end of the obstacle or at the end of the scanning line, calculating an adjacent path in the tr state with a greedy algorithm, i.e. continuing to track the obstacle contour until moving directly to the target point, breaking away from the state of entering the locally optimum area and reaching the target point, in the scanning task, for a scenario in which a dynamic obstacle exists, performing a collision avoidance action by the USMV, and switching to the tr state, continuing to enter the BL0-level map after past and clear, resuming the coverage operation, if it is still impossible to break away from the local optimum when l=1, updating the map level by level until the tp point is derived and if there is no solution when l=L, then preliminarily determining that the traversal is completed.
In some alternative embodiments, at the BLl-level map phase, the priority domain is specifically expressed as:
F
l={αl∈Dl(ω):BVα
In some alternative embodiments, the step (4) includes:
based on the known partial environmental information, reviewing missing areas, generating coverage rate information, and considering whether to switch the tr state to perform the return or continue the scanning task in a specific area according to the actual state requirements of the USMV.
According to another aspect of the present invention, there is provided a computer readable storage medium having stored thereon a computer program which, when executed by a processor, implements the steps of the method of any of the above.
In general, the above solutions conceived by the present invention can achieve the following advantageous effects compared to the prior art:
According to the invention, the traditional coverage path planning algorithm is used for reference, the research on cooperative coverage path planning of multiple USMVs is carried out in depth, and the IBA* (Improved BA*) algorithm is designed to plan a high-efficiency and high-quality scanning path for the USMV. Simulation results show that the performance of IBA* algorithm is significantly improved compared with existing algorithms in path length, turning times, number of units and coverage rate. The invention provides a theoretical basis for the research on the coverage path planning of the USMV, can promote the unmanned and intelligent process of marine measurement from the aspect of coverage path planning algorithm design, reduces the cost of marine information construction, and has wide application prospects and scientific value.
In order to make the objectives, technical solutions and advantages of the invention more clear, the invention will be described in further detail below in conjunction with the accompanying drawings and embodiments. It should be understood that the specific embodiments described herein are intended only to explain the invention and are not intended to limit it. Further, the technical features related to the various embodiments of the present invention described below can be combined with each other as long as they do not conflict with each other.
The invention provides an optimized coverage-path planning method (IBA*) for a single unmanned surface mapping vessel, which improves the coverage rate and coverage effect of the unmanned surface mapping vessel in a complex working environment and improves the working efficiency of the unmanned surface mapping vessel. In order to make the above objectives, features and advantages of the invention more obvious and understandable, the invention will be further described in detail in combination with the drawings and specific embodiments.
In particular,
S101: an environmental map is rasterized, GT values of all grids are initialized as ue, a value BVa0 is assigned to a grid a0 in a BL0-level map, then an initialized environmental map is imported, coordinates are input, and the environmental map is continued to be updated;
The grid specific state is defined as GT, and the ue represents the free space where the bathymetry mission is not completed.
The environmental map is rasterized: the rasterization method divides the environmental map into several equally sized adjacent grids for easy update and maintenance. The environmental map is first quantized at a certain size, grid coordinates are established, then the coordinated grids are placed in one array, and attribute assignment is made to each grid for distinguishing different locations or grid cells.
S102: a USMV outputs position information ω and obstacle information η thereof according to the updated environmental map, an environmental map is started to update, a grid status list GT_list is output according to the updated environmental map, and the BL0-level map receives input map information (such as the state and assigned value of a generated grid map) and USMV information according to the GT_list, path planning is started, and a target point tp is output to the USMV, wherein the tp represents an index value of the grid where a next target point of the USMV is located;
BL0, . . . BLL represent respective dynamic map levels BaseLayer and L is the highest level.
OC represents a USMV task instruction.
ac represents directing the USMV to perform collision avoidance.
The specific grid status list is defined as GT_list, and
GT_list={obs,exp,fz,ue}
S103: if the solution is trapped in a local optimum at the BL0-level map, each map level BL0 is updated in ascending order, and the corresponding level is searched for the tp, if a tp list is acquired, a final tp is calculated according to a cost value, the final tp is transmitted to the USMV, and the USMV is caused to switch to a tr state, and when the tr state is entered, entering the BL0-level map and continuing to perform planning; wherein the tr state represents a non-normal task state after the USMV is in a Travel state and reaches local optimum.
S104: if still no target point tp is found at the map corresponding to the highest level BLL, the task is ended, the status of the highest level BLL map is checked, and an E state is output; wherein the S state represents a list of states, the O state represents a start state, the E state represents an end state, and the COM state represents a calculation state.
In some alternative embodiments, the step S101 may be implemented by:
The GT_list is updated first, since the USMV has not yet started to traverse and the number of exps is 0, the vast majority of grids are defined as a ue state, a preset assigned value BVa0 of the grid a0 in the BL0-level map is calculated and updated level by level till the highest BLL-level, eventually environmental map information is imported, obstacles, exclusion zones, and navigable waters are updated, respectively, at the same time, the USMV starts to record and transfer position information ω and obstacle information η thereof, thus starting circular traversal officially; wherein the vast majority of the embodiments of the present invention represent a preset number, which can be determined according to actual needs.
In some alternative embodiments, the step S102 may be implemented by:
a detection field of the USMV in the updated environmental map is recorded as D0(ω), ω∈D0(ω) wherein wherein the D0(ω) contains all the grid information perceptible to the USMV at the current position; for each grid a0 in the D0(ω), if a connection line with the ω does not pass through a grid in a fz or obs state and a potential energy value of the grid a0 is positive, a grid set satisfying the above requirements is defined as a priority field F0⊆D0(μ), wherein the D0(μ) represents the priority field determined from the D0(ω); for coverage of the BL0-level map, since a priority path of the USMV is to complete the coverage task in the direction of a single scanning line, the grid on the same scanning line in the D0(ω) is preferentially selected as the target point, the grids in the D0(ω) in both north and south directions are defined as ωN and ωS, if BVω>0 and {ωN,ωS}⊂F0, wherein, ω represents the grid sequence number of the position where the USMV is currently located, the BV is the potential value of the ω grid, in order to circumvent the case of massive backtracking, the grid adjacent to the obstacle is preferentially selected from the two grids, the grid is denoted as tpobs, in the case where both the ωN and ωs meet the condition, both are introduced into a cost calculation formula to calculate the potential cost values J(tp) produced by both paths, and a relatively optimum path is selected from local and global points of view:
The purpose of calculating the potential cost value is to comprehensively consider the moving distance, turning angle and global trend, so that the tp of the USMV is in a reasonable range of the map. Calculating the situation can make the USMV give priority to cover areas with the high task completion degree and avoid redundant paths in large blank areas.
If there is an adjacent obstacle on only one side of ωN and ωs, then then a ωN or ωs orientation where the adjacent obstacle is located is given priority to start traversal, wherein in the case of BVω>0, the above judgment conditions are not met, then the situation should be: the ω grid where the USMV is located has not yet been explored, in the two upper and lower orientations, one side is the mission completion or obstacle area and the other side is the free space that has not yet been explored, at the moment, the ω is the tp point, and the USMV switches to a tc instruction which guides the USMV to start the actual bathymetry mission.
If BVω=0, F0≠Ø, the USMV has completed the task on the single scanning line, and starts to turn to the next phase of traversal, at the moment, the grid α0 with the largest BVF
If none of the above cases are met, it is determined that the USMV is in the locally optimum state at the moment, wherein the most likely case is driving into a concave obstacle field or being surrounded by an area with BV≥0, at the moment, the high-level map phase is started for path finding, and a tr instruction is output. The tr instruction represents a non-normal task state after the USMV is in a Travel state and reaches local optimum.
The priority field is determined by:
F
0={α0∈D0(ω):BVα
The potential cost value is determined by:
J(tp)=kθ·θ(ω,tp)+kd·d(ω,tp)+kid·Nexp,
wherein,
d(ω,tp)=∥(ωx,ωy)−(tpx,tpy)∥2
kθ represents a turn cost coefficient and is considered as a unit turn angle cost; θ represents an absolute value of an angular change; kd represents a distance cost coefficient, and is considered as a unit distance movement cost; d represents a Euclidean distance; kul represents a global trend coefficient and is considered as as the cost of changing the situation; Nexp represents the number of ue-state grids in the input direction, (ωx,ωy) represents the horizontal and vertical coordinates of the ω point, and (tpx,tpy) represents the horizontal and vertical coordinates of the tp point.
In some alternative embodiments, in the step S103, the BLl-level map phase refers to a phase where the level is higher than the BL0-level map, i.e. 1≤l≤Land L represents the number of map phases. First, the detection field and priority field at the BLl-level map phase are defined: the USMV detection field at the ω position in the BLl-level map and having the detection range of RI, is defined as Dl(ω), wherein ω∈Dl(ω); the field in the detection domain Dl(ω) that is reachable through an adjacent path with ω and is positive in the BVα
Because of the strategy of IBA* algorithm for priority obstacle avoidance, the local optimum case occurs in the vast majority of cases at the end of the obstacle or at the end of the scanning line, an adjacent path in the tr state is calculated with a greedy algorithm, i.e. the obstacle contour is continued to be tracked until the USMV moves directly to the target point, the state of entering the locally optimum area is broken away and the target point is reached, in the scanning task, for a scenario in which a dynamic obstacle exists, a collision avoidance action is performed by the USMV, and the USMV switches to the tr state, the BL0-level map is continued to be entered after past and clear, the coverage operation is resumed, if it is still impossible to break away from the local optimum when l=1, the map is updated level by level until the tp point is derived and if there is no solution when l=L, then it is preliminarily determined that the traversal is completed.
At the BL-level map phase, the priority domain is specifically expressed as:
F
l={αl∈Dl(ω):BVαl>0}
In some alternative embodiments, in the step S104, based on the known partial environmental information, reviewing missing areas, generating coverage rate information, and considering whether to switch the tr state to perform the return or continue the scanning task in a specific area according to the actual state requirements of the USMV.
The application also provides a computer-readable storage medium, such as a flash memory, a hard disk, a multimedia card, a card-type memory (e.g., SD or DX memory, etc.), a random access memory (RAM), a static random access memory (SRAM), a read-only memory (ROM), an electrically erasable programmable read-only memory (EEPROM), a programmable read-only memory (PROM), a magnetic memory, a disk, an optical disk, a server, an App market, etc., a computer program is stored thereon which, when executed by a processor, implements the coverage-path planning method for the single unmanned surface mapping vessel in a method embodiment.
It should be noted that the various steps/components described in the present application may be split into more steps/components or two or more steps/components or partial operations of the steps/components may be combined into new steps/components to achieve the objectives of the present invention, depending on the requirements of the implementation.
It will be readily understood by those skilled in the art that the above description is only preferred embodiments of the present invention and is not intended to limit the present invention. Any modification, equivalent replacement, improvement, etc. made within the spirit and principles of the present invention should be included in the scope of protection of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
202010987645.4 | Sep 2020 | CN | national |
This application is a continuation of International Patent Application No. PCT/CN2021/117160 with a filing date of Sep. 8, 2021, designating the United States, now pending, and further claims priority to Chinese Patent Application No. 202010987645.4 with a filing date of Sep. 8, 2020. The content of the aforementioned applications, including any intervening amendments thereto, are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2021/117160 | Sep 2021 | US |
Child | 18069986 | US |