基带编码软件课程设计设计报告.doc

上传人:仙人指路1688 文档编号:4138392 上传时间:2023-04-07 格式:DOC 页数:19 大小:265.50KB
返回 下载 相关 举报
基带编码软件课程设计设计报告.doc_第1页
第1页 / 共19页
基带编码软件课程设计设计报告.doc_第2页
第2页 / 共19页
基带编码软件课程设计设计报告.doc_第3页
第3页 / 共19页
基带编码软件课程设计设计报告.doc_第4页
第4页 / 共19页
基带编码软件课程设计设计报告.doc_第5页
第5页 / 共19页
点击查看更多>>
资源描述

《基带编码软件课程设计设计报告.doc》由会员分享,可在线阅读,更多相关《基带编码软件课程设计设计报告.doc(19页珍藏版)》请在三一办公上搜索。

1、 课程设计报告书设计题目 : 基带码型编码软件 学院(系): 物理与电子工程学院 专 业: 通信工程 年级班级 : 2006级通信工程(1)班 学 号: 106263010 学生姓名 : XXX 起止日期 : 2011年8月29日至2011年9月16日 指导教师: XXX 内容摘要:数字基带传输是数字传输技术的一种基本形式,是研究数字频带传输系统的基础。数字基带码型的选择对于数字基带传输系统的性能具有重要意义。基于AMI码、HDB3码、CMI码、曼切斯特码、差分曼切斯特码的编码原理,用Visual C+6.0设计AMI码、HDB3码、CMI码、曼切斯特码、差分曼切斯特码的编码软件,能够根据用户

2、输入的二进制信息序列及设定的编码类型给出对应的编码结果,并以图形化的方式显示出波形来。本软件编码器详细叙述了其相关编码算法和关键技术,系统以MFC的单文档为模板,界面设计人性化,操作简易明了。编码算法有多种参数设置。对学习AMI、HDB3码、CMI码、曼切斯特码、差分曼切斯特码有很大的帮助,使学习者可以更加直观了认识这几个码型的编码规则,同时也可以应用于实际中某些适合这类码型传输的系统,为这些系统提供编码使其更利于传输。关键词:Visual C+6.0,HDB3,AMI,CMI,曼切斯特码,编码器,随机码,极性,线条宽度,颜色,波形目 录一、设计要求:4二、设计意义:4三、设计原理43.1、

3、AMI码43.2、HDB3码43.3、CMI码53.4、 曼彻斯特码53.5、系统设计方法分析53.6、系统的设计思路5四、系统的具体设计与实现64.1编码算法设计64.1.1 AMI编码算法64.1.2 HDB3 编码算法84.1.3 CMI 编码算法104.1.4 曼彻斯特码编码算法124.1.5 随机信号生成算法144.2、 画图设计14五、调试结果与现象分析15六、系统不足之处18七、心得体会18八、参考文献19一、设计要求:基本要求:用C+等高级语言设计AMI码、HDB3码的编码软件,要求能根据用户输入的二进制信息序列及设定的编码类型给出对应的编码结果,并以图形化的方式显示出波形来。

4、能够设置一些参数:如线的颜色、宽度;能够控制是否显示网格线、是否在编码波形旁边显示其编码结果等。能产生由用户设定信息序列长度的随机序列,并给出此序列的编码结果,并以图形化的方式显示出波形来。扩展要求:能够对其它常见基带码型,如Manchester码、差分Manchester码、多电平码等进行编码和显示。 二、设计意义:通过本次课程设计,系统了解和掌握通信系统的基带码型编码软件设计过程、方法及实现;掌握运用C+高级语言设计通信软件的方法,为以后设计和实现通信系统打下良好基础。三、设计原理3.1、 AMI码 AMI码全称是传号交替反转码。其编码规则是将二进制消息代码“1”(传号)交替地变换为传输码

