msk的调制解调MATLAB源代码

合集下载

qpsk调制 matlab代码

qpsk调制 matlab代码

QPSK(Quadrature Phase Shift Keying)调制是一种常用的数字调制方式,它使用4个相互正交的相位来表示数字信号,从而实现信号的传输和识别。

在无线通信、数字通信和数字电视等领域都有着广泛的应用。

在本文中,我们将使用Matlab编写QPSK调制的代码,以帮助读者更好地理解QPSK调制的原理和实现。

1. QPSK调制简介QPSK调制是一种常用的相位调制方式,它将两路独立的数据流分别调制到正交的载波上,实现了频谱的高效利用和传输速率的提高。

QPSK调制共有4种状态,分别是0°、90°、180°、270°,对应的二进制数据为00、01、10、11。

通过改变相位来表示不同的数字信号,QPSK调制在噪声干扰下具有一定的抗干扰能力,因此在实际应用中得到了广泛的应用。

2. Matlab实现QPSK调制在Matlab中,我们可以利用其强大的信号处理工具箱实现QPSK调制的模拟,并通过仿真结果来验证QPSK调制的正确性。

以下是实现QPSK调制的Matlab代码:```matlab设置参数fc = 1000; 载波频率fs = 0; 采样频率T = 1; 信号持续时间t = 0:1/fs:T-1/fs; 时间序列data = randi([0 1],1,100); 随机生成100个二进制数据数据映射为QPSK调制信号data_I = 2*data(1:2:end)-1; I路数据data_Q = 2*data(2:2:end)-1; Q路数据s = (data_I + 1i*data_Q).*exp(1i*2*pi*fc*t); QPSK调制信号显示QPSK调制信号subplot(211)plot(t,real(s))title('QPSK调制信号-I路')xlabel('时间')ylabel('幅度')subplot(212)plot(t,imag(s))title('QPSK调制信号-Q路')xlabel('时间')ylabel('幅度')```在上述代码中,我们首先设置了载波频率fc、采样频率fs、信号持续时间T和时间序列t,然后随机生成了100个二进制数据,并分别将其映射到I路和Q路数据中。

MSK调制及相干解调实验

MSK调制及相干解调实验

实验四 MSK调制及相干解调实验一、实验目的和要求1、了解MSK调制原理及特性2、了解MSK解调原理及特性3、了解载波在相干及非相干时的解调特性二、实验内容和原理1)、实验内容1、观察I、Q两路基带信号的特征及与输入NRZ码的关系。

2、观察IQ调制解调过程中各信号变化。

3、观察解调载波相干时和非相干时各信号的区别。

2)、基本原理1、MSK调制原理MSK称为最小移频键控调制,是一种恒包络调制,这是因为MSK属于二进制连续相位移频键控(CPFSK)的一种特殊情况,它不存在相位跃变点,因此在带限系统中,能保持恒包络特性。

恒包络调制有以下优点:极低的旁瓣能量;可使用高效率的C类功率放大器;容易恢复用于相干解调的载波;已调信号峰平比低。

MSK是CPFSK满足移频系数时的特例:当时,满足在码元交替点相位连续的条件,是移频键控为保证良好的误码性能所允许的最小调制指数;且此时波形的相关性为0,待传送的两个信号是正交的。

它能比PSK传送更高的比特速率。

二进制MSK信号的表达式可写为:或者这里——载波角频率;——码元宽度;——第k个码元中的信息,其取值为±1;——第k个码元的相位常数,它在时间中保持不变由式(4-1)可见,当ak=+1时,信号的频率为当ak=+1时,信号的频率为由此可得频率间隔为如图4-1(a)所示,由图4-1(b)中的波形可以看出,“+”信号与“-”信号在一个码元期间恰好相差二分之一周,即相差π。

下面我们就来说明MSK信号的频率间隔是如何确定的。

对于一般移频键控(2FSK),两个信号波形具有以下的相关系数式中,是载波频率。

MSK是一种正交调制,其信号的波形的相关系数等于零。

因此,对MSK信号来说,式(4-7)应为零,也就是上式右边两项均应为零。

第一项等于零的条件是(k=1,2,3…),令k等于其最小值1,则图4-1 MSK信号的频率间隔与波形这正是MSK信号所要求的频率间隔。

第二项等于零的条件是(n=1,2,3…),即这说明,MSK信号在每一个码元周期内,必须包含四分之一载波周期的整数倍。

基于MATLAB的GMSK调制解调实验

基于MATLAB的GMSK调制解调实验

本科课程设计说明书题目:基于Matlab的GMSK调制与解调院(部):信息与电气工程学院专业:通信工程班级:姓名:学号:指导教师:完成日期:目录摘要 (Ⅱ)第1章绪论 (1)第2章 GMSK调制与解调系统 (2)2.1 GMSK系统的介绍 (2)2.2 GMSK系统的设计原理 (2)2.2.1 GMSK调制原理 (3)2.2.2 GMSK解调原理 (4)第3章 GMSK系统功能模块设计与结果分析 (5)3.1 GMSK系统的功能模块设计 (5)3.1.1 信号发生模块 (5)3.1.2 调制与解调模块 (7)3.1.3 误码率计算模块 (9)3.1.4 波形观察模块 (10)3.2 GMSK系统结果分析 (15)3.2.1 GMSK调制与解调波形 (15)3.2.2 GMSK调制信号眼图 (17)第4章结论 (19)参考文献 (20)附录一:程序附录二:建模图摘要高斯滤波最小频移键控(GMSK)系统的特点是在MSK(最小移频键控)调制器之前插入高斯低通预调制滤波器进行预调制滤波,因此GSMK调制的信号频谱紧凑、误码特性好,在数字移动通信中得到了广泛使用,如现在广泛使用的GSM(Global System for Mobile communication)移动通信体制就是使用GMSK 调制方式。

本文主要在瑞利信道下,通过在Matlab中的Simulink建立仿真模型进行仿真研究。

并通过观察GMSK系统调制、解调信号的的波形、频谱图、眼图和误码率曲线,从而验证GMSK系统较为良好的性能。

关键词:GMSK,瑞利信道,SimuLink仿真,误码率曲线第1章设计要求1.1 设计内容:学习GMSK系统的传输原理,并使用Simulink搭建GMSK系统的调制与解调模块,利用高斯信道模块来模拟信号传输仿真,用示波器观察各点波形,通过与理论波形的对比,验证电路的正确性。

1.2 设计要求:1. 观察基带信号和解调信号波形;2. 观察已调信号频谱图3.分析调制性能和BT参数的关系。

msk调制与解调

msk调制与解调

msk调制与解调引言:在现代通信系统中,调制和解调是基本的信号处理技术。

而在调制和解调的方法中,最常用的之一就是Minimum Shift Keying (MSK)调制和解调技术。

本文将深入探讨MSK调制与解调的原理、特点以及应用。

一、MSK调制的原理MSK调制是一种连续相位调制技术,其基本原理是通过改变载波的相位来传输数字信号。

MSK调制的关键在于选择合适的载波频率和相位变化规律。

1.1 载波频率选择在MSK调制中,载波的频率应该满足一定的条件,即与数据速率相等或是其整数倍。

这样可以确保每个数据比特对应一个载波周期,避免信息的混叠和交叠。

