24小时热门版块排行榜    

Znn3bq.jpeg
查看: 264  |  回复: 0

zeng0927

金虫 (初入文坛)

[求助] 求教一个FORTRAN一维稳态流体模拟的程序错误

PROGRAM MAIN
! Predictor Corrector Method for Coupled Exchange in Column
! Boundary conditions C(N+1)=C(N), C(0)=CHS or CDS
! IMPLICIT REAL*8 (A-H),REAL*8 (P-Z)
DIMENSION CHG(0:200),CHGM(0:200)
DIMENSION CDG(0:200),CDGM(0:200)
DIMENSION PA(0:200),VF(0:200),AVF(0:200)
REAL*8 K,M,NTIME,L
   OPEN(UNIT=3,FILE='TEST1.OUT',FORM='FORMATTED',STATUS='UNKNOWN')
   OPEN(UNIT=4,FILE='INPUT.TXT',FORM='FORMATTED',STATUS='UNKNOWN')
   WRITE(*,*)'Input column lenghth (cm)'
   READ(4,*)L
   WRITE(*,*)'Input temperature (K)'
   READ(4,*)T
   WRITE(*,*)'Input let in pressure (Torr)'
   READ(4,*)PIN
   WRITE(*,*)'Input let out pressure (Torr)'
   READ(4,*)POUT
   WRITE(*,*)'Input porosity (1)'
   READ(4,*)E
   WRITE(*,*)'Input viscosity (10-6pa.s)'
   READ(4,*)M
   WRITE(*,*)'Input permeability (10-12m2)'
   READ(4,*)K
   WRITE(*,*)'Input total exchange time(sec)'
   READ(4,*)TIME
   L=L*0.01
   !M=M*0.000001
   !K=K*0.000000000001
   N=199
   NPO=N+1
   DELL=L/(NPO)
   DELT=0.1
   DELTDT=DELT/2
   NTSTOP=TIME/DELT
   CHGR=1
   CDGR=0
   DO 10 J=1,NPO
   CHG(J)=0
10 CDG(J)=0
   CHG(0)=CHGR
   CDG(0)=CDGR
   DO 12 NT=1,NTSTOP
! Perform Predictor Operation (half time step)
   CALL COEFFV(PA,VF,AVF,PIN,POUT,DELL,DELTDT,L,K,E,M,N)
   CALL UPTWOHG(CHG,CHG,CHGM,AVF,DELTDT,E,N)
   CALL UPTWODG(CDG,CDG,CDGM,AVF,DELTDT,E,N)
! Perform Corrector Operation (full time step)
   CALL COEFFV(PA,VF,AVF,PIN,POUT,DELL,DELT,L,K,E,M,N)
   CALL UPTWOHG(CHG,CHGM,CHGM,AVF,DELT,E,N)
   CALL UPTWODG(CDG,CDGM,CDGM,AVF,DELT,E,N)
   DO 11 J=0,NPO
   CHGM(J)=(CHGM(J)+CHG(J))/2
11 CDGM(J)=(CDGM(J)+CDG(J))/2
   CALL COEFFV(PA,VF,AVF,PIN,POUT,DELL,DELT,L,K,E,M,N)
   CALL UPTWOHG(CHG,CHGM,CHG,AVF,DELT,E,N)
   CALL UPTWODG(CDG,CDGM,CDG,AVF,DELT,E,N)
   NTIME=NT*DELT
   WRITE(3,202) NTIME,' ',CHG(1),' ',CHG(10),' ',CHG(100),' ',CHG(150)
12 CONTINUE
202 FORMAT (1F7.2,A1,1F12.5,A1,1F12.5,A1,1F12.5,A1,1F12.5)
STOP
END

SUBROUTINE COEFFV(PA,VF,AVF,PIN,POUT,DELL,DELT,L,K,E,M,N)
DIMENSION PA(0:200),VF(0:200),AVF(0:200)
REAL*8 K,M,L
   DO 10 J=1,N
10 PA(J)=(PIN**2-((PIN**2)-(POUT**2))*(J*DELL/L))**0.5
   PA(0)=PIN
   PA(N+1)=POUT
   DO 11 J=1,N
11 VF(J)=(PA(J-1)-PA(J+1))*K/(2*DELL*E*M)
   DO 12 J=1,N
12 AVF(J)=VF(J)*DELT/(4*DELL)
   AVF(0)=AVF(1)
   AVF(N+1)=AVF(N)
RETURN
END

SUBROUTINE UPTWOHG(CHG,CHGM,CHGN,AVF,DELT,E,N)
! This is version for gas phase H concentration change in column coordinates
! IMPLICIT REAL*8 (A-H),REAL*8 (P-Z)
DIMENSION CHG(0:200),CHGM(0:200),CHGN(0:200)
DIMENSION AVF(0:200)
DIMENSION A(199),B(199),C(199),QH(199),UDAG(199)
   DO 10 J=1,N
   A(J)=-AVF(J)
   B(J)=1
10 C(J)=AVF(J)
! Calculate H array at beginning of time step
   DO 11 J=1,N
   QH(J)=CHG(J)+AVF(J)*(CHGM(J-1)-CHGM(J+1))+2*(AVF(J-1)-AVF(J+1))*CHG(J)
