CN1458764A - 一种单向广播文件传输中的前向纠错方法 - Google Patents
一种单向广播文件传输中的前向纠错方法 Download PDFInfo
- Publication number
- CN1458764A CN1458764A CN 03134217 CN03134217A CN1458764A CN 1458764 A CN1458764 A CN 1458764A CN 03134217 CN03134217 CN 03134217 CN 03134217 A CN03134217 A CN 03134217A CN 1458764 A CN1458764 A CN 1458764A
- Authority
- CN
- China
- Prior art keywords
- data
- data block
- error correction
- protected
- piece
- 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
Links
Images
Landscapes
- Detection And Prevention Of Errors In Transmission (AREA)
Abstract
本发明涉及一种单向广播文件传输中的前向纠错方法。该方法依次包括以下步骤:100)把待发送的数据拆分成多个数据块,计算每个数据块的校验和;200)将该多个数据块进行数据块的异或运算,计算保护数据块;300)发送数据块内容,包括保护数据块内容;400)接收数据块,校验接收到的数据块是否正确,并作标识;500)若有数据错误,统计错误数据块个数,若只有一个数据块发生错误,且接收到保护数据块,进行数据块的纠错还原;600)若无数据错误,按照编码规则,直接拼接还原数据。本发明可对字节数很大的数据进行纠错、运算量小、冗余数据量小且信道利用率高。
Description
一、技术领域
本发明涉及一种单向广播文件传输中的前向纠错方法。
二、背景技术
单向广播文件传输指的是:在播出端,将文件按照协议拆分成数据包,调制该数据包,通过单向广播传输信道传输出去;在接收端,通过该单向广播传输信道接收该调制的数据包,将其进行解调、还原、拼接成原来的文件。在单向广播文件传输领域,由于使用的单向广播传输信道没有反向传输通道,所以只能使用前向纠错的方法纠正错误的数据,以提高数据传输的性能。
当需要传输一个大文件时,一般情况下不可能将这个大文件作为一个数据包向外传输,通常做法是将这个大文件拆成几个小的数据块、对该数据块编码、通过某单向广播传输信道对外传输。在接收过程中,若一个数据块发生误码,则需要对该数据块纠错、拼接、还原到原始文件。若某时刻突发一个强烈的干扰,导致其中一个数据块被破坏的内容较多而无法纠正,那么这个文件就无法正确还原,只好等待下一轮的该文件的数据块纠错、拼接、还原全过程。在信号差的情况下,可能需要2~3次循环才能接收到正确的文件。
在单向广播传输信道中,常用的对拆分后的数据块纠错的方法有:
1、汉明(8,4)编码:一个字节,4比特有效数据,4比特冗余保护数据。该方法可以在一个比特发生错误的情况下正确纠错,运算速度快。其缺点是有2个以上比特发生错误,就会造成误判。每次只能保护4个比特的数据位,在发生突发干扰的情况下,不能产生前向纠错的效果。
2、格雷(23,12)编码:23比特,一般对齐为3个字节。12比特有效数据位,11比特为冗余保护数据。该方法最多能够同时纠错2个比特,能够正确指示3个比特以上的错误。该方法运算速度较快,但比汉明(8,4)编码慢。其缺点是每次只能保护12比特,在发生突发干扰的情况下,不能产生前向纠错的效果。
3、BCH编码、RS编码、Turbo编码:该类编码,编码效率高,纠错能力强,但是运算量随码长的增加而急剧增加。该类编码适合于小数据块的保护,而且一般只纠正其中的数个或数十个字节。其运算量巨大,在发生突发干扰的时间相对长的情况下,不能产生前向纠错的效果。
4、多次重复播出,覆盖接收方法:有的单向广播传输信道在对外传输中,采用连续传输两遍的方法来修补被丢弃数据块,即循环播传输出方式,基本上可归纳为两种:一种是大循环传输,如:ABCABC;另一种是连续循环传输两遍,如:AABBCC。这种循环传输的方法,可能实现丢弃数据块的修补。但其信道利用率低,而且多遍修补也不一定能够成功修补。
总的来说,现有的纠错方法,是在一个数据块内的纠错,只能对较小数据量的数据块提供了保护。为了能够修补被丢弃了的数据块,采用重复传输的方法,虽然重复传输的方法有可能修补丢弃的数据块,但需要较长的时间,而且需要占用带宽,这降低带宽的利用率。
三、发明内容
本发明为解决背景技术中存在的上述技术问题,而提供一种可对字节数很大的数据进行纠错、运算量小、冗余数据量小和信道利用率高的单向广播文件传输中的前向纠错方法。
本发明的技术解决方案是:一种单向广播文件传输中的前向纠错方法,其特殊之处在于:该方法依次包括以下步骤:
100)把待发送的数据拆分成多个数据块,计算每个数据块的校验和;
200)将该多个数据块进行数据块的异或运算,计算保护数据块;
300)发送数据块内容,包括保护数据块内容;
400)接收数据块,校验接收到的数据块是否正确,并作标识。
500)若有数据错误,统计错误数据块个数,若只有一个数据块发生错误,且接收到保护数据块,进行数据块的纠错还原。
600)若无数据错误,按照编码规则,直接拼接还原数据。
上述步骤100)中当原始数据字节数很多时,用多个保护数据块来分段保护,此时每个分段数据就相当于一个独立的待播出的数据,将该分段数据拆分成多个数据块,再计算每个数据块的校验和。
上述步骤200)中保护数据块按公式P0=S1S2S3S4…Sn-2Sn-1Sn进行异或运算;同时对保护数据块本身进行编码。
上述步骤300)中发送数据块时,先发送保护数据块,再发送原始数据块内容。
上述步骤100)中在对数据块进行编码时,添加一个字段,用于标记播出轮次或编码时间。
在突发强干扰的环境中,容易导致某一个数据块整体丢弃而其他数据块正确接收的情况,若不能将该丢失的数据块“找”回来,就意味此次传输无效。应用本发明就可将被丢弃的某一个数据块“找”回来,从而实现一次循环就能完整、正确地接收整个文件。因此本发明具有以下优点:
1、本发明是一个数据块级的数据保护编码,可以对字节数很大的数据提供保护。
2、本发明运算量小。本发明采用异或操作,不会因数据保护长度增加而急剧增加,编、解码运算量小。
3、本发明冗余数据量小,信道利用率高。本发明在n个有效数据块后,才使用一个保护数据块,编码效率高,解决有些编码效率低的缺点。
4、本发明在丢失数据块的情况下,让一个播出循环就能够成功接收成为可能,不用像“多次重复播出,覆盖接收方法”那样,可以缩短接收时间,同时提供信道利用率。
5、本发明还可提高单向广播文件传输、接收性能,降低对信道的要求,同时还可以降低文件传输的循环次数,节约带宽,提高带宽的利用率。
四、附图说明
图1为本发明的方法流程图;
图2为本发明的实施例流程图。
五、具体实施方式
参见图1,本发明的方法流程如下:
100)把待发送的数据拆分成多个数据块,计算每个数据块的校验和;
200)将该多个数据块进行数据块的异或运算,计算保护数据块;
300)发送数据块内容,包括保护数据块内容;
400)接收数据块,校验接收到的数据块是否正确,并作标识。
500)若有数据错误,统计错误数据块个数,若只有一个数据块发生错误,且接收到保护数据块,进行数据块的纠错还原。
600)若无数据错误,按照编码规则,直接拼接还原数据。
参见图2,本发明方法详细流程说明如下:
100)把待播出的数据,按Y字节拆分成n个数据块,其中n=(X+Y-1)/Y,对数据块进行编码,标识每个数据块(在文件中)的偏移,计算该数据块的校验和。以Y=1024字节为佳,以便于计算。数据块的校验和可以采用多种算法,只要能够判断数据块是否发生错误即可,此处推荐使用32位CRC校验,即循环冗余码校验。在对数据块编码时,可添加一个字段,用于标记播出轮次或编码时间,便于接收端判断一个文件是否播出完成。对于最后一个数据块,即第n数据块,其有效字节数据为r=X除以Y的余数,若r等于0,标识该数据块正好为Y字节,r应该等于Y;若r不等于Y,则剩余的Y-r字节填成数字0。
200)保护数据块按P0=S1S2S3S4…Sn-2Sn-1Sn进行异或运算;保护数据块本身也要进行编码,一方面让接收端能够判断该保护块的数据内容是否正确,另一方面让接收端能够区分保护数据块与其他数据块。此处符号“”表示数据块的异或操作,数据块的异或操作,是指两个数据块对应字节进行异或操作,如,将第m个数据块的第1字节A1与第m+1字节的第1字节B1进行异或运算,得到结果C1,同理A2与B2运算得到C2。
300)发送n个数据块和保护数据块的内容。以先发送保护数据块内容为佳,这样便于程序设计,在接收时不会因为保护数据块是否已经接收而进行等待。先传输保护块P0,然后传输原始数据块S1,S2,…Sn-1,Sn。
400)接收数据块,计算各数据块的校验和,并与播出端计算的校验和进行比较,确定数据块是否正确接收。播出端计算的校验和随数据一起发送到客户端。若一个数据块不正确,则将对应的数据缓冲区用数字0代替。若一个数据块丢失,则等效于发生错误。然后根据播出端对数据块编码时,添加的字段,来检测当前文件是否已经播出完成。
500)统计错误数据块个数(保护数据块不被统计),若只有一个数据块发生错误,且接收到保护数据块,则进行纠错。假设第m个数据块发生错误,还原第m个数据的公式为:Sm=P0S1…Sm-1Sm+1…Sn-2Sn-1Sn。其中符号标识数据块的异或操作。若没有数据块发生错误,则不用进行纠错。
600)若无数据错误,按照编码规则,直接拼接还原数据。
当原始数据字节数很多时,可以用多个保护数据块来分段保护。此时每个分段数据就相当于一个独立的待播出的数据。再依次按上述步骤将该分段数据进行纠错处理。
现举一具体实例对本发明方法做进步说明:
数据块校验和采用32位CRC方式,假设在接收端发现第3个数据块发生错误,即m=3。待播出的数据总长度X=100000字节,拆分单位Y=1000字节,那么总数据块个数n=(100000+1000-1)/1000=100。
对每个数据块进行编码,标识数据块在文件中的偏移,播出轮次,并计算该数据块的32位CRC校验和。(符号“”表示异或操作)。
计算保护数据块P0=S1S2S3S4…S98S99S100。
发送保护数据块P0,依次发送S1,S2,,,,S100
接收数据块,并判断文件是否完成发送。
统计错误数据块个数,发现一个数据S3块发生错误,则进行还原。
还原方法,先将S3对应的缓冲区清成0,然后计算
S3=P0S1S2S4…S98S99S100。
通用的计算方法是:假设第m数据块发生错误,则
当m=1
S1=P0S2S3…S98S99S100
当m=100
S100=P0S1S2…S98S99
其他
Sm=P0S1S2…Sm-1Sm+1…S98S99S100
至此,成功还原错误的数据包Sm的纠正。
其中,SmSm+1表示Sm与Sm+1两个数据包内对应字节的异或操作。
Claims (5)
1、一种单向广播文件传输中的前向纠错方法,其特征在于:该方法依次包括以下步骤:
100)把待发送的数据拆分成多个数据块,计算每个数据块的校验和;
200)将该多个数据块进行数据块的异或运算,计算保护数据块;
300)发送数据块内容,包括保护数据块内容;
400)接收数据块,校验接收到的数据块是否正确,并作标识;
500)若有数据错误,统计错误数据块个数,若只有一个数据块发生错误,且接收到保护数据块,进行数据块的纠错还原;
600)若无数据错误,按照编码规则,直接拼接还原数据。
2、根据权利要求1所述的单向广播文件传输中的前向纠错方法,其特征在于:所述步骤100)中当原始数据字节数很多时,用多个保护数据块来分段保护,此时每个分段数据就相当于一个独立的待播出的数据,将该分段数据拆分成多个数据块,再计算每个数据块的校验和。
3、根据权利要求1或2所述的单向广播文件传输中的前向纠错方法,其特征在于:所述步骤200)中保护数据块按公式P0=S1S2S3S4…Sn-2Sn-1Sn进行异或运算;同时对保护数据块本身进行编码。
4、根据权利要求3所述的单向广播文件传输中的前向纠错方法,其特征在于:所述步骤300)中发送数据块时,先发送保护数据块,再发送原始数据块内容。
5、根据权利要求1所述的单向广播文件传输中的前向纠错方法,其特征在于:所述步骤100)中在对数据块进行编码时,添加一个字段,用于标记播出轮次或编码时间。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CNB031342175A CN100417071C (zh) | 2003-05-30 | 2003-05-30 | 一种单向广播文件传输中的前向纠错方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CNB031342175A CN100417071C (zh) | 2003-05-30 | 2003-05-30 | 一种单向广播文件传输中的前向纠错方法 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN1458764A true CN1458764A (zh) | 2003-11-26 |
CN100417071C CN100417071C (zh) | 2008-09-03 |
Family
ID=29430626
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CNB031342175A Expired - Fee Related CN100417071C (zh) | 2003-05-30 | 2003-05-30 | 一种单向广播文件传输中的前向纠错方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN100417071C (zh) |
Cited By (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7710934B2 (en) | 2005-05-11 | 2010-05-04 | Samsung Electronics Co., Ltd. | Method and apparatus for keeping information in routing tables consistent throughout wireless network |
CN101355705B (zh) * | 2007-07-23 | 2010-12-08 | 中兴通讯股份有限公司 | 一种用于多媒体广播系统的数据传输方法 |
CN101267210B (zh) * | 2007-03-12 | 2011-01-05 | 华为技术有限公司 | 数据编译码和收发方法及装置 |
CN101465791B (zh) * | 2007-12-18 | 2011-08-17 | 国家广播电影电视总局广播科学研究院 | 一种基于单向链路的文件传输方法 |
CN101383678B (zh) * | 2007-09-04 | 2011-12-28 | 中兴通讯股份有限公司 | 基带单元与射频单元间传输的正交调制数据的校验方法 |
CN101510818B (zh) * | 2009-03-27 | 2012-01-04 | 华为技术有限公司 | 一种光纤链路的检测方法、装置和系统 |
CN1972455B (zh) * | 2006-11-30 | 2012-02-22 | 中兴通讯股份有限公司 | 一种移动多媒体广播系统的容错方法 |
CN101114887B (zh) * | 2006-07-24 | 2012-03-21 | 华为技术有限公司 | 一种业务数据的传输方法及其接收装置与设备 |
CN101312384B (zh) * | 2007-05-24 | 2012-05-23 | 上海贝尔阿尔卡特股份有限公司 | 通信网络中计算奇偶校验信息的方法和装置 |
CN106843958A (zh) * | 2017-01-18 | 2017-06-13 | 成都黑盒子电子技术有限公司 | 一种嵌入式固件升级方法 |
CN108712235A (zh) * | 2018-05-29 | 2018-10-26 | 北京光润通科技发展有限公司 | 一种单向无反馈传输方法 |
CN109560864A (zh) * | 2017-09-26 | 2019-04-02 | 中兴通讯股份有限公司 | 一种数据传输方法和装置 |
CN112968754A (zh) * | 2021-02-01 | 2021-06-15 | 航天国盛科技有限公司 | 一种基于n+1路e1信道实现数据可靠性传输方法 |
CN113938248A (zh) * | 2020-07-14 | 2022-01-14 | 华为技术有限公司 | 数据报文纠错方法和数据报文纠错装置 |
CN115079673A (zh) * | 2022-07-05 | 2022-09-20 | 成都赛力斯科技有限公司 | 一种故障上传方法、装置、设备及存储介质 |
US11604746B2 (en) | 2011-09-30 | 2023-03-14 | Sk Hynix Nand Product Solutions Corp. | Presentation of direct accessed storage under a logical drive model |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1148916C (zh) * | 2001-07-25 | 2004-05-05 | 英业达集团(南京)电子技术有限公司 | 利用无线通讯协定下载大型数据的方法 |
JP3427382B2 (ja) * | 2001-10-26 | 2003-07-14 | 富士通株式会社 | エラー訂正装置及びエラー訂正方法 |
CN1208968C (zh) * | 2002-11-21 | 2005-06-29 | 北京中科大洋科技发展股份有限公司 | 制作和发送及接收广播式准视频点播节目的装置和方法 |
-
2003
- 2003-05-30 CN CNB031342175A patent/CN100417071C/zh not_active Expired - Fee Related
Cited By (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101171799B (zh) * | 2005-05-11 | 2011-06-29 | 三星电子株式会社 | 在整个无线网络中维持路由表中的信息一致的方法和设备 |
US7710934B2 (en) | 2005-05-11 | 2010-05-04 | Samsung Electronics Co., Ltd. | Method and apparatus for keeping information in routing tables consistent throughout wireless network |
CN101114887B (zh) * | 2006-07-24 | 2012-03-21 | 华为技术有限公司 | 一种业务数据的传输方法及其接收装置与设备 |
CN1972455B (zh) * | 2006-11-30 | 2012-02-22 | 中兴通讯股份有限公司 | 一种移动多媒体广播系统的容错方法 |
CN101267210B (zh) * | 2007-03-12 | 2011-01-05 | 华为技术有限公司 | 数据编译码和收发方法及装置 |
CN101312384B (zh) * | 2007-05-24 | 2012-05-23 | 上海贝尔阿尔卡特股份有限公司 | 通信网络中计算奇偶校验信息的方法和装置 |
CN101355705B (zh) * | 2007-07-23 | 2010-12-08 | 中兴通讯股份有限公司 | 一种用于多媒体广播系统的数据传输方法 |
CN101383678B (zh) * | 2007-09-04 | 2011-12-28 | 中兴通讯股份有限公司 | 基带单元与射频单元间传输的正交调制数据的校验方法 |
CN101465791B (zh) * | 2007-12-18 | 2011-08-17 | 国家广播电影电视总局广播科学研究院 | 一种基于单向链路的文件传输方法 |
CN101510818B (zh) * | 2009-03-27 | 2012-01-04 | 华为技术有限公司 | 一种光纤链路的检测方法、装置和系统 |
US11604746B2 (en) | 2011-09-30 | 2023-03-14 | Sk Hynix Nand Product Solutions Corp. | Presentation of direct accessed storage under a logical drive model |
US12079149B2 (en) | 2011-09-30 | 2024-09-03 | Sk Hynix Nand Product Solutions Corp. | Presentation of direct accessed storage under a logical drive model |
CN106843958A (zh) * | 2017-01-18 | 2017-06-13 | 成都黑盒子电子技术有限公司 | 一种嵌入式固件升级方法 |
CN109560864B (zh) * | 2017-09-26 | 2021-10-19 | 中兴通讯股份有限公司 | 一种数据传输方法和装置 |
CN109560864A (zh) * | 2017-09-26 | 2019-04-02 | 中兴通讯股份有限公司 | 一种数据传输方法和装置 |
CN108712235B (zh) * | 2018-05-29 | 2020-11-20 | 北京光润通科技发展有限公司 | 一种单向无反馈传输方法 |
CN108712235A (zh) * | 2018-05-29 | 2018-10-26 | 北京光润通科技发展有限公司 | 一种单向无反馈传输方法 |
CN113938248A (zh) * | 2020-07-14 | 2022-01-14 | 华为技术有限公司 | 数据报文纠错方法和数据报文纠错装置 |
CN112968754A (zh) * | 2021-02-01 | 2021-06-15 | 航天国盛科技有限公司 | 一种基于n+1路e1信道实现数据可靠性传输方法 |
CN115079673A (zh) * | 2022-07-05 | 2022-09-20 | 成都赛力斯科技有限公司 | 一种故障上传方法、装置、设备及存储介质 |
CN115079673B (zh) * | 2022-07-05 | 2024-06-11 | 重庆赛力斯凤凰智创科技有限公司 | 一种故障上传方法、装置、设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN100417071C (zh) | 2008-09-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN1458764A (zh) | 一种单向广播文件传输中的前向纠错方法 | |
CN1154285C (zh) | 灵活的通信差错保护方法 | |
CN1215671C (zh) | 为空中文件转发提供差错保护的方法和装置 | |
CN1132495C (zh) | 用于在电信系统中传送识别符信息的方法 | |
CN1100394C (zh) | 自动请求重发系统的检错方案 | |
CN1656693A (zh) | 迭代硬输入前向纠错的方法 | |
CN100344069C (zh) | 编码/解码装置及编码/解码方法 | |
CN1152511C (zh) | 通过合并数据包改变交织长度的信息重传方法 | |
CN106817192B (zh) | 一种错误估计的方法、基站及终端 | |
CN1400827A (zh) | 在移动通信系统中发射和接收信号的方法和系统 | |
CN1602588A (zh) | 用于降低通信系统中解码复杂度的方法和系统 | |
CN101044710A (zh) | 对无线通信系统中的上行链路短长度数据进行格式化和编码的方法 | |
CN1957532A (zh) | 用于转换fec编码以太网帧中数据的方法和设备 | |
CA2543349C (en) | Method for lost packet reconstruction and device for carrying out said method | |
CN1117233A (zh) | 语音、数据同时传输中的副信道通信 | |
EP2317680B1 (en) | Data transmission method, data reception method, mobile terminal and radio communication system | |
CN1647440A (zh) | 在接收器端具有决定可能重传请求的拥塞控制的传输系统 | |
CN1324897C (zh) | 差错检测方法和装置 | |
CN1913531A (zh) | 一种tcp/ip包头的传输方法、压缩方法和装置 | |
CN1610339A (zh) | 传送和恢复数据分组的方法和装置 | |
CN1144429C (zh) | 分组校验数据传输法 | |
CN1918928A (zh) | 用于在e-dch中执行tfci可靠性检测的方法和设备 | |
CN1271855C (zh) | 数字广播系统的发送装置及方法 | |
CN1656694A (zh) | 具有以优先顺序排列的数据的系统中用于错误控制编码的分集方案 | |
CN1933479A (zh) | 通信系统中传输数据的方法及其系统 |
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 | ||
CF01 | Termination of patent right due to non-payment of annual fee |
Granted publication date: 20080903 Termination date: 20150530 |
|
EXPY | Termination of patent right or utility model |