1.2 相位变化规律MSK调制的特点之一是相位变化为连续的线性函数,即相位在每个符号周期内以恒定的速率线性变化。

这种相位变化规律使得MSK信号的频谱特性更加优良,有利于抗干扰和传输性能的提高。

二、MSK调制的特点MSK调制具有许多优点,使其成为现代通信系统中广泛使用的调制技术。

2.1 频谱效率高由于MSK调制的相位变化规律为线性连续变化,其频谱特性非常优秀。

相邻的频带之间没有交叠,使得频谱利用率更高,频谱效率更大。

2.2 抗多径衰落能力强MSK调制对于多径衰落的抗干扰能力较强,能够有效地抑制多径衰落引起的码间干扰,提高信号的传输质量。

2.3 抗相位偏移干扰由于MSK调制的相位变化规律为线性连续变化,相位偏移对于信号的影响较小。

因此,MSK调制对于相位偏移干扰具有较好的抗干扰能力。

三、MSK解调的原理MSK解调是将调制信号还原为原始数字信号的过程,其原理与调制相对应。

3.1 相干解调相干解调是MSK解调的一种常用方法。

它通过与接收信号进行相干检测,提取出信号的相位信息,从而实现解调。

3.2 频率鉴别解调频率鉴别解调是另一种常见的MSK解调方法。

它通过对接收信号的频率进行鉴别,来实现解调。

四、MSK的应用MSK调制与解调技术在许多通信系统中被广泛应用。

4.1 无线通信系统在无线通信系统中,MSK调制与解调技术被广泛应用于GSM、CDMA等数字通信系统中,以提高信号的传输质量和抗干扰能力。

基于matlab的数字信号调制与解调

基于matlab的数字信号调制与解调