5、的“+1”和“-1”,而“0”(空号)保持不变。例如消息码100110000000110011AMI码:+1001+10000000-1+100-1+1AMI码对应的基带信号是正负极性交替的脉冲序列,而0电位持不变的规律。AMI码的优点是,由于+1与-1 交替, AMI码的功率谱中不含直流成分,高、低频分量少,能量集中在频率为1/2码速处。位定时频率分量虽然为0,但只要将基带信号经全波整流变为单极性归零波形,便可提取位定时信号。此外,AMI码的编译码电路简单,便于利用传号极性交替规律观察误码情况。鉴于这些优点,AMI码是CCITT建议采用的传输码性之一。 AMI码的不足是,当原信码出现连“0”

6、串时,信号的电平长时间不跳变,造成提取定时信号的困难。解决连“0”码问题的有效方法之一是采用HDB3码。 3.2、HDB3码 HDB3码的全称是三阶高密度双极性码,它是AMI码的一种改进型, 其目的是为了保持AMI码的优点而克服其缺点, 使连“0”个数不超过3个。其编码规则如下: (1) 当信码的连“0”个数不超过3时,仍按AMI码的规则编,即传号极性交替; (2)当连“0”个数超过3时,则将第4个“0”改为非“0”脉冲,记为+V或-V,称之为破坏脉冲。相邻V码的极性必须交替出现,以确保编好的码中无直流; (3)为了便于识别, V码的极性应与其前一个非“0”脉冲的极性相同,否则,将四连“0”的

7、第一个“0”更改为与该破坏脉冲相同极性的脉冲,并记为+B或-B;(4) 破坏脉冲之后的传号码极性也要交替。 例如: 消息代码:1000010000110000l1AMI码:-10000+10000-1+10000-1+1HDB3码:-1000-V+1000+V-1+1-B00-V+1-1 其中的V脉冲和B脉冲与1脉冲波形相同,用V或B符号的目的是为了示意是将原信码的“0”变换成“1”码。 虽然HDB3码的编码规则比较复杂,但译码却比较简单。 从上述原理看出,每一个破坏符号V总是与前一非0符号同极性(包括B在内)。这就是说,从收到的符号序列中可以容易地找到破坏点V,于是也断定V符号及其前面的3个

8、符号必是连0符号,从而恢复4个连0码,再将所有-1变成+1后便得到原消息代码。 HDB3码保持了AMI码的优点外,同时还将连“0”码限制在3个以内,故有利于位定时信号的提取。HDB3码是应用最为广泛的码型,A律PCM四次群以下的接口码型均为HDB3码。3.3 CMI码CMI码是传号反转码的简称,与双相码类似,它也是一种双极性二电平码。其编码规则是:“1”码交替用“11”和“00”两位码表示;“0”码固定地用“01”表示。例如:消息码100110000000110011CMI码:110101001101010101010101001101011100CMI码易于实现,含有丰富的定时信息。此外,由

9、于10喂禁用码组,不会出现三个以上的连码,这个规律可用于宏观检错。3.4曼彻斯特码曼彻斯特码即双性码,它用一个周期的正负对称方波表示“0”,而用其反相波形表示“1”。编码规则之一是:“1”码用“10”两位码表示;“0”码用“01”表示。例如:消息码100110000000110011曼彻斯特码:100101101001010101010101101001011010其波形是一种双极性NRZ波形,只有极性相反的两个电平。它在每个码元间隔的中心点都存在电平跳变,所以含有丰富的位定时信息,且没有直流分量,编码过程也简单。缺点是占用带宽加倍,使频带利用率降低。3.5、系统设计方法及系统主要功能概述在该

10、编码系统设计中,我们采用了面向对象的技术。基于AMI码、HDB3码、CMI码和曼彻斯特码的编码原理,本编码器采用Visual C+6.0设计。所采用编译器的是Visual C+6.0,它是微软开发的基于Windows下的面向对像的编程软件,它有着强大的MFC支持,在可视化设计方面有着强大的优势,并且高度支持C+标准,是一个进行C+编程的超强集成环境。本设计为实现用户友好交互信息,采用拆分单文档实现,一部分实现用户输入信息序列及相关信息的显示,另一部分实现编码结果图形显示。本设计中用户可有AMI码、HDB3码、CMI码和曼彻斯特码四种编码类型可选择。并能对前一个1码或前一个v码的正负极性,坐标轴

