目录

1.算法仿真效果

2.MATLAB核心程序

3.算法涉及理论知识概要

3.1pts

3.2SLM

3.3 Filter

4.完整MATLAB


1.算法仿真效果

matlab2022a仿真结果如下:

2.MATLAB核心程序

.........................................
K = 128;
N = 4;
QPSK_Set  = [1 -1 j -j];
Phase_Set = [1 -1];
MAX_SYMBOLS  = 1e5;
PAPR_Orignal = zeros(1,MAX_SYMBOLS);
PAPR_SLM     = zeros(1,MAX_SYMBOLS);
X     = zeros(N,K);
Index = zeros(N,K);
for nSymbol=1:MAX_SYMBOLSIndex(1,:)   = floor(length(QPSK_Set)*rand(1,K))+1;Index(2:N,:) = floor(length(Phase_Set)*rand(N-1,K))+1;X(1,:) = QPSK_Set(Index(1,:));
......................................................x = ifft(X,[],2);                                                       Signal_Power = abs(x.^2);Peak_Power   = max(Signal_Power,[],2);Mean_Power   = mean(Signal_Power,2);PAPR_temp = 10*log10(Peak_Power./Mean_Power);PAPR_Orignal(nSymbol) = PAPR_temp(1);PAPR_SLM(nSymbol)     = min(PAPR_temp);
end
[cdf1, PAPR1] = ecdf(PAPR_Orignal);
[cdf2, PAPR2] = ecdf(PAPR_SLM);figure;
semilogy(PAPR1,1-cdf1,'-k','LineWidth',1)
hold on
semilogy(PAPR2,1-cdf2,'-b','LineWidth',2)
legend('Orignal','SLM')
xlabel('PAPR0 [dB]');
ylabel('CCDF (Pr[PAPR>PAPR0])');
grid on
A338

3.算法涉及理论知识概要

正交频分复用(OFDM)是长期演进的4G蜂窝网络标准中采用的调制技术。但是,OFDM具有较强的带外辐射和较高的旁瓣,对频谱的感知精度低下。未来的无线标准需要为下一代移动系统提出具有高传输数据速率和高频谱利用率的新调制技术。带有偏移正交幅度调制(OQAM)的滤波器组多载波调制(FBMC)作为未来第五代移动通信标准中的主要候选,已经引起了人们的关注。

FBMC-OQAM是一种多载波技术,通过基于快速傅里叶逆变换/快速傅里叶变换的滤波器组和OQAM符号,能够以两倍FBMC/QAM的符号速率将实数符号载入子载波,因此具有较高的频谱效率。利用较小旁瓣的滤波器减小了载波频移,缓解了其对OFDM传输的影响,可以使频谱带外泄露特别低。因为FBMC-OQAM系统中没有插入循环前缀,所以具有高传输数据速率和高频谱利用率。然而,FBMC-OQAM与OFDM都是多载波调制技术,在符号传输过程中,由于多个子信道传输信号的叠加会产生较大的峰值,从而引起较高的峰均比(PAPR)。高PAPR导致非线性功率放大器中FBMC-OQAM性能的严重劣化,所以降低FBMC-OQAM系统的PAPR是下一代通信技术的一个主要问题。一般地,PAPR降低技术可以大致分为两大类——有失真技术和无失真技术。有失真技术包含压扩法技术(星座扩展法)和限幅类技术(消峰法),无失真技术包含编码类技术(分组编码)和概率类技术。概率类的解决方案如选择性映射(SLM)和部分传输序列(PTS)方案,主要是降低信号中高峰值出现的概率,而不是减少最大信号的幅度[4]。它们具有相对较低的复杂度,在边带信息恢复时不会影响误码率,因而更具优势。

3.1pts

部分传输序列(Partial Transmit Sequence , PTS)由于其不受载波数量限制,并且能够有效的,无失真的降低OFDM信号峰均比,而受到广泛关注。部分传输序列算法(PTS)最初是由S.H.Muller和J.B.Huber于1997年提出。PTS算法的核心思想是将具有N个符号的输入序列按照一定的分割方式分割成V个子数据块,并且保持每个子数据块仍含有N个符号。然后对V个子数据块进行相位加权与合并处理,选择具有最小PAPR的一组符号进行传输,达到降低OFDM信号PAPR的目的。传统的PTS算法理论比较多,现成的资料也比较多,这里就不多做介绍了,通过仿真,对比PTS和没有PTS下。目前OFDM的PAPR主要算法有信号预畸变,信号扰码,编码三个方向来解决。

在本课题中,我们将在传统PTS算法基础上引入了TR的思路到改进后的PTS算法中,引入的意义为:先预留出若干子载波来加载削峰信号,然后利用优化过的PTS算法对OFDM符号的PAPR进行抑制,之后再利用改进的TR算法对符号的PAPR进行进一步的抑制。整个算法的流程如下所示:

步骤一:加入门限,降低PTS算法的复杂度(但是这样会降低性能)

当满足要求:

算法就停止搜索,这样的话,就降低的算法的复杂度,但是会影响性能。

步骤二:加入限幅的方法

通过这个方法,可以在步骤一的基础上,提高性能,使其在复杂度降低的前提下,保存系统的性能不变。

3.2SLM

     slm算法就是对QAM信号乘以U组相位因子序列,再进行ifft得到 U组ofdm信号,选择papr最小的那一组进行发送。
  因为对于ofdm信号而言,高PAPR出现的概率很小,一般1000个ofdm信号只会有个位数papr过高的值。那SLM方法对同一个QAM信号乘以N组相位后得到U个ofdm信号,从中选择PAPR最小的进行发送,就用概率的方法将高PAPR的ofdm信号滤出在外。