基于matlab的数字信号调制与解调一matlab常用函数1、特殊变量与常数ans 计算结果的变量名computer 确定运行的计算机eps 浮点相对精度Inf 无穷大I 虚数单位inputname 输入参数名NaN 非数nargin 输入参数个数nargout 输出参数的数目pi 圆周率nargoutchk 有效的输出参数数目realmax 最大正浮点数realmin 最小正浮点数varargin 实际输入的参量varargout 实际返回的参量操作符与特殊字符+ 加- 减* 矩阵乘法 .* 数组乘(对应元素相乘)^ 矩阵幂 .^ 数组幂(各个元素求幂)\ 左除或反斜杠/ 右除或斜面杠 ./ 数组除(对应元素除)kron Kronecker张量积: 冒号() 圆括[] 方括 . 小数点 .. 父目录 ... 继续, 逗号(分割多条命令); 分号(禁止结果显示)% 注释! 感叹号' 转置或引用= 赋值== 相等<> 不等于& 逻辑与| 逻辑或~ 逻辑非xor 逻辑异或2、基本数学函数abs 绝对值和复数模长acos,acodh 反余弦,反双曲余弦acot,acoth 反余切,反双曲余切acsc,acsch 反余割,反双曲余割angle 相角asec,asech 反正割,反双曲正割secant 正切asin,asinh 反正弦,反双曲正弦atan,atanh 反正切,双曲正切tangent 正切atan2 四象限反正切ceil 向着无穷大舍入complex 建立一个复数conj 复数配对cos,cosh 余弦,双曲余弦csc,csch 余切,双曲余切cot,coth 余切,双曲余切exp 指数fix 朝0方向取整floor 朝负无穷取整*** 最大公因数imag 复数值的虚部lcm 最小公倍数log 自然对数log2 以2为底的对数log10 常用对数mod 有符号的求余nchoosek 二项式系数和全部组合数real 复数的实部rem 相除后求余round 取整为最近的整数sec,sech 正割,双曲正割sign 符号数sin,sinh 正弦,双曲正弦sqrt 平方根tan,tanh 正切,双曲正切3、基本矩阵和矩阵操作blkding 从输入参量建立块对角矩阵eye 单位矩阵linespace 产生线性间隔的向量logspace 产生对数间隔的向量numel 元素个数ones 产生全为1的数组rand 均匀颁随机数和数组randn 正态分布随机数和数组zeros 建立一个全0矩阵colon) 等间隔向量cat 连接数组diag 对角矩阵和矩阵对角线fliplr 从左自右翻转矩阵flipud 从上到下翻转矩阵repmat 复制一个数组reshape 改造矩阵roy90 矩阵翻转90度tril 矩阵的下三角triu 矩阵的上三角dot 向量点集cross 向量叉集ismember 检测一个集合的元素intersect 向量的交集setxor 向量异或集setdiff 向是的差集union 向量的并集数值分析和傅立叶变换cumprod 累积cumsum 累加cumtrapz 累计梯形法计算数值微分factor 质因子inpolygon 删除多边形区域内的点max 最大值mean 数组的均值mediam 中值min 最小值perms 所有可能的转换polyarea 多边形区域primes 生成质数列表prod 数组元素的乘积rectint 矩形交集区域sort 按升序排列矩阵元素sortrows 按升序排列行std 标准偏差sum 求和trapz 梯形数值积分var 方差del2 离散拉普拉斯diff 差值和微分估计gradient 数值梯度cov 协方差矩阵corrcoef 相关系数conv2 二维卷积conv 卷积和多项式乘法filter IIR或FIR滤波器deconv 反卷积和多项式除法filter2 二维数字滤波器cplxpair 将复数值分类为共轭对fft 一维的快速傅立叶变换fft2 二维快速傅立叶变换fftshift 将FFT的DC分量移到频谱中心ifft 一维快速反傅立叶变换ifft2 二维傅立叶反变换ifftn 多维快速傅立叶变换ifftshift 反FFT偏移nextpow2 最靠近的2的幂次unwrap 校正相位角多项式与插值conv 卷积和多项式乘法roots 多项式的根poly 具有设定根的多项式polyder 多项式微分polyeig 多项式的特征根polyfit 多项式拟合polyint 解析多项式积分polyval 多项式求值polyvalm 矩阵变量多项式求值residue 部分分式展开interp1 一维插值interp2 二维插值interp3 三维插值interpft 使用FFT的一维插值interpn 多维插值meshgrid 为3维点生成x和y的网格ndgrid 生成多维函数和插值的数组pchip 分段3次Hermite 插值多项式ppval 分段多项式的值spline 3次样条数据插值绘图函数bar 竖直条图barh 水平条图hist 直方图histc 直方图计数hold 保持当前图形loglog x,y对数坐标图pie 饼状图plot 绘二维图polar 极坐标图semilogy y轴对数坐标图semilogx x轴对数坐标subplot 绘制子图bar3 数值3D竖条图bar3h 水平3D条形图comet3 3D 慧星图cylinder 圆柱体fill3 填充的3D多边形plot3 3维空间绘图quiver3 3D震动(速度)图slice 体积薄片图sphere球stem3 绘制离散表面数据wate***ll 绘制瀑布trisurf三角表面clabel 增加轮廓标签到等高线图中datetick 数据格式标记grid 加网格线gtext 用鼠标将文本放在2D图中legend 图注plotyy 左右边都绘Y轴title 标题xlabel X轴标签ylabel Y轴标签zlabel Z轴标签contour 等高线图contourc 等高线计算contourf 填充的等高线图hidden 网格线消影meshc 连接网格/等高线mesh 具有参考轴的3D网格peaks 具有两个变量的采样函数surf 3D阴影表面图su***ce 建立表面低层对象surfc 海浪和等高线的结合surfl 具有光照的3D阴影表面trimesh 三角网格图二Matlab常用指令1、通用信息查询(General information)demo 演示程序help 在线帮助指令helpbrowser 超文本文档帮助信息helpdesk 超文本文档帮助信息helpwin 打开在线帮助窗info MATLAB 和MathWorks 公司的信息subscribe MATLAB 用户注册ver MATLAB 和TOOLBOX 的版本信息version MATLAB 版本whatsnew 显示版本新特征2、工作空间管理(Managing the workspace)clear 从内存中清除变量和函数exit 关闭MATLAB load 从磁盘中调入数据变量pack 合并工作内存中的碎块quit 退出MATLAB save 把内存变量存入磁盘who 列出工作内存中的变量名whos 列出工作内存中的变量细节workspace 工作内存浏览器3 、管理指令和函数(Managing commands and functions)edit 矩阵编辑器edit 打开M 文件inmem 查看内存中的P 码文件mex 创建MEX 文件open 打开文件pcode 生成P 码文件type 显示文件内容what 列出当前目录上的M、MAT、MEX 文件which 确定指定函数和文件的位置4 、搜索路径的管理(Managing the seach patli)addpath 添加搜索路径rmpath 从搜索路径中删除目录path 控制MATLAB 的搜索路径pathtool 修改搜索路径5、指令窗控制(Controlling the command window)beep 产生beep 声echo 显示命令文件指令的切换开关diary 储存MATLAB 指令窗操作内容format 设置数据输出格式more 命令窗口分页输出的控制开关6、操作系统指令(Operating system commands)cd 改变当前工作目录computer 计算机类型copyfile 文件拷贝delete 删除文件dir 列出的文件dos 执行dos 指令并返还结果getenv 给出环境值ispc MATLAB 为PC(Windows)版本则为真isunix MATLAB 为Unix 版本则为真mkdir 创建目录pwd 改变当前工作目录unix 执行unix 指令并返还结果vms 执行vms dcl 指令并返还结果web 打开web 浏览器! 执行外部应用程序三Matlab运算符和特殊算符1、算术运算符(Arithmetic operators)+ 加- 减* 矩阵乘 .* 数组乘^ 矩阵乘方 .^ 数组乘方\ 反斜杠或左除/ 斜杠或右除 ./或.\ 数组除张量积[注]本表第三栏括号中的字符供在线救助时help 指令引述用2、关系运算符(Relational operators)= = 等号~= 不等号< 小于> 大于<= 小于或等于>= 大于或等于3、逻辑操作(Logical operators)& 逻辑与| 逻辑或~ 逻辑非xor 异或any 有非零元则为真all 所有元素均非零则为真4、特殊算符(Special characters):冒号( ) 圆括号[ ] 方括号{ } 花括号@ 创建函数句柄 . 小数点 . 构架域的关节点 .. 父目录? 续行号, 逗号; 分号% 注释号! 调用操作系统命令= 赋值符号ˊ引号ˊ复数转置号.ˊ转置号[,] 水平串接[;] 垂直串接( ),{ },. 下标赋值( ),{ },. 下标标识subsindex 下标标识四Matlab编程语言结构控制语句(Control flow)break 终止最内循环case 同switch 一起使用catch 同try 一起使用continue 将控制转交给外层的for 或while 循环else 同if 一起使用elseif 同if 一起使用end 结束for,while,if 语句for 按规定次数重复执行语句if 条件执行语句otherwise 可同switch 一起使用return 返回switch 多个条件分支try try-cathch 结构while 不确定次数重复执行语句2、计算运行(Evaluation and execution)assignin 跨空间赋值builtin 执行内建的函数eval 字符串宏指令evalc 执行MATLAB 字符串evalin 跨空间计算串表达式的值feval 函数宏指令run 执行脚本文件3、脚本文件、函数及变量(Scripts,function,and variables)exist 检查变量或函数是否被定义function 函数文件头global 定义全局变量isglobal 若是全局变量则为真iskeyword 若是关键字则为真mfilename 正在执行的M 文件的名字persistent 定义永久变量script MATLAB 命令文件4、宗量处理(Augument handling)inputname 实际调用变量名nargchk 输入变量个数检查nargin 函数输入宗量的个数nargout 函数输出宗量的个数nargoutchk 输出变量个数检查varagin 输入宗量varagout 输出宗量5、信息显示(Message display)disp 显示矩阵和文字内容display 显示矩阵和文字内容的重载函数error 显示错误信息fprintf 把格式化数据写到文件或屏幕lasterr 最后一个错误信息lastwarn 最后一个警告信息sprintf 按格式把数字转换为串warning 显示警告信息6 、交互式输入(Interactive input) input 提示键盘输入keyboard 激活键盘做为命令文件pause 暂停uicontrol 创建用户界面控制uimenu 创建用户界面菜单五Matlab基本矩阵函数和操作1、基本矩阵(Elementary matrices)eye 单位阵linspace 线性等分向量logspace 对数等分向量meshgrid用于三维曲面的分格线坐标ones 全1 矩阵rand 均匀分布随机阵randn 正态分布随机阵repmat 铺放模块数组zeros 全零矩阵: 矩阵的援引和重排2、矩阵基本信息(Basic array information)disp 显示矩阵和文字内容isempty 若是空矩阵则为真isequal 若对应元素相等则为1 islogical 尤其是逻辑数则为真isnumeric 若是数值则为真length 确定向量的长度logical 将数值转化为逻辑值ndims 数组A的维数size 确定矩阵的维数3、矩阵操作(Matrix manipulateion)blkdiag 块对角阵串接diag 创建对角阵,抽取对角向量end 数组的长度,即最大下标find 找出非零元素1 的下标fliplr 矩阵的左右翻转flipud 矩阵的上下翻转flipdim 交换对称位置上的元素ind2sub 据单下标换算出全下标reshape 矩阵变维rot90 矩阵逆时针90°旋转sub2idn 据全下标换算出单下标tril 抽取下三角阵triu 抽取上三角阵4、特殊变量和常数(Special variables and constants)ans 最新表达式的运算结果eps 浮点相对误差i,j 虚数单位inf 或Inf 无穷大isfinite 若是有限数则为真isinf 若是无穷大则为真isnan 若为非数则为真NaN 或nan 非数pi 3.1415926535897?. realmax 最大浮点数realmin 最小正浮点数why 一般问题的简明答案5、特殊矩阵(Specialized matrices)compan 伴随矩阵gallery 一些小测试矩阵hadamard Hadamard 矩阵hankel Hankel 矩阵hilb Hilbert 矩阵invhilb 逆Hilbert 矩阵magic 魔方阵pascal Pascal 矩阵rosser 典型对称特征值实验问题toeplitz Toeplitz 矩阵vander Vandermonde 矩阵wilkinson Wilkinson's 对称特征值实验矩阵六Matlab基本数学函数1、三角函数(Trigonometric)acos 反余弦acosh 反双曲余弦acot 反余切acoth 反双曲余切acsc 反余割acsch 反双曲余割asec 反正割asech 反双曲正割asin 反正弦asinh 反双曲正弦atan 反正切atanh 反双曲正切atan2四象限反正切cos 余弦cosh 双曲余弦cot 余切coth 双曲余切csc 余割csch 双曲余割sec 正割sech 双曲正割sin 正弦sinh 双曲正弦tan 正切tanh 双曲正切2、指数函数(Exponential)exp 指数log 自然对数log10 常用对数log2 以2 为底的对数nestpow2 最近邻的2 的幂pow2 2 的幂sqrt 平方根3、复数函数(Complex)abs 绝对值angle 相角complex 将实部和虚部构成复数conj 复数共轭cplxpair 复数阵成共轭对形式排列imag 复数虚部isreal 若是实数矩阵则为真real 复数实部unwrap 相位角360°线调整4、圆整和求余函数(Rounding and remainder)ceil 朝正无穷大方向取整fix 朝零方向取整floor 朝负无穷大方向取整mod 模数求余rem 求余数round 四舍五入取整sign 符号函数 6 特殊函数(Specialized math functions) cart2pol 直角坐标变为柱(或极)坐标cart2sph 直角坐标变为球坐标cross 向量叉积dot 向量内积isprime 若是质数则为真pol2cart 柱(或极)坐标变为直角坐标sph2cart 球坐标变为直角坐标七Matlab矩阵函数和数值线性代数1、矩阵分析(Matrix analysis)det 行列式的值norm 矩阵或向量范数normest 估计2 范数null 零空间orth 值空间rank 秩rref 转换为行阶梯形trace迹subspace 子空间的角度2、线性方程(Linear equations)chol Cholesky 分解cholinc 不完全Cholesky 分解cond 矩阵条件数condest 估计1-范数条件数inv 矩阵的逆lu LU 分解luinc 不完全LU 分解lscov 已知协方差的最小二乘积nnls 非负二乘解pinv 伪逆qr QR 分解rcond LINPACK 逆条件数\、/ 解线性方程3、特性值与奇异值(Eigenvalues and singular values)condeig 矩阵各特征值的条件数eig 矩阵特征值和特征向量eigs 多个特征值gsvd 归一化奇异值分解hess Hessenberg 矩阵poly 特征多项式polyeig 多项式特征值问题qz 广义特征值schur Schur 分解svd 奇异值分解svds 多个奇异值4、矩阵函数(Matrix functions)expm 矩阵指数expm1 矩阵指数的Pade 逼近expm2 用泰勒级数求矩阵指数expm3 通过特征值和特征向量求矩阵指数funm 计算一般矩阵函数logm 矩阵对数sqrtm 矩阵平方根5、因式分解(Factorization utility)cdf2rdf 复数对角型转换到实块对角型balance 改善特征值精度的平衡刻度rsf2csf 实块对角型转换到复数对角型八数据分析和傅里叶变换1、基本运算(Basic operations)cumprod 元素累计积cumsum 元素累计和cumtrapz 累计积分hist 统计频数直方图histc 直方图统计max 最大值mean 平均值median 中值min 最小值prod 元素积sort 由小到大排序sortrows 由小到大按行排序std 标准差sum 元素和trapz 梯形数值积分var 求方差2、有限差分(Finite differentces)del2 五点离散Laplacian diff 差分和近似微分gradient 梯度3、相关(Correlation)corrcoef 相关系数cov 协方差矩阵subspace 子空间之间的角度4、滤波和卷积(Filtering and convoluteion)conv 卷积和多项式相乘conv2 二维卷积convn N 维卷积detrend 去除线性分量deconv 解卷和多项式相除filter 一维数字滤波器fliter2 二维数字滤波器5、傅里叶变换(Fourier transforms)fft 快速离散傅里叶变换fft2 二维离散傅里叶变换fftn N 维离散傅里叶变换fftshift 重排fft 和fft2 的输出ifft 离散傅里叶反变换ifft2 二维离散傅城叶反变换ifftn N 维离散傅里叶反变换ifftshift 反fftshift 九音频支持1、音频硬件驱动(Audio hardware drivers)sound 播放向量soundsc 自动标刻并播放waveplay 利用系统音频输出设配播放waverecor 利用系统音频输入设配录音2、音频文件输入输出(Audio file import and export)auread 读取音频文件(.au) auwrite 创建音频文件(.au) wavread 读取音频文件(.wav) wavwrite 创建音频文件(.wav)3、工具(Utilities)lin2mu 将线性信号转换为μ 一律编码的信号mu2lin 将μ 一律编码信号转换为线性信号十插补多项式函数1、数据插补(Data Interpolation)griddata 分格点数据griddata3 三维分格点数据griddatan 多维分格点数据interpft 利用FFT 方法一维插补interp1 一维插补interp1q 快速一维插补interp2 二维插补interp3 三维插补intern N 维插补pchip hermite 插补2 、样条插补(Spline Interpolation)ppval 计算分段多项式spline 三次样条插补3 、多项式(Polynomials)conv 多项式相乘deconv 多项式相除poly 由根创建多项式polyder多项式微分polyfit 多项式拟合polyint 积分多项式分析polyval 求多项式的值polyvalm 求矩阵多项式的值residue 求部分分式表达roots 求多项式的根十一数值泛函函数和ODE 解算器1、优化和寻根(Optimization and root finding)fminbnd 非线性函数在某区间中极小值fminsearch 单纯形法求多元函数极值点指令fzero 单变量函数的零点2、优化选项处理(Optimization Option handling)optimget 从OPTIONS 构架中取得优化参数optimset 创建或修改OPTIONS 构架3、数值积分(Numerical intergration)dblquad 二重(闭型)数值积分指令quad 低阶法数值积分quadl 高阶法数值积分4、绘图(Plotting)ezcontour 画等位线ezcontourf 画填色等位线ezmesh 绘制网格图ezmeshc 绘制含等高线的网格图ezplot 绘制曲线ezplot3 绘制3 维曲线ezpolar 采用极坐标绘图ezsurf 画曲面图ezsurfc 画带等位线的曲面图fplot 画函数曲线图5、内联函数对象(Inline function object)argnames 给出函数的输入宗量char 创建字符传输组或者将其他类型变量转化为字符串数组formula 函数公式inline 创建内联函数6、差微分函数解算器(Differential equation solvers)ode113 变阶法解方程ode15s 变阶法解刚性方程ode23 低阶法解微分方程ode23s 低阶法解刚性微分方程ode23t 解适度刚性微分方程odet23tb 低阶法解刚性微分方程ode45 高阶法解微分方程十二二维图形函数1、基本平面图形(Elementary X-Y graphs)loglog 双对数刻度曲线plot 直角坐标下线性刻度曲线plotyy 双纵坐标图polar 极坐标曲线图semilogx X 轴半对数刻度曲线semilogy Y 轴半对数刻度曲线2 、轴控制(Axis control)axes 创建轴axis 轴的刻度和表现box 坐标形式在封闭式和开启词式之间切换grid 画坐标网格线hold 图形的保持subplot 创建子图zoom 二维图形的变焦放大3、图形注释(Graph annotation)gtext 用鼠标在图上标注文字legend 图例说明plotedit 图形编辑工具text 在图上标注文字texlabel 将字符串转换为Tex 格式title 图形标题xlabel X 轴名标注ylabel Y 轴名标注4、硬拷贝(Hardcopy and printing)orient 设置走纸方向print 打印图形或把图存入文件printopt 打印机设置十三三维图形函数1、基本三维图形(Elementary 3-D plots) fill3 三维曲面多边形填色mesh 三维网线图plot3 三维直角坐标曲线图surf 三维表面图2 、色彩控制(Color control)alpha 透明色控制brighten 控制色彩的明暗caxis (伪)颜色轴刻度colordef 用色风格colormap 设置色图graymon 设置缺省图形窗口为单色显示屏hidden 消隐shading 图形渲染模式whitebg 设置图形窗口为白底3、光照模式(Lighting)diffuse 漫反射表面系数light 灯光控制lighting 设置照明模式material 使用预定义反射模式specular 漫反射surfnorm 表面图的法线surfl 带光照的三维表面图4 、色图(Color maps)autumn 红、黄浓淡色bone 蓝色调灰度图colorcube 三浓淡多彩交错色cool 青和品红浓淡色图copper 线性变化纯铜色调图flag 红-白-蓝黑交错色图gray 线性灰度hot 黑-红-黄-白交错色图hsv 饱和色彩图jet 变异HSV 色图lines 采用plot 绘线色pink 淡粉红色图prism 光谱色图spring 青、黄浓淡色summer 绿、黄浓淡色vga 16 色white 全白色winter 蓝、绿浓淡色5、轴的控制(Axis control)axes 创建轴axis 轴的刻度和表现box 坐标形式在封闭式和开启式之间切换daspect 轴的DataAspectRatio 属性grid 画坐标网格线hold 图形的保持pbaspect 画坐标框的PlotBoxAspectRatio 属性subplot 创建子图xlim X 轴范围ylim Y 轴范围zlim Z 轴范围zoom 二维图形的变焦放大6、视角控制(Viewpoint control)rotate3d 旋动三维图形view 设定3-D 图形观测点viewmtx 观测点转换矩阵7、图形注释(Graph annotation)colorbar 显示色条gtext 用鼠标在图上标注文字plotedit 图形编辑工具text 在图上标注文字title 图形标题xlabel X 轴名标注ylabel Y 轴名标注zlabel Z 轴名标注8 、硬拷贝(Hardcopy and printing)orient 设置走纸方向print 打印图形或把图存入文件printopt 打印机设置verml 将图形保存为VRML2.0 文件十四特殊图形1、特殊平面图形(Specialized 2-D graphs)area 面域图bar 直方图barh 水平直方图comet 彗星状轨迹图compass 从原点出发的复数向量图errorbar 误差棒棒图ezplot 画二维曲线ezpolar 画极坐标曲线feather 从X 轴出发的复数向量图fill 多边填色图fplot 函数曲线图hist 统计频数直方图pareto Pareto图pie 饼形统计图plotmatrix 散点图阵列scatter 散点图stairs 阶梯形曲线图stem 火柴杆图2 、等高线及二维半图形(Contour and 2-1/2D graphs)clabel 给等高线加标注contour 等高线图contourf 等高线图contour3 三维等高线ezcontour 画等位线ezcontourf 画填色等位线pcolor 用颜色反映数据的伪色图voronoi Voronoi 图3、特殊三维图形(Specialized 3-D graphs)bar3 三维直方图bar3h 三维水平直方图comet3 三维彗星动态轨迹线图ezgraph3 通用指令ezmesh 画网线图ezmeshc 画等位线的网线图ezplot3 画三维曲线ezsurf 画曲面图ezsurfc 画带等位线的曲面图meshc 带等高线的三维网线图meshz 带零基准面的三维网线图pie3 三维饼图ribbon 以三维形式绘制二维曲线scatter3 三维散点图stem3 三维离散杆图surfc 带等高线的三维表面图trimesh 三角剖分网线图trisurf 三角剖分曲面图waterfall 瀑布水线图4、内剖及向量视图(Volume and vector visualization)coneplot 锥体图contourslice 切片等位线图quiver 矢量场图quiver3 三维方向箭头图slice 切片图5、图像显示及文件处理(Image display and file I/O)brighten 控制色彩的明暗colorbar 色彩条状图colormap 设置色图contrast 提高图像对比度的灰色图gray 线性灰度image 显示图像imagesc 显示亮度图像imfinfo 获取图像文件的特征数据imread 从文件读取图像的数据阵(和伴随色图))imwrite 把强度图像或真彩图像写入文件6、影片和动画(Movies and animation)capture 当前图的屏捕捉frame2im 将影片动画转换为编址图像getframe 获得影片动画图像的帧im2frame 将编址图像转换为影片动画movie 播放影片动画moviein 影片动画内存初始化rotate 旋转指令7、颜色相关函数(Color related function)spinmap 颜色周期性变化操纵8、三维模型函数(Solid modeling)cylinder 圆柱面patch 创建块sphere 球面Surf2patch 将曲面数据转换为块数据十五句柄图形1、图形窗的产生和控制(Figure window creation and control)clf 清除当前图close 关闭图形figure 打开或创建图形窗口gcf 获得当前图的柄openfig 打开图形refresh 刷新图形shg 显示图形窗2、轴的产生和控制(Axis creation and control)axes 在任意位置创建轴axis 轴的控制box 坐标形式在封闭式和开启式之间切换caxis 控制色轴的刻度cla 清除当前轴gca 获得当前轴的柄hold 图形的保持ishold 若图形处保持状态则为真subplot 创建子图3、句柄图形对象(Handle Graphics objects)axex 在任意位置创建轴figure 创建图形窗口image 创建图像light 创建光line 创建线patch 创建块rectangle 创建方surface 创建面text 创建图形中文本uicontextmenu 创建现场菜单对象uicontrol 用户使用界面控制uimenu 用户使用菜单控制4、句柄图形处理(Handle Graphics operations)copyobj 拷贝图形对象及其子对象delete 删除对象及文件drawnow 屏幕刷新findobj 用规定的特性找寻对象gcbf "正执行回调操作"的图形的柄gcbo "正执行回调操作"的控件图柄指令gco 获得当前对象的柄get 获得对象特性getappdat 获得应用程序定义数据isappdata 检验是否应用程序定义数据reset 重设对象特性rmappdata 删除应用程序定义数据set 建立对象特性setappdata 建立应用程序定义数据5 、工具函数(Utilities)closereq 关闭图形窗请求函数ishandle 若是图柄代号侧为真newplot 下一个新图十六图形用户界面工具align 对齐用户控件和轴cbedit 编辑回调函数ginput 从鼠标得到图形点坐标guide 设计GUI menu 创建菜单menuedit 菜单编辑propedit 属性编辑uicontrol 创建用户界面控制uimenu 创建用户界面菜单十七字符串1 、通用字符串函数(General)blanks 空格符号cellstr 通过字符串数组构建字符串的元胞数组char 创建字符传输组或者将其他类型变量转化为字符串数组deblank 删除最后的空格double 把字符串变成ASCII 码值eval 执行串形式的MATLAB 表达式2、字符串查询(String tests)iscellstr 若是字符串组成的元胞数组则为真ischar 若是字符串则为真isletter 串中是字母则为真isspace 串中是空格则为真isstr 若是字符串则为真3、字符串操作(String operations)base2dec X-进制串转换为十进制整数bin2dec 二进制串转换为十进制整数dec2base 十进制整数转换为X 进制串dec2bin 十进制整数转换为二进制串dec2hex 十进制整数转换为16 进制串findstr 在一个串中寻找一个子串hex2dec 16-进制串转换为十进制整数hex2num 16-进制串转换为浮点数int2str 将整数转换为字符串lower 把字符串变成小写mat2str 将数组转换为字符串num2str 把数值转换为字符串strcat 把多个串连接成长串strcmp 比较字符串strcmpi 比较字符串(忽略大小写)strings MATLAB 中的字符串strjust 字符串的对齐方式strmatch 逐行搜索串strnomp 比较字符串的前N 个字符strncmpi 比较字符串的前N 个字符(忽略大小写)strrep 用另一个串代替一个串中的子串strtok 删除串中的指定子串strvcat 创建字符串数组str2mat 将字符串转换为含有空格的数组str2num 将字符串转换为数值upper 把字符串变成大写十八文件输入/输出clc 清除指令窗口disp 显示矩阵和文字内容fprintf 把格式化数据写到文件或屏幕home 光标返回行首input 提示键盘输入load 从磁盘中调入数据变量pause 暂停sprintf 写格式数据到串sscanf 在格式控制下读串十九时间和日期clock 时钟cputme MATLAB 战用CPU 时间date 日期etime 用CLOCK 计算的时间now 当前时钟和日期pause 暂停tic 秒表启动toc 秒表终止和显示二十数据类型1、数据类型(Data types)cell 创建元胞变量char 创建字符传输组或者将其他类型变量转化为字符串数组double 转化为16 位相对精度的浮点数值对象function handle 函数句柄inline 创建内联函数JavaArray 构建Java 数组JavaMethod 调用某个Java 方法JavaObject 调用Java 对象的构造函数single 转变为单精度数值sparse 创建稀疏矩阵struct 创建构架变量uint8(unit16、unit32) 转换为8(16、32)位无符号整型数int8(nit16、nit32) 转换为8(16、32)位符号整型数2、多维数组函数(Multi-dimensional array functions)cat 把若干数组串接成高维数组ndims 数组A 的维数ndgrid 为N-D 函数和插补创建数组ipermute 广义反转置permute 广义非共轭转置shiftdim 维数转换squeeze 使数组降维3、元胞数组函数(Cell array functions)cell 创建元胞变量celldisp 显示元胞数组内容cellfun 元胞数组函数cellplot 图示元胞数组的内容cell2struct 把元胞数组转换为构架数组deal 把输入分配给输出is cell 若是元胞则为真num2 cell 把数值数组转换为元胞数组struct2 cell 把构架数组转换为元胞数组4、构架函数(Structure functions)fieldnames 获取构架的域名getfield 获取域的内容isfield 若为给定构架的域名则为真isstruct 若是构架则为真rmfield 删除构架的域setfield 指定构架域的内容struct 创建构架变量5、函数句柄函数(Function handle functions)@ 创建函数句柄functions 列举函数句柄对应的函数func2str 将函数句柄数组转换为字符串str2func 将字符串转换为函数句柄6、面向对象编程(Object oriented programming functions)dlass 查明变量的类型isa 若是指定的数据类型则为真inferiorto 级别较低isjava 若是java 对象则为真isobject 若是对象则为真methods 显示类的方法名substruct 创建构架总量superiorto 级别较高二一示例demo 演示程序flow 无限大水体中水下射流速度数据intro 幻灯演示指令peaks 产生peaks 图形数据二二符号工具包1、微积分(Calculus)diff 求导数limit 求极限int 计算积分jacobian Jacobian 矩阵symsum 符号序列的求和trylor Trylor 级数2、线性代数(Linear Algebra)det 行列式的值diag 创建对角阵,抽取对角向量eig 矩阵特征值和特征向量expm 矩阵指数inv 矩阵的逆jordan Jordan 分解null 零空间poly 特征多项式rank 秩rref 转换为行阶梯形svd 奇异值分解tril 抽取下三角阵triu 抽取上三角阵3、化简(Simplification)collect 合并同类项expand 对指定项展开factor 进行因式或因子分解horner 转换成嵌套形式numden 提取公因式simple 运用各种指令化简符号表达式simplify 恒等式简化subexpr 运用符号变量置换子表达式subs 通用置换指令4、方程求解(Solution of Equation)compose 求复函数dsolve 求解符号常微分方程finverse 求反函数fminunc 拟牛顿法求多元函数极值点fsolve 解非线性方程组lsqnonlin 解非线性最小二乘问题solve 求解方程组5、变量精度(Variable Precision Arithmetic)digits 设置今后数值计算以n 位相对精度进行vpa 给出数值型符号结果6、积分变换(Integral Transforms)fourier Fourier 变换ifourier Fourier 反变换ilaplace Ilaplace 反变换iztrans Z 反变换laplace Ilaplace 变换ztrans Z 变换7、转换(Conversions)。