11、与分割线的显示与否,图形线条宽度、颜色等相关参数进行设置。输入原始信号,系统经过特定算法编码给出编码结果并画出编码波形给与用户形象化的结果。系统会实时对用户所做的操作进行结果反馈,有很好的用户交互性。3.6、系统的设计思路软件编码器的基本操作流程是:用户选择编码类型并设置相关参数设置,然后输入原始信号(或通过随机码按钮产生相应长度的随机码信号),系统经过特定算法编码给出编码结果并画出编码波形给与用户形象化的结果。系统会实时对用户所做的操作进行结果反馈,有很好的用户交互性。根据上述分析,系统结构如图3.4.1所示图3.4.1用户层提供用户与仿真系统交互的接口。系统层根据接口层的输入,建立仿真模块

12、的动态模型,并调用相应的算法返回仿真结果。数据层存储仿真层运行算法处理的各种中间数据。获取用户数据 根据编码类型进行编码 根据编码结果进行绘图四、系统的软件设计流程及描述4.1编码算法设计4.1.1 AMI编码算法(1)流程图:开始码型标识符号变量CodeChoos=“AMI”获取输入信号及其长度,flag1保存前一个1码的极性第i位信号=1?前一个1码为正?将此1码编为-1,flag1=-1将此1码编为+1,flag1=+1结束是否是否(2)具体描述:获取输入信号及其长度,保存前一个1码极性 1)在AMI码编码函数中将编码码型标识符号变量CodeChoose赋值为“AMI”。定义字符串变量s

13、trAMI来存储用GetDlgItemText获取的输入信号和编码结果,并定义整形变量SignalLength存储用GetLength来获取的输入信号长度,定义变量flag1来保存前一个1码的极性。2)然后用for语句对输入信号进行检测,用GetAt(i)来获取第i位信号,并用if语句进行判断,若输入信号为1再判断前一个1码的极性,若前一个1码为正,则此输入信号1码应编为负极性码,用SetAt将其替换为e(代表-1),并将flag1赋值为“-1”保存当前1码的极性。若前一个1码为负,则此输入信号1码应编为正极性码,用SetAt将其替换为E(代表+1),并将flag1赋值为“+1”保存当前1码的

14、极性。3)设置好每位输入信号后退出for语句,定义变量strAMITemp来保存编码的中间结果,以供绘图使用。用Replace将“e”取代“-1”, 将“E”取代“+1”,用 SetDlgItemText将编码结果显示在编码结果编辑框中。使主框架类指针变量pCDrMFrame指向当前视图类的父框架类指针。主框架类的公有成员变量Code存放编码结果的中间结果strAMITemp,并用Invalidate();语句强迫调用画图函数OnDraw();这就完成了AMI码的编码。(3)实现代码如下:/ AMI码编码void CBIANMAView:OnRadioAmi() CodeChoose = AM

15、I;/ TODO: Add your control notification handler code herethis-GetDlgItem(IDC_STATIC_SETPOLAR)-ShowWindow( SW_SHOW );this-GetDlgItem(IDC_STATIC_SETPOLAR)-SetWindowText(AMI码设置);this-GetDlgItem(IDC_STATIC_POLARV)-ShowWindow(SW_HIDE);/隐藏前一个V码极性的选项this-GetDlgItem(IDC_RADIO_POSV)-ShowWindow(SW_HIDE);this-