11 CONTINUE
   QH(N)=QH(N)+AVF(N)*CHGM(N-1)
   CALL TRIDAG (A,B,C,QH,UDAG,N)
   DO 12 J=1,N
12 CHGN(J)=UDAG(J)
   CHGN(0)=CHG(0)
   CHGN(N+1)=CHG(N)
RETURN
END

SUBROUTINE UPTWODG(CDG,CDGM,CDGN,AVF,DELT,E,N)
! This is version for gas phase D concentration change in column coordinates
! IMPLICIT REAL*8 (A-H),REAL*8 (P-Z)
DIMENSION CDG(0:200),CDGM(0:200),CDGN(0:200)
DIMENSION AVF(0:200)
DIMENSION A(199),B(199),C(199),QD(199),UDAG(199)
   DO 10 J=1,N
   A(J)=-AVF(J)
   B(J)=1
10 C(J)=AVF(J)
! Calculate D array at beginning of time step
   DO 11 J=1,N
   QD(J)=CDG(J)+AVF(J)*(CDGM(J-1)-CDGM(J+1))+2*(AVF(J-1)-AVF(J+1))*CDG(J)
11 CONTINUE
   CALL TRIDAG (A,B,C,QD,UDAG,N)
   DO 12 J=1,N
12 CDGN(J)=UDAG(J)
   CDGN(0)=CDG(0)
   CDGN(N+1)=CDG(N)
RETURN
END

SUBROUTINE TRIDAG (A,B,C,Q,U,N)
! This is from Numerical Recipes in Fortran
! IMPLICIT REAL*8 (A-H),REAL*8 (P-Z)
PARAMETER (NMAX=200)
DIMENSION GAM(NMAX),A(N),B(N),C(N),Q(N),U(N)
! IF(B(1).EQ.0.)PAUSE
   BET=B(1)
   U(1)=Q(1)/BET
   DO 11 J=2,N
   GAM(J)=C(J-1)/BET
   BET=B(J)-A(J)*GAM(J)
! IF(BET.EQ.0.)PAUSE
   U(J)=(Q(J)-A(J)*U(J-1))/BET
11 CONTINUE
   DO 12 J=N-1,1,-1
   U(J)=U(J)-GAM(J+1)*U(J+1)
12 CONTINUE
RETURN
END

具体的问题是:
速度VF是线性递增的,我估计是有压力降的原因,不知道对不对;

还有就是SUBROUTINE UPTWOHG这个子程序算出的CHG与理论值相差太大,一直找不到原因。

涉及的公式
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

智能机器人

Robot (super robot)

我们都爱小木虫

相关版块跳转 我要订阅楼主 zeng0927 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 271求调剂 +32 2261744733 2026-04-11 33/1650 2026-04-15 22:03 by noqvsozv
[考研] 297,工科调剂? +3 河南农业大学-能 2026-04-14 3/150 2026-04-15 22:02 by noqvsozv
[考研] 求调剂 +11 小聂爱学习 2026-04-11 15/750 2026-04-15 21:57 by noqvsozv
[考研] 291分调剂 +11 上岸小莹加油 2026-04-09 12/600 2026-04-15 21:55 by noqvsozv
[考研] 307中医考研调剂 +4 于以采蘩 2026-04-14 4/200 2026-04-15 19:14 by AN流800
[考研] 297工科调剂? +14 河南农业大学-能 2026-04-13 15/750 2026-04-15 13:25 by 黑科技矿业
[考研] 复试调剂 +21 积极向上; 2026-04-10 23/1150 2026-04-15 12:50 by 西北望—风沙
[考研] 农学0904 312求调剂 +4 Say Never 2026-04-11 4/200 2026-04-14 09:10 by zs92450
[考研] 一志愿211 0703化学 346分求调剂 +26 土豆er? 2026-04-09 29/1450 2026-04-13 15:15 by 独醉梦孤城
[考研] 0831一轮调剂失败求助 +10 小熊睿睿_s 2026-04-11 10/500 2026-04-12 22:43 by 长弓傲
[考研] 307求调剂 +10 tzq94092 2026-04-10 10/500 2026-04-12 08:18 by wise999
[考研] 270求调剂 +14 杨乐369 2026-04-11 14/700 2026-04-11 20:16 by 蓝云思雨
[考研] 085600材料与化工329分求调剂 +16 叶zilin 2026-04-10 16/800 2026-04-11 11:04 by may_新宇
[考研] 0854调剂 +8 950824he@ 2026-04-09 8/400 2026-04-11 10:11 by zhq0425
[考研] 中药学调剂 初试324 +4 洋甘菊、 2026-04-10 6/300 2026-04-11 09:41 by gong120082
[考研] 调剂 +19 小张ZA 2026-04-10 20/1000 2026-04-10 22:08 by 猪会飞
[考研] 22408 366分,本科211,一志愿西工大 +4 Rubt 2026-04-09 4/200 2026-04-10 19:51 by chemisry
[考研] 0858求调剂 5+5 Gky09300550, 2026-04-10 8/400 2026-04-10 19:13 by chemisry
[考研] 一志愿中科大070300化学,314分求调剂 +12 wakeluofu 2026-04-09 12/600 2026-04-10 09:57 by liuhuiying09
[考研] 083200 初试305分 求调剂 暂不考虑跨专业 +15 Claireyyyy 2026-04-09 15/750 2026-04-09 16:11 by zhuimr
信息提示
请填处理意见