我继承了传统的Fortran 77代码,现在我尝试在Fortran 2003标准中进行编译。我对 Fortran (我知道 C 和 Python)一无所知,我正在学习它。
下面的代码片段会导致编译器错误(也在下面给出)。说实话,光看这段代码就很头疼:我真的不明白怎么能写出这样一行代码
A(i) = A(i) + B(q)
其中 A 和 B 都是函数。我熟悉 C 和 Python 中递归函数的概念,如果我是此处介绍的这种情况下的编译器,我可能会抱怨并至少提出WTF警告。
我不希望任何人为我修复此代码。如果有人可以向我解释该行(尝试)要实现的目标,我将非常高兴:
cipr(IPR_WADV, ipa_idx, ispc) = cipr(IPR_WADV, ipa_idx, ispc) + fc1(l)/dy/depth(i,j,k)
或者把我介绍给我可以查到的好地方。
下面是代码片段和相应的编译器错误。
IF( lipr ) THEN
!-----Change from X-direction horizontal advection
l = 1
DO i=i1+1,i2-1
l = l+1
IF( ipa_cel(i,j,k) .GT. 0 ) THEN
ipa_idx = ipa_cel(i,j,k)
!-----Flux at west boundary
cipr(IPR_WADV, ipa_idx, ispc) = cipr(IPR_WADV, ipa_idx, ispc) + fc1(l)/dy/depth(i,j,k)
!-----Flux at east boundary
cipr(IPR_EADV, ipa_idx, ispc) = cipr(IPR_EADV, ipa_idx, ispc) + fc2(l)/dy/depth(i,j,k)
!-----Average volume
cipr(IPR_VOL, ipa_idx, ispc) = cipr(IPR_VOL, ipa_idx, ispc) + dx(j)*dy*depth(i,j,k)
npastep(ipa_idx,ispc) = npastep(ipa_idx,ispc) + 1
END IF
END DO
END IF
编译器将此输出消息作为错误提供
gfortran -std=f2003 -c -g -o build/Debug/GNU-Linux-x86/xyadvec.o
xyadvec.f03 xyadvec.f03:177.42:
cipr(IPR_WADV, ipa_idx, ispc) = cipr(IPR_WADV, ipa_idx, ispc) + fc1(l
1
Error: Statement function at (1) is recursive