16、GetDlgItem(IDC_RADIO_NEGV)-ShowWindow(SW_HIDE);CString strAMI;this-GetDlgItemText(IDC_EDIT_INPUT,strAMI);/取输入信号CString flag1=polar1;/保存1码的极性int SignalLength=strAMI.GetLength();/获得输入信号的长度for(int i=0;iSetDlgItemText(IDC_EDIT_OUPUT,strAMI);/在编码结果编辑框中显示编码结果pCDrMFrame= (CMainFrame*)this-GetParentFrame();

17、pCDrMFrame-CodeChoose = AMI;pCDrMFrame-Code=strAMITemp;pCDrMFrame-Invalidate();4.1.2 HDB3 编码算法(1)流程图: 获取输入信号及其长度,flag1保存前1码极性,flagv保存前v码极性,连0个数计数变量Zerocount=0将此第四个0码编为+V, flagv=+V将第一个0码编为+B,flag1=+1flag1=-1?否开始码型标识符号变量CodeChoos=“HDB3”第i位信号=1?是否Zerocount=0;结束将此1码编为-1,flag1=-1前一个1码为正?将此1码编为+1,flag1=+1

18、否是Zerocount+;Zerocount=4?Zerocount=0;flagv=+V?flag1=+1?将此第四个0码编为-V,flagv=-V将第一个0码编为-B,flag1=-1是是是是否否否(2)具体描述:获取输入信号及其长度,保存前一个1码极性 1)在HDB3码编码函数中将编码码型标识符号变量CodeChoose赋值为“HDB3”。定义字符串变量stHDB3来存储用GetDlgItemText获取的输入信号和编码结果,并定义整形变量SignalLength存储用GetLength来获取的输入信号长度,定义变量flag1来保存前一个1码的极性, flagv来保存前一个v码的极性,Z

19、erocount来计算连0个数。2)然后用for语句对输入信号进行检测,用GetAt(i)来获取第i位信号,并用if语句进行判。3)若输入信号为1,Zerocount清0,再判断前一个1码的极性,若前一个1码为正,则此输入信号1码应编为负极性码,用SetAt将其替换为e(代表-1),并将flag1赋值为“-1”保存当前1码的极性。若前一个1码为负,则此输入信号1码应编为正极性码,用SetAt将其替换为E(代表+1),并将flag1赋值为“+1”保存当前1码的极性。4)若输入信号为0,Zerocount+1,判断Zerocount是否等于4,若等于4,判断前一个V码极性.。若为+V将第四个0替换

20、为x(代表-V),并将flagv赋值为-V,再判断此时的前一个1码极性,若为正极性,则将第一个0码替换为y(代表-B),并将flag1赋值为-1。若为-V将第四个0替换为X(代表+V),并将flagv赋值为+V,再判断此时的前一个1码极性,若为正负极性,则将第一个0码替换为Y(代表+B),并将flag1赋值为+1。5)设置好每位输入信号后退出for语句,定义变量strHDB3Temp来保存编码的中间结果,以供绘图使用。用Replace将“e”取代“-1”, 将“E”取代“+1”, “x”取代“-V”, “X”取代“+V”, “y”取代“-B”, “Y”取代“+B”,用 SetDlgItemTe

21、xt将编码结果显示在编码结果编辑框中。使主框架类指针变量pCDrMFrame指向当前视图类的父框架类指针。主框架类的公有成员变量Code存放编码结果的中间结果strHDB3Temp,并用Invalidate();语句强迫调用画图函数OnDraw();这就完成了HDB3码的编码。实现代码如下:/ HDB3码编码void CBIANMAView:OnRadioHdb3() / TODO: Add your control notification handler code hereCodeChoose=HDB3;if(GetCheckedRadioButton(IDC_RADIO_POSV,IDC

22、_RADIO_NEGV)=0) polarv=+V;CheckRadioButton(IDC_RADIO_POSV,IDC_RADIO_NEGV,IDC_RADIO_POSV);this-GetDlgItem(IDC_STATIC_SETPOLAR)-ShowWindow( SW_SHOW ); this-GetDlgItem(IDC_STATIC_SETPOLAR)-SetWindowText(HDB码设置);this-GetDlgItem(IDC_STATIC_POLARV)-ShowWindow(SW_SHOW);this-GetDlgItem(IDC_RADIO_POSV)-ShowW

