【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。
由仿真结果可知,LDPC码的抗噪声性能是最佳的,Turbo码次之,卷积码的抗噪声性能相对较差。但这种关系也不是一定的,当LDPC的码长较小时,其性能也可能比Turbo码的性能要差,因为码长越长,LDPC码的性能越好。
LDPC的SPA译码和Turbo的BCJR译码都是迭代译码,因此性能与迭代次数有关。迭代次数越大,译码性能越好,但复杂度也越高。
如上图(1)所示,在信噪比较小时,Turbo码的BCJR译码性能要明显优于卷积码,但随着信噪比的增加,这种优势逐渐变弱,直至消失。当信噪比增加到一定值时,BER随SNR增加而下降的速度突然变慢,形成差错平台,这是Turbo的一个内在的缺点,它是由于小码重码字的出现所引起的。

2、仿真结果演示

3、关键代码展示

4、MATLAB 源码获取

点击下方原文链接获取

【MATLAB源码-第69期】基于matlab的LDPC码,turbo码,卷积码误码率对比,码率均为1/3,BPSK调制。_matlab turbo编码-CSDN博客文章浏览阅读1k次,点赞11次,收藏4次。LDPC码仿真取信息位长度K=200,码字长度N=400,因此校验位长度M=N-K=200,码率为1/2;仿真中校验矩阵H是稀疏且不规则的(irregular)。译码算法采用和积算法SPA,SPA也是一种迭代译码算法,在达到最大迭代次数以前,若某次迭代所得结果满足。Turbo码译码采用BCJR算法,它是一种最大后验概率算法(MAP),Turbo码的译码是一个迭代过程,仿真中迭代次数设置为4次。本文章介绍了卷积码、Turbo码和LDPC码。以相同的码率仿真这三种编码,并对比其误码率性能。_matlab turbo编码https://blog.csdn.net/Koukesuki/article/details/134277403?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522171426856716800188518497%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=171426856716800188518497&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~blog~first_rank_ecpm_v1~rank_v31_ecpm-1-134277403-null-null.nonecase&utm_term=69%E6%9C%9F&spm=1018.2226.3001.4450

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-29 10:22:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-29 10:22:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-29 10:22:01       87 阅读
  4. Python语言-面向对象

    2024-04-29 10:22:01       96 阅读

热门阅读

  1. 代码随想录训练营28day-动态规划

    2024-04-29 10:22:01       29 阅读
  2. vite构建工具

    2024-04-29 10:22:01       33 阅读
  3. Ali-Sentinel-节点与度量

    2024-04-29 10:22:01       32 阅读
  4. db2 SQLCODE=-1585和SQLSTATE=54048

    2024-04-29 10:22:01       33 阅读
  5. Linux yum/环境变量/服务/进程/hash/bash/防火墙命令

    2024-04-29 10:22:01       40 阅读
  6. 23种设计模式简单记录

    2024-04-29 10:22:01       29 阅读
  7. Vue--关于v-model指令

    2024-04-29 10:22:01       31 阅读
  8. python爬虫6

    2024-04-29 10:22:01       27 阅读