Compaq Visual Fortran 6.6 で以前にコンパイルされたコードを gfortran に変換しようとして、いくつかの問題に直面しています。
これは私が gfortran で遭遇した特定の問題です:
値 3E+10 を取る "et" と呼ばれる変数があります。次に、プログラムはサブルーチンを呼び出します。「et」はサブルーチンに現れませんが、メイン プログラムに戻ると、値が 0 になっています
。Compaq Visual Fortran でコンパイルすると、この問題は発生しませんでした。
私が取り組んでいるコードは巨大な科学プログラムなので、その一部だけを以下に示します。
c
c calculate load/unload modulus
c
500 t=(s1-s3)/2.
aa=1.00
if(iconeps.ne.1)bb=1.00
if(smean.lt.ap1) smean=ap1
if(xn.gt.0.000001) aa=(smean/atmp)**xn
if(iconeps.eq.1)go to 220
if(xm.gt.0.000001) bb=(smean/atmp)**xm
220 if(t.ge.0.99*sm1) go to 600
et=xku*aa*atmp+tt*tm1
if(iconeps.ne.1)bt=xkb*atmp*bb
go to 900
600 et=(xkl*aa*atmp+tt*tm1)*(1.0-rf*sr)**2
if(iconeps.ne.1)bt=xkb*atmp*bb
900 continue
btmax=17.0*et
btmin=0.33*et
if(iconeps.ne.1)then
tbt=(alf1+alf3*dtt)*dtt*(1.+vide)*tm2
btf=bt+tbt
bt=btf
endif
if(bt.lt.btmin) bt=btmin
if(bt.gt.btmax) bt=btmax
if(iconeps.eq.1)go to 1100
1000 continue
1050 if(mt.eq.mtyp4c)goto 1100
s=0.0
t=0.0
call shap4n(s,t,f,pfs,pft) ! Modification by NHV
call thick4n(s,t,xe,ye,thick)
call bmat4n(xe,ye,f,pfs,pft,b,detj,thick)
c calculate incremental strains
do 1300 i=1,4
temp=0.0
do 1200 j=1,8
1200 temp=temp+b(i,j)*disp(j)
1300 depi(i)=temp
epsv=0.0
do 1400 i=1,2
1400 epsv=epsv+depi(i)
epsv=epsv+depi(4)
ev=vide-(1.+vide)*epsv
if(ev.lt.0.0)ev=vide*.01
1100 continue
call perm(permws,xkw,coef,rw,tvisc,ev,vide,tt,pp)
: "et" は、サブルーチン "perm" を呼び出す直前まで適切な値を保持します。このサブルーチンの直後に値ゼロを取ります。
「et」はどの共通ブロックにもありません
このコード片は、いくつかの異なるサブルーチンによって呼び出されるサブルーチンの一部です。さらに奇妙なのは、コードの他の部分で呼び出されたときにこの問題が発生しないことです (「et」はその値を保持します)
。とても感謝しています