24小时热门版块排行榜    

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

xmch2011

铁虫 (小有名气)

[求助] 求fortran95编写的数值程序

想学学用fortran95写的数值程序,那位同学有没有这样的程序,学习一下,谢谢!
回复此楼
数学,力学,物理
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wll778824

银虫 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★
感谢参与,应助指数 +1
小雨萌萌: 金币+5, 帮发放金币咯~ 2012-04-05 16:34:13
给你一个有限体积算法求解Burgers  方程的fortran程序,源代码用固定格式写的
        !Solve Burgers equation u_t+(u^2/2)_x=0 using Finite Volume Method
        !The time is discretized by using RK3





        module constant
        implicit double precision(a-h,o-z)
        parameter pi=3.1415926,dt=0.001,nw=2000
        parameter n=20,h=2.0*pi/dble(n),san=0.0
        end module

        program FVM
        use constant
        implicit double precision(a-h,o-z)
        common u0(-1:n+2),u1(-1:n+2),u2(-1:n+2)
        common/u/ u(-1:n+2),uminus(0:n),uadd(0:n) !uminus=u^-,uadd=u^+
        common/flux/ flux(0:n)
        common/ua/ ua1(n),ua2(n),state(n)

        common u3(-1:n+2)


        do j=1,n
        u0(j)=1.0/3.0+2.0/(3.0*h)
     &*(cos((dble(j-1))*h+san)-cos(dble(j)*h+san))
        enddo
        u0(0)=u0(n)
        u0(-1)=u0(n-1)
        u0(n+1)=u0(1)
        u0(n+2)=u0(2)




        u=u0
        call RECONS

        do ntime=1,nw



        call AVERAGE
       

        u1=0
        u0(0)=0
        u0(n+1)=0
        u(0)=0
        u(n+1)=0
        u1=u0+dt*u
        u=u1
        u(0)=u(n)
        u(-1)=u(n-1)
        u(n+1)=u(1)
        u(n+2)=u(2)
         
       
        call RECONS
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
        call AVERAGE
        u2=0
        u0(0)=0
        u0(n+1)=0
        u1(0)=0
        u1(n+1)=0
        u(0)=0
        u(n+1)=0
        u2=0.75*u0+0.25*u1+0.25*dt*u
        u=u2
        u(0)=u(n)
        u(-1)=u(n-1)
        u(n+1)=u(1)
        u(n+2)=u(2)
         
       
        call RECONS
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
        call AVERAGE
        u3=0
        u0(0)=0
        u0(n+1)=0
        u2(0)=0
        u2(n+1)=0
        u(0)=0
        u(n+1)=0
       

        u3=(u0+2.0*u2+2.0*dt*u)/3.0
        u=u3
        u(0)=u(n)
        u(-1)=u(n-1)
        u(n+1)=u(1)
        u(n+2)=u(2)

        u0=u
         
       
        call RECONS
        write(*,*)ntime


       









        if(ntime==1400)then
        open(11,file='1.4uadd.dat')

        do i=0,n
        write(11,'(2f15.6)')san+dble(i)*h,uadd(i)
        enddo

        open(12,file='1.4uminus.dat')

        do i=0,n
        write(12,'(2f15.6)')san+dble(i)*h,uminus(i)

        enddo
        elseif(ntime==1500)then
        open(13,file='1.5uadd.dat')

        do i=0,n
        write(13,'(2f15.6)')san+dble(i)*h,uadd(i)
        enddo

        open(14,file='1.5uminus.dat')

        do i=0,n
        write(14,'(2f15.6)')san+dble(i)*h,uminus(i)

        enddo

        elseif(ntime==2000)then
        open(15,file='2uadd.dat')

        do i=0,n
        write(15,'(2f15.6)')san+dble(i)*h,uadd(i)
        enddo

        open(16,file='2uminus.dat')

        do i=0,n
        write(16,'(2f15.6)')san+dble(i)*h,uminus(i)

        enddo

        elseif(ntime==1000)then
        open(17,file='1uadd.dat')

        do i=0,n
        write(17,'(2f15.6)')san+dble(i)*h,uadd(i)
        enddo

        open(18,file='1uminus.dat')

        do i=0,n
        write(18,'(2f15.6)')san+dble(i)*h,uminus(i)

        enddo
        endif

        enddo
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!


        end

以上为主程序,以下为子程序
2楼2012-04-02 12:12:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wll778824

银虫 (小有名气)

【答案】应助回帖

★ ★ ★
小雨萌萌: 金币+3, 3Q! 2012-04-05 16:33:56
subroutine AVERAGE
        use constant
        implicit double precision(a-h,o-z)
        common/u/ u(-1:n+2),uminus(0:n),uadd(0:n)
        common/flux/ flux(0:n)
        flux=0


        do i=0,n
        flux(i)=0.5*(0.5*uminus(i)*uminus(i)
     &+0.5*uadd(i)*uadd(i)-0.6*(uadd(i)-uminus(i)))
        enddo

        do j=1,n
        u(j)=(flux(j-1)-flux(j))/h
        enddo

        end
