- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 中小学生国庆假期安全教育主题班会PPT课件.pptx VIP
- 《电子商务基础》第一章课件.pptx VIP
- 第2单元活动3 编程实现算法 课件湘科版信息科技五年级上册.ppt
- 1.2记录个人观点(课件)-三年级信息科技全一册(河北大学版2024).pptx VIP
- 《黄金交易基础知识》课件.pptx VIP
- (高清版)DB22∕T 2758-2017 黑参 地标.pdf VIP
- 品牌管理完整版课件全套ppt教学教程(最新).pptx
- 2025年GB 45673《危险化学品企业安全生产标准化通用规范》解读宣贯学习课件.pptx
- 消防救援人员申请结婚报告表.doc VIP
- 答司马谏议书选择题及答案.pdf VIP
文档评论(0)