Embodiments of the present disclosure relate to the field of intelligent control, and more specifically, to a path planning method and apparatus.
Path planning is an important branch in the field of intelligent control researches. Using a good path planning technology can reduce an operating time of an intelligent execution apparatus (for example, a robot), improve task execution efficiency, and improve task execution quality.
A map may be used to implement path planning. The map includes location information and obstacle information such that an intelligent execution apparatus can find, based on the map, a path that can bypass an obstacle.
However, only the location information and the obstacle information are considered in existing path planning, and other factors are not considered. Consequently, application of path planning is limited.
Embodiments of the present disclosure provide a path planning method and device, to implement better path planning.
According to a first aspect, a path planning method is provided. The method includes obtaining, based on a pass-through distance of each of a plurality of first areas and a representation value of an environment characteristic of each first area, a pass-through cost for passing through each first area, obtaining a start location and a target location, and performing path planning based on the pass-through cost for passing through each first area, to determine a pass-through path from the start location to the target location, where the pass-through path includes an area passed through from the start location to the target location.
Therefore, the pass-through cost for passing through each first area is obtained based on the pass-through distance of each of the plurality of first areas and the representation value of the environment characteristic of each first area, and path planning is performed based on the pass-through cost. In this way, when path planning is performed, not only a pass-through distance of an area but also a representation value of an environment characteristic of the area can be considered, to implement better path planning. Further, the pass-through distance and the representation value are quantized into a pass-through cost such that when an intelligent execution apparatus performs path planning, a pass-through path is obtained based on the pass-through cost, to reduce an operating time of the intelligent execution apparatus, and improve task execution efficiency.
Optionally, the pass-through path may be a path with a minimum pass-through cost.
Optionally, the method further includes generating an environment map based on the pass-through cost for passing through each first area, where the environment map includes the pass-through cost for passing through each first area, and is used to mark the representation value of each first area within a coverage area of the plurality of first areas, and the performing path planning based on the pass-through cost for passing through each first area, to determine a pass-through path from the start location to the target location includes based on the environment map, determining the pass-through path based on the pass-through cost for passing through each area within the coverage area of the plurality of areas.
Therefore, the pass-through cost in each first area is obtained based on the pass-through distance of each of the plurality of first areas and the representation value of the environment characteristic of each first area, and the environment map on which a pass-through cost of each area is marked is generated such that a better map can be obtained.
Optionally, the environment map may be a pass-through cost list or a global pass-through cost topology view.
Optionally, the obtaining, based on a pass-through distance of each of a plurality of first areas and a representation value of an environment characteristic of each first area, a pass-through cost for passing through each first area includes determining, based on the pass-through distance of each first area, a first pass-through cost component corresponding to the pass-through distance of each first area, determining, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the representation value of the environment characteristic of each first area, and calculating, based on the first pass-through cost component and the second pass-through cost component of each first area, the pass-through cost for passing through each first area.
Therefore, for each task type, a pass-through cost of the task type in each area is calculated. In this way, when path planning of a task type is performed, a pass-through cost of each area for the task type can be directly obtained, to implement more optimized path planning.
Optionally, the method further includes obtaining at least one task type to be executed when the pass-through path is passed through, the obtaining, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the pass-through distance of each first area includes obtaining, based on a representation value of at least one type of available environment characteristic of each of the at least one task type in each first area, a second pass-through cost component corresponding to each task type at each first area, the calculating, based on the first pass-through cost component and the second pass-through cost component of each first area, the pass-through cost for passing through each first area includes calculating, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to each task type in each first area, a pass-through cost for passing through each first area when each task type is executed, and the performing path planning based on the pass-through cost for passing through each first area includes determining, based on the pass-through cost for passing through each first area when each task type is executed, the pass-through path used for executing each task type.
Optionally, the at least one task type includes a first task type, and the obtaining the second pass-through cost component corresponding to each task type in each first area includes determining, based on a representation value of at least one type of environment characteristic whose representation value meets a predetermined condition and that is in an available environment characteristic of the first task type in each first area, a second pass-through cost component corresponding to the first task type in each first area.
Optionally, the first area is an area that meets the following condition, the representation value of an available environment characteristic of the first task type in the first area meets an environment characteristic requirement of the first task type.
Optionally, the method further includes determining at least one second area, where the representation value of the available environment characteristic of the first task type in the second area does not meet the environment characteristic requirement of the first task type, and when path planning is performed, considering each of the at least one second area as an obstacle.
Optionally, the method further includes obtaining a plurality of task types to be executed when the pass-through path is passed through, the obtaining, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the representation value of the environment characteristic of each first area includes obtaining, based on a representation value of at least one type of available environment characteristic of each of the plurality of task types, a second pass-through cost component corresponding to a whole of the plurality of task types in each first area, the calculating, based on the first pass-through cost component and the second pass-through cost component of each first area, the pass-through cost for passing through each first area includes calculating, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to the whole of the plurality of task types in each first area, a pass-through cost corresponding to the whole of the plurality of task types in each first area, and the performing path planning based on the pass-through cost for passing through each first area includes determining, based on the pass-through cost corresponding to the whole of the plurality of task types in each first area, the pass-through path used for executing the plurality of task types.
Therefore, the plurality of task types may be considered as a whole, and the pass-through cost of the whole of the plurality of task types in each area is obtained. In this way, when path planning required for executing the plurality of task types is performed, a pass-through cost of the whole of the plurality of task types in each area can be directly obtained, to reduce a processing time of the intelligent execution apparatus, and improve processing efficiency.
Optionally, the obtaining a second pass-through cost component corresponding to a whole of the plurality of task types in each first area includes obtaining, based on a representation value of at least one type of available environment characteristic of each of the plurality of task types in each first area, a second pass-through cost component corresponding to each task type in each first area, and performing weighted processing on a plurality of second pass-through cost components corresponding to the plurality of task types in each first area, to obtain the second pass-through cost component corresponding to the whole of the plurality of task types in the first area.
Optionally, the first area is an area that meets the following condition, the representation value of the available environment characteristic of each of the plurality of task types in the first area meets an environment characteristic requirement of each task type.
Optionally, the method further includes determining at least one third area, where a representation value of an environment characteristic corresponding to at least one of the plurality of task types in the third area does not meet a representation value requirement of the at least one task type, and when path planning is performed, considering each of the at least one third area as an obstacle.
Optionally, the determining, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the representation value of the environment characteristic of each first area includes determining, based on a representation value of an environment characteristic of each area and a correspondence between a representation value interval of an environment characteristic and a pass-through cost component, the second pass-through cost component in each first area.
Optionally, the obtaining, based on a pass-through distance of each of a plurality of first areas and a representation value of an environment characteristic of each first area, a pass-through cost for passing through each first area includes obtaining, in a statistical manner based on the pass-through distance of each first area and representation values that are of an environment characteristic of each first area and that are obtained at a plurality of times, the pass-through cost for passing through each first area, or obtaining, in real time based on the pass-through distance of each first area and a real-time representation value of an environment characteristic of each first area, the pass-through cost for passing through each first area, or obtaining, based on the pass-through distance of each first area and a predicted representation value of an environment characteristic of each first area, the pass-through cost for passing through each first area.
Optionally, the obtaining, in a statistical manner based on the pass-through distance of each first area and representation values that are of an environment characteristic of each first area and that are obtained at a plurality of times, the pass-through cost for passing through each first area includes, when a change rate of a representation value of an environment characteristic of each first area is less than or equal to a first threshold, obtaining, in a statistical manner based on the pass-through distance of each first area and the representation values that are of the environment characteristic of each first area and that are obtained at a plurality of times, the pass-through cost for passing through each first area.
Optionally, the obtaining, in real time based on the pass-through distance of each first area and a real-time representation value of an environment characteristic of each first area, the pass-through cost for passing through each first area includes, when a change rate of a representation value of an environment characteristic of each first area is greater than a second threshold, obtaining, in real time based on the pass-through distance of each first area and the real-time representation value of the environment characteristic of each first area, the pass-through cost for passing through each first area.
Optionally, the environment characteristic includes a visual signal, the determining, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the representation value of the environment characteristic of each first area includes obtaining, based on a representation value of a visual signal that passes through each first area and that is in each of the plurality of directions, a second pass-through cost component corresponding to each direction at each first area, and the calculating, based on the first pass-through cost component and the second pass-through cost component of each first area, the pass-through cost for passing through each first area includes determining, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to each direction in each first area, a pass-through cost for passing through each first area in each direction.
Optionally, the environment characteristic includes at least one of a visual signal, a sound signal, and a contact surface status.
Optionally, the environment characteristic includes a visual signal, and a representation value of the visual signal includes light intensity and/or a quantity of visible characteristics.
Optionally, the environment characteristic includes a sound signal, and a representation value of the sound signal includes strength of the sound signal.
Optionally, the environment characteristic includes a contact surface status, and a representation value of the contact surface status includes an inclination degree, a height change rate, and/or a friction degree of a contact surface of the location.
According to a second aspect, a path planning apparatus is provided. The path planning apparatus may include a unit configured to perform the method in the first aspect or any one of the optional implementations of the first aspect.
According to a third aspect, a path planning apparatus is provided. The path planning apparatus may include a memory and a processor. The memory may store program code, the processor communicates with the memory using an internal connection path, and the processor may invoke the program code stored in the memory, to perform the method in the first aspect or any one of the optional implementations of the first aspect.
According to a fourth aspect, a storage medium is provided. The storage medium may store program code, and a processor may invoke the program code stored in the storage medium, to perform the method in the first aspect or any one of the optional implementations of the first aspect.
The following describes the technical solutions in the embodiments of the present disclosure with reference to the accompanying drawings in the embodiments of the present disclosure.
The environment system 110 may generate an environment characteristic, and the environment characteristic may include at least one of a visual signal, a sound signal, and a contact surface status. The environment characteristic may further include another characteristic, which is not specifically limited herein.
The intelligent execution apparatus 120 may perform path planning based on a representation value of the environment characteristic generated by the environment system 110.
In an embodiment, the intelligent execution apparatus 120 may generate an environment map based on the representation value of the environment characteristic, and perform path planning based on the environment map.
Optionally, the system may further include an intelligent execution apparatus 130.
The intelligent execution apparatus 120 may further send the generated environment map to the intelligent execution apparatus 130. The intelligent execution apparatus 130 may perform path planning based on the environment map sent by the intelligent execution apparatus 120.
It should be understood that the intelligent execution apparatus described in this embodiment of the present disclosure may be a machining apparatus that automatically works, for example, may be a robot, a self-driving vehicle, or an unmanned aerial vehicle. Although the intelligent execution apparatuses 120 and 130 shown in
When path planning is performed, a candidate area may be divided into a plurality of areas, and a pass-through cost for passing through an area is marked in all or some areas. If a pass-through cost is high, a cost for passing through the area is high, and a probability that the area is selected is small when path planning is performed.
Optionally, a pass-through cost may be a value, and unitless values corresponding to all areas may be obtained for all the areas based on a same criterion.
The following describes in detail how to obtain pass-through costs for passing through a plurality of areas and generate an environment map based on the pass-through costs of the plurality of areas, and describes how to perform path planning based on the pass-through costs of the plurality of areas.
As shown in
210. Obtain, based on a pass-through distance of each of a plurality of first areas and a representation value of an environment characteristic of each first area, a pass-through cost for passing through each first area.
Optionally, the intelligent execution apparatus may directly detect a representation value of an environment characteristic of each area, or may receive a representation value that is of an environment characteristic and that is sent by another device, or may receive a manually-input representation value of an environment characteristic.
Optionally, when directly detecting the representation value of the environment characteristic of each area, the intelligent execution apparatus may traverse all areas, to obtain the representation value of the environment characteristic for calculating a pass-through cost.
Optionally, the area described in this embodiment of the present disclosure may be referred to as a node, and the area may be a square structure, or may be a rectangle, a hexagon, or any other shape.
Optionally, pass-through distances of all areas in a map may be the same, or may be different.
Optionally, the pass-through distance of the first area is a length between any two points in the first area. For example, area division in a grid manner is used as an example, and a length between any two points may be a side-length distance or a diagonal distance.
Optionally, the environment characteristic described in this embodiment of the present disclosure may include at least one of a visual signal, a sound signal, and a contact surface status.
Optionally, a representation value of the visual signal includes light intensity and/or a quantity of visible characteristics.
Optionally, the visual signal may be used for positioning, for example, for positioning using a visible characteristic. Therefore, if a quantity of visible characteristics is large, positioning is easier. When positioning is performed, the light intensity may also affect positioning, for example, when the light intensity meets a visual requirement of an intelligent execution device, positioning is easier.
Optionally, the environment characteristic includes a sound signal, and a representation value of the sound signal includes strength of the sound signal.
Optionally, sound signals may be classified into noise and a beneficial sound signal, and the beneficial sound signal may include an ultrasonic signal, and positioning may be performed using the signal.
For example, intensity of noise in each area may be recorded, and if intensity of noise at a location is small or there is no noise, the location is more easily passed through.
For another example, when communication or positioning is performed using a sound, if strength of a sound signal in an area is high, it is considered that the area is more easily passed through.
Optionally, a representation value of the contact surface status includes an inclination degree, a height change rate, and/or a friction degree of a contact surface of the location.
For example, it is assumed that the contact surface is a road surface, and a representation value of the road surface may be a pass-through difficulty degree or a bumpy degree, whether the road surface is muddy, a slippery status, or an inclination angle of the road surface.
The contact surface status may be manually obtained, or contact surface statuses at different locations may be identified through detection performed by a device.
For example, a score may be manually provided based on a road surface status. For example, a road surface with water is scored 0 points, a muddy road surface is scored 10 points, a road surface with an inclination angle greater than 5 degrees is scored 0 points, a road surface with a slippery degree or bumpy degree exceeding a threshold is scored 10 points, and another case is scored 100 points. A pass-through cost is determined based on a score, for example, a higher score indicates a lower pass-through cost.
For example, a material of the road surface may be estimated using a visual identification method. If there is a visually identifiable object, such as a wire, a threshold, or a stairway, a representation value may be obtained by quantizing the object. The slippery degree may be estimated using a plurality of positioning manners and a method of robot odometry information comparison. The pass-through difficulty degree of a corresponding road segment may be estimated by recording an output power of a motor. The inclination angle of the road surface may be obtained through calculation using a sensor such as a gravity meter or a camera built in a robot.
It should be understood that the first area described in this embodiment of the present disclosure may be any area in the candidate area, or may be an area that meets a specific condition, for example, an area whose representation value of an environment characteristic meets a specific condition, and a pass-through cost may be calculated for the area. However, an area that does not meet a condition may be directly considered as an obstacle.
It should be understood that in this embodiment of the present disclosure, the pass-through cost for passing through the first area sometimes may be referred to as a pass-through cost of the first area or a pass-through cost in the first area.
Optionally, in this embodiment of the present disclosure, the intelligent execution apparatus may generate an environment map based on the pass-through cost for passing through each first area, where the environment map includes the pass-through cost for passing through each first area, and is used to mark the representation value of each first area within a coverage area of the plurality of first areas, and the environment map may be used for performing path planning.
Optionally, the environment map may be a pass-through cost list or a global pass-through cost topology view.
It should be understood that in this embodiment of the present disclosure, the environment map may mark a representation value of an environment characteristic, but it does not mean that a pass-through cost of each area in the map is related only to the representation value of the environment characteristic. The pass-through cost of each area is further related to a pass-through distance of each area. For example, if pass-through distances are inconsistent, representation values of an environment characteristic may be different even though pass-through costs are the same.
It should be understood that in this embodiment of the present disclosure, the intelligent execution apparatus may further not generate a map, but directly performs path planning based on pass-through costs of a plurality of first areas.
Optionally, the intelligent execution apparatus may obtain a pass-through cost in a corresponding area in a statistical or voting manner using representation values that are of an environment characteristic and that are obtained at a plurality of times, or may obtain in real time a pass-through cost in a corresponding area using a real-time representation value of an environment characteristic, or may obtain a pass-through cost in a corresponding area using a predicted representation value of an environment characteristic.
In an embodiment, the intelligent execution apparatus may obtain the pass-through cost in the corresponding area in the statistical or voting manner using the representation values that are of the environment characteristic and that obtained at a plurality of times, to generate an environment map, or may obtain in real time the pass-through cost in the corresponding area using the real-time representation value of the environment characteristic, to update an environment map in real time, or may obtain the pass-through cost in the corresponding area using the predicted representation value of the environment characteristic, to generate an environment map.
The statistical manner is to process together the representation values that are of the environment characteristic and that are obtained at a plurality of times, for example, perform weighted processing, to obtain the pass-through cost in the corresponding area. The voting manner is to select, from the representation values that are of the environment characteristic and that are obtained at a plurality of times, representation values that are of an environment characteristic and that are obtained at some of the plurality of times, to obtain the pass-through cost in the corresponding area.
In an embodiment, it may be determined with reference to an actual situation to obtain the pass-through cost in the statistical or voting manner, or in real time, or in a prediction manner, or through a combination of any two of the manners.
Optionally, when stability of the representation value of the environment characteristic is relatively good, the pass-through cost in the corresponding area may be obtained in the statistical manner, or when stability of the representation value of the environment characteristic is relatively poor, the pass-through cost in the corresponding area may be obtained in real time.
For example, when the environment characteristic is a visual signal, in an outdoor environment, illumination conditions are different at different time periods, and a map may be updated according to a time period. In indoor environments (for example, during business periods of shopping malls), illumination conditions are basically the same at same time periods, and a map may be generated in a statistical manner.
The stability of the representation value of the environment characteristic may be a change rate of the environment characteristic. For example, when a change rate of strength of the environment characteristic is less than or equal to a predetermined value, or a change rate of a direction of the environment characteristic is less than or equal to a predetermined value, it is considered that stability is relatively good.
Optionally, when the environment characteristic is a predictable environment characteristic, in other words, when the representation value of the environment characteristic at another moment and/or in another area can be predicted based on the representation value of the environment characteristic at a moment and/or in an area, it can be considered that the environment characteristic is a predictable environment characteristic.
For example, when the environment characteristic is a visual signal, an illumination condition at another time period may be predicted based on an illumination condition at a time period. When the environment characteristic is a sound signal, a sound signal at another time period may be predicted based on a sound signal at a time period. When the environment signal is a road surface status, the road surface status may be predicted based on a weather forecast status.
It should be understood that there may be another implementation for the prediction manner of the representation value of the environment characteristic in this embodiment of the present disclosure, and details are not described herein.
Optionally, the environment map in this embodiment of the present disclosure may include a pass-through cost of each of a plurality of areas, and the pass-through cost of each area may include a plurality of pass-through costs, for example, may include predicted pass-through costs at various moments. Therefore, when path planning is performed, a corresponding path plan in an area may be obtained with reference to a pass-through cost of the area at each moment and a current moment when the apparatus moves to the area, to select a better path.
Optionally, the map in this embodiment of the present disclosure may include pass-through costs for a plurality of directions in each of the plurality of areas, and a pass-through cost in each direction is a pass-through cost for passing through the area in the direction. For example, when the environment characteristic is a visual signal, different directions may have different representation values. For example, a representation value for a pass-through direction away from the sun is different from a representation value for a pass-through direction towards the sun.
It is assumed that an area in the map may include eight pass-through directions respectively at 0 degrees, 45 degrees, 90 degrees, 135 degrees, 180 degrees, 225 degrees, 270 degrees, and 315 degrees, and pass-through costs may be determined based on illumination conditions collected by cameras in the eight directions of the area.
It should be understood that another quantity of pass-through costs may be determined, and may be specifically determined based on a division shape of each area, a capability of the intelligent execution device, a requirement of a to-be-executed task, and the like.
In this embodiment of the present disclosure, the pass-through cost in each first area is obtained based on the pass-through distance of each of the plurality of first areas and the representation value of the environment characteristic of each first area such that when the environment map is generated, a pass-through cost in each area can be marked in each area. When the environment map is generated, not only a pass-through distance of an area but also a representation value of an environment characteristic of the area can be considered, and the pass-through distance and the representation value of the environment characteristic are quantized into a pass-through cost, to obtain a better environment map. In this way, the environment map is more widely applied, better path planning can be implemented, and the pass-through distance and the representation value of the environment characteristic are quantized into the pass-through cost such that when performing path planning, a robot can obtain a pass-through path based on the pass-through cost, thereby reducing an operating time of the robot, and improving task execution efficiency.
Optionally, in this embodiment of the present disclosure, when the pass-through cost in the first area is obtained with reference to the pass-through distance of the first area and the representation value of the environment characteristic, a first pass-through cost component corresponding to the pass-through distance and a second pass-through cost component corresponding to the representation value of the environment characteristic may be calculated, and the pass-through cost for passing through the area may be obtained with reference to the first pass-through cost component and the second pass-through cost component.
In an implementation, the first pass-through cost component and the second pass-through cost component of the first area may be added, to obtain the pass-through cost of the first area.
In another implementation, weighted processing may be performed on the first pass-through cost component of the first area and the second pass-through cost component of the first area, to obtain the pass-through cost of the first area. A weighting coefficient may be set based on a specific case, for example, if a to-be-executed task has relatively high sensitivity to a pass-through distance of an area, a relatively high weighting coefficient may be set for a size.
In another implementation, the second pass-through cost may be a coefficient that is multiplied by the first pass-through cost component to obtain the pass-through cost, and the pass-through cost in the first area may be obtained with reference to the first pass-through cost component and the coefficient.
It should be understood that in this embodiment of the present disclosure, in addition to the pass-through distance of the area and the representation value of the environment characteristic, another factor may be further considered. For example, a third pass-through cost component in each area is determined based on signal quality of a wireless signal (for example, a satellite signal or a network signal). Therefore, the first pass-through cost component, the second pass-through cost component, and the third pass-through cost component may be added or weighted, to obtain a pass-through cost of the area.
Optionally, the obtained second pass-through cost component in each area may be determined based on a representation value of an environment characteristic of each area and a correspondence between a representation value interval of an environment characteristic and a pass-through cost.
For example, an environment characteristic may be graded at three levels, good, medium, and poor. Each level includes a range of values that can be quantized, and each level may be corresponding to a different second pass-through cost component. After a representation value of an environment characteristic is obtained, a level of the representation value of the environment characteristic may be determined, and a second pass-through cost component corresponding to the level may be obtained.
For example, a good representation value of an environment characteristic is corresponding to a coefficient 1, a medium representation value of an environment characteristic is corresponding to a coefficient 5, and a poor representation value of an environment characteristic is corresponding to a coefficient 10. Pass-through costs corresponding to distances of an area are 10 (for a side-length distance) and 14 (for a diagonal distance). If a representation value of an environment characteristic at the location is poor, pass-through costs of the side-length distance and the diagonal distance at the location may be determined as 100 and 140, or if a representation value of an environment characteristic at the location is medium, pass-through costs of the side-length distance and the diagonal distance at the location may be determined as 50 and 70, or if a representation value of an environment characteristic at the location is good, pass-through costs of the side-length distance and the diagonal distance at the location may be determined as 10 and 14.
It should be understood that in this embodiment of the present disclosure, quality of an environment characteristic represents a difficulty degree in executing a task when the environment characteristic is used. Good quality represents that a task is easy to execute, and poor quality represents that a task is difficult to execute.
Optionally, in this embodiment of the present disclosure, a pass-through cost may be set on the environment map for each of a plurality of types of environment characteristics with reference to the pass-through distance. When a task is executed using the environment map, an environment characteristic usable in the task may be determined, and path planning may be performed using a pass-through cost obtained based on the usable environment characteristic.
Optionally, in this embodiment of the present disclosure, a pass-through cost of each area may be obtained with reference to at least one to-be-executed task type. In addition, optionally, a pass-through cost corresponding to the task type may be marked on the environment map, and when a task is executed using the environment map, a pass-through cost corresponding to the task may be determined, to perform path planning. The to-be-executed task includes but is not limited to at least one of positioning, communication, network connection, detection, and identification.
Optionally, the environment characteristic includes a visual signal. A second pass-through cost component corresponding to each direction in each first area is obtained based on a representation value of a visual signal that passes through each first area in each of the plurality of directions, and a pass-through cost in each first area in each direction is determined based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to the representation value of the visual signal that passes through each first area in each direction.
Optionally, in this embodiment of the present disclosure, a pass-through cost of each area may be obtained with reference to the at least one to-be-executed task type on the map. When the task is executed using the map, the pass-through cost corresponding to the task may be determined, to perform path planning. The to-be-executed task on the map includes but is not limited to at least one of positioning, communication, network connection, detection, and identification.
Optionally, a wireless pass-through cost is determined with reference to a requirement of a task type for a representation value of an environment characteristic and a representation value of an environment characteristic. For example, if an environment characteristic a is used in both a task type A and a task type B, and a requirement of the task type A for an environment characteristic is higher than a requirement of the task type B for an environment characteristic, with a same representation value, a pass-through cost component corresponding to the task type A is greater than a pass-through cost component corresponding to the task type B.
With reference to a manner A and a manner B, the following describes how to obtain a pass-through cost in each area with reference to a to-be-executed task type when an environment map is generated.
Manner A.
At least one to-be-executed task type is obtained, a second pass-through cost component of each task type in each first area is obtained based on a representation value of at least one type of available environment characteristic of each of the at least one task type in each first area, and a pass-through cost of each task type in each first area is calculated based on the first pass-through cost component of each first area and the second pass-through cost component of each task type in each first area.
Optionally, the environment map may be generated based on the pass-through cost of each task type in each first area, and the environment map includes the pass-through cost of each task type in each first area.
In other words, for each task type, a pass-through cost of the task type in each area is calculated. In this way, when path planning of a task type is performed, a pass-through cost of each area for the task type may be directly obtained, to implement better path planning.
When a second pass-through cost component of each task type in an area is calculated, a pass-through cost may be determined with reference to a requirement of a task type for a representation value of an environment characteristic and a representation value of an environment characteristic.
Optionally, the at least one task type includes a first task type, and a second pass-through cost component of the first task type in each first area is determined based on a representation value of at least one type of environment characteristic whose representation value meets a predetermined condition and that is in an available environment characteristic of the first task type in each first area.
Optionally, the at least one type of environment characteristic that meets the predetermined condition may be an environment characteristic whose representation value is greater than a specific threshold, or may be an environment characteristic with an optimal representation value.
In an embodiment, if there are a plurality of types of available environment characteristics for a task, an environment characteristic with relatively good quality may be selected when the intelligent execution apparatus moves to the area and executes the to-be-executed task. Therefore, a pass-through cost component can be calculated using the environment characteristic with relatively good quality. For example, when a task is to perform positioning, if the positioning may be performed in an area using a quantity of visible characteristics and a sound signal, positioning precision in the two manners may be estimated, and higher positioning precision may be determined as a parameter used for determining a pass-through cost in the area.
For the first task type, if there are a plurality of types of available environment characteristics in an area, the second pass-through cost component may be calculated with reference to representation values of the plurality of types of environment characteristics, for example, weighted processing may be performed on the representation values of the plurality of types of environment characteristics, and the representation value obtained through the weighted processing may be used for calculating the second pass-through cost component. Alternatively, the second pass-through cost components are separately calculated based on the representation values of the plurality of types of environment characteristics, and weighted processing is performed on the obtained plurality of second pass-through cost components, to obtain a final available second pass-through cost component. Certainly, in addition to weighted processing, another processing manner may be used, which may be specifically determined based on an actual situation. For example, if there are a plurality of types of environment characteristics, the plurality of types of environment characteristics may be used together, processing similar to addition processing may be performed on representation values of the plurality of types of environment characteristics, and the second pass-through cost component may be further obtained through calculation.
Optionally, the first area may be any area included in the candidate area, or may be an area that meets the following condition, the representation value of an available environment characteristic of the first task type in each first area meets an environment characteristic requirement of the first task type.
Optionally, at least one second area is determined, and the representation value of the available environment characteristic of the first task type in the second area does not meet the environment characteristic requirement of the first task type, and when path planning is performed, the second area may be considered as an obstacle.
Optionally, each of the at least one second area is marked as an obstacle on the environment map for the first task type.
Manner B.
A plurality of to-be-executed task types are obtained, a second pass-through cost component of a whole of the plurality of task types in each first area is obtained based on a representation value of at least one type of available environment characteristic of each of the plurality of task types, and a pass-through cost of the whole of the plurality of task types in each first area is calculated based on the first pass-through cost component of each first area and the second pass-through cost component of the whole of the plurality of task types in each first area.
Optionally, the environment map may be generated based on the pass-through cost of the whole of the plurality of task types in each first area, and the environment map includes the pass-through cost of the whole of the plurality of task types in each first area.
In other words, the plurality of task types may be considered as a whole, and the pass-through cost of the whole of the plurality of task types in each area may be obtained. In this way, when path planning required for executing the plurality of task types is performed, a pass-through cost of the whole of the plurality of task types in each area may be directly obtained, to implement better path planning.
Optionally, a second pass-through cost component of each task type in each first area is obtained based on a representation value of at least one type of available environment characteristic of each of the plurality of task types in each first area, and weighted processing is performed on a plurality of second pass-through cost components of the plurality of task types in each first area, to obtain the second pass-through cost component of the whole of the plurality of task types in the first area.
In addition to weighted processing, another processing manner may be used, which may be specifically determined based on an actual situation. For example, processing similar to addition processing may be performed on representation values of the plurality of types of environment characteristics, and the second pass-through cost component may be further obtained through calculation. Alternatively, addition processing is performed on a plurality of second pass-through cost components corresponding to a plurality of task types, and a sum value is used as a pass-through cost corresponding to the whole of the plurality of task types.
It should be understood that in this embodiment of the present disclosure, when a second pass-through cost component of the whole of the plurality of task types in an area is calculated, the used at least one type of available environment characteristic of each task type may be all available environment characteristics of a corresponding task type in the area, or may be some available environment characteristics of a corresponding task type in the area, for example, at least one type of environment characteristic with an optimal representation value.
Optionally, the first area may be any area included in the environment map, or may be an area that meets the following condition. the representation value of the available environment characteristic of each of the plurality of task types in each first area meets an environment characteristic requirement of each task type.
Optionally, at least one third area is determined, and a representation value of an environment characteristic corresponding to at least one of the plurality of task types in the third area does not meet a representation value requirement of the at least one task type, and when path planning is performed, the third area is considered as an obstacle.
Optionally, each of the at least one third area is set as an obstacle on the environment map for the plurality of task types.
It should be understood that when the environment map is generated, the foregoing manner A and manner B may be combined for use.
For example, tasks to be executed using the environment map include a task 1, a task 2, and a task 3, pass-through costs are respectively calculated for the task 1, the task 2, and the task 3, and a total pass-through cost of the task 1, the task 2, and the task 3 is calculated, or a pass-through cost of the task 1 is calculated, and a total pass-through cost of the task 2 and the task 3 is calculated.
It should be understood that in this embodiment of the present disclosure, classification of “types” of environment characteristics may indicate differences of environment characteristics, for example, a visual signal and a sound signal are considered as different types of environment characteristics, or may indicate different sources of a same type of environment characteristic, for example, light emitted from the sun and light emitted from a lamp in visual signals. A distinguishing dimension of “type” may be determined based on a specific actual situation.
Similarly, classification of “types” of tasks may also be determined based on a specific situation, for example, agricultural use and industrial use are different task types, and for example, positioning and communication are different task types.
220. Obtain a start location and a target location.
230. Perform path planning based on the pass-through cost for passing through each first area, to determine a pass-through path from the start location to the target location, where the pass-through path includes an area passed through from the start location to the target location.
Optionally, in this embodiment of the present disclosure, the path from the start location to the target location may be determined using the environment map.
When path planning is performed using the environment map, a plurality of algorithms may be used, for example, a Dijksra algorithm, an A* algorithm, and the like.
For ease of understanding, the following describes how to implement path planning with reference to the A* searching algorithm.
In the A* algorithm, the following formula 1 is required:
F(n)=G(n)+H(n) formula 1
F(n) is an estimated pass-through cost for passing through an start node, an intermediate node n, and then a target node, G(n) is an actually obtained pass-through cost for passing through the start node to the intermediate node n, and H(n) is an estimated pass-through cost of an optimal path from the intermediate node n to the target node.
H(n) may be calculated using a Manhattan algorithm or another algorithm, and is not specifically limited herein.
A key to find out the optimal path lies in selection of an evaluation function F(n). For clear understanding of the algorithm, the following specifically describes an execution manner of the algorithm.
Step 1: Add the start node to an enabled list.
Step 2: Repeat the following operations.
a. Find a node with a lowest value of F in the enabled list, namely, a current node.
b. Switch the current node to a disabled list.
c. Perform the following operations on each adjacent node of the current node.
(1) If the adjacent node cannot be passed through or is in the disabled list, ignore the node.
(2) If the adjacent node is not in the enabled list, add the adjacent node to the enabled list, use the current node as a traceback node of the node, and record values of F, G, and H of the node.
(3) If the adjacent node is already in the enabled list, use a value of G as a reference to check whether a new path is better, and if the new path is better, use a traceback node of the adjacent node as the current node, and re-calculate values of G and F of the node.
d. Stop the process in the following two cases.
(1) The target node is added to the disabled list, and in this case, the path has been found.
(2) No target path is found. In this case, the enabled list is empty, indicating that no path is found.
Step 3: Save a path. A path from the target node to the start node along a traceback node of each node is a selected path.
For clearer understanding of an implementation of the A* algorithm, the following is described with reference to
As shown in
As shown in
As shown in
As shown in
As shown in
Therefore, it can be seen from
310. Obtain, based on a pass-through distance of each of a plurality of first areas and a representation value of an environment characteristic of each first area, a pass-through cost for passing through each first area.
320. Generate an environment map based on the pass-through cost for passing through each first area, where the environment map includes the pass-through cost for passing through each first area, and is used to mark the representation value of each first area within a coverage area of the plurality of first areas.
Optionally, for a specific implementation of the map generation method shown in
410. Obtain an environment map, where the environment map includes a pass-through cost for passing through each of a plurality of first areas, and is used to mark a representation value of each first area within a coverage area of the plurality of first areas, and the pass-through cost of each first area is determined based on a pass-through distance of each first area and a representation value of an environment characteristic of each first area.
420. Perform path planning using the environment map.
In an implementation, when a representation value of an environment characteristic at the current location does not meet a pass-through requirement, a location to which a robot is to move is selected from the plurality of locations based on the map.
Therefore, a robot does not actively move to an area whose representation value of an environment characteristic does not meet a pass-through requirement such that stability of environment characteristic input is improved, and robustness of a corresponding function of the robot is improved. Further, when the robot finds that the representation value of the environment characteristic does not meet the pass-through requirement, the robot can actively move to, based on the map, an area whose representation value of the environment characteristic meets the pass-through requirement such that robot use stability is improved, and user experience is improved.
In another implementation, a start location and a target location are obtained, and a path from the start location to the target location is determined using the map.
Optionally, for a specific implementation of the path planning method shown in
Optionally, the apparatus 500 further includes a map generation unit 540, configured to generate an environment map based on the pass-through cost for passing through each first area, where the environment map includes the pass-through cost for passing through each first area, and is used to mark the representation value of each first area within a coverage area of the plurality of first areas, and the path planning unit 530 is further configured to, based on the environment map, determine the pass-through path based on a pass-through cost for passing through each area within a coverage area of the plurality of areas.
Optionally, the first obtaining unit 510 is further configured to determine, based on the pass-through distance of each first area, a first pass-through cost component corresponding to the pass-through distance of each first area, determine, based on the representation value of the environment characteristic of each first area, a second pass-through cost component corresponding to the representation value of the environment characteristic of each first area, and calculate, based on the first pass-through cost component and the second pass-through cost component of each first area, the pass-through cost for passing through each first area.
Optionally, the first obtaining unit 510 is further configured to obtain at least one task type to be executed when the pass-through path is passed through, obtain, based on a representation value of at least one type of available environment characteristic of each of the at least one task type in each first area, a second pass-through cost component corresponding to each task type at each first area, and calculate, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to each task type in each first area, a pass-through cost for passing through each first area when each task type is executed, and the path planning unit 530 is further configured to determine, based on the pass-through cost for passing through each first area when each task type is executed, the pass-through path used for executing each task type.
Optionally, the at least one task type includes a first task type, and the first obtaining unit 510 is further configured to determine, based on a representation value of at least one type of environment characteristic whose representation value meets a predetermined condition and that is in an available environment characteristic of the first task type in each first area, a second pass-through cost component corresponding to the first task type in each first area.
Optionally, the first area is an area that meets the following condition, the representation value of an available environment characteristic of the first task type in the first area meets an environment characteristic requirement of the first task type.
Optionally, the first obtaining unit 510 is further configured to determine at least one second area, where the representation value of the available environment characteristic of the first task type in the second area does not meet the environment characteristic requirement of the first task type, and the path planning unit 530 is further configured to, when performing path planning, consider each of the at least one second area as an obstacle.
Optionally, the first obtaining unit 510 is further configured to obtain a plurality of task types to be executed when the pass-through path is passed through, obtain, based on a representation value of at least one type of available environment characteristic of each of the plurality of task types, a second pass-through cost component corresponding to a whole of the plurality of task types in each first area, and calculate, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to the whole of the plurality of task types in each first area, a pass-through cost corresponding to the whole of the plurality of task types in each first area, and the path planning unit 530 is further configured to determine, based on the pass-through cost corresponding to the whole of the plurality of task types in each first area, the pass-through path used for executing the plurality of task types.
Optionally, the first obtaining unit 510 is further configured to obtain, based on a representation value of at least one type of available environment characteristic of each of the plurality of task types in each first area, a second pass-through cost component corresponding to each task type in each first area, and perform weighted processing on a plurality of second pass-through cost components corresponding to the plurality of task types in each first area, to obtain the second pass-through cost component corresponding to the whole of the plurality of task types in the first area.
Optionally, the first area is an area that meets the following condition the representation value of the available environment characteristic of each of the plurality of task types in the first area meets an environment characteristic requirement of each task type.
Optionally, the first obtaining unit 510 is further configured to determine at least one third area, where a representation value of an environment characteristic corresponding to at least one of the plurality of task types in the third area does not meet a representation value requirement of the at least one task type, and the path planning unit 530 is further configured to when performing path planning, consider each of the at least one third area as an obstacle.
Optionally, the first obtaining unit 510 is further configured to determine, based on a representation value of an environment characteristic of each area and a correspondence between a representation value interval of an environment characteristic and a pass-through cost component, the obtained second pass-through cost component in each first area.
Optionally, the first obtaining unit 510 is further configured to obtain, in a statistical manner based on the pass-through distance of each first area and representation values that are of an environment characteristic of each first area and that are obtained at a plurality of times, the pass-through cost for passing through each first area, or obtain, in real time based on the pass-through distance of each first area and a real-time representation value of an environment characteristic of each first area, the pass-through cost for passing through each first area, or obtain, based on the pass-through distance of each first area and a predicted representation value of an environment characteristic of each first area, the pass-through cost for passing through each first area.
Optionally, the first obtaining unit 510 is further configured to, when a change rate of a representation value of an environment characteristic of each first area is less than or equal to a first threshold, obtain, in a statistical manner based on the pass-through distance of each first area and the representation values that are of the environment characteristic of each first area and that are obtained at a plurality of times, the pass-through cost for passing through each first area.
Optionally, the first obtaining unit 510 is further configured to, when a change rate of a representation value of an environment characteristic of each first area is greater than a second threshold, obtain, in real time based on the pass-through distance of each first area and the real-time representation value of the environment characteristic of each first area, the pass-through cost for passing through each first area.
Optionally, the environment characteristic includes a visual signal, and the first obtaining unit 510 is further configured to obtain, based on a representation value of a visual signal that passes through each first area and that is in each of the plurality of directions, a second pass-through cost component corresponding to each direction at each first area, and determine, based on the first pass-through cost component of each first area and the second pass-through cost component corresponding to each direction in each first area, a pass-through cost for passing through each first area in each direction.
Optionally, the environment characteristic includes at least one of a visual signal, a sound signal, and a contact surface status.
Optionally, the environment characteristic includes a visual signal, and a representation value of the visual signal includes light intensity and/or a quantity of visible characteristics.
Optionally, the environment characteristic includes a sound signal, and a representation value of the sound signal includes strength of the sound signal.
Optionally, the environment characteristic includes a contact surface status, and a representation value of the contact surface status includes an inclination degree, a height change rate, and/or a friction degree of a contact surface of the location.
It should be understood that the path planning apparatus 500 may perform the method shown in
It should be understood that, for a manner of obtaining the pass-through cost by the obtaining unit 610 and a manner of generating the map by the map generation unit 620, refer to the description of the foregoing method. For brevity, details are not described herein again.
It should be understood that, for a manner of obtaining the environment map by the obtaining unit 710 and a manner of performing path planning by the path planning unit 720, refer to the description of the foregoing method. For brevity, details are not described herein again.
As shown in
The control system 810 may send an instruction to the drive mechanism 820, and the drive mechanism 820 may drive the execution mechanism 840 to perform a corresponding action based on the instruction sent by the control system 810.
The control system 810 may externally output a signal using the external output apparatus 850. Optionally, the external output apparatus 850 may include a display, a voice output apparatus, a wireless transmitter, or the like, where the display may display quantity of electricity, a planned path, or the like, the voice output apparatus may coordinate with a voice detection sensor, to implement a dialog with a user or the like, and the wireless transmitter may send a wireless signal or the like.
The sensor 830 may include an internal information sensor and an external information sensor. The internal information sensor may detect a working status of each part of the intelligent execution apparatus, for example, a location, a speed, acceleration, and the like of each joint included in the execution mechanism 840. The external information sensor may detect external information, for example, may obtain the representation value of the environment characteristic described in the embodiments of this application or the like, and may further obtain other information, for example, obtain a voice instruction that is input by the user, and receive a wireless signal.
The sensor 830 may provide the obtained information for the control system 810, and the control system 810 may send, based on the information provided by the sensor, an instruction to the drive mechanism 820, and/or externally output a signal using the external output apparatus 850.
Optionally, the drive mechanism 820 may be a power driving apparatus, such as a stepper motor or a servo motor.
Optionally, the execution mechanism 840 is configured to perform a corresponding action based on a drive of the drive mechanism 820. The execution mechanism 840 may use a space open-chain linkage mechanism, where a revolute pair may be referred to as a joint, and a freedom degree of the intelligent execution apparatus may be determined by a quantity of joints. For example, the intelligent execution mechanism 800 is a robot, the execution mechanism may include a hand, a wrist, an arm, a walking part, and the like, and parts may be optionally connected to each other using a joint.
Optionally, the control system 810 may include a processor 814 and a memory 812. The memory 812 may store program code, and the processor 814 may execute the program code stored in the memory 812. The processor 814 communicates with the memory 812 using an internal connection path.
Optionally, the processor 814 may invoke the program code stored in the memory 812, to perform the method shown in
It should be understood that the intelligent execution apparatus 800 shown in
The memory in the embodiments of the present disclosure may be a volatile memory or a nonvolatile memory, or may include both a volatile memory and a nonvolatile memory. The nonvolatile memory may be a Read-Only Memory (ROM), a Programmable ROM (PROM), an erasable programmable read-only memory (EPROM), an electrically erasable programmable read-only memory (EEPROM), or a flash memory. The volatile memory may be a Random Access Memory (RAM), used as an external cache. Through example but not limitative description, many forms of RAMs may be used, for example, a static random access memory (SRAM), a dynamic random access memory (DRAM), a synchronous dynamic random access memory (SDRAM), a double data rate synchronous dynamic random access memory (DDR SDRAM), an enhanced synchronous dynamic random access memory (ESDRAM), a synchronous link dynamic random access memory (SLDRAM), and a direct Rambus dynamic random access memory (DR RAM). It should be noted that the memory of the systems and methods described in this specification includes but is not limited to these and any memory of another proper type.
A person of ordinary skill in the art may be aware that, in combination with the examples described in the embodiments disclosed in this specification, units and algorithm steps may be implemented by electronic hardware or a combination of computer software and electronic hardware. Whether the functions are performed by hardware or software depends on particular applications and design constraint conditions of the technical solutions. A person skilled in the art may use different methods to implement the described functions for each particular application, but it should not be considered that the implementation goes beyond the scope of the present disclosure.
It may be clearly understood by a person skilled in the art that, for the purpose of convenient and brief description, for a detailed working process of the foregoing system, apparatus, and unit, reference may be made to a corresponding process in the foregoing method embodiments, and details are not described herein again.
In the several embodiments provided in the present disclosure, it should be understood that the disclosed system, apparatus, and method may be implemented in other manners. For example, the described apparatus embodiment is merely an example. For example, the unit division is merely logical function division and may be other division in actual implementation. For example, a plurality of units or components may be combined or integrated into another system, or some features may be ignored or not performed. In addition, the displayed or discussed mutual couplings or direct couplings or communication connections may be implemented using some interfaces. The indirect couplings or communication connections between the apparatuses or units may be implemented in electronic, mechanical, or other forms.
The units described as separate parts may or may not be physically separate, and parts displayed as units may or may not be physical units, may be located in one location, or may be distributed on a plurality of network units. Some or all of the units may be selected according to actual requirements to achieve the objectives of the solutions of the embodiments.
In addition, functional units in the embodiments of the present disclosure may be integrated into one processing unit, or each of the units may exist alone physically, or two or more units are integrated into one unit.
When the functions are implemented in the form of a software functional unit and sold or used as an independent product, the functions may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions may be implemented in a form of a software product. The computer software product is stored in a storage medium, and includes several instructions for instructing a computer device (which may be a personal computer, a server, or a network device) to perform all or some of the steps of the methods described in the embodiments of the present disclosure. The foregoing storage medium includes, any medium that can store program code, such as a USB flash drive, a removable hard disk, a read-only memory (ROM), a random access memory (RAM), a magnetic disk, or an optical disc.
The foregoing descriptions are merely specific implementations of the present disclosure, but are not intended to limit the protection scope of the present disclosure. Any variation or replacement readily figured out by a person skilled in the art within the technical scope disclosed in the present disclosure shall fall within the protection scope of the present disclosure. Therefore, the protection scope of the present disclosure shall be subject to the protection scope of the claims.
Number | Date | Country | Kind |
---|---|---|---|
201710034754.2 | Jan 2017 | CN | national |
This application is a continuation of International Application No. PCT/CN2018/073114 filed on Jan. 18, 2018, which claims priority to Chinese Patent Application 201710034754.2, filed on Jan. 18, 2017. The disclosures of the aforementioned applications are hereby incorporated by reference in their entireties.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2018/073114 | Jan 2018 | US |
Child | 16515502 | US |