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

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

?? areamod.f90

?? CCSM Research Tools: Community Atmosphere Model (CAM)
?? F90
?? 第 1 頁 / 共 5 頁
字號:
! Method: ! ! Author: Mariana Vertenstein! !-----------------------------------------------------------------------! ------------------------ arguments ---------------------------------    integer , intent(in) :: nlat              !dimension: number of latitude points    integer , intent(in) :: nlon              !dimension: number of longitude points    integer , intent(in) :: numlon(nlat)      !number of grid cells per latitude strip    real(r8), intent(in) :: longxy(nlon,nlat) !longitude at center of grid cell    real(r8), intent(in) :: latixy(nlon,nlat) !latitude at center of grid cell    real(r8), intent(in) :: edgen             !northern edge of grid (degrees)    real(r8), intent(in) :: edgee             !eastern edge of grid (degrees)    real(r8), intent(in) :: edges             !southern edge of grid (degrees)    real(r8), intent(in) :: edgew             !western edge of grid (degrees)    real(r8), intent(out):: lats(nlat+1)      !grid cell latitude, southern edge (degrees)    real(r8), intent(out):: lonw(nlon+1,nlat) !grid cell longitude, western edge (degrees)! --------------------------------------------------------------------! ------------------- local variables -----------------------------    integer i,j             !indices    real(r8) dx             !cell width! --------------------------------------------------------------------! --------------------------------------------------------------------! Latitudes -- southern/northern edges for each latitude strip. ! For grids oriented South to North, the southern! and northern edges of latitude strip [j] are:!        southern = lats(j  )!        northern = lats(j+1)! For grids oriented North to South: the southern! and northern edges of latitude strip [j] are:!        northern = lats(j  )!        southern = lats(j+1)! In both cases, [lats] must be dimensioned lats(lat+1)! --------------------------------------------------------------------    if (nlat == 1) then       lats(1) = edges        lats(nlat+1) = edgen     else       if (latixy(1,2) > latixy(1,1)) then    !South to North grid          lats(1) = edges           lats(nlat+1) = edgen        else                                   !North to South grid          lats(1) = edgen           lats(nlat+1) = edges        end if    end if    do j = 2, nlat       lats(j) = (latixy(1,j-1) + latixy(1,j)) / 2.    end do! --------------------------------------------------------------------! Longitudes -- western edges. Longitudes for the western edge of the ! cells must increase continuously and span 360 degrees. Assume that! grid starts at Dateline with western edge on Dateline Western edges ! correspond to [longxy] (longitude at center of cell) and range from ! -180 to 180 with negative longitudes west of Greenwich. ! Partial grids that do not span 360 degrees are allowed so long as they! have the convention of Grid 1 with !      western edge of grid: >= -180 and < 180!      eastern edge of grid: > western edge  and <= 180! [lonw] must be dimensioned lonw(lon+1,lat) because each latitude! strip can have variable longitudinal resolution! --------------------------------------------------------------------! Western edge of first grid cell -- since grid starts with western! edge on Dateline, lonw(1,j)=-180. This is the same as [edgew].! Remaining grid cells. On a global grid lonw(numlon+1,j)=lonw(1,j)+360. ! This is the same as [edgee].  Set unused longitudes to non-valid number    do j = 1, nlat       dx = (edgee - edgew) / numlon(j)       lonw(1,j) = edgew       do i = 2, numlon(j)+1          lonw(i,j) = lonw(1,j) + (i-1)*dx       end do       do i = numlon(j)+2, nlon          lonw(i,j) = -999.       end do    end do    return  end subroutine celledge_regional!=======================================================================  subroutine celledge_global (nlat, nlon, numlon, longxy, latixy, &                              lats, lonw )!----------------------------------------------------------------------- ! ! Purpose: ! Southern and western edges of grid cells - global grid!! Method: ! ! Author: Mariana Vertenstein! !-----------------------------------------------------------------------! ------------------------ arguments ---------------------------------    integer , intent(in) :: nlat               !dimension: number of latitude points    integer , intent(in) :: nlon               !dimension: number of longitude points    integer , intent(in) :: numlon(nlat)       !number of grid cells per latitude strip    real(r8), intent(in) :: longxy(nlon,nlat)  !longitude at center of grid cell    real(r8), intent(in) :: latixy(nlon,nlat)  !latitude at center of grid cell    real(r8), intent(out):: lats(nlat+1)       !grid cell latitude, southern edge (degrees)    real(r8), intent(out):: lonw(nlon+1,nlat)  !grid cell longitude, western edge (degrees)! --------------------------------------------------------------------! ------------------- local variables -----------------------------    integer i,j             !indices    real(r8) dx             !cell width! --------------------------------------------------------------------! --------------------------------------------------------------------! Latitudes -- southern/northern edges for each latitude strip. ! For grids oriented South to North, the southern! and northern edges of latitude strip [j] are:!        southern = lats(j  )!        northern = lats(j+1)! For grids oriented North to South: the southern! and northern edges of latitude strip [j] are:!        northern = lats(j  )!        southern = lats(j+1)! In both cases, [lats] must be dimensioned lats(lat+1)! --------------------------------------------------------------------    do j = 1, nlat+1              !southern edges       if (j == 1) then           !south pole          lats(j) = -90.       else if (j == nlat+1) then !north pole          lats(j) = 90.       else                       !edge = average latitude          lats(j) = (latixy(1,j-1) + latixy(1,j)) / 2.       end if    end do! --------------------------------------------------------------------! Longitudes -- western edges. Longitudes for the western edge of the ! cells must increase continuously and span 360 degrees.! --------------------------------------------------------------------    if (longxy(1,1) >= 0.) then       do j = 1, nlat          dx = 360./(numlon(j))          do i = 1, numlon(j)+1             lonw(i,j) = -dx/2. + (i-1)*dx          end do          do i = numlon(j)+2, nlon             lonw(i,j) = -999.          end do       end do    else       write(6,*)'global non-regional grids currently only supported ', &            'for grids starting at greenwich and centered on Greenwich'       call endrun    endif    return  end subroutine celledge_global!=======================================================================  subroutine areaini_point (io      , jo          , nlon_i  , nlat_i  , numlon_i, &                            lon_i   , lon_i_offset, lat_i   , area_i  , mask_i  , &                            nlon_o  , nlat_o      , numlon_o, lon_o   , lat_o   , &                            area_o  , fland_o     , novr_i2o, iovr_i2o, jovr_i2o, &                            wovr_i2o)!----------------------------------------------------------------------- ! ! Purpose: ! area averaging initialization !! Method: ! This subroutine is used in conjunction with areaave.F for area-average! mapping of a field from one grid to another. !!    areaini_point  - initializes indices and weights for area-averaging from !                     input grid to output grid!    areamap_point  - called by areaini: finds indices and weights!    areaovr_onit   - called by areamap: finds if cells overlap and area of overlap! ! To map from one grid to another, must first call areaini to build! the indices and weights (iovr_i2o, jovr_i2o, wovr_i2o). Then must! call areaave to get new field on output grid.!! Not all grid cells on the input grid will be used in the area-averaging! of a field to the output grid. Only input grid cells with [mask_i] = 1! contribute to output grid cell average. If [mask_i] = 0, input grid cell ! does not contribute to output grid cell. This distinction is not usually! required for atm -> land mapping, because all cells on the atm grid have! data. But when going from land -> atm, only land grid cells have data.! Non-land grid cells on surface grid do not have data. So if output grid cell! overlaps with land and non-land cells (input grid), can only use land! grid cells when computing area-average. !! o Input and output grids can be ANY resolution BUT:!!   a. Grid orientation -- Grids can be oriented south to north!      (i.e. cell(lat+1) is north of cell(lat)) or from north to !      south (i.e. cell(lat+1) is south of cell(lat)). Both grids must be !      oriented from west to east, i.e., cell(lon+1) must be east of cell(lon)!!   b. Grid domain -- Grids do not have to be global. Both grids are defined!      by their north, east, south, and west edges (edge_i and edge_o in!      this order, i.e., edge_i(1) is north and edge_i(4) is west).!      !      For partial grids, northern and southern edges are any latitude!      between 90 (North Pole) and -90 (South Pole). Western and eastern!      edges are any longitude between -180 and 180, with longitudes !      west of Greenwich negative.!!      For global grids, northern and southern edges are 90 (North Pole) !      and -90 (South Pole). The grids do not have to start at the!      same longitude, i.e., one grid can start at Dateline and go east;!      the other grid can start at Greenwich and go east. Longitudes for!      the western edge of the cells must increase continuously and span!      360 degrees. Examples!!                              West edge    East edge!                            ---------------------------------------------------!      Dateline            :        -180 to 180        (negative W of Greenwich)!      Greenwich (centered):    0 - dx/2 to 360 - dx/2 !!   c. Both grids can have variable number of longitude points for each!      latitude strip. However, the western edge of the first point in each!      latitude must be the same for all latitudes. Likewise, for the!      eastern edge of the last point. That is, each latitude strip must span !      the same longitudes, but the number of points to do this can be different!!   d. One grid can be a sub-set (i.e., smaller domain) than the other grid.!      In this way, an atmospheric dataset for the entire globe can be!      used in a simulation for a region 30N to 50N and 130W to 70W -- the !      code will extract the appropriate data. The two grids do not have to!      be the same resolution. Area-averaging will work for full => partial!      grid but obviously will not work for partial => full grid.!! o Field values fld_i on an  input grid with dimensions nlon_i and nlat_i =>!   field values fld_o on an output grid with dimensions nlon_o and nlat_o as!!   fld_o(io,jo) =!   fld_i(i_ovr(io,jo,    1),j_ovr(io,jo,    1)) * w_ovr(io,jo,   1) !                             ... + ... +!   fld_i(i_ovr(io,jo,maxovr),j_ovr(io,jo,maxovr)) * w_ovr(io,jo,maxovr)!! o Error checks:!!   Overlap weights of input cells sum to 1 for each output cell.!   Global sum of dummy field is conserved for input => output area-average.! ! Author: Gordon Bonan! !-----------------------------------------------------------------------! ------------------------ arguments --------------------------------    integer , intent(in)    :: io                     !output grid longitude index    integer , intent(in)    :: jo                     !output grid latitude index     integer , intent(in)    :: nlon_i                 !input  grid: max number of longitude points    integer , intent(in)    :: nlat_i                 !input  grid: number of latitude  points    integer , intent(in)    :: numlon_i(nlat_i)       !input  grid: number lon points at each lat    real(r8), intent(in)    :: lon_i(nlon_i+1,nlat_i) !input grid: longitude, west edge (degrees)    real(r8), intent(in)    :: lon_i_offset(nlon_i+1,nlat_i) !input grid : cell lons, west edge (deg)    real(r8), intent(in)    :: lat_i(nlat_i+1)        !input grid: latitude, south edge (degrees)    real(r8), intent(in)    :: area_i(nlon_i,nlat_i)  !input grid: cell area    real(r8), intent(in)    :: mask_i(nlon_i,nlat_i)  !input  grid: mask (0, 1)    integer , intent(in)    :: nlon_o                 !output grid: max number of longitude points    integer , intent(in)    :: nlat_o                 !output grid: number of latitude  points    integer , intent(in)    :: numlon_o(nlat_o)       !output grid: number lon points at each lat    real(r8), intent(in)    :: lon_o(nlon_o+1,nlat_o) !output grid: longitude, west edge  (degrees)    real(r8), intent(in)    :: lat_o(nlat_o+1)        !output grid: latitude, south edge (degrees)    real(r8), intent(in)    :: area_o                 !output grid: cell area    real(r8), intent(in)    :: fland_o                !output grid: fraction that is land    integer , intent(out)   :: novr_i2o               !number of overlapping input cells    integer , intent(out)   :: iovr_i2o(maxovr)        !lon index of overlap input cell    integer , intent(out)   :: jovr_i2o(maxovr)        !lat index of overlap input cell    real(r8), intent(out)   :: wovr_i2o(maxovr)        !weight    of overlap input cell! --------------------------------------------------------------------! ------------------------ local variables ---------------------------    real(r8) :: relerr = 0.00001       !relative error for error checks    integer  :: ii                     !input  grid longitude loop index    integer  :: ji                     !input  grid latitude  loop index    integer  :: n                      !overlap index    real(r8) :: dx_i                   !input grid  longitudinal range    real(r8) :: dy_i                   !input grid  latitudinal  range    real(r8) :: dx_o                   !output grid longitudinal range    real(r8) :: dy_o                   !output grid latitudinal  range! --------------------------------------------------------------------! -----------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品你懂的| 一区二区三区四区精品在线视频| 一区二区三区免费看视频| 精品一区二区精品| 在线观看91精品国产入口| 国产欧美一区二区精品秋霞影院 | 亚洲精品一区二区三区四区高清 | 亚洲欧洲另类国产综合| 精品一区二区三区免费观看| 欧美性猛交xxxx乱大交退制版 | 欧美丰满少妇xxxbbb| 亚洲免费观看高清在线观看| 成人蜜臀av电影| 国产亚洲污的网站| 久久av老司机精品网站导航| 欧美人妖巨大在线| 亚洲一区二区三区四区在线观看 | 欧美mv日韩mv国产| 日韩精品一二三区| 欧美无砖砖区免费| 亚洲激情在线激情| 色八戒一区二区三区| 中文字幕一区二区三区乱码在线| 国产精品88av| 久久色在线观看| 国产一区二区在线免费观看| 欧美一区二区三区视频免费播放| 亚洲成人av福利| 欧美日韩亚洲另类| 亚洲第四色夜色| 欧美婷婷六月丁香综合色| 亚洲精品日韩专区silk| 色综合久久综合| 亚洲人成在线播放网站岛国| 99精品视频在线观看| 亚洲视频一区二区在线| 成人av午夜电影| 国产精品久久久久久久久动漫| 国产不卡视频在线播放| 欧美激情在线一区二区| 成人aa视频在线观看| 中文字幕一区二区三区不卡| 成人va在线观看| 亚洲另类春色校园小说| 欧美亚洲国产一卡| 日韩成人精品在线| 91精品国产综合久久蜜臀| 奇米一区二区三区| 2020国产精品自拍| 成人蜜臀av电影| 亚洲人成人一区二区在线观看| 91久久精品一区二区三区| 亚洲一二三四久久| 欧美日韩国产精品成人| 久久精品国产网站| 国产拍揄自揄精品视频麻豆| 97se亚洲国产综合自在线不卡| 一区二区三区视频在线观看| 欧美日韩黄视频| 久久99久久精品| 亚洲国产高清在线| 日本道色综合久久| 亚洲国产美女搞黄色| 在线不卡a资源高清| 国精产品一区一区三区mba视频 | 一区二区三国产精华液| 欧美日韩一区成人| 国内精品视频666| 国产精品剧情在线亚洲| 在线观看日韩电影| 麻豆91免费看| 国产精品国产三级国产有无不卡| 色婷婷狠狠综合| 免费一区二区视频| 国产精品婷婷午夜在线观看| 在线观看日韩国产| 麻豆精品视频在线观看免费| 欧美极品xxx| 欧美午夜片在线观看| 国内成+人亚洲+欧美+综合在线| 日韩理论在线观看| 91精选在线观看| 成人综合婷婷国产精品久久蜜臀 | 久久婷婷国产综合国色天香 | 国产精品亚洲专一区二区三区| 亚洲婷婷在线视频| 日韩欧美一区电影| 99re这里只有精品首页| 日韩—二三区免费观看av| 国产欧美日产一区| 欧美美女直播网站| 成人夜色视频网站在线观看| 午夜精品爽啪视频| 欧美激情一区二区三区在线| 欧美日韩精品一区二区三区蜜桃| 国产精品一区二区三区99| 秋霞成人午夜伦在线观看| 国产精品人成在线观看免费| 欧美精品一级二级三级| 国产99久久久国产精品潘金 | 亚洲国产精品成人综合| 欧美日韩精品福利| hitomi一区二区三区精品| 青青草视频一区| 亚洲视频一二区| 久久久另类综合| 7777精品伊人久久久大香线蕉完整版 | 国产精品免费久久久久| 日韩欧美电影在线| 91蜜桃在线观看| 国产主播一区二区| 五月婷婷激情综合网| 中文字幕一区日韩精品欧美| 久久综合色鬼综合色| 欧美日韩在线播放一区| av电影在线观看完整版一区二区 | 亚洲乱码一区二区三区在线观看| 26uuu亚洲综合色欧美| 欧美久久一二区| 色视频欧美一区二区三区| 国产精品996| 久久99九九99精品| 日本vs亚洲vs韩国一区三区二区| 亚洲综合男人的天堂| 国产精品传媒在线| 久久久综合视频| 日韩女优av电影| 欧美丰满高潮xxxx喷水动漫| 一本色道亚洲精品aⅴ| 成人国产视频在线观看| 国产高清精品久久久久| 麻豆91小视频| 蜜臀av一区二区| 婷婷一区二区三区| 艳妇臀荡乳欲伦亚洲一区| 一区二区中文字幕在线| 亚洲国产电影在线观看| 国产婷婷一区二区| 久久一区二区视频| 精品美女一区二区三区| 日韩欧美国产成人一区二区| 日韩一区二区在线观看视频| 欧美卡1卡2卡| 欧美精品在线视频| 欧美高清视频在线高清观看mv色露露十八 | 成人在线视频一区| 国产精品一区二区在线看| 国产一区二区精品久久99| 国模大尺度一区二区三区| 国内精品免费**视频| 国产在线不卡视频| 国产精品亚洲成人| 成人午夜免费视频| 97超碰欧美中文字幕| 色综合久久九月婷婷色综合| 色综合中文字幕国产 | 国产午夜精品久久久久久久| 国产亚洲成aⅴ人片在线观看 | 精品国产123| 久久麻豆一区二区| 亚洲国产精品av| 亚洲欧美色图小说| 亚洲国产精品久久人人爱蜜臀| 亚洲午夜久久久久| 热久久免费视频| 国产综合久久久久影院| 国产成人啪午夜精品网站男同| 丁香亚洲综合激情啪啪综合| 成人免费看片app下载| 91蜜桃免费观看视频| 在线观看91精品国产入口| 欧美精品自拍偷拍| 精品剧情在线观看| 日本一区二区视频在线| 亚洲欧美偷拍卡通变态| 亚洲大型综合色站| 青青草国产精品亚洲专区无| 国产一区二区精品久久91| 成人av在线看| 欧美日韩一区视频| 日韩欧美中文一区二区| 国产亚洲一区二区三区在线观看| 国产午夜亚洲精品理论片色戒 | 日韩一区二区高清| 国产色婷婷亚洲99精品小说| 国产精品久久久久久久裸模| 曰韩精品一区二区| 青青青伊人色综合久久| 国产老女人精品毛片久久| 99精品国产99久久久久久白柏| 欧美日韩aaaaaa| 久久久久久久性| 玉足女爽爽91| 激情国产一区二区| 91色乱码一区二区三区| 欧美一区二区三区免费视频| 久久久久88色偷偷免费| 夜夜嗨av一区二区三区四季av| 久久99精品久久久久| 92精品国产成人观看免费|