LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

CRC-6 for BiSS Communication

Solved!
Go to solution

Hi, I am trying to implement a CRC-6 check for a Kubler encoder using LabVIEW. I've been there are 34 bits coming back from the sensor including multiturn bits, singleturn bits, status bits and CRC bits. These are used in the CRC calculation - see below. NOTE: There is no Lifecounter for my specific device so it can be ignored.

 

AJ232_0-1736182060683.png

The 6 bit CRC is also transmitted inversely, which I am assuming means that I will need to do a "Bitwise NOT" operator on them:

 

AJ232_1-1736182156861.png

 

I've taken the LabVIEW CRC calculation algorithm from the following post on this forum and modified so it fits a 6-bit CRC with initial value of 0x00 and a poly of 0x43: Solved: Re: Implementing CRC checksum CRC-8 with 0xFF initialization - Sensirion SHT85 - NI Communit...

 

I get the data from the sensor as a Boolean array which I then manipulate and convert into byte arrray to then feed into the algorithm - which if done correctly should output zero. Unfortunately, I don't seem to be getting zero when I do this. 

 

A snippet of my code is shown below:

 

AJ232_2-1736182638558.png

I have also attempted a Lookup Table implementation of the algorithm which uses the pre-computed LUT mentioned in the comment within the snippet. I have luck with neither implementation.

 

AJ232_5-1736183111527.png

 

 

I would be grateful if someone can help me troubleshooting the code.

 

The sample code which I have taken from my sensor is the boolean array as follows. Where the first (bit "0") can be ignored/disregarded for the calculation.

 

AJ232_4-1736182822772.png

 

Thanks 🙂

 

0 Kudos
Message 1 of 10
(286 Views)

@AJ232 wrote:

A snippet of my code is shown below:


This is not a snippet, just a simple image. We cannot run or debug pictures.

 

Please attach your VI (do a "save for previous", 2019 or below and make sure all controls have typical default values).

0 Kudos
Message 2 of 10
(279 Views)

Here is the actual snippet of the code attached below saved as LV 2019.

 

Thanks!

0 Kudos
Message 3 of 10
(238 Views)

Hi, I can provide more examples of the output from the sensor (in bits) if needs be.

0 Kudos
Message 4 of 10
(189 Views)

The exact specification for the BISS CRC calculation can be found in this document: https://biss-interface.com/download/biss-an-3/

Rolf Kalbermatter
My Blog
0 Kudos
Message 5 of 10
(180 Views)

Thanks for your response Rolf. I've had a look at that BiSS-C doucment before but still have made no progress in getting my LabVIEW CRC-6bit implementation working. The document does provide example C-code at the end however, my sensor is fully controlled via LabVIEW and I've compared the C-code to my VI which are both in essense similar. But still no luck 😞

0 Kudos
Message 6 of 10
(127 Views)
Solution
Accepted by AJ232

This should work. It's quick and dirty. You can probably make improvements.

 

I found an exemplar on the web and it comes back with the correct CRC. I also did a CRC check of your "Useful Bits from Sensor" and it came back with the expected value of 0b111111 (0x3F).


I also saved it as a previous version (2019) just in case you don't have the latest installed.

 

version 2024 Q3

BiSS CRC-6 Snippet.png

 

Message 7 of 10
(100 Views)

Brilliant thanks maxandzoey! That seems to work now. To help my understanding of the algorithm, why is it performing an "AND" operation with the bytes using 0x3F before "XOR"-ing with the value from the Look-up Table? I thought the polynomial for the BiSS CRC-6 was 0x43 which is not present in your algorithm? Is this another method you are which is different to what I had?

 

Thanks 🙂

 

AJ232_0-1737110356545.png

 

 

0 Kudos
Message 8 of 10
(78 Views)

The polynomial 0x43 is not directly present in the algorithm. Instead, the polynomial is used to build the LUT.

 

The 0x3F (circled in RED) is a mask. In binary it is 0b00111111. The LUT values are only valid with indexes from 0 to 63. Since the index is an unsigned 8 bit integer and the CRC is 6 bit, the 0x3F with AND clears the 2 MSB which are not used. The way I build the index value, the mask is probably not necessary and can be removed. I just put it there for posterity.

 

The 0x3F and XOR outside the For Loop is there to invert the CRC. You only want to invert the 6 LSB of the CRC-6, thus the 0x3F.

0 Kudos
Message 9 of 10
(53 Views)

Thanks for the reply. It makes a lot more sense now! The mask is there to ensure that only 6 bits from the unsgned 8-bit integer gets passed to the LUT. I have modified my original code with one or two of the changes from your code which has now resulted in my code also working. 

I have not included the mask, but I realised one of the key things I was missing was to reverse the bool array before converting to a byte array. I have also now created a bool array with a multiple of 6 rather than 8. My code also runs the XOR before passing to the LUT index whereas in your code it carries out the XOR operation after the indexing.

 

AJ232_0-1737467543864.png

 

0 Kudos
Message 10 of 10
(41 Views)