Embodiments described herein generally relate to combining sensor data from multiple sensors and updating a probability density function of objects within an area.
Multi-agent mapping is an active research field with different approaches. However, all of them have to deal with information fusion from different sources at different times. When combining the information, it is important to detect outliers and low-fidelity information that might jeopardize the final result of the fusion. Crowdsourced maps will rely on many autonomous cars from different makers using different sensors that might suffer from with different wear.
The present disclosure is illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
The following description refers to the accompanying drawings. The same reference numbers may be used in different drawings to identify the same or similar elements. In the following description, for purposes of explanation and not limitation, specific details are set forth such as particular structures, architectures, interfaces, techniques, etc. in order to provide a thorough understanding of the various aspects of various embodiments. However, it will be apparent to those skilled in the art having the benefit of the present disclosure that the various aspects of the various embodiments may be practiced in other examples that depart from these specific details. In certain instances, descriptions of well-known devices, circuits, and methods are omitted so as not to obscure the description of the various embodiments with unnecessary detail.
The following description and the drawings sufficiently illustrate specific embodiments to enable those skilled in the art to practice them. Other embodiments may incorporate structural, logical, electrical, process, and other changes. Portions and features of some embodiments may be included in, or substituted for, those of other embodiments. Embodiments set forth in the claims encompass all available equivalents of those claims.
Described herein are various examples that leverage multi-agent localization of objects for updating a map of those objects. In addition, sensor analysis and diagnostics of sensors of the multi-agents may be done. The sensor data and a map of objects, such as a probability density function, may be used to determine a sensor quality or sensor ranking. The ranking may be used to combine the sensor data with the map. In addition, the fusion may simultaneously localize objects, such as static objects, and rank the sensors by quality. The sensor ranking may be used to improve a sensor model for the agent, such as an autonomous vehicle, or to raise an alarm that the sensor is suffering from low quality. The alarm may indicate that the sensor needs to be replaced or fixed.
Vehicles with sensors may send sensor data to an edge device that indicates a position of each static object detected together with its estimated uncertainty (combining vehicle localization uncertainty and sensor measurement uncertainty) and a sensor identifier of the sensor that detected the object. The edge device may maintain a queue, such as a circular queue, per object. Each element of the queue may contain: object location, estimated uncertainty, sensor identifier, and vehicle identifier. The edge device may process each queue and obtain the fused object position and an array of weights that represent the sensor quality. Sensor quality may be used in further computations and may be sent back to each vehicle to improve the model the vehicle has of its own sensors. The sensor quality may be used to trigger service alarms when needed. In various examples, a tiled map may be maintained on the edge by devices located on communications base stations.
The base station 120 may be a static device that includes a communications device with computation and storage capabilities that has coverage over a determined area and transmits and receives information to/from the vehicles, e.g., the vehicles 104 and 110, in its area of coverage. The base station 130 may receive and combine the information from the vehicles 104 and 110 about the environment and update an area map that may be retransmitted to vehicles. Vehicles 104 and 110 may be manned or unmanned with on-board sensors with the capability to detect and localize objects. Vehicles may also have the necessary means to geo-localize themselves using their on-board sensors and report the accuracy of their object and self-localization processes. Vehicles are able to transmit the information about the detected objects with their estimated uncertainty, sensor id and object type to the base station 130.
A fusion engine 234 may be used to fuse together multiple object detections from different vehicles. In an example, the fusion engine 234 may use a maximum a posteriori (MAP) algorithm that is executed to combine the readings in the queue and calculates the object position by weighing the sensor readings based on corresponding prior sensor accuracies. A geographical map update 236 may then be done to update a geographical map 238 of objects that are within an area of the base station 230.
The result of the fusion may include a probability density function (PDF) over the location of the detected objects by the different vehicles, such as the vehicles 202 and 204. The PDF from the fusion engine 234 is combined with the previous PDF of the objects or directly inserted into the map 238 as a new object if there was no previous detection. Therefore, the geographical map consists of a set of object ids and PDF that represent their estimated location.
Accordingly, as shown in
After performing the fusion and the map update, the information in the sensor data history 232 may be used to compute the difference of each measurement and the final MAP estimate of the localized detection. That difference may be used as a sensor quality metric.
From the sensor ranking, the base station 230 may determine the quality of each sensor and identifies the low-performed sensors by pre-defined quality thresholds. The base station 230 may notification to the vehicles which are using those low-performed sensors for maintenance checks or replacement warnings. In an example, the base station 230 may have connections to the traffic administration organism to enforce and monitor autonomous vehicles that rely on sensing for correct operation to maintain road safe.
After a sensor has provided several detections, the system may have a good estimate about the sensor quality and its confidence. However, the first time that a sensor provides a measurement the fusion engine requires a prior distribution in order to perform the MAP estimate. In an example, instead of using a default prior, the prior distribution can be computed as a combination of the manufacturer specifications and other models that take into account the effect of weather, temperature, sensor modality and wear effects due to aging of the sensor.
At 308, a rank for PDF from the first remote device is determined. The rank may be based on locations of the objects in the PDF compared to location of the objects in the current PDF. For example, the closer objects within the PDFs are the higher the ranking for the PDF. At 310, a rank for the PDF from the second remote device is determined. The rank may be based on locations of the objects in the PDF compared to location of the objects in the current PDF. For example, the closer objects within the PDFs are the higher the ranking for the PDF.
At 312, the PDFs from the first remote device and the second remote device are combined into a combined PDF. The PDFs may be combined using the fusion engine 234. In an example, the determined ranks may be used to combine the PDFs. At 314, the current PDF may be updated with the combined PDF. The combined PDF may become more accurate with additional sensor data from various device. More accurate PDFs may be generated even when the individual sensor data includes a margin of error.
The ranks of the PDFs may be also be used to determine a health of the sensor that was used to generate the PDF. For example, a ranking below a predetermined threshold may indicate that the sensor has a large margin of error and should be serviced. Based on the rank of a PDF, an alert may be sent to the corresponding remote device. The alert may indicate that the sensor requires service or replacement. In addition, the rank of the sensor may be indicated in the sensor data history. This rank may be used to ignore future readings from that sensor or to weight the PDF from the remote vehicle accordingly. For example, a low-ranking sensor may have its PDF weighted less compared to other PDFs from more accurate sensors.
The rank of the PDF may also be sent to the corresponding remote device. The remote device may then use the rank of the PDF in its PDF generation. The updated PDF, e.g., the current PDF, may also be sent to the remote devices. A remote device may combine the received updated PDF with a PDF generated from its sensors. In addition, the rank may be used in the combination, such that the PDF generated from the remote device's sensors is weighted based on the rank.
In sonic examples, the information from the remote devices may include a location covariance as a measure of self-localization and object-localization uncertainty. This information may be used in fusing the PDFs together.
Examples, as described herein, may include, or may operate on, logic or a number of components, components, or mechanisms. Modules are tangible entities (e.g., hardware) capable of performing specified operations and may be configured or arranged in a certain manner. In an example, circuits may be arranged (e.g., internally or with respect to external entities such as other circuits) in a specified manner as a component. In an example, the whole or part of one or more computer systems (e.g., a standalone, client or server computer system) or one or more hardware processors may be configured by firmware or software (e.g., instructions, an application portion, or an application) as a module that operates to perform specified operations. In an example, the software may reside on a machine readable medium. In an example, the software, when executed by the underlying hardware of the module, causes the hardware to perform the specified operations.
Accordingly, the term “module” is understood to encompass a tangible entity, be that an entity that is physically constructed, specifically configured (e.g., hardwired), or temporarily (e.g., transitorily) configured (e.g., programmed) to operate in a specified manner or to perform part or all of any operation described herein. Considering examples in which modules are temporarily configured, each of the modules need not be instantiated at any one moment in time. For example, where the modules comprise a general-purpose hardware processor configured using software, the general-purpose hardware processor may be configured as respective different modules at different times. Software may accordingly configure a hardware processor, for example, to constitute a particular module at one instance of time and to constitute a different module at a different instance of time.
Machine (e.g., computer system) 400 may include a hardware processor 402 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), a hardware processor core, or any combination thereof), a main memory 404 and a static memory 406, some or all of which may communicate with each other via an interlink (e.g., bus) 408. The machine 400 may further include a display unit 410, an alphanumeric input device 412 (e.g., a keyboard), and a user interface (UI) navigation device 414 (e.g., a mouse). In an example, the display unit 410, input device 412 and UI navigation device 414 may be a touch screen display. The machine 400 may additionally include a storage device (e.g., drive unit) 416, a signal generation device 418 (e.g., a speaker), a network interface device 420, and one or more sensors, such as a global positioning system (GPS) sensor, compass, accelerometer, or other sensor. The machine 400 may include an output controller 428, such as a serial (e.g., universal serial bus (USB), parallel, or other wired or wireless (e.g., infrared (IR), near field communication (NFC), etc.) connection to communicate or control one or more peripheral devices (e.g., a printer, card reader, etc.).
The storage device 416 may include a machine readable medium 422 on which is stored one or more sets of data structures or instructions 424 (e.g., software) embodying or utilized by any one or more of the techniques or functions described herein. The instructions 424 may also reside, completely or at least partially, within the main memory 404, within static memory 406, or within the hardware processor 402 during execution thereof by the machine 400. In an example, one or any combination of the hardware processor 402, the main memory 404, the static memory 406, or the storage device 416 may constitute machine readable media.
While the machine readable medium 422 is illustrated as a single medium, the term “machine readable medium” may include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) configured to store the one or more instructions 424.
The term “machine readable medium” may include any medium that is capable of storing, encoding, or carrying instructions for execution by the machine 400 and that cause the machine 400 to perform any one or more of the techniques of the present disclosure, or that is capable of storing, encoding or carrying data structures used by or associated with such instructions. Non-limiting machine readable medium examples may include solid-state memories, and optical and magnetic media. Specific examples of machine readable media may include: non-volatile memory, such as semiconductor memory devices (e.g., Electrically Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM)) and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; Random Access Memory (RAM); and CD-ROM and DVD-ROM disks. In some examples, machine readable media may include non-transitory machine-readable media. In some examples, machine readable media may include machine readable media that is not a transitory propagating signal.
The instructions 424 may further be transmitted or received over a communications network 426 using a transmission medium via the network interface device 420 utilizing any one of a number of transfer protocols (e.g., frame relay, internet protocol (IP), transmission control protocol (TCP), user datagram protocol (UDP), hypertext transfer protocol (HTTP), etc.). Example communication networks may include a local area network (LAN), a wide area network (WAN), a packet data network (e.g., the Internet), mobile telephone networks (e.g., cellular networks), Plain Old Telephone (POTS) networks, and wireless data networks (e.g., Institute of Electrical and Electronics Engineers (IEEE) 802.11 family of standards known as Wi-Fi®, IEEE 802.16 family of standards known as WiMax®), IEEE 802.15.4 family of standards, a Long Term Evolution (LTE) family of standards, a Universal Mobile Telecommunications System (UMTS) family of standards, peer-to-peer (P2P) networks, among others. In an example, the network interface device 420 may include one or more physical jacks (e.g., Ethernet, coaxial, or phone jacks) or one or more antennas to connect to the communications network 426. In an example, the network interface device 420 may include a plurality of antennas to wirelessly communicate using at least one of single-input multiple-output (SIMO), multiple-input multiple-output (MIMO), or multiple-input single-output (MISO) techniques. In some examples, the network interface device 420 may wirelessly communicate using Multiple User MIMO techniques. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding or carrying instructions for execution by the machine 400, and includes digital or analog communications signals or other intangible medium to facilitate communication of such software.
Additional examples of the presently described method, system, and device embodiments include the following, non-limiting configurations. Each of the following non-limiting examples may stand on its own or may be combined in any permutation or combination with any one or more of the other examples provided below or throughout the present disclosure.
Example 1 is an apparatus for updating a current probability density function, the apparatus comprising: an electronic processor configured to: store the current probability density function (PDF) of objects within a location; receive first information from a first remote device at a first position within the location, the first information comprising a vehicle identification, a first PDF of the objects within the location and a sensor identification that identifies a first sensor used to generate the first PDF; receive second information from a second remote device at a second position within the location, the second information comprising a vehicle identification, a second PDF of the objects within the location and a sensor identification that identifies a second sensor used to generate the second PDF, wherein the first information and the second information are received within a time period; determine a first rank for the first PDF based on locations of the objects in the first PDF compared to locations of the objects in the current PDF; determine a second rank for the second PDF based on locations of the objects in the second PDF compared to locations of the objects in the current PDF; combine the first PDF and the second PDF using the first rank and the second rank into a combined PDF; and update the current PDF based on the combined PDF.
In Example 2, the subject matter of Example 1 includes, wherein the electronic processor is further configured to: determine the first rank is below a predetermined threshold; and send an alert to the first remote device regarding the first sensor based on the first rank being below the predetermined threshold.
In Example 3, the subject matter of Example 2 includes, wherein the alert indicates the first sensor requires service.
In Example 4, the subject matter of Examples 1-3 includes, wherein the electronic processor is further configured to send the first rank to the first remote device, wherein the first rank is used by the first remote device to generate a PDF of the location.
In Example 5, the subject matter of Example 4 includes, wherein the electronic processor is further configured to send the current PDF to the first remote device, wherein the current PDF is combined with a PDF from the first sensor based on the first rank.
in Example 6, the subject matter of Examples 1-5 includes, wherein the first device is a vehicle.
In Example 7, the subject matter of Examples 1-6 includes, wherein the first information further comprises a location covariance as a measure of self-localization and object-localization uncertainty.
Example 8 is a method for updating a current probability density function, the method comprising operations performed using an electronic processor, the operations comprising: storing the current probability density function (PDF) of objects within a location; receiving first information from a first remote device at a first position within the location, the first information comprising a vehicle identification, a first PDF of the objects within the location and a sensor identification that identifies a first sensor used to generate the first PDF; receiving second information from a second remote device at a second position within the location, the second information comprising a vehicle identification, a second PDF of the objects within the location and a sensor identification that identifies a second sensor used to generate the second PDF, wherein the first information and the second information are received within a time period; determining a first rank for the first PDF based on locations of the objects in the first PDF compared to locations of the objects in the current PDF; determining a second rank for the second PDF based on locations of the objects in the second PDF compared to locations of the objects in the current PDF; combining the first PDF and the second PDF using the first rank and the second rank into a combined PDF; and updating the current PDF based on the combined PDF.
in Example 9, the subject matter of Example 8 includes, wherein the operations further comprise: determining the first rank is below a predetermined threshold; and sending an alert to the first remote device regarding the first sensor based on the first rank being below the predetermined threshold.
In Example 10, the subject matter of Example 9 includes, wherein the alert indicates the first sensor requires service.
In Example 11, the subject matter of Examples 8-10 includes, wherein the operations further comprise sending the first rank to the first remote device, wherein the first rank is used b the first remote device to generate a PDF of the location.
In Example 12, the subject matter of Example 11 includes, wherein the operations further comprise sending the current PDF to the first remote device, wherein the current PDF is combined with a PDF from the first sensor based on the first rank.
In Example 13, the subject matter of Examples 8-12 includes, wherein the first device is a vehicle.
In Example 14, the subject matter of Examples 8-13 includes, wherein the first information further comprises a location covariance as a measure of self-localization and object-localization uncertainty.
Example 15 is at least one computer-readable medium including instructions for updating a current probability density function, the computer-readable medium comprising instructions that, when executed by a machine, cause the machine to perform operations comprising: storing the current probability density function (PDF) of objects within a location; receiving first information from a first remote device at a first position within the location, the first information comprising a vehicle identification, a first PDF of the objects within the location and a sensor identification that identifies a first sensor used to generate the first PDF; receiving second information from a second remote device at a second position within the location, the second information comprising a vehicle identification, a second PDF of the objects within the location and a sensor identification that identifies a second sensor used to generate the second PDF, wherein the first information and the second information are received within a time period; determining a first rank for the first PDF based on locations of the objects in the first PDF compared to locations of the objects in the current PDF; determining a second rank for the second PDF based on locations of the objects in the second PDF compared to locations of the objects in the current PDF; combining the first PDF and the second PDF using the first rank and the second rank into a combined PDF; and updating the current PDF based on the combined PDF.
In Example 16, the subject matter of Example 15 includes, wherein the operations further comprise: determining the first rank is below a predetermined threshold; and sending an alert to the first remote device regarding the first sensor based on the first rank being below the predetermined threshold.
In Example 17, the subject matter of Example 16 includes, wherein the alert indicates the first sensor requires service.
In Example 18, the subject matter of Examples 15-17 includes, wherein the operations further comprise sending the first rank to the first remote device, wherein the first rank is used by the first remote device to generate a PDF of the location.
In Example 19, the subject matter of Example 18 includes, wherein the operations further comprise sending the current PDF to the first remote device, wherein the current PDF is combined with a PDF from the first sensor based on the first rank.
In Example 20, the subject matter of Examples 15-19 includes, wherein the first device is a vehicle.
In Example 21, the subject matter of Examples 15-20 includes, wherein the first information further comprises a location covariance as a measure of self-localization and object-localization uncertainty.
Example 22 is at least one machine-readable medium including instructions that, when executed by processing circuitry, cause the processing circuitry to perform operations to implement of any of Examples 1-21.
Example 23 is an apparatus comprising means to implement of any of Examples 1-21.
Example 24 is a system to implement of any of Examples 1-21.
Example 25 is a method to implement of any of Examples 1-21.
In the above Detailed Description, various features may be grouped together to streamline the disclosure. However, the claims may not set forth every feature disclosed herein as embodiments may feature a subset of said features. Further, embodiments may include fewer features than those disclosed in a particular example. Thus, the following claims are hereby incorporated into the Detailed Description, with a claim standing on its own as a separate embodiment.