利用MATLAB实现DPSK调制及解调

利用MATLAB实现DPSK调制及解调

利用MATLAB实现DPSK调制及解调
DPSK(Differential Phase Shift Keying)调制是一种数字信息传输调制方式。

它采用相位差的改变来表示数字信息,具有抗噪声和波动的能力,因此在数字通信领域得到了广泛的应用。

MATLAB是一种适合数字信号处理的工具,可以有效地实现DPSK调制及解调。

以下是具体的实现步骤:
DPSK调制
1. 生成数字信息比特流,转换为1和-1形式。

2. 将比特流进行差分编码得到差分比特流。

3. 将差分比特流分组,每组2个比特。

4. 根据相邻两个比特的差异,确定相位差。

差分比特流为00或11时,相位差为0;差分比特流为01或10时,相位差为π。

5. 根据相位差,生成相位进行调制得到调制信号。

可以使用sinc函数或高斯函数对信号进行脉冲整形。

DPSK解调
1. 将DPSK调制后的信号送入相干解调器。

2. 使用带通滤波器去除高频噪声。

3. 再次进行相干解调,得到调制信号。

4. 对调制信号进行差分解码还原差分比特流。

5. 对差分比特流进行译码得到数字信息比特流。

利用MATLAB实现DPSK调制及解调的代码可在Matlab官网上找到并学习使用。

