十七世纪的常用对数表是怎么编出来的

十七世纪的常用对数表是怎么算出来的

前不久,在网上看到了金泽长街小牛先生的博文《回到十七世纪,让我来编算一本常用对数表》,受益匪浅。在我上中学时,也曾对数学用表中的对数和三角函数值是怎么算出来的感到好奇,但始终不得其解。中学时学的是四位对数表,后来也见到过八位对数表和十位对数表,但看不懂,不会用。读过小牛先生的文章后,不仅知道了对数表是怎么算出来的,也豁然明白八位对数表是怎么回事了。受小牛先生博文启发,我也想到了一种更为简单精确的计算常用对数表的方法,不用手算开高次方,只需加减乘除开平方,就可以编制出常用对数表,这里介绍出来,与大家分享。

第一步、计算第一组基础对数

这组基础的对数值是:1/2, 1/4, 1/8, 1/16, 1/32, 1/64, 1/128, 1/256, 1/512, 1/1024, 1/2048, 1/4096, 1/8192共13个。

计算的方法很简单,就是不断开平方。在常用对数里,10的对数是1,把10开平方就得到对数1/2的真数值,即√10,把计算结果再开平方就得到对数1/4的真数值,把计算结果再开平方就得到对数1/8的真数值,......一直进行下去,等开到1/8192就可以了。有这13个基础对数值,算8位对数表就够了,如果想要更精确的对数表,可以再多算几个基础对数,这里就不讨论了。

开平方是简单的运算,列竖式就可以开出来,开12位有效数字

一般不会超过半小时,计算这13个基础对数一个人几小时就可以完成。有了这组基础对数,就可以通过把若干个基础对数相加的方式,计算出从1/8192,2/8192,3/8192,......到8191/8192的任何一个对数,这8191个对数在0~1之间均匀分布。

第二步、计算第二组基础对数

这第二组基础的对数值是:0.5, 0.1, 0.05, 0.01, 0.005, 0.001, 0.0005, 0.0001共八个。

0.5即1/2,在第一组基础对数中就有;0.1=819.2/8192,介于819/8192与820/8192之间,其中

819/8192=512/8192+256/8192+32/8192+16/8192+2/8192+1/8192 =1/16+1/32+1/256+1/512+1/4096+1/8192

对数相加,真数需相乘,将式中这6个基础对数对应的真数值相乘就可以得到819/8192的真数值。

820/8192=512/8192+256/8192+32/8192+16/8192+4/8192 =1/16+1/32+1/256+1/512+1/2048

将式中这5个基础对数对应的真数值相乘就可以得到820/8192的真数值。

819/8192与820/8192之间的间距仅有1/8192,非常小,可以近似当成直线处理,在算出对数819/8192和820/8192的真数值后,通过“线性内插法”就可以算出对数819.2/8192即0.1对应的真数值。如担心多次相乘以及做线性内插时导致误差积累增大,可以把对数

0.1的真数值累乘计算5次方,看与对数0.5的真数值误差有多少,然后用开方公式做修正,消除误差。由于这样的计算本身已经很精确,误差修正的工作不会太费事。

得到对数0.1的真数值后,将之开平方就得到对数0.05的真数值。 然后,0.01=81.92/8192,分别计算出对数81/8192和82/8192的真数值,再用“线性内插法”计算出对数0.01的真数值,当然,也要做误差修正。

同样的方法,可以计算出对数0.005, 0.001, 0.0005, 0.0001的真数值。

这一组8个对数务必要准确,在算出这一组8个基础对数之后,就可以计算编制反对数表了。

第三步、计算编制反对数表

用对数做乘、除、乘方、开方运算得到的对数值,最终都要通过查反对数表才能得到真数,所以,反对数表是迟早必须要编的,而反对数表在计算方法上没有障碍,所以应该首先计算编制。有反对数表之后,再计算对数表就容易多了。

