亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? eno2sr.f

?? visual fortran程序編寫的用于計算euno差分格式
?? F
字號:
      program eno2sr
c...Performs 2nd-order Essentially Non-Oscillatory (ENO) method
c...described in Harten, Engquist, Chakravarthy, and Osher,
c...J. Comput. Phys., vol. 71, 231-303 (1987)
c...Subcell resolution performed at discontinuities as described
c...in Harten, J. Comput. Phys., vol. 83, 148-184 (1989)

      parameter (nmax=100,delta=.000001)
      real lambda,u(-2:nmax+2),h(0:nmax),u0(1:nmax+1),S(-1:nmax+1)
      real delta_u(-2:nmax+1),delta2_u(-1:nmax+2),a(-1:nmax+1)
      real minmod,mm,g1(0:nmax),g2(-1:nmax),sigma(-1:nmax+1)
      real C(-1:nmax+1)

c...If f(x) is redefined here, it must also be redefined in function
c..."riemann."  Also, all sonic points (max and min of f) must be
c...specified in "riemann."
      f(x) =   x
      df(x) =  1.

      open(unit=9,file='eno2sr.out')

c...Read initial data samples.  Samples evenly spaced.
c...Data assumed periodic.
      open(unit=8,file='nb.dat',status='old')
      read(8,*) n, lambda, tfinal
      if(n.gt.nmax) then
        write(9,*) '****Too many data points****'
        close(unit=8)
        close(unit=9)
        stop
      endif
      if(n.lt.2) then
        write(9,*) '****Too few data points****'
        close(unit=8)
        close(unit=9)
        stop
      endif
      if(lambda.lt.0.01) then
        write(9,*) '****Lambda small or negative****'
        close(unit=8)
        close(unit=9)
        stop
      endif
      i=1
      read(8,*,err=1000,end=1000) xmin, u(1)
      do 10, i=2,n
        read(8,*,err=1000,end=1000) dummy, u(i)
 10   continue
      i=n+1
      read(8,*,err=1000,end=1000) xmax, u(n+1)
      if(abs(u(n+1)-u(1)).gt..0001) then
        write(9,*) '****Data not periodic****'
        close(unit=8)
        close(unit=9)
        stop
      endif
      if(xmax.le.xmin+.0001) then
        write(9,*) '****Bad x-axis****'
        close(unit=8)
        close(unit=9)
        stop
      endif
      u(0) = u(n)
      u(-1) = u(n-1)
      u(-2) = u(n-2)
      u(n+2) = u(2)
      do 15, i=1,n+1
        u0(i) = u(i)
 15   continue

      delta_x=(xmax-xmin)/real(n)
      delta_t=lambda*delta_x
      itert=nint(tfinal/delta_t)
      write(9,*) 'Final time requested: ', tfinal
      tfinal = real(itert)*delta_t
      write(9,*) 'Actual final time: ', tfinal
      write(9,*) 'delta_t = ', delta_t
      write(9,*) 'delta_x = ', delta_x
      write(9,*) 'lambda = ', lambda

 
      do 500, it=1,itert

      do 50, i=-2,n+1
        delta_u(i) = u(i+1)-u(i)
 50   continue

      do 60, i=-1,n+1
        delta2_u(i) = delta_u(i)-delta_u(i-1)
 60   continue
      delta2_u(n+2) = delta2_u(2)

c...Define wave speeds at cell centers 
      do 70, i=-1,n+1
        a(i) = lambda*df(u(i))
 70   continue

      iflag = 1

      do 80, i=0,n+1

      if(iflag.eq.0) then
c...Reconstruction via Deconvolution (RD)
        t1 = mm(delta2_u(i),delta2_u(i+1))
        t2 = mm(delta2_u(i-1),delta2_u(i))
        S(i) = minmod(delta_u(i)-.5*t1,delta_u(i-1)+.5*t2)
        C(i) = 0.
      else
c...Reconstruction via Primitive Function.
        if(abs(delta_u(i)).lt.abs(delta_u(i-1))) then
          i2 = i
        else
          i2 = i-1
        endif

        if(abs(delta2_u(i2+1)).lt.abs(delta2_u(i2))) then
          i3 = i2+1
        else
          i3 = i2
        endif

        S(i) = delta_u(i2) + delta2_u(i3)*(real(i-i2)-.5)

