PCM通信系统的性能分析与MATLAB仿真.pdf
淮海工学院课程设计报告书课程设计报告书课程名称:通信系统的计算机仿真设计题 目:PCM 通信系统的性能分析与 MATLAB 仿真系(院):电子工程学院学期:专业班级:姓名:学号:1 1绪论绪论研究背景与研究意义研究背景与研究意义数字化 e 时代,我们身边的数字产品越来越多,像数码相机,手机,数字电视等等。我们重点关注的是这些现代无线通信系统有一个共同的特点,那就是它们采用的都是数字制式。在现阶段,数字通信系统相对模拟通信系统有着巨大的优势。脉冲编码(PCM)调制是一种将模拟信号转变成数字信号的编码方式,主要运用与语音传输。于 20 世纪 40 年代,在通信技术中就已经实现了这一编码技术,并迅速在光纤通信、卫星通信、数字微波通信中得到广泛应用,目前它不仅运用于通信领域,还广泛运用于计算机、遥控遥测、数字仪表广播电视等许多领域。借助于 MATLAB 软件,可以直观方便的进行计算和仿真。课程设计的目的和任务课程设计的目的和任务通信系统的计算机仿真设计课程设计目的在于使学生在课程设计过程中能够理论联系实际,在实践中充分利用所学理论知识分析和研究设计过程中出现的各类技术问题,巩固和扩大所学知识面,为以后走向工作岗位进行设计打下一定的基础。评语:评语:成绩:成绩:签名:日期:课程设计的任务是:(1)掌握一般通信系统设计的过程、步骤、要求、工作内容及设计方法;掌握用计算机仿真通信系统的方法。(2)训练学生网络设计能力。(3)训练学生综合运用专业知识的能力,提高学生进行通信工程设计的能力。2 PCM2 PCM 通信系统通信系统 PCM PCM 通信系统介绍通信系统介绍信道性能信道 PCM 系统的原理框图,本次课程设计应用 Matlab 进行仿真,仿真基本框图如图 1 所示。PCM 主要优点是:抗干扰能力强;传输性能稳定,远距离信号再生中继时噪声不累积,且可以使用压缩编码和纠错编码和保密编码等来提高系统有效性、可靠性、保密性。PCM PCM 通信系统的性能指标通信系统的性能指标1误码率:错误接收的码元数在传送总码元数中所占的比例,误码率是码元在传输系统中被传错的概率。2误信率:指错误接收的信息量在传送信息总量中所占的比例。3 PCM3 PCM 通信系统主要模块通信系统主要模块模拟信号的抽样模拟信号的抽样抽样定理抽样是时间上连续的模拟信号变成一系列时间上离散的抽样序列的过程。抽样定理要解决的是能否由此抽样序列无失真地恢复出原模拟信号。抽样定理是模拟信号数字化的理论依据。根据乃奎斯特抽样定理:若频带宽度有限的,要从抽样信号中无失真地恢复原信号,抽样频率应大于 2 倍信号最高频率。抽样过程抽样的过程是将输入的模拟信号与抽样信号相乘,通常抽样信号是一个周期为 Ts 的周期脉冲信号,抽样后得到的信号称为抽样序列。对幅度 A 频率 f 的信号进行的周期性扫描即是对信号的抽样。话音信号频率在 4kHZ 以内,实际中话音的抽样频率采用的是8kHZ,此次课程设计也是采用 fs=8kHZ 的抽样频率,抽样周期 T=1/fs。所以由音频信号和抽样函数可得抽样后的信号为:S=Asin(w*n*T),抽 n 个值。每隔时间 t(时间 t 要尽量小,如)对低通连续的语音信号进行取样。MATLAB 对抽样的仿真结果(1)时域抽样 MATLAB程序运行仿真出的一百个点的序列,连线形成的波形为正弦波如图所示。图 2 原始语音信号语音信号幅度 A=,频率 f=2K;图 3 抽样脉冲信号抽样频率 fs=8K,抽样周期 Ts=1/fs图 4 时域抽样信号在-0s 到时间段 T 内,每隔进行取样,信源的单音频信号为y=Asin(w*t),抽样后的信号为:S=Asin(w*n*T),抽 100 个值,即n=1,100。(2)抽样信号的频谱原音频信号 f=的单频信号,抽样频率是 8kHZ,两个信号相乘即为已抽样信号,时域相乘对应频域卷积,所以已抽样信号的频谱应是周期离散的,如果只显示一个周期(08kHZ)的,只在和有值,如图3,理论分析与实际仿真结果正好吻合。图 5 抽样信号频谱量化和编码量化和编码量化就是将一个有连续幅度值的信号映射成取值离散的抽样。量化方案可分为标准量化和矢量量化,标量量化中每个信源输出被分别量化,又分为均与量化和非均匀量化。均匀量化对大的输入信号还是小的输入信号一律采用相同的量化间隔。为适应幅度大的输入信号,同时又要满足精度要求,就需要增加样本的位数。但是,对话音信号来说,大信号出现的机会并不多,增加的样本位数就没有充分利用。为了克服这个不足,就出现了非均匀量化的方法。非均匀量化非均匀量化是根据信号的不同区间来确定量化间隔的。对于信号取值小的区间,其量化间隔v也小;反之,量化间隔就大。它与均匀量化相比,有两个突出的优点。实际中,非均匀量化的实际方法通常是将抽样值通过压缩再进行均匀量化。通常使用的压缩器中,大多采用对数式压缩。广泛采用的两种对数压缩律是压缩律和 A 压缩律。美国采用压缩律,我国和欧洲各国均采用 A 压缩律,所谓 A 压缩律也就是压缩器具有如下特性的压缩律:1 ln Ax 1Ax1y,X 1y,0 X 1 ln AA1 ln AA,由于 A 律压缩实现复杂,常使用 13 折线法编码,压扩特性图如图 4所示:图 6 13 折线法编码编码编码是把量化后的信号变换成代码的过程。其反过程称为译码。编码的原理:把量化后的所有量化级,按其量化电平的大小次序排序起来,并列出个对应的码字。PCM 编码中一般采用二进制编码,常用的二进制码型 有自然码和折叠码等。语音信号数字化国际标准采用的是折叠码型。A 律 13 折线编码规则中采用 8 位二进制码,对应有 M=28=256 个量化级,即正、负输入幅度范围内各有 128 个量化级。每根折线为一个区间,正负各 8 个区间。每个区间均匀量化成16 个量化电平。13 折线编码码位的安排按照极性码、段落码、段内码的顺序。A 律 PCM 编码规则:极性码段落码段内码 C1 C2C3C4 C5C6C7C8C1:极性码,1 为正;0 为负,表示信号的正负极;C2C3C4:段落码,表示信号绝对值处在 8 个区间中的哪个区间,为000111 共有 8 种组合,分别表示对应的8 个分段,即第1 至 8 段;C5C6C7C8:段内码,表示区间中的 16 个均匀量化级,00001111 共有 16 中组合,表示每段的 16 个分级。信道编码信道编码/译码译码信道编码的目的就是增强数字信号的抗干扰能力。数字信号在信道中传输容易受到噪声干扰,为了减少差错,我们对传输信息的码元按一定的规则加入保护成分(监督元),组成所谓的抗干扰编码。主要实现方法是增加冗余位。常见的纠错编码有线性分组码、循环码、卷积码等等。本课程采用了线性分组码中的典型编码方式(7,4)汉明码和(15,8)循环编码。程序(见附录)中这两种编码方式;对收到的信号还要进行译码,信道译码是信道编码的逆过程。数字调制数字调制/解调解调编码完成后的信息序列还不能再信道中传输,必须经过调制后才能发射出去,数字调制就是把数字基带信号的频谱搬移到高频处,形成适合在信道中传输的带通信号。对数字信号调制的方式有很多种,基本的调制方式有振幅键控(ASK)、频移键控(FSK)、绝对相移键控(PSK)、差分相移键控(DPSK)等,本课程设计中则采用的是振幅键控(ASK)。数字解调:在接收端可以采用相干解调或者非相干解调还原数字基带信号。性能分析性能分析 PCM 通信系统的主要参数设置信噪比(SNR)范围:dB=-25:5:25;信源模块:我们设定原始信号的幅值 A 为,频率 f 为 2KHZ;信源编码/译码:取样时间间隔t:,范围T 是;抽样频率fs=8K,抽样数量 n=100,进行非均匀量化。PCM 系统中噪声的影响PCM 系统的噪声主要有两种:量化噪声和加性噪声。在图 1 中的(t)m(t)nq(t)ne(t)PCM 系统的低通滤波器的输出信号为m其中m(t):接收端输出的信号成分;nq(t):由量化引起的输出噪声成分;ne(t):由信道加性噪声引起的输出噪声成分。S0E m2(t)N0N Nqe在接收端输出信号的总信噪比为Nq:量化噪声的平均功率;Ne:信道加性噪声的平均功率;(1)量化噪声对系统的影响PCM 系统输出端的量化信号与量化噪声的平均功率比为S0 M2Nq对于二进制编码,设其编码位数为 N,则上式又可写为S0 22NNq(2)加性噪声对系统的影响仅考虑信道加性噪声时 PCM 系统的输出信噪比为S01Nq4pe从上式可以看出,由于误码引起的信噪比与误码率成反比。(3)PCM 系统接收端输出信号的总信噪比S0E m2(t)M222NNqNq Ne14pe22N14pe22N在接收端输入大信噪比的情况下,误码率pe将极小,于是4pe22N1,所以总信噪比近似为S0 22N1Nq与只考虑量化噪声情况下的系统输出信噪比是相同的。在接收端输入小信噪比的情况下,有4pe22N1,则又可近似为S022N1与只考虑噪声干扰时系统的输出信噪比是相同的。Nq4pe22N4pe由于在基带传输时误码率降到以下是不难的,所以此时通常用式1来估算 PCM 系统的性能。MATLAB 仿真分析系统误码律系统误码率仿真图如图4:从仿真图可以看出,信噪比越大,误码率越低,与理论相符;还可以直观的看出误码率在有信道编码的情况下明显低于无信道编码的情况,尤其是当信噪比dB5时,有信道编码的系统的误码率几乎为0,其传输可靠性远好于无信道编码的情况;两种信道编码方式(7,4)汉明编码和(15,8)循环编码在此传输系统中,性能相当。由图可以得知通过信道编码可以增加通信系统的可靠性。图 7 系统误码率信噪比仿真曲线图4 4 心得体会心得体会设计给人以创作的冲动,在这学期的设计过程中,在收获知识的同时,还收获了阅历,收获了成熟,在此过程中,我们通过查找大量资料,不懈的努力,不仅培养了独立思考、动手操作的能力,在各种其它能力上也都有了提高。更重要的是,我们学会了很多学习的方法。而这是日后最实用的,真的是受益匪浅。要面对社会的挑战,只有不断的学习、实践,再学习、再实践。通过此次课程设计,更加扎实的掌握了有关的知识,在设计过程中虽然遇到了一些问题,但经过一次又一次的思考,检查找出了原因所在,也暴露出了我在这方面的知识的欠缺和经验的不足。实践出真知,通过亲自动手制作,使我们掌握的知识不再是纸上谈兵。在课程设计过程中,我们不断发现错误,不断改正,不断领悟,不断获取。在今后社会的发展和学习实践过程中,一定要不懈努力,不厌其烦的发现问题所在,然后一一进行解决,只有这样,才能成功的做成想做的事,才能在今后的道路上劈荆斩棘,收获成功,得到社会及他人的认可!参考资料参考资料1 黄吉顺.数字信号处理及其应用.北京:国防工业出版社,19822 邓华.MATLAB 通信仿真及应用实例详解M.北京:人民邮电大学出版社,2006 3 张贤达.现代数字信号处理.北京:清华大学出版社,19944 王世一.数字信号处理.北京:北京理工大学出版社,20105 赵静,张瑾.基于基于 MATLAB 的通信系统的仿真.北京:北京航空航天大学出版社,20076 郭文彬.通信原理基于 MATLAB 的计算机仿真M.北京:北京邮电大学出版社,20067 韩利竹,王华.MATLAB 电子仿真与应用M.北京:国防工业出版社,2003.8 刘卫国.MATLAB程序设计与应用M.北京:高等教育出版社,2006.9 丛玉良,王宏志.数字信号处理原理及其 MATLAB 实现M.北京:电子工业出版社,2005.附录附录实验程序实验程序clear allA=;f=2000;w=2*pi*f;%语音信号频率2K,幅值t=-0:y=A*sin(w*t);%语音信号figure(4)plot(t,y);xlabel(t);ylabel(A);legend(原始语音信号)n=1:100;%抽样的个数fs=8*103;T=1/fs;Y(n)=1;figure(5)stem(n,Y(n);axis(0 50 0 1);xlabel(n);ylabel(幅度);legend(抽样脉冲信号);n=1:100;fs=8*103;T=1/fs;s=A*sin(w*n*T);figure(1)stem(n,s);%时域抽样后的信号图axis(0 100-4 4);xlabel(n);ylabel(幅度);legend(时域抽样信号图);f=n./(100*T);y1=abs(fft(s);figure(2)plot(f,y1);xlabel(f);ylabel(幅频);legend(抽样信号频谱);s1=s./max(s);%归一化s2=s1./(1/2048);for i=1:100%c是pcm码100*8 y=s2(i);u=0 0 0 0 0 0 0 0 if(y0)%极值码判断 u(1)=1;else u(1)=0;endy=abs(y);if(y=0&y=16&y=32&y=64&y=128&y=256&y=512&y=1024&y=2048)u(2)=1;u(3)=1;u(4)=1;step=64;st=1024;endif(y=0)&(qq2=2)=3;qq2(find(qq2=-2)&(qq20)=-1;qq2(find(qq2=0)=1;rx1(find(rx1=0)=1;rx2(find(rx20)=0;c22=decode(rx1,7,4,hamming/binary);%hamming 信 道 译 码200*4 c33=decode(rx2,15,8,cyclic/binary);%循环译码 errors1=zeros(200,4);errors2=zeros(100,8);errors1(find(c22=c1)=1;%发现错误让其值为1 errors2(find(c33=c7)=1;%发现错误让其值为1 errors1=reshape(errors1,1,800);%把矩阵变成1行800列的矩阵 errors2=reshape(errors2,1,800);%把矩阵变成 1行800列的矩阵 biterrors1=sum(errors1);%统计错误 biterrors2=sum(errors2);%统计错误 errorbit(q)=biterrors1/(100*8);errorbit2(q)=biterrors2/(100*8);%误码率 endfigure(3)semilogy(dB,errorbit,:ro);holdsemilogy(dB,bit1,-bs);semilogy(dB,errorbit2,*);grid;legend(:ro汉明,-bs无信道编码,*循环码);xlabel(dB);ylabel(误码率);