Embodiments of the present disclosure relate to the field of information technologies, and more specifically, to a method for detecting anomalies of LiDAR point cloud data and a related device.
Light detection and ranging (LiDAR) systems are used in mapping, surveying and object detection among other uses. LIDAR has many applications including in robotics, navigation, autonomous driving, or other similar applications. LIDAR systems emit laser light and detect reflections in the emitted laser light. By measuring the time-of-flight (TOF) between the emission of the laser light and detection of the reflected laser light, a distance between the LIDAR unit and the object which reflected the laser light may be calculated.
However, the LiDAR has vulnerabilities that could be performable physically due to the technologies' characteristics. The LiDAR shoots and receives the laser light from the LiDAR to surrounding objects. In further detail, the specific objects reflect the laser light signal from the LiDAR, and the laser light signal returns to the receiver in the LiDAR. This principle about the LiDAR's distance measurement could be applied to vulnerabilities by the attackers. The LiDAR receives the replicated laser light signal even though it is an attack of the laser light signal due to the no consideration of the attack threats. As a result, the attacked LiDAR point cloud data via the attack can cause false recognition for the surrounding objects. In the other threat, the attack models were proposed not to trust the machine learning model and deep learning model for object detection by generating an adversarial object from the point cloud in the LiDAR. These vulnerabilities and attack models are critical threats to the safety of drivers and pedestrians in autonomous driving. The anomaly detection and intrusion detection method for the LiDAR is needed to improve autonomous driving's security and safety.
Embodiments of this application provide a method for detecting anomalies of LiDAR point cloud data and related device. The technical solution can detect the anomaly point efficiently.
According to a first aspect, an embodiment of this application provides a method for detecting anomalies of LiDAR point cloud data, characterized in including: obtaining a first position information, wherein the first position information indicating a position of a target data point in the LiDAR point cloud data; determining a second position information corresponding to the target data point according specifications of a LiDAR sensor; determining the target data point is an anomaly point or a normal point according to the first position information and the second position information.
It is very difficult for the attacker to know all the specifications of LiDAR and calculating all points in real time. Therefore, the above-mentioned technical solution can detect the anomaly point efficiently. Further, the above-mentioned technical solution can be a suitable intrusion detection system when used in a limited volume of vehicles, because it has less computational complexity than the detection methods that compares with other sensor (e.g., camera, GPS) output.
In one embodiment, the obtaining a first position information, includes: determining the first position information of the target data point according to a coordinate of the target data point in the Cartesian coordinate system, wherein the first position information comprising an azimuth angle of the target data point and a vertical angle of the target data point.
In one embodiment, the specifications of the LiDAR sensor include: a horizontal angular resolution, a firing interval, number of channels of the LiDAR sensor, a vertical angle for each channel, and a horizontal angle offset for each channel; the determining a second position information corresponding to the target data point according to specifications of a LiDAR sensor, includes: determining a plurality of pieces of position information according to the specifications of the LiDAR sensor, wherein each piece of the position information corresponding to a data point, and the each piece of the position information comprising a azimuth angle of a corresponding data point and a vertical angle of the corresponding data point; determining the second position information from the plurality of pieces of position information according to the first position information, wherein a difference between an azimuth angle included in the second position information and an azimuth angle included in the first position information is smaller than a difference between an azimuth angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the azimuth angle included in the first position information, a difference between a vertical angle included in the second position information and a vertical angle included in the first position information is smaller than a difference between a vertical angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the vertical angle included in the first position information.
In one embodiment, the determining the target data point is an anomaly point or a normal point according to the first position information and the second position information, includes: determining an anomaly score according to the first position information and the second position information; determining the target data point is the anomaly point or the normal point according to the anomaly score.
In one embodiment, the determining an anomaly score according to the first position information and the second position information, includes: determining the anomaly score according to a following formula: Sanom=|α−αnear|+|+ω−ωnear|, Sanom is the anomaly score, α is the azimuth angle included in the first position information, αnear is the azimuth angle included in the second position information, ω is the vertical angle included in the first position information, and ωnear is the vertical angle included in the second position information.
In one embodiment, the determining the target data point is the anomaly point or the normal point according to the anomaly score, includes: determining the target data point is the anomaly point when the anomaly score is greater or equals to a preset threshold; determining the target data point is the normal point when the anomaly score is smaller than the preset threshold.
According to a second aspect, an embodiment of this application provides an electronic device, and the electronic device has function of implementing the method in the first aspect. The function may be implemented by hardware, or may be implemented by hardware executing corresponding software. The hardware of the software includes one or more modules corresponding to the function.
According to a third aspect, an embodiment of this application provides a computer readable storage medium, including instructions. When the instructions run on a computer, the computer is enabled to perform the method in the first aspect or any possible implementation of the first aspect.
According to a fourth aspect, an electronic device is provided, including a processor and a memory. The processor is connected to the memory. The memory is configured to store instructions, the processor is configured to execute the instructions. When the processor executes the instructions stored in the memory, the processor is enabled to perform the method in the first aspect or any possible implementation of the first aspect.
According to a fifth aspect, a chip system is provided, where the chip systems includes a memory and a processor, wherein the memory is configured to store a computer program, and the processor is configured to invoke the computer program from the memory and run the computer program, so that a server on which the chip is disposed performs the method in the first aspect or any possible implementation of the first aspect.
According to a sixth aspect, a computer program product is provided, wherein when the computer program product runs on an electronic device, the electronic device is enabled to perform the method in the first aspect or any possible implementation of the first aspect.
The following describes the technical solutions in this application with reference to the accompanying drawings.
As shown in
The LiDAR scanning system may be coupled to a host system. The host system may include, but is not limited to, a three dimensional object scanner, a vehicle control system used for automated parking assistance, automated driver assistance (e.g., blind spot and collision avoidance), semi or fully autonomous driving, a robotic navigation system, a security camera, a monitoring or surveillance system, a sensor network for monitoring or surveillance of an area of the environment.
The LiDAR sensor 101 may include a laser source and a detector subsystem comprising one or more detectors, such as one more avalanche photodiodes (APDs), charge-coupled device (CCD) sensors, complementary metal-oxide-semiconductor (CMOS) sensors, or micro-electro-mechanical systems (MEMS) sensors.
The laser source, comprising one or more laser emitters, is configured to generate and transmit laser light, such as a laser beam. The laser source may generate Gaussian beams. The laser source may transmit pulsed laser light (e.g., pulsed beams). The laser source typically emits infrared (IR), such as near infrared (NTR) light, but may emit one or more types of visible light and/or or possibly ultraviolet (UV) light in addition to, or instead of, infrared light. The laser source may comprise a plurality of laser emitters, each laser emitter being configured to transmit a different type of light. In one example, each laser emitter in the plurality of laser emitter is configured to transmit a respective one of infrared light or one or more type of visible light. In one example, the plurality of laser emitters comprises an infrared laser emitter configured to transmit infrared light, a blue laser emitter configured to transmit blue light, a red laser emitter configured to transmit a red light, and a green laser emitter configured to transmit a green light. These laser lights may be controlled to send laser beams simultaneously or non-concurrently.
Those skilled in the art will understand that other light sources, such as an LED, may be adapted to substitute for a laser source. However, such a substitution must account for the system requirements, and may be accompanied by additional modification e.g. collimation, to meet requirements.
The detector subsystem detects reflected laser light using the one or more detectors, generates and outputs a raw data signal corresponding to the received laser light that is sent to the preprocessing module 102.
The LiDAR sensor may be a single channel LiDAR sensor or a multiple channel LiDAR sensor.
The preprocessing module 102 may be configured to receive the raw data signal from the LiDAR sensor 101. The raw data signal may include a distance between each point to the LiDAR sensor 101 and an azimuth angle of the each point. The preprocessing module may be further configured to convert the raw data signal into a LiDAR point cloud data, which is a (x, y, z) format. The x, y, z values are the projection of the polar coordinate on the Cartesian coordinate system. P The preprocessing module 102 forwards the LiDAR point cloud data to the perception module 103.
The perception module 103 may be configured to determine a distance from the LIDAR scanning system 100 to one or more objects in the environment of the LIDAR scanning system 100, and/or determine where and what kinds of the objects.
According to the LiDAR scanning system 100 shown in
Compared with the LIDAR scanning system 100 shown in
The function of the LiDAR sensor 202 is similar to the function of the LiDAR sensor 101. The function of the preprocessing module 202 is similar to the function of the preprocessing module 102, except that the preprocessing module 202 forwards the LiDAR point cloud data to the detection module 204 instead of the perception module 203. The detection module 204 may be configured to receive the LiDAR point cloud data from the preprocessing module 202, determine a point in the LiDAR point cloud data is a normal point or an anomaly point and forward the normal point to the perception module 203. The perception module 203 may be configured to determine a distance from the LiDAR scanning system 200 to one or more objects in the environment of the LiDAR scanning system 200, and/or determine where and what kinds of the objects.
The detection module 204 can be used to detect whether a point in the LiDAR point cloud data has been tampered with or injected by an attacker. In another word, if a point in the LiDAR point cloud data is not determined according to the raw data signal obtained by the LiDAR sensor 201 (that is the anomaly point), the detection module 204 may identify it. This ensures that all the points in the LiDAR point cloud data received by the perception module 203 are determined according to the raw data signal obtained by the LiDAR sensor (that is the normal point).
In one embodiment, the detection module 204 may be located inside the trust boundary of the perception module 203. This may be further ensure the security of the LiDAR scanning system.
The functions of the detection module 204 are described below in conjunction with
301, obtaining a first position information, wherein the first position information indicating a position of a target data point in the LiDAR point cloud data.
302, determining a second position information corresponding to the target data point according specifications of a LiDAR's sensor.
303, determining the target data point is an anomaly point or a normal point according to the first position information and the second position information.
The target data point is any one of the point in the LiDAR point cloud data.
In one embodiment, in some embodiments, the first position information may include an azimuth angle of the target data point and a vertical angle of the target data point.
As mentioned in above, the detection module 204 receives the LiDAR point cloud data from the preprocessing module 202. The preprocessing module 202 converts the raw data signal into a LiDAR point cloud data, which is a (x, y, z) format. In another word, when the detection module 204 receives the LiDAR point cloud data, the detection module 204 obtains the coordinate of the target data point in the Cartesian coordinate system. The first position information may be obtained according to the following formulas:
0 (x, y, z) is the coordinate of the target data point in the Cartesian coordinate system, ω is the vertical angle of the target data point, α is the azimuth angle of the target data point, and δ is a horizontal angle offset which is pre-defined constant value. α+δ is the horizontal angle of the target data point. In another word, according to the formulas 1.1-1.3, the vertical angle and the horizontal angle of the target data point may be obtained, and the azimuth angle of the target data point may be obtained according to the horizontal angle of the target data point and the pre-defined horizontal angle offset.
In one embodiment, in some embodiments, the determining a second position information corresponding to the target data point according to specifications of a LiDAR sensor, includes: determining a plurality of pieces of position information according to specifications of the LiDAR sensor, wherein each piece of the position information corresponding to a data point, and the each piece of the position information comprising a azimuth angle of a corresponding data point and a vertical angle of the corresponding data point; determining the second position information from the plurality of pieces of position information according to the first position information, wherein a difference between an azimuth angle included in the second position information and an azimuth angle included in the first position information is smaller than a difference between an azimuth angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the azimuth angle included in the first position information, a difference between a vertical angle included in the second position information and a vertical angle included in the first position information is smaller than a difference between a vertical angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the vertical angle included in the first position information.
The specifications of the LiDAR sensor include: a horizontal angular resolution, a firing interval, number of channels of the LiDAR sensor, a vertical angle for each channel, and a horizontal angle offset for each channel.
The horizontal angulation resolution, the firing interval and the number of channels of the LiDAR sensor determines the number of possible pairs of horizontal angle and vertical angle. Possible values of azimuth angle for each frame may be determined according to the horizontal angulation resolution and the firing interval. In detail, the quotient of the horizontal angulation resolution and the firing interval is the possible values of the azimuth angle for each fame. If the quotient of the horizontal angulation resolution and the firing interval is not an integer, the quotient may be floored/ceiled/rounded to obtain the possible values. For each azimuth angle, the number of channels of the LiDAR sensor is the number of possible pairs of horizontal angle and vertical angle. The value of the vertical angle in each horizontal-vertical angle pair may be determined according to the vertical angle of the corresponding channel. The value of the horizontal angle in the each horizontal-vertical angle pair may be determined according to the horizontal angular resolution, and the value of an azimuth angle corresponding to the each horizontal-vertical angle pair may be determined according to the horizontal angle in the each horizontal-vertical angle pair and the horizontal angle offset of the corresponding channel. For example, the azimuth angle may be determined according to the following formula:
φi is the horizontal angle in the ith horizontal-vertical angle pair in a frame, the ith horizontal-vertical angle pair corresponds to the jth channel of the LiDAR sensor, δi is the horizontal angle offset of the jth channel, αi is the azimuth angle corresponding to the ith horizontal-vertical angle pair.
It is assume that there is a single return mode 32 channel LiDAR sensor with firing interval of 55.52 microsecond and 10 Hz horizontal angular resolution. There are roughly 1801 (=10 Hz/55.52 microsecond) possible values of azimuth angle for each frame. For each azimuth angle, there are 32 possible pairs of the horizontal angle and the vertical angle. The 32 possible pairs of the horizontal angle and the vertical angle are in one-to-one correspondence with the 32 channels of the LiDAR sensor. There are 1801*32 horizontal-vertical angle pairs for each frame. Consequently, there are 1801*32 pieces of position information. The 1801*32 pieces of position information are in one-to-one correspondence with the 1801*32 horizontal-vertical angle pairs. Each position information includes the azimuth angle and the vertical angle of the corresponding horizontal-vertical angle pair, wherein the azimuth angle of the corresponding horizontal-vertical angle pair may be determined according to the formula 1.4. The second position information is one of the 1801*32 pieces of position information. The process of finding the second position in the 1801*32 pieces of position information may be performed quickly through binary search or parallel operations.
In one embodiment, in some embodiments, the determining the target data point is an anomaly point or a normal point according to the first position information and the second position information, includes: determining an anomaly score according to the first position information and the second position information; determining the target data point is the anomaly point or the normal point according to the anomaly score.
In one embodiment, in some embodiments, the determining an anomaly score according to the first position information and the second position information, includes: determining the anomaly score according to a following formula:
Sanom is the anomaly score, α is the azimuth angle included in the first position information, αnear is the azimuth angle included in the second position information, ω is the vertical angle included in the first position information, and ωnear is the vertical angle included in the second position information.
In one embodiment, in some embodiments, the determining an anomaly score according to the first position information and the second position information, includes: determining the anomaly score according to a following formula:
Sanom is the anomaly score, α is the azimuth angle included in the first position information, αnear is the azimuth angle included in the second position information, ω is the vertical angle included in the first position information, and ωnear is the vertical angle included in the second position information.
In one embodiment, in some embodiments, the determining an anomaly score according to the first position information and the second position information, includes: determining the anomaly score according to a following formula:
Sanom is the anomaly score, α is the azimuth angle included in the first position information, αnear is the azimuth angle included in the second position information. Under this condition, the first position information may merely include the azimuth angle of the target data point. Correspondingly, the second position information may be the piece of the position information which includes the closest azimuth angle to the target data point.
In one embodiment, in some embodiments, the determining the target data point is the anomaly point or the normal point according to the anomaly score, includes: determining the target data point is the anomaly point when the anomaly score is greater or equals to a preset threshold; determining the target data point is the normal point when the anomaly score is smaller than the preset threshold.
In addition, if the target data point is the normal point, the target data point may be forward to the perception module 203. If the target data point is the anomaly point, the target data point may be discarded.
It is very difficult for the attacker to know all the specifications of LiDAR and calculating all points in real time. The present application can detect attacks without delay by performing relatively low computing operations. Meanwhile, the present application can be used with other intrusion detection systems located at after the perception module, so it can increase higher detection rate. Further, the present application can be a suitable intrusion detection system when used in a limited volume of vehicles, because it has less computational complexity than the detection methods that compares with other sensor (e.g., camera, GPS) output.
In one embodiment, the detection module which is used to perform the method shown in
The obtaining module 401 is configured to obtain a first position information, wherein the first position information indicating a position of a target data point in LiDAR point cloud data.
The determining module 402 is configured to determine a second position information corresponding to the target data point according specifications of a LiDAR sensor.
The determining module 402, further configured to determine the target data point is an anomaly point or a normal point according to the first position information and the second position information.
In one embodiment, the obtaining module 401 is specifically configured to determine the first position information of the target data point according to a coordinate of the target data point in the Cartesian coordinate system, wherein the first position information comprising an azimuth angle of the target data point and a vertical angle of the target data point.
In one embodiment, the specifications of the LiDAR sensor comprise: a horizontal angular resolution, a firing interval, number of channels of the LiDAR sensor, a vertical angle for each channel, and a horizontal angle offset for each channel; the determining module 402 is specifically configured to: determine a plurality of pieces of position information according to the specifications of the LiDAR sensor, wherein each piece of the position information corresponding to a data point, and the each piece of the position information comprising a azimuth angle of a corresponding data point and a vertical angle of the corresponding data point; determine the second position information from the plurality of pieces of position information according to the first position information, wherein a difference between an azimuth angle included in the second position information and an azimuth angle included in the first position information is smaller than a difference between an azimuth angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the azimuth angle included in the first position information, a difference between a vertical angle included in the second position information and a vertical angle included in the first position information is smaller than a difference between a vertical angle included in any piece of position information other than the second position information among the plurality of pieces of position information and the vertical angle included in the first position information.
In one embodiment, the determining module 402 is specifically configured to: determine an anomaly score according to the first position information and the second position information; determine the target data point is the anomaly point or the normal point according to the anomaly score.
In one embodiment, the determining module 402 is specifically configured to determine the anomaly score according to a following formula:
Sanom is the anomaly score, α is the azimuth angle included in the first position information, anear is the azimuth angle included in the second position information, ω is the vertical angle included in the first position information, and ωnear is the vertical angle included in the second position information.
In one embodiment, the determining module 402 is specifically configured to: determine the target data point is the anomaly point when the anomaly score is greater or equals to a preset threshold; determine the target data point is the normal point when the anomaly score is smaller than the preset threshold.
As shown in
It should be understood that the processor 502 may be an integrated circuit chip and has a signal processing capability. In an implementation process, operations of the foregoing method embodiments may be completed by using a hardware integrated logic circuit in the processor, or by using instructions in a form of software. The processor may be a general purpose processor, a digital signal processor (DSP), an application-specific integrated circuit (ASIC), a field programmable gate array (FPGA) or another programmable logic device, a discrete gate or transistor logic device, or a discrete hardware component. The processor may implement or perform the methods, the operations, and the logical block diagrams that are disclosed in the embodiments of the present disclosure. The general purpose processor may be a microprocessor, or the processor may be any conventional processor or the like. The operations of the methods disclosed with reference to the embodiments of the present disclosure may be directly performed and completed by a hardware decoding processor, or may be performed and completed by using a combination of hardware in the decoding processor and a software module. The software module may be located in a mature storage medium in the art, such as a random access memory, a flash memory, a read-only memory, a programmable read-only memory, an electrically erasable programmable memory, or a register. The storage medium is located in the memory, and the processor reads information in the memory and completes the operations of the foregoing methods in combination with hardware in the processor.
It may be understood that the memory 503 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 read-only memory ( ), 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 ( ) and is used as an external cache. By way of example rather than limitation, many forms of RAMs may be used, and are, 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 random access memory (DR RAM).
It should be noted that the memory in the systems and the methods described in this specification includes but is not limited to these memories and a memory of any other appropriate type.
An embodiment of this application further provides a system chip, where the system chip includes an input/output interface, at least one processor, at least one memory, and a bus. The at least one memory is configured to store instructions, and the at least one processor is configured to invoke the instructions of the at least one memory to perform operations in the methods in the foregoing embodiments.
An embodiment of this application further provides a computer storage medium, where the computer storage medium may store a program instruction for performing any of the foregoing methods.
In one embodiment, the storage medium may be specifically the memory 503.
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 operations can 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 constraints 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 this application.
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, refer to a corresponding process in the foregoing method embodiment. Details are not described herein again.
In the several embodiments provided in this application, 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 through 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 be or may not be physically separate, and parts displayed as units may be or may not be physical units, may be located in one position, or may be distributed on a plurality of network units. Some or all of the units may be selected based on actual requirements to achieve the objectives of the solutions of the embodiments.
In addition, functional units in the embodiments of this application 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 a 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 in this application essentially, or the part contributing to the prior art, or some of 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, a network device, or the like) to perform all or some of the operations of the methods described in the embodiments of this application. 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 this application, but are not intended to limit the protection scope of this application. Any variation or replacement readily figured out by a person skilled in the art within the technical scope disclosed in this application shall fall within the protection scope of this application. Therefore, the protection scope of this application shall be subject to the protection scope of the claims.
This application is a continuation of International Application No. PCT/CN2021/114368, filed on Aug. 24, 2021, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2021/114368 | Aug 2021 | WO |
Child | 18584834 | US |