Skip to content
Xevel edited this page Nov 26, 2010 · 25 revisions

Welcome to the NXV11 wiki!

Here are some stuff about the lidar on the Neato Robotics XV-11 vacuum cleaner.

The data on this page and in the provided code are not based on official information, so take everything with a grain of salt...

See https://sites.google.com/site/chenglung/home/xv-11-open-lidar-project-matlab-script too for a matlab version with it's own improvements !

and here for the original Trossen Robotics thread and here http://random-workshop.blogspot.com/ for new data and info.

2010/11/25 : aww, man ! I just go away for one day and the data format has changed :s

#Data format for firmeware V2.4 (new scans)

A full revolution will yield 90 packets, containing 4 consecutive readings each. The length of a packet is 22 bytes. This amounts to a total of 360 readings (1 per degree) on 1980 bytes.

Each packet is organized as follows:

<start byte> <index> <speed> <Data 0> <Data 1> <Data 2> <Data 3> <checksum>

where:

  • start byte is always FA

  • index is the index byte in the 90 packets, going from A0 (packet 0, readings 0 to 3) to F9 (packet 89, readings 356 to 359).

  • speed is a two-byte information, little-endian. It represents the speed, in 64th of RPM.

  • Data 0 to 3 are the 4 readings. Each on is 4 bytes long, and organized as follows :

byte 0 : <distance 7:0>

byte 1 : <"invalid data" flag> <"quality warning" flag> <distance 13:8>

byte 2 : <quality 7:0>

byte 3 : <quality 15:8>

As chenglung points out, the distance information is in mm, and coded on 13 or 14 bits. This would put the tests made by Sparkfun in a room of around 3.3m x 3.9m (11ft x 13 ft ?), which seems reasonable to me. 13 bits should be enough if the sensor is destined to work up to 6m. This needs some tests...

The bit 7 of byte 1 seems to indicate that data could not be read.

It's interesting to see that when this bit is set, the second byte is always 80, and the values of the first byte seem to be only 02, 03, 21, 25, 35 or 50... When it's 21, then the whole block is 21 80 XX XX, but for all the other values it's the data block is YY 80 00 00 maybe it's a code to say what type of error ? (35 is preponderant, 21 seems to be when the beam is interrupted by the supports of the cover) . Another thing to have a look to is the temporal repartition of the data... the first sample after the sync seems to always be 21 80 XX XX, and when this pattern appears again, it's immediately after an other value, without the 0.2ms interval we can see most of the time between two blocks of 4...

The bit 6 of byte 1 is a warning when the reported quality is greatly inferior to what is expected at this distance. This may happen when the material has a low reflectance (black material...), or when the dot does not have the expected size or shape (porous material, transparent fabric, grid, edge of an object...), or when there are parasitic reflections (glass... ).

Byte 2 and 3 look like the LSB and MSB of the quality indication, in which only the 10 first bits seems to be used.

  • checksum is a two-byte checksum of the packet. Details need to be ironed out.

Data format for firmeware 2.1 (Sparkfun scans)

The periodicity of the data is 1446 bytes.

It is organized as follow :

5A A5 00 C0 XX XX <data>

where XX XX is an information about the current rotation speed of the module, in clock ticks (little endian). FJ_Sanchez and shimniok posted interesting data about this.

<data> is composed of 360 group of 4 bytes, organized like this :

byte 0 : <distance 7:0>

byte 1 : <"invalid data" flag> <"quality warning" flag> <distance 13:8>

byte 2 : <quality 7:0>

byte 3 : <quality 15:8>

As chenglung points out, the distance information is in mm, and coded on 13 or 14 bits. This would put the tests made by Sparkfun in a room of around 3.3m x 3.9m (11ft x 13 ft ?), which seems reasonable to me. 13 bits should be enough if the sensor is destined to work up to 6m. This needs some tests...

The bit 7 of byte 1 seems to indicate that data could not be read.

It's interesting to see that when this bit is set, the second byte is always 80, and the values of the first byte seem to be only 02, 03, 21, 25, 35 or 50... When it's 21, then the whole block is 21 80 XX XX, but for all the other values it's the data block is YY 80 00 00 maybe it's a code to say what type of error ? (35 is preponderant, 21 seems to be when the beam is interrupted by the supports of the cover) . Another thing to have a look to is the temporal repartition of the data... the first sample after the sync seems to always be 21 80 XX XX, and when this pattern appears again, it's immediately after an other value, without the 0.2ms interval we can see most of the time between two blocks of 4...

The bit 6 of byte 1 is a warning when the reported quality is greatly inferior to what is expected at this distance. This may happen when the material has a low reflectance (black material...), or when the dot does not have the expected size or shape (porous material, transparent fabric, grid, edge of an object...), or when there are parasitic reflections (glass... ).

Byte 2 and 3 look like the LSB and MSB of the quality indication, in which only the 10 first bits seems to be used.

Clone this wiki locally