【MATLAB源码-第69期】基于matlab的LDPC码,turbo码,卷积码误码率对比,码率均为1/3,BPSK调制。

2023-11-08 14:01

本文主要是介绍【MATLAB源码-第69期】基于matlab的LDPC码,turbo码,卷积码误码率对比,码率均为1/3,BPSK调制。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

操作环境:

MATLAB 2022a

1、算法描述

本文章介绍了卷积码、Turbo码和LDPC码。以相同的码率仿真这三种编码,并对比其误码率性能

  • 信源输出的数据符号(二进制)是相互独立和等概率的;
  • 信道是加性白高斯噪声信道(AWGN);
  • 采用BPSK调制,忽略载波;
  • (3,1,2)卷积码:移位寄存器个数为2,码率为1/3,生成多项式g=[5,7,7];卷积码译码采用Viterbi最大似然译码,回溯长度为18;
  • Turbo码编码器结构为并行级联卷积码,由两个(2,1,2)递归系统卷积码作为分量编码器,总码率为1/3,分量编码器具有相同的生成矩阵,为:                                                       

Turbo码译码采用BCJR算法,它是一种最大后验概率算法(MAP),Turbo码的译码是一个迭代过程,仿真中迭代次数设置为4次。

LDPC码仿真取信息位长度K=200,码字长度N=400,因此校验位长度M=N-K=200,码率为1/2;仿真中校验矩阵H是稀疏且不规则的(irregular)。译码算法采用和积算法SPA,SPA也是一种迭代译码算法,在达到最大迭代次数以前,若某次迭代所得结果满足

  • 则开始判决输出,否则继续迭代,若当迭代次数大于最大迭代次数时仍不满足条件,则译码失败。仿真中将最大迭代次数分别设置4次和10次,以便于与卷积码、Turbo码相比较的同时,比较最大迭代次数对LDPC译码性能的影响。
  • 仿真中卷积码和Turbo的码率都是1/3,LDPC码率为1/2,因此为了比较的公平性,在计算高斯白噪声方差时需要考虑到码率。
  • 仿真量(对每个SNR值,发送信源符号的个数)的选择:根据蒙特卡罗仿真量确定方法的结论,对于误码率仿真统计而言,只有平均出错个数大于100,才能将相对误差超过20%的可能性控制在5%以内。例如,要想使传输误码率达到10^-5且结果可靠,要求仿真量需要大于10^7。
  1. 由仿真结果可知,LDPC码的抗噪声性能是最佳的,Turbo码次之,卷积码的抗噪声性能相对较差。但这种关系也不是一定的,当LDPC的码长较小时,其性能也可能比Turbo码的性能要差,因为码长越长,LDPC码的性能越好。
  2. LDPC的SPA译码和Turbo的BCJR译码都是迭代译码,因此性能与迭代次数有关。迭代次数越大,译码性能越好,但复杂度也越高。
  3. 如上图(1)所示,在信噪比较小时,Turbo码的BCJR译码性能要明显优于卷积码,但随着信噪比的增加,这种优势逐渐变弱,直至消失。当信噪比增加到一定值时,BER随SNR增加而下降的速度突然变慢,形成差错平台,这是Turbo的一个内在的缺点,它是由于小码重码字的出现所引起的。

2、仿真结果演示

3、关键代码展示

4、MATLAB 源码获取

      V

点击下方名片

这篇关于【MATLAB源码-第69期】基于matlab的LDPC码,turbo码,卷积码误码率对比,码率均为1/3,BPSK调制。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/370341

相关文章

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Java实现本地缓存的四种方法实现与对比

《Java实现本地缓存的四种方法实现与对比》本地缓存的优点就是速度非常快,没有网络消耗,本地缓存比如caffine,guavacache这些都是比较常用的,下面我们来看看这四种缓存的具体实现吧... 目录1、HashMap2、Guava Cache3、Caffeine4、Encache本地缓存比如 caff

MySQL中读写分离方案对比分析与选型建议

《MySQL中读写分离方案对比分析与选型建议》MySQL读写分离是提升数据库可用性和性能的常见手段,本文将围绕现实生产环境中常见的几种读写分离模式进行系统对比,希望对大家有所帮助... 目录一、问题背景介绍二、多种解决方案对比2.1 原生mysql主从复制2.2 Proxy层中间件:ProxySQL2.3

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

关于MyISAM和InnoDB对比分析

《关于MyISAM和InnoDB对比分析》:本文主要介绍关于MyISAM和InnoDB对比分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录开篇:从交通规则看存储引擎选择理解存储引擎的基本概念技术原理对比1. 事务支持:ACID的守护者2. 锁机制:并发控制的艺

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3