有了对数0.5和0.1对应的真数值,就可以计算出从0.1,0.2,0.3,...0.9这9个对数对应的真数值了,这9个对数构成的反对数表可以叫一级反对数表。计算的方法很简单,就是对数相加,真数相乘,比如0.6的对数,对数0.6=0.5+0.1,所对应的真数就是

3.[1**********]8*1.[1**********]4=3.[1**********]...

有了对数0.05和0.01对应的真数值以及一级反对数表,很容易就可以计算出从0.01,0.02,0.03,...0.99这99个对数对应的真数值,这99个对数构成的反对数表可以叫二级反对数表。计算的方法与前面相同,即对数相加,真数相乘。

有了对数0.005和0.001对应的真数值以及二级反对数表,就可以计算出从0.001,0.002,0.003,...0.999这999个对数对应的真数值,这999个对数构成的反对数表可以叫三级反对数表。计算的方法与前面相同。

同样,可以计算出包含0.0001,0.0002,0.0003,...0.9999这9999个构成的四级反对数表。有四级反对数表应该就够了。要计算编制包含99999个对数的五级反对数表不是做不到,而是有没有必要,值不值得做。

编制时要先完成一级反对数表,然后再扩充到二级反对数表、三级反对数表、四级反对数表,不要用很小的对数累乘得到大的对数,以避免误差累积增大。

这样计算出的反对数表非常齐整,而且精确度有充分保证。 扩充计算对数表只用两数相乘,不用除法。我觉得乘法比除法简单,工作量小。比如两个有10位有效数字的数相乘,会得到一个大约有20位的数字,但我们只要10位有效数字,后面的那些位数都要舍去,既然不需要,为什么要乘出来?所以在列竖式相乘时,那些注定不会加到前12位的数字,主要是乘数的后几位与被乘数的后几位相乘的数字,根本就别乘,直接画0补位,只要前12位,多出的两

位用于四舍五入,故而乘法可以减少计算量。

在编制反对数表过程中已经可以多找人手分摊工作量了。以前在书上看到过去有“制表工人”一说,应该是指专门从事计算制表的工作人员,如果是职业熟练工人,那应该会掌握很多计算技巧,计算速度也会快过常人,以我估计的计算量,如果有几十人同时工作,两三周做出反对数表应该没问题。

第四步,计算给定真数的对数值,编制常用对数表

在有了反对数表之后,再计算编制常用对数表就好办了,而且精确度有保证。方法就是“线性内插法”。以求2的对数为例,在反对数表里可以查到,对数0.3010对应的真数是1.9998618696,对数0.3011对应的真数是2.0003224078,那就在0.3010和0.3011之间做线性内插,求2的对数值,由于1.9998618696与2.0003224078的间距非常微小,所以得到的2的对数值也必是非常精准的。

从1.001~9.999之间的所有数都可以用这种“线性内插”法算出,用这8999个数就可以编制出一个完整的常用对数表,而且精度极佳,只不过要计算8999个数据,计算量颇大。

如果先算出那些质数(即素数)的对数,合数的对数由其质因子的对数相加而得到,计算量就可以大幅减少。

10000以内的质数仅有1229个,而且那些较大的质数,其对数可以用两对数平均值算出,例如8663是个素数,在算出8662和8664这两个数的对数后,8663的对数就是8662和8664这两个数的对数

的平均值。平均值计算实际也是“线性内插”,但要简单得多,真正需要用比较麻烦的“线性内插”计算的质数只有几百个,合数的对数由其约数的对数相加得到,这种制表方法计算量要少一些,但精度也要稍逊一些。总的来说,编制对数表要比反对数表计算量要少一些。 计算编制常用对数表的工作也一样可以找多人分担,以加快速度。

结语

编制八位常用对数表和反对数表,计算量巨大,个人很难独力完成,如果有几十个人分工合作,一两个月制出常用对数表和反对数表,应该不算什么大问题。

对数函数不是直线函数,做线性内插必会有误差,误差大小决定于插值区间大小,区间越小,误差也越小。若想要更精确的对数表,我认为应该增加多算几个基础对数,尽量减小插值区间。第二组基础对数值必须进行检验,消除误差。

