LDPC译码算法代码概述


程序说明

V0.0 2015/1/24


LDPC译码算法代码概述

?


概述


?

本文介绍了包括LDPC_Simulation.m, ldpcdecoderbp1.m,ldpcdecoderminsum.m, ldpcdecoderbp2.m,ldpcdecoderminsum2.m在内的MATLAB代码的编写思路,基本原理和功能,具体代码可见文后。本文暂不涉及LDPC校验矩阵的构造和编码程序,此部分由他人提供。



修订历史


以下表格展示了本文档的修订过程


日期


版本号


修订内容


2015/02/02


V1.0


初始版本,初步仿真正确


简介


?

本程序基于MATLAB 2014a 编写,本文档中提到的"MATLAB"均指该特定版本MATLAB。本文提到的LDPC编码均指二进制LDPC编码,多进制暂时不进行讨论。

LDPC(低密度奇偶校验)编码,顾名思义有两个特性:纠错编码采用奇偶校验,该种编码方式具有低密度的特点。在学习LDPC编码之前,必须要对线性分组码的基本概念有详细的了解,包括线性分组码的映射思想、生成矩阵、校验矩阵等。这部分内容可参考《通信原理》等书籍。有限域上的编码可不做了解,这一点我现在也不懂。

低密度的意思是对于校验矩阵H而言,1的个数远小于0的个数。这对于译码算法而言是至关重要的,这表现在两个方面。其一是对于一个大的校验矩阵而言,太多的1会导致计算上的困难;其二是译码算法(此处特指置信传播类算法)中的很多假设实际上是不成立的,在H不满足低密度约束下对其性能会有很大影响。

LDPC的置信传播算法包括以下假设:

  • Tanner图无环
  • 各个校验方程独立
  • 矩阵设计过程中各个码字距离足够远
  • 计算条件边缘概率(?)
  • 其他

关于置信传播的具体原理和假设将在《学习笔记:LDPC编译码基本原理》中做具体阐述,此处不再详细说明。(由于《学习笔记:LDPC编译码基本原理》还未开始撰写,该部分内容可能会有较大变动)


程序设计


?

程序结构

校验矩阵和编码程序已经给定程序(脚本)按顺序由以下几个部分构成

  • 参数设置
  • 随机序列(数据)生成和编码
  • AWGN信道仿真
  • 译码程序
  • 误比特数等信息统计

校验矩阵已知,且命名为H(800,480).mat,采用load(‘H(800,480).mat‘)即可载入,校验矩阵为H。随机序列(数据)生成和编码采用ldpcencoder(H)调用函数,返回数据及其编码。本文仅对AWGN信道和译码程序做说明。

?

AWGN信道

加性高斯白噪声信道,说明信道的仿真只需要加上一个高斯白噪声就可以了。"白"意味着任意两个不同时刻的噪声都是不相关的,"高斯"即服从高斯分布,满足这两个要求很简单,采用randn生成一组序列即可。唯一不确定的就是噪声的方差了。

对于零均值信号而言,方差代表的就是功率。问题就转变成了如何通过EbN0计算噪声的功率?EbN0是一个比值,每比特能量/噪声功率谱密度。如果我们将信号功率归一化,那么噪声功率就是信噪比SNR的倒数。

在本程序中,校验矩阵为480×800(比特速率为码速率的0.4),采样频率等于码速率(带宽为采样频率的一半),因此有

SNR_dB = EbN0_dB((nEbN0)) + 10*log10(2)+10*log10(0.4);

?

译码程序编写思想(置信传播为例)

译码算法实际上是很简单的,问题在于呢,如何早到那些要乘的数。就是下式中所表现的 集合中的数据

对于这个问题,有两个考虑方式:

1. 传播都是在边上的,那么从边入手。

H矩阵中有多少个非零元素,就有多少条边,记为L。对于每一条边而言,用两个个长度也为L的向量保存边所连接的变量节点和校验节点的编号(r_Mark,c_Mark)。

初始化:

变量节点传递的信息是P(X|Y),那么只需要知道边所对应的变量节点(c_Mark(l))就知道了传递的信息。

迭代:

对于每一次的迭代,从第一条边开始。找出边的r=r_Mark(l),之后找到所有的r_Mark = r的边,计算校验节点的信息。

同理计算变量节点传播的信息

