当前位置: 首页 > article >正文

基于QPSK调制解调+Polar编译码(SCL译码)的matlab性能仿真,并对比BPSK

目录

1.引言

2.算法仿真效果演示

3.数据集格式或算法参数简介

4.MATLAB核心程序

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

6.参考文献

7.完整算法代码文件获得


1.引言

       Polar码由土耳其教授Erdal Arikan于2008年提出,是第一种被严格证明可以达到香农极限的构造性编码方法。其核心思想是通过信道极化(Channel Polarization)将多个独立的二进制输入信道转化为一组极化信道,一部分信道接近无差错,另一部分接近完全噪声。

2.算法仿真效果演示

软件运行版本:

matlab2024b

仿真结果如下(仿真操作步骤可参考程序配套的操作视频,完整代码运行后无水印)

3.数据集格式或算法参数简介

K = 19;
N = 64;
R = K/N;
List = [4];EBN0  = [-3,-2,-1,0,1,2,2.5];            % 信噪比的范围
Times = [5000,2500,1000,300,200,150,60];

4.MATLAB核心程序

......................................................................while (err0 <= Times(ij))    [err0,EbNo]count = count +1;for num = 1: (Frames/batch)   dats = binornd(1, 0.5, batch, K);for iter = 1: batch      info_bit = dats(iter,:);% 将信息序列存储到数组before_code_bit中code_0          = zeros(1,N);code_0(idxs(:)) = info_bit(:);% 极化码编码S               = func_polar_enc(N, code_0);          % 开始调制Sbp   = bpskMod(S');rSig  = func_Channel(Sbp, sigma);rxLLR = bpskDemod(rSig);  [dec_list] = func_SCL_dec(L, N, rxLLR, noiseVar, idxs, G);ydec       = dec_list(:,1)';%解码之后的序列err0       = err0 + sum(info_bit ~= ydec);bitall     = bitall + K;endendfigure;
semilogy(EBN0,ERR,'-*b');
xlabel('EBN0(dB)')  %x轴坐标描述
ylabel('ERR') %y轴坐标描述
grid onif K==6save R11.mat EBN0 ERR
end
if K==13save R12.mat EBN0 ERR
end
if K==19save R13.mat EBN0 ERR
end
014_053m

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

       Polar码由土耳其教授Erdal Arikan于2008年提出,是第一种被严格证明可以达到香农极限的构造性编码方法。其核心思想是通过信道极化(Channel Polarization)将多个独立的二进制输入信道转化为一组极化信道,一部分信道接近无差错,另一部分接近完全噪声。

Polar码编码过程

信道极化:通过递归计算信道容量,将n个原始信道转化为n个极化信道

信道选择:选择容量最大的k个信道作为信息位,其余作为冻结位 (固定为0)

编码运算:信息位向量u与生成矩阵Gn​相乘得到码字c:

c=u⋅Gn​

SCL译码是对原始SC译码的改进,通过维护一个候选路径列表提高译码性能:

6.参考文献

[1]孔维凡,程云鹏.短波通信中的低码率CRC-Polar编译码设计与仿真[J].通信技术, 2024, 57(8):775-782.

[2]高洁.5G 通信中Polar码的编译码研究和应用[J].Electronic Science & Technology, 2024, 37(1).DOI:10.16180/j.cnki.issn1007-7820.2024.01.009.

7.完整算法代码文件获得

完整程序见博客首页左侧或者打开本文底部

V

http://www.lryc.cn/news/2399309.html

相关文章:

  • go语言学习 第5章:函数
  • Qt Quick快速入门笔记
  • 《波段操盘实战技法》速读笔记
  • Glide NoResultEncoderAvailableException异常解决
  • 工厂模式与多态结合
  • 无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌
  • 相机--相机成像原理和基础概念
  • 2025-0604学习记录17——文献阅读与分享(2)
  • 图解浏览器多进程渲染:从DNS到GPU合成的完整旅程
  • 【计算机网络】第3章:传输层—TCP 拥塞控制
  • idea不识别lombok---实体类报没有getter方法
  • 【Hive入门】
  • 亚马逊站内信规则2025年重大更新:避坑指南与合规策略
  • 01 - AI 时代的操作系统课 [2025 南京大学操作系统原理]
  • 数组1 day7
  • SAP学习笔记 - 开发15 - 前端Fiori开发 Boostrap,Controls,MVC(Model,View,Controller),Modules
  • Redis中的过期策略与内存淘汰策略
  • 基于SDN环境下的DDoS异常攻击的检测与缓解
  • HarmonyOS 实战:给笔记应用加防截图水印
  • 如何轻松地将文件从 PC 传输到 iPhone?
  • 前端面试二之运算符与表达式
  • 【运维实战】使用Nvm配置多Node.js环境!
  • Bresenham算法
  • 【从GEO数据库批量下载数据】
  • day 44
  • 鸿蒙OSUniApp开发跨平台AR扫描识别应用:HarmonyOS实践指南#三方框架 #Uniapp
  • NER实践总结,记录一下自己实践遇到的各种问题。
  • 微信小程序实现运动能耗计算
  • iTunes 无法备份 iPhone:10 种解决方法
  • 施耐德特价型号伺服电机VIA0703D31A1022、常见故障