2012年西南科技大学工业数据通信 现场总线期末作业题.docVIP

2012年西南科技大学工业数据通信 现场总线期末作业题.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
2012年西南科技大学工业数据通信 现场总线期末作业题

现场总线技术及其应用 期末作业 课程名称: 现场总线技术及其应用 姓 名: 学 号: 班 级: 电气09 任课教师: 张 海 涛 信息工程学院 2012年5月15日 1、为了实现数据的可靠传输,在通信过程中常采取一些差错检测措施。常用的检错方式有奇偶校验、求和校验、纵向冗余校验、循环冗余校验等。说简要明这些检错方式的原理及其实现方法,并编写程序代码(C语言编写)。(20分) 奇偶校验 在奇偶校验中,一个单一的校验位被加在每个单位数据域上,使得包括该校验位在内的各单位数据域中1的个数是偶数(即为偶校验),或者为奇数(奇校验)。在接收端采用同一种校验方式检查接收到的数据和校验位,判断该传输过程是否出错,如果出现1的个数为偶数,就表明传输的过程是正确的,数据可用。若在某个数据域中1的个数不是偶数,就说明传输过程出现错误。 奇偶校验程序为: #includestdio.h #includestring.h #define set_bit(x,y) ((x)|=(0x01(y))) //置位x的y位 #define clr_bit(x,y) ((x)=(~(0x01(y)))) //清零x的y位 unsigned char parity_check(unsigned char Data) { int i; unsigned char Count = 0; // 单个数据类型内1的个数 for(i = 0; i 8; i++) { if(Data 0x01) { Count++;} Data = 1;} return(Count 0x01); } int main() { unsigned char Data[200]; unsigned char Parity_bit[25]={0}; int i,length_Data,length_Parity_bit; printf(\n*********以下数据均以字符串形式输入************\n); printf(请输入数据:); gets(Data); length_Data=strlen(Data); printf(原始数据(字符串):(%d字节)\n,length_Data); for(i = 0; ilength_Data; i++) { printf(%c,Data[i]); if(parity_check(Data[i])) { set_bit(Parity_bit[i/8], i%8); } else { clr_bit(Parity_bit[i/8], i%8); } } length_Parity_bit=strlen(Parity_bit); printf(\n校验码(十六进制):(%d字节)\n,length_Parity_bit); for(i=0;ilength_Parity_bit;i++) { printf(%4x,Parity_bit[i]); } printf(\n****************偶校验*********\n); return 0; } 2、求和校验: 在求和校验中,在发送端将数据分为k段,每段均为等长的n比特。将分段1与分段2做求和操作,再逐一与分段3至k做求和操作,得到长度为n比特的求和结果,将该结果取反后作为校验和放在数据块后面,与数据块一起发送到接收端。在接收端对接收到的、包括校验和在内的所有k+1段数据求和,如果结果为零,就认为传输过程没有错误,所传数据正确,否则认为传输的数据出现错误。 求和校验的C语言程序为: #includestdio.h #includestring.h unsigned char sum_checking( unsigned char *data,int n) { int i; char sum=0; for(i=0;in;i++) { sum+=*(data+i); } sum=~s

文档评论(0)

yaocen + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档