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

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

?? dyn_grid.f90

?? CCSM Research Tools: Community Atmosphere Model (CAM)
?? F90
字號:
#include <misc.h>module dyn_grid!----------------------------------------------------------------------- ! ! Purpose: Definition of dynamics computational grid.!! Method: Variables are private; interface routines used to extract!         information for use in user code.! ! Entry points:!!      get_block_bounds_d  get first and last indices in global !                          block ordering!      get_block_owner_d   get process "owning" given block!      get_block_col_cnt_d get number of columns in given block!      get_block_lvl_cnt_d get number of vertical levels in column!      get_block_levels_d  get vertical levels in column!!      get_block_coord_cnt_d   get number of blocks containing!                              data from a given vertical column!      get_block_coord_d   get global block indices and local columns !                          index for given coordinates!!      get_xxx_d           get global indices or coordinates for a single!                          column!      where xxx is!       lat                for global latitude index!       lon                for global longitude index!! Author: John Drake and Patrick Worley! !-----------------------------------------------------------------------   use precision   use pmgrid, only: plevcontains!========================================================================!   integer function get_block_coord_cnt_d(glon,glat)!----------------------------------------------------------------------- ! !                          ! Purpose: Return number of blocks contain data for the vertical column!          at location (glon,glat)! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: glon     ! global longitude index   integer, intent(in) :: glat     ! global latitude index!-----------------------------------------------------------------------!  latitude slice block   get_block_coord_cnt_d = 1   return   end function get_block_coord_cnt_d!!========================================================================!   subroutine get_block_coord_d(glon,glat,cnt,blockid,bcid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return global block index and local column index!          for column at location (glon,glat)! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: glon     ! global longitude index   integer, intent(in) :: glat     ! global latitude index   integer, intent(in) :: cnt      ! size of blockid and bcid arrays   integer, intent(out) :: blockid(cnt) ! block index   integer, intent(out) :: bcid(cnt)    ! column index within block!---------------------------Local workspace-----------------------------!    integer jb                     ! loop index!-----------------------------------------------------------------------!  latitude slice block   if (cnt < 1) then      write(6,*)'GET_BLOCK_COORD_D: arrays not large enough (', &                          cnt,' < ',1,' ) '      call endrun   else      blockid(1) = glat      bcid(1)    = glon      do jb=2,cnt         blockid(jb) = -1         bcid(jb)    = -1      enddo   endif!   return   end subroutine get_block_coord_d!!========================================================================!   Subroutine get_block_bounds_d(block_first,block_last)!----------------------------------------------------------------------- ! !                          ! Purpose: Return first and last indices used in global block ordering! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   use pmgrid, only: plat   implicit none!------------------------------Arguments--------------------------------   integer, intent(out) :: block_first  ! first (global) index used for blocks   integer, intent(out) :: block_last   ! last (global) index used for blocks!-----------------------------------------------------------------------!  latitude slice block   block_first = 1   block_last  = plat   return   end subroutine get_block_bounds_d!!========================================================================!   integer function get_block_col_cnt_d(blockid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return number of lon/lat coordinates in indicated block! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   use rgrid, only: nlon   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id!-----------------------------------------------------------------------!  latitude slice block   get_block_col_cnt_d = nlon(blockid)   return   end function get_block_col_cnt_d!!========================================================================!   integer function get_block_lvl_cnt_d(blockid,bcid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return number of levels in indicated column. If column!          includes surface fields, then it is defined to also!          include level 0.! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id   integer, intent(in) :: bcid    ! column index within block!-----------------------------------------------------------------------!  latitude slice block   get_block_lvl_cnt_d = plev + 1   return   end function get_block_lvl_cnt_d!!========================================================================!   subroutine get_block_levels_d(blockid, bcid, lvlsiz, levels)!----------------------------------------------------------------------- ! !                          ! Purpose: Return level indices in indicated column. If column!          includes surface fields, then it is defined to also!          include level 0.! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id   integer, intent(in) :: bcid    ! column index within block   integer, intent(in) :: lvlsiz   ! dimension of levels array   integer, intent(out) :: levels(lvlsiz) ! levels indices for block!---------------------------Local workspace-----------------------------!    integer k                      ! loop index!-----------------------------------------------------------------------!  latitude slice block   if (lvlsiz < plev + 1) then      write(6,*)'GET_BLOCK_LEVELS_D: levels array not large enough (', &                          lvlsiz,' < ',plev + 1,' ) '      call endrun   else      do k=0,plev         levels(k+1) = k      enddo      do k=plev+2,lvlsiz         levels(k) = -1      enddo   endif   return   end subroutine get_block_levels_d!!========================================================================!   integer function get_lon_d(blockid,bcid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return global longitude index for the column at location bcid!          in block blockid.! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id   integer, intent(in) :: bcid     ! block column index!-----------------------------------------------------------------------!  latitude slice block   get_lon_d = bcid   return   end function get_lon_d!!========================================================================!   integer function get_lat_d(blockid,bcid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return global latitude index for the column at location bcid!          in block blockid.! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id   integer, intent(in) :: bcid     ! block column index!-----------------------------------------------------------------------!  latitude slice block   get_lat_d = blockid   return   end function get_lat_d!!========================================================================!   integer function get_block_owner_d(blockid)!----------------------------------------------------------------------- ! !                          ! Purpose: Return id of processor that "owns" the indicated block! ! Method: ! ! Author: Patrick Worley! !-----------------------------------------------------------------------#if ( defined SPMD )   use spmd_dyn, only: proc#endif   implicit none!------------------------------Arguments--------------------------------   integer, intent(in) :: blockid  ! global block id!-----------------------------------------------------------------------!  latitude slice block#if (defined SPMD)   get_block_owner_d = proc(blockid)#else   get_block_owner_d = 0#endif   return   end function get_block_owner_d!#######################################################################end module dyn_grid

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美在线观看一区二区三区| 国产精品日产欧美久久久久| 欧美做爰猛烈大尺度电影无法无天| 成人午夜精品在线| 丰满少妇在线播放bd日韩电影| 国产九色sp调教91| 国产一区二区三区在线观看免费 | 欧美精品一区二区三区在线播放| 欧美日韩在线免费视频| 在线影视一区二区三区| 国产精品美女视频| 国产精品入口麻豆原神| 国产精品久久夜| 亚洲乱码中文字幕综合| 亚洲国产精品久久久男人的天堂| 亚洲大尺度视频在线观看| 天堂成人免费av电影一区| 六月婷婷色综合| 国产一区欧美一区| 成人av集中营| 欧美亚洲动漫制服丝袜| 正在播放一区二区| 精品久久99ma| 欧美国产日韩亚洲一区| 亚洲激情综合网| 日韩黄色免费电影| 韩国av一区二区| 99久久99久久精品国产片果冻| 91在线一区二区三区| 欧美日韩免费电影| 一区二区三区免费看视频| 亚洲大片一区二区三区| 久久草av在线| 99vv1com这只有精品| 欧美日韩国产一区| 亚洲精品一线二线三线无人区| 国产精品婷婷午夜在线观看| 亚洲午夜视频在线| 久久99精品久久久| 91香蕉视频mp4| 欧美妇女性影城| 国产婷婷精品av在线| 一区二区不卡在线播放| 日韩成人精品在线| 成人免费av网站| 欧美精品1区2区3区| 欧美国产日韩亚洲一区| 亚洲成人久久影院| 国产激情精品久久久第一区二区 | 91麻豆精品国产91久久久久久| 精品美女一区二区| 亚洲视频免费看| 捆绑紧缚一区二区三区视频| 99久久精品费精品国产一区二区| 欧美一区二区人人喊爽| 国产精品国产三级国产aⅴ中文 | 国产盗摄精品一区二区三区在线 | 久久久久久久一区| 97久久精品人人做人人爽50路| 欧美精品日韩综合在线| 国产精品久久久久久久久快鸭| 午夜私人影院久久久久| 成人国产电影网| 日韩欧美一级二级| 一区二区三区精品视频| 国产一区999| 555夜色666亚洲国产免| 自拍偷拍欧美激情| 国产精品一级黄| 欧美精品一二三四| 亚洲欧美日韩中文字幕一区二区三区| 精品在线免费视频| 91国内精品野花午夜精品| 久久久久久99精品| 麻豆国产一区二区| 欧美日韩你懂得| 亚洲人被黑人高潮完整版| 国产乱码一区二区三区| 日韩精品综合一本久道在线视频| 一区二区三区中文在线观看| 成人小视频免费在线观看| 精品免费视频.| 麻豆国产精品视频| 亚洲免费在线电影| 成人激情av网| 国产亚洲女人久久久久毛片| 久久精品99国产精品日本| 欧美福利一区二区| 亚洲一区二区三区激情| 91免费国产在线观看| 国产精品久久久久四虎| 粉嫩在线一区二区三区视频| 久久久久久综合| 国产一区二区三区四区五区入口 | 91亚洲午夜精品久久久久久| 日本一区二区成人| 国产精品 欧美精品| 久久蜜臀中文字幕| 国产一区二区日韩精品| 日韩精品一区二| 精品在线亚洲视频| 欧美精品一区二区三区蜜臀| 6080yy午夜一二三区久久| 亚洲美女视频在线观看| 99久久久精品免费观看国产蜜| 中文字幕不卡在线| 成人激情av网| 综合激情成人伊人| 91论坛在线播放| 亚洲男同性视频| 在线观看亚洲精品| 亚洲成年人网站在线观看| 欧美日韩国产色站一区二区三区| 亚洲国产日韩a在线播放性色| 在线精品视频一区二区| 亚洲第一精品在线| 欧美一区二区视频在线观看 | 蜜桃久久久久久| 久久中文字幕电影| 国产不卡一区视频| 国产精品久久久久久久岛一牛影视| 成人福利视频在线| 成人激情电影免费在线观看| 亚洲日本中文字幕区| 在线观看一区不卡| 免费成人av在线播放| 精品久久久久香蕉网| 成人av网站在线| 一区二区三区国产豹纹内裤在线| 欧美性猛交一区二区三区精品| 日韩高清一级片| 欧美精品一区视频| 91性感美女视频| 亚洲va欧美va人人爽| 精品国产乱码久久久久久免费| 粉嫩蜜臀av国产精品网站| 一区二区三区四区五区视频在线观看| 欧美中文字幕一区二区三区亚洲 | 欧美艳星brazzers| 美女视频一区二区| 国产精品美女久久久久久久| 欧美图区在线视频| 精品亚洲国内自在自线福利| 欧美国产日产图区| 欧美日韩国产精选| 国产成人精品一区二区三区四区 | 国产精品久久久久久妇女6080| 欧美视频一区二区三区在线观看| 另类综合日韩欧美亚洲| 一区视频在线播放| 欧美人与性动xxxx| 高清av一区二区| 日韩中文字幕区一区有砖一区| 久久久久久一级片| 欧美日韩亚洲综合在线| 国产成人亚洲综合a∨婷婷| 亚洲一区二区三区中文字幕| 精品久久久久一区二区国产| 色94色欧美sute亚洲线路一ni | 欧美高清www午色夜在线视频| 国产精品一区二区久激情瑜伽| 亚洲一二三区不卡| 国产欧美1区2区3区| 69堂亚洲精品首页| 99国内精品久久| 国产一区二区三区久久久| 99久久久国产精品免费蜜臀| 免费在线成人网| 一二三区精品福利视频| 国产视频一区二区在线| 欧美人牲a欧美精品| 91亚洲精品久久久蜜桃网站 | 成人国产精品视频| 美女网站色91| 亚洲成av人片一区二区梦乃| 国产精品无人区| 精品精品国产高清a毛片牛牛| 欧美亚洲一区三区| 91亚洲男人天堂| 国产成人免费av在线| 麻豆91小视频| 午夜精品在线看| 亚洲综合在线免费观看| 中文字幕av不卡| 2017欧美狠狠色| 日韩欧美成人一区| 欧美区视频在线观看| 日本韩国精品一区二区在线观看| 国产99久久久国产精品免费看| 麻豆精品蜜桃视频网站| 日韩精品成人一区二区在线| 91丝袜国产在线播放| 风间由美一区二区av101| 精品一区二区三区的国产在线播放| 亚洲国产综合91精品麻豆| 亚洲免费视频成人| 亚洲免费观看高清在线观看| 中文字幕一区日韩精品欧美| 日本一区二区电影| 中文幕一区二区三区久久蜜桃|