判决

……

?

问题在于:

找在MATLAB中采用find就可以了,但是复杂度到底是多少呢?每个循环都要find一下实在是太浪费了……

?

2. 利用H矩阵的天然结构

也就是说实际上我们要取的集合是H对应的每一行或每一列的数。如果我们采用和H矩阵完全相同的方式去构造信息传递的两个矩阵,那么在寻址的过程中将会容易很多。

想法1对应的程序是ldpcdecoderbp1和ldpcdecoderminsum,想法2对应的程序是ldpcdecoderbp2和ldpcdecoderminsum2。实验证明,程序对应的校验矩阵如本代码所附时,采用方式1运行效率高。



算法


?

置信传播

以下内容是置信传播算法的编程具体实现方式,按上述思路1编写对应ldpcdecoderbp1

LDPC译码过程可以用Tanner图直观表示,如图 1所示,接收到的序列表示为 ,校验节点为 ,我们要求的是 的条件后验概率。

图 1 Tanner图

?

本文不叙述过多原理性问题,仅列出计算步骤,此处假定编码后的星座映射为

1.初始化:(P0,P1 = 1-P0)

2.校验消息处理:(校验节点传递信息rmn0,rmn1 = 1-rmn0)

????

3.变量消息处理:(k为归一化常数)

????

4.译码判决:(求0,1后验概率之比值qn0_1,大于1判决为0)

????

如果满足 或达到最大迭代次数,返回译码后结果,退出循环;否者回到步骤2。

最小和算法

以下内容是最小和算法的编程具体实现方式,按上述思路2编写,对应ldpcdecoderminsum2。

对于最小和算法,尤其要注意的是发送端的映射关系。对于置信传播算法而言,如果把关系搞错了,会发现误码率大约是1减正确情况下误码率,这个时候很快就能发现毛病所在;但在最小和中,弄错了的话,误码率会变得怪怪的。

最小和算法本质上和置信传播没有什么区别。正如我们所观察到的,置信传播算法中有两个可以改进的地方:其一是对于概率来说,不是0就是1,没有必要采用两组变量,更好的选项可能是采用比值的形式;其二是算法中采用的乘法取对数之后会变成加法,这样能减少运算量。从这两点出发,提出了对数似然比算法,最小和算法实际上是对数似然比算法的近似。

同置信传播算法的前提假设,但以想法2为例,最小和算法阐述如下。

1.初始化: (按校验矩阵结构对应vl至vnm)

2.校验消息处理:(校验节点传递信息unm)

????

3.变量消息处理:(变量节点)

????

4.译码判决:(qn0_1,大于0判决为0)

????

如果满足 或达到最大迭代次数,返回译码后结果,退出循环;否者回到步骤2。



改进思路


?

改进的意思是这一程序是对的,但是能够做得更好。译码程序的初步验证过程是将EbN0设置为一个较大的值,在这一情况下迭代次数应该是1。很显然这里的四个译码函数都完成了这一个测试,但是否真正无误还有待更进一步的考验。

做得更好的"好"往往是必须有一个标准的,如果我们将程序计算复杂度和空间复杂度降低、且易于FPGA实现作为"好"的标准,那么可以从以下几个方面改进

  • 采用最小和算法
  • 采用了两种变量存储变量信息和校验信息,但实际上一组足以
  • 可以选择一种综合1、2想法的存储思路
  • 将1想法中需要find的取值预先存起来
  • 多参考译码器实现的学位论文
  • ……



参考


?

《LDPC码基础与应用》 贺鹤云

An Introduction to Low-Density Parity Check Codes Daniel J. Costello, Jr.


代码


……

时间: 2024-10-10 05:46:18

LDPC译码算法代码概述的相关文章

算法相关概述

算法概述 从字面意义上理解,算法(Algorithm)就是用于计算的方法,并通过这种方法可以达到预期的计算结果.算法的专业解释:算法是解决实际问题的一种精确描述的方法,算法是对特定问题的求解步骤的一种精确描述方法.但更广泛认可的算法专业定义:算法是模型分析的一组可行的.精确的和有穷的规则. 通俗的讲,算法可以理解为一个完整的解题步骤,由一些基本运算和规定的运算顺序而构成.通过这样的解题步骤可以解决特定的问题.从计算机程序设计的角度看,算法由一系列求解问题的指令构成,能够根据规范的输入,在有限的时

