-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Release 2.0.1 sick_lidar_localization phase II: time synchronization,…
… configuration of time sync during initialization
- Loading branch information
Showing
49 changed files
with
2,109 additions
and
179 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,77 @@ | ||
# SoftwarePLL | ||
|
||
Software PLL for synchronisation between ticks and timestamps. | ||
|
||
## Introduction | ||
|
||
Many sensor devices, e.g. lidar devices, provide sensor data with timestamps. These timestamps can be synchronized with | ||
the current system time by additional hardware, e.g. by GPS. But without specialized hardware, sensor timestamps and | ||
system time is normally unsynchronized. Sensor timestamps are often quite accurate, but have a different time base and | ||
a bias to the system time or to other sensor clocks. This difference is estimated and compensated by this Software PLL. | ||
|
||
To compensate the different time base and bias between sensor and system clock, the system time when receiving sensor data | ||
is gathered together with the sensor timestamp. While the system time is often measured in seconds resp. nanoseconds, | ||
the sensor timestamp is normally received in clock ticks. SoftwarePLL estimates the correlation between system time in | ||
seconds/nanoseconds and sensor ticks, and computes a corrected time from ticks. This way you know at which time stamp the data | ||
have been measured by your sensor. | ||
|
||
SoftwarePLL is a generic module and independant from specific sensor types. It just uses the system timestamps and ticks, | ||
estimates their correlation and predicts the time from sensor ticks. See [timing.md](timing.md) for an application | ||
example using SICK laser scanner https://github.com/SICKAG/sick_scan. | ||
|
||
## How Software PLL works | ||
|
||
SoftwarePLL computes a linear regression between ticks and system timestamps. The system time is measured immediately | ||
after receiving new sensor data, while sensor ticks represent the sensor clock at the time of measurement. Thus we have | ||
three different times for each measurement: | ||
|
||
- The time when the system receives the sensor data (receive time t_rec), measured in seconds resp. nanoseconds. | ||
|
||
- The sensor ticks (or just ticks) at the time of the measurement. These ticks are contained in the sensor data and | ||
received later by the system. | ||
|
||
- The time of the measurement (measurement time t_mea). We don't know this time yet, but we estimate it from both the ticks | ||
and their receive time t_rec using the SoftwarePLL. | ||
|
||
During initialization, ticks and system timestamps are stored in fifo buffer (first-in, first-out). After initialization, | ||
typically after N=7 measurements, a regression line is computed, i.e. the slope `m` (gradient) of a function | ||
`f(ticks) = m * ticks + c` is estimated from ticks `x(i)` and timestamps `y(i)` by a linear regression | ||
`m = (N * sum(x(i) * y(i)) - sum(x(i)) * sum(y(i))) / (N * sum(x(i) * x(i)) - sum(x(i))*sum(x(i)))` with `0 <= i < N` and | ||
unbiased values `x(i) = tick(i) - tick(0)`, `y(i) = t_rec(i) - t_rec(0)`. | ||
|
||
data:image/s3,"s3://crabby-images/510ea/510eaf68c5358bf2c4814a2875f77e5eb0c4fbc2" alt="pll_regression.png" | ||
|
||
The estimated system time `t_esti(i)` of a measurement can be computed from its sensor tick by `t_esti(i) = m * (ticks(i) - ticks(0)) + t_rec(0)`. | ||
If the difference between estimated times `t_esti(i)` and the measured system timestamps `t_rec(i)` is small (typically | ||
less than 100 milliseconds), the estimation can be considered to be valid. With a valid estimation of `m`, we can | ||
get a corrected timestamp for new measurements by applying function `SoftwarePLL::GetCorrectedTimeStamp`, which returns | ||
the estimated system time of a measurement `t_esti = m * (ticks - ticks(0)) + t_rec(0)`. | ||
|
||
If the estimation is not valid (i.e. the difference between estimated times and measured system timestamps in the buffer is | ||
significant), we can't estimate system timestamps from sensor ticks. If this happens more than a given number of times | ||
after initialization (typically 20 times), the fifo is reset and a new initialization is done. | ||
|
||
## Source code example | ||
|
||
Use the following code snippet as an example: | ||
|
||
``` | ||
#include "softwarePLL.h" | ||
// Create an instance of SoftwarePLL | ||
SoftwarePLL& software_pll = SoftwarePLL::Instance("Sensor1"); | ||
// Get system time t_rec in seconds and nanoseconds when receiving sensor data | ||
ros::Time t_rec = ros::Time::now(); | ||
uint32_t sec = t_rec.nsec; | ||
uint32_t nanosec = t_rec.nsec; | ||
// Get sensor ticks from sensor data | ||
uint32_t ticks = scanner_msg.ticks; | ||
// Update SoftwarePLL | ||
software_pll.UpdatePLL(sec, nanosec, ticks); | ||
// Get corrected timestamp (time of measurement from ticks) | ||
software_pll.GetCorrectedTimeStamp(sec, nanosec, ticks); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
## Time synchronization | ||
|
||
Many laser scanner applications require accurate timing down to the level of individual points, so time synchronization is implemented in this ROS driver. | ||
The scanner has an internal time base of microseconds since system startup. Against this "tick" time base all time stamps are made in the scanner. | ||
When sending messages from the scanner, two time stamps are added: | ||
1. scan generation ticks--> timestamp at the time of the first shot | ||
2. scan transmission ticks--> time stamp for the transmission of the data | ||
|
||
When data packets are received, they are timestamped by the driver against the systemtime in ros::time format. See following Fig. | ||
|
||
data:image/s3,"s3://crabby-images/6f485/6f4857239903b7b3f54114ed173d892a32c1462a" alt="timing_syn.png" | ||
The relationship between system time and ticks is then derived from the time stamps and kept synchronous.The time required for the transmission of data over the network is assumed to be short and constant and is therefore neglected. | ||
The function of the algorithms is shown in the following Fig. | ||
data:image/s3,"s3://crabby-images/43b1e/43b1e2a4059a3bfb46097104e16bbda51d05365e" alt="sequence_time_pll.png" | ||
|
||
# Data buffering in MRS 1xxx | ||
|
||
Due to their construction the MRS 1xxx scanners generate different layers at the same time which are output sequentially by the scanner firmware. In order to ensure that only point cloud messages that follow one another in time are sent, buffering can be activated in the driver. | ||
data:image/s3,"s3://crabby-images/7becc/7becc2ef1751a7a55f34ca1c002119b260668437" alt="scannbuffering.png" |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.