我正在尝试设置我的功能f
作为数组,但我收到以下错误:
Program received signal SIGSEGV: Segmentation fault - invalid memory reference.
Backtrace for this error:
#0 0x6f8b36e3
#1 0x6f8a2722
#2 0x402752
#3 0x747bd411
我必须解开普勒方程:f=psi-e*sin(psi)-M
对于每个值M
.所以,如果我有一个数组M
对于 8 维,我的程序将计算 8 个零。问题是,如果我写f=psi-e*sin(psi)-M(1)
我将计算第一个零,如果我写f=psi-e*sin(psi)-M(8)
我将计算最后一个零。但是,我的问题是,如果我想一次计算所有零,我必须写f=psi-e*sin(psi)-M(1:8)
我的程序应该输入全零,但是,这并没有发生,我收到了前面提到的错误。这是代码:
子程序(我在外部使用):这个子程序是二分法(得到零):
subroutine bisecc(f,xl,xr,kmax,tol,k,xm)
implicit real*8 (a-h,o-z)
real*8 f
fl=f(xl)
fr=f(xr)
if(fl*fr .gt. 0.0D0) goto 100
do k=1,kmax
xm=(xr+xl)/2.0D0
fm=f(xm)
dif=abs((xr-xl)/xm)
if(dif .lt. tol) goto 200
write(*,*) k,xm!,dif
if (fm*fr .le. 0.0D0) then
xl=xm
fl=fm
else
xr=xm
fr=fm
end if
end do
return
200 write(*,*) 'WISHED PRECISION REACHED'
return
100 write(*,*) 'BAD CHOICE OF DATA'
return
end
主要程序:
include 'bisecc.f'
implicit real*8 (a-h,o-z)
external f
real*8 f
! I WRITE THE INTERVAL OF MY 8 ZEROS(left and right point)
b=0.1D0
xl1=-0.5D0
xr1=0.D0
xl2=xr1+b
xr2=1.D0
xl3=xr2+b
xr3=2.D0
xl4=xr3+b
xr4=3.D0
xl5=xr4+b
xr5=4.D0
xl6=xr5+b
xr6=5.D0
xl7=xr6+b
xr7=6.D0
xl8=xr7+b
xr8=7.D0
kmax=100
tol=0.0001D0
call bisecc(f,xl1,xr1,kmax,tol,k,xm1)
call bisecc(f,xl2,xr2,kmax,tol,k,xm2)
call bisecc(f,xl3,xr3,kmax,tol,k,xm3)
call bisecc(f,xl4,xr4,kmax,tol,k,xm4)
call bisecc(f,xl5,xr5,kmax,tol,k,xm5)
call bisecc(f,xl6,xr6,kmax,tol,k,xm6)
call bisecc(f,xl7,xr7,kmax,tol,k,xm7)
call bisecc(f,xl8,xr8,kmax,tol,k,xm8)
write(*,*) 'Program ended'
stop
end program
real*8 function f(psi)
implicit real*8 (a-h,o-z)
real*8 M(8)
dimension f(8)
e=0.2056D0
pi=acos(-1.0D0)
M=(/pi/4.D0,pi/2.D0,3.D0/4.D0*pi,pi,5.D0/4.D0*pi,3.D0*
& pi/2.D0,7.D0/4.D0*pi,2.D0*pi/)
c=sqrt((1.0D0-e)/(1.0D0+e))
f=psi-e*sin(psi)-M(1:8) !KEPLER EQUATION
return
end function
例子:
这里我想计算M的第一个值的psi值,M(1)=pi/4
.
In https://i.stack.imgur.com/qxEv2.jpg https://i.stack.imgur.com/qxEv2.jpg你可以看到psi=0.95303344726562489
。所以我刚刚计算了第一个零。但是,您还可以看到此消息 7 次datos mal elegidos
。这意味着该程序只能向我显示零(对于M(1)
),其余7个零不计算,因为我写了 f=psi-e*sin(psi)-M(1)
。
我应该写什么才能得到结果all零而不是 1,就像这个例子中那样?