24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1943  |  回复: 10

xiaobear20

兑换贵宾

(⊙o⊙)…

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

[求助] FORTRAN新手 求助主程序循环问题

我现贴出主程序部分:
     PROGRAM MAIN  
        USE SAME
        IMPLICIT NONE            

       N=120
      M=241
      ITMAX=60  
     ITER=0            
     CALL INPUT
     CALL GRID      
     DO I=1,M                        !!!!!!初始条件!!!!!!!!!!
          DO J=2,N-1                    
          W(I,J)=1-EXP(-ETA(J))
          ENDDO                        
     ENDDO
60 ITER=ITER+1
     SELECT CASE(ITER-ITMAX)
     CASE(:-1)        !  <= -1   整数
   GO TO 70
    CASE(0)          !   =0
    WRITE(6,2500)
    GO TO 70
    CASE(1         !   >=1
    WRITE(6,2600)
    GO TO 90
    END SELECT
70  DO I=1,M
         DO J=2,N-1
         WOLD(I,J)=W(I,J)      
        ENDDO
     ENDDO            
     CALL EDDY
     CALL CMOM                              
     CALL SOLV
     DO I=2,M
          DO J=2,N-1
           CONVER(I,J)=ABS(1-(WOLD(I,J)/W(I,J)))  
          ENDDO
      ENDDO
      MX=MAXVAL(CONVER)   !选取误差中的最大值
      IF(MX.LE.EPS)THEN    !     <=0.0001 !收敛判断  EPS=0.0001   误差 CONVER
      GO TO  90   
      ELSE
      GOTO 60
      ENDIF                                                                              
90 CALL OUTPUT
      END PROGRAM
程序主要过程如下是,(计算的是一个二维网格点上的速度,即二维数组),先给迭代的矩阵赋初值,继而进行第一次迭代,每次迭代完后,把此次结果与上一次的结果进行比较,逐点比较,选出最大误差,再与收敛条件ESP比较,如满足条件则输出结果,如不满足,再返回迭代,直到满足收敛条件为止,(其中也对迭代的次数进行了判断)
我的问题如下:不知道怎么回事,程序只进行了一次计算就输出了结果,没有进行第二次,还有误差判断CONVER(I,J)总是为0,我把子程序的结果也输出看了一下,各个子程序还是运行了一次。我就不知道问题在哪了。是结构问题还是别的,求大神指道,分少别嫌弃啊,急等啊
子程序
CALL EDDY
     CALL CMOM                              
     CALL SOLV
在子程序EDDY中都用到了初始值,CMOM是矩阵系数的计算,SOLV是最后的结果计算,谢谢
回复此楼
一切还好
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

专家顾问

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖


感谢参与,应助指数 +1
xzhdty: 金币+1, 欢迎常来 2012-04-07 14:48:19
这个程序没有办法改,比如你的 W(I,J) 的值有更新吗?在你的程序中,你的 WOLD 与 W 一直都是一样的,那么 CONVER 当然总是 0 了。因此,只迭代一次是很正常的。如果在 WOLD 之后,还有 W 更新,那么情况可能会不一样。但这个没有办法看出来,因为你的所有 subroutine 的返回值是啥都看不出来……

另外,你似乎喜欢用全局变量作为 subroutine 的参数和返回值,很多时候,这个习惯并不好,呵呵……
2楼2012-04-07 12:55:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaobear20

主管区长

(⊙o⊙)…

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

引用回帖:
2楼: Originally posted by snoopyzhao at 2012-04-07 12:55:00:
这个程序没有办法改,比如你的 W(I,J) 的值有更新吗?在你的程序中,你的 WOLD 与 W 一直都是一样的,那么 CONVER 当然总是 0 了。因此,只迭代一次是很正常的。如果在 WOLD 之后,还有 W 更新,那么情况可能会不 ...

对,如果W值改变了的话,这样是把前一次的W值赋给WOLD啊,这样就可以看做是与前一次值进行比较啊,那这个全局变量的问题有怎么改了,我是新手 呵呵
一切还好
3楼2012-04-07 13:35:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

专家顾问

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

引用回帖:
3楼: Originally posted by xiaobear20 at 2012-04-07 13:35:37:
对,如果W值改变了的话,这样是把前一次的W值赋给WOLD啊,这样就可以看做是与前一次值进行比较啊,那这个全局变量的问题有怎么改了,我是新手 呵呵

你的 W 值在哪里改变的呢?在 WOLD 之前,还是之后?反正你给的主程序中看不出来……

用全局变量似乎也没有啥问题,如果可能尽量不要用全局变量(这只是我个人的看法)……
4楼2012-04-07 14:37:59
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xiaobear20

专家顾问

(⊙o⊙)…

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

引用回帖:
4楼: Originally posted by snoopyzhao at 2012-04-07 14:37:59:
你的 W 值在哪里改变的呢?在 WOLD 之前,还是之后?反正你给的主程序中看不出来……

用全局变量似乎也没有啥问题,如果可能尽量不要用全局变量(这只是我个人的看法)……

是在WOLD之后改变的,就在子程序 EDDY  CMOM  SOLV后啊  在SOLV后 用W值与WOLD比较,即W与前一次W值比较
一切还好
5楼2012-04-07 15:34:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

管理员

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖

引用回帖:
5楼: Originally posted by xiaobear20 at 2012-04-07 15:34:19:
是在WOLD之后改变的,就在子程序 EDDY  CMOM  SOLV后啊  在SOLV后 用W值与WOLD比较,即W与前一次W值比较

w 到底在哪里改变的?

从你的描述来看应该是在 wold 之前,因为 wold 之后,w 和 wold 就是相同的了,所以就就会出问题了。

你可以把 wold 那个循环放在 eddy, cmom solv 之前试试看……
6楼2012-04-07 16:28:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

管理员

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
xiaobear20: 金币+50, 有帮助, 谢谢 2012-04-10 18:57:32
哦,不好意思,看错了。如果在 eddy, comom, solv 之后变化的应该没有问题啊……

你把 w 和 wold 打印出来看看吧……
7楼2012-04-07 16:30:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

snoopyzhao

管理员

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

【答案】应助回帖

如果不是保密的,以及巨大的程序,最好放个可以编译执行的源码上来吧,否则太费劲了……
8楼2012-04-07 16:32:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fys131415

兑换贵宾

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

请问你解决了吗,我也是在调用子程序的时候,虽然子程序有做运算,但感觉最后的值没返回去。我也是每次循环的结果都一样,不知问题在哪里。
9楼2012-06-28 15:51:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fys131415

实习版主

优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!优秀!!有木有!!!

希望可以交流一下,
10楼2012-06-28 15:52:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 xiaobear20 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 335求调剂 +3 321* 2026-03-31 4/200 2026-04-01 00:00 by 321*
[考研] 070300化学专业279调剂 +10 哈哈哈^_^ 2026-03-31 10/500 2026-03-31 23:13 by liu823948201
[考研] 271求调剂 +8 勒布朗@ 2026-03-31 10/500 2026-03-31 22:53 by wwytracy
[考研] 334分 一志愿武理-080500 材料求调剂 +10 李李不服输 2026-03-25 10/500 2026-03-31 21:20 by yuq
[考研] 安徽大学专硕生物与医药专业(086000)324分,英语已过四六级,六级521,求调剂 +10 美味可乐鸡翅 2026-03-26 11/550 2026-03-31 19:20 by syh9288
[考研] 329求调剂,一志愿西北工业大学,材料工程(085601) +6 小小机灵虫 2026-03-29 12/600 2026-03-31 16:58 by 记事本2026
[考研] 求化学调剂 +12 wulanna 2026-03-28 12/600 2026-03-31 16:38 by 690616278
[考研] 材料与化工272求调剂 +25 阿斯蒂芬2004 2026-03-28 25/1250 2026-03-31 16:27 by hypershenger
[考研] 求收留 +8 1943443204 2026-03-28 8/400 2026-03-31 15:00 by -迷了路啊路
[考研] 22408 359分调剂 +4 Qshers 2026-03-27 8/400 2026-03-31 08:53 by Qshers
[考研] 一志愿食品科学与工程083200求调剂 +4 XQTJZ 2026-03-30 4/200 2026-03-31 04:10 by fmesaito
[考研] 303求调剂 +7 DLkz1314. 2026-03-30 7/350 2026-03-30 21:07 by peike
[考研] 281求调剂 +5 亚克西good 2026-03-26 7/350 2026-03-30 20:42 by dophin1985
[考研] 考研调剂 +5 Sanmu-124 2026-03-26 5/250 2026-03-30 13:36 by chemdavid
[考研] 环境科学与工程334分求调剂 +6 王一一依依 2026-03-30 8/400 2026-03-30 11:52 by yjolah
[考研] 299求调剂 +10 15188958825 2026-03-25 10/500 2026-03-29 17:51 by 王亮_大连医科大
[考研] 085600,专业课化工原理,321分求调剂 +5 大馋小子 2026-03-28 5/250 2026-03-29 08:56 by qingfeng258
[考研] 本科新能源科学与工程,一志愿华理能动285求调剂 +3 AZMK 2026-03-27 5/250 2026-03-28 16:19 by xxxsssccc
[考研] 085600,材料与化工321分,求调剂 +9 大馋小子 2026-03-27 9/450 2026-03-27 14:30 by mmm just
[考研] 化学调剂一志愿上海交通大学336分-本科上海211 +4 小鱼爱有机 2026-03-25 4/200 2026-03-26 10:19 by aa331100
信息提示
请填处理意见