湖南科技大学《数字系统设计》综合实验报告实验题目:CRC编码模块设计班级:学号:姓名:日期:一:题目功能分析;设计一个在数字传输中常用的校验、纠错模块,CRC循环冗余校验模块设计简介:循环冗余校验(CRC)是一种根据网络数据封包或电脑档案等数据产生简短固定位数校验码的一种散列函数,主要用来检测或校验数据传输或者保存后可能出现的错误。生成的数字在传输或者储存之前计算出来并且附加到数据后面,然后接收方进行检验确定数据是否发生变化。而且CRC码是目前通信系统中最常用的一种差错控制编码,利用其进行检错的过程可简单描述为:在发送端根据要传送的二进制码序列,以一定的规则产生一个校验用的监督码,附在原始信息后边,构成一个新的二进制码序列数,然后发送出去。在接收端根据信息码和CRC码之间所遵循的规则进行检验,一旦传输过程中发生差错,则信息码元与监督码元之间的关系遭到破坏,从而可以发现错误,乃至纠正错误。CRC实验原理:CRC检验原理实际上就是在一个p位二位进制数据序列之后附加一个r位二进制检验码(序列),从而构成一个总长为n=p+r位的二进制序列;附加在数据序列之后的这个检验码与数据序列的内容之间存在着某种特定的关系。如果因干扰等原因使数据序列中的某一位或某些位发生错误,这种特定关系就会被破坏。因此,通过检查这一关系,就可以实现对数据正确性的检验。本设计需要完成16位信息和5位CRC校验码发送、接收,其功能实现为:采用平台上的A、B两组开关输入16位二进制数,输出为X、Y、Z三组发光二极管,同时要求6个数码管显示其相对应的16进制编码结果。二:总模块划分;由两个模块构成:CRC校验生成模块(发送)和CRC校验检错模块(接收),采用输入、输出否为并行的CRC校验生成方式。数据源CRC编码组帧随机错误帧解析CRC校验发送端接收端(结构图)三:代码实现;VHDL代码:libraryieee;useieee.std_logic_1164.all;useieee.std_logic_arith.all;useieee.std_logic_unsigned.all;entitycrcisport(clk:instd_logic;sdata:instd_logic_vector(15downto0);smg:outstd_logic_vector(7downto0);led:outstd_logic_vector(7downto0);error,hsend:outstd_logic);endcrc;architecturecommofcrcisconstantmulti_coef:std_logic_vector(5downto0):=110101;--signalsdata:std_logic_vector(15downto0):=1010001000100011;signaldatacrco:std_logic_vector(23downto0);signalcnt:std_logic_vector(4downto0);signaldtemp:std_logic_vector(15downto0);signalsdatam:std_logic_vector(15downto0);signalrdtemp:std_logic_vector(15downto0);signalrdatacrc:std_logic_vector(20downto0);signalrcnt:std_logic_vector(4downto0);signalst:std_logic;signalrt:std_logic;signalcn:std_logic;signalstate:integerrange0to8;signaltdata1,tdata2,tdata3,tdata4,tdata5,tdata6,data:std_logic_vector(3downto0);beginp1:process(clk)variablecrcvar:std_logic_vector(5downto0);beginifclk'eventandclk='1'thenif(st='0')thendtemp=sdata;sdatam=sdata;cnt=(others='0');hsend='0';st='1';elsif(st='1'andcnt11)thencnt=cnt+1;if(dtemp(15)='1')thencrcvar:=dtemp(15downto10)xormulti_coef;dtemp=crcvar(4downto0)&dtemp(5downto0)&'0'&'0'&'0'&'0'&'0';elsedtemp=dtemp(14downto0)&'0';endif;elsif(st='1'andcnt=11)thendatacrco='0'&'0'&'0'&sdata&dtemp(15downto11);hsend='1';cnt=cnt+1;elsif(st='1'andcnt=11)thenhsend='0';st='0';endif;endif;endprocessp1;tdata1=datacrco(23downto20);tdata2=datacrco(19downto16);tdata3=datacrco(15downto12);tdata4=datacrco(11downto8);tdata5=datacrco(7downto4);tdata6=datacrco(3downto0);cn='1';process(clk)beginif(clk'eventandclk='1'andcn='1')thenstate=state+1;endif;endprocess;process(data,state)begincasedataiswhen0000=smg=10111111;when0001=smg=10000110;when0010=smg=11011011;when0011=smg=11001111;when0100=smg=11100110;when0101=smg=11101101;when0110=smg=11111101;when0111=smg=10000111;when1000=smg=11111111;when1001=smg=11101111;when1010=smg=11110111;when1011=smg=11011110;when1100=smg=10111001;when1101=smg=11111100;when1110=smg=11111001;when1111=smg=11110001;whenothers=smg=00000000;endcase;endprocess;process(tdata1,tdata2,tdata3,tdata4,tdata5,tdata6,state)begincasestateiswhen1=led=11111110;data=tdata1;when2=led=11111101;data=tdata2;when3=led=11111011;data=tdata3;when4=led=11110111;data=tdata4;when5=led=11101111;data=tdata5;when6=led=11011111;data=tdata6;whenothers=led=11111111;data=1111;endcase;endprocess;endcomm;四:仿真与实验结果;首先在工程下VHDLfile编写上述代码,编写完成,点击电脑上的complication图标,然后再点击assignments,选择pins选项,按照所编程程序的要求,完成对输入输出引脚的绑定,在点击仿真模拟的图标,将程序仿真模拟,在实验平台上显示结果如上图。五:小组成员及分工说明;小组成员:分工说明:首先各自通过老师发的资料安装破解quartus软件,再看视频来学习其软件的基础使用。然后再翻阅书籍和在网上查阅资料了解到CRC编码模块设计的基本原理,一起编写VHDl代码,在软件上进行调试,运行,纠错。通过多次,最后在实验平台上进行功能实现。六:设计心得,体会;通过这次的EDA课题设计,让我们对CRC校验码有了很深的了解,也相应的对quartus软件的使用有了很大的加深。经过我们几周的努力,还是比较符合要求的完成了课题的设计。这使我们明白了,学习上的很多事情,只要肯下工夫去钻研,就一定能够有所收获,提高了我们对通信电路设计领域的认识,通过与同学分工合作既锻炼了我们合作能力也提高了我们独立分析问题和解决问题的能力。设计过程的复杂加老师的严格要求有益于培养我们严谨的工作作风。在CRC编码模块设计的实验中,最开始对其完全没有任何概念,也不知道是拿来做什么的,觉得对其基础知识掌握的很差,对VHDL代码的编写也不了解,不知道怎样做本实验,突然感觉我们应该仔细的看看书本知识才行,首先我们学习了怎样操作quartus软件,我们上网查询了CRC的基本原理。了解其实验需要实现的功能。然后编写代码,不断的进行调试,运行,纠错。之后经过多天的努力,加上对老师同学的帮助,终于基本能实现本实验的实验要求了。在本次课题设计中我们遇到了很多问题和困难,但是我们没有放弃,通过翻阅书籍和在网上查询资料,以及在同学们和老师的帮助下,我们才能顺利的完成任务。通过理论的学习和实际操作应用,我们更加深刻的了解到了理论和实践结合的重要性,在设计中遇到了种种困难和问题,通过对这些问题的解决也相应的提高了我们的动手能力和解决问题的本领,总而言之在这次的课题设计中都让我们受益匪浅。