当前位置:文档之家› 数据链路层-ARQ协议

数据链路层-ARQ协议

实验:数据链路层-ARQ协议

∙任务

1.同学编写数据链路层通信协议,由《发送端程序》和《接收端程序》实现,确保数据可靠传输;

2.总结实验过程(实验报告,左侧装订):方案、编程、调试、结果、分析、结论。

∙成绩评定

1. 若完全实现无差错传输(无丢失、无差错、不重叠、不乱序、...)且实验报告出色,5分;

2. 若完成部分无差错传输,依据实验结果定成绩,3~4分;

3. 若没有完成基本的传输任务,依据实验结果定成绩,1~2分;

4. 没有进行实验和无实验报告者,0分;

∙实验环境

1. Windws 9x/NT/2000/XP/2003

2. TCP/IP协议

∙同学程序

1. 认真复习数据链路层内容,熟悉编程语言C、C++和WINDOWS程序设计技术(查阅参考书);

2. 开发工具:Visual C++ 6.0、Visual Basic 6.0、C++ Builder、Java、C#、Turbo C/C++或其它;

3. 程序示例:理想信道的《发送端程序》和《接收端程序》(含源码VC6.0);

1. ARQ基本协议1:_引入检错和应答帧

2. ARQ基本协议2:_引入超时计时器

3. ARQ基本协议3:_引入数据帧携带发送序号0~1

4. ARQ基本协议4:_引入确认帧携带发送序号0~1

5. ARQ基本协议5:_引入应答帧含有校验码

6. ARQ基本协议6:_引入数据帧和确认帧含有发送序号0~7,Ws=1,Ws=1

7. 下载:ARQ基本协议1~6及数字信道仿真程序

4. 示例实验指导

∙协议设计建议

-协议中不考虑成帧

1. 数据帧和应答帧以字节为单位;

2. 数据帧:低4位D3~D0为数据段(取值0000B~1001B,即0~9),最高位为校验位(D7),发送序号段:D6~D4;

3. 应答帧:确认帧ACK:低4位D3~D0取值1111B(FH),否认帧NAK:低4位D3~D0取值1110B(EH),发送序号段:

D6~D4;

4. 按上述定义,发送序号个数最大为8;实际使用时,可自行选取发送序号个数2或4,甚至不使用。-协议中考虑成帧

1. 参见授课讲义和教材的相关内容;

2. 数据帧:帧头+发送序号+数据段+校验段+帧尾;

3. 应答帧:帧头+发送序号+校验段+帧尾;

-协议方案提示

1. 基本ARQ协议;否认帧不必携带出错数据帧的发送序号。

2. 连续ARQ协议-回退N帧ARQ协议;应采用滑动窗口技术和否认帧应携带出错数据帧的发送序号。

3. 连续ARQ协议-选择重发ARQ协议;基本同上;

∙信道仿真程序

1. 功能:可仿真信道上的信息(数据帧或应答帧)产生丢失、产生差错和传输时延;

2. 下载:V1.21,解压后,直接运行!

3. 界面:

∙实验系统原理

1. 《发送端程序》、《信道仿真程序》和《接收端程序》采用UDP(TCP/IP)通信;

2. 若单机实验:《发送端程序》、《信道仿真程序》和《接收端程序》的IP地址设置为127.0.0.1(本机);

3. 《发送端程序》的端口=6666、《信道仿真程序》的端口=7777、《接收端程序》的端口=8888;

4. 用户程序(《发送端程序》和《接收端程序》)的信息发送到信道(《信道仿真程序》),《信道仿真程序》经过处理(产生丢失、

产生差错和传输时延),然后转发到对方。

∙实验系统示例

注:

“7:81H>80H” 表示信道上第7个信息帧产生差错,信息值由81H变为80H;

“4:81H>丢失” 表示信道上第4个信息帧产生丢失;

∙参考程序段

1.设置(偶)校验位

//-------------------------------------------------------------- void SetCheck(char& c) //设置(偶)校验位D7 (一个字节)

{

int i,sum = 0;

BYTE x = 0x01;

for(i=0; i<7; i++) //求D6~D0位的有1的个数->sum

{

if(c & x) sum++;

x = x << 1;

}

if(sum % 2) c = c|0x80; //若sum为奇数,则置D7=1

else c = c & 0x7F; //若sum为偶数,则置D7=0

}

//-------------------------------------------------------------- 2..校验(偶)校验位

//-------------------------------------------------------------- bool checkSum(BYTE c) //(偶)校验计算(一个字节)

{

int i,sum = 0;

BYTE x = 0x01;

for(i=0; i<8; i++) //求D7~D0位的有1的个数->sum

{

if(c & x) sum++;

x = x<<1;

}

if(sum % 2) return false; //若sum为奇数,则有差错!

return true; //若sum为偶数,则无差错

}

//-------------------------------------------------------------- 3.定时器函数(WIN32 API函数)

//-------------------------------------------------------------- #define ID_TIMER 1 //定时器标号

#define ID_TIMER_c 1000L //超时时间:1000L=1000 ms

//消息处理

LRESULT CALLBACK WndProc(HWND hW, UINT msg, WPARAM wP, LPARAM lP) {

switch( msg )

{

case WM_XXXXX: //其它事件触发.

相关主题