博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Rocket - util - ECC
阅读量:6193 次
发布时间:2019-06-21

本文共 2732 字,大约阅读时间需要 9 分钟。

 
介绍ECC(Error Correcting Code/Error Checking and Correcting)的实现框架。不涉及编码的具体实现细节。
 
 
1. 码:Code
 
所有编码(如奇偶校验码、海明码)的抽象父类。
 
包含如下几个方面:
a. 能否检错:canDetect;
b. 能否纠错:canCorrect;
c. width():输入为数据的宽度,输出为编码后码文的宽度,一般情况下为数据和监督码的宽度之和;
d. encode(x):把数据x进行编码,并输出编码后的码文;
e. decode(y):对码文y进行解码,输出解码结果Decoding;
f. swizzle(x):参考注释;
 
2. 解码结果:Decoding
 
 
Decoding为解码结果,包含如下几个方面:
a. uncorrected:码文中未纠错的数据,即码文中的原始数据;
b. corrected: 使用监督码纠错之后的数据,即解码的输出结果;
c. correctable:根据各种码的实现,correctable意义为:有没有进行纠错;
d. uncorrectable:根据各种码的实现,uncorrectable的意义为:解码输出的结果是否正确;
e. error:是否包含错误,无论是否可以纠正的错误,都视为错误;
 
correctable/uncorrectable的命名是有问题的,词不达意,且造成误解。
 
从字面意思上看,correctable和uncorrectable应该相反,即correctable = !uncorrectable,为什么会定义两个呢?所以不能从字面意思上理解,他们代表了两个不同的意义。
 
correctable和uncorrectable分别代表能修正的错误位和不能修正的错误位?也不是,两者的类型皆为Bool,而非UInt。
 
单从命名上无法推知他们的意义。
 
参考IdentityCode/ParityCode/SECCode的实现之后,推知两者的意义分别为:
a. correctable:有没有进行纠错;
b. uncorrectable:解码输出的结果是否正确,即corrected的值是否正确(是否存在不可挽回的错误);
 
即两者标识从原始数据(uncorrected)到最终数据(corrected)过程中的两个情况:
a. 是否发生了纠错;
b. 是否纠正了错误;
 
为了提高可读性,个人尝试对Decoding改名如下:
 
 
PS. 因为对码研究有限,这个修改未必正确,提请注意。
 
再回过头来看uncorrectable的注释:
因为uncorrectable是对纠错结果的标识,如果uncorrectable为真,则存在不可挽回的错误,即不可纠正的错误,那么有没有发生过纠错(由correctable标识)就无关紧要了。
 
3. IdentityCode
 
相同编码。
a. 没有检错能力:def canDetect = false
b. 没有纠错能力:def canCorrect = false
c. 码文宽度与数据宽度相同:def width(w0: Int): Int = w0
d. 码文与数据相同,没有监督码:
e. swizzle:没有研究;
f. decode:
 
重构之后为:
a. 码文中的原始数据(raw)为y,即全部都是原始数据,不存在监督码;
b. 最终输出的数据(out)为y;
c. 是否发生过纠错(corrected):没有;
这里存在两个层次:首先IdentityCode没有纠错能力,进而也没有发生纠错;
d. 是否存在不可纠正的错误(uncorrectable):没有;
这个没有是因为IdentityCode没有检错能力,不知道是否存在错误;
 
4. ParityCode
 
奇偶检验码。
a. 能够检错:def canDetect: Boolean = true
b. 不能纠错:def canCorrect: Boolean = false
c. 含有1位监督码:def width(w0: Int): Int = w0+1
d. 使用逐位异或计算奇偶校验码:def encode(x: UInt, poison: Bool = Bool(false)): UInt = Cat(x.xorR ^ poison, x)
e. decode:
其中:
a. 码文中的数据(raw)为去掉最高的奇偶校验码:val raw: UInt = y(y.getWidth-2,0)
b. 最终输出的数据(out)为raw:不具备纠错能力;
c. 是否发生过纠错(corrected):没有,同IdentityCode;
d. 是否存在不可挽回的错误:因为没有纠错能力,所以只要发生错误,即是不可挽回的错误。检错通过对码文逐位异或实现。如果结果为0,则没检测到错误(检错能力有限,不代表没有错误);如果结果为1,则检测到错误。
 
5. SECCode
 
既能检错,又能纠错的单个错误校正码(single-error-correcting)。这里不具体研究其实现,只研究decode输出的Decoding。
 
监督码的值代表发生错误的位:
其中:
a. 码文中的原始数据(raw):y(k-1, 0),除去监督码;
b. 最终输出的数据(out)为纠错后的数据,把检测到错误的位反转:val out: UInt = raw ^ sysBadBitOH
c. 是否发生过纠错(corrected):如果监督码不为0,则发生了纠错:val corrected: Bool = syndromeUInt.orR
d. 是否存在不可挽回的错误(uncorrectable)
如果长度合适,则所有的码文都可以纠正,即uncorrectable恒为Bool(false);
如果长度不合适,则是否能够纠正取决于监督码是否异常:syndromeUInt > UInt(n)
 
6. SECDEDCode
 
 
Single Error Correction, Double Error Detection。
能力有限,这里不做研究了。
 
7. ErrGen
 
错误发生器。
 
8. CanHaveErrors
 
是否包含错误的特征。
 
9. ECCParams
 
ECC的参数:
a. 字节数;
b. 码的类型;
c. 是否通知错误;
 
10. 伴生对象Code
 
方便从名称生成相应的码的对象。
 
11. 附录
 
ECCRefactored.scala:
 
 
 

转载于:https://www.cnblogs.com/wjcdx/p/10925408.html

你可能感兴趣的文章
Ansible模块知多少
查看>>
生成唯一标识的元素
查看>>
Skype for Business Server 2015-11-Web Application Proxy-部署
查看>>
重新定义工作站的“边界”
查看>>
开发人员学Linux(13):CentOS7安装配置IT设备监控系统Zabbix
查看>>
SEOer未来之路到底在哪里?
查看>>
XenServer 6.5实战系列之八:Creating a VM Template from an Existing VM
查看>>
也谈ibm aix jfs2
查看>>
使用TMG2010企业版组建大型***网络之2-陈列安装
查看>>
处理文本文件及其排序去重
查看>>
Android系统默认Home应用程序(Launcher)的启动过程源代码分析(4)
查看>>
从技术到管理,艰难的转型
查看>>
Exchange Server 2013 OWA IIS重定向
查看>>
解决nginx不支持websocket
查看>>
How to import the Spring Framework sourcecode into Eclipse
查看>>
2013年8月工作小结 ----- SMMC,这是一个好项目
查看>>
“憨仔游戏”寻求资金合作伙伴
查看>>
It appears as though you do not have permission to view information ...
查看>>
百度要革自己的命?移动搜索或取消PC网页收录
查看>>
打开思维:技术不是什么神奇的事物
查看>>