0

我正在尝试使用 Openmp 并行化子例程。该子程序包含一个连续的过松弛循环,该循环在作为共享变量的总误差上运行。现在,当我将在主程序中调用子例程的部分并行化时,它会使错误成为私有变量,然后我无法在主程序中显式地将其设为共享变量。

我正在粘贴代码以供参考。

program test
!$omp parallel
call sub()
!$omp end parallel
end program test

subroutine sub()
do  while(totalerror.ge.0.0001.and.sor.lt.10000)
totalerror=0.0
sor=sor+1
error=0.0
!$OMP DO REDUCTION(+:toterror) REDUCTION(MAX:error) 
! shared (vorticity,strmfn,toterror,error,guess) PRIVATE (i,j,t1,t2)
do i=1,nx
do j=1,ny
guess(i,j)=0.25*((h**2.)*vorticity(i,j)+strmfn(i+1,j)+strmfn(i-    1,j)+strmfn(i,j+1)+strmfn(i,j-1))
totalerror = totalerror + error
error      = max(abs(strmfn(`enter code here`i,j) - guess(i,j)),error)
strmfn(i,j)= strmfn(i,j) + omega*(guess(i,j)-strmfn(i,j))
enddo
enddo
!$OMP END DO
enddo

任何帮助,将不胜感激。

4

1 回答 1

0

toterror并且error不应该在shared子句中,因为它们在reduction. 如果您需要shared版本,请将它们复制到不同的变量中。

于 2013-04-28T15:07:29.223 回答