24小时热门版块排行榜    

查看: 1113  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿985,本科211,0817化学工程与技术319求调剂 +5 Liwangman 2026-03-15 5/250 2026-03-16 17:10 by 我的船我的海
[基金申请] 今年的国基金是打分制吗? 50+3 zhanghaozhu 2026-03-14 3/150 2026-03-16 17:07 by 北京莱茵润色
[考研] 一志愿211 0703方向310分求调剂 +3 努力奋斗112 2026-03-15 3/150 2026-03-16 16:44 by houyaoxu
[考研] 312求调剂 +3 陌宸希 2026-03-16 4/200 2026-03-16 15:06 by peike
[考研] 290求调剂 +5 孔志浩 2026-03-12 10/500 2026-03-16 09:01 by 余晖&
[考研] 326求调剂 +4 上岸的小葡 2026-03-15 5/250 2026-03-16 08:39 by Linda Hu
[考博] 欢迎申博同学联系 +3 天道酬勤2026686 2026-03-10 7/350 2026-03-15 19:03 by 天道酬勤2026686
[考研] 289求调剂 +5 步川酷紫123 2026-03-11 5/250 2026-03-15 00:45 by kruisytel
[考研] 【0703化学调剂】-一志愿华中师范大学-六级475 +5 Becho359 2026-03-11 5/250 2026-03-14 11:35 by 哦哦123
[考研] 学硕285求调剂 +13 Wisjxn 2026-03-12 46/2300 2026-03-14 10:33 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-10 3/150 2026-03-14 00:30 by JourneyLucky
[考研] 337一志愿华南理工0805材料求调剂 +7 mysdl 2026-03-11 9/450 2026-03-13 22:43 by JourneyLucky
[考研] [0860]321分求调剂,ab区皆可 +4 宝贵热 2026-03-13 4/200 2026-03-13 22:01 by 星空星月
[考研] 26调剂/材料/英一数二/总分289/已过A区线 +6 步川酷紫123 2026-03-13 6/300 2026-03-13 21:59 by 星空星月
[硕博家园] 085600 260分求调剂 +3 天空还下雨么 2026-03-13 5/250 2026-03-13 18:46 by 天空还下雨么
[考研] 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 白夜悠长
[考研] 290求调剂 +3 ADT 2026-03-13 3/150 2026-03-13 10:19 by peike
[考研] 420求调剂 +4 莫向外求11 2026-03-10 6/300 2026-03-12 14:41 by ruiyingmiao
[考研] 哈工大材料324求调剂 +6 闫旭东 2026-03-10 8/400 2026-03-10 22:49 by 星空星月
信息提示
请填处理意见