24小时热门版块排行榜    

Znn3bq.jpeg
查看: 263  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿A区211,22408 321求调剂 +4 随心所欲☆ 2026-04-15 4/200 2026-04-15 19:45 by qingfeng258
[考研] 294求调剂 +5 淡然654321 2026-04-15 5/250 2026-04-15 19:36 by coolfishwll
[考研] 296求调剂 +5 汪!?! 2026-04-08 5/250 2026-04-15 14:38 by 黑科技花岗岩
[考研] 0854调剂 +13 长弓傲 2026-04-12 16/800 2026-04-15 13:45 by fenglj492
[考研] 279求调剂 +12 张番茄不炒蛋 2026-04-11 12/600 2026-04-14 15:38 by zs92450
[考研] 271求调剂 +35 2261744733 2026-04-11 41/2050 2026-04-14 15:36 by zs92450
[考研] 一志愿华南理工大学331分材料求调剂 +10 天下ww 2026-04-09 11/550 2026-04-13 23:25 by pies112
[考研] 0856专硕求调剂 希望是a区院校 +24 好好休息好不好 2026-04-09 27/1350 2026-04-13 22:22 by pies112
[基金申请] 2026 WR青拔 +3 冬日阳光CAS 2026-04-09 6/300 2026-04-13 18:40 by liuchb715
[考研] 材料考研调剂 +29 云木达达 2026-04-11 31/1550 2026-04-13 13:32 by lyh鲁老师
[教师之家] 山东双非院校考核超级无底线,领导幸灾乐祸,教师遭殃恐 +3 qut2026 2026-04-11 7/350 2026-04-12 20:24 by qut2026
[考研] 326求调剂 +6 Shansyn 2026-04-10 6/300 2026-04-12 09:46 by hammer3
[考研] 085410 273求调剂 +10 X1999 2026-04-09 10/500 2026-04-12 09:24 by 逆水乘风
[考研] 307求调剂 +10 tzq94092 2026-04-10 10/500 2026-04-12 08:18 by wise999
[考研] 359求调剂 +5 胃痉挛累了 2026-04-11 5/250 2026-04-11 19:55 by lbsjt
[考研] 352 求调剂 +6 yzion 2026-04-11 8/400 2026-04-11 16:24 by 明月此时有
[考研] 085402通信工程调剂,有4项学科竞赛国奖(电赛国二),硕士研究生调剂自荐信。 +5 m永o不v言o弃m 2026-04-09 5/250 2026-04-11 09:33 by zhq0425
[考研] 考研调剂 +26 硕星赴 2026-04-09 27/1350 2026-04-10 22:24 by 猪会飞
[考研] 083200 305分 求二轮调剂 不接受跨专业 +9 Claireyyyy 2026-04-09 10/500 2026-04-10 21:21 by Claireyyyy
[考研] 调剂申请086000一志愿西北农林科技大学生物与医药320分-本科齐鲁工业大学 +3 美美女士 2026-04-09 3/150 2026-04-10 10:31 by liuhuiying09
信息提示
请填处理意见