1基于matlab环境下FSK的调制与解调的分析1引言MATLAB是由MATHWORKS公司于1984年推出的一种面向科学与工程的计算软件,通过MATLAB和相关工具箱,工程师、科研人员、数学家和教育工作者可以在统一的平台下完成相应的科学计算工作。MATLAB本身包含了600余个用于数学计算、统计和工程处理的函数,这样,就可以迅速完成科学计算任务而不必进行额外的开发。业内领先的工具箱算法极大的扩展了MATLAB的应用领域,所以MATLAB自推出以来就受到广泛的关注。MATLAB特点:一,数值计算功能,在MATLAB中,每个数值元素都视为复数,而且只有双精度(64位)一种数据格式,省去多种的设置,虽然在运行速度和内存消耗方面付出了代价,却使MATLAB的编程大大简化。MATLAB的数值计算基本功能包括:矩阵运算、多项式和有理分式计算、数据统计分析以及数值分析等。二,符号计算功能,在实际应用中,除了数值计算外,还需要得到方程的解析解,简化和展开多项式和函数表达,求解函数值等,所有这些均属于符号计算的领域。三,便栈式的编程语言,与Fortran和C等高级语言相比,MATLAB的语法规则更简单,更贴近人的思维方式和表达习惯,使得编写程序就像在便栈上列写公式和演算一样。四,强大而简易的作图功能,能根据输入数据自动确定坐标绘图。五,高智能化,绘图时自动选择最佳坐标,大大方便了用户。自动检测和显示程序错误,减轻编程和调试的工作量。六,丰富实用的工具箱,MATLAB软件包括基本部分和扩展部分。扩展部分成为工具箱。工具箱分为两类:功能性工具箱和学科性工具箱。功能性工具箱主要用来扩充其符号计算功能,可视建摸仿真功能以及文字处理功能等。学科性工具箱专业性比较强,如控制系统工具箱、信号处理工具箱、神经网络工具箱、最优化工具箱、金融工具箱、小波工具箱等。MATLAB6.x的集成环境,在Windos桌面,双击MATLAB图标,系统就会进入MATLAB6.x的工作环境。MATLAB6.x的集成环境由桌面平台以及组件组成。它包括8个组成部分:指令窗口、历史指令窗口、工作台及工具箱窗口、当前工作目录窗口、工作空间窗口、矩阵编辑器、程序编辑器和帮助浏览器。MATLAB帮助系统,MATLAB为用户提供了三种帮助功能:一.利用帮助菜单获取帮助信息。单击MATLAB工作窗口的菜单栏Help菜单项,弹出帮助菜单项。选择HelpWindow选项,可以打开MATLAB的主题窗口。选择HelpDesk选项,可以打开MATLAB帮助工作台。二.通过指令窗口获取帮助信息,用户可以在指令窗口直接键入帮助指令来获得帮助。三.使用演示功能(Demo)。MATLAB带有生动直观的演示程序,可以帮助用户形象直观地学习和理解MATLAB的使用方法和强大的功能。启动演示程序有下面几种方法:(一)在工作台和工具箱窗口中,列出了MATLAB和已经安装的各种工具箱。单击欲学习的工具箱前面的“+”号,在打开的功能项中,双击Demos,即可打开演示程序。(二)选择Help菜单Demos选项,可以打开MATLAB的演示窗口。(三)在指令窗口中键入指令demo,同样可以打开MATLAB演示窗口。FSK简介:FSK(Frequency-shiftkeying)-频移键控是利用载波的频率变化来传递数字信息。它是利用基带数字信号离散取值特点去键控载波频率以传递信息的一种数字调制技术FSK在matlab环境下过程与结果FSK的模拟仿真是采用的matlab软件,其在电脑运行环境如图3-1所示。实验过程是在窗口点击matlab快捷方式,使其运行,将FSK调制与解调的程序输入框中,点击回车即可运行,运行结果后面进行分析。在matlab环境下调制与解调的程序如下:(百分号后为程序注释)functionFSKFc=10;%载频Fs=40;%系统采样频率Fd=1;%码速率3N=Fs/Fd;df=10;numSymb=25;%进行仿真的信息代码个数M=2;%进制数SNRpBit=60;%信噪比SNR=SNRpBit/log2(M);seed=[1234554321];numPlot=15;%产生25个二进制随机码x=randsrc(numSymb,1,[0:M-1]);%产生25个二进制随机码figure(1)stem([0:numPlot-1],x(1:numPlot),'bx');title('二进制随机序列')xlabel('Time');ylabel('Amplitude');%调制y=dmod(x,Fc,Fd,Fs,'fsk',M,df);numModPlot=numPlot*Fs;t=[0:numModPlot-1]./Fs;figure(2)plot(t,y(1:length(t)),'b-');axis([min(t)max(t)-1.51.5]);title('调制后的信号')xlabel('Time');ylabel('Amplitude');%在已调信号中加入高斯白噪声randn('state',seed(2));y=awgn(y,SNR-10*log10(0.5)-10*log10(N),'measured',[],'dB');%在已调信号中加入高斯白噪声figure(3)plot(t,y(1:length(t)),'b-');%画出经过信道的实际信号axis([min(t)max(t)-1.51.5]);title('加入高斯白噪声后的已调信号')xlabel('Time');ylabel('Amplitude');%相干解调figure(4)z1=ddemod(y,Fc,Fd,Fs,'fsk/eye',M,df);title('相干解调后的信号的眼图')%带输出波形的相干M元频移键控解调figure(5)stem([0:numPlot-1],x(1:numPlot),'bx');holdon;stem([0:numPlot-1],z1(1:numPlot),'ro');holdoff;axis([0numPlot-0.51.5]);title('相干解调后的信号原序列比较')legend('原输入二进制随机序列','相干解调后的信号')xlabel('Time');ylabel('Amplitude');%非相干解调figure(6)z2=ddemod(y,Fc,Fd,Fs,'fsk/eye/noncoh',M,df);title('非相干解调后的信号的眼图')%带输出波形的非相干M元频移键控解调figure(7)stem([0:numPlot-1],x(1:numPlot),'bx');holdon;stem([0:numPlot-1],z2(1:numPlot),'ro');holdoff;axis([0numPlot-0.51.5]);title('非相干解调后的信号')legend('原输入二进制随机序列','非相干解调后的信号')xlabel('Time');ylabel('Amplitude');%误码率统计5[errorSymratioSym]=symerr(x,z1);figure(8)simbasebandex([0:1:5]);title('相干解调后误码率统计')[errorSymratioSym]=symerr(x,z2);figure(9)simbasebandex([0:1:5]);title('非相干解调后误码率统计')%滤除高斯白噪声Delay=3;R=0.5;PropD=0;%滞后3s程序的运行过程是:首先产生25个随机序列码(如图3-2所示注:此序列为随机序列,每一次运行程序所产生的序列都不同),然后通过调用函数对该序列进行调制(如图3-3所示)。在调制信号中加入高斯白噪声(如图3-4所示)。在通过调用函数让函数通过相干解调方式进行解调,解调信号(如图3-5所示)。在通过调用函数让调制信号图3-2图3-3图3-4图3-5通过非相干解调方式进行解调,解调信号(如图3-6所示)。图3-7是相干解调后的误码率统计,图3-8是非相干解调的误码率统计。图3-6图3-7图3-87(注释:图3-7,图3-8中右上角的意思为,TheoreticalSER理论软件错误率;TheoreticalBER理论二进制误码率;SimulatedSER模拟软件错误率;SimulatedBER模拟二进制误码率。)FSK在matlab环境下实验的优劣优点:(1)调制信号和载频都具有随机性,而且具有在课堂演示的功能。(2)实验程序已经编好,不易发生故障,多会都可进行。(3)进行了相干解调和非相干解调两种方式的比较,(4)解调后对相干解调和非相干解调的误码率统计缺点:(1)不能通过实验操作调试出实验结果。(2)前期编程和数学建模工作也比较复杂。