调制解调的Matlab仿真实现

调制解调的Matlab仿真实现摘要在通信过程中,调制与解调占有十分重要的地位。

假如没有调制与解调技术,就没有通信,没有广播和电视,也没有今天的BP 寻呼、手持电话、传真、电脑通信及Internet 国际互联网。

本设计是基于MATLAB来实现调制与解调的仿真。

主要设计思想是利用MATLAB 这个强大的数学软件工具方便快捷灵活的功能实现模拟调制解调中的幅度调制和角度调制及数字调制解调中的FSK和DPSK的调制解调设计。

首先,先介绍这几种模拟和数字调制解调的产生、频谱、解调等过程及原理,接着就编写相应的m文件先后对模拟调制中的幅度调制和角度调制里面的频率调制的进行仿真,并对仿真得出调试及仿真结果并进行分析。

FM调制的时候是让基带信号去控制振荡电路的频率,AM是用基带信号去控制载波的幅度。

无论哪一种调制方式,采用相干解调的性能优于非相干解调的性能。

而且D PSK可以消除PSK的“倒 ”现象。

DPSK的系统性能要优于FSK系统。

相干系统要求本地载波与发送信号之间保持同步,否则误码率增加。

因此,在高质量的数字通信系统中多采用相干解调,而对抗噪声性能要求不高的就采用较为简单的非相干解调。

