24小时热门版块排行榜    

查看: 1114  |  回复: 2

mplanck

至尊木虫 (职业作家)

之上又是啥子虫虫?

[交流] 【求助】fortran 程序windows 下编译正确,而linux下出错 已有2人参与

如题,一个cpc上下的程序,windows 下编译得到结果正确,
放在linux下就出问题:
用f77, fort77 编译,在两个sub模块结尾提示
Error on line 1679: Declaration error for rvv: adjustable dimension on non-
argument
Error on line 1679: wr_ardecls:  nonconstant array size
但我的数组没问题呀

再用gfortran,f95编译,编译通过,但结果不对

再用ifort编译,编译也通过,又出来一个不对的新结果

真搞不懂为什么这样?

麻烦虫虫门指点下,谢谢!

附出错部分代码:
其中报错的一个sub模块代码如下,1679行对应于最后一行,即‘end’所在行;再就是 整个代码中没有找到wr_ardecls这个东西,不知道咋搞的。非常感谢!
c------------------------------------------------------------------------
      subroutine dcludcmp(a,n,np,indx,d,ierror)
c  this is the double complex version of the homonyme sbr. from Numerical
c  Recipes
      implicit double complex(a-h,o-q,s-z)
      implicit double precision (r)
      parameter (tiny=(1.0d-30,1.0d-30))
      dimension a(np,np),indx(n),rvv(n)
      d=dcmplx(1.d0,0.d0)
    ierror=0
      do 12 i=1,n
        raamax=0.d0
        do 11 j=1,n
          if (cdabs(a(i,j)).gt.raamax) raamax=cdabs(a(i,j))
11      continue
        if (raamax.eq.0.d0)then
    write (*,*) 'singular matrix in dcludcmp'
    ierror=1
    return
    endif
        rvv(i)=1.d0/raamax
12    continue
      do 19 j=1,n
        if (j.gt.1) then
          do 14 i=1,j-1
            sum=a(i,j)
            if (i.gt.1)then
              do 13 k=1,i-1
                sum=sum-a(i,k)*a(k,j)
13            continue
              a(i,j)=sum
            endif
14        continue
        endif
        raamax=0.d0
        do 16 i=j,n
          sum=a(i,j)
          if (j.gt.1)then
            do 15 k=1,j-1
              sum=sum-a(i,k)*a(k,j)
15          continue
            a(i,j)=sum
          endif
          rdum=rvv(i)*cdabs(sum)
          if (rdum.ge.raamax) then
            imax=i
            raamax=rdum
          endif
16      continue
        if (j.ne.imax)then
          do 17 k=1,n
            dum=a(imax,k)
            a(imax,k)=a(j,k)
            a(j,k)=dum
17        continue
          d=-d
          rvv(imax)=rvv(j)
        endif
        indx(j)=imax
        if(j.ne.n)then
          if(cdabs(a(j,j)).eq.0.d0) a(j,j)=tiny
          dum=1.d0/a(j,j)
          do 18 i=j+1,n
            a(i,j)=a(i,j)*dum
18        continue
        endif
19    continue
      if(cdabs(a(n,n)).eq.0.d0) a(n,n)=tiny
      return
      end
c---------------------------------------------------------------------------
回复此楼
不知不觉过2W了!那向3W挺进~~
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

至尊木虫 (职业作家)

★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
余泽成(金币+2):辛苦了! 2010-07-17 10:46:06
不要用 f2c 编译你的程序,用 gfortran 或其它正宗的 Fortran 编译器,呵呵
用第二个错误提示 google 一下,你会发现,你不是遇到这个错误的第一人,呵呵……
f2c does not support automatic arrays; g77 does, as do most other f77
compilers (and all f90+).

至于结果不同,最大的可能是一些 local variable 没有赋值,这在 Fortran,尤其是一些老的程序中是非常常见的。用 gfortran  编译时加上 -fno-automatic -finit-local-zero 之类的参数试试……
2楼2010-07-17 08:56:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

mplanck

至尊木虫 (职业作家)

之上又是啥子虫虫?

非常感谢你的中肯回复,我试下
不知不觉过2W了!那向3W挺进~~
3楼2010-07-17 11:27:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 mplanck 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 机械专硕325,寻找调剂院校 +3 y9999 2026-03-15 5/250 2026-03-16 19:58 by y9999
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 283求调剂 +10 小楼。 2026-03-12 14/700 2026-03-16 16:08 by 13811244083
[考研] 0703化学调剂,求各位老师收留 +8 秋有木北 2026-03-14 8/400 2026-03-16 15:21 by 哦哦123
[考研] 材料与化工专硕调剂 +3 heming3743 2026-03-16 3/150 2026-03-16 15:05 by peike
[考研] 309求调剂 +5 花与叶@ 2026-03-10 5/250 2026-03-16 14:13 by 哦哦123
[教师之家] 焦虑 +7 水冰月月野兔 2026-03-13 9/450 2026-03-16 10:00 by Quakerbird
[考研] 344求调剂 +3 knight344 2026-03-16 3/150 2026-03-16 09:42 by 无际的草原
[考研] 294求调剂 +3 Zys010410@ 2026-03-13 4/200 2026-03-15 10:59 by zhq0425
[考研] 材料工程327求调剂 +3 xiaohe12w 2026-03-11 3/150 2026-03-14 20:20 by ms629
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[考研] 297求调剂 +4 学海漂泊 2026-03-13 4/200 2026-03-14 11:51 by 热情沙漠
[考研] 0703,333分求调剂 一志愿郑州大学-物理化学 +3 李魔女斗篷 2026-03-11 3/150 2026-03-13 22:24 by JourneyLucky
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] 0703化学一志愿211 总分320求调剂 +5 玛卡巴卡啊哈 2026-03-11 5/250 2026-03-13 21:40 by JourneyLucky
[考研] 333求调剂 +3 球球古力 2026-03-11 3/150 2026-03-13 21:27 by JourneyLucky
[考研] 工科278分求调剂 +5 周慢热啊 2026-03-12 7/350 2026-03-13 15:49 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-12 3/150 2026-03-13 14:30 by 求调剂zz
[考研] 277求调剂 +4 anchor17 2026-03-12 4/200 2026-03-13 11:15 by 白夜悠长
[考研] 大连大学化学专业研究生调剂 +3 琪久. 2026-03-10 8/400 2026-03-11 10:02 by 琪久.
信息提示
请填处理意见