crc8算法
“crc8算法”相关的资料有哪些?“crc8算法”相关的范文有哪些?怎么写?下面是小编为您精心整理的“crc8算法”相关范文大全或资料大全,欢迎大家分享。
CRC8 - verilog
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////// // Company: // Engineer: //
// Create Date: 15:40:57 09/17/09 // Design Name:
// Module Name: crc8 // Project Name: // Target Device: // Tool versions: // Description: //
// Dependencies: //
// Revision:
// Revision 0.01 - File Created // Additional Comments: //
////////////////////////////////////////////////////////////////////////////////
module crc8(reset,clk,start,data_in,out_rs,crc_code); paramet
CRC8 - verilog
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////// // Company: // Engineer: //
// Create Date: 15:40:57 09/17/09 // Design Name:
// Module Name: crc8 // Project Name: // Target Device: // Tool versions: // Description: //
// Dependencies: //
// Revision:
// Revision 0.01 - File Created // Additional Comments: //
////////////////////////////////////////////////////////////////////////////////
module crc8(reset,clk,start,data_in,out_rs,crc_code); paramet
CRC8 - verilog
`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////// // Company: // Engineer: //
// Create Date: 15:40:57 09/17/09 // Design Name:
// Module Name: crc8 // Project Name: // Target Device: // Tool versions: // Description: //
// Dependencies: //
// Revision:
// Revision 0.01 - File Created // Additional Comments: //
////////////////////////////////////////////////////////////////////////////////
module crc8(reset,clk,start,data_in,out_rs,crc_code); paramet
C的CRC8校验的源代码:
简要介绍资料的主要内容,以获得更多的关注
C的CRC8校验的源代码:
// CRC8校验
// X^8 + X^2 + X^1 + 1
unsigned int code CRC8_TAB[256] = {
0x00,0x07,0x0E,0x09,0x1C,0x1B,0x12,0x15,0x38,0x3F,0x36,0x31,0x24,0x23,0x2A,0x2D, 0x70,0x77,0x7E,0x79,0x6C,0x6B,0x62,0x65,0x48,0x4F,0x46,0x41,0x54,0x53,0x5A,0x5D, 0xE0,0xE7,0xEE,0xE9,0xFC,0xFB,0xF2,0xF5,0xD8,0xDF,0xD6,0xD1,0xC4,0xC3,0xCA,0xCD, 0x90,0x97,0x9E,0x99,0x8C,0x8B,0x82,0x85,0xA8,0xAF,0xA6,0xA1,0xB4,0xB3,0xBA,0xBD, 0xC7,0xC0,0xC9,0xCE,0xDB,0xD
crc8校验查表法实现方法
/*
CRC-8 for Dallas iButton products
From Maxim/Dallas AP Note 27
\ Dallas Semiconductor iButton Products\
The Ap note describes the CRC-8 algorithm used in the iButton products. Their implementation involves a 256 byte CRC table. This algorithm is implemented here. In addition two other algorithms are shown. One uses nibble arrays and the other uses boolean arithmetic.
18JAN03 - T. Scott Dattalo */
/*
crc array from the Maxim ApNote */
unsigned char crc_array[256] = {
0x0
crc8校验查表法实现方法
/*
CRC-8 for Dallas iButton products
From Maxim/Dallas AP Note 27
\ Dallas Semiconductor iButton Products\
The Ap note describes the CRC-8 algorithm used in the iButton products. Their implementation involves a 256 byte CRC table. This algorithm is implemented here. In addition two other algorithms are shown. One uses nibble arrays and the other uses boolean arithmetic.
18JAN03 - T. Scott Dattalo */
/*
crc array from the Maxim ApNote */
unsigned char crc_array[256] = {
0x0
CRC算法原理
CRC校验算法
CRC(Cyclic Redundancy Check)循环冗余校验是常用的数据校验方法,讲CRC算法的文章很多,之所以还要写这篇,是想换一个方法介绍CRC算法,希望能让大家更容易理解CRC算法。
先说说什么是数据校验。数据在传输过程(比如通过网线在两台计算机间传文件)中,由于传输信道的原因,可能会有误码现象(比如说发送数字5但接收方收到的却是6),如何发现误码呢?方法是发送额外的数据让接收方校验是否正确,这就是数据校验。最容易想到的校验方法是和校验,就是将传送的数据(按字节方式)加起来计算出数据的总和,并将总和传给接收方,接收方收到数据后也计算总和,并与收到的总和比较看是否相同。如果传输中出现误码,那么总和一般不会相同,从而知道有误码产生,可以让发送方再发送一遍数据。 CRC校验也是添加额外数据做为校验码,这就是CRC校验码,那么CRC校验码是如何得到的呢?
非常简单,CRC校验码就是将数据除以某个固定的数(比如ANSI-CRC16中,这个数是0x18005),所得到的余数就是CRC校验码。
那这里就有一个问题,我们传送的是一串字节数据,而不是一
CRC算法原理
CRC校验算法
CRC(Cyclic Redundancy Check)循环冗余校验是常用的数据校验方法,讲CRC算法的文章很多,之所以还要写这篇,是想换一个方法介绍CRC算法,希望能让大家更容易理解CRC算法。
先说说什么是数据校验。数据在传输过程(比如通过网线在两台计算机间传文件)中,由于传输信道的原因,可能会有误码现象(比如说发送数字5但接收方收到的却是6),如何发现误码呢?方法是发送额外的数据让接收方校验是否正确,这就是数据校验。最容易想到的校验方法是和校验,就是将传送的数据(按字节方式)加起来计算出数据的总和,并将总和传给接收方,接收方收到数据后也计算总和,并与收到的总和比较看是否相同。如果传输中出现误码,那么总和一般不会相同,从而知道有误码产生,可以让发送方再发送一遍数据。 CRC校验也是添加额外数据做为校验码,这就是CRC校验码,那么CRC校验码是如何得到的呢?
非常简单,CRC校验码就是将数据除以某个固定的数(比如ANSI-CRC16中,这个数是0x18005),所得到的余数就是CRC校验码。
那这里就有一个问题,我们传送的是一串字节数据,而不是一
CRC校验PLC算法
CRC校验函数
cBuffer:计算CRC校验码的数组。 iBufLen:该数组的长度。
unsigned int CRC_Verify(unsigned char *cBuffer, unsigned int iBufLen) {
unsigned int i, j; //#define wPolynom 0xA001 unsigned int wCrc = 0xffff;
unsigned int wPolynom = 0xA001;
/*---------------------------------------------------------------------------------*/ for (i = 0; i < iBufLen; i++) {
wCrc ^= cBuffer[i]; for (j = 0; j < 8; j++) {
if (wCrc &0x0001)
{ wCrc = (wCrc >> 1) ^ wPolynom; } else
{ wCrc = wCrc
CRC校验算法
1.生成多项式。
16位的CRC码产生的规则是先将要发送的二进制序列数左移16位(既乘以
)后,再除以一个多项式,最后所得到的余数既是CRC码。任意一个由二进制位串组成的代码都可以和一个系数仅为?0?和?1?取值的多项式一一对应。例如:代码1010111对应的多项式为x6+x4+x2+x+1,而多项式为x5+x3+x2+x+1对应的代码101111。 标准CRC生成多项式如下表:
名称 生成多项式 简记式* 标准引用 CRC-4 x4+x+1 3 ITU G.704 CRC-8 x8+x5+x4+1 0x31 CRC-8 x8+x2+x1+1 0x07 CRC-8 x8+x6+x4+x3+x2+x1 0x5E CRC-12 x12+x11+x3+x+1 80F
CRC-16 x