关键词:MATLAB;调制解调;AM;FM;FSK;DPSKSIMULATION OF MODEM IN MATlABABSTRACTIn the communication process, modulation and demodulation is very important position. If there is no modulation and demodulation technology, there is no communication, no radio and television, nor did the BP pager, handheld phone, fax, computer communications and Internet Internet.The design is based on MATLAB to achieve modulation and demodulation of the simulation. The main design idea is the use of MATLAB software, this powerful mathematical tool for convenient and flexible function for analog modulation and demodulation of amplitude modulation and angle modulation and digital modulation and demodulation of FSK and DPSK modem design. First of all, to introduce these types of analog and digital modulation and demodulation of the resulting spectrum, demodulator,etc. Then the preparation of the corresponding document has m analog modulation of the amplitude modulation and angle modulation frequency modulation inside the simulation, and simulation debugging and simulation results obtained and analyzed.FM modulation is the time base-band signal to control the frequency of oscillator circuit, AM base-band signals used to control the range of carrier. No matter what kind of modulation, the use of the performance of coherent demodulation is superior to the performance of non-coherent demodulation. DPSK can remove the "anti-π" phenomenon of PSK. DPSK system performance is superior to FSK system. The local carrier coherent system requirements and to maintain synchronization between the transmitted signal, Otherwise, increase the bit error rate. So, In high-quality digital communication systems use coherent demodulation, and noise performance of low-resistance on the use of relatively simple non-coherent demodulation.Key words: matlab; modem; am; fm; fsk; dpsk目录1 绪论 (1)1.1 课题发展的现状 (1)1.2 课题研究的内容和目的 (2)1.3 课题研究的步骤 (2)2 调制解调原理 (3)2.1 实现AM的调制解调的原理 (3)2.2 实现FM的调制解调的原理 (4)2.3 实现FSK的调制解调的原理 (6)2.4 实现DPSK的调制解调的原理 (8)3 调制与解调的MATLAB仿真实现 (10)3.1 仿真工具MATLAB的介绍 (10)3.1.1 MATLAB软件 (10)3.1.2 M文件 (11)3.2 AM的仿真实现 (11)3.2.1 未加噪声时的AM调制解调 (11)3.2.2 叠加噪声时的AM调制解调 (13)3.2.3 AM系统的抗噪声性能 (16)3.3 FM的仿真实现 (17)3.3.1 未加噪声的FM解调实现 (17)3.3.2 叠加噪声时的FM解调 (20)3.4 FSK的调制解调的实现 (23)3.4.1 FSK调制实现 (23)3.4.2 FSK相干解调实现 (25)3.5 DPSK的调制解调的实现 (26)4 总结 (28)参考文献 (31)附录 (33)附录A (33)附录B (36)附录C (38)附录D (40)附件1 开题报告 (42)附件2 译文和原文影印件 (49)1 绪论1.1课题发展的现状调制在通信系统中具有重要的作用。

