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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? dyndrv.f90

?? CCSM Research Tools: Community Atmosphere Model (CAM)
?? F90
字號:
#include <misc.h>#include <params.h>! Note that this routine has 2 complete blocks of code for PVP vs. non-PVP.! Make sure to make appropriate coding changes where necessary.#if ( defined PVP )subroutine dyndrv(grlps1,  grt1,   grz1,    grd1,    grfu1,    &                  grfv1,   grut1,  grvt1,   grrh1,   grlps2,   &                  grt2,    grz2,   grd2,    grfu2,   grfv2,    &                  grut2,   grvt2,  grrh2,   vmax2d,  vmax2dt,  &                  vcour   )!----------------------------------------------------------------------- ! ! Purpose: ! Driving routine for Gaussian quadrature, semi-implicit equation! solution and linear part of horizontal diffusion.! The need for this interface routine is to have a multitasking! driver for the spectral space routines it invokes.! ! Method: ! ! Author: ! Original version:  J. Rosinski! Standardized:      J. Rosinski, June 1992! Reviewed:          D. Williamson, B. Boville, J. Hack, August 1992! Reviewed:          D. Williamson, March 1996! Reviewed:          B. Boville, April 1996!!-----------------------------------------------------------------------!! $Id: dyndrv.F90,v 1.3 2001/10/19 17:50:31 eaton Exp $! $Author: eaton $!   use precision   use pmgrid   use pspect   use time_manager, only: get_step_size, is_first_step!-----------------------------------------------------------------------   implicit none!------------------------------Commons----------------------------------use commap!------------------------------Arguments--------------------------------!! Input arguments!   real(r8), intent(in) :: grlps1(2*pmmax,plat/2)       ! ----------------------------   real(r8), intent(in) :: grt1(2*pmmax,plev,plat/2)    ! |   real(r8), intent(in) :: grz1(2*pmmax,plev,plat/2)    ! |   real(r8), intent(in) :: grd1(2*pmmax,plev,plat/2)    ! |   real(r8), intent(in) :: grfu1(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grfv1(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grut1(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grvt1(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grrh1(2*pmmax,plev,plat/2)   ! |- see linems and quad for   real(r8), intent(in) :: grlps2(2*pmmax,plat/2)       ! |  definitions: these variables are   real(r8), intent(in) :: grt2(2*pmmax,plev,plat/2)    ! |  declared here for data scoping   real(r8), intent(in) :: grz2(2*pmmax,plev,plat/2)    ! |   real(r8), intent(in) :: grd2(2*pmmax,plev,plat/2)    ! |   real(r8), intent(in) :: grfu2(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grfv2(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grut2(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grvt2(2*pmmax,plev,plat/2)   ! |   real(r8), intent(in) :: grrh2(2*pmmax,plev,plat/2)   ! ----------------------------   real(r8), intent(in) :: vmax2d(plev,plat)            ! max. wind at each level, latitude   real(r8), intent(in) :: vmax2dt(plev,plat)           ! max. truncated wind at each lvl,lat   real(r8), intent(in) :: vcour(plev,plat)             ! maximum Courant number in slice!!---------------------------Local workspace-----------------------------!   real(r8) ztdtsq(2*pnmax)              ! 2dt*(n(n+1)/a^2)   real(r8) zdt                          ! dt unless nstep = 0   real(r8) ztdt                         ! 2*zdt (2dt)   integer irow                      ! latitude pair index   integer n                         ! meridional wavenumber index   integer k                         ! level index   call t_startf('dyn')!$OMP PARALLEL DO PRIVATE (IROW)   do irow=1,plat/2      call dyn(irow, grlps1(1,irow), grt1(1,1,irow), grz1(1,1,irow), grd1(1,1,irow),&         grfu1(1,1,irow),  grfv1(1,1,irow),  grut1(1,1,irow),  grvt1(1,1,irow),grrh1(1,1,irow),  &         grlps2(1,irow),   grt2(1,1,irow),   grz2(1,1,irow),   grd2(1,1,irow), grfu2(1,1,irow),  &         grfv2(1,1,irow),  grut2(1,1,irow),  grvt2(1,1,irow),  grrh2(1,1,irow)  )   end do   call t_stopf('dyn')!!-----------------------------------------------------------------------!! Build expanded vector with del^2 response function!   zdt = get_step_size()   if (is_first_step()) zdt = .5*zdt   ztdt = 2.*zdt!DIR$ IVDEP   do n=1,pnmax      ztdtsq(2*n-1) = ztdt*sq(n)      ztdtsq(2*n  ) = ztdt*sq(n)   end do!! Perform Gaussian quadrature (multitasked loop)!   call t_startf('quad_tstep')!$OMP PARALLEL DO PRIVATE (N)   do n=1,pmax      call quad(n,       zdt,     ztdtsq,  grlps1,  grlps2,  &                grt1,    grz1,    grd1,    grfu1,   grfv1,   &                grvt1,   grrh1,   grt2,    grz2,    grd2,   &                grfu2,   grfv2,   grvt2,   grrh2   )!! Complete time advance, solve vertically coupled semi-implicit system!#ifdef HADVTEST!!jr Turn off semi-implicit so T equation is horizontal advection only!        call tstep(n,zdt,ztdtsq)#else      call tstep(n,zdt,ztdtsq)#endif   end do   call t_stopf('quad_tstep')!! Find out if courant limit has been exceeded.  If so, the limiter will be! applied in HORDIF!   call t_startf('courlim')   call courlim(vmax2d,  vmax2dt, vcour   )   call t_stopf('courlim')!! Linear part of horizontal diffusion (multitasked loop)!   call t_startf('hordif')!$OMP PARALLEL DO PRIVATE(K)   do k=1,plev      call hordif(k,ztdt)   end do   call t_stopf('hordif')!   returnend subroutine dyndrv#elsesubroutine dyndrv(grlps1,  grt1,    grz1,    grd1,    grfu1,    &                  grfv1,   grut1,   grvt1,   grrh1,   grlps2,   &                  grt2,    grz2,    grd2,    grfu2,   grfv2,    &                  grut2,   grvt2,   grrh2,   vmax2d,  vmax2dt,  &                  vcour   )!-----------------------------------------------------------------------!! Driving routine for Gaussian quadrature, semi-implicit equation! solution and linear part of horizontal diffusion.! The need for this interface routine is to have a multitasking! driver for the spectral space routines it invokes.!!---------------------------Code history--------------------------------!! Original version:  J. Rosinski! Standardized:      J. Rosinski, June 1992! Reviewed:          D. Williamson, B. Boville, J. Hack, August 1992! Reviewed:          D. Williamson, March 1996!!-----------------------------------------------------------------------   use precision   use pmgrid   use pspect   use comspe   use commap   use time_manager, only: get_step_size, is_first_step#if ( defined SPMD ) && ( defined TIMING_BARRIERS )   use mpishorthand#endif   implicit none!! Input arguments!   real(r8) grlps1(2*pmmax,plat/2)       ! ----------------------------   real(r8) grt1(plev,2*pmmax,plat/2)    ! |   real(r8) grz1(plev,2*pmmax,plat/2)    ! |   real(r8) grd1(plev,2*pmmax,plat/2)    ! |   real(r8) grfu1(plev,2*pmmax,plat/2)   ! |   real(r8) grfv1(plev,2*pmmax,plat/2)   ! |   real(r8) grut1(plev,2*pmmax,plat/2)   ! |   real(r8) grvt1(plev,2*pmmax,plat/2)   ! |   real(r8) grrh1(plev,2*pmmax,plat/2)   ! |- see linems and quad for   real(r8) grlps2(2*pmmax,plat/2)       ! |  definitions: these variables are   real(r8) grt2(plev,2*pmmax,plat/2)    ! |  declared here for data scoping   real(r8) grz2(plev,2*pmmax,plat/2)    ! |   real(r8) grd2(plev,2*pmmax,plat/2)    ! |   real(r8) grfu2(plev,2*pmmax,plat/2)   ! |   real(r8) grfv2(plev,2*pmmax,plat/2)   ! |   real(r8) grut2(plev,2*pmmax,plat/2)   ! |   real(r8) grvt2(plev,2*pmmax,plat/2)   ! |   real(r8) grrh2(plev,2*pmmax,plat/2)   ! ----------------------------   real(r8) vmax2d(plev,plat)            ! max. wind at each level, latitude   real(r8) vmax2dt(plev,plat)           ! max. truncated wind at each lvl,lat   real(r8) vcour(plev,plat)             ! maximum Courant number in slice!!---------------------------Local workspace-----------------------------!   real(r8) ztdtsq(pnmax)                ! 2dt*(n(n+1)/a^2)   real(r8) zdt                          ! dt unless nstep = 0   real(r8) ztdt                         ! 2*zdt (2dt)   integer irow                      ! latitude pair index   integer m                         ! longitudinal wavenumber index   integer n                         ! total wavenumber index   integer k                         ! level index#if ( defined SPMD )#if ( defined TIMING_BARRIERS )   call t_startf ('sync_realloc3')   call mpibarrier (mpicom)   call t_stopf ('sync_realloc3')#endif   call t_startf ('realloc3')   call realloc3 (grlps1,  grt1,   grz1,   grd1,    grfu1,    &                  grfv1,   grut1,  grvt1,  grrh1,   grlps2,   &                  grt2,    grz2,   grd2,   grfu2,   grfv2,    &                  grut2,   grvt2,  grrh2   )   call t_stopf ('realloc3')#endif   call t_startf('dyn')!$OMP PARALLEL DO PRIVATE (IROW)   do irow=begirow,endirow      call dyn(irow,   grlps1(1,irow),   grt1(1,1,irow),    &         grz1(1,1,irow),   grd1(1,1,irow),   &         grfu1(1,1,irow),  grfv1(1,1,irow),  &         grut1(1,1,irow),  grvt1(1,1,irow),  &         grrh1(1,1,irow),  &         grlps2(1,irow),   grt2(1,1,irow),   &         grz2(1,1,irow),   grd2(1,1,irow),   &         grfu2(1,1,irow),  &         grfv2(1,1,irow),  grut2(1,1,irow),  &         grvt2(1,1,irow),  grrh2(1,1,irow)  )   end do   call t_stopf('dyn')!!-----------------------------------------------------------------------!! Build vector with del^2 response function!   zdt = get_step_size()   if (is_first_step()) zdt = .5*zdt   ztdt = 2.*zdt   do n=1,pnmax      ztdtsq(n) = ztdt*sq(n)   end do#if ( defined SPMD )#if ( defined TIMING_BARRIERS )   call t_startf ('sync_realloc4')   call mpibarrier (mpicom)   call t_stopf ('sync_realloc4')#endif   call t_startf('realloc4')   call realloc4(grlps1,  grt1,    grz1,    grd1,    grfu1,   &                 grfv1,   grut1,   grvt1,   grrh1,   grlps2,  &                 grt2,    grz2,    grd2,    grfu2,   grfv2,   &                 grut2,   grvt2,   grrh2    )   call t_stopf('realloc4')#endif   call t_startf('quad_tstep')!$OMP PARALLEL DO PRIVATE(M)   do m=begm(iam),endm(iam)!! Perform Gaussian quadrature!      call quad(m,      zdt,     ztdtsq,  grlps1,  grlps2,  &                grt1,   grz1,    grd1,    grfu1,   grfv1,   &                grvt1,  grrh1,   grt2,    grz2,    grd2,   &                grfu2,  grfv2,   grvt2,   grrh2   )!! Complete time advance, solve vertically coupled semi-implicit system!#ifdef HADVTEST!!jr Turn off semi-implicit so T equation is horizontal advection only!        call tstep(m,zdt,ztdtsq)#else      call tstep(m,zdt,ztdtsq)#endif   end do   call t_stopf('quad_tstep')!! Find out if courant limit has been exceeded.  If so, the limiter will be! applied in HORDIF!   call t_startf('courlim')   call courlim(vmax2d,  vmax2dt, vcour   )   call t_stopf('courlim')!! Linear part of horizontal diffusion!   call t_startf('hordif')!$OMP PARALLEL DO PRIVATE(K)   do k=1,plev      call hordif(k,ztdt)   end do   call t_stopf('hordif')#if ( defined SPMD )#if ( defined TIMING_BARRIERS )   call t_startf ('sync_realloc6')   call mpibarrier (mpicom)   call t_stopf ('sync_realloc6')#endif   call t_startf('realloc6')   call realloc6   call t_stopf('realloc6')#endif   returnend subroutine dyndrv#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一二精品视频| 日日噜噜夜夜狠狠视频欧美人| 久久99久久99小草精品免视看| 91精品国产综合久久福利软件| 亚洲一区二区欧美| 欧美日韩成人激情| 麻豆精品在线看| 国产亚洲精品aa午夜观看| 国产精品18久久久久| 国产欧美日韩中文久久| 99久久婷婷国产综合精品电影| 一区二区三区小说| 日韩视频一区在线观看| 激情五月婷婷综合网| 国产精品色在线| 在线免费观看视频一区| 蜜臀av性久久久久蜜臀aⅴ流畅 | 91免费观看在线| 亚洲最新视频在线观看| 日韩无一区二区| www.99精品| 五月激情六月综合| 欧美激情自拍偷拍| 欧美精品一卡二卡| 国产精品一区二区不卡| 一区二区三区欧美| 欧美xfplay| 99久久精品国产毛片| 日韩成人免费看| 国产精品久久久爽爽爽麻豆色哟哟| 欧美性受极品xxxx喷水| 国产一区在线观看麻豆| 亚洲午夜久久久久久久久电影院| 欧美v亚洲v综合ⅴ国产v| 91视频91自| 国产精品亚洲专一区二区三区| 一区二区三区**美女毛片| 中文字幕综合网| 日韩欧美黄色影院| 欧洲精品一区二区三区在线观看| 久久国产综合精品| 亚洲激情欧美激情| 欧美国产一区在线| 日韩美一区二区三区| 91国偷自产一区二区使用方法| 国产美女在线观看一区| 亚洲成av人片一区二区梦乃| 久久精品亚洲乱码伦伦中文| 制服丝袜亚洲精品中文字幕| 波多野结衣在线aⅴ中文字幕不卡| 奇米精品一区二区三区在线观看 | 亚洲精品在线网站| 欧美色成人综合| 粉嫩高潮美女一区二区三区| 蜜臀av一级做a爰片久久| 亚洲综合一区二区三区| 国产精品久久一卡二卡| 国产丝袜美腿一区二区三区| 日韩欧美国产午夜精品| 欧美日韩在线观看一区二区| 97se亚洲国产综合自在线| 国产精品中文欧美| 久久er99热精品一区二区| 日韩在线一区二区三区| 午夜一区二区三区在线观看| 亚洲精选视频在线| 亚洲丝袜精品丝袜在线| 国产精品视频九色porn| 国产欧美日韩一区二区三区在线观看| 精品乱人伦小说| 精品国产一区二区三区不卡| 91精品欧美综合在线观看最新 | 亚洲精品写真福利| 亚洲精品免费在线| 一区二区在线观看视频| 亚洲精品乱码久久久久久| 亚洲欧美色一区| 一区二区三区国产精品| 亚洲精品视频一区| 一区二区三区在线播| 亚洲一区国产视频| 婷婷综合另类小说色区| 日日噜噜夜夜狠狠视频欧美人| 日本sm残虐另类| 国产美女精品在线| av资源网一区| 欧美中文字幕久久| 欧美一级片免费看| 久久久久国产成人精品亚洲午夜| 久久久精品免费网站| 国产精品护士白丝一区av| 亚洲美女电影在线| 午夜久久电影网| 国产综合一区二区| 不卡的av网站| 欧美色成人综合| 精品国产sm最大网站免费看| 久久噜噜亚洲综合| 久久精品国产精品亚洲红杏| 六月婷婷色综合| 大陆成人av片| 欧美日韩在线三区| 久久久精品一品道一区| 综合久久国产九一剧情麻豆| 午夜不卡在线视频| 国产成人免费视频一区| 91丨porny丨蝌蚪视频| 欧美日韩中文一区| 精品日韩欧美一区二区| 国产精品第一页第二页第三页| 亚洲国产cao| 国产激情视频一区二区三区欧美 | 国产精品久久久一本精品| 亚洲一区在线视频| 久久99久久精品欧美| 91在线观看污| 欧美xxxxxxxx| 亚洲国产色一区| 国产成人av影院| 欧美日韩免费视频| 国产欧美一区二区三区在线看蜜臀 | 岛国av在线一区| 6080国产精品一区二区| 国产精品久久久久久妇女6080 | 狠狠色伊人亚洲综合成人| 99re热这里只有精品免费视频| 欧美美女喷水视频| 中文字幕一区二区视频| 另类小说视频一区二区| 色婷婷激情综合| 国产亚洲综合性久久久影院| 午夜精品久久久久久久久久| 成人听书哪个软件好| 日韩美女视频一区二区在线观看| 亚洲日本欧美天堂| 国产成人高清视频| 欧美成人vps| 亚洲成av人片在线| 欧洲精品一区二区三区在线观看| 国产亚洲精品久| 久久精品国产免费| 欧美一区二区在线播放| 一区二区三区不卡视频在线观看| 国产美女视频91| 欧美成人一区二区三区片免费 | 亚洲品质自拍视频| 国产成人一区在线| 亚洲精品一区二区三区香蕉| 污片在线观看一区二区| 欧美亚洲国产一卡| 亚洲黄色av一区| 91在线观看视频| 日韩一区中文字幕| 99这里只有久久精品视频| 国产日产欧美一区二区三区| 激情小说欧美图片| 久久―日本道色综合久久| 免费成人av资源网| 日韩视频一区在线观看| 免费观看91视频大全| 91精品国产全国免费观看 | 亚洲精品视频观看| 波多野结衣中文一区| 国产精品进线69影院| 不卡电影一区二区三区| 中文字幕一区二区日韩精品绯色| 夫妻av一区二区| 综合久久综合久久| 色综合一区二区| 一区二区三区 在线观看视频| 91美女福利视频| 一区二区三区精品在线观看| 91福利区一区二区三区| 亚洲一区二区视频在线| 欧美色图天堂网| 视频一区二区三区入口| 欧美人与性动xxxx| 另类综合日韩欧美亚洲| 久久夜色精品国产欧美乱极品| 国产一区不卡在线| 国产精品午夜在线| 色综合网色综合| 五月婷婷另类国产| 精品毛片乱码1区2区3区| 国产精品自在在线| 亚洲美女屁股眼交| 欧美夫妻性生活| 国产伦理精品不卡| 亚洲视频一区二区在线观看| 91麻豆视频网站| 日韩高清国产一区在线| 久久亚洲免费视频| 99re这里只有精品视频首页| 亚洲宅男天堂在线观看无病毒| 日韩一区二区视频在线观看| 国产成人综合网站| 一区二区三区日韩| 欧美草草影院在线视频| 国产91精品免费| 五月婷婷激情综合网|