我刚才又算了一遍,还是不行,大体思路我明白了,主要是角度和弧度的互换,太容易出错了,你刚才说的纬度需要换成弧度我觉得不对,我重新编了代码,后面都表明了单位,可是还是浮点数异常或者NAN,实在不知为何,计算了一上午,求解
[Fortran] 纯文本查看 复制代码 program ex0109
real*8:: delta(366),y(366),ws(366),sl(366)
integer n
real*8,parameter::pi=3.1415926
real*8 lat
lat=42.4025
do n=1,366
y(n)=(2*pi)*(n-1)/366!年角:弧度
delta(n)=(0.006918-0.399912*cos(y(n))+0.070257*sin(y(n))-0.006758*cos(2*y(n))&
+0.000907*sin(2*y(n))-0.002697*cos(3*y(n))+0.00148*sin(3*y(n)))!太阳赤纬:角度
!delta(n)=6.918E-3-3.99912E-1*cos(y(n))+7.0257E-2*sin(y(n))-6.758E-3*cos(2*y(n))&
!+9.07E-4*sin(2*y(n))-2.697E-3*cos(3*y(n))+1.48E-3*sin(3*y(n))
ws(n)=acos(-tan(lat)*tan(delta(n)))!时角(角度),算出来为弧度
sl(n)=ws(n)*(2/15)*(pi/180)!日长:弧度
end do
!write(*,fmt="(365f8.2)")delta(n)
open(unit=7,file="D:\Fortran读写文件\计算云量\tiwen\2012tianwen")
write(*,*)sl*10
stop
end |