3楼2012-04-02 12:12:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

wll778824

银虫 (小有名气)

【答案】应助回帖

★ ★ ★
小雨萌萌: 金币+3, 3Q! 2012-04-05 16:33:44
subroutine RECONS
        use constant
        implicit double precision(a-h,o-z)
        common/u/ u(-1:n+2),uminus(0:n),uadd(0:n)
        common/flux/ flux(0:n)
        uminus=0
        uadd=0
        do j=0,n
        uminus(j)=-1.0/6.0*u(j-1)+5.0/6.0*u(j)+1.0/3.0*u(j+1)
        enddo


        do j=0,n
        uadd(j)=1.0/3.0*u(j)+5.0/6.0*u(j+1)-1.0/6.0*u(j+2)
        enddo
         

        end
4楼2012-04-02 12:13:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

xmch2011

铁虫 (小有名气)

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
小雨萌萌: 金币-10, 谢人家也不把悬赏的金币发一下呀?帮你发放金币! 2012-04-05 16:33:33
引用回帖:
4楼: Originally posted by wll778824 at 2012-04-02 12:13:01:
subroutine RECONS
        use constant
        implicit double precision(a-h,o-z)
        common/u/ u(-1:n+2),uminus(0:n),uadd(0:n)
        common/flux/ flux(0:n)
        uminus=0
        uadd=0
        do j=0,n
        uminus(j)=-1.0/6.0*u(j-1) ...

谢谢你啊,学习一下
数学,力学,物理
5楼2012-04-03 11:35:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 xmch2011 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 331求调剂 +8 于征yz 2026-04-05 8/400 2026-04-06 00:54 by fmesaito
[考研] 材料工程302分求调剂 +9 zyx上岸! 2026-04-04 9/450 2026-04-05 22:08 by 醉翁wl
[考研] 22408 总分320,一篇论文二作,两个国三,求调剂 +3 Leomulufu 2026-04-04 5/250 2026-04-05 19:04 by chongya
[考研] 材料专硕(0856) 339分求调剂 +10 哈哈哈鹅哈哈哈 2026-04-04 10/500 2026-04-05 18:51 by 蓝云思雨
[考研] 298求调剂 +3 manman511 2026-04-05 3/150 2026-04-05 18:09 by kk112233
[考研] 085410人工智能 初试316分 求调剂 +6 残星拂曙 2026-03-31 6/300 2026-04-05 12:15 by rainbow11
[考研] 求调剂,一志愿郑州大学材料与化工专硕,英二数二342分,求老师收留 +18 v12abo 2026-04-02 20/1000 2026-04-05 11:37 by a8144223
[考研] 男生,一志愿沪9生物学071000,初试308求调剂 +3 刘墨墨 2026-04-04 3/150 2026-04-05 08:26 by barlinike
[考研] 285求调剂 +11 哦呦呼o 2026-04-04 11/550 2026-04-05 08:15 by 544594351
[考研] 085400电子信息319求调剂(接受跨专业调剂) +5 星星不眨眼喽 2026-04-03 6/300 2026-04-04 21:50 by hemengdong
[考研] 336求调剂 +8 kiyy 2026-04-01 8/400 2026-04-03 19:41 by lijunpoly
[考研] 材料专硕322分 +13 哈哈哈吼吼吼哈 2026-04-01 13/650 2026-04-03 16:08 by 哦哦123
[考研] 081200-11408-276学硕求调剂 +5 崔wj 2026-04-03 5/250 2026-04-03 15:06 by arrow8852
[考研] 工科 267求调剂 +5 wanwan00 2026-04-02 7/350 2026-04-03 14:14 by zhangdingwa
[考研] 一志愿厦门大学材料工程专硕354找调剂!!! +8 贝呗钡钡 2026-03-30 8/400 2026-04-03 09:41 by hypershenger
[考研] 312 化工或制药调剂 +8 小小墨123 2026-04-02 9/450 2026-04-03 09:12 by zhouxiaoyu
[考研] 318求调剂,计算材料方向 +10 吸喵有害笙命 2026-04-01 11/550 2026-04-02 16:29 by oooqiao
[考研] 272求调剂,接受跨专业调剂! +4 闲鱼卢 2026-03-31 4/200 2026-04-02 11:18 by guyan1000
[考研] 286求调剂 +5 Sa67890. 2026-04-01 7/350 2026-04-01 19:50 by 6781022
[考研] 材料与化工(0856)304求B区调剂 +8 邱gl 2026-03-30 16/800 2026-04-01 17:58 by 邱gl
信息提示
请填处理意见