上面就是我对常用对数表计算方法的思考。时隔几百年,十七世纪的常用对数表究竟是不是这样算出来的,有没有更好的方法就不知道了。以我的看法,本文叙述的方法已经足够简单精确了,没有技术障碍,若组织好了,即便是一些中学生也能完成这样的计算编制工作。

十七世纪的常用对数表是怎么算出来的

前不久,在网上看到了金泽长街小牛先生的博文《回到十七世纪,让我来编算一本常用对数表》,受益匪浅。在我上中学时,也曾对数学用表中的对数和三角函数值是怎么算出来的感到好奇,但始终不得其解。中学时学的是四位对数表,后来也见到过八位对数表和十位对数表,但看不懂,不会用。读过小牛先生的文章后,不仅知道了对数表是怎么算出来的,也豁然明白八位对数表是怎么回事了。受小牛先生博文启发,我也想到了一种更为简单精确的计算常用对数表的方法,不用手算开高次方,只需加减乘除开平方,就可以编制出常用对数表,这里介绍出来,与大家分享。

第一步、计算第一组基础对数

这组基础的对数值是:1/2, 1/4, 1/8, 1/16, 1/32, 1/64, 1/128, 1/256, 1/512, 1/1024, 1/2048, 1/4096, 1/8192共13个。

计算的方法很简单,就是不断开平方。在常用对数里,10的对数是1,把10开平方就得到对数1/2的真数值,即√10,把计算结果再开平方就得到对数1/4的真数值,把计算结果再开平方就得到对数1/8的真数值,......一直进行下去,等开到1/8192就可以了。有这13个基础对数值,算8位对数表就够了,如果想要更精确的对数表,可以再多算几个基础对数,这里就不讨论了。

开平方是简单的运算,列竖式就可以开出来,开12位有效数字

一般不会超过半小时,计算这13个基础对数一个人几小时就可以完成。有了这组基础对数,就可以通过把若干个基础对数相加的方式,计算出从1/8192,2/8192,3/8192,......到8191/8192的任何一个对数,这8191个对数在0~1之间均匀分布。

第二步、计算第二组基础对数

这第二组基础的对数值是:0.5, 0.1, 0.05, 0.01, 0.005, 0.001, 0.0005, 0.0001共八个。

0.5即1/2,在第一组基础对数中就有;0.1=819.2/8192,介于819/8192与820/8192之间,其中

819/8192=512/8192+256/8192+32/8192+16/8192+2/8192+1/8192 =1/16+1/32+1/256+1/512+1/4096+1/8192

对数相加,真数需相乘,将式中这6个基础对数对应的真数值相乘就可以得到819/8192的真数值。

820/8192=512/8192+256/8192+32/8192+16/8192+4/8192 =1/16+1/32+1/256+1/512+1/2048

将式中这5个基础对数对应的真数值相乘就可以得到820/8192的真数值。

819/8192与820/8192之间的间距仅有1/8192,非常小,可以近似当成直线处理,在算出对数819/8192和820/8192的真数值后,通过“线性内插法”就可以算出对数819.2/8192即0.1对应的真数值。如担心多次相乘以及做线性内插时导致误差积累增大,可以把对数

0.1的真数值累乘计算5次方,看与对数0.5的真数值误差有多少,然后用开方公式做修正,消除误差。由于这样的计算本身已经很精确,误差修正的工作不会太费事。

得到对数0.1的真数值后,将之开平方就得到对数0.05的真数值。 然后,0.01=81.92/8192,分别计算出对数81/8192和82/8192的真数值,再用“线性内插法”计算出对数0.01的真数值,当然,也要做误差修正。

同样的方法,可以计算出对数0.005, 0.001, 0.0005, 0.0001的真数值。

这一组8个对数务必要准确,在算出这一组8个基础对数之后,就可以计算编制反对数表了。

第三步、计算编制反对数表

