爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 6890|回复: 2

[作图] 求取异常值(时次非12的倍数)求助!!!

[复制链接]

新浪微博达人勋

发表于 2015-5-13 19:31:05 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
本帖最后由 aa22556688 于 2015-5-13 19:32 编辑

对全球海冰(时间:1870.01~2015.02dimsizes(time)=1742多出两个月),calcMonAnomTLL要求必须是12的倍数:
所以先利用calcMonAnomTLL求出前1740个时次的异常值;
然后利用dim_avg_n求出第1741,1742个时次的异常值;
最后把他们放到一个ssta(1741,:,:)数组里面。但是画出来的图有问题。

主要在于copy_VarMeta(st,ssta) 的所放的位置
copy_VarMeta(st,ssta)放在下面第一个位置的时候,
画ssta(1739:1741,::),图依次为下图:qian-1739正常),qian-1740有问题),qian-1741有问题)。

copy_VarMeta(st,ssta)放在下面第二个位置的时候,
画ssta(1739:1741,::),图依次为下图:hou-1739有问题),hou-1740正常),hou-1741正常)。

求高手指点,遇到这种时间不是12倍数的数据,例如2015年多出几个月,但想求其全部时次的异常值,应该如何求,NCL初学者,求指点!!!
latS             =  -89.5
latN             =  89.5
lonL             =  -179.5                 
lonR            =  179.5
yrStrt           = 1870
yrLast           = 2014
yrClimStrt      = 1961
yrClimLast     = 1990
dir    = "/cvfs01/disk1/wangq316/zc/d/"
fi1    = "HadISST_ice.nc"
fsst   = addfile(dir+fi1,"r")
st     = fsst->sic
ss     = fsst->sic(0,:,:)
lat    = fsst->latitude
lon    = fsst->longitude
time   = fsst->time
utc_date  = cd_calendar(time, 0)
YYYY       = tointeger(utc_date(:,0))  
istime      = ind(YYYY.ge.yrStrt.and.YYYY.le.yrLast)
cltime      = ind(YYYY.ge.yrClimStrt.and.YYYY.le.yrClimLast)
sst_selc   = st(istime,{latS:latN},{lonL:lonR})  
sst_clm    = st(cltime,{latS:latN},{lonL:lonR})
sstClm     = clmMonTLL(sst_clm)
ssta        = new((/dimsizes(time),dimsizes(lat),dimsizes(lon)/),"float",st@_FillValue)
copy_VarMeta(st,ssta)  ;;; 第一个位置
ssta(0:1739,:,:)     = calcMonAnomTLL(sst_selc(0:1739,:,:),sstClm)
ssta(1740,:,:)        = st(1740,:,:)-dim_avg_n(st(1092:1440:12,:,:),0)
ssta(1741,:,:)        = st(1741,:,:)-dim_avg_n(st(1093:1441:12,:,:),0)
copy_VarMeta(st,ssta)  ;;; 第二个位置

wks = gsn_open_wks("ps" ,"polar")  
;gsn_define_colormap(wks,"wgne15")            
res                                    = True                          
res@gsnPolar                     = "NH"   
res@cnFillOn                      = False          ; turns on the color
res@mpMinLatF                  = 40   
res@gsnSpreadColors          = True                ; use full colormap
res@gsnSpreadColorStart     = 2
res@gsnSpreadColorEnd      = -3        
plot = gsn_csm_contour_map_polar(wks,ssta(1739,:,:),res)








qian-1739.jpg
qian-1740.jpg
qian-1741.jpg
hou-1739.jpg
hou-1740.jpg
hou-1741.jpg
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2015-5-13 20:35:57 | 显示全部楼层
用缺测值补成12的倍数
密码修改失败请联系微信:mofangbao

新浪微博达人勋

 楼主| 发表于 2015-5-13 21:13:30 | 显示全部楼层
longlivehj 发表于 2015-5-13 20:35
用缺测值补成12的倍数

哦哦,对对这确实是一个不错的方法,非常感谢!
密码修改失败请联系微信:mofangbao
您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表