加载中
加载中
表情图片
评为精选
鼓励
加载中...
分享
加载中...
文件下载
加载中...
修改排序
加载中...
【代码】LDPC校验矩阵转换到alist格式
warmonkey2018/11/27电子技术 IP:广东

title: converting ldpc parity matrix to alist format (for gnuradio ldpc encoder use)

LDPC(低密度奇偶校验码)是通信中常用的FEC(前向纠错)编码之一。

GnuRadio的LDPC编解码器接受的输入格式是alist格式的校验矩阵(通常记作H矩阵),本文提供了将H矩阵转换为alist格式的工具。

alist是一种通用的稀疏矩阵存储格式,具体定义见 www.inference.org.uk/mackay/codes/alist.html

可用以下matlab代码将矩阵x转换为alist,并保存到名字为filename的文件。

Other
function write_alist(x, filename) n = size(x,1); m = size(x,2); num_nlist = sum(x,1)'; num_mlist = sum(x,2); biggest_num_m = max(num_mlist); biggest_num_n = max(num_nlist); for i = 1:n nlist{i} = find(x(i, :) > 0); end for i = 1:m mlist{i} = find(x(:, i) > 0)'; end fd = fopen(filename, 'w'); fprintf(fd, '%d %d\n', n, m); fprintf(fd, '%d %d\n', biggest_num_n, biggest_num_m); fprintf(fd, '%d ', num_nlist); fprintf(fd, '\n'); fprintf(fd, '%d ', num_mlist); fprintf(fd, '\n'); for i=1:length(nlist) fprintf(fd, '%d ', nlist{i}); fprintf(fd, '\n'); end for j=1:length(mlist) fprintf(fd, '%d ', mlist{j}); fprintf(fd, '\n'); end fclose(fd); end

调用示例:

Other
% convert sparse matrix to alist format % http://www.inference.org.uk/mackay/codes/alist.html clear all; x= [0 0 1 0 0 0 0 1 0 1 0 0 1 0 0 0; 0 0 0 1 0 0 1 0 1 0 0 0 1 0 0 0; 0 1 0 0 1 0 1 0 0 1 0 0 0 0 0 0; 0 0 0 1 0 1 0 0 0 0 1 0 0 1 0 0; 0 0 1 0 0 0 0 0 1 0 0 0 0 0 1 1; 1 0 0 0 0 1 0 0 1 1 0 0 0 0 0 0; 0 0 0 1 0 0 0 1 0 0 0 1 0 0 1 0; 0 1 0 0 0 1 0 0 0 0 0 1 0 0 0 1; 1 0 0 0 0 0 1 0 0 0 0 0 0 1 0 1; 0 0 1 0 1 0 0 0 0 0 0 1 0 1 0 0; 0 1 0 0 0 0 0 0 0 0 1 0 1 0 1 0; 1 0 0 0 1 0 0 1 0 0 1 0 0 0 0 0;]; write_alist(x, 'x.alist');

输出结果与原文链接中的例子完全一致。


======TODO:补充CCSDS C2 LDPC 7/8的例子=====

来自:电子信息 / 电子技术
1
4
新版本公告
~~空空如也

想参与大家的讨论?现在就 登录 或者 注册

所属专业
所属分类
上级专业
同级专业
warmonkey
学者 机友
文章
363
回复
8010
学术分
12
2008/10/11注册,1天12时前活动

Cubesat

主体类型:个人
所属领域:无
认证方式:手机号
IP归属地:未同步
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

笔记
{{note.content}}
{{n.user.username}}
{{fromNow(n.toc)}} {{n.status === noteStatus.disabled ? "已屏蔽" : ""}} {{n.status === noteStatus.unknown ? "正在审核" : ""}} {{n.status === noteStatus.deleted ? '已删除' : ''}}
  • 编辑
  • 删除
  • {{n.status === 'disabled' ? "解除屏蔽" : "屏蔽" }}
我也是有底线的