运行代码时,我的子程序中出现错误信息。
此代码来自Kincaid&切尼关于高斯赛德尔方法的书,用于求解椭圆偏微分方程。
错误消息是:
在(1)的变量定义上下文(赋值)中使用INTENT(IN)伪参数'u'。
我在下面的代码中引用(1)。如何修复子程序以便错误消息不会出现?
subroutine seidel(ax,ay,nx,ny,h,itmax,u)
real, dimension(0:nx,0:ny), intent(in) :: u
real, intent(in) :: ax,ay, h
integer, intent(in) :: nx, ny, itmax
integer:: i,j,k
do k = 1,itmax
do j = 1,ny-1
y = ay + real(j)*h
do i = 1,nx-1
x = ax + real(i)*h
v = u(i+1,j) + u(i-1,j) + u(i,j+1) + u(i,j-1)
u(i,j) = (v - h*h*g(x,y))/(4.0 - h*h*f(x,y)) (1)
end do
end do
end do
end subroutine seidel
答案 0 :(得分:3)
intent(in)
是对编译器的承诺,例程不会尝试更新参数的值。您展示的代码违反了该行中的承诺:
u(i,j) = (v - h*h*g(x,y))/(4.0 - h*h*f(x,y))
通过不违反您的承诺来解决此问题,或者在这种情况下更合适,制作意图inout
,就像这样
real, dimension(0:nx,0:ny), intent(inout) :: u
inout
告诉编译器该例程将被传递给参数并可能对其进行修改。
(我认为这可能是重复的,但还无法找到。)