第六百八十章 汇编语言之母Kathleen Booth (第1/2页)
微看书 www.vkss.cc,最快更新数学心!
Kathleen hylda Valerie booth教授是英国早期的计算机先驱之一。
想象一下,必须通过重新布线来对计算机进行编程。是不是很不可思议?
在1940年代中期,第一台通用电子计算机就是以这种方式工作的。
像ENIAc这样的计算机,最初并没有用于代码的内部存储。如果我们想要用它编程,就要操纵数千个开关和电缆,而这些开关和电缆所在的位置,就是程序。
所有带旋转开关的单元都是需要大量编程的地方。
此时的编程,必须手动更改数千根电缆和开关,或者在卡片上打孔,然后将卡片送入计算机,这可能需要数天时间,而且极易出错。
在Kathleen booth开始研究计算机的那个年代,有那么一小群人,开始产生了将程序存储在计算机内部的想法。而她也是最早研究「软件」这一新概念的人之一,她从中看到了需求,发明了汇编语言,使计算机编程更加人性化。
Andrew booth在与x射线晶体学家Jd bernal教授(伯纳尔球的发明者)合作期间,使用x射线衍射数据来研究晶体结构。他发现手动计算非常繁琐,于是造了一台模拟计算机,来自动化部分步骤。
1946年,他在伯贝克担任纳菲尔德研究员。但由于学院没有空间,而且由于bRpRA为其提供资金,所以他的工作是在bRpRA的设施上完成的。
就在那时,他遇到了Kathleen。同年,Kathleen和Andrew在伯贝克学院合作发明了一台早期的数字计算机——自动中继计算机(ARc)。ARc使用纸带进行输入,实际上是一台用作傅立叶合成器的专用计算机。
在此期间,他们一同创建了如今的伯贝克计算机科学与信息系统系。
1945年,约翰·冯·诺依曼(John von Neumann)撰写了一份名为「EdVAc报告初稿」的文件,在这份文件中,他描述了后来被称为计算机的冯·诺依曼架构。
在这个架构中,他定义了计算机的各个部分,特别是存储在计算机内存中的程序。出于这个原因,它也被称为存储程序计算机。
在经典的冯·诺依曼计算机架构中,地址空间大部分用于指向内存,其余部分用于指向外部设备:内存并不关心里面存储的是什么。
1947年,Andrew和Kathleen在普林斯顿大学与冯诺依曼和IAS机器合作时,编写了一个程序,用于在电子计算机上实现翻译词典,前提是提供必要的存储容量。这是史上最早的机器翻译奠基工作。
在这一年,bernal帮助Kathleen和Andrew从洛克菲勒基金会申请到了访问普林斯顿高等研究院的资金。在此期间,Andrew和Kathleen与冯诺依曼一起共事了6个月。
根据Andrew的说法,在访问期间,只有bernal的朋友约翰·冯·诺伊曼在任何时间都会接待他们。
一个简化的内存管理系统——cpU中的程序计数器不再直接指向内存,而是产生一个进入mmU的虚拟地址,重定位常量添加到虚拟地址,以在内存中创建物理地址。
就是这次访问,让他们第一次听说了冯诺依曼架构。受到启发,他们重新设计了ARc,仅用了2个月就设计了机器的继电器部分,并且提出了关于ARc2的构想。
还是在1947年,Kathleen和他还写了两份关于它的报告《通用电子数字计算机设计中的一般考虑因素》和《ARc编码》。其中第一份报告广为流传。在其中,他们详细介绍了冯诺依曼架构机器,并介绍了内存的不同选项。
此外,这份报告还描述了她发明「汇编语言」的前身,她在报告中将其命名为contracted Notation。这是对计算机编程进行抽象思考的第一步,无需编写显式的1和0或机器代码指令。
在这份报告中,Kathleen的编程能力大放异彩。并且,她设想了同步与异步操作的可能性,这可是在1947年!在此之后,我们唯一能够找到的异步描述来自1980年代中期。
同步与异步操作将允许程序中的多条指令并行执行。因此,在执行下一条指令之前,程序不会被阻止等待当前指令的结果。这将有效地改善程序执行时间,即处理所有指令所需的时间。
摘自《通用电子数字计算机设计中的一般考虑因素》
第二份报告「coding For ARc」,于1947年9月出版。在这份报告里,Kathleen首次详细介绍了ARc2「汇编语言」。
在该报告中,Kathleen还解释了orders(现在称为指令instructions)是如何由加载到某种存储中的0和1表示的。
通过汇编语言,我们不必再记住机器代码作为指令,只需记住并输入汇编语言助记符moV作为指令。
不过,目前已无法找到这份报告的数字副本。
在1948年,Andrew和Kathleen将研究方向转向简单电子计算机(SEc),然后是通用电子x射线计算机或ApE(x)c。现在,我们可以在mESS模拟器中试用ApE(x)c。
hollerith电子计算机(hEc)是世界上现存最早的电子计算机之一。
他们最着名的机器ApEc(通用电子计算机)是在1949年设计出来的。
1951年,btm使用其硬件电路作为hEc1计算机设计的基础,这种计算机在1950年代末直接成为最畅销的英国计算机,安装了近100台。
Andrew发明了一种并行乘法器算法,该算法仍然构成现代计算机芯片(布斯乘法器)中乘法电路的基础。
他们还一起发明了旋转存储设备。在1940年代后期,他们试图制造可工作的光盘,但失败了,不过,他们成功地建造了世界上第一个磁鼓存储器,该存储在1950年代被广泛用于主存储器和后备存储。
在磁鼓存储器中,信息存储在滚筒上的可磁化条上,数字信息存储为二进制磁性图案
1950年,Kathleen和Andrew结婚,就在同年,Kathleen从伦敦大学获得了应用数学博士学位。
为了争取更多资金,两夫妇再次前往洛克菲勒基金会。基金会提出的条件:必须让ApE(c)x既可以用人类语言,也可以用数学语言。这也就是我们所熟知的自然语言处理。
他们做到了,在1955年11月,他们展示了机器翻译的过程。
他们的目标是实现准确的技术翻译,而不是追求文学质量。
(本章未完,请点击下一页继续阅读)