0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于BCJR算法的MAP译码器嵌入式系统的应用设计

电子设计 来源:中国集成电路 作者:李丁,胡剑浩 2020-12-08 10:16 次阅读

1.引言

无线通信系统中,可靠的数据传输是一个非常重要的论题。Turbo编码得到逼近香农限的译码性能,成为研究和应用的热点。Turbo码的译码采用迭代运算的方式,即将前级译码器的输出作为外信息输入到本级译码运算,如此反复进行直到达到相应收敛度才结束译码。

Turbo码有多种译码算法,基于Bahl-Cocke-Je-linek-Raviv(BCJR)算法的MAP译码是最为广泛应用的一种。MAP算法可以通过系统信息和外信息来获得对一个比特良好的概率估计,其译码输出的信息可以作为外信息由其他译码器在下一次迭代过程中使用。经过一定次数的迭代运算之后,对外部信息的运输结果收敛时,译码器盼陛能逼近香农限。

尽管Turbo码的性能接近最优值,但在实际集成电路硬件设计中,对于MAP算法的实现面临两个主要问题:

(1)时间延迟过大。

(2)对于存储器容量空间需求大。

MAP译码器采用迭代的方式工作,即在每次迭代过程中,MAP译码器首先利用前一次迭代中得到的外信息和信道接收信息,对待译码的码字从头部到尾部再从尾部到头部两个方向收集译码信息;利用收集到的译码信息,译码器做最大释然估计,估计值可以作为其他译码器做下一次迭代过程中的外信息使用。对于比特长度为n的数据帧,前向和后向的信息提取共需2n步处理,另外估计数据需要n步。从而MAP算法共需要3n步操作,因此其译码延迟较大。MAP译码器在新的外部信息生成之前需要保存之前所有的译码信息,对于一个长度为n比特的数据帧,且Turho码空间为S,则需要2×n × S个存储单元来保存信息。例如,在CDMA2000系统中的Turbo码中S=8,且n=20730,则MAP译码器需要331680个存储单元,这对于存储器的需求压力较大。为了降低对存储空间的要求以及提高MAP及其改进算法Log_MAP[3,4]的度量信息计算速度,本文提出了嵌入式度量存储(ESMS)。

本文内容组织结构如下:在第二部分介绍了Log_MAP算法;第三部分介绍了ESMS方法;第四部分给出ESMS方法的性能分析;第五部分是我们的结论。

2.Log_MAP算法

Turbo编码器根据编码约束关系利用源数据比特形成冗余的校验比特,源数据比特与校验比特形成码字一同被发送。接收机收到的是被噪声“污染”了的码字,MAP译码器根据编码约束关系对接收数据从头部到尾部扫描得到前向搜索网格状态信息,然后从尾部到头部扫描得到反向搜索网格状态信息。译码器通过得到的网格状态信息从所有可能路径中找到最佳译码路径,最佳路径即是对所有输人数据的最佳估计的译码路径。

每个译码器的输出为码字中每个比特的估计概率概率值,常用对数释然比(LLR)来表示,第k个比特的LLR定义为:

基于BCJR算法的MAP译码器嵌入式系统的应用设计

可以使用下面的公式简化Log_MAP算法中的幂运算。

在实际应用中,In(1+exp(-|b-a|))可以用查找表来实现。研究表明长度为8的表可以提供足够的精确度。在Log_MAP算法中对网格信息的归一化操作如下:

3.嵌入式状态信息存储(ESMS)

根据Log_MAP算法的原理,每步中的状态信息为0到负无穷间的一组数(实际应用中为0到一个有界的负数之间)。一个状态的度量接近0意味着该状态最优译码路径上的正确的状态的概率最大。如果αk(s)是最大值,αk(s)=0,s为前向搜索第k步正确状态的概率最大。如果βk(s)是最大值,βk(s)=0,s是反向搜索第k步正确状态的概率最大。

