目录
- 1. LDPC码概述
- 2. LDPC码描述方法
- 2.1 校验矩阵H
- 2.2 二分图(tanner图)
- 2.3 度分布函数
- 3. LDPC码的编码方法
- 4. LDPC的译码算法
- 4.1 高斯消去法——peeling decoder(硬判决)
- 4.2 和积算法
- 4.2 置信传播算法(软判决)
- 5. 习题分析-和积算法
1. LDPC码概述
低密度校验码(LDPC码),一种前向纠错码(前向纠错指利用发送端信道编码添加冗余的方式使得接收端解码时会自动纠正传输误码)。
特点:
- 校验矩阵的稀疏性使得译码复杂度和最小码距随码长n线性增长。
- AWGN信道中的仿真结果:采用密度演进分析得到在码长趋向无穷时传输速率距离香农极限0.0045dB
2. LDPC码描述方法
LDPC属于(n,K)线性分组码
举例一个源码:→LDPC码:的过程,不妨假设,一般来说LDPC 码会更稀疏,这里仅作为一个例子供后续理解。
2.1 校验矩阵H
校验矩阵
特性:
- 每一行表示一个校验方程约束,包含k个码元
- 每一列表示一个码元参加 j个校验方程
- 任意两个校验方程包含至多一个相同码元
如果上述 j、k为常数(一般来说 k > j),即每一行都有 j 个1,每一列都有 k 个1,则为规则LDPC码,可记为(n,j,k)正则LDPC码;反之,如果每一行或者每一列中的j、k不固定(出现了不相等的情况),则为非规则LDPC码。
在sec2开篇的例子中,,显然每一列的j的数目不相等,所以这是个不规则的LDPC码编码。如果没有收到干扰,接受端 存在
2.2 二分图(tanner图)
Tanner图里有两种节点:变量节点、校验节点。变量节点对应纠错码的各个码位(信息位+校验位);校验节点就像是神经网络中中间层的节点,它负责接收、处理信号,并输出一个结果。举例中的H矩阵等价如下的Tanner图:
图二中c1、c2、c4连到校验节点s1上,表示校验方程:。
图的一些定义(后续译码算法会涉及到):
- 相互之间有连接线的节点互为邻点(Neighbor)
- 一个节点的邻点数量称为这个节点的度(Degree)
- 回路(cycle,环):从一个端点出发,经过不重复的边回到出发端点;经过的边数定义为回路的长度;图中最短回路长度称为图的周长(girth)
2.3 度分布函数
,其中表示二分图中度为i的变量节点相连的边数所占所有边数的比例。表示变量节点的最大度。
校验节点的度分布函数:,其中 表示二分图中度为i的校验节点相联的边(Edge)占所有边的比例。表示校验节点的最大度。
码率
推导:校验节点数目,求和式从边化为节点数,求和为校验节点总数,即H矩阵的行数。
同理表示变量节点的总数,即H矩阵的列数。
3. LDPC码的编码方法
构造目标:一个二进制稀疏矩阵
- 任意两行之间至多只有一个共同的位置有 ‘ 1’
- 任意两列之间至多只有一个共同的位置有 ‘ 1’
- 避免出现长度为4的环
编码衡量方法:误码率(通过仿真得到)
构造准则:
- 获得更好的误码性能
- 更大的最小码距以及降低高信噪比下的error floor
- 更均匀的环分布特性以便译码时更快更均匀的收敛
- 更规则的H矩阵结构便于工程实现
LDPC码的构造方法:
- 随机搜索法(最初论文里面的方法)
参考一:LDPC编译码原理
- 边循序增长(Progressive Edge Growth,PEG)算法——图的方法
参考二:二进制LDPC码的构造及译码算法
- 代数的方法,如基于RS码的方法
同参考二
4. LDPC的译码算法
4.1 高斯消去法——peeling decoder(硬判决)
高斯消去法是4.2中和积算法的特例,因为和积算法本身需要对单维度节点消去
4.2 和积算法
相关定义:
- 概率的对数似然比:
,其意义是概率的另外一种表现形式- 奇偶校验和的对数似然比:
校验和 即:
以BPSK为例子假设数字符号取值0,1映射为{+1,-1}编码系统中,各个符号之间存在校验和关系
利用对数似然比可以推导出:◼ 已知各个校验和的置信度,求出参与校验的各个符号的置信度
◼ 已知各个符号的置信度,求出各个校验和的置信度
数字符号 ui 遵从 N 个校验和 Sn,其中
• ui 之外的数字符号只出现一次
• ui 之外的数字符号相互独立
✓将数字符号 ui从校验和 Sn中除去,得到 “修正校验和”
•“修正校验和”的似然比➔数字符号 ui的似然比
• 校验和包含的其余符号似然比➔” 修正校验和” 的似然比其中乘积可以化简为
- 对数似然比和置信度的关系
对数似然比即概率,概率即置信度,只是表现形式不同,导致运算形式不同(概率相乘即对数似然比相加)
数字符号置信度 = 修正校验和似然比 + 先验概率似然比:
每次迭代结束之后,需要进行判决
❑ 求与有连接的所有校验节点传递给的似然比信息之和,判决
❑ 满足校验方程约束,则结束译码
❑ 不满足校验方程约束,则继续迭代
过程见习题(4)
4.2 置信传播算法(软判决)
参考blog LDPC编译码原理中的BP解码过程。
置信传播算法是基于 Tanner 图的迭代译码算法。在迭代过程中,可靠性信息,即“消息”通过 Tanner图上的边在变量节点和校验节点中来回传递,经多次迭代后趋于稳定值,然后据此进行最佳判决。译码过程是在变量节点和校验节点之间传递信息。每个变量节点告诉它所连接的校验节点“我认为该变量是什么”,而校验节点告诉它所连接的变量节点“我认为该变量应该是什么”。经过反复的消息传递后,变量节点和校验节点不断改变自己对各个变量是什么的看法,最终能形成一个满足校验方程的码字,这就是译码的结果。如果经过充分的迭代后仍然不能形成一个满足校验方程的码字,则译码器宣布它无法译出这个码字,即译码失败。
5. 习题分析-和积算法
一个简单的奇偶校验码
(1)写出其校验方程
(2)画出二分图,给出其周长
(3)计算其密度分布多项式,计算码率
(4)采用最小和算法进行解码
(1)可以定义变量节点和校验节点如下
校验方程为:
根据编码图可知校验矩阵为:
(2)根据校验矩阵,其二分图为
周长为最小环长,
, 长度为 8
(3)
(4)最小和译码的迭代公式为:
- 初始化:
- 注意初始化过程本质是信道信息的体现:
- 变量节点到校验节点,求和
- 校验节点到变量节点,求符号+最小值
- 变量节点到校验节点,求和
- 进行译码硬判决(大于0表示BPSK为+1,判0,小于0表示BPSK为-1判1):00001101,
代入校验方程: