莫尔斯码(Morse Code) 是由塞缪尔.莫尔斯发明的(1791-1872),在本书的其他章节中我们还将频繁地提到他。莫尔斯码其实是伴随着电报机的问世而被发明的,关于电报机,我们在后面的章节将做更详细的探讨。正如通过研究莫尔斯码我们可以很方便地理解编码的本质一样,通过电报机来了解计算机硬件也是个不错的途径。
大多数人都会发现莫尔斯码发送和接收更为简半单。即使你并没有熟记莫尔斯码,也可以很方便地使用下面这张按字母表顺序排列的表格。
比起发送莫尔斯码,接收莫尔斯码要费力得多,因为译码者不得不根据一串由“点”、“划”组成的晦涩的编码序列来反查字母。例如,如果你接收到一串形如“划-点-划-划”的编码,那么你就必须从表的第一字母开始逐个搜寻,直到找到与这串编码相同的字母“Y”为止。
问题就出现在这里,因为我们现在只有一张提供“字母→莫尔斯”的编码表,而缺少一张可以实现反向查询的“莫尔斯→字母”译码表。在开始学习莫尔斯码的初级阶段,如果有这样的一个表无疑将是很方便的。但是要建立这样一张表,谈何容易。似乎这些字母对应的“点-划”序列并没的什么规律。
所以忘掉字母序列吧。或许根据编码中所含点、划的多少对其进行分组,是一个更好的组织这些编码的方法。例如,一个仅包含一个点或一个划的莫尔斯码只能俘代表两个字母:“E”或“T”.
一个含有两个点或划的编码组合,可能给我们呈现出4个字母———— I, A, N 和M。
. | E |
- | T |
.. | I | -. | N |
.- | A | -- | M |
一组含有3个点或划的莫尔斯码可以为我们表现更多的字母。
... | S | -.. | D |
..- | U | -.- | K |
.-. | R | --. | G |
.-- | W | --- | O |
最后(如果我们不想考虑存在数字和标点符号的莫尔斯码的情况), 一串由4个点或划组组成的莫尔斯码就可以表示16个字符。
*.... | H | -... | B |
...- | V | -..- | X |
..-. | F | -.-. | C |
..-- | ü | -.-- | Y |
.-.. | L | --.. | Z |
.-.- | ? | --.- | Q |
.--. | P | ---. | ? |
.--- | J | ---- | S |
综合以上数据来看,这四张表包含了2+4+8+16组码字,总共30个字母,比拉丁字母表的26个字母还要多出4个。所以,你会注意到最后一个表中有4组编码是用来表示重音字母的。
当有人给你发送莫尔斯码的时候, 上述四张表可能会让你的解码工作变得轻松很多。当接收到某一代表特定字母的码字后,你就可以知道其中所含的“点”和“划”的数目,那么你至少可以很快找到对应的表格去进行查找。每个表格都组织得很规整,全部是“点”的码字被排在左上角,而全部是“划”的则被排在右下角。
你发现这四张表格在大小上的规律了么?注意看,每个表格所包含的码字数目是前一张的两倍。这其实很好理:每个表格所含有的码字,可以看成是在前一张表格所包含的全部码字上再加一个“点”,或者再加一个“划”而组成的新码字。
我们可以用如下这样一个列表总结这个有趣的规律。
点和划的数目 | 码字的数目 |
1 | 2 |
2 | 4 |
3 | 8 |
4 | 16 |
在这四张表中, 每张表的码字数都是前一张表码字数量的两倍,因此如果第一张表含有2个码字,那么第二张表含有2*2个码字,而第三个表就有2*2*2个码字。下面用另一种方式呈现这个规律.
点和划的数目 | 码字的数目 |
1 | 2 |
2 | 2*2 |
3 | 2*2*2 |
4 | 2*2*2*2 |
当然,如果我们遇到了数字的自乘,就可以通过幂的方式来表示它,例如2*2*2*2可以记作24(2的4次幂)。数字2, 4, 8和16都是以2为底数的幂值。因为你可以通过使其自乘2得到它们。由此我们总结列表可以写成下面这种样子。
点和划的数目 | 码字的数目 |
1 | 21 |
2 | 22 |
3 | 23 |
4 | 24 |
现在, 这个表已经变得很简洁了。如果知道了码字中“点”和“划”的数目,那么以这个数目为指数的2的幂运算结果就是其总共可以表示的码字数。我们可以用下面这个简单的公式来概括上述表格所表示的内容:
码字的数目=2“点”和“划”的数目
使用2的幂值的形式可以表示很多码字,在下一章中,我们还将接触另一个例子。
为了让莫尔斯的解码过程更加简单,或许画一张图会有帮助,例如下面这张树型图。
这张图给出了所有字母及其所对应的由“点”和“划”组成的连续序列。当对一串码字进行解码时,我们需要沿着箭头从左向右进行搜寻。以“点-划-点”的码字为例来说,当你需要找出这串码字所代表的字母时同,应首先从图的左边开始,选择“点”的分支;然后继续沿着箭头向右选择“划”,接着又是一个“点”。找到最后一个“点”时结果就会紧随其后出现了,没错就是字母R。