The present invention relates to the field of robot perception and computer vision, in particular to an active scene mapping method based on constraint guidance and space optimization strategies.
It is essential for many applications in the field of computer vision and robots to scan complex and unknown indoor scenes and construct a complete map. If manually operated, the scanning process is time-consuming and inconvenient, and the mapping results depend heavily on the experience of the scanner, which is not friendly to novice users. Therefore, how to design an exploration strategy that can guide the robot to independently complete the exploration scanning of the whole scene and maximize the scanning of the scene regions with the shortest exploration path has become a crucial research problem which is often called active mapping. Methods related to active mapping can be roughly divided into three categories:
The pioneering work for active mapping introduces the concept of frontier in the traditional heuristic method in “Yamauchi B. A frontier-based approach for autonomous exploration[C]//Proceedings 1997 IEEE International Symposium on Computational Intelligence in Robotics and Automation CIRA'97. ‘Towards New Computational Principles for Robotics and Automation’. IEEE, 1997: 146-151.”. Grid maps are defined as three types: free, unknown and occupy.
By moving the robot to the nearest frontier point in the occupancy map, the robot is driven to explore and scan the whole scene until no frontier point exists in the map, that is, the whole scene is considered to be completely scanned and the exploration ends. Such methods work well for scene exploration. However, the selection of frontier points is usually based on the greedy strategy, so it is difficult to obtain an approximate global optimal solution.
Unlike the traditional heuristic method which uses the myopic strategies to select goals from a set of frontier points, the learning-based method in “Chaplot D S, Gandhi D, Gupta S, et al. Learning to explore using active neural slam[J]. arXiv preprint arXiv:2004.05155, 2020” and “Ye K, Dong S, Fan Q, et al. Multi-robot active mapping via neural bipartite graph matching[C]//Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition. 2022: 14839-14848” directly uses a convolutional neural network (CNN) or a graph neural network (GNN) to regress the goal position by maximizing the long-term value via reinforcement learning, which allows the exploration strategy to approach global optimization and reduces the computing time of the decision-making process. However, such work usually only uses raw data as the state input of reinforcement learning without further data processing to improve the exploration efficiency.
In the information-theoretic method in “Whaite P, Ferrie F P. Autonomous exploration: Driven by uncertainty[J]. IEEE Transactions on Pattern Analysis and Machine Intelligence, 1997, 19(3): 193-205.” and “Elfes A. Robot navigation: Integrating perception, environmental constraints and task execution within a probabilistic framework[C]//Reasoning with Uncertainty in Robotics: International Workshop, RUR'95 Amsterdam. The Netherlands Dec. 4-6, 1995 Proceedings. Berlin, Heidelberg: Springer Berlin Heidelberg, 2005: 91-130”, another method in the field of active mapping is to use the information theory to guide the robot to select an action that can maximize information gain or reduce scene uncertainty by calculating the information gain or uncertainty values of actions, so as to complete the independent exploration of the scene. However, the action selection of the exploration strategy in the information-theoretic method is still essentially based on the greedy strategy, and the calculation method for information gain or uncertainty values will also have a serious effect on the exploration efficiency.
Most of the above methods rely on the greedy strategy, or the state input form is simple, so the efficiency is limited. In contrast, the method of the present invention optimizes the global optimal exploration problem by means of hybrid-stage optimization instead of maximizing the immediate reward, so as to seek an optimal exploration path globally.
Aiming at the problem that the existing active mapping of robots has low exploration efficiency and is prone to local optimization, the present invention proposes an active scene mapping method based on constraint guidance and space optimization strategies. By calculating the information entropy of each action in the action space and using the action mask based on reinforcement learning to constrain and guide the exploration strategy of the robot, the entropy space is aligned with the geodesic distance space of the real world so that the exploration process of the robot is not to maximize the immediate reward, so as to seek an optimal exploration path globally.
The present invention has the following technical solution: an active scene mapping method based on constraint guidance and space optimization strategies, comprising a global planning stage and a local planning stage; in the global planning stage, the next exploration goal of a robot is calculated to guide the robot to explore a scene; and after the next exploration goal is determined, specific actions are generated according to the next exploration goal, the position of the robot and the constructed occupancy map in the local planning stage to drive the robot to go to the next exploration goal, and observation data is collected to update the information of the occupancy map, specifically comprising the following steps:
Step 1: generating a state according to the scanning data of the robot;
The state comprises three parts: an occupancy map Mt, a geodesic distance map D(Mt, ωt) and a frontier-based entropy I(Mt); and ωt indicates the position of the robot;
s(ωt)=(Mt,D(Mt,ωt),I(Mt)
A 3D scene model is obtained by back projection of the depth with the pose of the robot according to the observation C(ωt) of the robot in position ωt; a 2D global map is constructed from the top-down view of the 3D scene model as an occupancy map Mt; at time t, the occupancy map is expressed as Mt∈[0,1]X×Y×2, and X, Y represent the length of the occupancy map and the width of the occupancy map, respectively; the occupancy map comprises two channels indicating the explored and occupied regions, respectively; the grids in the occupancy map Mt are classified as follows: free (explored but not occupied), occupy (occupied) and unknown (not explored); and the frontier grid Ft⊂Mt is a free grid adjacent to an unknown grid;
Given the current position cot and the currently constructed occupancy map Mt, a geodesic distance map D(Mt, ωt)∈X×Y is constructed, wherein Dx,y(Mt, ωt) represents the geodesic distance from the position (x, y) to the position cot of the robot:
D
x,y(Mt,ωt)=distM
The geodesic distance distM
In addition to raw data Mt and D(Mt, ωt), the present invention is also expected to introduce high-level information as constraints, so the frontier-based entropy is introduced as constraints to reduce the searching space when the height of the occupancy map Mt is incomplete; and the frontier point f∈Ft represents a next potential optimal exploration goal, it is found through observation that the frontier points in the scene usually do not exist alone and have the characteristics of small-range aggregation and large-range dispersion, a frontier-based entropy I is introduced for encoding the spatial distribution information of the frontier points, the encoded spatial distribution information is used as one of the inputs of the actor network in the global planning strategy Π to constrain action search, and the frontier-based entropy I is defined as follows:
wherein Ix,y(Mt) represents the number of frontier points within the γ×γ neighborhood centered on the position (x,y) of the frontier point in the occupancy map Mt; and the spatial distribution information contained in each frontier point includes the (x,y) coordinate of the position of the point and the statistical information of the spatial distribution of the frontier points within the neighborhood;
It should be noted that if a frontier point is surrounded by more frontier points, the frontier point will be given a larger information entropy, and for scattered frontier points or noise points, a smaller information entropy can also reduce the impact on global optimization.
Step 2: calculating the probability distribution of the action space of the robot according to the state input;
Off-policy learning approach proximal policy optimization (PPO) is used as a policy optimizer for training optimization and decision execution of the global planning strategy; and the policy optimizer comprises an actor network and a critic network;
The actor network is trained to learn a strategy network and outputs the probability that each action is selected, which uses a multi-layer perceptron (MLP) as an encoder for feature extraction and uses a graph neural network for feature fusion; and a graph is constructed according to the frontier point given by the state s(ωt), and feature extraction and feature fusion are carried out on the constructed graph to obtain the score of the frontier point;
The critic network comprises five convolutional layers, a flatten operation and three linear layers, a ReLu activation function is attached behind each convolutional layer and each linear layer, and the flatten operation is used for flattening multi-dimensional data into one-dimensional data; and the critic network is used for predicting the state value V(s(ωt)) of the occupancy map to indicate the critic value obtained by the current state of the frontier point, and the critic value, as part of the loss function, is used for back propagation during training and for training the actor network;
The process of calculating the probability distribution of the action space according to the state input is specifically as follow:
A graph G(Ft,Ωt) is constructed based on the frontier grid Ft and the exploration path Ωt={ω0, . . . , ωt} to represent the context information of the current scene, a corresponding relation between the robot and the frontier point extracted from the occupancy map Mt is established in the graph G(Ft,Ωt), and the information given by the state s(ωt) is assigned to the node and edge of G(Ft,Ωt); for each node ng, the node input feature feat(n)∈5 includes: (x,y) coordinate information in the occupancy map Mt, semantic label information indicating ni∈Ft or ni∈Ωt, historical label information indicating that ni is the current node ωt or historical exploration node ni∈{ω0, . . . , ωt−1}, and a frontier-based entropy In
Step 3: carrying out action mask guided space alignment and selecting the next exploration goal;
The robot selects the frontier point with the highest score a according to
as the next exploration goal ωt+1, wherein Π represents the global planning strategy to calculate the score of each frontier point in the current state; and the action space A is to select a frontier point f from the frontier grid Ft;
Misalignment of the space metrics of the real-world space and Π(a|s(ωt)) will cause the robot to get stuck or turn back and forth in particular cases. Therefore, based on the score of the frontier point, the action mask strategy is introduced to solve the misalignment problem of the space metrics, and the metrics of the critic value space and the real-world space are aligned; and the action mask strategy includes two action masks: a valid distance mask and a stuck mask, which are used for filtering actions in the action space of the global planning strategy Π and constraining action sampling to a valid action space;
When the robot is exploring in a wide range of complex scenes, it is reasonable and efficient to explore the scenes gradually instead of wandering back and forth among multiple goals. Therefore, ideally, actions given by Π(a|s(ωt)) shall be distributed within a reasonable range around wt to ensure gradual exploration, and such heuristic property also implicitly requires that the metric of Mt and Π(a|s(ωt)) be aligned. To achieve the purpose, a valid distance mask is designed to filter invalid goals in the action space of the global planning strategy; the action space is filtered according to the geodesic distance from the position ωt of the robot to the next optimal exploration goal; the nearest threshold βnear and the farthest threshold βfar are set; and for a next potential optimal exploration goal beyond the threshold range [βnear, βfar], the sampling probability is set to 0, and Πmask(f|s(ωt)) after the valid distance mask is as follows:
wherein Πmask(f|s(ωt)) represents the action mask probability of selecting the frontier point f as the next exploration goal, distM
The stuck mask is used for filtering out actions in the action space that cause the robot to get stuck; the max moving length
and the max area increment
of the robot in the last three global planning stages are calculated, wherein c(Mt) represents the area of the scanned region at time t calculated according to the occupancy map Mt, and when the moving length lmax and the area increment cmax are greater than the set thresholds, the action is considered reasonable; otherwise, the probability value corresponding to the action is set to 0, that is Πmask(a|s(ωt)=0;
Step 4: planning a path to the next exploration goal;
The robot uses the fast marching method (FMM) to plan a moving path according to the position wt of the robot, the next exploration goal ωt+1 obtained by calculation and the constructed occupancy map Mt to drive the robot to go to the next exploration goal, and observation data scanned by the robot during movement is collected to update the information of the map.
Step 5: making a judgment about the termination of exploration;
Repeating steps 1-4 to judge whether the exploration meets the termination conditions, and terminating the exploration when the scanning coverage of the robot exceeds the set threshold or the number of exploration steps of the robot exceeds the maximum set number of steps.
In the present invention, the entropy of each frontier point is calculated firstly and used as additional information of the state input to guide the exploration strategy of the robot to imitate the local greedy strategy. However, entropy-based optimization is prone to local optimization because the entropy space and the real world do not share the same metric. Inspired by constrained reinforcement learning, the present invention introduces constraint optimization based on action masks to align the metrics of the two spaces, and the exploration optimization in the aligned spaces can more effectively avoid long-distance round trips and improve the scene exploration efficiency.
The specific implementation result is that the robot constructs a graph according to the collected local scene information, independently decides the position of the next goal through deep reinforcement learning, drives the robot to scan the scene, and iterates the process to complete the active mapping of the indoor scene and obtain a complete scene map, which involves the methods of robot mapping and independent decision-making.
Steps 1-3 belong to the global planning stage, which determines the next exploration goal, that is the long-term goal, for the robot through the policy network. Step 4 belongs to the local planning stage.
The present invention has the following beneficial effects: the present invention introduces a frontier-based entropy to constrain network inputs, the method combines the traditional heuristic method with reinforcement learning methods and proposes action mask constraints to guide the network to carry out valid global planning by adjusting the metrics of the critic value space and the real-world space, and such design is proved to effectively avoid long-distance round trips in the exploration process so that the robot can take account of information gain and movement loss in the exploration process, find a balance of the exploration efficiency, and realize the improvement of the active mapping efficiency.
Specific embodiments of the present invention are further described below in combination with accompanying drawings and the technical solution.
The present embodiment is run based on the IGibson simulator, 50 scenes are selected from the IGibson data set for training, and 13 scenes are selected from the IGibson and Matterport data sets for testing. Most of the training scenes and testing scenes are large-scale scenes (with the area greater than or equal to 30 m2), and also comprise large-scale scenes and small-scale scenes. The maximum number of scene exploration steps is set to n=3000, and the scene coverage of exploration termination is set to r=90%. The exploration will be terminated only when the number of exploration steps exceeds n or the area of the explored region is larger than r.
The quantitative verification results of the contrast experiment are shown in Table 1. The exploration area represents the total area of the regions scanned by the robot, and the coverage ratio is the ratio of the exploration area to the area of the whole scene, which is used for measuring the exploration completeness of the robot. The larger the value of completeness is, the more complete the scene scanning is. The exploration efficiency is the ratio of the exploration area to the number of exploration steps, which represents the average information gain of each exploration step of the robot and is used for measuring the exploration efficiency of the robot. The larger the value is, the higher the exploration efficiency of the robot is, and the more reasonable the exploration path planning of the robot is, without large-scale reentry and invalid actions.
Number | Date | Country | Kind |
---|---|---|---|
202310196559.5 | Mar 2023 | CN | national |