INTENT(IN)变量定义上下文中的伪参数

时间:2017-01-21 17:38:17

标签: fortran differential-equations discretization

运行代码时,我的子程序中出现错误信息。

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

1 个答案:

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

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