采用汇编语言的BCH解码校验算法

发布者:化羽2015最新更新时间:2011-11-02 关键字:汇编语言  BCH码  伽罗华域  解码校验 手机看文章 扫描二维码
随时随地手机看文章

  在信号传输中,BCH码以其独特的优点被广泛应用于微机级的通信中,但因其算法复杂,通常只用在动态实时的无线通信中,而对更底层的单片机级的信号传输纠错,往往只采用奇偶校验等简单的校验方法。本文结合一些测控系统和监控系统的开发,摸索出了在实时动态单片机中的BCH解码检纠方法,并通过汇编语言加以实现,取得了一定的效果。下面以BCH(15,7)码为例进行探讨。

1  BCH码在单片机中的放置结构

  BCH码作为一种检纠能力较强的循环码,由信息多项式i(x)和监督多项式j(x)组成。这里以c(x)表示整个BCH(15,7)码的15位码组多项式,则有:

按此在新窗口浏览图片

  在单片机中其放置的具体结构如下:

按此在新窗口浏览图片

  其中,7位信息位放入寄存器R3中,8位监督位放入寄存器R4中。

2  BCH解码校验原理

  二元BCH(15,7)码的解码校验原理是在时域上直接利用码的代数结构进行解码。首先,由于BCH(15,7)码的纠错能力t=2,所以根据接收序列计算伴随式sk=r(αk),其在伽罗华域GF(24)上的规定连续根为α、α2、α3、α4。与其对应的伴随式分别为: s1=r(α),s2=r(α2),s3=r(α3),s4=r(α4)。

  然后,由伴随式计算差错定位多项式[1]的系数。在二元BCH码中,对于任何值都有s2k=s2k;同理可推,s4=s24=s41,s6=s23等。所以在求差错定位多项式的系数时,仅须用到奇数下标的伴随式值。就BCH(15,7)码而言,根据s1和s3这两个伴随式值便可计算出差错定位多项式的2个系数: σ1=s1和σ2=s3+s31  s1。

  最后,依据Chien氏搜索算法对码的每个位置逐位检索,以确定其错误位置。若s1=s3=0,则可判定无差错发生;若s31+s3=0,则有1个差错发生,错码位置就是s1;若有2个或2个以上的差错发生,则可按σ1αi+σ2α2i=1(i=0,1,2,…,14)进行搜索。若在搜索中找到的根少于2个,则说明该多项式有的根在定位域之外,这表明发生的差错已超过2个;若找到的根恰好等于2个,则表示刚好有2个差错发生,可根据差错位置予以纠正。经差错定位找到差错位置后,便可进行纠错了。纠错的原理相对来说比较简单,因为单片机处理的是二进制数,而二进制数只有2个状态,即不是“0”就是“1”,因此纠错只须将对应差错位取反。

3  BCH解码校验算法的汇编语言实现

  具体的解码程序采用单片机的汇编语言实现,包括1个主程序和6个子程序。主程序的工作流程是整个程序的主线,决定着解码的效率;而子程序则是为了提高主程序在伽罗华域上代数运算的效率,优化主程序的程序结构。主程序的清单如下:

  MOV03H,R3
  MOV04H,R4
  MOVR1,#60H;错误位置初始地址
  MOVR7,#00H;出错个数初始值
  MOVR0,#00H;Chien氏搜索的初始值
  LCALLS1;调用s1=r(α)子程序
  MOVA,71H
  CJNEA,#00H,L1;s1≠0
  LCALLS3;调用s3=r(α3)子程序
  MOVA,70H
  CJNEA,#00H,L1;s3≠0
  LJMPRIGHT;送至解码输出程序
L1:MOVA,71H
  MOV78H,A;s1的矢量值
  LCALLTAB2;s1的指数
  MOVB,A
  RLA
  ADDA,B;得到s31的指数
  LCALL DIV15;调用模15求余子程序
  LCALL TAB1;s31的矢量值
  XRLA,70H;(s31+s3)的矢量值
  MOV73H,A
  CJNEA,#00H,L2;s31+s3≠0
  LJMP CORRECT;s31+s3=0,纠1位错
  LJMPRIGHT;送至解码输出程序
L2:MOVA,73H
  LCALL TAB2
  MOV74H,A;(s31+s3)的指数
  MOVA,71H
  LCALL TAB2
  MOV76H,A;76H中放s1的指数
  MOVA,74H
  SUBA,76H
  JCL3
L4:MOV75H,A
  LJMPL5
L3:ADD74H,#0FH;进行求逆
  MOVA,74H
  SUBA,76H
  LJMPL4
