目录

1.算法描述

2.仿真效果预览

3.MATLAB核心程序

4.完整MATLAB


1.算法描述

LDPC码是麻省理工学院Robert Gallager于1963年在博士论文中提出的一种具有稀疏校验矩阵的分组纠错码。几乎适用于所有的信道,因此成为编码界近年来的研究热点。它的性能逼近香农极限,且描述和实现简单,易于进行理论分析和研究,译码简单且可实行并行操作,适合硬件实现。

LDPC仿真系统图LDPC 码的奇偶校验矩阵H是一个稀疏矩阵,相对于行与列的长度,校验矩阵每行、列中非零元素的数目(我们习惯称作行重、列重)非常小,这也是LDPC码之所以称为低密度码的原因。由于校验矩阵H的稀疏性以及构造时所使用的不同规则,使得不同LDPC码的编码二分图(Taner图)具有不同的闭合环路分布。而二分图中闭合环路是影响LDPC码性能的重要因素,它使得LDPC码在类似可信度传播(Belief ProPagation)算法的一类迭代译码算法下,表现出完全不同的译码性能。
       当H的行重和列重保持不变或尽可能的保持均匀时,我们称这样的LDPC码为正则LDPC码,反之如果列、行重变化差异较大时,称为非正则的LDPC码。研究结果表明正确设计的非正则LDPC码的性能要优于正则LDPC。根据校验矩阵H中的元素是属于GF(2)还是GF(q)(q=2p),我们还可以将LDPC码分为二元域或多元域的LDPC码。研究表明多元域LDPC码的性能要比二元域的好。

在LDPC编码中,会用到一个叫做H矩阵的校验矩阵(Parity Check Matrix),比如,我们来看一个简单的H矩阵:

为了可以更加直观的理解H矩阵,可以借助Tanner图,来表示H矩阵:

64QAM(Quadrature Amplitude Modulation,相正交振幅调制),在使用同轴电缆的网络中,这种数字频率调制技术通常用于发送下行数据。64QAM在一个6MHz信道中,64QAM传输速率很高,最高可以支持38.015Mbps的峰值传输速率。但是,对干扰信号很敏感,使得它很难适应嘈杂的上行传输(从电缆用户到因特网)。参见QPSK, DQPSK, CDMA, S-CDMA, BPSK和VSB。
       它的调制效率高,对传输途径的信噪比要求高,具有带宽利用率高的特点,适合有线电视电缆传输;我国有线电视网中广泛应用的DVB-C 调制即QAM 调制方式。QAM是幅度和相位联合调制的技术,它同时利用了载波的幅度和相位来传递信息比特,不同的幅度和相位代表不同的编码符号。因此,在最小距离相同的条件下,QAM星座图中可以容纳更多的星座点即可实现更高的频带利用率。

2.仿真效果预览

matlab2022a仿真结果如下:

3.MATLAB核心程序

clc;
clear;
close all;
warning off;
addpath(genpath(pwd));load G.mat;
load H.mat;max_iter=1;
L_frame=size(G,1);
n_frame=200;
start=0;
step=2;
finish=12;
r=size(G,1)/size(G,2);
M=6;
Es=42;   % 一个64QAM符号能量 也是信号功率
Eb=Es/M;
plot_pe=[];
Q=1;%  err_list_index=1;  % used by test
axis_EbN0=start:step:finish;
%******************************************************
for EbN0=start:step:finish;Liner_EbN0=10^(EbN0/10);pe_number=0;variance=0.5*(Eb/Liner_EbN0)/r;  % 噪声方差, 来源于a^2/(2*delta^2)=Liner_EbN0,a^2信息幅值的平方即比特能量, 2*delta^2=N0.    N0/r得到编码后的噪声功率谱密度for number_frame=1:n_frame       [EbN0,number_frame]x_msg = (sign(randn(1,size(G,1)))+1)/2; % random bitsx_code_msg= mod(x_msg*G,2); % coding in=x_code_msg;x_tx_msg= QAM64m(in); % 16QAM modulation real_tx=real(x_tx_msg);  imag_tx=imag(x_tx_msg);waveform= x_tx_msg+sqrt(variance)*( randn(size(real_tx)) + randn(size(imag_tx))*i ) ; % AWGN transmission [f0,f1]=QAM64d(waveform,2*variance);LLR=log(f0./(f1+eps));[z_hat, success, k] = log_ldpc_decode(H,LLR,max_iter);; % likelihoodsx_dec_msg = z_hat(1:size(G,1)); %  码率1/2 时使用pe_number=pe_number+sum(x_msg~=x_dec_msg);current_time=fix(clock);fprintf('i am working %g,total(%g)      %g年  %g月  %g日  %g时  %g分  %g秒\n\n',Q,(((finish-start)/step)+1)*n_frame,current_time(1),current_time(2),current_time(3),current_time(4),current_time(5),current_time(6))Q=Q+1;fprintf('\n\n')endpe=pe_number/(L_frame*n_frame);plot_pe=[plot_pe,pe];
endsemilogy(axis_EbN0,plot_pe,'b*-')xlabel('Eb/N0 信号功率/噪声功率(db)')
ylabel('BER')
title('误码率')
grid onif max_iter==50save R50.mat axis_EbN0 plot_pe
endif max_iter==20save R20.mat axis_EbN0 plot_pe
endif max_iter==5save R5.mat axis_EbN0 plot_pe
endif max_iter==1save R1.mat axis_EbN0 plot_pe
endA120