从(9)式可知,LLek的值取决于{αk-1(s′)}中的最大值和{βk-1(s′}中的最大值。如果编码器的输出为dsk=+1且译码器的估计正确,则LLek为正。如果编码器的输出为dsk=-1且译码器的估计正确,LLek为负。LLek的绝对值越大,第k步估计为正确估计的概率越大。如果LLek最大值与次大值之差越大,LLek会越快收敛于正确估计。因此,译码的关键在于得到最大信息的状态,而状态信息的绝对值不影响结果,即这个最大值是否为0并不影响结果。

在Log_MAP译码算法中使用模圆周上的相对位置的状态信息度量而不是绝对位置的度量。令

由此,我们将状态转移到了新的位置,这里αk(0)和βk(0)永远为0。因此不需要存储{αk(0)}={α0(0), α1,(0)……αtength(0)和{β(0)}={β0(0),β1,(0)……βtength(0)。我们将这种技术称为嵌入式状态信息存储(ESMS)。它可以降低实际应用对存储器的要求。

ESMS使用二进制补码加法器和减法器。使用ESMS技术需要对Log_MAP算法进行如下修改。

3.1状态度量信息更新

在ESMS度量更新的时候同时完成归一化操作,因此,在ESMS归一化过程中,不需要搜索每一步的最大状态信息,从而可以降低VLSI应用中的延迟和面积。

3.2外信息计算

由于在计算状态信息和外信息的过程中,αk(0)和βk(0)始终为0,所以相关的运算可以省略;因此ESMS可以减少译码运算量。

4.性能分析

本文使用仿真来分析ESMS技术的性能。仿真中采用CDMA2000标准中的turbo码,。为性能评价,在设计数据路径时采用了Synopsys作为综合器。为了比较,同时采用了传统的Log_MAP算法。从而得出结论使用了ESMS技术的Log_MAP算法的译码器可以达到传统算法相同的性能。表3列出了采用ESMS技术的Log_MAP算法的译码器,采用MEPMUM技术的译码器以及采用传统方法译码器为存储度量信息所要求的存储器空间数值。从表3中显示MEPMUM和ESMS能极大的降低存储器用量,且ESMS能协助MEPMUM降低12.5%的存储器空间。

采用了ESMS和传统方法两种应用来实现Log_MAP译码器。为了比较,应用还采用了智能归一化[8]的Log_MAP译码器。在综合中选择速度最优化选项。表4列出了综合结果。表4显示智能归一化和ESMS相比传统方式能减少超过36%的面积和17%的延迟。采用了ESMS技术的Log_MAP算法比智能归一化实现多降低了1%的面积和延迟,但相比存储器空间竞降低了12.5%。因此,本文提出的这种新技术ESMS能够使Log_MAP译码器运算更快,面积更小,存储器空间消耗更小。

5.结论

本文提出的嵌入式状态信息存储技术能够提高Turbo译码器的运算速度,并减小面积占用,这种状态信息存储机制能够用于Log_MAP和Max-Log_MAP译码器的ASICFPGA设计中。

责任编辑:gt

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5087

    文章

    19145

    浏览量

    306111
  • 存储器
    +关注

    关注

    38

    文章

    7514

    浏览量

    163994
  • 译码器
    +关注

    关注

    4

    文章

    311

    浏览量

    50382
收藏 人收藏

    评论

    相关推荐

    基于IP核的Viterbi译码器实现

    【摘要】:Viterbi译码器在通信系统中应用非常普遍,针对采用DSP只能进行相对较低速率的Vit-erbi译码的问题,人们开始采用FPGA实现高速率Viterbi译码。本文首先简单描
    发表于 04-26 16:08

    译码器定义

    译码器1. 译码器定义译码器是一种用以检测输入位(码)的特定组合是否存在,并以特定的输出电平来指示这种特定码的存在的数字电路。——《数字电子技术基础系统方法》
    发表于 12-07 09:37

    基于MAP嵌入式MP3播放设计与实现

    基于MAP嵌入式MP3播放设计与实现:多媒体应用处理简称MAP,是一种适用于便携数字音视
    发表于 08-02 14:50 38次下载

    基于DSP的Max-Log-MAP算法实现与优化

    Turbo 码的工程应用与实现是近年来研究工作的热点。Turbo 码采用反馈迭代译码结构,成员译码器使用最大后验概率(MAP)译码算法
    发表于 11-27 15:15 7次下载

    译码器

    译码器 译码是编码的逆过程,即将某个二进制翻译成电路的某种状态。实现译码操作的电路称为译码器
    发表于 09-27 12:59 1.4w次阅读
    <b class='flag-5'>译码器</b>

    数码译码器的应用

    数码译码器的应用:译码器课件ppt
    发表于 12-17 14:31 1143次阅读
    数码<b class='flag-5'>译码器</b>的应用

    译码器,译码器是什么意思

    译码器,译码器是什么意思 译码器是组合逻辑电路的一个重要的器件,其可以分为:变量译码和显示译码两类。  变量
    发表于 03-08 16:32 5494次阅读

    Viterbi译码器回溯算法实现

    该文介绍了两种Viterbi 译码器回溯译码算法,通过对这两种算法硬件实现结构上的优化,给出了这两种算法的FPGA 实现方法,比较了两种实现
    发表于 05-28 15:18 33次下载
    Viterbi<b class='flag-5'>译码器</b>回溯<b class='flag-5'>算法</b>实现

    基于MAP嵌入式MP3播放设计与实现

    多媒体应用处理简称MAP,是一种适用于便携数字音视频设备的新型嵌入式应用处理。 文中介绍了MAP
    发表于 08-07 13:57 1153次阅读

    基于FPGA的RS码译码器的设计

    介绍了符合CCSDS标准的RS(255,223)码译码器的硬件实现结构。译码器采用8位并行时域译码算法,主要包括了修正后的无逆BM迭代译码
    发表于 01-25 16:43 68次下载
    基于FPGA的RS码<b class='flag-5'>译码器</b>的设计

    Max-Log-Map算法优化

    ,如何实现高性能的Turbo码译码器,成为第三代移动通信系统开发中接收机基带处理部分的重点和难点之一。Turbo译码器中的分量译码器的实现算法
    发表于 10-31 10:24 14次下载
    Max-Log-<b class='flag-5'>Map</b><b class='flag-5'>算法</b>优化

    译码器的逻辑功能_译码器的作用及工作原理

    本文首先介绍了译码器的定义与译码器的分类,其次介绍了译码器的作用和译码器的工作原理,最后介绍了译码器的逻辑功能。
    发表于 02-08 14:04 11.5w次阅读
    <b class='flag-5'>译码器</b>的逻辑功能_<b class='flag-5'>译码器</b>的作用及工作原理

    译码器的分类和应用

    本文主要介绍了译码器的分类和应用。译码器指的是具有译码功能的逻辑电路,译码是编码的逆过程,它能将二进制代码翻译成代表某一特定含义的信号(即电路的某种状态),以表示其原来的含义。
    的头像 发表于 04-04 11:51 4.3w次阅读
    <b class='flag-5'>译码器</b>的分类和应用

    嵌入式系统教程之嵌入式系统的IO模块详细资料说明

    本文档的主要内容详细介绍的是嵌入式系统教程之嵌入式系统的IO模块详细资料说明包括了:1 复位电路,2 时钟,3 I/O模块,4
    发表于 06-14 17:14 8次下载
    <b class='flag-5'>嵌入式</b><b class='flag-5'>系统</b>教程之<b class='flag-5'>嵌入式</b><b class='flag-5'>系统</b>的IO模块详细资料说明

    如何使用FPGA实现跳频系统中的Turbo码译码器

    给出了跳频系统中 Turbo码译码器的FPGA( field programmable gate array)实现方案。译码器采用了MaxLog-map
    发表于 04-01 11:21 5次下载
    如何使用FPGA实现跳频<b class='flag-5'>系统</b>中的Turbo码<b class='flag-5'>译码器</b>