中南大学计算机网络实验报告

中南大学计算机网络实验报告

ID:23555862

大小:317.66 KB

页数:12页

时间:2018-11-09

中南大学计算机网络实验报告_第1页
中南大学计算机网络实验报告_第2页
中南大学计算机网络实验报告_第3页
中南大学计算机网络实验报告_第4页
中南大学计算机网络实验报告_第5页
资源描述:

《中南大学计算机网络实验报告》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、針真机网辂实臉報告学生姓名王伟平信息科学与工程学院2014年5月学号专业班级指导教师学院完成时间实验一分槽ALOHA协议仿真实验一、实验目的1.掌握VB、VC++、VS或jAVA等集成开发环境编写仿真程序的方法;2.理解并掌握分槽ALOHA协议原理。二、实验内容与实现原理实验内容:编写仿真程序,对一定网络环境下MAC层的多路访问协议的分槽ALOHA协议进行实现。通过仿真,学习协议采取的介质访问管理,包括介质分配和冲突解决机制,并对协议的性能与理论结果进行比较分析。实现原理:分槽Aloha的基本思想是把信道时间分成离散的时间槽,槽长力一个帧所耑的发送时间。每个站点只能在时槽开

2、始时才允许发送。其他过程与纯ALOHA协议相同。分槽Aloha的信道效率比纯Aloha要髙。分槽Aloha的易受冲突区比纯Aloha小了一半。它的重发策略是等待一段随机的时间,然后重发;如再次冲突,则再等待一段随机的时间,直到重发成功为止,但是发送的吋间也是在每个吋间槽的开始。三、具体设计实现及结果1.仿真思路设置各站点初始产生包的时间点及产生包的时间间隔(均为随机值),得到所有站点成功发送10000个数据包的总时间以及这段时间内所有数据包的个数(包括各站点每次新产生的包以及rti于冲突而重发的包),从而计算出每包时内尝试次数及其对应的吞吐量。针对不同的包产生间隔,得到不同

3、的每包时內尝试次数及其对应的吞吐W:,将其画成一条曲线。2.具体步骤1)初始化各站点产生包的时间点(可采川0到1的随机数),统一归并到时槽开始的时间点。Mgtime=[Ttime/log(l-X/Mnum)]*log(rand(l,Mnum));%初始化各站点包产生的时间点,为[0,1]的随机数mtime=(fix(mgtime/slot)+l)*slot;%各站点数据包发送时间点,归并到时槽的开始处其中:Ttime为发送一个包所需的时间,Mrwm为站点的总个数,可通过改变不同的X值得到不同的包产生时间点。X的取值小于站点总个数2)选山最早产生数据包的站点作为初始发送站点,

4、若此吋槽只有一个数据包,则发送成功:若有两个以上数据包,则冲突。记录此时槽内所有包的个数idx=find(mtime==now_time);%findingoftheterminalwhichtransmissionstartiflength(idx)>0State(idx)=TRANSMIT;%State为各站点在此吋槽的状态mtime(idx)=now_time+Mplen(idx)/Srate;%发送结束时间,Mplen为数据包的长度,Snte为发送的速率mtime(idx)=round(mtime(idx)/slot)*slot;Tplen=Tplen+sum(Mp

5、len(idx));%此时槽内所有包的总长度endidx=find(State==TRANSMIT

6、State==COLLISION);iflength(idx)>1State(idx)=COLLISION;%当有两个以上数据包时,发生冲突end1)若成功,则发送成功的数据包数加1,程序结束点也是成功的个数为10000吋。然后根据生成包的随机时间间隔,得出此站点下一次发送包的时间点。idx=find(mtime==now_time&State==TRANSMIT);%findingoftheterminalwhichtransmissionsucceedediflength

7、(idx)>0Spnum=Spnum+1;%发送成功的数据包数加1Splen=Splen+Mplen(idx);%总共发送成功数据包的长度(计算吞吐量)State(idx)=STANDBY;%设置此站点发送状态为等待mgtime(idx)=now一time+[Ttime/log(l-X/Mnum)]*log(l-rand);%算出此站点下次产生的时间点mtime(idx)=(fix(mgtime(idx)/slot)+l)*slot;%归并到时槽的开始点end2)若发生冲突,根据随机后退时间,得出此站点下一次发送包的时间点。idx=find(mtime==now_time&

8、State==COLLISION);%findingoftheterminalwhichtransmissionfailediflength(idx)>0State(idx)=STANDBY;mtime(idx)=now_time+[Ttime/log(l-X/Mnum)]*log(rand(l,length(idx)));%站点等待的时间,下次重发此数据包的时间点mtime(idx)=(fix(mtime(idx)/slot)+l)*slot;%归并到时槽的开始处end3)依次循环上述过程,直至10000个数裾包

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

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

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