16apsk调制matlab代码

16apsk调制matlab代码16APSK调制是一种常用的数字调制技术,它广泛应用于无线通信系统中,特别是卫星通信领域。

在本文中,我们将逐步解答关于16APSK调制的问题,并提供MATLAB代码实现。

首先,我们需要了解什么是16APSK调制。

16APSK是一种组合了相移键控(PSK)和星座点(AM)调制技术的调制方式。

具体来说,16APSK 调制将16个相位恒定的载波信号与4个星座点进行组合,使得每个星座点对应于不同的相位,从而实现16种不同的调制符号。

接下来,我们将介绍16APSK调制的原理。

1. 构建星座图:首先,我们需要构建16APSK星座图。

星座图是一个画在复平面上的点阵,其中每个点表示一个可能的调制符号。

对于16APSK 调制,我们可以将星座图分为两个环状区域,分别表示8个相移键控(PSK)符号和8个星座点符号。

2. 星座点选择:选择星座点是16APSK调制过程中的关键步骤。

它通常是通过最小距离准则或其他优化算法来确定的。

我们可以使用MATLAB 中的“combinator”函数生成所有可能的星座点组合,并通过计算每个组合之间的最小距离来选择最佳的星座点。

3. 星座点映射:一旦选择了星座点,我们需要将输入数据映射到最接近的星座点上。

这个过程通常是通过计算输入数据与每个星座点之间的欧几里德距离来实现的。

选择最小距离的星座点作为输出调制符号。

MATLAB中的“kmeans”函数可以用于实现星座点映射。

4. 符号映射:一旦得到调制符号,我们需要将它们映射到16个相位相移键控(PSK)载波信号和4个星座点中的一个。

这可以通过使用MATLAB 的“modulate”函数来实现,该函数通过将调制符号与相应的相位偏移进行相乘来生成16APSK调制信号。

现在我们已经了解了16APSK调制的原理,接下来我们将提供MATLAB 代码实现。

matlab定义调制参数M = 16; 调制阶数pskModulator = comm.PSKModulator('ModulationOrder', M,'BitInput', true);amModulator =comm.RectangularQAMModulator('ModulationOrder', M/4);生成星座图constellation = pskModulator.constellation;选择星座点numBits = log2(M);combinations = combinator(length(constellation), numBits, 'p'); minDist = Inf;optimalPoints = [];for i = 1:size(combinations, 1)points = constellation(combinations(i, :), :);dist = minDistance(points);if dist < minDistminDist = dist;optimalPoints = points;endend进行星座点映射mapping = kmeans(constellation, optimalPoints);生成调制符号importSym = randi([0 M-1], 10000, 1); 随机生成输入数据modSym = mapping(importSym + 1); 进行星座点映射进行符号映射modSignal = modulate(pskModulator, pskModulator(modSym)); 进行相移键控调制amSignal = amModulator(modSym); 进行星座点调制以上是一个简单的MATLAB代码,用于实现16APSK调制过程。

MSK

设计一MSK信号的调制与解调一、设计的基本要求1、设计MSK数字通信系统的结构,包括调制与解调。

2、根据通信原理,设计出各个模块的参数3、基于MATLAB平台对系统进行仿真4、分析仿真波形二、设计的具体内容整个设计的结构框图如下图:具体设计步骤:1、根据MSK信号调制与解调原理设计如下系统:2、设置MSK系统各模块的参数Bernoulli Binary Generator和AwgnMSK Modulato Baseband和MSK Demodulator basebandError Rate Calculation3、运行系统,得仿真结果三、设计结果与分析1、误码率分析上图中的Display模块窗口显示的数值是该系统的误码率。

误码率的计算器将在一定时间内收到的数字信号中发生差错的比特数与同一时间所收到的比特数的比值通过显示窗口显示出来。

误码率是衡量数据在规定时间内数据传输精确性的指标。

如上图所示,在Scope窗口中可以看到输入信号与输出信号的序列,可以看出经过调制解调后的信号与原信号相比无明显失真。

2、星座图分析在MSK信号星座图中,1比特区间仅使用圆周的1/4,信号点必定必是轴上4个点中任何一个,因此,相位必然连续。

采用MSK旁瓣降低得非常明显,即使不使用截止特性较好的带通滤波器,也能获得邻道干扰少的调制信号。

由MSK信号点配置图可知,调制时出现旁瓣是由于调制载波相位急剧变化所引起的。

