24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1602  |  回复: 7
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

liming9398

金虫 (正式写手)

[求助] numerical recipes in fortan 代码的疑惑已有1人参与

SUBROUTINE flmoon(n,nph,jd,frac)
      INTEGER jd,n,nph
      REAL frac,RAD
      PARAMETER (RAD=3.14159265/180.)
      INTEGER i
      REAL am,as,c,t,t2,xtra
      c=n+nph/4.
      t=c/1236.85
      t2=t**2
      as=359.2242+29.105356*c
      am=306.0253+385.816918*c+0.010730*t2
      jd=2415020+28*n+7*nph
      xtra=0.75933+1.53058868*c+(1.178e-4-1.55e-7*t)*t2
      if(nph.eq.0.or.nph.eq.2)then
        xtra=xtra+(0.1734-3.93e-4*t)*sin(RAD*as)-0.4068*sin(RAD*am)
      else if(nph.eq.1.or.nph.eq.3)then
        xtra=xtra+(0.1721-4.e-4*t)*sin(RAD*as)-0.6280*sin(RAD*am)
      else
        pause 'nph is unknown in flmoon'
      endif
      if(xtra.ge.0.)then
        i=int(xtra)
      else
        i=int(xtra-1.)
      endif
      jd=jd+i
      frac=xtra-i
      return
      END
fotran77b标准谢的,为什么要用八位或者九位的常数给real数据RAD,as,am赋值?单精度不是最多七位吗,多了有意义吗?
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

jackplay

金虫 (小有名气)

c语言中,如果最多有效位的数是这段函数的有效位,所以较少有效数位的数其实省去了最后的0而已,不知道是不是可以类比

发自小木虫Android客户端
maths physics chemistry
7楼2016-01-09 08:21:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 8 个回答

hklulu

木虫 (正式写手)

000

【答案】应助回帖

感谢参与,应助指数 +1
哈哈,新手吧。

八位不是指的数字的位数,而是二进制的8B,就是通常用64位二进制数字来表示双精度数字。

此位非彼位。
00
2楼2012-05-14 11:26:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

liming9398

金虫 (正式写手)

可能我没说清楚3.14159265不就是九位的吗,可RAD是real类型的也就是单精度类型的,最多七位有效数字啊,赋值时写这么多位还有意义吗,同样的问题出现在给real类型数据as赋值时表达式中出现29.105356,也超过7位有效数字啊
3楼2012-05-14 11:51:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hklulu

木虫 (正式写手)

000

【答案】应助回帖

奥,当然有意义:
32位机的单双精度的数据:单精度的有效数字:6位;双精度的有效数字:15位
64位机器上有最大18位有效数字和4932为指数的类型。

有些计算需要有效位数1000多位,比如Pi的计算等,这时候就需要自己编写程序来控制有效位数的输出。我记着10年前,我为了在PC上输出20位有效位数,亲自编写了一个多有效位(名为doubledoubledboule类型)的程序,不过现在网上多的很,楼主可以自己找一找,如果感兴趣的话。
00
4楼2012-05-14 13:47:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见