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

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

3天内不再提示

基于VHDL的卷积编码实现 详解卷积编码的应用

ss 作者:工程师谭军 2018-08-20 16:58 次阅读

在现代数字通信中,为降低数据传输的误码率,提高通信质量及其可靠性,常在通信中采用纠错编码技术。

本文主要介绍的就是关于卷积编码的相关介绍,希望通过本文能让你对卷积编码有更深的认识。

卷积编码

在信道编码研究的初期,人们探索、研究出各种各样的编码构造方法,其中包括卷积码。早在1955年,P.Elias首先提出了卷积码。但是它又经历了十几年的研究以后,才开始具备应用价值。在这十几年期间,J.M.Wozencraft提出了适合大编码约束度的卷积码的序列译码,J.L.Massey提出了实现简单的门限译码,A.J.Viterbi提出了适合小编码约束度的卷积码Viterbi算法。20年后,即1974年,L.R.Bahl等人又提出一种支持软输入软输出(SISO,Soft-Input Soft-Output)的最大后验概率(MAP,Maximum A Posteriori)译码——BCJR算法。其中,Viterbi算法有力地推动了卷积码的广泛应用,BCJR算法为后续Turbo码的发现奠定了基础。

基于VHDL的卷积编码实现 详解卷积编码的应用

编码技术

在卷积码的编码过程中,对输入信息比特进行分组编码,每个码组的编码输出比特不仅与该分组的信息比特有关,还与前面时刻的其他分组的信息比特有关。同样,在卷积码的译码过程中,不仅从当前时刻收到的分组中获取译码信息,还要从前后关联的分组中提取相关信息。正是由于在卷积码的编码过程中充分利用了各组的相关性,使得卷积码具有相当好的性能增益。

编码器图中,编码器的每组输入包含k0个信息比特,第一组寄存器单元存储当前时刻的k0个信息比特,而其他组寄存器单元存储前面时刻的(K−1)k0个信息比特。编码器有n0个编码输出,每个编码输出Yi由当前时刻的输入信息分组以及其他(K−1)个寄存器单元内的信息分组根据相应的连接关系进行模2运算来确定。

因此,一般定义K为编码约束度,说明编码过程中相互关联的分组个数,定义 m=k-1 为编码存储级数,码率 R=k0/n0,这类码通常称为(n0,k0,K)卷积码。在许多实际应用场合,往往采用编码约束度比较小、码率为的卷积码。如图3-29所示的两种卷积码(2,1,9)和(3,1,9),它们的存储级数都是8,加法器完成二进制加法(模2加)。图中省略了存储当前时刻输入的寄存器单元。在图3-29(a)中,(2,1,9)卷积码编码器有一个输入端口、两个输出端口,这两个输出端口分别对应两个生成多项式(使用八进制表示):561和753。该码率是1/2。在图3-29(b)中,(3,1,9)卷积码编码器有一个输入端口、3个输出端口,这3个输出端口分别对应3个生成多项式(使用八进制表示):557、663和711。该码率是1/3。

TD-LTE系统中采用了(3,1,7)卷积码,存储级数是6,使用了6个寄存器。这个卷积码的主要优点包括最优距离谱、咬尾编码、译码复杂度小。具体描述见后续章节内容。另外,卷积码也可以按照其他方式进行分类,比如系统码或者非系统码,递归码或者非递归码,最大自由距离码或者最优距离谱码。常用的卷积码一般是非递归的非系统码,而Turbo码常常使用递归的系统卷积码。

咬尾编码通常卷积码编码器开始工作时都要进行初始化,常常将编码器的所有寄存器单元都进行清零处理。而在编码结束时,还要使用尾比特进行归零的结尾操作(Tailed Termination)。相对于编码比特而言,尾比特增加了编码开销。TD-LTE系统的卷积码编码器采用了咬尾编码方法。

编码器开始工作时要进行特殊的初始化,将输入信息比特的最后m个比特依次输入编码器的寄存器中,当编码结束时,编码器的结束状态与初始状态相同。由于这个编码方法没有出现尾比特,因此称为咬尾编码。咬尾编码减少了尾比特的编码开销。对于咬尾编码方法,在译码过程中,由于编码器的初始状态和结尾状态是未知的,因此就需要增加一定的译码复杂度,才能确保好的译码性能。3.性能界卷积码的性能一般使用误比特率(BER,Bit Error Rate)来统计,其理论上界(Upper Bound)一般使用联合界(Union Bound)来确定,即(3-13)其中,卷积码的转移函数(Transfer Function),代表非零输入信息比特的转移分支,Y的指数表示输入信息比特的汉明重量,Z代表输出编码比特的转移分支,Z的指数表示输出编码比特的汉明重量。为了进一步分析上述性能界,一般假设最大似然译码(ML,Maximum-Likelihood)、BPSK调制和加性高斯白噪声(AWGN,Additive White Gaussian Noise)信道,则有