MSk相位变化是连续的,但是相位变化速率的比特点变化成不连续。

要使相应的一次微分连续,相位点必须以恒定速度旋转,若接近比特点,旋转速度就变慢,变化点处速度必须为0。

通过Display—Time Scatter Plot Scope窗口可以观察到该MSK系统调制的星座图,MSK星座图的特点在改图中都明显的表现出来,这也进一步验证了改系统的正确性。

3、眼图分析系统中的眼图如下。

在实际的通信中,数字信号经过非理想的传输系统必定要产生畸变,信号通过信道后,也会引入噪声和干扰,也就是说,总是在不同程度上存在码间干扰。

数字频带传输系统的MATLAB仿真实现源代码

一、设计内容:数字频带传输系统的MATLAB仿真实现[1]个人部分:2PSK的调制、信道模拟、抽样判决及解调1、2PSK的调制基本任务:原始PCM脉冲编码信号的2PSK调制1)、主要步骤和要求:对原始的PCM脉冲编码信号进行2PSK调制。

要求原始的PCM脉冲编码信号可以是数字型也可以是字符型;要求画出原始PCM脉冲编码信号和2PSK调制信号的波形图。

2)2PSK调制程序代码及说明:function psk_sig=modulat_1(pcm,Fc,Fd,Fs)%输入信号pcm为原始的PCM脉冲编码信号,Fc为载波频率,Fd输出信号的抽样%频率为,Fs为输入信号的抽样频率;输出信号psk_sig为2PSK调制后的信号。

%原始PCM脉冲编码信号的2PSK调制%%检测输入信号的类型%2PSK调制程序代码:function psk_sig=modulat_1(pcm,fc,fd,fs)for i=1:length(pcm); % 判断是数字还是字符if ischar(pcm(i))==1;pcm(i)=str2num(pcm(i));endi=i+1;endpsk_sig=dmod(pcm,fc,fd,fs,'psk');subplot(2,1,1)plot(pcm,'r*')subplot(2,1,2)plot(psk_sig,'b.')实验截图:2、随机噪声信道的MATLAB仿真实现基本任务:简单随机噪声信道的MATLAB仿真实现。

1)、主要步骤和要求:要求2PSK调制信号经过一个常用的AWGN信道;要求2PSK 调制信号可以是数字型也可以是字符型;要求信道信噪比snr可变;要求在同一个figure中给出输入信号psk_sig和输出信号psk_after_channel的波形图。

2)、2PSK+AWGN程序代码及说明:function psk_after_channel=channel_1(psk_sig,snr)%输入变量psk_sig为2PSK调制信号,snr为AWGN信道的信噪比;输出变量%psk_after_channel为经过AWGN信道后的2PSK调制信号。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

msk的调制解调MATLAB源代码 function out = delay(data,n,sample_number) %data:延迟的数据 %n:延迟码元个数 %sample_number:码元采样个数 out = zeros(1,length(data)); out(n*sample_number+1:length(data)) = data(1:length(data)-n*sample_number);

function [data_diff] = difference(data) %差分编码 %************************************************************************** %data 输入信号 %data_diff 差分编码后信号 %**************************************************************************

%-------------------------------------------------------------------------- data_diff = zeros(1,length(data)); data_diff(1) = 1 * data(1); %1为差分编码的初始参考值 for i = 2:length(data) data_diff(i) = data_diff(i-1) * data(i); end %**************************************************************************

function [signal_out,I_out,Q_out] = mod_msk(data,data_len,sample_number,Rb) %MSK基带调制 %************************************************************************** % data 调制信号 % data_len 码元个数 % sample_number 每个码元采样点数 % Rb 码元速率 % signal_out 基带调制输出 % I_out I路输出 % Q_out Q路输出 %**************************************************************************

% data_len = 10; %码元个数 % sample_number = 8; %采样点数 % Rb = 16000; %码元速率 % data1 = randint(1,data_len); % data = 2*data1-1; %传输的序列

Tb = 1/Rb; %码元时间 fs = Rb*sample_number; %采样速率

%-------------------------------------------------------------------------- %差分编码 [data_diff] = difference(data); %**************************************************************************

%-------------------------------------------------------------------------- %并串转换,延时 I(1) = 1; %fai0 = 0,cos(fai0) = 1 for i = 1:2:data_len Q(i) = data_diff(i); Q(i+1) = data_diff(i); end for i = 2:2:data_len I(i+1) = data_diff(i); I(i) = data_diff(i); end

for i = 1:sample_number I1(i:sample_number:data_len*sample_number) = I(1:data_len); Q1(i:sample_number:data_len*sample_number) = Q(1:data_len); end %**************************************************************************

%-------------------------------------------------------------------------- %乘加权函数 t=1/fs:1/fs:data_len*Tb; I_out = I1 .* cos(pi*t/2/Tb); Q_out = Q1 .* sin(pi*t/2/Tb); %**************************************************************************

%-------------------------------------------------------------------------- %调制信号产生 signal_out = I_out + j*Q_out; %**************************************************************************

% %-------------------------------------------------------------------------- % %画图 % subplot(221) % plot(data,'.-');title('MSK传输的数据');xlabel('时间');ylabel('幅度') % subplot(222) % plot(data_diff,'.-');title('差分后的数据');xlabel('时间');ylabel('幅度') % subplot(223) % plot(I1,'.-');title('加权前I路');xlabel('时间');ylabel('幅度'); % subplot(224) % plot(Q1,'.-');title('加权前Q路');xlabel('时间');ylabel('幅度'); % % figure(2) % subplot(221) % plot(cos(pi*t/2/Tb),'.-');title('加权函数cos(πt/(2Tb))');xlabel('时间');ylabel('幅度') % subplot(222) % plot(sin(pi*t/2/Tb),'.-');title('加权函数sin(πt/(2Tb))');xlabel('时间');ylabel('幅度') % subplot(223) % plot(I_out,'.-');title('加权后I路');xlabel('时间');ylabel('幅度'); % subplot(224) % plot(Q_out,'.-');title('加权后Q路');xlabel('时间');ylabel('幅度'); % %**************************************************************************

function [signal_out,I_out,Q_out,phase] = mod_msk2(data,data_len,sample_number,Rb) %MSK基带调制 %************************************************************************** % data 调制信号 % data_len 码元个数 % sample_number 每个码元采样点数 % Rb 码元速率 % signal_out 基带调制输出 % I_out I路输出 % Q_out Q路输出 %**************************************************************************

% data_len = 10; %码元个数 % sample_number = 8; %采样点数 % Rb = 16000; %码元速率 % data1 = randint(1,data_len); % data = 2*data1-1; %传输的序列

Tb = 1/Rb; %码元时间 fs = Rb*sample_number; %采样速率

%-------------------------------------------------------------------------- %采样 for i = 1:sample_number data_sample(i:sample_number:data_len*sample_number) = data; end %**************************************************************************

%-------------------------------------------------------------------------- %计算相位 phase = zeros(1,data_len*sample_number); phase(1) = data_sample(1) * pi/2/sample_number; for i = 2:data_len*sample_number phase(i) = phase(i-1) + data_sample(i-1) * pi/2/sample_number; end %**************************************************************************

%-------------------------------------------------------------------------- %I/Q I_out = cos(phase); Q_out = sin(phase);

相关文档
最新文档