5G LDPC编码器IP设计

特性列表

1.支持5G NR协议中BG1、BG2两种编码矩阵,以及51种lifting size(Zc)。

2.支持可变的输入信息位长度,BG1时支持的信息位长度为1-22个lifting size;BG2时支持的信息位长度为1-10个lifting size。

3.支持矩阵前两列对应的信息位是否打孔的配置。

4.支持编码校验位长度可配,BG1时支持的校验位长度为1-22个lifting size;BG2时支持的校验位长度为1-10个lifting size。

资源占用

LUTsFFsBRAMs(36K)
653641297.5

有需要或问题的可私信我。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
5G LDPC编码C代码是一种在5G通信中使用的编码方式,它可以有效提高通信的可靠性和稳定性。该编码方式通过将信息进行分块,然后对每个块进行矩阵乘积计算。这个矩阵乘积可以使用高效的LDPC编码算法来完成。以下是5G LDPC编码C代码的实现步骤: 1.定义需要编码的信息块和LDPC编码矩阵 2.对信息块进行分块,每个块的大小等于矩阵的列数 3.用分块后的信息块乘以LDPC编码矩阵,得到密文矩阵 4.将密文矩阵转换为二进制位流,用于传输或存储 具体的C代码实现可以参考以下步骤: 首先定义矩阵和分块大小: #define MAT_COL 2304 #define MAT_ROW 1920 #define BLK_SIZE 384 然后定义信息块和LDPC编码矩阵: unsigned char blk[BLK_SIZE]; unsigned char mat[MAT_ROW][MAT_COL]; 对信息块进行分块: for(int i=0; i<BLK_SIZE; i++) { blk[i] = (unsigned char)i; } int blk_cnt = 2 * MAC_COL / BLK_SIZE; for(int i=0; i<blk_cnt; i++) { encode_block(blk + i*BLK_SIZE); } 进行矩阵乘积计算: static void encode_block(unsigned char blk[]) { unsigned int i, j, s; int val; for (i = 0; i < MAT_ROW; i++) { s = 0; for (j = 0; j < BLK_SIZE; j++) { if (blk[j]) { val = mat[i][j] * blk[j]; s += val; } } blk[i+BLK_SIZE] = s % 2; } } 最后将密文矩阵转换为位流: for(int i=0; i<out_len; i++) { *out++ = (unsigned char)out_mat[i/8]; } 以上就是通过LDPC编码实现5G通信中的编码C代码的方法,它可以提高通信的可靠性,并保证数据传输的稳定性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值