c       C(i) = delta2_u(i3)
        C(i) = 0.
      endif
      S(-1) = S(n-1)
      C(-1) = C(n-1)
        
 80   continue

      do 90, i=0,n
        h(i) = lambda*riemann( u(i)+.5*(1.-a(i))*S(i),
     .                       u(i+1)-.5*(1.+a(i+1))*S(i+1))
 90   continue    


c...Apply subcell resolution

c...Define variable for discontinuity test
      do 100, i=-1,n+1
        sigma(i) = abs(S(i))
 100  continue

      do 110, i=0,n
c...Possible discontinuity in cell i if sigma(i) is a local maximum.
        if(sigma(i).gt.sigma(i+1).and.sigma(i).gt.sigma(i-1)) then
c...Determine F(theta) at edges of cell i.
          fl =  delta_u(i)  -S(i+1)
          fr = -delta_u(i-1)+S(i-1)
c...Discontinuity in cell i considered confirmed if F switches sign.
          if(fl*fr.lt.0.) then
            if(a(i).gt.0.) then
              g2(i-1) = 0.
              fxat = (1.-a(i))*(u(i-1)+.5*(2.-a(i))*S(i-1))
     .              + a(i)*(u(i+1)-.5*(1.+a(i))*S(i+1)) -u(i)
              if(fxat*fl.lt.0.) then
                g1(i) = a(i+1)*(u(i+1)-.5*S(i+1)*(1.+a(i+1)))
     .                      -a(i)*(u(i)+.5*S(i)*(1.-a(i)))
     .               +a(i+1)*(a(i+1)+1.)*(2.*a(i+1)+1.)*C(i+1)/12.
              else
                g1(i) = a(i-1)*(u(i-1)+.5*S(i-1)*(3.-a(i-1)))
     .                      -a(i)*(u(i)+.5*S(i)*(1.-a(i)))
     .                      + u(i)-u(i-1)-S(i-1)-.5*C(i-1)   
     .           +a(i-1)*(13.-9.*a(i-1)+2.*a(i-1)*a(i-1))*C(i-1)/12.
              endif
            else
              g1(i) = 0.
              fxat = -a(i)*(u(i-1)+.5*(1.-a(i))*S(i-1))
     .             +(1.+a(i))*(u(i+1)-.5*(2.+a(i))*S(i+1)) -u(i)
              if(fxat*fr.lt.0.) then
                g2(i-1) = a(i-1)*(u(i-1)+.5*S(i-1)*(1.-a(i-1)))
     .                  -a(i)*(u(i)-.5*S(i)*(1.+a(i)))
     .               +a(i-1)*(a(i-1)-1.)*(2.*a(i-1)-1.)*C(i-1)/12.
              else
                g2(i-1) = a(i+1)*(u(i+1)-.5*S(i+1)*(3.+a(i+1)))
     .                  -a(i)*(u(i)-.5*S(i)*(1.+a(i)))
     .                     + u(i+1)-u(i)-S(i+1) + .5*C(i+1)
     .           +a(i+1)*(13.+9.*a(i+1)+2.*a(i+1)*a(i+1))*C(i+1)/12.
              endif
            endif
          else
            if(a(i).gt.0.) then
              g1(i) = a(i)*(a(i)-1.)*(2.*a(i)-1.)*C(i)/12.
              g2(i-1) = 0.
            else
              g1(i) = 0.
              g2(i-1) = a(i)*(a(i)+1.)*(2.*a(i)+1.)*C(i)/12.
            endif
          endif
        else
          if(a(i).gt.0.) then
            g1(i) = a(i)*(a(i)-1.)*(2.*a(i)-1.)*C(i)/12.
            g2(i-1) = 0.
          else
            g1(i) = 0.
            g2(i-1) = a(i)*(a(i)+1.)*(2.*a(i)+1.)*C(i)/12.
          endif
        endif
 110  continue
      g2(n) = g2(0)

      do 120, i=1,n
        u(i) = u(i)-h(i)-g1(i)-g2(i)+h(i-1)+g1(i-1)+g2(i-1)
 120  continue

      u(0) = u(n)
      u(-1) = u(n-1)
      u(-2) = u(n-2)
      u(n+1) = u(1)
      u(n+2) = u(2)
 500  continue

      sum = 0.
      smax = 0.
      write(9,*)
      write(9,1050)
      do 800, i=1,n+1
        sum = sum + abs(u(i)-u0(i))
        smax = max(smax,abs(u(i)-u0(i)))
        write(9,1100) i, u0(i), u(i), abs(u(i)-u0(i))
 800  continue
      write(9,*) 'L1 ERROR = ', sum/real(n+1)
      write(9,*) 'MAX ERROR = ', smax

      close(unit=8)
      close(unit=9)