23、indow(SW_SHOW);this-GetDlgItem(IDC_RADIO_NEGV)-ShowWindow(SW_SHOW);CString strHDB3;this-GetDlgItemText(IDC_EDIT_INPUT,strHDB3);/取输入信号 CString flag1=polar1;/保存1码的极性CString flagv=polarv;/保存v码的极性int Zerocount=0;/计算连零个数int SignalLength=strHDB3.GetLength();/获得输入信号的长度for(int i=0;iSetDlgItemText(IDC_EDIT_O

24、UPUT,strHDB3);/在编码结果编辑框中显示编码结果pCDrMFrame= (CMainFrame*)this-GetParentFrame();pCDrMFrame-CodeChoose=HDB3; pCDrMFrame-Code=strHDB3Temp; pCDrMFrame-Invalidate();4.1.3 CMI编码算法(1)流程图: 开始码型标识符号变量CodeChoos=“CMI”获取输入信号及其长度,flag1保存前一个1码的极性第i位信号=1?前一个1码为正?将此1码编为11,flag1=-1将此1码编为00,flag1=+1结束是否是否将此0码编为01(2)具体描

25、述:获取输入信号及其长度,保存前一个1码极性 1)在CMI码编码函数中将编码码型标识符号变量CodeChoose赋值为“CMI”。定义字符串变量strCMI来存储用GetDlgItemText获取的输入信号和编码结果,并定义整形变量SignalLength存储用GetLength来获取的输入信号长度,定义变量flag1来保存前一个1码的极性。2)然后用for语句对输入信号进行检测,用GetAt(i)来获取第i位信号,并用if语句进行判断,若输入信号为1再判断前一个1码的极性,若前一个1码为正,则此输入信号1码应编为11,用SetAt将其替换为c(代表11),并将flag1赋值为“-1”保存当前

26、1码的极性。若前一个1码为负,则此输入信号1码应编为00,用SetAt将其替换为C(代表00),并将flag1赋值为“+1”保存当前1码的极性。若输入信号为0则将此码编为01,用SetAt将其替换为o(代表01).3)设置好每位输入信号后退出for语句,定义变量strCMITemp来保存编码的中间结果,以供绘图使用。用Replace将“c”取代“11”, 将“C”取代“00”, 将“o”取代“01”,用 SetDlgItemText将编码结果显示在编码结果编辑框中。使主框架类指针变量pCDrMFrame指向当前视图类的父框架类指针。主框架类的公有成员变量Code存放编码结果的中间结果strCM

27、ITemp,并用Invalidate();语句强迫调用画图函数OnDraw();这就完成了CMI码的编码。实现代码如下:/ CMI码编码void CBIANMAView:OnRadioCmi() CodeChoose=CMI;/ TODO: Add your control notification handler code herethis-GetDlgItem(IDC_STATIC_SETPOLAR)-ShowWindow( SW_SHOW );this-GetDlgItem(IDC_STATIC_SETPOLAR)-SetWindowText(CMI码设置); this-GetDlgIt

28、em(IDC_STATIC_POLARV)-ShowWindow( SW_HIDE );this-GetDlgItem(IDC_RADIO_POSV)-ShowWindow( SW_HIDE );this-GetDlgItem(IDC_RADIO_NEGV)-ShowWindow( SW_HIDE );CString strCMI;this-GetDlgItemText(IDC_EDIT_INPUT,strCMI);/取输入信号 CString flag1=polar1;/保存1码的极性int SignalLength=strCMI.GetLength();/获得输入信号的长度for(int

29、i=0;iSetDlgItemText(IDC_EDIT_OUPUT,strCMI);/在编码结果编辑框中显示编码结果pCDrMFrame= (CMainFrame*)this-GetParentFrame();pCDrMFrame-CodeChoose=CMI;pCDrMFrame-Code=strCMITemp;pCDrMFrame-Invalidate();4.1.4 MANCHESTER编码算法(1)流程图: 开始码型标识符号变量CodeChoos=“MANCHESTER”获取输入信号及其长度第i位信号=1?将此1码编为10结束是否将此0码编为01(2)具体描述:获取输入信号及其长度,

30、保存前一个1码极性 1)在MANCHESTER码编码函数中将编码码型标识符号变量CodeChoose赋值为“MANCHESTER”。定义字符串变量strMANCHESTER来存储用GetDlgItemText获取的输入信号和编码结果,并定义整形变量SignalLength存储用GetLength来获取的输入信号长度。2)然后用for语句对输入信号进行检测,用GetAt(i)来获取第i位信号,并用if语句进行判断,若输入信号为1则此输入信号编为10,用SetAt将其替换为m(代表10),若输入信号为0则将此码编为01,用SetAt将其替换为M(代表01).3)设置好每位输入信号后退出for语句,

