32位CRC校验码课程设计

32位CRC校验码课程设计

ID:40669703

大小:238.50 KB

页数:8页

时间:2019-08-05

32位CRC校验码课程设计_第1页
32位CRC校验码课程设计_第2页
32位CRC校验码课程设计_第3页
32位CRC校验码课程设计_第4页
32位CRC校验码课程设计_第5页
资源描述:

《32位CRC校验码课程设计》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、32位CRC校验码课程设计摘要:通过对CRC校验码原理的分析,研究了一种并行32位CRC算法。该算法采用递推的方法,直接得出计算多位数据后的CRC余数与计算前余数之间的逻辑关系。相对于一般的按位串行计算或者查表并行计算的方法来说,该方法运算速度快且不需要额外的空间存储余数表,十分有利于硬件实现。概述:在数字通信系统中可靠与快速往往是一对矛盾。若要求快速,则必然使得每个数据码元所占地时间缩短、波形变窄、能量减少,从而在受到干扰后产生错误地可能性增加,传送信息地可靠性下降。若是要求可靠,则使得传送消息地速率变慢。因此,如何合理地解决

2、可靠性也速度这一对矛盾,是正确设计一个通信系统地关键问题之一。为保证传输过程的正确性,需要对通信过程进行差错控制。差错控制最常用的方法是自动请求重发方式(ARQ)、向前纠错方式(FEC)和混合纠错(HEC)。在传输过程误码率比较低时,用FEC方式比较理想。在传输过程误码率较高时,采用FEC容易出现“乱纠”现象。HEC方式则式ARQ和FEC的结合。在许多数字通信中,广泛采用ARQ方式,此时的差错控制只需要检错功能。实现检错功能的差错控制方法很多,传统的有:奇偶校验、校验和检测、重复码校验、恒比码校验、行列冗余码校验等,这些方法都是

3、增加数据的冗余量,将校验码和数据一起发送到接受端。接受端对接受到的数据进行相同校验,再将得到的校验码和接受到的校验码比较,如果二者一致则认为传输正确。但这些方法都有各自的缺点,误判的概率比较高。循环冗余校验CRC(CyclicRedundancyCheck)是由分组线性码的分支而来,其主要应用是二元码组。编码简单且误判概率很低,在通信系统中得到了广泛的应用。下面重点介绍了CRC校验的原理及其算法实现。一、CRC原理分析计算机系统中的数据,在进行读、写或者传输时可能产生错误,为了减少和避免错误的产生,一方面可以通过对特定电路的精心

4、设计,提高电路的稳定性和可靠性;另一方面则是对数据采用某种编码,通过少量的附加电路,使之能发现某些错误,甚至能确定出错位置,进而实现自动改错的功能。CRC(循环冗余码)就是一种常用的错误检测码,它可以发现并纠正数据存储或传输过程中连续出现的多位错误,因此在介质存储和网络通信方面得到了广泛的应用。随着技术的发展,数据存储和传输速度大大提高,在一些高速的场合如usb2.0或者快速以太网中,传统的串行CRC算法已不能满足速度上的要求,而必须采用速度更快的并行算法。CRC校验的基本思路是利用线性码原理,对需要进行传输的原始k位二进制数据

5、按照一定的规则处理,产生一个r位的校验码并附加在原始数据后面,形成一个k+r位的二进制数据,最后一起发送出去。首先,可将待编码的k位数据表示成多项式其中为0或者1。对于r位CRC来说,校验码产生的过程为:将M(X)左移r位,然后除以一个称为生成多项式的G(X),所得余数就是CRC校验码。这里,生成多项式G(X)是一个r+1位的多项式。用公式表示如下:其中Q(X)为商,在CRC的计算过程中不需要关注,R(x)为余数,就是需要的CRC码。CRC的计算使用的是模2运算,即不带进位和借位的按位加减,这在逻辑上等同于异或运算。串行32位的

6、CRC算法设为计算前的CRC多项式,为生成多项式G(x)的第i位系数。则新读入一位数据后,若记为计算一位数据后的CRC码多项式,则可得:式(1)给出了读入一位数据后新的CRC码与原来的之间的逻辑关系。采用这种算法,当原始数据依次输入完毕后,32位寄存器内的值就是最后的CRC码。这种算法无需在原始数据后添加32位0进行计算。二、并行32位CRC算法串行算法一个时钟周期内只能处理一位数据,在某些高速场合只能靠提高时钟频率来达到所需的速度要求,这增加了开发的难度和成本,因此提出了CRC的并行算法。并行CRC算法一次读入多位数据,通过当

7、前余数与读入数据的运算,得出新的余数。显然,一个时钟周期处理n位数据的并行算法在计算结果上与串行算法处理n个时钟周期所得的余数应该相同。基于这一点,采用递推的方法可由串行算法导出并行算法计算前后余数之间的逻辑关系。下面以4位CRC-32并行算法为例,说明推导的过程。CRC-32的生成多项式G(x)为:转换成二进制序列就是100000100110000010001110110110111为了便于表达,记为:(2)其中,对应于生成多项式的系数,取0或者1。定义为计算了第j位数据后所得CRC值的第i位,,,,,,,,为读入的数据顺序,

8、最初时的CRC值为:,,,…,,,。基本思想就是连续套用式(1)给出的串行公式8次,以期得到处理8位数据后与和,,,,,,,之间的逻辑关系。推导过程如下:以上推导结果表明,计算8位数据后的CRC值可由当前CRC值与输入数据的异或组合来表示,这为并行CRC的实现提

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。