C...write simple file for plotting
      open(unit=10,file='eno2sr.plt')
c     write(10,*) '2nd order ENO-SR'
c     write(10,*)  n, lambda, tfinal
      do 900, i=1,n+1
        write(10,1150) -1 + real(2*i-2)/real(n), u(i)
 900  continue
      close(unit=10)

      stop

 1000 write(9,*) '****Error reading data point number ', i,'****'
      close(unit=8)
      close(unit=9)
      stop

 1050 format(4x,'N',11x,'INITIAL',11x,'ENO-2SR',8x, 'DIFFERENCE')
 1100 format(i5,5x,f13.8,5x,f13.8,5x,f13.8)
 1150 format(f14.9,5x,f14.9)

      end


      real function minmod(x,y)

      if(x*y.lt.0.) then
        minmod = 0.
      elseif(abs(x).ge.abs(y)) then
        minmod = y
      else
        minmod = x
      endif
       
      return
      end

      real function mm(x,y)

      if(abs(x).ge.abs(y)) then
        mm = y
      else
        mm = x
      endif
       
      return
      end

      real function riemann(x,y)
      parameter(nsonic=3)
      real sonic(1:nsonic)

      f(x) =  x

c...Enter the location of sonic points (max and min of f(x)).
c...(It is ok to have additional false sonic points. In fact, it is 
c...convenient, so that the list includes all of the sonic points
c...for any likely choice of f)
      sonic(1)=.5
      sonic(2)= 0.
      sonic(3)=-.5

      if(x.le.y) then
        rm = 10.E20
        do 10, i=1,nsonic
          if(x.le.sonic(i).and.sonic(i).le.y) then
             rm = min(rm,f(sonic(i)))
          endif
 10     continue
        riemann = min(f(x),f(y),rm)
      else
        rm = -10.E20
        do 20, i=1,nsonic
          if(x.ge.sonic(i).and.sonic(i).ge.y) then
             rm = max(rm,f(sonic(i)))
          endif
 20     continue
        riemann = max(f(x),f(y),rm)
      endif

      return
      end
      

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩精品一二三区| www.久久精品| 国产成人精品亚洲777人妖| 成人午夜看片网址| 欧美午夜精品电影| 久久先锋影音av| 亚洲三级电影全部在线观看高清| 天天影视网天天综合色在线播放| 精品中文字幕一区二区| 91色视频在线| 欧美videos大乳护士334| 国产精品夫妻自拍| 免费一区二区视频| jlzzjlzz亚洲日本少妇| 91精品国产乱码| 国产精品成人午夜| 久久丁香综合五月国产三级网站| 97se亚洲国产综合自在线观| 69av一区二区三区| 国产精品久久久久久久久免费丝袜 | 视频在线观看一区二区三区| 国产精品亚洲午夜一区二区三区 | 五月综合激情婷婷六月色窝| 国产成人午夜视频| 欧美日韩精品福利| 亚洲理论在线观看| 欧美一区二区视频在线观看 | 日本午夜精品视频在线观看| 不卡视频一二三| 日韩欧美亚洲一区二区| 亚洲视频一二区| 国模大尺度一区二区三区| 欧美亚一区二区| 国产精品女人毛片| 精品在线播放免费| 欧美日韩免费视频| 亚洲三级免费电影| 国产91精品一区二区| 欧美一个色资源| 一区二区三区不卡视频在线观看| 国产麻豆精品久久一二三| 欧美喷水一区二区| 亚洲理论在线观看| av不卡免费电影| 国产女同性恋一区二区| 国内精品伊人久久久久av一坑| 欧美日韩精品福利| 亚洲综合成人在线| a级高清视频欧美日韩| 久久久久久久精| 久久国产精品第一页| 欧美一级一区二区| 亚洲成人av电影| 欧美午夜在线观看| 亚洲欧美日韩综合aⅴ视频| 国产99一区视频免费| 精品成人a区在线观看| 日韩国产欧美视频| 欧美美女直播网站| 亚洲成人三级小说| 欧美老人xxxx18| 亚洲第一会所有码转帖| 欧美综合一区二区三区| 一区二区日韩电影| 欧洲精品中文字幕| 亚洲一区二区在线免费看| 91蜜桃在线观看| 亚洲激情综合网| 欧美综合天天夜夜久久| 一区二区在线观看免费 | 午夜激情一区二区三区| 在线视频观看一区| 亚洲综合视频网| 欧美人狂配大交3d怪物一区| 丝瓜av网站精品一区二区| 欧美剧情片在线观看| 日本系列欧美系列| 欧美大黄免费观看| 国内成人免费视频| 欧美激情一区二区三区| 成人黄色国产精品网站大全在线免费观看 | 亚洲成年人网站在线观看| 欧美美女直播网站| 老鸭窝一区二区久久精品| 精品国产制服丝袜高跟| 国产不卡在线播放| 一色桃子久久精品亚洲| 91久久精品一区二区| 亚洲成人一区二区在线观看| 日韩视频在线永久播放| 国产福利精品一区| 亚洲欧美一区二区久久| 欧美精选午夜久久久乱码6080| 蜜桃久久久久久久| 国产日韩欧美高清在线| 91在线一区二区三区| 午夜精品国产更新| 久久综合色综合88| 91亚洲资源网| 日韩高清国产一区在线| 久久蜜桃香蕉精品一区二区三区| 成人福利视频在线| 午夜欧美视频在线观看| 亚洲精品在线电影| 97se亚洲国产综合自在线观| 日韩精品国产精品| 国产偷国产偷亚洲高清人白洁| av男人天堂一区| 天堂午夜影视日韩欧美一区二区| 久久毛片高清国产| 91美女视频网站| 另类综合日韩欧美亚洲| 中文字幕va一区二区三区| 在线亚洲高清视频| 国产一区二区不卡在线| 一卡二卡三卡日韩欧美| 久久嫩草精品久久久精品一| 在线观看亚洲精品| 国产麻豆视频一区| 亚洲一级二级在线| 久久亚洲综合色一区二区三区| 在线免费观看日本欧美| 国产一区二区调教| 亚洲一二三四在线| 国产亚洲一二三区| 欧美日韩美少妇| 大胆欧美人体老妇| 日韩av电影免费观看高清完整版| 国产精品久久久久影院亚瑟| 3d成人h动漫网站入口| 99久久国产免费看| 国内精品伊人久久久久av影院| 亚洲国产日日夜夜| 亚洲国产电影在线观看| 日韩精品一区二区三区三区免费| 91麻豆6部合集magnet| 国产一区二区在线观看免费| 三级久久三级久久久| 国产精品久久久久婷婷| 精品国产一区二区三区忘忧草 | 日本成人中文字幕| ㊣最新国产の精品bt伙计久久| 日韩西西人体444www| 在线视频一区二区三区| 成人一区二区三区在线观看| 美国十次综合导航| 亚洲国产你懂的| 成人免费视频在线观看| 国产亚洲欧美在线| 欧美一区二区三区在线看| 色狠狠桃花综合| jlzzjlzz亚洲女人18| 国产成人综合精品三级| 免费观看在线色综合| 午夜av一区二区三区| 亚洲另类在线一区| 亚洲欧美一区二区视频| 亚洲国产精品激情在线观看| 精品国产乱码久久久久久久| 日韩视频免费观看高清完整版在线观看| 在线观看日韩av先锋影音电影院| 97se亚洲国产综合自在线观| 波多野结衣在线一区| 国产精品99久久久久久似苏梦涵 | 亚洲精品一区二区三区影院| 91精品免费观看| 欧美日韩国产a| 欧美午夜片在线看| 一本大道综合伊人精品热热| 99re这里只有精品首页| 成人黄色av电影| 成人av影视在线观看| 成人动漫一区二区| www.日韩av| 成人18精品视频| www.欧美色图| 91偷拍与自偷拍精品| 91美女在线看| 欧美午夜视频网站| 欧美日韩五月天| 欧美日韩成人高清| 欧美精品第一页| 欧美一区二区在线不卡| 91精品在线观看入口| 欧美一级理论片| 日韩久久免费av| 精品国产乱码久久久久久影片| 精品国产乱码久久久久久久| 久久久久久免费网| 国产精品美女久久久久久| 成人欧美一区二区三区白人 | 欧美日韩国产精选| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲精品中文字幕乱码三区| 亚洲精品亚洲人成人网在线播放| 一区二区成人在线| 日韩av中文在线观看| 精品中文字幕一区二区| 成人午夜视频在线观看| 色综合久久九月婷婷色综合|