31、定义变量strMANCHESTERTemp来保存编码的中间结果,以供绘图使用。用Replace将“m”取代“10”, 将“M”取代“01”,用 SetDlgItemText将编码结果显示在编码结果编辑框中。使主框架类指针变量pCDrMFrame指向当前视图类的父框架类指针。主框架类的公有成员变量Code存放编码结果的中间结果strMANCHESTERTemp,并用Invalidate();语句强迫调用画图函数OnDraw();这就完成了MANCHESTER码的编码。实现代码如下:/ MANCHESTER码编码void CBIANMAView:OnRadioManchester() CodeCh

32、oose=MANCHESTER;CString strMANCHESTER;this-GetDlgItemText(IDC_EDIT_INPUT,strMANCHESTER);/取输入信号int SignalLength=strMANCHESTER.GetLength();/获得输入信号的长度 for(int i=0;iSetDlgItemText(IDC_EDIT_OUPUT,strMANCHESTER);/在编码结果编辑框中显示编码结果pCDrMFrame= (CMainFrame*)this-GetParentFrame();pCDrMFrame-CodeChoose=MANCHESTE

33、R; pCDrMFrame-Code=strMANCHESTERTemp;pCDrMFrame-Invalidate();4.1.5 随机信号生成算法为了方便信号生成,本系统还设计了可随用户自定义长度的随机原始信号生成算法。实现代码如下:void CBIANMAView:OnButton1() / TODO: Add your control notification handler code hereUpdateData(1);CString str,strtemp;str=;int j;srand( (unsigned)time( NULL ) ); /设置一个随机起点for(int i=

34、0;iSetWindowText(str); OnChangeEditInput();4.2、 画图设计为了使用户能对编码结果能有更形象化的了解,该系统还设计了编码结果图形显示。各种码型编码后画波形由以下程序实现。实现代码如下:void CDrawView:OnDraw(CDC* pDC) CDocument* pDoc = GetDocument();CRect Rect; CWnd* pWnd = pDC-GetWindow(); pWnd-GetWindowRect(Rect); CMainFrame*pCDrMFrame = (CMainFrame*)this-GetParentFra

35、me();if(pCDrMFrame-Code.GetLength() = 0)return;if(pCDrMFrame-ShowCoodinate) DrawCoordinate(pDC,pCDrMFrame-m_linewith);/画坐标轴if(pCDrMFrame-ShowDottedLine)DrawDottedLine(pDC,pCDrMFrame-Code.GetLength();/画虚线if(pCDrMFrame-CodeChoose=AMI)DrawAMI(pDC, pCDrMFrame-Code, pCDrMFrame-color1, pCDrMFrame-color2,

36、pCDrMFrame-m_linewith); /画AMI编码DrawTheCode(pDC,pCDrMFrame-firstCode); /画输入信号原码if(pCDrMFrame-CodeChoose=HDB3)DrawHDB3(pDC, pCDrMFrame-Code, pCDrMFrame-color1, pCDrMFrame-color2, pCDrMFrame-m_linewith); /画HDB3编码DrawTheCode(pDC,pCDrMFrame-firstCode); /画输入信号原码if(pCDrMFrame-CodeChoose=CMI)DrawCMI(pDC, pCDrMFrame-Code, pCDrMFrame-color1, pCDrMFrame-co

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号