²é¿´: 1052  |  »Ø¸´: 4
µ±Ç°Ö»ÏÔʾÂú×ãÖ¸¶¨Ìõ¼þµÄ»ØÌû£¬µã»÷ÕâÀï²é¿´±¾»°ÌâµÄËùÓлØÌû

xmch2011

Ìú³æ (СÓÐÃûÆø)

[ÇóÖú] Çófortran95±àдµÄÊýÖµ³ÌÐò

ÏëѧѧÓÃfortran95дµÄÊýÖµ³ÌÐò£¬ÄÇλͬѧÓÐûÓÐÕâÑùµÄ³ÌÐò£¬Ñ§Ï°Ò»Ï£¬Ð»Ð»£¡
»Ø¸´´ËÂ¥

» ²ÂÄãϲ»¶

» ±¾Ö÷ÌâÏà¹Ø¼ÛÖµÌùÍÆ¼ö£¬¶ÔÄúͬÑùÓаïÖú:

Êýѧ£¬Á¦Ñ§£¬ÎïÀí
ÒÑÔÄ   »Ø¸´´ËÂ¥   ¹Ø×¢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µÄ»ØÌû
²é¿´È«²¿ 5 ¸ö»Ø´ð

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: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µÄ»ØÌû
×î¾ßÈËÆøÈÈÌûÍÆ¼ö [²é¿´È«²¿] ×÷Õß »Ø/¿´ ×îºó·¢±í
[²©ºóÖ®¼Ò] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +6 3dfhjxgsh7 2026-02-22 9/450 2026-02-23 07:49 by w4l55oybr1
[¿¼²©] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +4 khieu8v8m0 2026-02-22 4/200 2026-02-23 06:46 by jsjzfl
[ÂÛÎÄͶ¸å] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 w89i99eaeh 2026-02-22 4/200 2026-02-23 06:36 by w4l55oybr1
[²©ºóÖ®¼Ò] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +4 khieu8v8m0 2026-02-22 5/250 2026-02-23 06:34 by w4l55oybr1
[¹«Åɳö¹ú] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 khieu8v8m0 2026-02-22 5/250 2026-02-23 06:29 by w4l55oybr1
[˶²©¼ÒÔ°] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +4 khieu8v8m0 2026-02-22 8/400 2026-02-23 06:24 by w4l55oybr1
[¿¼ÑÐ] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +4 usprnugpzw 2026-02-21 10/500 2026-02-23 04:58 by 5jlh3qtdvx
[ÂÛÎÄͶ¸å] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 khieu8v8m0 2026-02-22 6/300 2026-02-23 02:08 by 5jlh3qtdvx
[½Ìʦ֮¼Ò] °æÃæ·Ñ¸Ã½»Âð +7 Æ»¹ûÔÚÄÄÀï 2026-02-22 8/400 2026-02-22 22:37 by otani
[»ù½ðÉêÇë] »ù½ðÕýÎÄ30Ò³Ö¸µÄÊDZ¨¸æÕýÎÄ»¹ÊÇÕû¸öÉêÇëÊé +5 successhe 2026-02-16 6/300 2026-02-22 21:38 by ɽÎ÷Ðü¿ÕË¿ÕÐüÎ
[»ù½ðÉêÇë] ÃæÉÏ¿ÉÒÔ³¬¹ý30Ò³°É£¿ +4 °¢À­¹±aragon 2026-02-22 4/200 2026-02-22 21:22 by ɽÎ÷Ðü¿ÕË¿ÕÐüÎ
[½Ìʦ֮¼Ò] ΪʲôÖйú´óѧ½ÌÊÚÃÇË®ÁËÄÇô¶àËùνµÄ¶¥»á¶¥¿¯£¬µ«»¹ÊÇ×ö²»³öÓîÊ÷»úÆ÷ÈË£¿ +5 »¶ÀÖËÌÒ¶Ýè 2026-02-21 5/250 2026-02-22 21:15 by ɽÎ÷Ðü¿ÕË¿ÕÐüÎ
[ÂÛÎÄͶ¸å] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +4 usprnugpzw 2026-02-21 6/300 2026-02-22 19:48 by w89i99eaeh
[¿¼ÑÐ] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 3dfhjxgsh7 2026-02-22 4/200 2026-02-22 16:52 by khieu8v8m0
[ÕÒ¹¤×÷] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 usprnugpzw 2026-02-22 3/150 2026-02-22 16:37 by khieu8v8m0
[¹«Åɳö¹ú] ÊÛSCIÒ»ÇøÎÄÕ£¬ÎÒ:8 O5 51O 54,¿ÆÄ¿ÆëÈ«,¿É+¼± +3 usprnugpzw 2026-02-21 4/200 2026-02-22 16:27 by khieu8v8m0
[»ù½ðÉêÇë] ¡°ÈËÎÄÉç¿Æ¶øÂÛ£¬Ðí¶àѧÊõÑо¿»¹Ã»ÓдﵽÃñ¹úʱÆÚµÄˮƽ¡± +4 ËÕ¶«ÆÂ¶þÊÀ 2026-02-18 5/250 2026-02-22 16:07 by liangep1573
[»ù½ðÉêÇë] ʲôÊÇÈËÒ»Éú×îÖØÒªµÄ£¿ +4 ˲ϢÓîÖæ 2026-02-21 4/200 2026-02-22 11:44 by huagongfeihu
[»ù½ðÉêÇë] ½ñÄê´ºÍíÓм¸¸ö½ÚÄ¿ºÜ²»´í£¬µãÔÞ£¡ +11 ˲ϢÓîÖæ 2026-02-16 12/600 2026-02-21 21:14 by lq493392203
[»ù½ðÉêÇë] ÌåÖÆÄÚ³¤±²ËµÌåÖÆÄÚ¾ø´ó²¿·ÖÒ»±²×ÓÔڵײ㣬ÈçͬÄãÃÇÒ»Ñù´ó²¿·ÖÆÕͨ½ÌʦæÇÒÊÕÈëµÍ +9 ˲ϢÓîÖæ 2026-02-20 12/600 2026-02-21 10:39 by »¶ÀÖËÌÒ¶Ýè
ÐÅÏ¢Ìáʾ
ÇëÌî´¦ÀíÒâ¼û