(3-14)其中,Bd是所有重量为d的码字的非零信息比特的重量,为卷积码的自由距离。当信噪比很高时,则式(3-14)近似为(3-15)BPSK调制性能为(3-16)考虑到误码性能主要是指数项占据主导作用,与未编码系统相比,卷积码的编码增益为(3-17)式(3-17)说明卷积码的渐近性能主要是由自由距离()决定的。因此,相对而言,卷积码的自由距离越大,其性能越好。以上述二进制卷积码(2,1,9)和(3,1,9)为例,自由距离分别为12和18,编码增益都为7.78dB。实际上,性能最佳的卷积码往往具有最优的距离谱(ODS,Optimum Distance Spectrum)或者重量分布,而且,具有最优距离谱的卷积码也具有最大的自由距离(MFD,Maximum Free Distance)。TD-LTE系统采用了最优距离谱的卷积码。

基于VHDL的卷积编码实现

在现代数字通信中,为降低数据传输的误码率,提高通信质量及其可靠性,常在通信中采用纠错编码技术。其中卷积码就是一种具有较强纠错能力的纠错码。由于 Vitebrbi 译码算法比较容易实现,卷积码得到了广泛应用。本课题简明地介绍了用 EDA 技术实现卷积码编码器的实现。 卷积码纠错性能常常优于分组码,是一种性能优越的信道编码。由于码字之间的相关性,其编码器要利用移位寄存器来存储状态。

随着纠错编码理论研究的不断深入,卷积码的实际应用越来越广泛。卷积码作为通信系统中重要的编码方式,以其良好的编码性能,合理的译码方式,被广泛应用。本文在阐述卷积码编码器基本工作原理的基础上,给出了(2,1,2)卷积编码器的 VHDL 设计,在QuartusⅡ环境下进行了波形功能仿真,并下载到 EP1C6T144C8N 芯片上进行验证,最终实现输入四位序列,编码输出八位通过指示灯显示。

基于VHDL的卷积编码实现 详解卷积编码的应用

卷积编码的编码约束长度定义为:串行输入比特通过编码其所需的移位次数,它表示编码过程中相互约束的分支码数,所以具有m级移位寄存器的编码器得约束长度为m十1,有时也说(m十1)n为卷积编码的编码约束长与分组编码一样。

卷积编码的编码效率也定义为R=k/η,与分组码具有固定码长η不同,卷积码没有,我们可通过周期性地截断来获得分组长度为了达到清空编码移位寄存器数据bit的目的,需要在输入数据序列末尾附加若于0bit。由于附加的0不包含任何信息,因而,有效编码效率降至kn以如果截断周期取值较大,则有效编码效率会逼近kn。

基于VHDL的卷积编码实现 详解卷积编码的应用

图中的小框表示寄存器的状态,连接小框的箭头表示状态转移的方向,两线旁的数字表示:输出分支码字/输入信息比特。状态图简明的表示了在某一时刻编码器的输入比特和输出分支码字的关系。

结语

关于卷积编码的相关介绍就到这了,如有不足之处欢迎指正。

相关阅读推荐:什么是卷积码

相关阅读推荐:什么是卷积

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

    关注

    30

    文章

    817

    浏览量

    128119
  • 卷积编码
    +关注

    关注

    0

    文章

    13

    浏览量

    2642