无锁算法CAS 概述

无锁算法CAS 概述 JDK5.0以后的版本都引入了高级并发特性,大多数的特性在java.util.concurrent包中,是专门用于多线并发编程的,充分利用了现代多处理器和多核心系统的功能以编写大规模并发应用程序.主要包含原子量.并发集合.同步器.可重入锁,并对线程池的构造提供了强力的支持. 原子量是定义了支持对单一变量执行原子操作的类.所有类都有get和set方法,工作方法和对volatile变量的读取和写入一样.并发集合是原有集合框架的补充,为多线程并发程序提供了支持.主要有:Block

大数据推荐系统算法代码全接触(企业内训,现场实录,机器学习算法+Spark实现)

[学途无忧网]大数据推荐系统算法代码全接触(企业内训,现场实录,机器学习算法+Spark实现)课程下载:https://pan.baidu.com/s/1piCNIxC2Sv0zMY0yWxY9Ug 提取码:b10v 一.课程简介: 推荐系统是利用电子商务网站向客户提供商品信息和建议,帮助用户决定应该购买什么产品,模拟销售人员帮助客户完成购买过程.个性化推荐是根据用户的兴趣特点和购买行为,向用户推荐用户感兴趣的信息和商品.随着电子商务规模的不断扩大,商品个数和种类快速增长,顾客需要花费大量的时间

算法数据结构01 /算法数据结构概述

目录 算法数据结构01 /算法数据结构概述 1. 算法 2. 评判程序优劣的方法 3. 时间复杂度 4. 数据结构 5. python数据结构性能分析 6. 总结 算法数据结构01 /算法数据结构概述 1. 算法 算法概述 算法是计算机处理信息的本质,因为计算机程序本质上是一个算法来告诉计算机确切的步骤来执行一个指定的任务.一般地,当算法在处理信息时,会从输入设备或数据的存储地址读取数据,把结果写入输出设备或某个存储地址供以后再调用. 算法是独立存在的一种解决问题的方法和思想. 对于算法而言,实

KMP算法代码实现

//普通的暴力求解法 int ViolentMatch(char* s, char* p)   {       int sLen = strlen(s);       int pLen = strlen(p);          int i = 0;       int j = 0;       while (i < sLen && j < pLen)       {           if (s[i] == p[j])           {               /

常用MD5算法代码

常用的MD5算法代码日期: 2014年8月4日作者: 铁锚 MD5,全称为 Message Digest Algorithm 5(消息摘要算法第五版).详情请参考 维基百科:MD5 MD5加密后是一个字节数组, 但我们一般是取其十六进制的字符串表示法,当然,十六进制数字符串是区分大小写,在 mysql数据库,Java,和JavaScript语言中,一般是使用小写的字符串来表示, 而在 Oracle数据库官方提供的包中,返回的是大写字符串,这算是一个坑,如果你想要执行多次 md5,可能需要转换为小

C++排序算法代码

C++的快排算法代码  #include<iostream> #include<algorithm> #include<iomanip> #include<time.h> #define N 5000 using namespace std; template <class T> void qsort(T *l,T *r) { T *i,*j,*k;   int t;   i=l;j=r-1;k=i+rand()%(r-l);   t=*k;  

java文本相似度计算(Levenshtein Distance算法(中文翻译:编辑距离算法))----代码和详解

算法代码实现: package com.util; public class SimFeatureUtil { private static int min(int one, int two, int three) { int min = one; if (two < min) { min = two; } if (three < min) { min = three; } return min; } public static int ld(String str1, String str2)

C语言快速排序算法代码分析

最近在很多场合都看见设计模式的影子,一直以来,都投入主要时间在搞算法与数据结构,很来发现设计模式真的很重要.有的时候代码的可维护.可重用.可扩展确实胜过单纯的算法效率高.所以拾起大牛书籍<大话设计模式>同时参考网上诸大牛的博客,开始我的设计模式之旅.由于平时编程时用C/C++,现在是Java,也练练Java语法. 今天先介绍一下命令模式. 概念: 命令模式(Command):将一个请求封装成一个对象,从而使你可用不同的请求对象对客户进行参数化,对请求排队或记录请求日志,以及支持可撤销的操作.