L5:MOVA,R0
  LCALL TAB2
  MOV7CH,A;7CH中放αi的指数
  ADDA,76H;s1αi的指数
  LCALLTAB1;s1αi的矢量值
  MOV77H,A
  MOVA,7CH
  RLA
  MOV79H,A;79H中放α2i的指数
  ADDA,75H;σ2α2i的指数
  LCALL TAB1;σ2σ2i的矢量值
  XRLA,77H;(σ1αi+σ2α2i)的矢量值
  CJNEA,#01H,L6
  MOVR1,#60H
  MOVA,R0
  MOV @R1,A;将错误位置放入60H单元中
  INCR1
  INCR7
L6:INCR0
  CJNER0,#0FH,L5;判断搜索完否
  CJNER7,#02H,L7;错误个数是否为2
  MOVA,60H;将第1个错误位置放入60H单元中
  MOV78H,A
  LCALL CORRECT
  MOVA,61H;将第2个错误位置放入61H单元中
  MOV78H,A
  LCALL CORRECT
  LJMPRIGHT;送至解码输出程序
L7:MOV80H,#01H;置超出纠错标志
  END

  供主程序调用的有6个子程序,其中2个是查表程序[2],2个是求s1和s3的程序[3],另外2个分别是纠错程序和求余程序。纠错程序和求余程序较为简单: 纠错程序只须先判断出差错位置,然后将对应的差错位进行取反操作;求余程序则是用于处理指数相加的结果大于15时出现的情况。相对关键的是查表程序和求伴随式值程序。查表程序为BCH码的有限域运算提供了便利,表1中按α指数的递增顺序列出了有限域内的矢量值;表2中按矢量的递增顺序列出了对应的α指数。

表1  指数对应的矢量
按此在新窗口浏览图片

  据此α的指数与对应的矢量值便可实现相互查找,具体程序如下。

①  查表1: 指数表示→二进制矢量表示。

  TAB1: ADDA,#30H
    MOVR5,A
    MOVA,@ R5
    RET

②  查表2: 二进制矢量表示→指数表示。

  TAB2: ADDA,#40H
    MOVR6,A
    MOVA,@ R6
    RET

  这里以s3为例,给出求伴随式值程序的实现方法,其他伴随式可依此类推。因为s3=r(α3),所以先判断03H中的内容,若为1,则向寄存器B中送入(α3)14=α42=α12(指数按模15运算)对应的二进制矢量值(1111),否则送0;而后依次判断接收的其他各位,若第2位也为1,则将(α3)13对应的二进制矢量值与B中的内容模2加,否则B中内容不变,直至判断到第15位。由于将s3展开后,其展开式按α0、α3、α6、α7和α12的规律重复出现了3次,因此毋须判断至第15位,只需判断至第5位,循环3次即可实现。

结语

  至此,通过上述主程序和子程序的软件编解码方法,有效地实现了BCH码的差错检验、差错查找和差错纠正。该BCH解码的汇编程序,经实践检验,不失为单片机级的信号传输中较好的应用程序。它可以对多位的随机差错进行检错和纠错,具体位数的多少仅受单片机工作频率的限制,而与方法无关。

关键字:汇编语言  BCH码  伽罗华域  解码校验 引用地址:采用汇编语言的BCH解码校验算法

上一篇:从LCD电极读数的单片机接口技术分析
下一篇:单片开关电源的快速设计法

推荐阅读最新更新时间:2024-03-16 12:45

实验六 定时器、计数器(80C51单片机汇编语言编程
P3.2口输出周期为2秒的方波;T1口为脉冲输入端,记录输入脉冲的个数,脉冲数由P1口所接的8个发光管显示出来(以二进制形式)。 实验箱晶振:6M ORG 00000H AJMP MAIN ORG 000BH AJMP T0 ORG 0030H MAIN:MOV TMOD,#51H MOV TH0,#3CH MOV TL0,#0B0H MOV TH1,#00H MOV TL1,#00H MOV P1,TL1 SETB EA SETB ET0 SETB ET1 setb tr0 setb tr1 MOV R7,#0AH
[单片机]
STM8与汇编语言(13)--修改CPU的时钟
在有些单片机的应用系统中,并不需要CPU运行在多高的频率。在低频率下运行,芯片的功耗会大大下降。因此希望单片机能提供这个功能,STM8单片机确实有这个功能,并且修改也非常方便。 下面的实验程序首先将CPU的运行时钟设置在8MHZ,然后快速闪烁LED指示灯。接着,通过修改主时钟的分频系数和CPU时钟的分频系数,将CPU时钟频率设置在500KHZ,然后再慢速闪烁LED指示灯。通过观察LED指示灯的闪烁频率,可以看到,同样的循环代码,由于CPU时钟频率的改变,闪烁频率和时间长短都发生了变化。 同样还是利用ST的开发工具,生成一个汇编程序的框架,然后修改其中的main.asm,修改后的代码如下。 stm8/ #inc
[单片机]
GCC的简单指令的分析
记下来以后以便于查询,以后还会更新更多的命令 -c 编译或者汇编源文件但是不作为连接,编译器输出对英语原文件的目标文件。 -S 编译后停止不进行汇编,对于每个属于的非汇编语言文件,输出文件时汇编语言。 -E 只是进行预编译 -o file 指定输出文件file 该选项不在乎GCC产生什么输出。 -include file 在处理常规输入文件之前首先处理文件file file会得到最先的编译 -imacros file 在处理常规输入文件之前, 首先处理文件 file 文件 唯一效果就是使文件中的宏定义生效 -nostdinc: 不要在标准系统目录中寻找文件,只是搜索‘-I’选项指定的目录。
[单片机]
基于汇编语言BCH解码校验算法
  在信号传输中,BCH码以其独特的优点被广泛应用于微机级的通信中,但因其算法复杂,通常只用在动态实时的无线通信中,而对更底层的单片机级的信号传输纠错,往往只采用奇偶校验等简单的校验方法。本文结合一些测控系统和监控系统的开发,摸索出了在实时动态单片机中的BCH解码检纠方法,并通过汇编语言加以实现,取得了一定的效果。下面以BCH(15,7)码为例进行探讨。 1 BCH码在单片机中的放置结构   BCH码作为一种检纠能力较强的循环码,由信息多项式i(x)和监督多项式j(x)组成。这里以c(x)表示整个BCH(15,7)码的15位码组多项式,则有: 500)this.width=500" border=0>   在单片机中其放置