收藏 人收藏

    评论

    相关推荐

    咬尾卷积编码是什么?如何实现咬尾卷积编码

    咬尾卷积码的原理是尾卷积码保证格形起始和终止于某个相同的状态。它具有不要求传输任何额外比特的优点。
    发表于 08-21 09:11 8189次阅读
    咬尾<b class='flag-5'>卷积</b><b class='flag-5'>编码</b>是什么?如何<b class='flag-5'>实现</b>咬尾<b class='flag-5'>卷积</b><b class='flag-5'>编码</b>?

    有没有Labview编的gold码生成VI以及RS编码卷积编码的VI啊?

    最近在做扩频调制,有没有Labview编的gold码生成VI以及RS编码卷积编码的VI啊?
    发表于 05-10 14:47

    如何实现CDMA2000系统前向链路卷积编码器?

    为了缩短卷积编码器设计周期,使硬件设计更具灵活性,在介绍卷积编码器原理的基础上,论述了一种基于可编程逻辑器件,采用模块化设计方法,利用VHDL
    发表于 08-27 07:41

    FPGA卷积编码1/2码率

    这是verilog写的可以实现卷积编码1/2码率的代码,附带测试文件0
    发表于 01-20 18:23 1次下载

    基于卷积LDPC码编码凿孔算法

    为设计出可近容量限传输且能普适应用于慢、快衰落信道下的编码协作方案,研究了基于卷积LDPC码的编码协作。基于卷积LDPC码的凿孔算法构造出可2路传输的分码字,
    发表于 01-16 14:38 0次下载
    基于<b class='flag-5'>卷积</b>LDPC码<b class='flag-5'>编码</b>凿孔算法

    卷积编码与分组编码的区别及应用案例

    卷积码又称连环码,他是非分组(没有固定长度)有记忆编码,但也是一种线性码,码的结构简单,其性能在许多实际情况优于分组码,通常更适用于向前纠错,是一种较为常见的纠错编码
    发表于 08-20 14:53 9949次阅读

    卷积编码码率是什么?怎么计算

    卷积码是一种差错控制编码,由P.Elias于1955年发明。因为数据与二进制多项式滑动相关故称卷积码。
    发表于 08-20 15:11 2.1w次阅读
    <b class='flag-5'>卷积</b><b class='flag-5'>编码</b>码率是什么?怎么计算

    卷积编码器怎么画 浅谈卷积编码器设计

    卷积码拥有良好的纠错性能,是一种被广泛应用于移动通信的信道编码系统。
    的头像 发表于 08-20 15:30 1.4w次阅读
    <b class='flag-5'>卷积</b>码<b class='flag-5'>编码</b>器怎么画 浅谈<b class='flag-5'>卷积</b>码<b class='flag-5'>编码</b>器设计

    基于C语言的卷积编码实现 浅谈卷积和滤波之区别

    在信道编码研究的初期,人们探索、研究出各种各样的编码构造方法,其中包括卷积码。
    发表于 08-21 08:31 3308次阅读

    浅谈卷积编码在通信中的应用 详解卷积编码设计应用

    通过以上两种分析都可以得到卷积的结果。回头看上边的卷积机器,将脉冲响应考虑为一组权重系数,在这种观点下每个输出信号采样点等于权重输入之和。
    的头像 发表于 08-21 08:49 8549次阅读
    浅谈<b class='flag-5'>卷积</b><b class='flag-5'>编码</b>在通信中的应用 <b class='flag-5'>详解</b><b class='flag-5'>卷积</b><b class='flag-5'>编码</b>设计应用

    浅谈卷积编码在DSL中的应用 详解卷积编码编码技术

    卷积码是一种差错控制编码,由P.Elias于1955年发明。因为数据与二进制多项式滑动相关故称卷积码。
    发表于 08-21 09:20 2585次阅读
    浅谈<b class='flag-5'>卷积</b><b class='flag-5'>编码</b>在DSL中的应用 <b class='flag-5'>详解</b><b class='flag-5'>卷积</b><b class='flag-5'>编码</b><b class='flag-5'>编码</b>技术

    卷积编码之维特比译码介绍 浅析卷积码之应用

    以(n,k,m)来描述卷积码,其中k为每次输入到卷积编码器的bit数,n为每个k元组码字对应的卷积码输出n元组码字,m为编码存储度,也就是
    发表于 08-21 09:56 3445次阅读

    卷积编码及译码实验 浅谈卷积编码下的FPGA实现

    卷积编码是现代数字通信系统中常见的一种前向纠错码,区别于常规的线性分组码,卷积编码的码字输出不仅与当前时刻的信息符号输入有关,还与之前输入的信息符号有关。
    的头像 发表于 08-21 10:26 8305次阅读
    <b class='flag-5'>卷积</b>码<b class='flag-5'>编码</b>及译码实验 浅谈<b class='flag-5'>卷积</b><b class='flag-5'>编码</b>下的FPGA<b class='flag-5'>实现</b>

    卷积编码译码程序仿真程序 卷积码应用详解

    卷积码是一种差错控制编码,由P.Elias于1955年发明。因为数据与二进制多项式滑动相关故称卷积码。
    发表于 08-21 10:34 4096次阅读
    <b class='flag-5'>卷积</b>码<b class='flag-5'>编码</b>译码程序仿真程序 <b class='flag-5'>卷积</b>码应用<b class='flag-5'>详解</b>

    深度解读VHDL语言的卷积码和Viterbi译码的实现

    介绍并用VHDL语言实现卷积编码和维特比译码。根据编码器特征设计了一种具有针对性的简洁的维特比译码器结构,
    的头像 发表于 05-12 15:22 2487次阅读
    深度解读<b class='flag-5'>VHDL</b>语言的<b class='flag-5'>卷积</b>码和Viterbi译码的<b class='flag-5'>实现</b>