格雷码

✍ dations ◷ 2025-11-25 13:48:48 #数字电子,数字电路

格雷码(循环二进制单位距离码)是任意两个相邻数的代码只有一位二进制数不同的编码,它与奇偶校验码同属可靠性编码。

格雷码(Gray code)是由贝尔实验室的Frank Gray在1940年提出,用于在PCM(脉冲编码调变)方法传送讯号时防止出错,并于1953年三月十七日取得美国专利。格雷码是一个数列集合,相邻两数间只有一个位元改变,为无权数码,且格雷码的顺序不是唯一的。

传统的二进制系统例如数字3的表示法为011,要切换为邻近的数字4,也就是100时,装置中的三个位元都得要转换,因此于未完全转换的过程时装置会经历短暂的,010,001,101,110,111等其中数种状态,也就是代表着2、1、5、6、7,因此此种数字编码方法于邻近数字转换时有比较大的误差可能范围。格雷码的发明即是用来将误差之可能性缩减至最小,编码的方式定义为每个邻近数字都只相差一个位元,因此也称为最小差异码,可以使装置做数字步进时只更动最少的位元数以提高稳定性。数字0~7的编码比较如下:

十进制 格雷码 二进制

0     000    0001     001    0012     011    0103     010    0114     110    1005     111    1016     101    1107     100    111

直接排列

以二进制为0值的格雷码为第零项,第一项改变最右边的位元,第二项改变右起第一个为1的位元的左边位元,第三、四项方法同第一、二项,如此反复,即可排列出n个位元的格雷码。

n位元的格雷码可以从n-1位元的格雷码以上下镜射后加上新位元的方式快速的得到,如右图所示一般。

(假设以二进制为0的值做为格雷码的0)
G:格雷码 B:二进制码 n:正在计算的位
根据格雷码的定义可得:
G(n) = B(n+1) XOR B(n)

G(n) = B(n+1) + B(n)
自低位至高位运算即可,无需考虑进位,例略。


00011110
3位元格雷码
000001011010110111101100 
4位元格雷码
0000000100110010011001110101010011001101111111101010101110011000
4位元2进制原始码
0000000100100011010001010110011110001001101010111100110111101111

格雷码转二进制数

由于G(n) = B(n+1) + B(n)
故而B(n) = -B(n+1)+ G(n)
自高位至低位运算即可,无需考虑借位。

例:格雷码0111,为4位数,故设二进制数自第5位至第1位分别为:0 b3 b2 b1 b0。
b3= 0-0 =0
b2=b3-1=0-1=1
b1=b2-1=1-1=0
b0=b1-1=0-1=1
因此所转换为之二进制码为0101

中国的古老益智玩具九连环有着和格雷码完全相同的数学模式,外国一款名为spin out的玩具也是运用相同的数学模式。

相关

  • 转化转型(英语:transformation),又译转化,即细胞通过摄取外源遗传物质(DNA或RNA)而发生遗传学改变的过程。在转化过程中,转化的DNA片段称为转化因子。受体菌只有处在感受态时才能够摄
  • 胆管细胞癌胆管癌(Cholangiocarcinoma),又称胆道癌,是一种由胆道上皮细胞(或呈现上皮细胞分化特征的细胞)癌变所造成的癌症。胆管癌主要的症状为肝功能异常、腹痛、黄疸、全身搔痒、发热和体
  • 中华人民共和国最高人民法院院长 政治主题中华人民共和国最高人民法院院长,是中华人民共和国最高人民法院的最高领导人,位列党和国家领导人,也是中华人民共和国最高级别的法官。2001年修订的《中华人民共和国
  • 迈克尔·奥尼尔 (足球运动员) 迈克尔·奥尼尔(Michael O'Neill,1969年7月5日-)是一位北爱尔兰足球教练和退役足球运动员,现为英冠球队斯托克城的主教练。米高奥尼尔出身北爱尔兰高利宁,其后效力纽卡斯尔联、
  • 缘木林跳鼠缘木林跳鼠(学名),属于啮齿目跳鼠科,分布在北美洲,是一种可以长途跳跃的小型动物。
  • N线N线可以指:
  • 菲比·瑞安菲比·霍利迪·瑞安(英语:Phoebe Holiday Ryan,1990年9月21日-)是美国歌手兼词曲作家。2015年,菲比·瑞安发行了R·凯利的《Ignition》和马吉尔(英语:Miguel (singer))的《Do You》,随
  • 布鲁克林历史学会布鲁克林历史学会(Brooklyn Historical Society,BHS)成立于1863年,是一个博物馆、图书馆和教育中心,保护和鼓励对布鲁克林400年历史的研究。布鲁克林历史学会总部大楼位于美国纽
  • 胡赛恩普尔胡赛恩普尔(Hussainpur),是印度旁遮普邦Kapurthala县的一个城镇。总人口15343(2001年)。该地2001年总人口15343人,其中男性8348人,女性6995人;0—6岁人口2401人,其中男1412人,女989人;
  • 极谱分析法极谱分析法(polarographic analysis method)或称极谱术(polarography),是捷克化学家雅罗斯拉夫·海罗夫斯基(Jaroslav Heyrovsky)于1922年提出的一种分析方法,海洛夫斯基先生也于195