[单片机]
基于<font color='red'>汇编语言</font>的<font color='red'>BCH</font><font color='red'>解码</font><font color='red'>校验</font>算法
汇编语言与C51语言实现跑马灯实验的比较
  当前开发 单片机 应用系统程序主要应用汇编语言和C51语言,采用汇编语言编写可直接操纵系统的硬件资源,能编写出高效运行的程序代码,程序运行速度快。而采用C51语言编写可改善程序的可读性和可移植性,利于产品的更新换代,大大加快了单片机应用程序的开发速度。下面通过一个简单的实验--跑马灯实验来分析一下这两种语言的差别。用AT89C5l实现的跑马灯实验的原理图如xia 图所示。   跑马灯实验的原理图用汇编语言编写程序来实现,程序如下: ORG 0 000H LJP START//转入主程序 ORG 0040H START:MOV SP,#60H//设置 堆栈指针 OV A,# 0 F
[单片机]
<font color='red'>汇编语言</font>与C51语言实现跑马灯实验的比较
51 单片机汇编语言:0~100 计数器
;单片机计数器 0~100。 ;外部中断控制加减。 ;高于100还是100,低于0还是0。 ;按照设计思路,程序全面改写如下: ORG 0000H AJMP MAIN ORG 0003H AJMP TL ORG 0013H AJMP TH ORG 0050H MAIN: MOV SP, #5FH SETB EA SETB EX0 SETB EX1 SETB IT0 SETB IT1 SETB P1.0 ;LED灯 ;----------------------------------------- MOV R1, #30 ;R0初始值设为30 M
[单片机]
51 单片机<font color='red'>汇编语言</font>:0~100 计数器
汇编语言实现BCH解码校验算法
摘要:介绍数据传输中BCH解码校验用汇编语言实现的算法。算法包含BCH码的差错检验、差错位查找和差错纠正,同时列出相关主要子程序清单并予说明。 关键词:BCH解码 校验算法 汇编语言 数据传输通信中,常常因传输差错造成误码错码,尤其在无线通信中,空中的突发或随机干扰噪声会造成编码差错。为了提高传输的正确率,往往采用一些校验方法,以检验纠正传输差错。通信中校验的方法很多,其中的BCH编码有其独特的优点:不仅可以检纠突发差错,还能检纠随机差错,被广泛地采用在微机级的通信中。但对更低层的单片机级的数据传输通信纠错,往往采用奇偶校验等简单的校验方法。BCH校验因其算法复杂,尤其是动态实时的无线通信中,单片机的通信往往无法采用BCH解
[应用]
利用汇编语言实现DES加密算法
DES算法是一种数据加密算法。自从1977年公布以来,一直是国际上的商用保密通信和计算机通信的最常用的加密标准。DES算法的实现一般用高级语言。 关键词:加密算法 DES 汇编语言 目前在金融界及非金融界的保密通信中,越来越多地用到了DES算法。DES(Data Encryption Standard)即数据加密算法,是IBM公司于 1977年研究成功并公开发表的。随着我国三金工程尤其是金卡工程的启动,DES算法在POS、ATM、磁卡及智能卡(IC卡)中被广泛应用,以此来实现关键数据的保密。如信用卡持卡人的PIN的加密传输、IC卡与POS间的双向认证、金融交易中的密码键盘等,均用到DES算法。由于密码键盘不可能使用高级语言,所以用
[工业控制]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved