Jef*_*aci 4 fortran differential-equations discretization
当我运行我的代码时,我在我的子例程中收到一条错误消息。
此代码来自 Kincaid & Cheney 的书中关于求解椭圆偏微分方程的 Gauss Seidel 方法的练习。
错误信息是:
在 (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
Run Code Online (Sandbox Code Playgroud)
intent(in)
是对编译器的承诺,即例程不会尝试更新参数的值。您显示的代码打破了这一承诺:
u(i,j) = (v - h*h*g(x,y))/(4.0 - h*h*f(x,y))
Run Code Online (Sandbox Code Playgroud)
通过不违反您的承诺来解决此问题,或者在这种情况下可能更合适,使意图像inout
这样
real, dimension(0:nx,0:ny), intent(inout) :: u
Run Code Online (Sandbox Code Playgroud)
inout
告诉编译器该例程将被传递参数并可对其进行修改。
(我认为这可能是重复的,但还找不到。)