4

当我运行我的代码时,我的子程序中收到一条错误消息。

此代码来自 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
4

1 回答 1

6

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告诉编译器例程将被传递参数并可以对其进行修改。

(我认为这可能是重复的,但还找不到。)

于 2017-01-21T17:49:25.753 回答