3.3 Filter

    for nIter=1:ITERATE_NUM% Clippingx_tmp = x(Signal_Power>CR*Mean_Power);x_tmp = sqrt(CR*Mean_Power)*x_tmp./abs(x_tmp);x(Signal_Power>CR*Mean_Power) = x_tmp;% FilteringXX = fft(x,[],2);XX(K/2+(1:N-K)) = zeros(1,N-K);x = ifft(XX,[],2); % PAPR ComputeSignal_Power = abs(x.^2);Peak_Power   = max(Signal_Power,[],2);Mean_Power   = mean(Signal_Power,2);PAPR_RCF(nIter,nSymbol) = 10*log10(Peak_Power./Mean_Power);end

4.完整MATLAB

V

PTS,SLM,Filter三种降低PAPR方法的matlab仿真相关推荐

  1. m瑞利信道下对比ZF-SIC,MMSE-SIC,MRC三种均衡算法的误码率matlab仿真

    目录 1.算法描述 2.仿真效果预览 3.MATLAB核心程序 4.完整MATLAB 1.算法描述 移动通信系统的性能在很大程度上决定于无线信道的特性.单发单收系统无线信道的特性已经研究得很透彻,针对 ...

  2. OpenCV函数应用:基于二值图像的三种孔洞填充方法记录(附python,C++代码)

    系列文章目录 函数系列: OpenCV函数简记_第一章数字图像的基本概念(邻域,连通,色彩空间) OpenCV函数简记_第二章数字图像的基本操作(图像读写,图像像素获取,图像ROI获取,图像混合,图形 ...

  3. 极低噪声幻像电源如何设计?详细原理图和三种消噪方法拿走不谢

    极低噪声幻像电源如何设计?详细原理图和三种消噪方法拿走不谢 原创 ADI 亚德诺半导体 2022-04-19 11:48 极低噪声幻像电源如何设计?详细原理图和三种消噪方法拿走不谢 Q: 是否可以利用 ...

  4. 三种引流方法案例分析

    第3课课程笔记 课程主题:三种引流方法&案例分析 课程题纲: 第一节:58同城引流方法详解(图文并茂) :宠物引流的第二种方法(资料收集与分享) :第三种最高端的玩法(让客户百分百信任你) 正 ...

  5. 【小白学习keras教程】十、三种Model Selection方法:k-fold cross-validation,GridSearchCV和RandomizedSearchCV

    @Author:Runsen Model Selection是划分训练集和测试集的手段,下面总结了三种Model Selection方法. k-fold cross-validation using ...

  6. Python实现二叉树的三种深度遍历方法!

    python代码实现了二叉树,这次将会实现二叉树的几种遍历方法,来更好的解析二叉树的结构特点.分别是一种广度遍历,和三种深度遍历方法:先序遍历,中序遍历,后序遍历.下面是代码实现: 1.先序遍历 遍历 ...

  7. php调用mysql库_PHP调用三种数据库的方法(1)

    PHP调用三种数据库的方法(1) 更新时间:2006年10月09日 00:00:00   作者: MySQL是一个小巧灵珑的数据库服务器软件,对于中.小型应用系统是非常理想的.除了支持标准的ANSI ...

  8. 实现两数 交换的三种不同编程方法。

    第一种 即常规方法 借助第三变量 int a = 5,b = 3,c; c = a; a = b; b = c; 第二种 不借助第三变量 int a=5,b=3,c; a = a+b;    //(缺 ...

  9. 常用的分隔符有哪三种_掌握这三种调漂方法,你想怎么钓就怎么钓,再也不用求人...

    调漂对于刚学钓鱼的钓友来说是一件非常头痛的事情,每次钓鱼大部分时间都浪费在调漂上,总是感觉调不好,不是灵了就是钝了!那么问题到底出在哪呢?今天就和大家分享三种针对悬坠钓的调漂方法,看懂弄明白了,再也不 ...

最新文章

  1. 兼容ie9以下css3,hover和圆角(htc)
  2. python tuple类型,Python基础数据类型(四) tuple元祖
  3. HUST1024 dance party(最大流)
  4. Enterprise Library 2.0 技巧(4):如何用编程的方法来配置Logging Application Block
  5. 博客园 Facebook风格,您不妨一试^^
  6. double 去掉小数点_JAVA编程有一个小数,如何去掉小数部分
  7. 链表题目----5 相交链表 和 环形链表 和 返回链表开始入环的第一个节点
  8. hadoop 之NullWritable与ObjectWritable
  9. 模板方法设计模式的原理及测试代码(手写JdbcTemplate)
  10. 2018/12/06 eclipse 快速加载需要的包
  11. 解决easyui textarea 值不显示及获取textarea的值
  12. python中的运算符重载_Python中的操作符重载
  13. selinux denied: u:r:untrusted_app:s0:c512,c768报错解决
  14. 南京邮电大学812自动控制原理高分经验
  15. 斐讯k3 搭建php环境,斐讯K3刷机教程官改V2.1D或者其它版本教程
  16. 计算机无法启动print,Win7无法启动print spooler服务报错1068怎么办
  17. 小程序实现下拉刷新功能
  18. Datawhale---Task2(EDA-数据探索性分析)
  19. UE5 预览版载具模板工程车不能移动的问题
  20. mysql通过视图插入数据_数据库视图 sql

热门文章

  1. Cronlog日志分割器
  2. android vold磁盘管理
  3. 30秒让你弄懂pdf怎么翻译,还在犹豫什么
  4. adb连接小米电视,尝试去除开机广告失败补救方法
  5. Oracle数据库配置
  6. vue——数字加逗号分隔
  7. Monkey的测试原理和方法
  8. Java之图片裁剪工具类-yellowcong
  9. http压力测试工具及使用说明
  10. centos7 挂载 硬盘 shell 懒人系列-2