Embodiments of this application relate to the field of time synchronization technologies, and in particular, to a communication method and apparatus.
During autonomous driving and assisted driving, an intelligent vehicle usually needs to sense an ambient environment by using various sensors. Typical sensors include a millimeter wave radar, a camera, a laser radar, and the like. The intelligent vehicle may detect and classify the ambient environment of the vehicle by using these sensors, transmit obtained information to a planning and control module for a decision on a future driving path of the vehicle, and finally execute the decision by using an actuator, to complete an entire assisted driving or autonomous driving process.
Different types of sensors usually have different characteristics, advantages, and disadvantages. For example, the millimeter wave radar can work in all weather conditions, and has high distance measurement and speed measurement accuracy but poor classification effect. The camera has strong resolution and strong target classification effect but poor capabilities such as distance measurement and speed measurement due to a loss of depth information. In addition, the laser radar has good depth information and can perform distance measurement and speed measurement, but a distance that can be detected by the laser radar is short. As described above, different types of sensors have different characteristics. Therefore, under different function requirements, data collected by various types of sensors usually needs to be fused, to obtain higher-precision and more comprehensive data. In this way, better environment sensing, road condition analysis, and the like are implemented.
Therefore, how to implement accurate fusion of data collected by sensors is an urgent problem to be resolved.
Embodiments of this application provide a communication method and apparatus, so as to synchronize time of different sensors in a same device, thereby ensuring accurate fusion of data collected by the different sensors.
According to a first aspect, an embodiment of this application provides a communication method, applied to an intelligent device, where the intelligent device includes a plurality of sensors. The method includes: determining N target sensors from the plurality of sensors, where N is an integer greater than 1, and correcting respective second moments of the N target sensors to a first moment of a first clock.
According to the method provided in the first aspect, in the intelligent device including the plurality of sensors, (for example, an intelligent vehicle or an intelligent robot with an autonomous driving function), time synchronization may be performed on respective local clocks of some or all sensors based on a reference clock (the first clock), to correct a moment of each sensor, thereby obtaining a moment after the time synchronization is performed based on the reference clock. In this way, when data fusion or data comparison needs to be performed on data collected by some or all of the sensors, because time of the sensors is synchronized, accuracy of time information (for example, a collection completion moment of the data) of the data collected by the sensors can be ensured. In this way, accuracy of the data fusion or data comparison can be ensured, for example, the data fusion can be ensured to be effective fusion for a same scenario. When data of the plurality of sensors is fused, no consideration whether time between the sensors is synchronized easily leads to different time for data actually collected at same time on different sensors or same time for data actually collected at different time on different sensors. In this way, data collected at actual same time cannot be smoothly fused, or data collected at different time is incorrectly fused, and the like. This causes the intelligent vehicle to generate a target false alarm and unnecessary automatic emergency braking, and the like, and endangers driving safety. In conclusion, in some possible embodiments, for example, in an autonomous driving scenario, in this embodiment of this application, accurate and effective fusion processing may be performed on data of the plurality of time-synchronized sensors, to obtain more comprehensive and accurate road condition analysis, environment sensing, and the like, and improve driving comfort and safety.
In a possible implementation, the method may further include: determining clock frequency offsets between respective clocks of the N target sensors and the first clock and determining respective transmission delays of the N target sensors based on a preset time synchronization protocol; and performing time synchronization on the N target sensors based on the clock frequency offsets between the respective clocks of the N target sensors and the first clock, and the respective transmission delays of the N target sensors.
In this embodiment of this application, the clock frequency offsets between the respective clocks of the plurality of sensors and the reference clock may be determined and the respective transmission delays of the plurality of sensors may be determined based on the preset time synchronization protocol (such as a generalized precision time protocol (generalized precision time protocol, gPTP) and a network time protocol (network time protocol, NTP)). Then, time synchronization is performed on the plurality of sensors based on the clock frequency offsets between the respective clocks of the plurality of sensors and the reference clock, and the respective transmission delays of the plurality of sensors. In this way, respective moments of the plurality of sensors may be corrected. For example, specifically, speeds of the respective clocks of the plurality of sensors may be determined based on the time synchronization, and then the respective moments correspondingly increase or decrease. Further, clock frequencies of the respective clocks of the plurality of sensors and a clock frequency of the reference clock may be adjusted to a consistent frequency. In this way, when the data collected by the plurality of time-synchronized sensors is subsequently fused, accurate data fusion may be performed based on accurate time information of each piece of time-synchronized data. In some possible embodiments, the reference clock may be a clock of a controller or a clock of any sensor.
In a possible implementation, the method may further include:
In this embodiment of this application, a time synchronization protocol to be used for current time synchronization may be further determined based on one or more of current speed information (for example, a current speed of the intelligent vehicle), direction information (information such as turning left, turning right or turning around of the intelligent vehicle), and scenario information (a scenario such as a turn-left curve, a turn-right curve, a U-shaped curve, a bridge, a muddy road and a highway) of the intelligent device. The time synchronization protocol may belong to a time synchronization protocol set. The time synchronization protocol set may include a generalized precision time protocol gPTP and a network time protocol NTP, and may further include another feasible time synchronization protocol such as a time-syc protocol for sensor network (time-syc protocol for sensor network, TPSN) protocol, reference broadcast synchronization (reference broadcast synchronization, RBS) or the like. This is not specifically limited in this embodiment of this application. In this way, for example, in a scenario in which a precision requirement of time synchronization is high, such as a curve, especially a U-shaped curve, time synchronization that does not meet the requirement usually causes a large detection deviation of a target detection position. In this case, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. For another example, when a vehicle speed is high, a requirement for time synchronization is high, and time synchronization that does not meet the requirement causes poor speed fusion effect of a target vehicle. In this case, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. For another example, a lateral control function such as lane centering control (LCC) has a higher requirement on time synchronization than a longitudinal control function such as adaptive cruise control (adaptive cruise control, ACC), and the time synchronization that does not meet the requirement may cause failure of the lateral function control. In this way, when it is detected that the current intelligent vehicle is in the lane centering control, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. When it is detected that the current intelligent vehicle is in the adaptive cruise control, the network time protocol NTP with low time synchronization precision may be selected to perform time synchronization on the plurality of sensors. In this way, an actual requirement for time synchronization precision can be met when the plurality of sensors are not used. In addition, a calculation amount and costs can be reduced by using a time synchronization protocol with low precision when the precision requirement is low.
In a possible implementation, the method may further include:
In this embodiment of this application, a specific time synchronization cycle may be set, and when triggered by the cycle, a reference clock used for time synchronization is obtained, to perform periodic time synchronization. In this way, a case in which time of each sensor is out of synchronization again after time synchronization is performed for a period of time can be avoided, and it is ensured that time of the plurality of sensors can be synchronized in real time. Therefore, when the data collected by the plurality of sensors needs to be fused, accuracy of data fusion of the plurality of sensors is ensured.
In a possible implementation, the method may further include:
In this embodiment of this application, the reference clock may be obtained in an event triggering manner, to perform time synchronization. For example, obtaining of the reference clock may be triggered based on synchronization request messages sent by one or more sensors after data is collected, so as to perform time synchronization. It may be understood that the one or more sensors may be sensors that have a data fusion requirement. After collecting the data, the one or more sensors determine that data fusion needs to be performed on the data of another sensor, and time synchronization needs to be performed on the another sensor before the fusion, to ensure accuracy of the data fusion. Therefore, after the data is collected, the one or more sensors may be triggered to send a synchronization request message, so as to further trigger the time synchronization. In other words, in this embodiment of this application, the time synchronization may be triggered when the sensor has a time synchronization requirement, thereby reducing unnecessary time synchronization, reducing a calculation amount, and the like. At the same time, it can be further ensured that time synchronization is performed before each fusion, to ensure accuracy of each fusion.
In a possible implementation, the determining N target sensors from the plurality of sensors includes:
In this embodiment of this application, after the synchronization request sent by the one or more sensors (that is, a sensor that has a data fusion requirement) is received, based on the one or more sensors and the preset fusion rule, another sensor configured to perform data fusion with the one or more sensors is determined from the plurality of sensors included in the intelligent device. For example, the sensor that sends the synchronization request message is a camera in the intelligent vehicle. It should be noted that the camera has strong resolution and excellent target classification effect, but cannot perform accurate distance measurement and speed measurement due to a loss of depth information. However, a millimeter wave radar in the intelligent vehicle is high in distance measurement and speed measurement accuracy, but is poor in classification effect. The camera and the millimeter wave radar have complementary functions. In this way, it may be determined, based on a data complementary fusion rule, that the millimeter wave radar in the intelligent vehicle may be used to perform data fusion with the camera. Therefore, time synchronization may be performed on the camera and the millimeter wave radar subsequently, to ensure accuracy of data fusion between the camera and the millimeter wave radar. In this way, more comprehensive road condition analysis and environment sensing are provided for the intelligent vehicle, and driving comfort and safety are improved.
In a possible implementation, the time synchronization is relative time synchronization or absolute time synchronization; and if the time synchronization is the relative time synchronization, the first clock is a relative clock; or if the time synchronization is the absolute time synchronization, the first clock is an absolute clock.
In this embodiment of this application, when time synchronization is performed on the plurality of sensors, the time synchronization may be relative time synchronization, or the absolute time synchronization. If the time synchronization is the relative time synchronization, the obtained reference clock may be a relative clock (for example, a clock inside the intelligent vehicle, where time displayed on the relative clock may be different from actual time, and may also be displayed as a simple 32nd minute, a 60th minute, or relative time in a form of 1 hour and 1 minute ago, 5 minutes ago, or the like). If the time synchronization is the absolute time synchronization, the obtained reference clock may be an absolute clock, (for example, standard universal time such as Beijing time). Generally, inside the intelligent device, only relative time synchronization of sensors needs to be ensured. However, when external communication needs to be performed, for example, data of the plurality of sensors of the intelligent device is fused or analyzed and compared with data of a plurality of sensors in another intelligent device, absolute time synchronization can be performed to ensure accuracy of data fusion or an analysis ratio.
In a possible implementation, the method may further include:
In this embodiment of this application, for example, in an autonomous driving scenario, accurate and effective fusion processing may be performed on data collected by the plurality of time-synchronized sensors, to obtain more comprehensive and accurate road condition analysis, environment sensing, and the like, and improve driving comfort and safety. In some possible embodiments, time synchronization may be performed on a plurality of sensors in an intelligent robot, and then data collected by the plurality of time-synchronized sensors is fused, so that the intelligent robot can better sense an environment and perform an operation such as obstacle avoidance. It should be noted that this embodiment of this application may be further used in another scenario other than the foregoing scenario. For example, the data collected by the plurality of sensors is analyzed and compared to detect performance of each sensor, and the like. This is not specifically limited in this embodiment of this application.
According to a second aspect, an embodiment of this application provides a communication apparatus, applied to an intelligent device, where the intelligent device includes a plurality of sensors, and the apparatus includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the first determining unit is specifically configured to:
In a possible implementation, the time synchronization is relative time synchronization or absolute time synchronization; and if the time synchronization is the relative time synchronization, the first clock is a relative clock; or if the time synchronization is the absolute time synchronization, the first clock is an absolute clock.
In a possible implementation, the apparatus further includes:
According to a third aspect, this application provides a communication apparatus. The apparatus includes a processor, and the processor is configured to support the communication apparatus in implementing a corresponding function in the communication method provided in the first aspect. The communication apparatus may further include a memory. The memory is configured to be coupled to the processor, and stores program instructions and/or data. The apparatus may further include a communication interface, configured to communicate between the apparatus and another device or a communication network.
According to a fourth aspect, an embodiment of this application provides a computer-readable storage medium. The computer-readable storage medium stores a computer program, and the computer program is executed by the processor to implement the communication method according to any implementation of the first aspect.
According to a fifth aspect, an embodiment of this application provides a computer program. The computer program includes instructions. When the instructions are executed by a computer, the computer can perform the communication method according to any implementation of the first aspect.
According to a sixth aspect, an embodiment of this application provides a chip system. The chip system includes the communication apparatus according to any implementation of the second aspect, and is configured to implement functions in the communication method according to any implementation of the first aspect. In a possible design, the chip system further includes a memory. The memory is configured to store program instructions and/or data. The chip system may include a chip, or may include a chip and another discrete component.
According to a seventh aspect, an embodiment of this application provides a communication system, including at least one of the communication apparatus according to any implementation of the second aspect, the communication apparatus according to the third aspect, or the chip system according to the sixth aspect, and a plurality of sensors.
The following describes embodiments of this application with reference to the accompanying drawings in embodiments of this application.
In the specification, claims, and accompanying drawings of this application, the terms “first”, “second”, “third”, “fourth” and so on are intended to distinguish between different objects but do not indicate a particular order. In addition, the terms “including” and “having” and any other variants thereof are intended to cover a non-exclusive inclusion. For example, a process, a method, a system, a product, or a device that includes a series of steps or units is not limited to the listed steps or units, but optionally further includes an unlisted step or unit, or optionally further includes another inherent step or unit of the process, the method, the product, or the device.
An “embodiment” mentioned in this specification means that a particular feature, structure, or characteristic described with reference to this embodiment may be included in at least one embodiment of this application. The phrase shown in various locations in the specification may not necessarily refer to a same embodiment, and is not an independent or optional embodiment exclusive from another embodiment. It may be understood that, when no conflict occurs, embodiments described in this specification may be combined with another embodiment.
Terminologies such as “component”, “module”, and “system” used in this specification are used to indicate computer-related entities, hardware, firmware, combinations of hardware and software, software, or software being executed. For example, a component may be, but is not limited to, a process that runs on a processor, a processor, an object, an executable file, an execution thread, a program, and/or a computer. As illustrated by using figures, both a computing device and an application that runs on the computing device may be components. One or more components may reside within a process and/or an execution thread, and a component may be located on one computer and/or distributed between two or more computers. In addition, these components may be executed from various computer-readable media that store various data. For example, the components may communicate by using a local and/or remote process and based on, for example, a signal having one or more data packets (for example, data from two components interacting with another component in a local system, a distributed system, and/or across a network such as the Internet interacting with other systems by using the signal).
Some terms in this application are first described, so as to help persons skilled in the art have a better understanding.
(1) Time synchronization is a process of providing a unified time scale for a distributed system by performing specific operations on a local clock. In a centralized system, all processes or modules can obtain time from a unique global clock of the system. Therefore, any two events in the system have a clear sequence. In a distributed system, due to physical dispersion, the system cannot provide a unified global clock for independent modules, and each process or module maintains its own local clock. Therefore, even if all local clocks are calibrated at a specific moment, these local clocks are inconsistent after a period of time due to inconsistent timing rates and operation environments of these local clocks. Time synchronization should be performed, so that these local clocks can reach a same time value again. Generally, synchronization of clocks in the system does not require all clocks to be completely aligned with a standard clock of the system. It is only required to know a clock difference between each clock and the standard clock of the system at a comparison moment, and a drift correction parameter of the clock difference obtained through comparison relative to the standard clock of the system. Therefore, clock adjustment is not required. In this embodiment of this application, time synchronization may be performed on clocks of a plurality of sensors in an intelligent device based on the obtained first clock (which may be the standard clock of the system), and time of each sensor is corrected based on an existing offset.
(2) A generalized precision time protocol (generalized precision time protocol, gPTP) is a standard used to ensure time synchronization between terminals that receive and transmit data, and may achieve nanosecond-level synchronization precision. Because clocks of nodes operate independently of each other, and some applications require the clocks of the nodes to be executed in step, the gPTP is used to synchronize clocks of nodes in an in-vehicle network. For example, tasks of playing audio and video may be implemented on different nodes. Therefore, two devices should have a same clock reference. If the two devices do not have a same clock reference, an image may not match a voice.
(3) A network time protocol (network time protocol, NTP) is a protocol used for network time synchronization based on a user datagram protocol (user datagram protocol, UDP), so that a clock of a terminal device in a network is synchronized to coordinated universal time (coordinated universal time, UTC), and a precise synchronization and time checking function can be implemented in cooperation with offset adjustment of each time zone. A time synchronization function provided by an NTP server enables a clock system of the device to run normally, so as to meet a time synchronization requirement of a fusion system.
To facilitate understanding of embodiments of this application, and further analyze and provide the technical problem specifically to be resolved in this application, the following, for example, lists a solution of a multi-sensor data fusion technology.
A plurality of pieces of data are aligned to same time of the fusion module based on time information of data respectively collected by the plurality of sensors, to perform fusion processing on the plurality of pieces of data.
First, it should be noted that, for example, in a field such as autonomous driving of an intelligent vehicle, a prerequisite for fusion of data of a plurality of sensors in the intelligent vehicle is that the data of the plurality of sensors is data collected by the plurality of sensors for a same scenario. If the data of the plurality of sensors is not the data collected by the plurality of sensors for the same scenario, effective fusion cannot be performed. An important criterion for determining whether the data collected by the plurality of sensors is for the same scenario is time information of the data, for example, the time information may be a moment at which data collection is completed, or a moment at which the sensors output the data. It is assumed that, in an ideal case, the plurality of sensors in the intelligent vehicle collect data at a same frequency, and the plurality of sensors start to collect data for a same scenario at the same time, and complete the collection at the same time. After the collection is completed, the plurality of sensors may add corresponding time information (for example, a corresponding timestamp is added based on a moment at which data collection is completed) to the data collected by the plurality of sensors based on respective clocks. In the ideal case, moments at which the plurality of sensors respectively collect the data are the same. After receiving the data collected by the plurality of sensors, the fusion module determines, based on the same moments of the data, that the data meets the prerequisite of data fusion. Then, the data collected by the plurality of sensors may be fused, to provide more comprehensive and accurate road condition analysis and environment sensing.
It may be understood that, in an actual case, the plurality of sensors in the intelligent vehicle usually cannot perform data collection at the same time, and cannot complete data collection at the same time. In this case, the moments at which the plurality of sensors collect the data are usually not the same. For example,
As shown in
In addition, in an actual case, collection frequencies of the sensors in the intelligent vehicle may be different.
Disadvantages of this solution are as follows.
As described above, when data of different sensors is fused, time information is usually reference information for data fusion. Both data fusion in the ideal case and data fusion in the actual case are performed based on a timestamp added, based on a local clock, by each sensor to the data collected by the sensor, where in the actual case, time alignment needs to be performed on data of each sensor, to implement data association on the data collected by each sensor, so as to ensure accurate and smooth data fusion. In this way, when local clocks of the plurality of sensors are different, different sensors collect data and record time based on different clocks. Therefore, data originally collected at a same moment has different moments on different sensors, and therefore data fusion cannot be performed. Alternatively, in a case in which local clocks of the sensors are different, and there is a specific delay when the different sensors output data, a case that the fusion module cannot accurately enable the data collected by each sensor to correspond to the same moment on the time axis of the fusion module is liable to occur. For example, because the local clock of the sensor is 300 ms faster, a timestamp added to the data that can be originally aligned to a same moment is 300 ms faster, and finally the data and data of another sensor cannot be aligned to the same moment. This greatly affects data association and subsequent fusion processing of the fusion module, for example, the data collected by the plurality of sensors cannot be fused or is incorrectly fused, consequently the intelligent vehicle is enabled to generate a target false alarm and unnecessary automatic emergency braking, and the like, and driving safety is endangered.
In conclusion, a plurality of sensors in the solution have respective local clocks, and time of the plurality of sensors is asynchronous, which cannot meet a requirement of data fusion accuracy. Therefore, to resolve a problem that an actual service requirement cannot be met in a multi-sensor data processing technology, a technical problem to be actually resolved in this application includes the following aspects: implementing time synchronization between the plurality of sensors, and ensuring accuracy of data fusion between the plurality of sensors. In addition, a multi-sensor fusion architecture has a plurality of forms, including a distributed architecture, a centralized architecture, and the like. In different multi-sensor fusion architectures, different deployments of a controller, a sensor, and a fusion module lead to different requirements for time synchronization. Different scenarios have different requirements on time synchronization precision. For example, a scenario such as a curve and a U-shaped curve has high requirements on time synchronization. This application further provides a flexible time synchronization method in multi-sensor fusion, so that time synchronization can be performed for various sensor configurations and transmission methods in a flexible architecture, to meet different fusion architecture requirements and meet different scenario requirements.
The intelligent vehicle 100 may include various systems, for example, a travel system 102, a sensor system 104, a control system 106, one or more peripheral devices 108, a power supply 110, a computer system 112, and a user interface 116. Optionally, the intelligent vehicle 100 may include more or fewer systems, and each system may include one or more elements. In addition, each system and element of the intelligent vehicle 100 may be interconnected in a wired or wireless manner.
The travel system 102 may include components that provide power to the intelligent vehicle 100. In an embodiment, the travel system 102 may include an engine 118, an energy source 119, a transmission apparatus 120, and a wheel 121. The engine 118 may be an internal combustion engine, an electric motor, an air compression engine, or another type of engine combination, for example, a hybrid engine including a gas-oil engine and an electric motor, or a hybrid engine including an internal combustion engine and an air compression engine. The engine 118 converts the energy source 119 into mechanical energy.
Examples of the energy source 119 include gasoline, diesel, other oil-based fuels, propane, other compressed gas-based fuels, ethanol, solar panels, batteries, or other power sources. The energy source 119 may also provide energy to another system of the intelligent vehicle 100.
The transmission apparatus 120 may transmit mechanical power from the engine 118 to the wheel 121. The transmission apparatus 120 may include a gearbox, a differential, and a drive shaft. In an embodiment, the transmission apparatus 120 may further include another component, for example, a clutch. The drive shaft may include one or more shafts that may be coupled to one or more wheels 121.
The sensor system 104 may include several sensors that can sense information about an ambient environment of the intelligent vehicle 100. For example, the sensor system 104 may include a positioning system 122 (the positioning system may be a global positioning system (global positioning system, GPS), or may be a BeiDou system or another positioning system), an inertial measurement unit (inertial measurement unit, IMU) 124, a radar 126, a laser rangefinder 128, and a camera 130. The sensor system 104 may further include a sensor (for example, an in-vehicle air quality monitor, a fuel gauge, or an engine oil thermometer) of an internal system of the monitored intelligent vehicle 100. Sensor data from one or more of these sensors can be used to detect an object and corresponding features (a position, a shape, a direction, a speed, and the like) of the object. Such detection and identification are key functions of security operations of an autonomous driving intelligent vehicle 100.
The positioning system 122 may be configured to estimate a geographical location of the intelligent vehicle 100. The IMU 124 is configured to sense a location and an orientation change of the intelligent vehicle 100 based on inertial acceleration. In an embodiment, the IMU 124 may be a combination of an accelerometer and a gyroscope.
The radar 126 may sense an object in the ambient environment of the intelligent vehicle 100 by using a radio signal. In some embodiments, in addition to sensing an object, the radar 126 may further be configured to sense a speed and/or a moving direction of the object.
The laser rangefinder 128 may sense, by using a laser, an object in an environment in which the intelligent vehicle 100 is located. In some embodiments, the laser rangefinder 128 may include one or more laser sources, a laser scanner, one or more detectors, and another system component.
The camera 130 may be configured to capture a plurality of images of the ambient environment of the intelligent vehicle 100. The camera 130 may be a static camera or a video camera.
In some possible embodiments, the sensor system 104 may further include a component configured to perform data fusion on data collected by a plurality of sensors in the sensor system 104, to output more comprehensive and accurate data for autonomous driving of the intelligent vehicle 100.
The control system 106 controls operations of the intelligent vehicle 100 and components of the intelligent vehicle 100. The control system 106 may include various elements, including a steering system 132, a throttle 134, a brake unit 136, a sensor fusion algorithm 138, a computer vision system 140, a route control system 142, and an obstacle avoidance system 144.
The steering system 132 may be operated to adjust a moving direction of the intelligent vehicle 100. For example, in an embodiment, the steering system 132 may be a steering wheel system.
The throttle 134 is configured to control an operating speed of the engine 118 and further control a speed of the intelligent vehicle 100.
The brake unit 136 is configured to control the intelligent vehicle 100 to decelerate. The brake unit 136 may use friction to slow down the wheel 121. In another embodiment, the brake unit 136 may convert kinetic energy of the wheel 121 into a current. The brake unit 136 may alternatively use another form to reduce a rotation speed of the wheel 121, to control the speed of the intelligent vehicle 100.
The computer vision system 140 may operate to process and analyze an image captured by the camera 130, to identify an object and/or a feature in the ambient environment of the intelligent vehicle 100. The object and/or the feature may include a traffic signal, a road boundary, and an obstacle. The computer vision system 140 may use an object recognition algorithm, a structure from motion (structure from motion, SFM) algorithm, video tracking, and another computer vision technology. In some embodiments, the computer vision system 140 may be configured to draw a map for an environment, track an object, estimate a speed of the object, and the like.
The route control system 142 is configured to determine a travel route of the intelligent vehicle 100. In some embodiments, the route control system 142 may combine data from the sensor system 104 and one or more predetermined maps to determine a travel route for intelligent vehicle 100.
The obstacle avoidance system 144 is configured to: identify, evaluate, and avoid or bypass a potential obstacle in the environment of the vehicle 100 in another manner.
Certainly, in an example, the control system 106 may add or alternatively include components other than those shown and described. Alternatively, the control system 106 may delete some of the components shown above. In some possible embodiments, the control system 106 may further include a component configured to perform time synchronization on a plurality of sensors in the sensor system 104.
The intelligent vehicle 100 interacts with an external sensor, another vehicle, another computer system, or a user by using the peripheral device 108. The peripheral device 108 may include a wireless communication system 146, a vehicle-mounted computer 148, a microphone 150, and/or a speaker 152.
In some embodiments, the peripheral device 108 provides a means for a user of the intelligent vehicle 100 to interact with the user interface 116. For example, the vehicle-mounted computer 148 may provide information for the user of the intelligent vehicle 100. The user interface 116 may further operate the vehicle-mounted computer 148 to receive a user input. The vehicle-mounted computer 148 may perform operations through a touchscreen. In another case, the peripheral device 108 may provide a means for the intelligent vehicle 100 to communicate with another device located in the intelligent vehicle. For example, the microphone 150 may receive audio (for example, a voice command or another audio input) from the user of the intelligent vehicle 100. Likewise, the speaker 152 may output audio to the user of the intelligent vehicle 100.
The wireless communication system 146 may wirelessly communicate with one or more devices directly or through a communication network. For example, the wireless communication system 146 may use 3G cellular communication such as CDMA, EVDO, or GSM/GPRS, 4G cellular communication such as LTE, or 5G cellular communication, or another cellular communication. The wireless communication system 146 may communicate with a wireless local area network (wireless local area network, WLAN) through Wi-Fi. In some embodiments, the wireless communication system 146 may directly communicate with a device by using an infrared link, Bluetooth, or ZigBee. Other wireless protocols, for example, various vehicle communication systems, such as the wireless communication system 146, may include one or more dedicated short-range communication (dedicated short-range communication, DSRC) devices, and these devices may include public and/or private data communication between the vehicle and/or roadside stations.
The power supply 110 may provide power to various components of the intelligent vehicle 100. In an embodiment, the power supply 110 may be a rechargeable lithium-ion or lead-acid battery. One or more battery packs of such a battery may be configured as a power supply to supply power to the various components of the intelligent vehicle 100. In some embodiments, the power supply 110 and the energy source 119 may be implemented together, for example, in some pure electric vehicles.
Some or all of functions of the intelligent vehicle 100 are controlled by the computer system 112. The computer system 112 may include at least one processor 113, and the processor 113 executes instructions 115 stored in a non-transient computer-readable medium such as the memory 114. The computer system 112 may alternatively be a plurality of computing devices that control an individual component or a subsystem of the intelligent vehicle 100 in a distributed manner.
The processor 113 may be any conventional processor, such as a commercially available central processing unit (central processing unit, CPU). Optionally, the processor may be a dedicated device such as an application-specific integrated circuit (application-specific integrated circuit, ASIC) or another hardware-based processor. Although
In various aspects described herein, the processor may be located far away from the vehicle and wirelessly communicate with the vehicle. In another aspect, some processes described herein are performed on a processor disposed inside the vehicle, while others are performed by a remote processor, including performing steps necessary for single manipulation.
In some embodiments, the memory 114 may include the instructions 115 (for example, program logic), and the instructions 115 may be executed by the processor 113 to perform various functions of the intelligent vehicle 100, including the functions described above. The memory 114 may also include additional instructions, including instructions used to send data to, receive data from, interact with, and/or control one or more of the travel system 102, the sensor system 104, the control system 106, and the peripheral device 108.
In addition to the instructions 115, the memory 114 may further store data, such as a road map, route information, and a location, a direction, a speed, and other such vehicle data of the vehicle, and other information. Such information may be used by the intelligent vehicle 100 and the computer system 112 during operation of the intelligent vehicle 100 in an autonomous, semi-autonomous, and/or manual mode.
The user interface 116 is used to provide information for or receive information from the user of the intelligent vehicle 100. Optionally, the user interface 116 may include one or more input/output devices in a set of peripheral devices 108, for example, the wireless communication system 146, the vehicle-mounted computer 148, the microphone 150, and the speaker 152.
The computer system 112 may control functions of the intelligent vehicle 100 based on inputs received from various systems (for example, the travel system 102, the sensor system 104, and the control system 106) and from the user interface 116. For example, the computer system 112 may use the input from the control system 106 to control the steering system 132 to avoid an obstacle detected by the sensor system 104 and the obstacle avoidance system 144. In some embodiments, the computer system 112 may operate to provide control on the intelligent vehicle 100 and the systems of the intelligent vehicle 100 in many aspects.
Optionally, the computer system 112 may further receive information from another computer system, or transfer information to another computer system. For example, the computer system 112 may transfer sensor data collected from the sensor system 104 of the intelligent vehicle 100 to another remote computer system and submit the data to the another computer system for processing, for example, the data collected by various sensors in the sensor system 104 is fused by the another computer system. Then, data or an analysis result obtained after the fusion is returned to the computer system 112. Optionally, data from the computer system 112 may be transmitted to a computer system on a cloud side by using a network for further processing. The network and an intermediate node may include various configurations and protocols, including Internet, World Wide Web, an intranet, a virtual private network, a wide area network, a local area network, a dedicated network using a proprietary communication protocol of one or more companies, Ethernet, Wi-Fi, HTTP, and various combinations thereof. Such communication may be performed by any device that can transmit data to and from other computers, such as a modem or a wireless interface.
As described above, in some possible embodiments, the remote computer system interacting with the computer system 112 in the intelligent vehicle 100 may include a server having a plurality of computers, such as a load balancing server cluster, and exchanges information with different nodes of the network for the purpose of receiving, processing, and transmitting data from the computer system 112. The server may have a processor, a memory, instructions, data, and the like. For example, in some embodiments of this application, the data of the server may include providing weather-related information. For example, the server may receive, monitor, store, update, and transmit various pieces of weather-related information. The information may include, for example, rainfall, cloud, and/or temperature information in a form of a report, radar information, a forecast, or the like. The data of the server may further include high-definition map data and traffic information of a road section in front (for example, real-time traffic congestion, and occurrence of a traffic accident). The server may send the high-definition map data, traffic information, and the like to the computer system 112, so as to assist the intelligent vehicle 100 in performing better autonomous driving and ensure driving safety.
Optionally, one or more of these systems may be separately installed or associated with the intelligent vehicle 100. For example, the memory 114 may be partially or completely separated from the vehicle 100. The foregoing components may be communicatively coupled together in a wired and/or wireless manner.
Optionally, the foregoing systems are merely examples. In actual application, the foregoing systems may be added or deleted based on an actual requirement.
An autonomous driving vehicle traveling on a road, for example, the intelligent vehicle 100, may recognize an object in an ambient environment of the autonomous driving vehicle, to determine to adjust a current speed. The object may be another vehicle, a traffic control device (for example, a traffic signal indicator such as a traffic light), or another type of object. In some examples, each identified object may be considered independently, and based on features of each object, such as a current speed of the object, acceleration of the object, and a spacing between the object and the vehicle, may be used to determine the speed to be adjusted by the autonomous driving vehicle.
Optionally, the autonomous driving intelligent vehicle 100 or a computing device associated with the autonomous driving intelligent vehicle 100 (for example, the computer system 112, the computer vision system 140, or the memory 114 in
In addition to providing instructions for adjusting the speed of the autonomous driving vehicle, the computing device may further provide instructions for correcting a steering angle of the intelligent vehicle 100, so that the autonomous driving vehicle follows a given trajectory and/or maintains safe horizontal and vertical distances between the autonomous driving vehicle and an object (for example, a car in an adjacent lane on the road) near the autonomous driving vehicle.
The intelligent vehicle 100 may be a car, a truck, a motorcycle, a bus, a boat, an airplane, a helicopter, a lawn mower, a recreational vehicle, a playground vehicle, a construction device, a trolley, a golf cart, a train, a handcart, or the like. This is not specifically limited in this embodiment of this application.
The processor 103 may be any conventional processor, including a reduced instruction set computing (“RISC”) processor, a complex instruction set computing (“CISC”) processor, or a combination thereof. Optionally, the processor may be a dedicated apparatus such as an application-specific integrated circuit (“ASIC”). Optionally, the processor 103 may be a neural-network processor or a combination of the neural-network processor and the foregoing conventional processor.
Optionally, in various embodiments described in this application, the computer system 101 may be located away from the autonomous driving intelligent vehicle 100, and may wirelessly communicate with the autonomous driving intelligent vehicle 100. In other aspect, some of the processes described in this application are performed on a processor disposed inside an autonomous driving vehicle, and others are performed by a remote processor, including actions required to perform a single operation.
The computer system 101 may communicate with a software deploying server 149 through a network interface 129. The network interface 129 is a hardware network interface, for example, a network interface card. A network 127 may be an external network such as the Internet, or an internal network such as the Ethernet or a virtual private network (virtual private network, VPN). Optionally, the network 127 may alternatively be a wireless network such as a Wi-Fi network or a cellular network.
A hard disk drive interface is coupled to the system bus 105. A hardware drive interface is connected to the hard disk drive. A system memory 135 is coupled to the system bus 105. Data running in the system memory 135 may include an operating system 137 and an application 143 of the computer 101.
The operating system includes a shell 139 and a kernel (kernel) 141. The shell 139 is an interface between a user and the kernel (kernel) of the operating system. The shell is the outermost layer of the operating system. The shell manages interaction between the user and the operating system, waits for an input of the user, explains the input of the user to the operating system, and processes various output results of the operating system.
The kernel 141 includes components of the operating system that are configured to manage a memory, a file, a peripheral, and a system resource. When directly interacting with hardware, the kernel of the operating system usually runs a process, provides inter-process communication, and provides functions such as CPU time slice management, interrupt, memory management, and I/O management.
The application 143 includes programs for controlling autonomous driving of the vehicle, for example, a program that manages interaction between the autonomous driving vehicle and a road obstacle, a program that controls a route or a speed of the autonomous driving vehicle, a program that controls interaction between the autonomous driving vehicle and another autonomous driving vehicle on a road. The application 143 also exists in a system of the deploying server 149. In one embodiment, when the application 147 needs to be executed, the computer system 101 may download the application 143 from the deploying server 14.
The sensor 153 is associated with the computer system 101. The sensor 153 may include a plurality of sensors, and may be the sensor system 104 shown in
Optionally, if the computer 101 is located in the autonomous driving intelligent vehicle, the sensor 153 may include a camera, an infrared sensor, a chemical detector, a microphone, an inertial measurement unit, a radar, and the like. For details, refer to the sensor system 104 shown in
In addition, optionally, in some embodiments of this application, the application 143 may further include a program used to perform time synchronization on the plurality of sensors. Therefore, rigor and reliability of data of each sensor on time can be ensured, and a case such as different time of data collected at the same time on different sensors can be avoided, so as to improve accuracy of data fusion and further ensure driving safety.
The following describes in detail the communication method provided in this embodiment of this application by using the sensor 1001 and the sensor 1002 as an example. As shown in
As shown in
As described above, a specific communication method between the controller 1005 and the sensors 1001, 1002, and 1003 may be proactive (Proactive), that is, the periodic time synchronization, or may be reactive (Reactive). To be specific, time synchronization is triggered by using the synchronization request message sent by the sensor after the data is collected. A time synchronization protocol specifically used for the time synchronization may be a common related protocol such as gPTP and NTP, and details are not described herein again.
The time synchronization may include absolute time synchronization or relative time synchronization. If the controller 1005 is connected to a GPS, that is, the controller 1005 may be connected to the absolute time serving device 1006 shown in
As described above, the intelligent vehicle 100 may be a car, a truck, a motorcycle, a bus, a boat, an airplane, a helicopter, a lawn mower, a recreational vehicle, a playground vehicle, a construction device, a trolley, a golf cart, a train, a handcart, or the like that has the foregoing function. This is not specifically limited in this embodiment of this application. In addition, this embodiment of this application may be further applied to an intelligent device that includes a plurality of sensors in addition to the intelligent vehicle, for example, an intelligent robot. This is not specifically limited in this embodiment of this application. The sensors 1001, 1002, and 1003 may be various sensors having the foregoing function, for example, may be a plurality of sensors such as a camera (including a monocular camera, a binocular camera, an infrared camera or the like), a millimeter wave radar, a laser radar, an inertial measurement unit, and a vehicle attitude sensor, and may alternatively be the inertial measurement unit 124 and the laser rangefinder 128 shown in
It may be understood that the system architecture of the communication method shown in
For ease of understanding of embodiments of this application, the following example lists an application scenario to which a communication method in this application is applicable. The following two scenarios may be included.
Scenario 1: Time synchronization is performed on a plurality of sensors in an intelligent robot.
In this embodiment of this application, before the intelligent device 200 fuses the data of the plurality of sensors, a controller in the intelligent device 200 may perform, by using the communication method provided in embodiments of this application, time synchronization on the plurality of sensors on which data fusion is performed, to ensure accuracy of the data fusion of the plurality of sensors. In this way, according to the communication method provided in embodiments of this application, emergency braking, incorrect route planning, or even a serious collision, damages to public facilities, and harm to personal safety can be effectively avoided when data fusion cannot be performed due to asynchronous time of the plurality of sensors, or data with a large difference between actual collection moments is incorrectly fused.
As described above, the intelligent device 200 may be the intelligent robot having the foregoing functions shown in
Scenario 2: Time synchronization is performed on a plurality of sensors in an intelligent vehicle.
In addition, the intelligent device 200 may further establish a communication connection to another driving vehicle in the application scenario by using Bluetooth or a wireless network, to obtain data collected by one or more sensors in the another driving vehicle. In addition, the data collected by the one or more sensors in the another driving vehicle may be further fused with data of the plurality of sensors in the intelligent device 200, to provide more comprehensive and multi-directional data for the autonomous driving of the intelligent device 200. Optionally, the intelligent device 200 may further obtain real-time traffic information (including real-time traffic congestion, occurrence of a traffic accident and a status of a traffic indicator) or the like of a road section ahead by using a network, and combine the real-time traffic information with the fused data of the plurality of sensors in the intelligent device 200, to provide more comprehensive and multi-directional data for the autonomous driving, and the like. This is not specifically limited in this embodiment of this application.
For example,
Optionally, the server 400 may run, based on the received data collected by the plurality of sensors in the intelligent vehicle, a program that is related to autonomous driving control of the intelligent vehicle and that is stored in the server 400, to control the autonomous driving intelligent vehicle. The program related to autonomous driving control of the intelligent vehicle may be a program for managing interaction between the autonomous driving intelligent vehicle and an obstacle on the road, a program for controlling a road driving route or a driving speed of the autonomous driving intelligent vehicle, or a program for controlling interaction between the autonomous driving intelligent vehicle and another autonomous driving intelligent vehicle on the road.
In some possible embodiments, after receiving the data collected by the plurality of sensors in the intelligent vehicle, the server 400 may first perform fusion processing on some or all of the sensor data. Then, the server 400 may better send, to the autonomous driving vehicle, a possible driving situation in an environment and a recommended solution (for example, informing the intelligent vehicle of an obstacle ahead and how to bypass the obstacle) based on more accurate and comprehensive road condition analysis obtained after the fusion processing. For example, the server 400 may assist the intelligent vehicle in determining how to travel when facing a specific obstacle in the environment. For example, the server 400 sends, to the intelligent vehicle, a response indicating how the intelligent vehicle should travel in a current scenario. For another example, the server 400 may determine, based on the collected sensor data and data obtained after the data of the plurality of sensors is fused, that there is a temporary stop sign or a “lane closed” sign on the road ahead. Correspondingly, the server 400 may send a recommended operation (for example, planning a driving route, and indicating the intelligent vehicle to change the lane to another road) to the intelligent vehicle, so that the intelligent vehicle passes through the obstacle, and the like. Details are not described herein again.
In this embodiment of this application, before the intelligent device 200 fuses the data of the plurality of sensors or before the intelligent device 200 sends the data collected by the plurality of sensors to the server 400, a controller in the intelligent device 300 may perform, by using the communication method provided in embodiments of this application, time synchronization on the plurality of sensors on which data fusion is performed, to ensure accuracy of the data fusion. This avoids a target false alarm, automatic emergency braking, incorrect route planning, or the like, and even a serious traffic accident, damages to public infrastructure, harm to personal safety, and the like caused when data fusion cannot be performed due to asynchronous time of the plurality of sensors, or data with a large difference between actual collection moments is incorrectly fused.
Optionally, as shown in
As described above, the intelligent device 300 may be an intelligent vehicle that includes a plurality of sensors and has the foregoing functions. The intelligent vehicle may be a vehicle with a fully autonomous driving function, or may be a vehicle with an assisted driving function, or the like, such as a car, a truck, a motorcycle, a bus, a boat, an airplane, a helicopter, a lawn mower, a recreational vehicle, a playground vehicle, a construction device, a trolley, a golf cart, a train, and a handcart. Alternatively, the intelligent device 200 may be another device including a plurality of sensors, or the like. This is not specifically limited in this embodiment of this application.
It should be noted that the communication method provided in this application may be further applied to another scenario other than the foregoing application scenarios in which data fusion is performed on the plurality of sensors in the intelligent robot and the intelligent vehicle. For example, the communication method may be further applied to an application scenario in which time synchronization is performed on a plurality of sensors to ensure accuracy of analysis and comparison of data collected by the plurality of sensors. For example, absolute time synchronization may be further applied to storage of video data, so as to compare the application scenario with another external scenario. Details are not described herein again.
Step S501: Determine N target sensors from the plurality of sensors.
Specifically, the controller determines the N target sensors from the plurality of sensors of the intelligent device, where N is an integer greater than 1. Each of the N target sensors may be a sensor configured to perform processing such as data fusion, so that time synchronization needs to be performed.
Step S502: Correct respective second moments of the N target sensors to a first moment of a first clock.
Specifically, the controller corrects the respective second moments of the N target sensors based on the first clock, to obtain a first moment corresponding to each second moment. Each first moment is a moment obtained after time synchronization is performed based on the first clock, and each second moment is a moment before time synchronization is performed based on the first clock. The sensor 1001 and the sensor 1002 are used as an example. It is assumed that a first moment of the first clock (namely, a system standard clock) is T1,1, a second moment of the sensor 1001 is T1, 2, and a second moment of the sensor 1002 is T2,2, T1,2 and T2,2 of the sensor 1001 and the sensor 1002 are corrected to T1,1.
By using the method, time synchronization of the plurality of sensors in the intelligent device can be implemented, to ensure accurate fusion of data collected by different sensors.
The following provides detailed examples with reference to
Step S601: Collect data.
Specifically, M target sensors in a plurality of sensors of the intelligent device may complete data collection at respective second moments.
Step S602: Send a synchronization request message to the controller. Correspondingly, the controller receives the synchronization request message.
Specifically, the M target sensors in the plurality of sensors of the intelligent device may send the time synchronization request messages to the controller after completing the data collection at the respective second moments.
Step S603: The controller obtains a first clock.
Specifically, after receiving the synchronization request messages sent by the M target sensors, to trigger a time synchronization procedure, the controller may first obtain the first clock used for time synchronization. The first clock may be a clock of the controller.
Step S604: Determine N target sensors from the plurality of sensors.
Specifically, the M target sensors may belong to the N target sensors. M is an integer greater than or equal to 1. After receiving the time synchronization request messages sent by the M target sensors, the controller may determine, from the plurality of sensors of the intelligent vehicle based on the M target sensors and a preset fusion rule, N-M target sensors configured to perform data fusion with the M target sensors. The N-M target sensors belong to the N target sensors. In other words, the N target sensors are finally determined from the plurality of sensors of the intelligent vehicle. For example, M is equal to 1, and the M target sensors are, for example, equivalent to one camera. Generally, the camera has strong resolution and excellent target classification effect, but cannot perform accurate distance measurement and speed measurement due to a loss of depth information. However, a millimeter wave radar in the intelligent vehicle is high in distance measurement and speed measurement accuracy, but is poor in classification effect. The camera and the millimeter wave radar have complementary functions, so that based on a data complementary fusion rule, it may be determined that the millimeter wave radar in the intelligent vehicle may be used to perform data fusion with the camera (the millimeter wave radar and the camera are the N target sensors). Therefore, time synchronization may be performed on the camera and the millimeter wave radar subsequently, to ensure accuracy of data fusion between the camera and the millimeter wave radar. In this way, more comprehensive road condition analysis and environment sensing are provided for the intelligent vehicle, and driving comfort and safety are improved.
In this embodiment of this application, the time synchronization may be triggered when the sensor has a time synchronization requirement, thereby reducing unnecessary time synchronization, reducing a calculation amount, and the like. At the same time, it can be further ensured that time synchronization is performed before each data fusion, to ensure accuracy of each data fusion. In addition, the sensor may further maintain a time synchronization cycle. After a specific time synchronization cycle is exceeded, even if the sensor does not collect data, the sensor may send a synchronization request message to the controller, to trigger the controller to perform time synchronization, so as to effectively avoid a risk caused by not performing time synchronization for a long time, and the like. This is not specifically limited in this embodiment of this application.
It should be noted that time of completing data collection by a sensor is set differently based on different sensors. For example, for the camera, time of completing data collection is generally time of completing exposure. For the millimeter wave radar, time of completing data collection is time of collecting an effective radar cross section (Radar Cross section, RCS) point. After collecting data, the sensor may add a corresponding timestamp to the data, to indicate a collection moment (or a collection completion moment) of the current sensor data. For example, the respective second moments of the M target sensors are moments at which the M target sensors respectively collect data. It may be understood that, because the M target sensors have not performed time synchronization at this time, the respective second moments of the M target sensors are moments determined based on respective clocks of the M target sensors before time synchronization.
It should be noted that a sequence of performing step S603 and step S604 in
Step S605a: The controller performs, based on the first clock and a preset time synchronization protocol (for example, a time synchronization protocol such as gPTP and NTP), time synchronization for a fusion module through message sending and receiving.
Step S605b: The controller performs, based on the first clock and the preset time synchronization protocol (for example, the time synchronization protocol such as gPTP and NTP), time synchronization for the N target sensors through message sending and receiving.
Specifically, the controller may first determine clock frequency offsets between respective clocks of the N target sensors and the first clock and determine respective transmission delays of the N target sensors based on the preset time synchronization protocol. The transmission delay is a transmission delay from the N target sensors to the controller. Then, the controller may perform time synchronization on the N target sensors based on the clock frequency offsets between the respective clocks of the N target sensors and the first clock, and the respective transmission delays of the N target sensors. Time synchronization of the fusion module is similar, and details are not described herein again. For example, using the gPTP time synchronization protocol as an example, the controller may first send a first synchronization message (sync message) to the N target sensors. After the N target sensors receive the first synchronization message, a first receiving moment t1 of the first synchronization message may be determined based on respective local clocks of the N target sensors, and then the controller sends a follow_up message (follow up message) to notify the N target sensors of a first sending moment t2 (the first sending moment t2 is determined by a clock of the controller, that is, is determined by the first clock) of the first synchronization message. Then, the controller may send a second synchronization message to the N target sensors. After receiving the second synchronization message, the N target sensors may determine a second receiving moment t3 of the second synchronization message based on respective local clocks, and then the controller sends a follow up message to notify the N target sensors of a second sending moment t4 (the second sending moment is determined by a clock of the controller, that is, determined by the first clock) of the second synchronization message. Details are not described herein again. Finally, a clock frequency offset between the first clock and a local clock of a target sensor may be obtained through calculation by using a formula R=(t4−t2)/(t3−t1), where R is the clock frequency offset between the first clock and the local clock of the target sensor. Measurement of a transmission delay is not described in detail herein. Refer to a specific time synchronization protocol.
Optionally, the fusion module may be used as a software module, and may be integrated into the controller, or may be integrated into a single sensor (for example, any one of the N target sensors). It may be understood that if the fusion module is integrated into the controller, the fusion module may directly use the first clock of the controller, so that time synchronization does not need to be performed, or the like. This is not specifically limited in this embodiment of this application.
It should be noted that a sequence of performing step S605a and step S605b is not specifically limited, and step S605a and step S605b may alternatively be performed simultaneously. Corresponding steps in
As described above, respective second moments of the M target sensors in the N target sensors are moments determined based on respective clocks of the M target sensors before time synchronization. The respective second moments of the N-M target sensors in the N target sensors may be moments determined by respective clocks of the N-M target sensors in the time synchronization process. In other words, respective second moments of the N-M target sensors are moments before time synchronization is performed based on the first clock. As described above, the M target sensors may complete data collection before the N-M target sensors, and complete data collection before current time synchronization, and the N-M target sensors may complete data collection after current time synchronization. In this case, a timestamp corresponding to each piece of the data collected by the N-M target sensors is a data collection moment after time synchronization. For example, if the N-M target sensors complete data collection at respective third moments, each third moment is a moment obtained after time synchronization is performed based on the first clock.
Step S606: The N target sensors send respective collected data to the fusion module.
Step S607: The fusion module performs data fusion on the data respectively collected by the N target sensors.
In this way, after time synchronization is performed on the N target sensors, data fusion is performed on the data of the N target sensors, to effectively ensure accuracy of data fusion.
Step S701: The controller obtains a first clock.
Specifically, a time synchronization mode in this embodiment of this application may be a predictive (proactive) mode. To be specific, as shown in
Optionally, after periodically triggering the time synchronization procedure based on the preset time synchronization cycle, the controller may first obtain the first clock used for time synchronization. The first clock may be a clock of the controller.
Step S702: Determine N target sensors from a plurality of sensors.
Specifically, as described above, in this solution, the sensor does not need to send a time synchronization request to trigger time synchronization. Instead, by periodically performing time synchronization, the controller may determine the N target sensors from a plurality of sensors of an intelligent device based on a preset fusion requirement (or another requirement that needs to perform time synchronization in advance). For example, data fusion needs to be performed for presetting data of a camera and a millimeter wave radar. To ensure accuracy of data fusion between the camera and the millimeter wave radar, time synchronization needs to be performed on the camera and the millimeter wave radar. In other words, it may be determined that the camera and the millimeter wave radar are the N target sensors. Optionally, for specific description of step S702, refer to the description of step S604. Details are not described herein again.
It should be noted that a sequence of performing step S701 and step S702 in
Optionally, for step S703a and step S703b, refer to step S605a and step S605b respectively. Details are not described herein. It should be noted that a sequence of performing step S703a and step S703b in
For step S704 and step S705, refer to step S606 and step S607 respectively. Details are not described herein. It should be noted that a sequence of performing step S704 and step S705 in
The time synchronization in this embodiment of this application may be relative time synchronization or absolute time synchronization; and if the time synchronization is the relative time synchronization, the first clock is a relative clock; or if the time synchronization is the absolute time synchronization, the first clock is an absolute clock. The time synchronization performed in
For steps S801 and S802, refer to step S601 and step S602 respectively. Details are not described herein again.
Step S803: The controller obtains a first clock by using an absolute time serving device.
Specifically, the controller may obtain the first clock by connecting to the absolute time serving device, where the first clock is an absolute clock. For example, in a scenario in which an operation such as absolute time synchronization is performed based on a detection characteristic, an absolute time synchronization requirement of detection data between different sensors usually needs to be considered. In this case, the controller may obtain an absolute clock by using an absolute time serving device (for example, a GPS), to perform absolute time synchronization on the N target sensors. Optionally, the controller may send a request to the absolute time serving device, to obtain an absolute clock used for absolute time synchronization. Optionally, the controller may also store time (which may be absolute time determined by the absolute clock) that the N target sensors and the fusion module perform absolute time synchronization each time, and periodically perform absolute time synchronization on the N target sensors and the fusion module based on a specific absolute time synchronization cycle. This avoids a case in which time between sensors is out of synchronization again after a period of time, and reduces a risk caused by not performing time synchronization for a long time.
For step S804, step S805a, step 805b, step S806, and step S807, refer to step S604, step S605a, step 605b, step S606, and step S607 respectively. Details are not described herein again.
It should be noted that, a difference between the steps related to
For step S901 and step S902, refer to step S801 and step S802 respectively. Details are not described herein.
Step S903: The controller obtains current status information of the intelligent device, where the status information may include at least one of speed information, direction information, and scenario information.
Specifically, after receiving the synchronization request message and triggering a time synchronization procedure, the controller may obtain the current status information of the intelligent device by using a vehicle posture sensor, a scenario detection module, and the like in the intelligent device.
Optionally, the controller may send a request message to the vehicle posture sensor and the scenario detection module, to obtain corresponding vehicle posture information (for example, including the speed information and the direction information) and the scenario information. For example, the intelligent vehicle is used as an example. The speed information may include information such as a speed and a gear at which the intelligent vehicle currently travels. The direction information may include information such as a current wheel angle, turning left, turning right, or turning around of the intelligent vehicle. The scenario information may be, for example, information about a driving environment in which the intelligent vehicle is currently located, for example, information about a straight lane, a left-turn lane, a right-turn lane, a U-shaped curve, a bridge, a muddy road, and a highway. Optionally, for example, in a straight lane scenario, the intelligent vehicle mostly use an adaptive cruise control ACC (a longitudinal control function), and in a left-turn lane scenario, a right-turn lane scenario, or a U-shaped curve scenario, the intelligent vehicle mostly uses a lane centering control LCC (a lateral control function).
For steps S904 and S905, refer to step S604 and step S605 respectively. Details are not described herein again.
Step S906: The controller determines a preset time synchronization protocol based on the current status information of the intelligent device.
Specifically, after the current status information of the intelligent device is obtained, for example, at least one of the speed information, the direction information, and the scenario information, the preset time synchronization protocol may be determined based on the at least one of the speed information, the direction information, and the scenario information. That is, a time synchronization protocol to be used for current time synchronization is determined. Optionally, the time synchronization protocol may belong to a time synchronization protocol set, and the time synchronization protocol set may include a common generalized precision time protocol gPTP and a network time protocol NTP, and may further include another feasible time synchronization protocol such as a time-syc protocol for sensor network TPSN and reference broadcast synchronization. This is not specifically limited in this embodiment of this application.
The intelligent vehicle is used as an example. It may be understood that, in different driving scenarios or driving states, the intelligent device usually has different requirements on precision of time synchronization. For example, in a scenario in which precision of time synchronization is high, such as a curve, especially a U-shaped curve, time synchronization that does not meet a requirement usually causes a large detection deviation of a target detection position. In this case, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. For another example, when a vehicle speed is high or a gear is high, a requirement for time synchronization is high, and time synchronization that does not meet a requirement causes poor speed fusion effect of a target vehicle. In this case, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. For another example, a lateral control function such as lane centering control (mostly in a curve scenario) has a high requirement on time synchronization than a longitudinal control function such as adaptive cruise control (mostly in a straight-lane scenario), and time synchronization that does not meet the requirement may cause failure of lateral function control. In this way, when it is detected that the current intelligent vehicle is in lane centering control, the generalized precision time protocol gPTP with high time synchronization precision may be selected to perform time synchronization on the plurality of sensors. When it is detected that the current intelligent vehicle is in adaptive cruise control, the network time protocol NTP with low time synchronization precision may be selected to perform time synchronization on the plurality of sensors. In this way, an actual requirement for time synchronization precision can be met when the plurality of sensors are not used. In addition, a calculation amount and costs can be reduced by using a time synchronization protocol with low precision when the precision requirement is low.
Optionally, in addition to determining the preset time synchronization protocol based on at least one of the speed information, the direction information, and the scenario information, in some possible embodiments, the controller may further determine a used time synchronization protocol based on a precision requirement of performing data fusion by a sensor. Optionally, if precision of performing data fusion on the N target sensors is high, (for example, fusion of data of the camera and the millimeter wave radar requires high fusion precision), a time synchronization protocol with high time synchronization precision (for example, gPTP) can be selected to ensure accuracy of the data fusion. Optionally, if precision of performing data fusion on the N target sensors is low, a time synchronization protocol (for example, NTP) with low time synchronization precision may be selected to ensure accuracy of the data fusion on the N target sensors, and reduce unnecessary costs and a calculation amount. Details are not described herein again.
It should be noted that a sequence of performing step S904, step S905 and step S906 in
In conclusion, optionally, in some possible embodiments, time synchronization may further be directly performed on all of the plurality of sensors in the intelligent device. For example, in an intelligent vehicle scenario, after the user starts the intelligent vehicle, the controller in the intelligent vehicle may immediately perform time synchronization on all or some of the sensors used for data fusion in the intelligent vehicle, to ensure that accurate data required for autonomous driving is provided. This is not specifically limited in this embodiment of this application. Optionally, in some possible embodiments, time synchronization may be further performed on one or more time-out-of-synchronization sensors in the N target sensors, or the like. In addition, if a target sensor on which data fusion needs to be performed is changed after a period of time, and one or more target sensors are added or removed, time synchronization may be performed on a plurality of target sensors determined after the change. This is not specifically limited in this embodiment of this application.
For step S907a, step 907b, step S908, and step S909, refer to step S805a, step 805b, step S806, and step S807 respectively. Details are not described herein again.
An embodiment of this application provides a communication method. In an intelligent device including a plurality of sensors, time synchronization may be performed, based on a reference clock, on respective local clocks of some or all of the sensors. In this way, when data fusion or data comparison needs to be performed on data collected by some or all of the sensors, because time of the sensors is synchronized, accuracy of time information of the data collected by the sensors can be ensured. In this way, accuracy of the data fusion or data comparison can be ensured, for example, the data fusion can be ensured to be effective fusion for a same scenario. For example, in the autonomous driving scenario, in this embodiment of this application, accurate and effective fusion processing may be performed on data of the plurality of time-synchronized sensors, to obtain more comprehensive and accurate road condition analysis, environment sensing, and the like, and improve driving comfort and safety.
It should be noted that this application aims to provide a communication method. Time synchronization is performed on a plurality of sensors, to ensure rigor and reliability of data of each sensor on time, and further ensure effective and accurate processing of the data respectively collected by the plurality of sensors. An actual application scenario is not specifically limited in this embodiment of this application. Data of each time-synchronized sensor may be used for data fusion, data comparison and analysis, any other possible processing, or the like. This is not specifically limited in this embodiment of this application.
The first determining unit 304 is configured to determine N target sensors from the plurality of sensors, where N is an integer greater than 1.
The correction unit 309 is configured to correct, based on a first clock, respective second moments of the N target sensors to a first moment of the first clock.
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the apparatus further includes:
In a possible implementation, the first determining unit 304 is specifically configured to:
In a possible implementation, the time synchronization is relative time synchronization or absolute time synchronization; and if the time synchronization is the relative time synchronization, the first clock is a relative clock; or if the time synchronization is the absolute time synchronization, the first clock is an absolute clock.
In a possible implementation, the apparatus further includes:
It should be noted that, for functions of functional units in the communication apparatus described in this embodiment of this application, refer to related descriptions of step S501 and step S502 in the method embodiment described in
Each unit in
It may be understood that a connection line between units in
Based on descriptions of the foregoing method embodiments and apparatus embodiments, an embodiment of this application further provides an intelligent device. The intelligent device may be the intelligent robot shown in
The processor 401 may be a general-purpose central processing unit (CPU), a microprocessor, an application-specific integrated circuit (application-specific integrated circuit, ASIC), or one or more integrated circuits configured to control program execution in the foregoing solution.
The memory in the intelligent device may be but is not limited to a read-only memory (read-only memory, ROM) or another type of static storage device capable of storing static information and instructions, a random access memory (random access memory, RAM) or another type of dynamic storage device capable of storing information and instructions, an electrically erasable programmable read-only memory (Electrically Erasable Programmable Read-Only Memory, EEPROM), a compact disc read-only memory (Compact Disc Read-Only Memory, CD-ROM) or another compact disc storage, an optical disc storage (including a compact disc, a laser disc, an optical disc, a digital versatile disc, a Blu-ray disc, and the like), a magnetic disk storage medium or another magnetic storage device, or any other medium that can be used to carry or store expected program code in a form of instructions or a data structure and can be accessed by a computer. The memory may exist independently, and is connected to the processor through the bus. The memory may alternatively be integrated with the processor.
The computer-readable storage medium 404 may be stored in the memory of the intelligent device. The computer-readable storage medium 404 is configured to store a computer program, the computer program includes program instructions, and the processor 401 is configured to execute the program instructions stored in the computer-readable storage medium 404. The processor 401 (or referred to as a CPU (Central Processing Unit, central processing unit)) is a computing core and a control core of the intelligent device, and is suitable for implementing one or more instructions, and is specifically suitable for loading and executing one or more instructions to implement a corresponding method flow or a corresponding function. In an embodiment, the processor 401 in this embodiment of this application may be configured to perform a series of processing such as time synchronization, including: determining N target sensors from a plurality of sensors, where N is an integer greater than 1; and correcting respective second moments of the N target sensors to a first moment of a first clock, and the like.
It should be noted that, for functions of functional units in the intelligent device described in this embodiment of this application, refer to step S501 and step S502 in the method embodiment described in
In the foregoing embodiments, the description of each embodiment has respective focuses. For a part that is not described in detail in an embodiment, refer to related descriptions in other embodiments.
An embodiment of this application further provides a computer-readable storage medium (Memory). The computer-readable storage medium is a memory device in an intelligent device, and is configured to store a program and data. It may be understood that the computer-readable storage medium herein may include a built-in storage medium in the intelligent device, and certainly may also include an extended storage medium supported by the intelligent device. The computer-readable storage medium provides storage space, and the storage space stores an operating system of the intelligent device. In addition, the storage space further stores one or more instructions that are suitable for being loaded and executed by the processor 401. These instructions may be one or more computer programs (including program code). It should be noted that the computer-readable storage medium herein may be a high-speed RAM memory, or may be a non-volatile memory (non-volatile memory), for example, at least one magnetic disk memory. Optionally, the device may be at least one computer-readable storage medium that is located far away from the foregoing processor.
An embodiment of this application further provides a computer program, and the computer program includes instructions. When the computer program is executed by a computer, the computer is enabled to perform some or all steps of any live detection method.
In the foregoing embodiments, the description of each embodiment has respective focuses. For a part that is not described in detail in an embodiment, refer to related descriptions in other embodiments.
It should be noted that, for brief description, the foregoing method embodiments are represented as a series of actions. However, persons skilled in the art should appreciate that this application is not limited to the described order of the actions, because according to this application, some steps may be performed in other orders or simultaneously. It should be further appreciated by persons skilled in the art that embodiments described in this specification all belong to preferred embodiments, and the involved actions and modules are not necessarily required by this application.
In the several embodiments provided in this application, it should be understood that the disclosed apparatus may be implemented in other manners. For example, the described apparatus embodiment is merely an example. For example, division into the units is merely logical function division and may be other division during 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 or other forms.
The foregoing 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 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 embodiments.
In addition, functional units in embodiments of this application may be integrated into one processing unit (for example, the determining units, the time synchronization unit, the correction unit, and the fusion unit may be integrated into one processing unit, for example, a processor, and the obtaining units may be integrated into one transceiver unit, for example, in a transceiver), or each unit may exist alone physically, or two or more units may be integrated into one unit. The integrated unit may be implemented in a form of hardware, or may be implemented in a form of a software functional unit.
When the foregoing integrated unit is implemented in the form of a software functional unit and sold or used as an independent product, the integrated unit may be stored in a computer-readable storage medium. Based on this understanding, all or some of the technical solutions of this application 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 enabling a computer device (which may be a personal computer, a server, a network device, or the like, and specifically may be a processor in a computer device) to perform all or some of the steps of the foregoing methods in the embodiments of this application. The foregoing storage medium may include: any medium that can store program code, such as a USB flash drive, a removable hard disk, a magnetic disk, an optical disc, a read-only memory (Read-Only Memory, ROM for short), or a random access memory (Random Access Memory, RAM for short).
In conclusion, the foregoing embodiments are merely intended for describing the technical solutions of this application, but not for limiting this application. Although this application is described in detail with reference to the foregoing embodiments, persons of ordinary skill in the art should understand that they may still make modifications to the technical solutions described in the foregoing embodiments or make equivalent replacements to some technical features thereof, without departing from the scope of the technical solutions of embodiments of this application.
This application is a continuation of International Application No. PCT/CN2020/133133, filed on Dec. 1, 2020, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2020/133133 | Dec 2020 | US |
Child | 18325566 | US |