4.完整MATLAB

V

基于MATLAB的LDPC编译码误码率仿真,仿真调制为64QAM,对比不同译码迭代次数相关推荐

  1. 基于matlab的LDPC编译码误码率仿真,调制方式为64QAM

    目录 1.算法概述 2.仿真效果 3.MATLAB仿真源码 1.算法概述 "LDPC编译码 低密度校验码(LDPC码)是一种前向纠错码,LDPC码最早在20世纪60年代由Gallager在他 ...

  2. 基于MATLAB的LDPC编译码仿真,调制为64QAM

    部分源码: % 首先加载G , H clear all load G.mat; load H.mat; max_iter=50; L_frame=size(G,1); n_frame=100; sta ...

  3. 基于Matlab的LDPC码性能研究毕业设计(含源文件)

    欢迎添加微信互相交流学习哦! 项目源码:https://gitee.com/oklongmm/biye 本科毕业设计(论文) 题 目    LDPC码性能研究 摘 要     信道编码是数字通信系统的 ...

  4. 74循环码matlab,基于matlab的(7,4)循环码的编译仿真.docx

    基于matlab的(7,4)循环码的编译仿真.docx 1EQUATIONCHAPTER1SECTION1HARBININSTITUTEOFTECHNOLOGY信息论与编码实验报告基于MATLAB的( ...

  5. 循环码差错图样matlab,基于MATLAB的(15,7)循环码的编译仿真.doc

    基于MATLAB的(15,7)循环码的编译仿真 <纠错码与差错控制> 课程设计 题目:基于MATLAB的(15,7)循环码的编译仿真 院(系) 信息科学与工程学院 专 业 通信工程专业 届 ...

  6. cdma matlab仿真程序,基于Matlab的CDMA通信完整系统分析及仿真.doc

    基于Matlab的CDMA通信完整系统分析及仿真 课程论文 题 目: 基于Matlab CDMA多址技术的仿真 学生姓名: 苏未然 学生学号: 1008030130 系 别: 电气信息工程学院 专 业 ...

  7. matlab 高斯信道,基于MATLAB高斯信道下的16QAM误码率分析的设计 通信系统课程设计报告.doc...

    基于MATLAB高斯信道下的16QAM误码率分析的设计 通信系统课程设计报告 目录 引言---------------------- 2 一.相关知识介绍---------------- 2 (1)Q ...

  8. 如何使用matlab得出pid控制参数值,基于MATLAB的PID控制器参数整定及仿真

    基于MATLAB的PID控制器参数整定及仿真 摘要:PID控制器结构和算法简单,应用广泛,但参数整定比较复杂,在此我探讨利用MATLAB实现PID参数整定及其仿真的方法,并分析比较比例.比例积分.比例 ...

  9. 基于matlab的数字下变频器的设计与仿真应用,基于MATLAB的数字下变频器的设计与仿真应用.pdf...

    基于MATLAB的数字下变频器的设计与仿真应用 中国科技论文在线 基于 Matlab 的数字下变频器的设计与仿真 朱建新,沈树群* (北京邮电大学电子工程学院,北京 100876 ) 摘要:本文通过对 ...

最新文章

  1. Android 获取标题栏的高度
  2. python 字典代码_Python 字典(Dictionary)
  3. linux c icmp协议 判断主机存活
  4. 西门子SIMENS学习网站
  5. Entity Framework Core生成的存储过程在MySQL中需要进行处理及PMC中的常用命令
  6. python将图例画在图外
  7. Opencv--CalcOpticalFlowPyrLK实现的光流法理解
  8. [Perl系列二-实战] 1. Perl 读取代码的行数
  9. Java 静态代理、Java动态代理、CGLIB动态代理
  10. mysql与java编写人事管理系统,java+mysql企业人事管理系统的设计
  11. 直播常见协议概念说明
  12. 不用校园网如何下载论文文献|DOI号|文献免费下载
  13. 中国海洋科技发展迅速 海洋重器世界领先
  14. 华为荣耀3c手机语言设置在哪个文件夹,(科普)详解Android系统SD卡各类文件夹名称...
  15. 最小公倍数三种方法(附代码)
  16. Debezium系列之:永久保存history topic中的数据
  17. java周总结1106
  18. Linux学习笔记RHEL 7(一)--RedHatEnterpriseLinux 7.0安装过程
  19. 视频画面裁剪怎么弄?分享几个实用技巧
  20. 【计算机网络】什么是 A、B、C 类地址?什么是子网掩码?

热门文章

  1. 双缸四柱液压机的液压系统设计和PLC控制【说明书(论文)+CAD (PLC控制框图+PLC输入输出接线图+液压系统原理图+梯形图+任务书……)】
  2. python字典取键值对_python 获取字典键值对的实现
  3. PCB模块化设计24——DCDC电源模块PCB布局布线设计规范
  4. PAT乙级题解1005(超级详细分析,看完就懂)
  5. ERROR in Entry module not found: Error: Can‘t resolve ‘./src‘ in ‘D:\contract\ipfs\go-ipfs\react_app
  6. Android屏幕共享及远程控制【免root】
  7. python turtle库seth_Python学习笔记_3 turtle库使用
  8. Delphi测试ODBC连接达梦数据库
  9. HTML——CSS行内样式
  10. 00008 - layui 表单验证,需要验证,但非必输