CN101227194A - 用于并行bch编码的电路、编码器及方法 - Google Patents

用于并行bch编码的电路、编码器及方法 Download PDF

Info

Publication number
CN101227194A
CN101227194A CNA2008100659719A CN200810065971A CN101227194A CN 101227194 A CN101227194 A CN 101227194A CN A2008100659719 A CNA2008100659719 A CN A2008100659719A CN 200810065971 A CN200810065971 A CN 200810065971A CN 101227194 A CN101227194 A CN 101227194A
Authority
CN
China
Prior art keywords
output
input
constant
length
bch
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CNA2008100659719A
Other languages
English (en)
Other versions
CN101227194B (zh
Inventor
彭洪
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Actions Technology Co Ltd
Original Assignee
Actions Semiconductor Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Actions Semiconductor Co Ltd filed Critical Actions Semiconductor Co Ltd
Priority to CN2008100659719A priority Critical patent/CN101227194B/zh
Publication of CN101227194A publication Critical patent/CN101227194A/zh
Application granted granted Critical
Publication of CN101227194B publication Critical patent/CN101227194B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Landscapes

  • Error Detection And Correction (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

本发明公开了一种用于BCH并行编码的方法,包括如下步骤:将当前周期的输入序列{x1…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,并将相乘结果求和作为第一输出;将寄存器组上一周期的输出与常数矩阵TM相乘结果作为第二输出;第一输出和第二输出求和输出至寄存器组,作为寄存器组当前周期的输出;上述步骤经过特定数量次运算,得到最终编码输出。本发明提供的用于并行BCH编码的方法采用了迭代算法,相对于串行编码有更快的运算速度;与基于查找表的并行算法相比,取消了查找表,大幅度减少了资源消耗;且有效控制了电路的扇出。本发明还公开了一种用于BCH并行编码的电路和编码器。

Description

用于并行BCH编码的电路、编码器及方法
技术领域
本发明涉及对数据进行纠错编码的技术领域,尤其涉及一种用于并行BCH编码的电路、编码器及方法。
背景技术
在各种各样的传输系统和网络中,为保证数据在对等端点间正确传输,需要一定的纠检错编码。在通信领域和消费类电子领域经常使用BCH码作为检错或纠错的依据。需要纠错或检错的数据通过BCH编码器生成校验码,并将校验码和原码同时发送出,然后在解码端解码并同时纠错或检错。所述BCH码取自Bose、Ray-Chaudhuri与Hocquenghem的缩写,是纠正多个随机错误的循环码,可以用生成多项式g(x)的根描述。对数据进行BCH编码的方式主要有两种,一种是串行编码方式,另一种是并行编码方式。
图1是一种常规的串行BCH编码器的原理图。其中输入序列为二进制序列m1 m2 m3…mK-2 mK-1 mK,Di为移位寄存器。ci是反馈序列的抽头系数,它的值为0或1,是BCH码的生成多项式g(x)=xN-K+1+cN-K-1xN-K+…+c1x+1中的系数。二进制序列的多项式表达式:比如输入序列为100100...001,mi代表的是0或者1,xi代表mi在序列中的位置,(i的范围是0~N-1)。图中符号为GF(2)的乘法器,为GF(2)的加法器,
Figure S2008100659719D00011
为选通控制器,GF是伽罗华域的意思,GF(2)指的是1位二进制占用的域元素空间。二进制序列m1 m2 m3…mK-2 mK-1 mK一位一位的输入编码器,输出完成以后寄存器序列D0…DN-K-1中保存的值就是校验码,此时选通控制器输出校验码序列。
但由于高速通信或者闪存控制器的数据传输速率非常快。例如闪存控制器向闪存芯片写入数据的时候,极限情况可以达到50MHz*8bit每秒,这时常规的BCH编码器的工作速度高达400MHz,并且运算的延迟很大(例如bch(8191,8048,23)至少要8191个时钟周期才能够完成编码),因此串行编码在速度要求很高的地方是不行的。其中bch(8191,8048,23)即bch(N,k,r)中具体的取值,其中N是码字的长度,也就是编码器输出的序列长度;K是有效信息序列的长度,也就是进入编码器的序列长度;r是最小半径。
而如果采用并行的方式对数据进行BCH编码,则可以在更短的时钟周期内完成编码,因此,现有技术中又出现了基于查找表的并行算法及相关的改进方法,其基本思路是:将长度为N的输入序列作为一个符号,这个符号有2N种组合。把这2N种序列的组合输入移位寄存器产生出对应的2N种输出序列。把这些输出序列作成一个表,以后运算时不再通过移位寄存器来运算,而是通过查表的方式来获得结果。
但此种方法在校验位比较多的时候,生成多项式g(x)的项数非常多(例如bch(8191,8048,23)的校验g(x)项数就有143个),如果输入序列的长度N=8191,则相对应的序列有28191种组合。生成序列的位宽为143位。因此需要28191*143位才能保存各种组合产生的序列。这种方法在实际上是不可能实现的。
在此基础上出现了进一步改进的方法,其方法是将输入序列的长度N减小(比如将长度减小到8),则新的查找表大小为2N·(N-K),其中(N-K)是移位寄存器的长度。再通过移位和异或等组合逻辑操作完成迭代运算。其原理如下:
1.假设输入序列的长度为K,用多项式可以表达为:
m(x)=mK-1xK-1+mK-2xk-2+…+m1x1+m0                      (B1)
其中mi为1或者0,(i=0,1,2,3…k-1)
2.设图1中移位寄存器的长度为R=N-K,其多项式表达式为
r(x)=rR-1xR-1+rR-2xR-2+…+r1x1+r0                     (B2)
其中ri为1或者0,(i=0,1,2,3…k-1)
3.可以得到以下等式
xRm(x)=a(x)·g(x)+r(x)                          (B3)
其中g(x)为生成多项式,xRm(x)表示xR与m(x)的乘积,a(x)为xRm(x)除以g(x)得到的商多项式,r(x)则是(2)式中定义的余数多项式
4.将输入的数据mi分解成N组,并假设输入序列长度K能够被N整除。则m(x)可以写成
m ( x ) = Σ l = 0 K N - 1 [ m lN + N - 1 . x lN + N - 1 + m lN + N - 2 x lN + N - 2 + · · · + m lN + 1 x lN + 1 + m lN x lN ]
= Σ l = 0 K N - 1 Σ i = 0 N - 1 m lN + i x lN + i = Σ l = 0 K N - 1 x lN u l ( x ) - - - ( B 4 )
其中 u l ( x ) = Σ i = 0 N - 1 m lN + i x i
5.又假设ul(x)=g(x)·al(x)+rl(x)                 (B5)
其中al(x)为ul(x)除以g(x)得到的商多项式,rl(x)则是ul(x)除以g(x)得到的余数多项式
6.将(5)式带入(4)得到
m ( x ) = Σ l = 0 K N - 1 x lN [ g ( x ) · a l ( x ) + r l ( x ) ] - - - ( B 6 )
并两边求模,得到
[ m ( x ) ] mod ( g ( x ) ) = [ Σ l = 0 K N - 1 x lN [ g ( x ) · a l ( x ) + r l ( x ) ] ] mod ( g ( x ) )
r ( x ) = [ Σ l = 0 K N - 1 x lN r l ( x ) ] mod ( g ( x ) ) - - - ( B 7 )
= [ Σ l = 0 K N - 1 x lN S l ( x ) ] mod ( g ( x ) )
= [ ( ( S K N - 1 ( x ) x N + S K N - 2 ( x ) ) x N + · · · + S 1 ( x ) ) x N + S 0 ( x ) ] mod ( g ( x ) )
= ( ( ( ( S K N - 1 ( x ) x N ) mod ( g ( x ) ) + S K N - 2 ( x ) ) x N mod ( g ( x ) ) + · · · + S 1 ( x ) x N ) mod ( g ( x ) ) - S 0 ( x ) ) mod ( g ( x ) )
其中Sl(x)=LOW(rl(x))+HIGH(rl(x))
LOW(rl(x))表示rl(x)的高N位,HIGH(rl(x))表示rl(x)的低R-N位采用这种算法每次运算过程是:
A、如果是第一次运算,则先查找序列ul(x)对应的输出序列表,得到rl(x)序列(它的长度为R),并令Sum=rl(x)。
B、Sum乘以xN(它的长度为R+N),得到序列Sum·xN
C、这个序列的长度超过了移位寄存器组的长度R,因此这个序列的最高N位还需要求一次模g(x)(同样可以查表)
D、最后将Sum·xN的低R位,Sum·xN的最高N位求模后的序列以及rl-1(x)相加,得到新的Sum
此运算直到加上r0(x)后结束,由此可以看出长度为K的序列的模g(x)余式可以由其N个子序列的余式gl(x)组合而成。
这种方式虽然大幅度节省了资源,但是当BCH编码器的冗余位比较多的时候对资源的消耗依然很大。例如,使用这种方式设计bch(8191,8049,23)码的编码器时,当并行宽度为8位,则需要消耗的存储空间为28*143位。如果要减少资源消耗,则必须要减少并行运算的宽度,因此必然影响速度。
发明内容
本发明实施例的目的在于提供一种用于并行BCH编码的电路、编码器及方法,旨在解决现有技术中的串行编码运算慢,扇出大及基于查找表的并行算法耗费资源的问题。
本发明实施例是这样实现的,一种用于BCH并行编码的电路,包括M个输入支路,所述每一输入支路包括一常数向量乘法器,当前周期的输入序列{x1,…,xi,…,xM}按顺序分别输入至所述系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果通过矩阵加法器求和得到最终编码输出;其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为bch编码后冗余位的长度,t为转置符号。
本发明实施例的另一目的在于提供一种采用如权利要求1所述的电路的编码器。
本发明实施例的另一目的在于提供一种用于BCH并行编码的电路,包括M个输入支路和一个反馈支路,所述每一输入支路包括一常数向量乘法器,所述反馈支路包括依次连接的系数为TM的常数矩阵乘法器、矩阵加法器及寄存器组;当前周期的输入序列{x1,…,xi,…,xM}按顺序分别输入至所述系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为bch编码后冗余位的长度,t为转置符号;所述寄存器组用于寄存所述矩阵加法器当前周期的输出,并将当前周期反馈,作为所述系数为TM的常数矩阵乘法器下一周期的输入;所述常数矩阵乘法器当前周期的输入与常数矩阵TM相乘结果作为第二输出;所述矩阵加法器将所述第一输出及第二输出求和后输出至寄存器组作为寄存器组当前周期的输出;所述输入支路和反馈支路经过特定数量次运算,得到最终编码输出。
本发明实施例的另一目的在于提供一种采用如权利要求3所述的电路的编码器。
本发明实施例的另一目的在于提供一种用于BCH并行编码的方法,包括如下步骤:将当前周期的输入序列{x1,…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,并将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为bch编码后冗余位的长度,t为转置符号;将寄存器组上一周期的输出与常数矩阵TM相乘结果作为第二输出;第一输出和第二输出求和输出至寄存器组,作为寄存器组当前周期的输出;上述步骤经过特定数量次运算,得到最终编码输出。
本发明提供的用于并行BCH编码的电路、编码器及方法采用了迭代算法,相对于串行编码有更快的运算速度;与基于查找表的并行算法相比,取消了查找表,大幅度减少了资源消耗;且有效控制了电路的扇出。
附图说明
图1是现有的串行BCH编码原理图;
图2是现有的bch(15,11,3)的串行编码原理图;
图3A是本发明实施例提供的一种并行BCH编码电路结构框图;
图3B是本发明实施例提供的一种并行BCH编码电路算法示意图;
图4A是本发明实施例提供的另一种并行BCH编码电路结构框图;
图4B是本发明实施例提供的另一种并行BCH编码电路算法示意图;
图5是本发明实施例提供的常数矩阵乘法器内部结构示意图;
图6是本发明实施例提供的常数向量乘法器内部结构示意图;
图7是本发明实施例提供的T8的扇出示意图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
以bch(15,11,3)的编码为例说明,图2是现有的bch(15,11,3)的串行编码原理图:
Bch(15,11,3)的生成多项式为g(x)=x4+x+1,又假设D(n)i表示第n个寄存器在第i个时钟后的状态,则可以得到如下表达式:
D(3)i=feedback+D(2)i-1
D(2)i=D(1)i-1
D(1)i=D(0)i-1                        (A1)
D(0)i=feedback
其中feedback=D(3)i-1+xi-1
变换后得到下面关系式:
D(3)i=D(3)i-1+D(2)i-1+xi-1
D(2)i=D(1)i-1                        (A2)
D(1)i=D(0)i-1
D(0)i=D(3)i-1+xi-1
写成矩阵表达式有:
Di=TDi-1+Xi-1S
其中 T = 0 0 1 1 0 1 0 0 1 0 0 0 0 0 0 1 , X i - 1 = x i - 1 0 0 0 0 x i - 1 0 0 0 0 x i - 1 0 0 0 0 x i - 1 , S = 1 0 0 1 , D i = D ( 0 ) i D ( 1 ) i D ( 2 ) i D ( 3 ) i .
很明显也有Di-1=TDi-2+Xi-2S
因此有Di=TDi-1+Xi-1S=T(TDi-2+Xi-2S)+Xi-1S
=T(T(TDi-3+Xi-3S)+Xi-2S)+Xi-1S=T3Di-3+Xi-3T2S+Xi-2TS+Xi-1S
=T11Di-11+Xi-11T10S+Xi-10T9S+…+Xi-2TS+Xi-1S                 (A3)
当Di(i∈[0,10])全为0时,有:
D i = Σ k = 0 10 X k T k S - - - ( A 4 )
由串行结构的表达式(A1)、(A2)推导出并行结构的表达式(A3)、(A4)。表达公式采用这种并行结构的表达式(A3)、(A4)方式可以将输入数据完全并行计算,只需要一个时钟周期就能够计算完成。
由上述公式的迭代计算,本发明实施例提供的一种并行BCH编码电路结构框图和算法示意图,如图3A和图3B所示;图中
Figure S2008100659719D00081
表示常数向量乘法器(i的范围是0~M-1),表示GF(2)矩阵加法器。
所述用于BCH并行编码的电路,包括M个输入支路,每一输入支路包括一常数向量乘法器;当前周期的输入序列{x1,…,xi,…,xM}按顺序分别输入至系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果通过矩阵加法器求和得到最终编码输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为bch编码后冗余位的长度,t为转置符号。
按照图3A和图3B所示的并行编码电路有如下优点:
(1)运算速度快,只需要一个时钟周期就可以计算出来;
(2)不需要ROM,因此节省了存储空间;
(3)在码长较短的时候电路复杂程度小。
本发明实施例提供的一种用上述并行编码电路编码的方法,将输入序列{x1,…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,将相乘结果求和得到最终编码输出;其中,M输入序列长度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为BCH编码后冗余位的长度,t为转置符号。
参考公式A3,由于通常处理数据是按照字节、双字节、或4字节进行的,在一个时钟内输入8048bit的输入是没有必要的。当输入序列长度变的很长,并且校验码比较多的时候,下面的方式可以有效减小扇出。假设并行度为M,则有
D i = T M D i - M + X i - M T M - 1 S + X i - M - 1 T 9 S + · · · + X i - 2 TS + X i - 1 S
= T M D i - M + Σ k = 0 M - 1 X i - k T k S - - - ( A 5 )
很明显
D i = T M D i - M + Σ k = 0 M - 1 X i - k T k S = T M ( T M D i - 2 M + Σ k = 0 M - 1 X i - M - k T k S ) + Σ k = 0 M - 1 X i - k T k S - - - ( A 6 )
由上述公式的迭代计算,本发明实施例提供的另一种并行BCH编码电路,如图4A和图4B所示;图中表示GF(2)的常数矩阵乘法器,
Figure S2008100659719D00093
表示常数向量乘法器(i的范围是0~M-1),表示GF(2)矩阵加法器,
Figure S2008100659719D00094
为寄存器组。
所述用于BCH并行编码的电路,包括M个输入支路和一个反馈支路,所述每一输入支路包括一常数向量乘法器,所述反馈支路包括依次连接的系数为TM的常数矩阵乘法器、矩阵加法器及寄存器组;当前周期的输入序列{x1,…,xi,…,xM}按顺序分别输入至所述系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[10…01]t,R为bch编码后冗余位的长度,t为转置符号;所述寄存器组用于寄存所述矩阵加法器当前周期的输出,并将当前周期反馈,作为所述系数为TM的常数矩阵乘法器下一周期的输入;所述常数矩阵乘法器当前周期的输入与常数矩阵TM相乘结果作为第二输出;所述矩阵加法器将所述第一输出及第二输出求和后输出至寄存器组作为寄存器组当前周期的输出;所述输入支路和反馈支路经过特定数量次运算,得到最终编码输出。
本发明实施例采用迭代计算方法,其流程如下:
将当前周期的输入序列{x1,…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,并将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为bch编码后冗余位的长度,t为转置符号;将寄存器组上一周期的输出与常数矩阵TM相乘结果作为第二输出;第一输出和第二输出求和输出至寄存器组,作为寄存器组当前周期的输出;上述步骤经过特定数量次运算,得到最终编码输出。
所述迭代计算方法在本电路中的具体实施方式为:
(1)首先,外部发出复位信号,将寄存器组D清零;
(2)复位完成以后,常数向量乘法器将输入序列中的每一个xi与每一常数向量乘法器对应的常数向量TM-1S相乘得到一组向量值并输出至所述矩阵加法器,所述xi表示输入序列中的位置,所述TM-1S表示常数向量乘法器的系数。而每次有输入的数据有M位(范围从xi-1到xi-M),因此在一次运算的时间内可以算出M组向量的值。
(3)在计算xi与常数向量TM-1S的同时,常数矩阵乘法器计算向量Di-1与常数矩阵TM的乘积,得到一组向量值并输出至所述矩阵加法器,所述TM表示输入信号异或常数;其中,Di-1表示迭代运算时D寄存器组中的内容。
(4)矩阵加法器把xi×TM-1S的结果(一共有M组向量)与Di-1×TM的结果(只有一组向量)加起来,输出结果Di至寄存器。
(5)让(2)(3)(4)过程不断循环,每一次运算都会得到新Di,用于下一次迭代运算。迭代运算的次数由输入信息数据的长度k和并行度M来决定,此时的迭代次数为k/M(如果k能够被M整除的话)或者为大于k/M的最小整数(如果k不能够被M整除的话)。使Di变成Di-1,将更新后的Di-1反馈至常数矩阵乘法器进行迭代运算,所述Di表示每一次矩阵加法的运算结果。
(6)等到完成了设计的迭代运算次数以后,停止运算,并串行输出寄存器组D中的值,并将其添加到输入的信息序列后。这样就得到了一个BCH码的码字。
图5是本发明实施例提供的常数矩阵乘法器内部结构示意图,现详述如下:图中
Figure S2008100659719D00101
表示输入信号异或常数Txy,表示GF(2)加法器,R的值为生成码字中的冗余位的数量。移位序列D1 i…DR i保持了每一次矩阵加法的运算结果,并且它作为输入变量进入各自的运算支路进行运算,从而实现乘法器。运算支路的Tij(0≤i≤R,0≤j≤R)均来自矩阵式(A5)(A6)中的T。
图6是本发明实施例提供的常数向量乘法器内部结构示意图,现详述如下:图中
Figure S2008100659719D00111
表示输入信号异或常数(T(k-1)S)R,R的值为生成码字中的冗余位的数量,k表示第k个常数向量乘法器支路。输入数据xi与常数向量T(k-1)S中的每一个元素(T(k-1)S)0…(T(k-1)S)R相乘,从而形成了新的向量序列x(i-k)out1…x(i-k)outR。运算器中的(T(k-1)S)0…(T(k-1)S)R(0≤i≤R,0≤j≤R)均来自矩阵式(A5)及(A6)中的向量T(k-1)S。
图7是本发明实施例提供的T8的扇出示意图,现详述如下:图7为当运算的并行程度M=8时(即每次输入8位数据),本发明实施例所采用方式的bch(8191,8048,23)编码扇出复杂程度示意图。图中纵坐标的值为0或者1,当其为1的时候表示有扇出发生,当其为0的时候表示没有扇出发生。由图7中可见采用这种方式得到的矩阵依然很大,但是它是一个稀疏矩阵,其大部分扇出都集中在对角线左右和矩阵的最后几列,其扇出大幅度减小,有利于硬件实现。
以上所述仅为本发明的较佳实施例而已,并不用以限制本发明,凡在本发明的精神和原则之内所作的任何修改、等同替换和改进等,均应包含在本发明的保护范围之内。

Claims (8)

1.一种用于BCH并行编码的电路,包括M个输入支路,所述每一输入支路包括一常数向量乘法器,输入序列{x1,…,x1,…,xM}按顺序分别输入至所述系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果通过矩阵加法器求和得到最终编码输出;其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为BCH编码后冗余位的长度,t为转置符号。
2.一种采用如权利要求1所述的电路的编码器。
3.一种用于BCH并行编码的电路,其特征在于,包括M个输入支路和一个反馈支路,所述每一输入支路包括一常数向量乘法器,所述反馈支路包括依次连接的系数为TM的常数矩阵乘法器、矩阵加法器及寄存器组;
当前周期的输入序列{x1,…,xi,…,xM}按顺序分别输入至所述系数为S,TS,…,TiS,…,TM-1S的常数向量乘法器对应相乘后,将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为BCH编码后冗余位的长度,t为转置符号;
所述寄存器组用于寄存所述矩阵加法器当前周期的输出,并将当前周期反馈,作为所述系数为TM的常数矩阵乘法器下一周期的输入;
所述常数矩阵乘法器当前周期的输入与常数矩阵TM相乘结果作为第二输出;
所述矩阵加法器将所述第一输出及第二输出求和后输出至寄存器组作为寄存器组当前周期的输出;
所述输入支路和反馈支路经过特定数量次运算,得到最终编码输出。
4.如权利要求3所述的电路,其特征在于,特定数量由输入信息数据的长度K和并行度M来决定,特定数量为不小于K/M的最小整数。
5.一种采用如权利要求3所述的电路的编码器。
6.一种用于BCH并行编码的方法,其特征在于,输入序列{x1,…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,将相乘结果求和得到最终编码输出;其中,M输入序列长度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为BCH编码后冗余位的长度,t为转置符号。
7.一种用于BCH并行编码的方法,其特征在于,包括如下步骤:
将当前周期的输入序列{x1,…,xi,…,xM}按顺序分别与常数向量S,TS,…,TiS,…,TM-1S对应相乘,并将相乘结果求和作为第一输出,其中,M为并行度,i为不大于M的自然数,T为一个R×R的方阵,S是一个R×1的固定向量[1 0…0 1]t,R为BCH编码后冗余位的长度,t为转置符号;
将寄存器组上一周期的输出与常数矩阵TM相乘结果作为第二输出;
第一输出和第二输出求和输出至寄存器组,作为寄存器组当前周期的输出;
上述步骤经过特定数量次运算,得到最终编码输出。
8.如权利要求6所述的方法,其特征在于,特定数量由输入信息数据的长度K和并行度M来决定,特定数量为不小于K/M的最小整数。
CN2008100659719A 2008-01-22 2008-01-22 用于并行bch编码的电路、编码器及方法 Active CN101227194B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN2008100659719A CN101227194B (zh) 2008-01-22 2008-01-22 用于并行bch编码的电路、编码器及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN2008100659719A CN101227194B (zh) 2008-01-22 2008-01-22 用于并行bch编码的电路、编码器及方法

Publications (2)

Publication Number Publication Date
CN101227194A true CN101227194A (zh) 2008-07-23
CN101227194B CN101227194B (zh) 2010-06-16

Family

ID=39858988

Family Applications (1)

Application Number Title Priority Date Filing Date
CN2008100659719A Active CN101227194B (zh) 2008-01-22 2008-01-22 用于并行bch编码的电路、编码器及方法

Country Status (1)

Country Link
CN (1) CN101227194B (zh)

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102545914A (zh) * 2010-12-27 2012-07-04 联芯科技有限公司 Bch编译码方法及装置
CN102761340A (zh) * 2012-08-10 2012-10-31 济南微晶电子技术有限公司 一种bch并行编码电路
CN102820892A (zh) * 2012-06-20 2012-12-12 记忆科技(深圳)有限公司 一种用于并行bch编码的电路、编码器及方法
CN102823141A (zh) * 2010-03-30 2012-12-12 国际商业机器公司 用于固态存储器件的两级bch码
CN104320145A (zh) * 2014-10-29 2015-01-28 中国科学院微电子研究所 (15,7)bch码的编码电路设计方法
CN104506201A (zh) * 2014-10-29 2015-04-08 中国科学院微电子研究所 (15, 5)bch码的编码电路设计方法
RU2591474C1 (ru) * 2015-07-21 2016-07-20 Открытое акционерное общество Научно-производственный центр "Электронные вычислительно-информационные системы" Параллельный реконфигурируемый кодер бчх кодов
RU2601827C1 (ru) * 2015-06-10 2016-11-10 Открытое акционерное общество Научно-производственный центр "Электронные вычислительно-информационные системы" Реконфигурируемый кодер бчх кодов
CN106921395A (zh) * 2015-12-28 2017-07-04 北京忆芯科技有限公司 Ldpc编码方法及其装置
CN108400787A (zh) * 2018-03-07 2018-08-14 中山大学 一种基于bch编码的并行fir滤波器容错方法
CN109756235A (zh) * 2018-12-07 2019-05-14 天津津航计算技术研究所 一种可配置的并行bch纠错编码方法
CN117294316A (zh) * 2023-11-24 2023-12-26 北京邮电大学 一种基于bch码的耦合结构拉链码编译码方法及系统

Cited By (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102823141B (zh) * 2010-03-30 2015-09-16 国际商业机器公司 用于固态存储器件的两级bch码
CN102823141A (zh) * 2010-03-30 2012-12-12 国际商业机器公司 用于固态存储器件的两级bch码
US8930798B2 (en) 2010-03-30 2015-01-06 International Business Machines Corporation Data encoding in solid state storage devices
CN102545914B (zh) * 2010-12-27 2015-03-25 联芯科技有限公司 Bch编译码方法及装置
CN102545914A (zh) * 2010-12-27 2012-07-04 联芯科技有限公司 Bch编译码方法及装置
CN102820892A (zh) * 2012-06-20 2012-12-12 记忆科技(深圳)有限公司 一种用于并行bch编码的电路、编码器及方法
CN102820892B (zh) * 2012-06-20 2016-06-01 记忆科技(深圳)有限公司 一种用于并行bch编码的电路、编码器及方法
WO2013189274A1 (zh) * 2012-06-20 2013-12-27 记忆科技(深圳)有限公司 一种用于并行bch编码的电路、编码器及方法
US9614550B2 (en) 2012-06-20 2017-04-04 Ramaxel Technology (Shenzhen) Limited Parallel BCH coding circuit, encoder and method
CN102761340A (zh) * 2012-08-10 2012-10-31 济南微晶电子技术有限公司 一种bch并行编码电路
CN102761340B (zh) * 2012-08-10 2015-04-01 济南大学 一种bch并行编码电路
CN104320145A (zh) * 2014-10-29 2015-01-28 中国科学院微电子研究所 (15,7)bch码的编码电路设计方法
CN104506201A (zh) * 2014-10-29 2015-04-08 中国科学院微电子研究所 (15, 5)bch码的编码电路设计方法
CN104506201B (zh) * 2014-10-29 2018-08-21 中国科学院微电子研究所 (15,5)bch码的编码电路设计方法
RU2601827C1 (ru) * 2015-06-10 2016-11-10 Открытое акционерное общество Научно-производственный центр "Электронные вычислительно-информационные системы" Реконфигурируемый кодер бчх кодов
RU2591474C1 (ru) * 2015-07-21 2016-07-20 Открытое акционерное общество Научно-производственный центр "Электронные вычислительно-информационные системы" Параллельный реконфигурируемый кодер бчх кодов
CN106921395A (zh) * 2015-12-28 2017-07-04 北京忆芯科技有限公司 Ldpc编码方法及其装置
CN108400787A (zh) * 2018-03-07 2018-08-14 中山大学 一种基于bch编码的并行fir滤波器容错方法
CN108400787B (zh) * 2018-03-07 2021-04-13 中山大学 一种基于bch编码的并行fir滤波器容错方法
CN109756235A (zh) * 2018-12-07 2019-05-14 天津津航计算技术研究所 一种可配置的并行bch纠错编码方法
CN117294316B (zh) * 2023-11-24 2024-03-26 北京邮电大学 一种基于bch码的耦合结构拉链码编译码方法及系统
CN117294316A (zh) * 2023-11-24 2023-12-26 北京邮电大学 一种基于bch码的耦合结构拉链码编译码方法及系统

Also Published As

Publication number Publication date
CN101227194B (zh) 2010-06-16

Similar Documents

Publication Publication Date Title
CN101227194B (zh) 用于并行bch编码的电路、编码器及方法
US4873688A (en) High-speed real-time Reed-Solomon decoder
WO2010115371A1 (zh) 一种循环冗余校验crc码的实现方法和装置
JPH0831803B2 (ja) 誤り訂正のための方法と装置
CN102377437B (zh) 一种准循环低密度奇偶校验码编码方法和装置
CN101277119B (zh) 里德所罗门码解码器硬件复用方法及其低硬件复杂度解码装置
CN100571045C (zh) 一种解码伴随式的计算方法、电路及解码器
CN102751995A (zh) 一种基于fpga的抗多位错误翻转rs码检错纠错系统
CN105553485A (zh) 基于fpga的bch编解码装置及其编解码方法
CN1095122C (zh) 差错定位多项式高速计算电路
CN101296053A (zh) 计算循环冗余校验码之方法及系统
CN102820892A (zh) 一种用于并行bch编码的电路、编码器及方法
EP0393080B1 (en) Hypersystolic reed-solomon encoder
CN106708654A (zh) 一种用于NANDflash的BCH纠错码的电路结构
CN101834616B (zh) 里德-索罗蒙解码器实现方法
CN102891689B (zh) 一种错误位置多项式求解方法及装置
US10367529B2 (en) List decode circuits
CN112468160A (zh) 一种基于钱搜索算法和福尼算法的并行电路
CN107688506B (zh) 一种流水结构的bch译码系统
EP0991196B1 (en) Method of correcting lost data and circuit thereof
CN101777922B (zh) 用于BCH译码器的高速低延时Berlekamp-Massey迭代译码电路
CN108347250A (zh) 适用于少量冗余里德-所罗门码的快速编码方法及设备
CN202856718U (zh) 一种基于fpga的抗多位错误翻转rs码检错纠错系统
CN108847851B (zh) 一种二元bch码伴随式矩阵的实现方法
CN113285725A (zh) 一种qc-ldpc编码方法及编码器

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant
C56 Change in the name or address of the patentee
CP02 Change in the address of a patent holder

Address after: 519085 hi tech Zone, Guangdong, Zhuhai science and Technology Innovation Coast Road, No. four, No. 1

Patentee after: Juli Integrated Circuit Design Co., Ltd.

Address before: 519085 No. 1, unit 15, building 1, 1 Da Ha Road, Tang Wan Town, Guangdong, Zhuhai

Patentee before: Juli Integrated Circuit Design Co., Ltd.

TR01 Transfer of patent right

Effective date of registration: 20170612

Address after: 519085 C District, 1# workshop, No. 1, science and technology No. four road, hi tech Zone, Zhuhai, Guangdong, China

Patentee after: ACTIONS (ZHUHAI) TECHNOLOGY Co.,Ltd.

Address before: 519085 hi tech Zone, Guangdong, Zhuhai science and Technology Innovation Coast Road, No. four, No. 1

Patentee before: Juli Integrated Circuit Design Co., Ltd.

TR01 Transfer of patent right
CP01 Change in the name or title of a patent holder

Address after: 519085 High-tech Zone, Tangjiawan Town, Zhuhai City, Guangdong Province

Patentee after: ACTIONS TECHNOLOGY Co.,Ltd.

Address before: 519085 High-tech Zone, Tangjiawan Town, Zhuhai City, Guangdong Province

Patentee before: ACTIONS (ZHUHAI) TECHNOLOGY Co.,Ltd.

CP01 Change in the name or title of a patent holder