用对数做乘、除、乘方、开方运算得到的对数值,最终都要通过查反对数表才能得到真数,所以,反对数表是迟早必须要编的,而反对数表在计算方法上没有障碍,所以应该首先计算编制。有反对数表之后,再计算对数表就容易多了。

有了对数0.5和0.1对应的真数值,就可以计算出从0.1,0.2,0.3,...0.9这9个对数对应的真数值了,这9个对数构成的反对数表可以叫一级反对数表。计算的方法很简单,就是对数相加,真数相乘,比如0.6的对数,对数0.6=0.5+0.1,所对应的真数就是

3.[1**********]8*1.[1**********]4=3.[1**********]...

有了对数0.05和0.01对应的真数值以及一级反对数表,很容易就可以计算出从0.01,0.02,0.03,...0.99这99个对数对应的真数值,这99个对数构成的反对数表可以叫二级反对数表。计算的方法与前面相同,即对数相加,真数相乘。

有了对数0.005和0.001对应的真数值以及二级反对数表,就可以计算出从0.001,0.002,0.003,...0.999这999个对数对应的真数值,这999个对数构成的反对数表可以叫三级反对数表。计算的方法与前面相同。

同样,可以计算出包含0.0001,0.0002,0.0003,...0.9999这9999个构成的四级反对数表。有四级反对数表应该就够了。要计算编制包含99999个对数的五级反对数表不是做不到,而是有没有必要,值不值得做。

编制时要先完成一级反对数表,然后再扩充到二级反对数表、三级反对数表、四级反对数表,不要用很小的对数累乘得到大的对数,以避免误差累积增大。

这样计算出的反对数表非常齐整,而且精确度有充分保证。 扩充计算对数表只用两数相乘,不用除法。我觉得乘法比除法简单,工作量小。比如两个有10位有效数字的数相乘,会得到一个大约有20位的数字,但我们只要10位有效数字,后面的那些位数都要舍去,既然不需要,为什么要乘出来?所以在列竖式相乘时,那些注定不会加到前12位的数字,主要是乘数的后几位与被乘数的后几位相乘的数字,根本就别乘,直接画0补位,只要前12位,多出的两

位用于四舍五入,故而乘法可以减少计算量。

在编制反对数表过程中已经可以多找人手分摊工作量了。以前在书上看到过去有“制表工人”一说,应该是指专门从事计算制表的工作人员,如果是职业熟练工人,那应该会掌握很多计算技巧,计算速度也会快过常人,以我估计的计算量,如果有几十人同时工作,两三周做出反对数表应该没问题。

第四步,计算给定真数的对数值,编制常用对数表

在有了反对数表之后,再计算编制常用对数表就好办了,而且精确度有保证。方法就是“线性内插法”。以求2的对数为例,在反对数表里可以查到,对数0.3010对应的真数是1.9998618696,对数0.3011对应的真数是2.0003224078,那就在0.3010和0.3011之间做线性内插,求2的对数值,由于1.9998618696与2.0003224078的间距非常微小,所以得到的2的对数值也必是非常精准的。

从1.001~9.999之间的所有数都可以用这种“线性内插”法算出,用这8999个数就可以编制出一个完整的常用对数表,而且精度极佳,只不过要计算8999个数据,计算量颇大。

如果先算出那些质数(即素数)的对数,合数的对数由其质因子的对数相加而得到,计算量就可以大幅减少。

10000以内的质数仅有1229个,而且那些较大的质数,其对数可以用两对数平均值算出,例如8663是个素数,在算出8662和8664这两个数的对数后,8663的对数就是8662和8664这两个数的对数

的平均值。平均值计算实际也是“线性内插”,但要简单得多,真正需要用比较麻烦的“线性内插”计算的质数只有几百个,合数的对数由其约数的对数相加得到,这种制表方法计算量要少一些,但精度也要稍逊一些。总的来说,编制对数表要比反对数表计算量要少一些。 计算编制常用对数表的工作也一样可以找多人分担,以加快速度。

结语

