计算机网络课程设计报告.docVIP

  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年7月2日 目 录 1.CRC检验码………………………………………………………… 3 1.1题目描述………………………………………………………… 3 1.2需求分析………………………………………………………… 3 1.3算法设计………………………………………………………… 3 1.4功能实现………………………………………………………… 6 2.RIP协议………………………………………………………………7 2.1题目描述………………………………………………………… 7 2.2需求分析………………………………………………………… 7 2.3算法设计………………………………………………………… 8 2.4功能实现………………………………………………………… 13 3.滑动窗口…………………………………………………………… 15 3.1题目描述………………………………………………………… 15 3.2需求分析………………………………………………………… 15 3.3算法设计………………………………………………………… 16 3.4功能实现………………………………………………………… 22 4.课程设计总结……………………………………………………… 24 5.重要程序清单……………………………………………………… 25 CRC检验码 1.1题目描述 课本P105页3-07:要发送的数据为1101011011,采用CRC的生成多项式是P(C)= X^4+X+1,试为该数据添加CRC码,并验证他的正确性,改动CRC码最后一位, 验证他的正确性。 1.2需求分析 CRC循环冗余检验是数据通信领域中最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定。上题即是要求编程实现CRC算法并利用其验证发送数据的正确性。 循环冗余校验码(CRC)的基本原理是:在K位信息码后再拼接R位的校验码,整个编码长度为N位,因此,这种编码又叫(N,K)码。对于一个给定的(N,K)码,可以证明存在一个最高次幂为N-K=R的多项式G(x)。根据G(x)可以生成K位信息的校验码,而G(x)叫做这个CRC码的生成多项式。 校验码的具体生成过程为:假设发送信息用信息多项式C(X)表示,将C(x)左移R位,则可表示成C(x)*2的R次方,这样C(x)的右边就会空出R位,这就是校验码的位置。通过C(x)*2的R次方除以生成多项式G(x)得到的余数就是校验码。CRC码的生成步骤 1、将x的最高幂次为R的生成多项式G(x)转换成对应的R+1位二进制数。    2、将信息码左移R位,相当与对应的信息多项式C(x)*2的R次方   3、用生成多项式(二进制数)对信息码做除,得到R位的余数。 4、将余数拼到信息码左移后空出的位置,得到完整的CRC码。   【例】的生成多项式是^4+X+1。位的原始报文为,求编码后的报文。    解: 1、将生成多项式^4+X+1转换成对应的二进制除数1011。 2、此题生成多项式有位(R+1),要把原始报文(x)左移(R)位变成  3、用生成多项式对应的二进制数对左移位后的原始报文进行除 步骤1中的转换过程可以由用户完成,即程序可以只提供二进制序列的输入(这样方便实现)。 1.3.3算法具体实现 核心函数CRC 定义一个函数名为string CRC(string data,string div)的函数,其参数分别为发送数据data和除数div(都有用户输入,由主函数传值) 函数分布实现 string s1,s2,temp; int len; len = div.length(); //下面的for循环式补0操作,相当于上述步骤2 for(int i=0;ilen-1;i++) data.append(0); //下面是当除数data长度大于等于除数时做循环异或操作的过程 while(data.length()=div.length()) { s2 = ; //中间变量,用来村粗每次异或的结果 s1 = data.substr(0,len); //求子串 data = data.substr(len,data.length()-len); //下面是具体的一对一的异或运算操作 for(int i=0;i(int)div.length();i++) { if(s1[i]==div[i]) //相同 s2.append(0); else s2.append(1); //相异 } //将s2前面0去掉,因为前面的0无意义,去掉后再继续下次异或 w

文档评论(0)

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

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

1亿VIP精品文档

相关文档