编制八位常用对数表和反对数表,计算量巨大,个人很难独力完成,如果有几十个人分工合作,一两个月制出常用对数表和反对数表,应该不算什么大问题。

对数函数不是直线函数,做线性内插必会有误差,误差大小决定于插值区间大小,区间越小,误差也越小。若想要更精确的对数表,我认为应该增加多算几个基础对数,尽量减小插值区间。第二组基础对数值必须进行检验,消除误差。

上面就是我对常用对数表计算方法的思考。时隔几百年,十七世纪的常用对数表究竟是不是这样算出来的,有没有更好的方法就不知道了。以我的看法,本文叙述的方法已经足够简单精确了,没有技术障碍,若组织好了,即便是一些中学生也能完成这样的计算编制工作。


相关文章

  • 初三生怎么样提高数学功力
  • 在新课程标准总目标中特别提出学生要"获得适应未来社会生活和继续学习所必需的数学基本知识和技能以及基本的数学思想方法".初中数学的基础知识,主要是概念.法则.性质.公式.公理.定理以及由其内容所反映出来的数学思想和方法.掌 ...查看


  • 数学的发展历史
  • 数学的发展历史 数学是一门伟大的科学,数学作为一门科学具有悠久的历史,与自然科学相比,数学更是积累性科学,它是经过上千年的演化发展才逐渐兴盛起来.同时数学也反映着每个时代的特征,美国数学史家克莱因曾经说过:"一个时代的总的特征在很 ...查看


  • 对数的概念-说课稿
  • 对数与对数的运算 尊敬的各位老师,大家好: 今天我说课的内容是对数的概念,下面我从教材分析.目标分析.教学程序.板书设计.评价反思五个方面汇报我对这节课的教学设想,主要阐述了教什么,怎么教,为什么这么教的问题. 一. 说教材 <§2. ...查看


  • 第一学期计划高中数学必修一和必修三
  • 高一数学第一学期教学工作计划 (2013-2014学年度) 李 海 燕 太原市第五十九中学校 2013.09 高一数学第一学期教学工作计划 2013.9-2013.1 一.学情分析 高一131班全班50人,男生20人,女生30人,高一132 ...查看


  • 常用特殊符号
  • ♡. 常用特殊符号介绍: $ & | ゜ ˇ ˉ ¦ ¥ ₩ Γ Γ Θ Ξ Π ΢ Τ Φ Φ Χ α β γ δ ε δ ε ζ η θ ι κ λ μ π ξ ζ η π θ ς σ Ё Б Г Д Е Ж З И Й К Л ...查看


  • 浅谈初中数学教学中数学思想方法的渗透
  • 中学数学思想方法的教学研究 [内容提要] 随着数学本身的不断进步和发展,对数学思想方法的重视.研究及教学探索,已成为了历史的必然.时代的要求,成为了中学数学教师及教育科究工作者的一个重要课题.本文从数学思想方法的现实意义着手,对数学思想.数 ...查看


  • 对数与对数运算导学案
  • 2.2.1 对数与对数运算(1) 教学目标 [特殊对数]常用对数和自然对数 我们通常将以10为底的对数叫做常用对数(common logarithm),简记为 在科学技术中常使用以无理数e=2.71828--为底的对数,以e 为底的对数叫自 ...查看


  • 关于微积分思想的浅见
  • 关于微积分思想的浅见 小学的课本里有<曹冲称象>这篇课文,当时只是跟着老师赞叹小曹冲是多么的聪明,却不明白其中的数学思想. 其实有的大臣已经想到了,就是把大象宰了,一块一块地称重,再加起来就是大象的重量,不过当时显然不能这么做. ...查看


  • 高中数学必修一公式定义
  • 第一章 集合(jihe)与函数概念 一.集合(jihe)有关概念 1.集合的含义:某些指定的对象集在一起就成为一个集合,其中每一个对象叫元素. 2.集合的中元素的三个特性: 1. 元素的确定性: 2. 元素的互异性: 3. 元素的无序性 说 ...查看


热门内容